how to filter data by rate of change?

I am trying to filter signal, where data of certain rate oif change is filtered out. I am not able to achieve my goals, for example with lowpass (tried for example lowpass(yTemp, 10, Fs2). below is plot with original signal to be filtered (blue) and with red, I have hand drawn what how I would like to filtered signal to behave. Of course it doesent need to be precisely like drawn, its just for example, to illustrate the point.
data is in attachment (x,y,Fs).
all help is appreciated

 Respuesta aceptada

Mathieu NOE
Mathieu NOE el 6 de Feb. de 2025
Editada: Mathieu NOE el 6 de Feb. de 2025
hello
I was thinking that I could use the "baseline" correction approach, then apply a scale factor on the baseline compensated signal , add some smoothing then put back the base
and this is the result so far :
load('vars.mat')
% option # 1 : obtain the lower envelope data
N = 200;
[up1,down1] = envelope(yTemp,N,'peak');
% now apply smoothing on baseline corrected data and put back the baseline in
yc = yTemp - down1;
yscale_factor = 0.25; % apply only a fraction of yc (baseline corrected signal)
yTemps = smoothdata(yscale_factor*yc,'gaussian',2*N) + down1;
figure
plot(x,yTemp,x,down1,'--',x,yTemps,'linewidth',2)
legend('signal','lower envelope','smoothed');

5 comentarios

this is another alternative using the attached function :
% option # 2 : Baseline correction
[Base, yc]=baseline(yTemp(:));
figure
subplot(2,1,1),plot(x,Base,'--',x,yTemp,'linewidth',2)
subplot(2,1,2),plot(x,yc,'linewidth',2)
% now apply smoothing on baseline corrected data and put back the baseline in
N = 300;
yscale_factor = 0.25; % apply only a fraction of yc (baseline corrected signal)
yTemps = smoothdata(yscale_factor*yc,'gaussian',N) + Base;
figure
plot(x,yTemp,x,yTemps,'linewidth',2)
legend('signal','smoothed');
Sven Larsen
Sven Larsen el 6 de Feb. de 2025
Thank you so much, this was precisewly what I was looking for. Both solutions are very good and it may be, I need to use lower envelope instead of smoothed.
Again, thanks! Will learn envelope and smoothdata, so I can use these also in future
Mathieu NOE
Mathieu NOE el 6 de Feb. de 2025
my pleasure ! glad I could help
what is peak_stripping in your line:
[Baseline, stripping]=peak_stripping(S,n);
Mathieu NOE
Mathieu NOE el 7 de Feb. de 2025
sorry, forgot to give you that function too
see attached :)

Iniciar sesión para comentar.

Más respuestas (0)

Productos

Preguntada:

el 6 de Feb. de 2025

Comentada:

el 7 de Feb. de 2025

Community Treasure Hunt

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

Start Hunting!

Translated by