필터 지우기
필터 지우기

Methods to make(fit) the samples of two signals for averaging them

조회 수: 10 (최근 30일)
Gova ReDDy
Gova ReDDy 2014년 1월 14일
댓글: Image Analyst 2014년 1월 16일
Hello,
I want to get the average of two signals but the number of samples(values) of the two are not equal.One method to make this possible is by using interpolation and here is the demo by Image Analyst for this but the values of the resultant(interpolated)signal are not equal to that of the real signal values.
Can someone explain if there are other methods available to fit the number of samples between two signals.
Thanks.
  댓글 수: 6
Amit
Amit 2014년 1월 16일
I think what he want is somehow get both data to be of same size, so he can average it. and yeah, the interpolation used in his code is no better than using y=x.
Image Analyst
Image Analyst 2014년 1월 16일
I gave him code to make them the same size in http://www.mathworks.com/matlabcentral/answers/111930#answer_120465 and then to average them. He accepted but then he changed it to the code above, which broke it.

댓글을 달려면 로그인하십시오.

답변 (1개)

Amit
Amit 2014년 1월 16일
Your s1 and s2 are 1x363 and 1x411 matrixes. Now what you're interpolating is essentially interp1(s1,s1,_blah_) which is simply a straight line. Moreover you're just plotting plot(s1) etc, which is essentially plot(1:length(s1),s1) etc. The problem here is that the number of elements in your matrixes are different and the plot will look like this.
Is there a 'x' values corresponding to s1 and s2?
  댓글 수: 2
Amit
Amit 2014년 1월 16일
편집: Amit 2014년 1월 16일
Okay, in that case I think you can do something like this (if I understand correctly).
In case length(s1)<length(s2), as in your case
s1_x = linspace(1,length(s1),length(s2));
s2_int = interp1(s2_x,s2,1:length(s1));
plot(s1);hold on;plot(s2_x,s2,,'-g');plot(s2_int,'-r');
%%For averaging
avg_s1s2 = mean([s1;s2_int]);
You dont have to interpolate s1 here.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Multirate Signal Processing에 대해 자세히 알아보기

태그

제품

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by