dyhdyh 发表于 2007-5-22 16:10

关于信噪比程序出错问题

y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
function snr=SNR(I,In)
% I:original signal
% In:noisy signal(ie. original signal + noise signal)
% snr=10*log10(sigma2(I2)/sigma2(I2-I1))
=size(I);
snr=0;
if nchannel==1%gray image
Ps=sum(sum((I-mean(mean(I))).^2));%signal power
Pn=sum(sum((I-In).^2));%noise power
snr=10*log10(Ps/Pn);
elseif nchannel==3%color image
for i=1:3
Ps=sum(sum((I(:,:,i)-mean(mean(I(:,:,i)))).^2));%signal power
Pn=sum(sum((I(:,:,i)-In(:,:,i)).^2));%noise power
snr=snr+10*log10(Ps/Pn);
end
snr=snr/3;
end


出现如下错误
??? Error: File: D:\mat\xinzao.m Line: 7 Column: 1
A function declaration cannot appear within a script M-file.

如何解决啊?弄了一下午了。。

[ 本帖最后由 eight 于 2007-5-22 16:12 编辑 ]

eight 发表于 2007-5-22 16:12

原帖由 dyhdyh 于 2007-5-22 16:10 发表 http://www.chinavib.com/forum/images/common/back.gif
y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
function snr=SNR(I,In)
% I:original signal
% In:noisy signal(ie. original signal + noise signal)
% snr=10*log10( ...

脚本文件不能定义函数,只能使用m文件

请多阅读 matlab 基础书

dyhdyh 发表于 2007-5-22 16:16

哦 谢谢 实在赶时间 图书馆又关门了 借不到指导类的书籍 所以我跳过了基础部分 直接信号处理了对于脚本不甚了解 如果能讲的具体点 将万分感谢!

dyhdyh 发表于 2007-5-22 16:20

是否意思是 我在M函数中 只能做FUNCTION 而不能做y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
是么?

eight 发表于 2007-5-22 16:22

原帖由 dyhdyh 于 2007-5-22 16:20 发表 http://www.chinavib.com/forum/images/common/back.gif
是否意思是 我在M函数中 只能做FUNCTION 而不能做y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
是么?

function 之前:命令窗口,之后:m文件

dyhdyh 发表于 2007-5-22 16:35

谢谢 EIGHT的帮助 我改成在COMMAND WINDOW里面输入
y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin

然后再RUN M文件执行FUNCTION 是这样么?

结果出了Input argument 'I' is undefined.

Error in ==> D:\mat\xinzao.m
On line 8==> =size(I);
是我脚本&M函数没定义清楚么?

eight 发表于 2007-5-22 16:42

原帖由 dyhdyh 于 2007-5-22 16:35 发表 http://www.chinavib.com/forum/images/common/back.gif
谢谢 EIGHT的帮助 我改成在COMMAND WINDOW里面输入
y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin

然后再RUN M文件执行FUNCTION 是这样么?

结果出了Input argumen ...

看来真的要送佛送到西,把 function 那行及之后的代码存储为m文件,然后在命令窗口输入:

y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
z = SNR(I,In)

dyhdyh 发表于 2007-5-22 16:50

呵呵,晚上还要出差,学个东西都不能静下心,要玩速成的....
真是麻烦这为EIGHT了!

dyhdyh 发表于 2007-5-22 16:51

又出了个新错误 呵呵。。。

??? Error using ==> -
Matrix dimensions must agree.

Error in ==> F:\matlab\work\SNR.m
On line 11==> Pn=sum(sum((I-In).^2));%noise power

看来好事多磨。。

eight 发表于 2007-5-22 17:06

原帖由 dyhdyh 于 2007-5-22 16:51 发表 http://www.chinavib.com/forum/images/common/back.gif
又出了个新错误 呵呵。。。

??? Error using ==> -
Matrix dimensions must agree.

Error in ==> F:\matlab\work\SNR.m
On line 11==> Pn=sum(sum((I-In).^2));%noise power

看来好事多磨。。

矩阵大小不匹配,估计一个是RGB,另一个是灰度


多看看基础书,你到处碰壁,然后不断上来提问根本不能解决问题,没有人有这个空闲

dyhdyh 发表于 2007-5-22 17:17

恩 矩阵中原一维信号SIZE 是601×1
而噪音信号的SIZE是1×601 就这里不匹配

知道以后一定去看书的,无论如何,谢谢EIGHT,占用你的时间十分抱歉。
页: [1]
查看完整版本: 关于信噪比程序出错问题