24小时热门版块排行榜    

查看: 595  |  回复: 1

holmescn

金虫 (正式写手)


[交流] 【求助】Matlab 程序结果不相同,求解

程序的一部分, 目标是求解一个类似泊松方程的场方程。原作者不是我, 程序写得很直接,但很缓慢。经过我修改后, 速度虽然提上去了,但貌似两个程序的结果不是很对,按说我都使用的相同的算法, 区别只在写法上。

方程:
周期性边界条件。

原始代码:
CODE:
C1 = (2+2*D44*dx^2/(D11*dz^2));
C2 = (2+2*D11*dz^2/(D44*dx^2));
C3 = D44*abs(P0)*sqrt(D11)*dx^2*dz/ ...
    (2*D11*af*sqrt(abs(A))*dz^2+2*D44* ...
    af*sqrt(abs(A))*dx^2);
Nx=101;Nz=101;
P1 = zeros(Nx,Nz);
FI = zeros(Nx,Nz);Fnew=zeros(Nx,Nz);Fold=zeros(Nx,Nz)+1;
while max(max(abs(FI-Fold)))>=0.001
    for k=1:Nz
        for i=1:Nx
            if i~=1&&i~=Nx&&k~=1&&k~=Nz
                Fnew(i,k)=(FI(i+1,k)+FI(i-1,k))/C1+(FI(i,k+1)+FI(i,k-1))/C2- ...
                          (P1(i,k)-P1(i,k-1))*C3;
            end
            if k==1
                if i~=1&&i~=Nx
                    Fnew(i,k)=(FI(i+1,k)+FI(i-1,k))/C1+ ...
                              (FI(i,k+1)+FI(i,Nz))/C2- ...
                              (P1(i,k)-P1(i,Nz))*C3;
                end
                if i==1
                    Fnew(i,k)=(FI(i+1,k)+FI(Nx,k))/C1+ ...
                              (FI(i,k+1)+FI(i,Nz))/C2- ...
                              (P1(i,k)-P1(i,Nz))*C3;
                end
                if i==Nx
                    Fnew(i,k)=(FI(1,k)+FI(i-1,k))/C1+ ...
                              (FI(i,k+1)+FI(i,Nz))/C2- ...
                              (P1(i,k)-P1(i,Nz))*C3;
                end
            end

            if k==Nz
                if i~=1&&i~=Nx
                    Fnew(i,k)=(FI(i+1,k)+FI(i-1,k))/C1+ ...
                              (FI(i,1)+FI(i,k-1))/C2- ...
                              (P1(i,k)-P1(i,k-1))*C3;
                end
                if i==1
                    Fnew(i,k)=(FI(i+1,k)+FI(Nx,k))/C1+ ...
                              (FI(i,1)+FI(i,k-1))/C2- ...
                              (P1(i,k)-P1(i,k-1))*C3;
                end
                if i==Nx
                    Fnew(i,k)=(FI(1,k)+FI(i-1,k))/C1+ ...
                              (FI(i,1)+FI(i,k-1))/C2- ...
                              (P1(i,k)-P1(i,k-1))*C3;
                end
            end
            if i==1&&k~=1&&k~=Nz
                Fnew(i,k)=(FI(i+1,k)+FI(Nx,k))/C1+ ...
                          (FI(i,k+1)+FI(i,k-1))/C2- ...
                          (P1(i,k)-P1(i,k-1))*C3;
            end
            if i==Nx&&k~=1&&k~=Nz
                Fnew(i,k)=(FI(1,k)+FI(i-1,k))/C1+ ...
                          (FI(i,k+1)+FI(i,k-1))/C2- ...
                          (P1(i,k)-P1(i,k-1))*C3;
            end
        end
    end
    Fold=FI;FI=Fnew;
end

注意这里的P1只是给了一个形式, 为的是说明他的结构, 计算中的P1是有一个分布的,不是零。

修改后的代码:
CODE:
C1 = (2+2*D44*dx^2/(D11*dz^2));
C2 = (2+2*D11*dz^2/(D44*dx^2));
C3 = D44*abs(P0)*sqrt(D11)*dx^2*dz/ ...
    (2*D11*af*sqrt(abs(A))*dz^2+2*D44* ...
    af*sqrt(abs(A))*dx^2);
