维纳滤波 matlab代码,完整的维纳滤波器Matlab源程序完整的维纳滤波器Matlab源程序.doc...

本文提供了一个完整的维纳滤波器Matlab源程序示例,包括信号生成、加噪、自相关函数计算及概率密度估计等关键步骤,并通过图表展示了信号处理过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

完整的维纳滤波器Matlab源程序完整的维纳滤波器Matlab源程序

完整的维纳滤波器Matlab源程序 学术 2009-11-20 20:31:58 阅读308 评论0 字号:大中小

完整的维纳滤波器Matlab源程序

clear;clc;

%输入信号

A=1; %信号的幅值

f=1000; %信号的频率

fs=10^5; %采样频率

t=(0:999); %采样点

Mlag=100; %相关函数长度变量

x=A*cos(2*pi*f*t/fs); %输入正弦波信号

xmean=mean(x); %正弦波信号均值

xvar=var(x,1); %正弦波信号方差

xn=awgn(x,5); %给正弦波信号加入信噪比为20dB的高斯白噪声

figure(1)

plot(t,xn) %绘制输入信号图像

title('输入信号图像')

xlabel('x轴单位:t/s','color','b')

ylabel('y轴单位:f/HZ','color','b')

xnmean=mean(xn) %计算输入信号均值

xnms=mean(xn.^2) %计算输入信号均方值

xnvar=var(xn,1) %计算输入信号方差

Rxn=xcorr(xn,Mlag,'biased'); %计算输入信号自相关函数

figure(2)

subplot(221)

plot((-Mlag:Mlag),Rxn) %绘制自相关函数图像

title('输入信号自相关函数图像')

[f,xi]=ksdensity(xn); %计算输入信号的概率密度,f为样本点xi处的概率密度

subplot(222)

plot(xi,f) %绘制概率密度图像

title('输入信号概率密度图像')

X=fft(xn); %计算输入信号序列的快速离散傅里叶变换

Px=X.*conj(X)/600; %计算信号频谱

subplot(223)

semilogy(t,Px) %绘制在半对数坐标系下频谱图像

title('输入信号在半对数坐标系下频谱图像')

xlabel('x轴单位:w/rad','color','b')

ylabel('y轴单位:w/HZ','color','b')

pxx=periodogram(xn); %计算输入信号的功率谱密度

subplot(224)

semilogy(pxx) %绘制在半对数坐标系下功率谱密度图像

title('输入信号在半对数坐标系下功率谱密度图像')

xlabel('x轴单位:w/rad','color','b')

ylabel('y轴单位:w/HZ','colo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值