python向信号添加自定义信噪比高斯白噪声--详细原理+公式+代码

python向信号添加自定义信噪比高斯白噪声–详细原理+公式+代码

使用python向信号添加自定义信噪比高斯白噪声–详细原理+公式+代码

1 原理公式

P s 、 P n Ps、Pn PsPn分别表示干净信号和噪声的有效功率,信噪比 (SNR) 是正常信号功率与噪声功率的比值,单位为 dB,信噪比应该越高越好。其中信号功率其实就是信号的能量或强度,在连续的情况下就是对信号x平方后求积分,而在离散情况下是对信号x平方后求和。
在这里插入图片描述
下式中 x ( t ) x(t) x(t) n ( t ) n(t) n(t) 分别为干净信号和噪声:
在这里插入图片描述
高斯白噪声的生成公式如下:
在这里插入图片描述

2 程序-代码可直接运行

import numpy as np
import pylab as plt
import math
def wgn(x, snr):  # 输出为高斯白噪声
   '''
	x:原始信号
   snr:目标信噪比。eg:10、0等
   return:生成的高斯白噪声
   '''
   snr = 10**(snr/10.0)
   xpower = np.sum(x**2)/len(x)
   npower = xpower / snr
   return np.random.randn(len(x)) * np.sqrt(npower)

t = np.arange(0, 1000000) * 0.1
x = np.sin(t)
snr=6
n = wgn(x, 6)
xn = x+n # 增加了6dBz信噪比噪声的信号
print(10*math.log10(sum(x**2) / sum(n**2)))  # 验算信噪比
# 用hist()检查噪声是否是高斯分布,psd()检查功率谱密度是否为常数。
plt.figure(figsize=(10,7))
plt.subplot(411)
plt.title('Gauss Distribution')
plt.hist(n, bins=100)

plt.subplot(412)
plt.psd(n)  # psd()检查功率谱密度是否为常数

plt.subplot(413)
plt.plot(t[0:100],x[0:100])
plt.title('The Original Sin Signal')

plt.subplot(414)
plt.plot(t[0:100],xn[0:100])
plt.title('The Noisy Sin Signal')
plt.tight_layout()
plt.show()

以上就是全部内容,感谢观看!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值