Nx=101;Nz=101;
P1=zeros(Nx+2,Nz+2);
FI=zeros(Nx+2,Nz+2);Fnew=zeros(Nx+2,Nz+2);Fold=zeros(Nx+2,Nz+2)+1;
i=2:Nx+1;k=2:Nz+1;
while max(max(abs(FI(i,k)-Fold(i,k))))>=0.001
    P1(1,:)=P1(Nx+1,:);P1(Nx+2,:)=P1(2,:);
    P1(:,1)=P1(:,Nz+1);P1(:,Nx+2)=P1(:,;2);
    FI(1,:)=FI(Nx+1,:);FI(Nx+2,:)=FI(2,:);
    FI(:,1)=FI(:,Nz+1);FI(:,Nx+2)=P1(:,2);
    Fnew(i,k)=(FI(i+1,k)+FI(i-1,k))/C1+ ...
              (FI(i,k+1)+FI(i,k-1))/C2- ...
              (P1(i,k)-P1(i,k-1))*C3;
    Fold=FI;FI=Fnew;
end

原始代码迭代次数为498次,修改后要多迭代100次,而且结果还对不上。注意程序里的C1,C2,C3和方程里的不是一回事。

问题:
1、第二段程序什么地方不正确,导致结果不同。
2、这样的方程是不是有什么方法使用库函数求解。
3、这种迭代格式是否正确。
4、还没想到……
回复此楼

» 猜你喜欢

» 抢金币啦!回帖就可以得到:

查看全部散金贴

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

holmescn

金虫 (正式写手)



余泽成(金币+1):谢谢分享,金币由版面来发! 2010-12-12 20:46:36
看来程序太长的话, 大家都很头痛。 这个问题已经被我师弟解决了, 是我的错误。
见代码段2倒数第6行末尾的P1应该是FI。又是一次复制粘贴的错误。

不过, 我的问题虽然解决了, 本帖也很好地展现了快速matlab程序的写法。 代码段2的运行效率大约是代码段1的10倍。此贴可供初学者围观。

金币将发给有价值的回帖讨论。
2楼2010-12-11 10:51:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 holmescn 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 考研化学学硕调剂,一志愿985 +3 张vvvv 2026-03-15 5/250 2026-03-16 20:25 by 张vvvv
[考研] 286求调剂 +3 lemonzzn 2026-03-16 4/200 2026-03-16 20:13 by zhq0425
[考研] 333求调剂 +3 文思客 2026-03-16 7/350 2026-03-16 18:21 by 文思客
[考研] 化学调剂0703 +8 啊我我的 2026-03-11 8/400 2026-03-16 17:23 by 我的船我的海
[考研] 308求调剂 +3 是Lupa啊 2026-03-16 3/150 2026-03-16 10:07 by 求调剂zz
[考研] 344求调剂 +3 knight344 2026-03-16 3/150 2026-03-16 09:42 by 无际的草原
[考研] 材料专硕326求调剂 +4 墨煜姒莘 2026-03-15 4/200 2026-03-15 11:02 by dyw
[考研] 288求调剂 +4 奇点0314 2026-03-14 4/200 2026-03-14 23:04 by JourneyLucky
[考研] 080500,材料学硕302分求调剂学校 +4 初识可乐 2026-03-14 5/250 2026-03-14 21:08 by peike
[考研] 328求调剂 +3 5201314Lsy! 2026-03-13 6/300 2026-03-14 15:31 by hyswxzs
[考研] 331求调剂(0703有机化学 +5 ZY-05 2026-03-13 6/300 2026-03-14 10:51 by Jy?
[考研] 308 085701 四六级已过求调剂 +7 温乔乔乔乔 2026-03-12 14/700 2026-03-14 10:49 by JourneyLucky
[考研] 328,0703考生求调剂,一志愿为东北师范大学 +4 观素律 2026-03-09 5/250 2026-03-14 01:24 by JourneyLucky
[考研] 306求调剂 +4 唐薏薏 2026-03-09 4/200 2026-03-14 01:19 by JourneyLucky
[考研] 308求调剂 +3 是Lupa啊 2026-03-10 3/150 2026-03-14 00:30 by JourneyLucky
[考研] 26考研调剂 +3 ying123. 2026-03-10 3/150 2026-03-14 00:18 by JourneyLucky
[考研] 304求调剂 +7 7712b 2026-03-13 7/350 2026-03-13 21:42 by peike
[考研] (081700)化学工程与技术-298分求调剂 +12 11啦啦啦 2026-03-11 35/1750 2026-03-13 21:25 by JourneyLucky
[考研] 工科调剂 +4 Jiang191123! 2026-03-11 4/200 2026-03-13 15:15 by Miko19
[硕博家园] 木虫好像不热闹了,是不是? +4 偏振片 2026-03-10 4/200 2026-03-10 09:51 by longwave
信息提示
请填处理意见