我是靠谱客的博主 感性白云,最近开发中收集的这篇文章主要介绍180305 手写python高斯白噪声函数,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

原文出处
https://wiki.woodpecker.org.cn/moin/MiscItems/2011-08-24
代码结果
这里写图片描述
代码实现

# -*- coding: utf-8 -*-
"""
Created on Mon Mar  5 13:41:09 2018

"""

'''
SNR = [-4,-2,0,2,4,6,8,10](dB)
SNR = 10*log10( sum(x**2) / sum(n**2))
程序中用hist()检查噪声是否是高斯分布,psd()检查功率谱密度是否为常数。
'''
import numpy as np
import pylab as plt

def wgn(x, snr):
    snr = 10**(snr/10.0)
    xpower = np.sum(x**2)/len(x)
    npower = xpower / snr
    return np.random.randn(len(x)) * np.sqrt(npower)

def wgn_matrix(X, snr):
    snr = 10**(snr/10.0)
    xpower = np.sum(X**2,axis=1)/X.shape[1]
    npowers = xpower / snr
    noise_arr = np.ones(X.shape)
    for n, npower in enumerate(npowers):
        noise_arr[n,:]=np.random.randn(X.shape[1]) * np.sqrt(npower) 
    return noise_arr

t = np.arange(0, 1000000) * 0.1
x = np.sin(t)
snr = 10
n = wgn(x, snr)
xn = x+n # 增加了6dBz信噪比噪声的信号

plt.figure(figsize=(6,8))
plt.subplot(411)
plt.title('Gauss Distribution')
plt.hist(n, bins=100, normed=True)
plt.subplot(412)
plt.psd(n)
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.show()
plt.tight_layout()

最后

以上就是感性白云为你收集整理的180305 手写python高斯白噪声函数的全部内容,希望文章能够帮你解决180305 手写python高斯白噪声函数所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(67)

评论列表共有 0 条评论

立即
投稿
返回
顶部