实信号转换为复信号的原理讲解及MATLAB验证
创作时间:
作者:
@小白创作中心
实信号转换为复信号的原理讲解及MATLAB验证
引用
CSDN
1.
https://blog.csdn.net/NIKANG12/article/details/145751398
在信号处理中,将实信号转换为复信号(解析信号)是提取相位、包络及抑制负频率分量的重要步骤。常用的方法有两种:希尔伯特变换、正交混频法。本文详细介绍了希尔伯特变换和正交混频法的原理,并结合Matlab代码进行效果演示。
一、方法原理与对比
1. 希尔伯特变换法
原理:希尔伯特变换通过将实信号的负频率分量相位偏移±90°,构造解析信号(复信号),其虚部为实信号的希尔伯特变换结果。解析信号的频谱仅保留正频率分量。
公式:
- 实信号x ( t ) x(t)x(t)的解析信号z ( t ) = x ( t ) + j ⋅ H [ x ( t ) ] z(t) = x(t) + j⋅H[x(t)]z(t)=x(t)+j⋅H[x(t)],其中H [ ⋅ ] H[⋅]H[⋅]表示希尔伯特变换。
- 频域操作:将实信号频谱的负频率部分置零,正频率部分幅度加倍。
适用场景:适合离线分析,如包络提取、瞬时频率计算。
2. 正交混频法(正交下变频)
原理:将实信号与复指数载波e − j 2 π f c t e^{-j 2 \pi fc t}e−j2πfct相乘,通过低通滤波保留基带信号,得到复信号的实部(I路)和虚部(Q路)。
公式:
- 混频后信号:z ( t ) = x ( t ) ⋅ e − j 2 π f c t z(t) = x(t)⋅e^{-j 2 \pi fc t}z(t)=x(t)⋅e−j2πfct,滤波后保留低频分量。
- 等效于将频谱从载频f c fcfc搬移到基带,消除负频率。
适用场景:适合通信系统实时处理,如软件定义无线电(SDR)。
二、Matlab实现与效果演示
1. 希尔伯特变换法
代码示例:
fs = 1000;
t = 0:1/fs:1-1/fs;
x = 0.5*cos(2*pi*5*t) .* cos(2*pi*50*t); % 调制信号(实信号)
z_hilbert = hilbert(x); % 希尔伯特变换得到复信号
% 绘图
figure();
subplot(3,1,1);
plot(t, x);
title('实信号时域波形');
subplot(3,1,2);
plot(t, real(z_hilbert));
title('复信号实部(原信号)');
subplot(3,1,3);
plot(t, imag(z_hilbert));
title('复信号虚部(希尔伯特变换)');
效果:
- 复信号的实部与原信号一致,虚部为相位偏移90°的结果(余弦→正弦)。
- 频谱分析显示单边谱(仅正频率):
f = (-fs/2:fs/length(x):fs/2-1);
Z_hilbert = fftshift(fft(z_hilbert));
Z_x = fftshift(fft(x));
figure();
subplot(2,1,1);
plot(f, abs(Z_x));
title('原始实信号频谱(双边)');
subplot(2,1,2);
plot(f, abs(Z_hilbert));
title('希尔伯特法频谱(单边)');
2. 正交混频法
代码示例:
fs = 1000;
t = 0:1/fs:1-1/fs;
fc = 50; % 载波频率
t = 0:1/fs:1;
x = (1 + 0.5*cos(2*pi*5*t)) .* cos(2*pi*fc*t + 0.5*sin(2*pi*10*t)); % 调制信号
local_osc = exp(-1j*2*pi*fc*t); % 本地复振荡器
z_mix = x .* local_osc; % 混频
% 低通滤波(保留基带)
[b, a] = butter(6, 10/(fs/2)); % 截止频率10Hz
z_mix_filtered = filtfilt(b, a, z_mix);
% 绘图
figure();
subplot(2,1,1);
plot(t, real(z_mix_filtered));
title('复信号实部(I路)');
subplot(2,1,2);
plot(t, imag(z_mix_filtered));
title('复信号虚部(Q路)');
效果:
- I/Q两路信号分别对应复信号的实部和虚部,频谱搬移到基带(中心频率0Hz):
Z_mix_filtered = fftshift(fft(z_mix_filtered));
Z_x = fftshift(fft(x));
figure();
subplot(2,1,1);
plot(f, abs(Z_x));
title('原始实信号频谱(双边)');
subplot(2,1,2);
plot(f, abs(Z_mix_filtered));
title('混频法频谱(单边)');
三、方法对比与选择建议
特性 | 希尔伯特变换法 | 正交混频法 |
|---|---|---|
计算复杂度 | 高(需FFT操作) | 低(实时性好) |
频谱处理 | 直接抑制负频率 | 需滤波抑制镜像频率 |
适用场景 | 离线分析(如故障诊断) | 实时系统(如通信接收机) |
四、应用案例:包络提取
希尔伯特法提取包络:
envelope = abs(z_hilbert); % 复信号模值为包络
figure();
plot(t, x, 'b');
hold on;
plot(t, envelope, 'r--');
title('包络提取对比');
legend('原信号', '包络');
效果:红色虚线为提取的包络,与理论包络1 + 0.5 cos ( 2 π 5 t ) 1+0.5\cos (2 \pi 5t)1+0.5cos(2π5t)一致。
五、结论
两种方法均能有效实现实信号到复信号的转换:
- 希尔伯特变换法适合需要精确频谱分析的场景;
- 正交混频法更适合实时系统及通信应用。
通过Matlab代码实践,可直观理解复信号构造原理及工程意义。
热门推荐
针清后毛孔会变大吗?一文读懂针清护理全攻略
在邢台该如何选择种植牙?
心绞痛的症状、检查方法与治疗方法全解析
二氧化氯在中水处理中的应用
内行人建议买电饭煲看什么?电饭煲选购攻略
寒梅傲雪 独绽小寒,古诗词里的梅花,傲然绽放,展现冬日的风采
快速摆脱感冒!这五个方法可以让你瞬间恢复,别再等了!
中年男性的「外貌溢价」:长得越帅,收入越高?
2025汽车出游保养指南:行前必检项目、五油三水、轮胎胎压全攻略
2024高考河南文科本科上线率27%,省内院校投档线位次近4年趋势
如何通过阿尔法波(α波)让大脑迅速「休息」,改善失眠的绝招
1938年,东北抗联五位师级以上干部叛逃始末
基于模糊控制与PID控制技术的船舶航向控制方案
冰箱选购八大原则:从容量到能效全方位解析
EMC电磁兼容测试中的近场与远场概念详解
匹兹堡睡眠量表计算方法
越南战争期间,美国士兵为何会怕越南女兵?
雪橇运动的起源与文化传承
“吃亏是福”:人生智慧还是话语陷阱?
家庭氧疗的二三事
道家风水中的文昌位布置指南
家庭照顾者之间的沟通方法
你想知道吗?都市传说的真相与谜团
如何用石膏粉修补墙面裂缝?一文详解各类裂缝修补方法
语言模型与人类反馈的深度融合:Chain of Hindsight技术
掌握有效道歉技巧,修复关系从这一刻开始
炒股的最佳时机是什么?这种时机有哪些投资策略和风险?
把熟人推荐选择权还给用户
什么是股票市场的分类方式?这些分类方式对投资者有哪些指导意义?
恐怖找不同游戏教案:探索游戏中的恐怖元素与心理影响