一、MATLAB中自带的高斯白噪声的两个函数

MATLAB中产生高斯白噪声非常方便,可以直接应用两个函数,一个是WGN,另一个是AWGN。WGN用于产生高斯白噪声,AWGN则用于在某一信号中加入高斯白噪声。

1. WGN:产生高斯白噪声

y = wgn(m,n,p) 产生一个m行n列的高斯白噪声的矩阵,p以dBW为单位指定输出噪声的强度。

y = wgn(m,n,p,imp) 以欧姆(Ohm)为单位指定负载阻抗。

y = wgn(m,n,p,imp,state) 重置RANDN的状态。

在数值变量后还可附加一些标志性参数:

y = wgn(…,POWERTYPE) 指定p的单位。POWERTYPE可以是'dBW',

'dBm'或'linear'。线性强度(linear power)以瓦特(Watt)为单位。

y = wgn(…,OUTPUTTYPE)

指定输出类型。OUTPUTTYPE可以是'real'或'complex'。

2. AWGN:在某一信号中加入高斯白噪声

y = awgn(x,SNR)

在信号x中加入高斯白噪声。信噪比SNR以dB为单位。x的强度假定为0dBW。如果x是复数,就加入复噪声。

y = awgn(x,SNR,SIGPOWER)

如果SIGPOWER是数值,则其代表以dBW为单位的信号强度;如果SIGPOWER为'measured',则函数将在加入噪声之前测定信号强度。

y = awgn(x,SNR,SIGPOWER,STATE) 重置RANDN的状态。

y = awgn(…,POWERTYPE)

指定SNR和SIGPOWER的单位。POWERTYPE可以是'dB'或'linear'。如果POWERTYPE是'dB',那么SNR以dB为单位,而SIGPOWER以dBW为单位。如果POWERTYPE是'linear',那么SNR作为比值来度量,而SIGPOWER以瓦特为单位。

二、通过相关概念自编函数实现任意噪声的叠加及信噪比的计算

在信号处理中经常需要把噪声叠加到信号上去,在叠加噪声时往往需要满足一定的信噪比,这样产生二个问题,其一噪声是否按指定的信噪比叠加,其二怎么样检验带噪信号中信噪比满足指定的信噪比。

在MATLAB中可以用randn产生均值为0方差为1的正态分布白噪声,但在任意长度下x=randn(1,N),x不一定是均值为0方差为1(有些小小的偏差),这样对后续的计算会产生影响。在这里提供3个函数用于按一定的信噪比把噪声叠加到信号上去,同时可检验带噪信号中信噪比。

1,把白噪声叠加到信号上去:

function [Y,NOISE] = noisegen(X,SNR)

% noisegen add white 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;

其中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 frequency is fs;

% filepath_name is NOISE's 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_power / ( 10^(SNR/10) );

NOISE=sqrt(noise_variance)/std(NOISE)*NOISE;

Y=X+NOISE;

其中X是纯信号,filepath_name是指定噪声文件(.wav)的路径和文件名,SNR是要求的信噪比,fs是信号X的采样频率,Y是带噪信号,NOISE是叠加在信号上的噪声。

3,检验带噪信号的信噪比

信噪比的定义为

信号能量 (纯信号)^2

SNR=-----------------=--------------------------

噪声能量 (带噪信号-纯信号)^2

function snr=SNR_singlech(I,In)

% 计算信噪比函数

% I :original signal

% In:noisy signal(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] = 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)

