偏微分方程数值解法的MATLAB源码题库.docxVIP

偏微分方程数值解法的MATLAB源码题库.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[原创]偏微分方程数值解法的MATLAB源码【更新完毕】 说明:由于偏微分的程序都比较长,比其他的算法稍复杂一些,所以另开一贴,专门上传偏微分的程序 谢谢大家的支持! 其他的数值算法见: HYPERLINK /Announce/Announce.asp?BoardID=209id=8245004 \t _blank ..//Announce/Announce.asp?BoardID=209id=8245004 1、古典显式格式求解抛物型偏微分方程(一维热传导方程) function [U x t]=PDEParabolicClassicalExplicit(uX,uT,phi,psi1,psi2,M,N,C) %古典显式格式求解抛物型偏微分方程 %[U x t]=PDEParabolicClassicalExplicit(uX,uT,phi,psi1,psi2,M,N,C) % %方程:u_t=C*u_xx 0 = x = uX,0 = t = uT %初值条件:u(x,0)=phi(x) %边值条件:u(0,t)=psi1(t), u(uX,t)=psi2(t) % %输出参数:U -解矩阵,第一行表示初值,第一列和最后一列表示边值,第二行表示第2层…… % ? ?? ?? x -空间变量 % ? ?? ?? t -时间变量 %输入参数:uX -空间变量x的取值上限 % ? ?? ?? uT -时间变量t的取值上限 % ? ?? ?? phi -初值条件,定义为内联函数 % ? ?? ?? psi1 -边值条件,定义为内联函数 % ? ?? ?? psi2 -边值条件,定义为内联函数 % ? ?? ?? M -沿x轴的等分区间数 % ? ?? ?? N -沿t轴的等分区间数 % ? ?? ?? C -系数,默认情况下C=1 % %应用举例: %uX=1;uT=0.2;M=15;N=100;C=1; %phi=inline(sin(pi*x));psi1=inline(0);psi2=inline(0); %[U x t]=PDEParabolicClassicalExplicit(uX,uT,phi,psi1,psi2,M,N,C); %设置参数C的默认值 if nargin==7 ? ? C=1; end %计算步长 dx=uX/M;%x的步长 dt=uT/N;%t的步长 x=(0:M)*dx; t=(0:N)*dt; r=C*dt/dx/dx;%步长比 r1=1-2*r; if r 0.5 ? ? disp(r 0.5,不稳定) end %计算初值和边值 U=zeros(M+1,N+1); for i=1:M+1 ? ? U(i,1)=phi(x(i)); end for j=1:N+1 ? ? U(1,j)=psi1(t(j)); ? ? U(M+1,j)=psi2(t(j)); end %逐层求解 for j=1:N ? ? for i=2:M ? ? ?? ?U(i,j+1)=r*U(i-1,j)+r1*U(i,j)+r*U(i+1,j); ? ? end end U=U; %作出图形 mesh(x,t,U); title(古典显式格式,一维热传导方程的解的图像) xlabel(空间变量 x) ylabel(时间变量 t) zlabel(一维热传导方程的解 U) return; 古典显式格式不稳定情况 古典显式格式稳定情况 2、古典隐式格式求解抛物型偏微分方程(一维热传导方程) function [U x t]=PDEParabolicClassicalImplicit(uX,uT,phi,psi1,psi2,M,N,C) %古典隐式格式求解抛物型偏微分方程 %[U x t]=PDEParabolicClassicalImplicit(uX,uT,phi,psi1,psi2,M,N,C) % %方程:u_t=C*u_xx 0 = x = uX,0 = t = uT %初值条件:u(x,0)=phi(x) %边值条件:u(0,t)=psi1(t), u(uX,t)=psi2(t) % %输出参数:U -解矩阵,第一行表示初值,第一列和最后一列表示边值,第二行表示第2层…… % ? ?? ?? x -空间变量 % ? ?? ?? t -时间变量 %输入参数:uX -空间变量x的取值上限 % ? ?? ?? uT -时间变量t的取值上限 % ? ?? ?? phi -初值条件,定义为内联函数 % ? ?? ?? psi1 -边值条件,定义为内联函数 % ? ?? ?? psi2 -边值条件,定义为内联函数 % ? ?? ?? M -沿x轴的等分区间数 % ? ?? ?

文档评论(0)

1112111 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档