hilbert和低通滤波求包络

希尔伯特

最重要的就两句
z=hilbert(x) am2=abs(z)
首先,不是第一句完成了希尔伯特变换就是包络了,它只是完成了希尔伯特变换,相位偏移了90度,而且要使用abs()而不是imag(),下面代码运行就可以得到对应的图,但是前提是要把数据包添加到matlab的文件夹里
链接:http://pan.baidu.com/s/1kU9DuAF 密码:gblw
,并且下列代码的m文件要和数据包在同一路径下

clc;
clear;
patterns = [];
targets = [];
Fs=50e6;%采样率
%Abstract feature
for i=1:1      
    floder = ['IQ_sincos_f2.395000e+09_s5.000000e+07_Tx' num2str(i) '\data'];
    fea_train =[];    
       for j=1:1
        path = [floder '\IQ_sincos_f2.395000e+09_s5.000000e+07_Tx' num2str(i) '_' num2str(j) '.pcm'];
        fileId = fopen(path,'r');
        x = fread(fileId,500,'float32');  
        lengthofsignal=length(x);
        T=1/Fs;
        t=(0:lengthofsignal-1)*T; %对应的时间序列
        %绘制原始图像
        figure();
        subplot(211)
        plot(t,x,'b');
        grid on
        xlabel('时间');
        ylabel('幅度')
        hold on
        z=hilbert(x);
        am=abs(z);
        plot(t,am,'r')
        title('希尔伯特变换后使用abs函数');
        legend('蓝色是原始波形','红色是abs求出的包络')
        
        %提取信号包络并画图
       subplot(212)
        plot(t,x,'b');
        grid on
        xlabel('时间');
        ylabel('幅度')
        hold on
        %提取信号包络并画图,法二
        z=hilbert(x);
        yi = imag(z); 
        plot(t,yi,'g')
        title('希尔伯特变换后使用imag函数'); 
        legend('绿色是imag求出的')
       
       end
    
end
image.png

其次,使用希尔伯特可以得到包络,但是得到包络的方法不止一只,还可以使用低通滤波,主程序如下:

clc;
clear;
patterns = [];
targets = [];
Fs=12000;%采样率
%Abstract feature
for i=1:1     %只用了一个来测试,如果要用多个改掉后面的1
    floder = ['IQ_sincos_f2.395000e+09_s5.000000e+07_Tx' num2str(i) '\data'];
    fea_train =[];    
       for j=1:1
        path = [floder '\IQ_sincos_f2.395000e+09_s5.000000e+07_Tx' num2str(i) '_' num2str(j) '.pcm'];
        fileId = fopen(path,'r');
        x = fread(fileId,10240,'float32'); 
        lengthofsignal=length(x);
        T=1/Fs;
        t=(0:lengthofsignal-1)*T; %对应的时间序列
        %绘制原始图像
        figure(1);
        plot(t,x);
        grid on
        title(['TX',num2str(i),'原始图像并采用希尔伯特求包络']);
        xlabel('Time');
        ylabel('Amp')
        hold on
        z=hilbert(x);%做希尔伯特变换
        %am1=sqrt(abs(x).^2+abs(z).^2);%使用此种函数处理后的包络没有用abs的好
        am2=abs(z);
        %plot(t,am1,'r')
        plot(t,am2,'g')
        axis([0 0.25 -1 1.5]);  % 设置坐标轴在指定的区间
        
        figure(2)
        plot(t,x);
        hold on
        re=envelope(x,Fs)
        plot(t,re,'r--');title('低通滤波求包络');
        axis([0 0.25 -1 1.5]);  % 设置坐标轴在指定的区间
        
        figure(3)
        plot(t,am2,'g')
        hold on
        plot(t,re,'r--')
        title('对比')
        legend('绿色是希尔伯特求出的包络','红色是低通滤波求出的包络')%文本标注
        
       end
    
end

其中调用的envelope.m文件

function y=envelope(signal,Fs)
%Envelope Detection based on Low pass filter and then FFT
[a,b]=butter(2,0.1);%butterworth Filter of 2 poles and Wn=0.1
%sig_abs=abs(signal); % Can be used instead of squaring, then filtering and
%then taking square root
sig_sq=2*signal.*signal;% squaring for rectifing
%gain of 2 for maintianing the same energy in the output
y_sq = filter(a,b,sig_sq); %applying LPF
y=sqrt(y_sq);%taking Square root
%advantages of taking square and then Square root rather than abs, brings
%out some hidden information more efficiently
N=3000;T=N/Fs;
sig_f=abs(fft(y(1:N)',N));

sig_n=sig_f/(norm(sig_f));

freq_s=(0:N-1)/T;
采用希尔伯特求包络.png
采用低通滤波求包络.png
两条包络做对比.png

从图上可以看出,采用低通滤波的包络更为集中,更稳定一些

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容