matlab中给信号加噪声的方法.docx

上传人:小飞机 文档编号:3161194 上传时间:2023-03-11 格式:DOCX 页数:3 大小:37.42KB
返回 下载 相关 举报
matlab中给信号加噪声的方法.docx_第1页
第1页 / 共3页
matlab中给信号加噪声的方法.docx_第2页
第2页 / 共3页
matlab中给信号加噪声的方法.docx_第3页
第3页 / 共3页
亲,该文档总共3页,全部预览完了,如果喜欢就下载吧!
资源描述

《matlab中给信号加噪声的方法.docx》由会员分享,可在线阅读,更多相关《matlab中给信号加噪声的方法.docx(3页珍藏版)》请在三一办公上搜索。

1、matlab中给信号加噪声的方法在信号处理中经常需要把噪声叠加到信号上去,在叠加噪声时往往需要满足一定的信噪比,这样产生二个问题,其一噪声是否按指定的信噪比叠加,其二怎么样检验带噪信号中信噪比满足指定的信噪比。 在MATLAB中可以用randn产生均值为0方差为1的正态分布白噪声,但在任意长度下x=randn(1,N),x不一定是均值为0方差为1,这样对后续的计算会产生影响。在这里提供3个函数用于按一定的信噪比把噪声叠加到信号上去,同时可检验带噪信号中信噪比。 1. 把白噪声叠加到信号上去: function Y,NOISE = noisegen(X,SNR) % noisegen add w

2、hite Gaussian noise to a signal. % Y, NOISE = NOISEGEN(X,SNR) adds white Gaussian NOISE to X. The SNR is in dB. NOISE=randn(size(X); NOISE=NOISE-mean(NOISE); signal_power = 1/length(X)*sum(X.*X); noise_variance = signal_power / ( 10(SNR/10) ); NOISE=sqrt(noise_variance)/std(NOISE)*NOISE; Y=X+NOISE;

3、其中X是纯信号,SNR是要求的信噪比,Y是带噪信号,NOISE是叠加在信号上的噪声。 2. 把指定的噪声叠加到信号上去 有标准噪声库NOISEX-92,其中带有白噪声、办公室噪声、工厂噪声、汽车噪声、坦克噪声等等,在信号处理中往往需要把库中的噪声叠加到信号中去,而噪声的采样频率与纯信号的采样频率往往不一致,需要采样频率的校准。 function Y,NOISE = add_noisem(X,filepath_name,SNR,fs) % add_noisem add determinated noise to a signal. % X is signal, and its sample fr

4、equency is fs; % filepath_name is NOISEs path and name, and the SNR is signal to noise ratio in dB. wavin,fs1,nbits=wavread(filepath_name); if fs1=fs wavin1=resample(wavin,fs,fs1); end nx=size(X,1); NOISE=wavin1(1:nx); NOISE=NOISE-mean(NOISE); signal_power = 1/nx*sum(X.*X); noise_variance = signal_p

5、ower / ( 10(SNR/10) ); NOISE=sqrt(noise_variance)/std(NOISE)*NOISE; Y=X+NOISE; 其中X是纯信号,filepath_name是指定噪声文件的路径和文件名,SNR是要求的信噪比,fs是信号X的采样频率,Y是带噪信号,NOISE是叠加在信号上的噪声。 3. 检验带噪信号的信噪比 信噪比的定义为 信号能量 (纯信号)2 SNR=-=- 噪声能量 (带噪信号-纯信号)2 function snr=SNR_singlech(I,In) % 计算信噪比函数 % I :original signal % In:noisy signa

6、l(ie. original signal + noise signal) snr=0; Ps=sum(sum(I-mean(mean(I).2);%signal power Pn=sum(sum(I-In).2); %noise power snr=10*log10(Ps/Pn); 其中I是纯信号,In是带噪信号,snr是信噪比 以下给出调用上函数的例子可作参考: 例一 clear all; clc; close all; filename,pathname=uigetfile(*.wav,请选择语音文件:); X,fs=wavread(pathname filename); Y,NOISE

7、 = noisegen(X,10); subplot 311; plot(X); subplot 312; plot(NOISE); subplot 313; plot(Y); mn=mean(NOISE) snr=SNR_singlech(X,Y) 例二 clear all; clc; close all; filename,pathname=uigetfile(*.wav,请选择语音文件:); filename1,pathname1=uigetfile(*.wav,请选择噪声文件:); filepath_name=pathname1 filename1; X,fs=wavread(pathname filename); Y,NOISE = add_noisem(X,filepath_name,10,fs); subplot 311; plot(X); subplot 312; plot(NOISE); subplot 313; plot(Y); mn=mean(NOISE) snr=SNR_singlech(X,Y)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号