Verwenden Sie Matlab, um dem Signal Rauschen mit einem bestimmten Signal-Rausch-Verhältnis hinzuzufügen

In MATLAB können Sie awgndie Funktion verwenden, um dem Signal Gaußsches weißes Rauschen hinzuzufügen, um dem Matrixsignal Rauschen mit einem bestimmten Signal-Rausch-Verhältnis hinzuzufügen, und plotdie Funktion verwenden, um das Signal vor und nach dem Hinzufügen von Rauschen zu visualisieren. Hier ist Beispielcode:

% 创建原始信号
Fs = 1000;  % 采样率
t = 0:1/Fs:1-1/Fs;  % 时间轴
signal = sin(2*pi*10*t);  % 频率为10Hz的正弦信号

% 添加噪声前的信号绘图
subplot(1, 2, 1)
plot(t, signal)
title('Original Signal')

% 添加噪声
snr_db = 10;  % 信噪比为10dB
noisy_signal = awgn(signal, snr_db, 'measured');

% 添加噪声后的信号绘图
subplot(1, 2, 2)
plot(t, noisy_signal)
title(['Noisy Signal (SNR = ' num2str(snr_db) 'dB)'])

sgtitle('Signal with Noise')

% 设置subplot间距
sgtitle('Signal with Noise')

% 设置subplot间距
subplotSpacing = 0.05;
subplotPosition = get(gcf, 'DefaultAxesPosition');
subplotPosition(3) = subplotPosition(3) + subplotSpacing;
set(gcf, 'DefaultAxesPosition', subplotPosition)

% 调整窗口大小以适应subplot间距
set(gcf, 'Position', get(0, 'Screensize'))

% 等待按键继续执行下一条命令
pause

Führen Sie den obigen Code aus und Sie sehen ein Diagramm, das das Originalsignal und das Signal nach dem Hinzufügen von Rauschen mit einem Signal-Rausch-Verhältnis von 10 dB zeigt. Sie können den SNR-Wert nach Bedarf ändern, um den Effekt bei unterschiedlichem SNR zu beobachten.

Supongo que te gusta

Origin blog.csdn.net/weixin_44463965/article/details/131735287
Recomendado
Clasificación