Extracting multiple envelopes from a signal

2 visualizaciones (últimos 30 días)
First Last
First Last el 11 de Ag. de 2017
Editada: Cedric el 20 de Oct. de 2017
I have a signal which when observed carefully shows a three individual sinusoidal signals (figures attached). I want these three individual signals to be extracted in terms of amplitude, frequency and phase. Please help!
  2 comentarios
John BG
John BG el 11 de Ag. de 2017
would you please be so kind to supply the signal?
in a .mat file
thanks in advance, awaiting answer
First Last
First Last el 11 de Ag. de 2017
Sure! Here is the .mat file. Thanks!

Iniciar sesión para comentar.

Respuesta aceptada

Cedric
Cedric el 17 de Oct. de 2017
Quick cheap trick gets 2/3. Was going to bed, no time for more but that could be a starting point.
function main
load( 'MultipleSignalEnvelope', 'ITDc0' ) ;
plot( ITDc0, 'b.' ) ;
grid on ;
hold on ;
t = 1 : numel( ITDc0 ) ;
A = 1.2 ;
P = fminsearch( @objective, zeros(3,1) ) ;
plot( A*sin((t+P)/360*2*pi).' ) ;
function mindif = objective( P )
mindif = sum( min( abs( ITDc0-A*sin((t+P)./360*2*pi )))) ;
end
end
%
  9 comentarios
First Last
First Last el 20 de Oct. de 2017
Do you think we can use the same logic for Amplitude too?
Cedric
Cedric el 20 de Oct. de 2017
Editada: Cedric el 20 de Oct. de 2017
You will have to try. Define P as a vector with 6 components instead of 3, the first three being amplitudes and the next three being "phases". In the objective function, replace A with P(1:3) and P with P(4:6). Also, update the initial conditions. Instead of zeros(3,1), try to start e.g.. with three unit amplitudes and three null phases: [ones(3,1);zeros(3,1)].
Note that you could use FMINCON and define constraints, e.g. upper and lower bounds for the amplitude and phases.
Also note that you'd better try to see if you could get help from someone with experience in digital signal processing, because this approach is just a quick trick. If you reword your question in a new thread and nobody answers, you may be able to hire someone for not that much on sites that market freelancers.

Iniciar sesión para comentar.

Más respuestas (1)

Image Analyst
Image Analyst el 11 de Ag. de 2017
Editada: Image Analyst el 11 de Ag. de 2017
Look at the fft.
  10 comentarios
Image Analyst
Image Analyst el 17 de Oct. de 2017
Well that's a change from what you said before. Too bad, that would have been so easy. I don't know how to solve it without spending way more time on it than I allow myself to spend on questions here, so . . . good luck.
First Last
First Last el 17 de Oct. de 2017
I am sorry, I miss understood your earlier comments. It should be autonomous.

Iniciar sesión para comentar.

Community Treasure Hunt

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

Start Hunting!

Translated by