يعني تصفية في MATLAB دون الحلقات أو معالجة الإشارات الأدوات

StackOverflow https://stackoverflow.com/questions/2569012

  •  24-09-2019
  •  | 
  •  

سؤال

أنا بحاجة لتنفيذ يعني تصفية على مجموعة من البيانات ، ولكن أنا لم يكن لديك الوصول إلى معالجة الإشارات الأدوات.هل هناك طريقة للقيام بذلك دون استخدام حلقة for?هنا هو رمز لدي العامل:

x=0:.1:10*pi;     
noise=0.5*(rand(1,length(x))-0.5);
y=sin(x)+noise;      %generate noisy signal
a=10;                %specify moving window size
my=zeros(1,length(y)-a);
for n=a/2+1:length(y)-a/2
  my(n-a/2)=mean(y(n-a/2:n+a/2));       %calculate mean for each window
end
mx=x(a/2+1:end-a/2);                    %truncate x array to match

plot(x,y)
hold on
plot(mx,my,'r')

تحرير:

بعد تنفيذ ميرف الحل المدمج في تصفية طريقة التخلف الإشارة الأصلية.هل هناك طريقة للتغلب على هذا ؟ alt text

هل كانت مفيدة؟

المحلول

استخدام المدمج في فلتر وظيفة

%# generate noisy signal
x = sin(0:.1:10*pi);
x = x + 0.5*(rand(1,length(x))-0.5); 

%# moving average smoothing
window = 15;
h = ones(window,1)/window;
y = filter(h, 1, x);

%# plot
subplot(211), plot(x), ylim([-1 1]), title('noisy')
subplot(212), plot(y), ylim([-1 1]), title('filtered')

حل مشكلة تأخر ، في محاولة شيء من هذا القبيل:

s = ceil(window/2);
yy = y(s:end);
n = length(x);
plot(1:n, x, 'b'), hold on, plot(1:n-s+1, yy,'r'), hold off
legend({'noisy' 'filtered'})

alt text

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top