24小时热门版块排行榜    

查看: 662  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

淸夏木笔

铁虫 (初入文坛)

[求助] 帮我看看这个matlab程序哪里错了?

fid1=fopen('diffusion temperature.txt','r');
[f,count]=fscanf(fid1,'%f %f',[1,50000]);
figure(1)
imagesc(f)
fclose(fid1);
fid2=fopen('diffusion coefficient.txt','r');
[e,count]=fscanf(fid2,'%f %f',[1,50000]);
figure(2)
imagesc(e)
fclose(fid2);
fid3=fopen('diffusion force.txt','r');
[g,count]=fscanf(fid3,'%f %f',[1,50000]);
figure(3)
imagesc(g)
fclose(fid3);
cell=zeros(1,50000);
cell(1:25000)=1;
for j=2:49999
        cell(1,j)=10^11*e(1,j)*(cell(1,j+1)-2*cell(1,j)+cell(1,j-1))-10^4/2/(1.38*10^(-23))*g(1,j)*e(1,j)/f(1,j)*(cell(1,j+1)-cell(1,j-1));
end
figure(4)
imagesc(cell)

??? Index exceeds matrix dimensions.
Error in ==> Untitled2 at 22
        cell(1,j)=10^11*e(1,j)*(cell(1,j+1)-2*cell(1,j)+cell(1,j-1))-10^4/2/(1.38*10^(-23))*g(1,j)*e(1,j)/f(1,j)*(cell(1,j+1)-cell(1,j-1));



回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

淸夏木笔

铁虫 (初入文坛)

引用回帖:
4楼: Originally posted by fouvy at 2012-07-12 23:59:18
try
cell(1,j)=10^11*e(1,j)*(cell(1,j+1)-2*cell(1,j)+cell(1,j-1))-10^4/2/(1.38*10^(-23))*g(1,j)*e(1,j)/f(1,j)*(cell(1,j+1)-cell(1,j-1));
catch
end
这样代码可以正常运行,不过结果可能出错,因为你的算 ...

大侠,算法有啥问题,求指导。。。。。
6楼2012-07-14 15:25:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

感谢参与,应助指数 +1
??? Index exceeds matrix dimensions.
下标越界错误,matlab的下标范围是[1,length]
对矩阵元素存取的时候,要么下标为0,要么超过了数组长度
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2012-07-12 15:56:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

csgt0

荣誉版主 (著名写手)

彩色挂图

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
淸夏木笔: 金币+2, 有帮助 2012-07-14 15:25:59
可能你的txt文件没那么长,这样读出来的f,e,g实际没有50000那么长,这样在for循环中就会出现越界。另外,你的f,e,g,cell都是一维数组,for中用一个下标就可以了,不需要用f(1,j)这样的
showmethemoney
3楼2012-07-12 16:20:40
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

fouvy

铁虫 (初入文坛)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
淸夏木笔: 金币+2, 有帮助 2012-07-14 15:26:06
try
cell(1,j)=10^11*e(1,j)*(cell(1,j+1)-2*cell(1,j)+cell(1,j-1))-10^4/2/(1.38*10^(-23))*g(1,j)*e(1,j)/f(1,j)*(cell(1,j+1)-cell(1,j-1));
catch
end
这样代码可以正常运行,不过结果可能出错,因为你的算法本身就有问题。
4楼2012-07-12 23:59:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见