关于信噪比程序出错问题
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 编辑 ] 原帖由 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 基础书 哦 谢谢 实在赶时间 图书馆又关门了 借不到指导类的书籍 所以我跳过了基础部分 直接信号处理了对于脚本不甚了解 如果能讲的具体点 将万分感谢! 是否意思是 我在M函数中 只能做FUNCTION 而不能做y=wavread('d:/mat/xinhao.wav');
save y
load y
I=y
load noissin
In=noissin
是么? 原帖由 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文件 谢谢 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函数没定义清楚么? 原帖由 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) 呵呵,晚上还要出差,学个东西都不能静下心,要玩速成的....
真是麻烦这为EIGHT了! 又出了个新错误 呵呵。。。
??? Error using ==> -
Matrix dimensions must agree.
Error in ==> F:\matlab\work\SNR.m
On line 11==> Pn=sum(sum((I-In).^2));%noise power
看来好事多磨。。 原帖由 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,另一个是灰度
多看看基础书,你到处碰壁,然后不断上来提问根本不能解决问题,没有人有这个空闲 恩 矩阵中原一维信号SIZE 是601×1
而噪音信号的SIZE是1×601 就这里不匹配
知道以后一定去看书的,无论如何,谢谢EIGHT,占用你的时间十分抱歉。
页:
[1]