24小时热门版块排行榜    

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

百里道

木虫 (初入文坛)

[求助] matlab函数调用与数组的问题

for i=1:I
    for j=1:J
        for n=0:N-1
            f(i,j,n)=feq(u,n,rho);
        end
    end
end

function result=feq(u,n,rho)   
   %u(i,j,1)是坐标位置为(i,j)处的水平速度,u(i,j,2)是竖直方向的速度
w=[4/9,1/9,1/9,1/9,1/9,1/36,1/36,1/36,1/36];
e=[0,0;1,0;0,1;-1,0;0,-1;1,1;-1,1;-1,-1;1,-1];
for i=1:I-1
    for j=1:J-1
        for n=1:N
          eu=e(n,1).*u(:,:,1)+e(n,2).*u(:,:,2);
          uv=u(:,:,1).*u(:,:,1)+u(:,:,2).*u(:,:,2);
   %uv是水平方向与竖直方向速度的平方和
          result=w(n)*rho*(1+3*eu+4.5*eu.*eu-1.5*uv);
        end
    end
end
feq这么调用对不?eu和uv的写法对不?
本人初学,函数调用数组这方面不明白,请指点
回复此楼
==
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

百里道

木虫 (初入文坛)

引用回帖:
17楼: Originally posted by csgt0 at 2012-10-30 17:17:09
这是你的三维矩阵维度的问题,
result(p,rho1)算出来的是一个行向量,放到三维矩阵中应该是用A=(i,:,j)来表示的
所以你跟他加减的项应该也是这样的,为了方便一般都用列向量放第一个最方便。
另外你这一句的问题 ...

非常感谢,不知道怎么才是按列排放,我只好定义了f=zeros(N,I+1,J+1),再没有出现问题
另外,我想请教函数调用的问题
对于下式
f(I+1,j,n)=feq(I+1,j,n)+f(I,j,n)-feq(I,j,n)
(feq只是说明坐标)一个式子里出现两次要调用的函数result,按照你前面所说的
主程序里面对于第(i,j)点就用
p=[u(i,j,1),u(i,j,2)];
rho1=rho(i,j);
feq(i,j,:)=result(p,rho1);

所以我写成
     p2=[u(1,I+1,j),u(2,I+1,j)];
     rho2=rho(I+1,j);
     r2=result(p2,rho2);
     
     p3=[u(1,I,j),u(2,I,j)];
     rho3=rho(I,j);
     r3=result(p3,rho3);
     
     f(n,I+1,j)=r2(n)+f(n,I,j)-r3(n);


可以运行程序,不过要求的feq的点比较多,所以这个过程很长,有没有简单的办法调用?
==
18楼2012-10-31 16:21:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 20 个回答

BlueAsia

新虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
直接输入到matlab里让计算机帮你找错误,对的话就能得到正确结果了呀
2楼2012-10-22 19:02:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

百里道

木虫 (初入文坛)

引用回帖:
2楼: Originally posted by BlueAsia at 2012-10-22 19:02:35
直接输入到matlab里让计算机帮你找错误,对的话就能得到正确结果了呀

程序比较长,所以没贴出来,程序运行一直是busy状态,不知道循环哪里出了问题。
==
3楼2012-10-23 08:28:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

BlueAsia

新虫 (小有名气)

【答案】应助回帖


jjdg: 金币+1, 感谢参与 2012-10-24 10:13:51
引用回帖:
3楼: Originally posted by 百里道 at 2012-10-23 08:28:36
程序比较长,所以没贴出来,程序运行一直是busy状态,不知道循环哪里出了问题。...

可以考虑把源程序分步运行,看看问题出在哪个点上
4楼2012-10-23 09:16:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见