matlaB程序的有限元法解泊松方程

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

基于matlaB编程的有限元法一、待求问题:泛定方程:2=x边界条件:以(0,-1),(0,1),(1,0)为顶点的三角形区域边界上=0二、编程思路及方法1、给节点和三角形单元编号,并设定节点坐标画出以(0,-1),(0,1),(1,0)为顶点的三角形区域figure1由于积分区域规则,故采用特殊剖分单元,将区域沿水平竖直方向分等份,此时所有单元都是等腰直角三角形,剖分单元个数由自己输入,但竖直方向份数(用Jmax表示)必须是水平方向份数(Imax)的两倍,所以用户只需输入水平方向的份数Imax。采用上述剖分方法,节点位置也比较规则。然后利用循环从区域内部(非边界)的节点开始编号,格式为NN(i,j)=n1,i,j分别表示节点所在列数与行数,并将节点坐标存入相应矩阵X(n1),Y(n1)。由于区域上下两部分形状不同因此,分两个循环分别编号赋值,然后再对边界节点编号赋值。然后再每个单元的节点进行局部编号,由于求解区域和剖分单元的特殊性,分别对内部节点对应左上角正方形的两个三角形单元,上左,左上,下斜边界节点要对应三个单元,上左,左上,左下,右顶点的左下、左上,右上边界的左上,分别编号以保证覆盖整个区域。2、求解泊松方程首先一次获得每个单元节点的整体编号,然后根据其坐标求出每个三角形单元的面积。利用有限元方法的原理,分别求出系数矩阵和右端项,并且由于边界条件特殊,边界上=0,因此做积分时只需对场域单元积分而不必对边界单元积分。求的两个矩阵后很容易得到节点电位向量,即泊松方程的解。3、画解函数的平面图和曲面图由节点单位向量得到,j行i列节点的电位,然后调用绘图函数imagesc(NNV)与surf(X1,Y1,NNV')分别得到解函数的平面图figure2和曲面图figure3。4、将结果输出为文本文件输出节点编号,坐标,电位值三、计算结果1、积分区域:00.10.20.30.40.50.60.70.80.91-1-0.8-0.6-0.4-0.200.20.40.60.812、f=1,x方向75份,y方向150份时,解函数平面图和曲面图20406080100120140102030405060700.0050.010.0150.020.0250.0300.20.40.60.8100.511.5200.010.020.030.040.0050.010.0150.020.0250.03对比:当f=1时,界函数平面图20406080100120140102030405060700.010.020.030.040.050.060.073、输出文本文件由于节点多较大,列在本文最末四、结果简析由于三角形区域分布的是正电荷,因此必定电位最高点在区域中部,且沿x轴对称,三角形边界电位最低等于零。当f=1时,发现电位最高点向x轴负方向移动了,这是由于此时电荷在三角形区域上均匀分布,而f=x时,x越大面电荷密度越大,附近相应电位越高,所得图像与实际情况相符。五、MatlaB源程序1、Finite_element_tri.m文件functionFinite_element_tri(Imax)%用有限元法求解三角形形区域上的Possion方程,其中a为1,f=xJmax=2*Imax;%其中ImaxJmax分别表示x轴和y轴方向的网格数,其中Jmax等于Imax的两倍%定义一些全局变量globalndmnelna%ndm总节点数%nel基元数%na表示活动节点数V=0;J=0;X0=1/Imax;Y0=X0;%V=0为边界条件domain_tri%调用函数画求解区域[X,Y,NN,NE]=setelm_tri(Imax,Jmax);%给节点和三角形元素编号,并设定节点坐标%以下求解有限元方程的求系数矩阵T=zeros(ndm,ndm);forn=1:neln1=NE(1,n);n2=NE(2,n);n3=NE(3,n);%整体编号s=abs((X(n2)-X(n1))*(Y(n3)-Y(n1))-(X(n3)-X(n1))*(Y(n2)-Y(n1)))/2;%三角形面积fork=1:3ifn1=na|n2=naT(n1,n2)=T(n1,n2)+((Y(n2)-Y(n3))*(Y(n3)-Y(n1))+(X(n3)-X(n2))*(X(n1)-X(n3)))/(4*s);T(n2,n1)=T(n1,n2);T(n1,n1)=T(n1,n1)+((Y(n2)-Y(n3))^2+(X(n3)-X(n2))^2)/(4*s);%V=0则边界积分为零,非零时积分编程类似,再加边界积分。endk=n1;n1=n2;n2=n3;n3=k;%轮换坐标将值赋入3阶主子矩阵中endendM=T(1:na,1:na);%求有限元方程的右端项f=X;%场源函数G=zeros(na,1);forn=1:neln1=NE(1,n);n2=NE(2,n);n3=NE(3,n);s=abs((X(n2)-X(n1))*(Y(n3)-Y(n1))-(X(n3)-X(n1))*(Y(n2)-Y(n1)))/2;fork=1:3ifn1=naG(n1)=G(n1)+(2*f(n1)+f(n2)+f(n3))*s/12;%f在单元上为线性差值时场域单元的积分公式endn4=n1;n1=n2;n2=n3;n3=n4;%轮换坐标标endendF=M\G;%求解方程得结果NNV=zeros(Imax+1,Jmax+1);fi=zeros(ndm,1);fi(1:na)=F(1:na);fi(na+1:ndm)=V;forj=0:Jmaxfori=0:Imaxn=NN(i+1,j+1);ifn=0n=na+1;endNNV(i+1,j+1)=fi(n);endendfigure(2)imagesc(NNV);%画解函数的平面图X1=zeros(1,Imax+1);Y1=zeros(1,Jmax+1);fori=1:Imax+1X1(i)=(i-1)*X0;endfori=1:Jmax+1Y1(i)=(i-1)*Y0;endfigure(3)surf(X1,Y1,NNV');%画解函数的曲面图%以下是结果的输出fid=fopen('Finite_element_tri.txt','w');fprintf(fid,'\n*********有限元法求解三角形区域上Possion方程的结果**********\n\n');L=[1:ndm]';fprintf(fid,'\n\n节点编号坐标分量x坐标分量yu(x,y)的值\n\n');fori=1:ndmfprintf(fid,'%8d%14.5f%14.5f%14.5f\n',L(i),X(i),Y(i),fi(i));endfclose(fid);End2、domain_tri.m文件functiondomain_tri%画求解区域xy=[01;0-1;10];A=zeros(3,3);A(1,1)=2;A(1,2)=-1;A(1,3)=-1;A(2,2)=2;A(2,1)=-1;A(2,3)=-1;A(3,3)=2;A(3,2)=-1;A(3,1)=-1;A=sparse(A);figure(1);gplot(A,xy);3、setelm_tri.m文件function[X,Y,NN,NE]=setelm_tri(Imax,Jmax)%给节点和三角形单元编号,并设定节点坐标%定义一些全局变量globalndmnelna%I1I2J1J2ImaxJmax分别描述网线纵向和横向数目的变量%XY表示节点坐标%NN描述节点编号%NE描述各单元局部节点编号与总体编号对应的矩阵%ndm总节点数%nel单元数%na表示不含边界的节点数nlm=Imax*Jmax;dx=1/Imax;dy=1/Jmax;X=nlm:1;Y=nlm:1;NN=zeros(Imax+1,Jmax+1);n1=0;forj=3:Jmax/2fori=2:j-1n1=n1+1;NN(i,j)=n1;%X=i列,Y=j行处节点X(n1)=(i-1)*dx;Y(n1)=-1+(j-1)*dy;endendk=Jmax/2+1;forj=Jmax/2+1:Jmax-1%三角形区域上下两部分节点坐标分别求k=k-1;fori=2:kn1=n1+1;NN(i,j)=n1;X(n1)=(i-1)*dx;Y(n1)=1+(j-Jmax-1)*dy;endendna=n1;%不含边界节点数forj=Jmax+1:-1:Jmax/2+1%降序n1=n1+1;NN(1,j)=n1;X(n1)=0;Y(n1)=1+(j-Jmax-1)*dy;endforj=Jmax/2:-1:1n1=n1+1;NN(1,j)=n1;X(n1)=0;Y(n1)=-1+(j-1)*dy;end%fori=2:Imax+1n1=n1+1;NN(i,i)=n1;X(n1)=(i-1)*dx;Y(n1)=-1+(i-1)*dy;endK=0;fori=Imax:-1:2K=K+2;n1=n1+1;NN(i,i+K)=n1;X(n1)=(i-1)*dx;Y(n1)=1+(i+K-Jmax-1)*dy;end%以上四个循环为对边界节点进行编号ndm=n1;NE=zeros(3,2*ndm);n1=0;forj=3:Jmax/2fori=2:j-1n1=n1+1;NE(1,n1)=NN(i,j);NE(2,n1)=NN(i-1,j+1);NE(3,n1)=NN(i-1,j);n1=n1+1;NE(1,n1)=NN(i,j);NE(2,n1)=NN(i,j+1);NE(3,n1)=NN(i-1,j+1);endendk=Jmax/2+1;forj=Jmax/2+1:Jmax-1k=k-1;fori=2:kn1=n1+1;NE(1,n1)=NN(i,j);NE(2,n1)=NN(i-1,j+1);NE(3,n1)=NN(i-1,j);n1=n1+1;NE(1,n1)=NN(i,j);NE(2,n1)=NN(i,j+1);NE(3,n1)=NN(i-1,j+1);endend%内部节点对应左上角正方形的两个三角形单元,上左,左上fori=2:Imaxn1=n1+1;NE(1,n1)=NN(i,i);NE(2,n1)=NN(i-1,i);NE(3,n1)=NN(i-1,i-1);n1=n1+1;NE(1,n1)=NN(i,i);NE(2,n1)=NN(i-1,i+1);NE(3,n1)=NN(i-1,i);n1=n1+1;NE(1,n1)=NN(i,i);NE(2,n1)=NN(i,i+1);NE(3,n1)=NN(i-1,i+1);end%下斜边界节点要对应三个单元,上左,左上,左下n1=n1+1;NE(1,n1)=NN(Imax+1,Imax+1);NE(2,n1)=NN(Imax,Imax+1);NE(3,n1)=NN(Imax,Imax);%右顶点的左下n1=n1+1;NE(1,n1)=NN(Imax+1,Imax+1);NE(2,n1)=NN(Imax,Imax+2);NE(3,n1)=NN(Imax,Imax+1);%右顶点的左上K=0;fori=Imax:-1:2K=K+2;n1=n1+1;NE(1,n1)=NN(i,i+K);NE(2,n1)=NN(i-1,i+K+1);NE(3,n1)=NN(i-1,i+K);end%右上边界的左上nel=n1;%此时n1值为总的单元个数六、输出文本文件*********有限元法求解三角形区域上Possion方程的结果**********节点编号坐标分量x坐标分量yu(x,y)的值10.01333-0.986670.0000020.01333-0.980000.0000130.02667-0.980000.0000140.01333-0.973330.0000250.02667-0.973330.0000360.04000-0.973330.0000270.01333-

1 / 138
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功