(33)MATLAB信号分析之信号功率、噪声功率、与信噪比

文章目录


前言

本文首先给出了信号功率、噪声功率、与信噪比的概念,以及信噪比线性值和分贝值的换算关系,然后使用MATLAB生成信号,并叠加awgn形成噪声信号,基于该仿真代码计算出信号功率、噪声功率,并说明其与信噪比的关系。


一、信号功率、噪声功率、与信噪比

1.信号功率

信号功率是指信号的平均功率,一般用S表示。若信号由序列A=[A0, A1, A2, ... Ai, ... AN]给出,则信号功率由下式给出:

信号功率的单位是W(瓦特)。

2.噪声功率

噪声功率是指噪声的平均功率,一般用N表示。它是噪声序列平方和的平均值,单位也是W(瓦特)。

3.信噪比

信噪比是指信号功率S与噪声功率N的比值,一般用SNR表示。SNR由下式给出:

显然,SNR是无量纲的。工程中一般使用SNR的dB值,此时便称SNR的单位是分贝(dB)。

4.信噪比线性值与分贝值的换算关系

若用S/N表示SNR的线性值(即由信号功率和噪声功率直接计算得到的比值),用SNR_dB表示SNR的分贝值,则两者之间换算关系如下:

SNR_dB = 10*log10(S/N)

S/N = 10^( SNR_dB/10)

例如,若已知SNR_dB=20dB和信号功率S=0.5W,则可计算出噪声功率N=S/[10^( SNR/10)]=0.005W。

二、MATLAB仿真分析

下面以awgn的使用为例,给出MATLAB仿真中信号功率、噪声功率、与信噪比的应用举例。

1.建立awgn信道通信模型

首先使用MATLAB生成一段余弦信号,并将其送入awgn函数增加噪声,然后用带噪信号和原始信号作差得到噪声序列。代码如下:

c 复制代码
% 指定信号的参数,频率1Hz,采样频率为64Hz,信号持续时间为10秒(640个samples)。
A = 1;                         % 余弦波的振幅
f = 1;                         % 余弦波的振荡频率,简称频率
fs = 64;                       % 数字信号的采样频率(sampling frequency ),简称采样率
Ts = 1/fs;                     % 采样周期,也即采样值的时间间隔
L = 640;                        % 一个采样值称为一个sample,L为sample的个数
t = (0:L-1)*Ts;                % 时间向量
snr = 20;                      % 信噪比,dB值

% 生成余弦波x
x = A * cos(2*pi*f*t);         % 余弦波

% 信号经过awgn信道
y = awgn(x,snr,'measured');    % 信号叠加高斯白噪声 

% 噪声
n = y - x;

% 画出生成余弦波的时域波形
figure()
subplot(311)
plot(t,x,'LineWidth',1.5)
title('余弦信号的时域波形')
grid on
xlabel('t/s')
ylabel('cos(2*pi*f*t)')

subplot(312)
plot(t,y,'LineWidth',1.5)
title('加噪余弦信号的时域波形(SNR=10dB)')
grid on
xlabel('t/s')
ylabel('cos(2*pi*f*t)+noise')

subplot(313)
plot(t,n,'LineWidth',1.5)
title('噪声的时域波形')
grid on
xlabel('t/s')
ylabel('noise')

得到的信号与噪声画图如下:

2.计算信号功率与噪声功率

代码如下:

c 复制代码
% 信号功率
n2 = norm(x, 2);                      % 2-范数
Ps = n2^2 / length(y)                 % 计算信号的平均功率(线性值)

% 噪声功率
n2_n = norm(n, 2);                    % 2-范数
Pn = n2_n^2 / length(n)               % 计算噪声的平均功率(线性值)

计算结果如下:

Ps = 0.5000

Pn = 0.0049

3.结果分析

SNR=20dB意味着信号功率是噪声功率的100倍,仿真中生成的余弦信号其功率为0.5W,所以加入的噪声功率为0.005W。仿真结果符合理论计算。


相关推荐
7yewh2 分钟前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
waicsdn_haha13 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
_WndProc15 分钟前
C++ 日志输出
开发语言·c++·算法
qq_4335545424 分钟前
C++ 面向对象编程:+号运算符重载,左移运算符重载
开发语言·c++
努力学习编程的伍大侠28 分钟前
基础排序算法
数据结构·c++·算法
数据小爬虫@43 分钟前
如何高效利用Python爬虫按关键字搜索苏宁商品
开发语言·爬虫·python
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
Narutolxy1 小时前
深入探讨 Go 中的高级表单验证与翻译:Gin 与 Validator 的实践之道20241223
开发语言·golang·gin
XiaoLeisj1 小时前
【递归,搜索与回溯算法 & 综合练习】深入理解暴搜决策树:递归,搜索与回溯算法综合小专题(二)
数据结构·算法·leetcode·决策树·深度优先·剪枝
Hello.Reader1 小时前
全面解析 Golang Gin 框架
开发语言·golang·gin