怎么给一个离散点生成的信号,在MATLAB中加噪声?

怎么给一个离散点生成的信号,在MATLAB中加噪声?,第1张

% 若data 是 一个离散信号

data_with_noise = zeros(1,length(data))

for i = 1:length(data)

data_with_noise(i) = data(i) + rand() %加了个随机噪声

end

% 这样得到的data_with_noise就是加了噪声的。

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以瓦特为单位。

把传递函数离散化

dsys=c2d(sys,ts,'method')传函离散

[num,den]=tfdata(dsys,'v')离散后提取分子分母

这里面的method有好多种,

zoh 零阶保持, 假设控制输入在采样周期内为常值,为默认值。

foh 一阶保持器,假设控制输入在采样周期内为线性。

tustin 采用双线性逼近。method用tustin替代

matched 采用SISO系统的零极点匹配法!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11531963.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存