输出信噪比公式_Matlab信号添加噪声及信噪比SNR的计算相关推荐

  1. matlab 自定义的snr,Matlab信号添加噪声及信噪比SNR的计算

    一.MATLAB中自带的高斯白噪声的两个函数 MATLAB中产生高斯白噪声非常方便,可以直接应用两个函数,一个是WGN,另一个是AWGN.WGN用于产生高斯白噪声,AWGN则用于在某一信号中加入高斯白 ...

  2. Matlab信号添加噪声及信噪比SNR的计算

    一.MATLAB中自带的高斯白噪声的两个函数 MATLAB中产生高斯白噪声非常方便,可以直接应用两个函数,一个是WGN,另一个是AWGN.WGN用于产生高斯白噪声,AWGN则用于在某一信号中加入高斯白 ...

  3. 输出信噪比公式_如何计算信号的信噪比

    展开全部 如何计算信号的信噪比 1.在仿真实验中要产生具有某个信62616964757a686964616fe58685e5aeb931333365653766噪比的混合信号样本zt.这时,先求出不含 ...

  4. 信噪比公式与相关链接

    一文理清信噪比及其应用,包含:公式与相关链接 定义 公式 python 写matlab中的加性高斯白噪声AWGN 思考为什么大家都在研究高斯白噪声? 心电研究常用噪声数据库 python合成指定信噪比 ...

  5. 对一个信号添加带限高斯白噪声 Matlab实现

    clear; clc; close all;%% 产生一个时域信号 SignalInput = cos(2 * pi * 1000 * (1:1:2048).' / 5000); %% 设计一个带通滤 ...

  6. 关于信噪比与向已知信号添加噪声的整理及个人心得

    说起"向已知信号添加噪声",有一个帖子不得不提,那是由happy教授介绍的两个常用函数,这里引用一下: %=============================happy=== ...

  7. 噪声和信噪比的转换(如何在数据集中添加噪声)

    之前参考别人的博客写了一篇,后来用的过程中发现有问题,但是相关理论部分还是可以用的. 之前我写的:https://blog.csdn.net/Kathleen_yuan/article/details ...

  8. 输出信噪比公式_最大输出信噪比准则接收机.ppt

    最大输出信噪比准则接收机 第9章数字信号的最佳接收 本章主要内容 §9.1 引言(什么是"最佳接收") §9.2 最大信噪比准则(即匹配滤波器) §9.3 最小误码率准则 §9.4 ...

  9. 使用matlab构建一个信号、添加噪声信号并图示信号

    先定义相关参数:      采样频率,采样时间,信号长度: 时间t: 构建一个信号x,t为自变量:  pi,3.141592......: 使用randn生成随机值加到x上,形成带噪声的信号y: 画一 ...

最新文章

  1. ceph osd 由于“No space left on device” 异常down,通过扩容文件系统或者显式运行osd进程解决
  2. 如何使用命令行中的“message”和“description”进行更改? [重复]
  3. php发送短信验证码
  4. ABAP--如何创建动态结构的报表
  5. python如何执行代码漏洞_织梦dedecms最新远程代码执行利用脚本(python)
  6. 前端开发:小程序--第一步
  7. android 编译时解析xml布局,android – 在xml布局中引用build.gradle versionName属性
  8. Federated Machine Learning: Concept and Applications
  9. ben we_惊!WE辅助选手Ben离开WE,大舅子还能再有这么默契的辅助吗?
  10. JavaScriptSerializer 类
  11. Linux系统启动流程和GRUB解释
  12. exe4j生成的exe反编译
  13. 机器人轨迹规划:三次样条曲线
  14. 解决Eclipse修改jsp文件需要重启Tomcat问题
  15. mysql怎么创建blog_「MySQL创建与删除数据库」- 海风纷飞Blog
  16. 用C#实现一个zip解压功能,无需引入dll(可直接放到Unity中使用)
  17. matlab 两个视频同时播放视频,视频画面合并教程:两个或多个视频合并在同一屏幕上同时播放...
  18. 科里奥利质量流量计的4个检定方法
  19. 强烈建议你把这5个跨境神器都收藏了
  20. AI背景下的新零售行业商业模式

热门文章

  1. JAVA设计模式-设计原则(三)里氏代换原则
  2. _variant_t、CComVariant与COleVariant、CDBVariant
  3. 如何利用售后服务管理系统实现企业精细化管理?
  4. 卡鲁机器人智能_成都屹安自动化 | MiR自主协作式智能AGV、优傲人机协作机器人...
  5. 【数电试题】西电通卓模拟卷一
  6. 微软基于云计算的免费杀毒软件Morro曝光
  7. RK3288 gpio读取
  8. 【Android 进阶】Android优秀框架
  9. 玲珑杯 1137 - Sin your life
  10. 图片kb太大怎么压缩变小?