Necesito implementar un filtro medio en un conjunto de datos, pero no tengo acceso a la caja de herramientas de procesamiento de señales. ¿Hay alguna manera de hacerlo sin usar un bucle for? Aquí está el código que tengo trabajo:Filtro medio en MATLAB sin bucles o caja de herramientas de procesamiento de señales
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')
EDIT:
Después de implementar la solución de Merv, la incorporada en el método de filtro de retardos de la señal original. ¿Hay alguna forma de evitar esto?