如何用Matlab求解偏微分方程,并画出图像

 我来答
lhmhz
高粉答主

2018-05-20 · 专注matlab等在各领域中的应用。
lhmhz
采纳数:7264 获赞数:17023

向TA提问 私信TA
展开全部

用Matlab求解偏微分方程,可以用pde工具箱来解决。例如,简单的点热源方程

求解步骤及主要函数:

1、问题定义

2、创建具有单个因变量的PDE模型, createpde()

3、创建几何结构并将其追加到PDE模型中,geometryFromEdges()

4、使用边界条件,pdegplot()

5、指定PDE系数

6、指定初始条件,setInitialConditions()

7、生成网格,pdemesh()

8、生成时间离散化

9、求解数值解,solvepde()

10、绘图解的图形,pdeplot()

执行代码:

clc

R1 = [3;4;-1;1;1;-1;-1;-1;1;1];

C1 = [1;0;0;0.4];

C1 = [C1;zeros(length(R1) - length(C1),1)];

gd = [R1,C1];

sf = 'R1+C1';

ns = char('R1','C1')';

g = decsg(gd,sf,ns);

numberOfPDE = 1;

pdem = createpde(numberOfPDE);

geometryFromEdges(pdem,g);

figure

pdegplot(pdem,'edgeLabels','on','subdomainLabels','on')

axis([-1.1 1.1 -1.1 1.1]);

axis equal

title 'Geometry With Edge and Subdomain Labels'

applyBoundaryCondition(pdem,'Edge',(1:4),'u',0);

specifyCoefficients(pdem,'m',0, 'd',1, 'c',1, 'a',0,'f',1);

setInitialConditions(pdem,0);

setInitialConditions(pdem,1,'face',2);

msh = generateMesh(pdem);

figure;

pdemesh(pdem); 

axis equal

nframes = 20;

tlist = linspace(0,0.1,nframes);

pdem.SolverOptions.ReportStatistics ='on';

result = solvepde(pdem,tlist);

u1 = result.NodalSolution;

figure

umax = max(max(u1));

umin = min(min(u1));

for j = 1:nframes,

pdeplot(pdem,'xydata',u1(:,j),'zdata',u1(:,j));

caxis([umin umax]);

axis([-1 1 -1 1 0 1]);

Mv(j) = getframe;

end

movie(Mv,1);

运行结果

Sievers分析仪
2025-01-06 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准... 点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式