matlab产生指定功率的噪声信号、固定SNR的信号

randn函数产生噪声信号

首先要理解信号的幅度和功率,例如信号的幅度为 U U U,那么信号的功率就是 U 2 U^2 U2,他们之间是平方的关系。
matlab中randn函数用法,产生正态分布的随机数或矩阵的函数。

randn:产生均值为0,方差σ^2 = 1,标准差σ = 1的正态分布的随机数或矩阵的函数。
例如下面的代码就是产生1个噪声信号,它的幅度和功率都是1。

noise = randn(1,1000);
plot(noise)
title('功率为1的噪声信号');

在这里插入图片描述

如何计算信号的平均功率

在matlab中计算信号的能量,可以通过以下公式,长度为 N N N的向量 x ( n ) x(n) x(n)的能量为
p o w e r = ∑ n = 1 N x ( n ) 2 power = \sum_{n=1}^{N}x(n)^2 power=n=1Nx(n)2
它的功率为:
P = 1 N ∑ n = 1 N x ( n ) 2 P = \frac{1}{N}\sqrt{\sum_{n=1}^{N}x(n)^2} P=N1n=1Nx(n)2

randn函数产生指定功率的噪声信号

知道了功率,只要开根号就可以知道信号的幅度

P = 2; %指定噪声信号的功率
noise = sqrt(P)*randn(1,1000); %开根号得到幅度
sum(abs(noise.^2))/1000 %输出信号的功率

matlab输出:

ans =

    2.0600

可以看出,计算出来的功率和指定的功率基本是吻合的。

指定功率的复信号噪声信号

复数 x = a + b j x=a+bj x=a+bj的幅度为 a 2 + b 2 \sqrt{a^2+b^2} a2+b2 ,因此指定幅度的时候要除以 2 \sqrt{2} 2

%%产生功率为P的复信号噪声信号
P = 2;
noise = sqrt(P/2)*(randn(1,1000)+1j*randn(1,1000));
sum(abs(noise.^2))/1000

matlab输出:

ans =

    1.9329

指定信噪比的信号

仿真的时候,我们先固定噪声功率,默认输出功率为1的噪声信号,然后再产生指定信噪比的有用信号。信噪比的定义:
s n r = 10 l o g 1 0 P s P n snr =10 log10^{\frac{P_s}{P_n}} snr=10log10PnPs
当噪声 P s = 1 P_s=1 Ps=1的时候,信号功率为:
P s = 1 0 s n r / 10 P_s=10^{snr/10} Ps=10snr/10
那么信号的幅度 U s U_s Us为:
U s = P s = 1 0 s n r / 10 U_s=\sqrt{P_s}=\sqrt{10^{snr/10}} Us=Ps =10snr/10
例如,要产生信噪比为snr的信号:

xs = sqrt(10^(snr/10))*exp(j*2*pi*fd*t); %构造有用信号
  • 5
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

nwsuaf_huasir

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值