Extracting envelope using hilbert transform
이전 댓글 표시
Hi, I want to extract the envelope using the hilbert transformation. I got the discrete intensity signal I as an input. I used the following code
H = hilbert(I);
env = abs(H);
plot(I)
hold on
plot(env)
hold off
But the envelope seems to be the same as the original signal:

Is there anything I'm missing? According to other explanations this code should not give back the original signal.
Thanks!
댓글 수: 2
Walter Roberson
2022년 9월 30일
Would it be possible for you to attach your data for us to test with?
Lucas Weissmann
2022년 9월 30일
답변 (1개)
Walter Roberson
2022년 9월 30일
1 개 추천
According to the documentation, the real part of the return value is the same as the input value, and the hilbert transform is stored as the imaginary component.
When you take abs() of the return value, you are taking the square root of (the square of the input plus the square of the hilbert). If your input is a larger magnitude compared to the hilbert transform then the contribution of the hilbert portion might not be very noticable.
You should plot(I) and plot(imag(h))
카테고리
도움말 센터 및 File Exchange에서 Hilbert and Walsh-Hadamard Transforms에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!