《实验一用有限差分法解静电场边值问题1.doc》由会员分享,可在线阅读,更多相关《实验一用有限差分法解静电场边值问题1.doc(33页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date实验一用有限差分法解静电场边值问题1用有限差分法解静电场边值问题实验名称:用有限差分法解静电场边值 时间:2011/5/7地点:电气工程学院 姓名 学号:20094470 用有限差分法解静电场边值问题一、目的1掌握有限差分法的原理与计算步骤;2理解并掌握求解差分方程组的超松弛迭代法,分析加速收敛因子a的作用;3学会用有限差分法解简单的二维静电场边值问题,并编制计算程序
2、。二、方法原理有限差分法是数值计算中应用得最早而又相当简单、直观的一种方法。应用有限差分法通常所采取的步骤是: 采用一定的网格分割方式离散化场域。 进行差分离散化处理。用离散的、只含有限个未知数的差分方程组,来近似代替场域内具有连续变量的偏微分方程以及边界上的边界条件(也包括场域内不同媒质分界面上的衔接条件)。 结合选定的代数方程组的解法,编制计算机程序,求解由上面所得对应于待求边值问题的差分方程组,所得解答即为该边值问题的数值解。现在,以静电场边值问题为例,说明有限差分法的应用。f(s)为边界点s的点函数,二位场域D和边界L示于图5.1-1中。图5.1-1 有限差分的网格分割1 离散化场域应
3、用有限差分法时,首先需从网格划分着手决定离散点的分布方式。通常采用完全有规律的方式,这样在每个离散点上可得出相同形式的差分方程,有效地提高解题速度。如图5.1-1所示,现采用分别与x,y轴平行的等距(步距为h)网格线把场域D分割成足够多的正方形网格。各个正方形的顶点(也即网格线的交点)称为网格的结点。这样,对于场域内典型的内结点0,它与周围相邻的结点1、2、3和4构成一个所谓对称的星形。2差分格式造好网格后,需把上述静电场边值问题中的拉普拉斯方程(1)式离散化。设结点0上的电位值为j0。结点1、2、3和4上的电位值相应为j1、j2、j3和j4,则基于差分原理的应用,拉普拉斯方程(1)式在结点0
4、处可近似表达为j1+j2+j3+j4-4j1=0 (3)这就是规则正方形网格内某点的电位所满足的拉普拉斯方程的差分格式,或差分方程。对于场域内的每一个结点,关系式(3)式都成立,都可以列出一个相同形式的差分方程。但是,对于近邻边界的结点,其边界不一定正好落在正方形网格的结点上,而可能如图5.1-2所示。其中1、2为边界线上的结点,p、q为小于1的正数。仿上所述,可推得对这些近邻边界结点的拉普拉斯方程的差分格式为 (4)式中:1和2分别是给定边界条件函数f (s)在对应边界点处的值,是已知的。图5.1-2 近邻边界的结点3边界条件的近似处理 为了求解给定的边值问题,还必须对边界条件,以及具体问题
5、中可能存在的分界面上的衔接条件,进行差分离散化处理,以构成相应的差分边值问题。这里,我们只考虑正方形网格分割下的边界条件的近似处理。第一类边界条件如果网格结点正好落在边界L上,因此对应于边界条件(2)式的离散化处理,就是把点函数f (s)的值直接赋予对应的边界结点。如果边界L不通过网格分割时所引进的结点(例如图5.1-2中的1、2结点是边界线L与网格线的交点,并不是网格分割时所引进的网格结点),那末在紧邻边界的结点的差分格式应选用(4)式,这时,把点函数f (s)的值直接赋予边界线L与网格线的交点1和2。第二类边界条件应当指出,从实际电场问题的分析出发,如图5.1-3所示,以电力线为边界的第二
6、类齐次边界条件是常见的一种情况。 (5)这时,可沿着场域边界外侧安置一排虚设的网格结点,显然,对于边界结点0,由于该处,故必有j1=j3,因此相应于边界条件(5)式的差分计算格式为2j1+j2+j4-4j0=0 (6) 图5.1-3 第二类齐次边界的一种情况 图5.1-4对称线上结点的差分格式同样,在许多工程问题中,常常能够判定待求电场具有某些对称性质,这样只需要计算某一对称部分的场就能完全决定整个场的分布。为此,还必须导出位于场的对称线上的结点所满足的差分计算格式。以对称线与网格结点相重合为例(见图5.1-4),设线为一对称线,对于位于对称线上的任一结点0,由拉普拉斯方程(因对称性,必有j1
7、=j3)可得相应的差分计算格式是 2j1+j2+j4-4j0=0 (7)媒质分界面上的衔接条件在此选取两种情况进行差分离散化的处理。分界面与网格线相重合的情况;设分界面L与网格线相重合,如图5.1-5所示,在两种媒质和中电位都满足拉普拉斯方程。容易导得,两种媒质分界面上衔接条件在结点0的差分格式为 (8)其中。 图5.1-5 分界面与网格线相重合 图5.1-6 分界面L对网格呈对角线形态分界面对于网格呈对角线形态的情况:如图5.1-6所示,分界面L对于网格呈对角线形态,在两种媒质和中电位j都满足拉普拉斯方程。容易导得,两种媒质分界面上衔接条件在结点0的差分格式为 (9)其中 。总之,类似以上的
8、分析处理方法,可以逐个导得各种类型的边界条件和衔接条件差分离散化的计算格式。限于篇幅,在此不再展开。4差分方程组的求解在对场域D内各个结点(包括所有场域内点和有关的边界结点)逐一列出对应的差分方程,组成差分方程组后,就可选择一定的代数解法,以算出各离散结点上待求的电位值。注意到差分方程组的系数一般是有规律的,且各个方程都很简单,包含的项数不多(最多不超过5项),因此,对于有限差分法,通常都采用逐次近似的迭代方法求解。在迭代法的应用中,为加速迭代解收敛速度,一般采用的是超松弛迭代法。由于编写计算机程序的需要,每一网格结点的位置由双下标(i,j)予以识别,如图5.1-7所示。对于差分方程(3)式,
9、采用超松弛迭代法(规定迭代的运算顺序是:从左下角开始做起,即i小的先做;对固定的i,j小的先做。),则关于结点0迭代到第(n+1)次时的近似值,应由如下迭代公式算得) (10)图5.1-7 结点的双下标(i,j)标号式中:a 称为加速收敛因子,其取值范围是1a1e-5) k=k+1 maxt=0 for i=2:hy-1 for j=2:hx-1 v2(i,j)=v1(i,j)+alpha/4*(v1(i+1,j)+v1(i,j+1)+v2(i-1,j)+v2(i,j-1)-4*v1(i,j); t=abs(v2(i,j)-v1(i,j); if(tmaxt)maxt=t;end end en
10、d v1=v2; end clf subplot(1,2,1),mesh(v2) axis(0,41,0,21,0,100) subplot(1,2,2),contour(v2,15) hold on x=1:1:hx;y=1:1:hy xx,yy=meshgrid(x,y); Gx,Gy=gradient(v2,0.6,0.6); quiver(xx,yy,Gx,Gy,-0.8,r) axis(-1.5,hx+2.5,-2,13) plot(1,1,hx,hx,1,1,hy,hy,1,1,k) text(hx/2,0.3,0v,fontsize,11); text(hx/2-0.5,hy+0
11、.5,100v,fontsize,11); text(hx+0.3,hy/2,0v,fontsize,11); hold off输出数据:010010010100100100100100100100100100100100100100100100100049.45168.6777.42581.9884.58986.17487.1687.7688.08388.18688.08387.7687.1686.17484.58981.9877.42568.6749.4510029.13447.80559.05165.90770.20172.94774.70775.79576.38876.57776.38
12、875.79574.70772.94770.20165.90759.05147.80529.1340019.28134.36545.06652.39557.36260.70862.92464.32565.09865.34565.09864.32562.92460.70857.36252.39545.06634.36519.2810013.62325.3134.45141.24546.14449.59751.95853.48254.33454.60854.33453.48251.95849.59746.14441.24534.45125.3113.623009.901818.826.18631.
13、98836.37339.57841.82943.3144.14844.41944.14843.3141.82939.57836.37331.98826.18618.89.9018007.183613.80419.50224.1527.78330.51332.47233.7834.52834.77234.52833.7832.47230.51327.78324.1519.50213.8047.1836005.02899.7313.86817.32820.09522.21823.76524.81225.41425.61125.41424.81223.76522.21820.09517.32813.8689.735.0289003.20196.21948.911211.19713.05414.49715.56116.28616.70616.84416.70616.28615.56114.49713.05411.1978.91126.21943.2019001.55923.03484.36055.49596.4267.15457.69528.06558.28078.35138.28078.06557.69527.15456.4265.49594.36053.03480.155920000000000000000000000输出图形:-
限制150内