声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 910|回复: 1

[编程技巧] 请教:请问为何在求SNR时将xd3改为与其大小一样的矩阵时图像就会发生较大畸变

[复制链接]
发表于 2006-12-23 17:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
clear
x=0:1:1600;
n=1:length(x);
a=50*exp(-(n-420).^2/144);
d=70*exp(-(n-1200).^2/324);
g=a+d;
h=40*exp(-(n-800).^2/2);
i1=g+h;
r=randn(1,1601);
r=r-mean(r);
r=sqrt(2.56)*r./sqrt(var(r));
ii=i1+r;
y=fft(ii,1600)
pyy=y.*conj(y)
y1=y;y1(20:890)=0
y2=y;y2(30:760)=0
y3=y;y3(40:1040)=0
xd1=real(ifft(y1,1600))
xd2=real(ifft(y2,1600))
xd3=real(ifft(y3,1600))
subplot(411);plot(ii);axis([0 1600 -50 100]);title('0');grid on;
subplot(412);plot(xd1);axis([0 1600 -50 100]);title('1');grid on;
subplot(413);plot(xd2);axis([0 1600 -50 100]);title('2');grid on;
subplot(414);plot(xd3);axis([0 1600 -50 100]);title('3');grid on;
[row,col,nchannel]=size(i1);
snr=0;
if nchannel==1%gray image
Ps=sum(sum((i1-mean(mean(i1))).^2));%signal power
Pn=sum(sum((i1-xd3).^2));%noise power
snr=10*log10(Ps/Pn);
elseif nchannel==3%color image
for i=1:3
Ps=sum(sum((i1(:,:,i)-mean(mean(i1(:,:,i)))).^2));%signal power
Pn=sum(sum((i1(:,:,i)-xd3(:,:,i)).^2));%noise power
snr=snr+10*log10(Ps/Pn);
end
snr=snr/3;
end
disp(snr);
回复
分享到:

使用道具 举报

发表于 2006-12-25 15:41 | 显示全部楼层

回复

没太明白你的意思.
xd3是一向量.
你后面的程序好象有点问题,建议将公式用word先传上来看看.
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-12 14:17 , Processed in 0.067584 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表