《牛顿拉夫逊法潮流计算.doc》由会员分享,可在线阅读,更多相关《牛顿拉夫逊法潮流计算.doc(34页珍藏版)》请在三一办公上搜索。
1、目录摘要11.设计意义与要求21.1设计意义21.2设计要求22.牛顿拉夫逊算法32.1牛顿算法数学原理:32.2 直角坐标系下牛顿法潮流计算的原理43 详细设计过程93.1节点类型93.2待求量93.3导纳矩阵93.4潮流方程103.5修正方程114.程序设计144.1 节点导纳矩阵的形成144.2 计算各节点不平衡量154.3 雅克比矩阵计算- 17 -4.4 LU分解法求修正方程- 19 -4.5 计算网络中功率分布- 22 -5.结果分析- 22 -6.小结- 25 -参考文献- 26 -附录:- 27 -摘要潮流计算是电力网络设计及运行中最基本的计算,对电力网络的各种设计方案及各种运
2、行方式进行潮流计算,可以得到各种电网各节点的电压,并求得网络的潮流及网络中各元件的电力损耗,进而求得电能损耗。在数学上是多元非线性方程组的求解问题,求解的方法有很多种。牛顿拉夫逊法是数学上解非线性方程式的有效方法,有较好的收敛性。将牛顿法用于潮流计算是以导纳矩阵为基础的,由于利用了导纳矩阵的对称性、稀疏性及节点编号顺序优化等技巧,使牛顿法在收敛性、占用内存、计算速度等方面都达到了一定的要求。本文以一个具体例子分析潮流计算的具体方法,并运用牛顿拉夫逊算法求解线性方程关键词: 电力系统 潮流计算 牛顿拉夫逊算法1.设计意义与要求1.1设计意义潮流计算是电力系统分析中的一种最基本的计算,他的任务是对
3、给定运行条件确定系统运行状态,如各母线上的电压(幅值及相角)、网络中的功率分布及功率损耗等。潮流计算的结果是电力系统稳定计算和故障分析的基础。具体表现在以下方面: (1)在电网规划阶段,通过潮流计算,合理规划电源容量及接入点,合理规划网架,选择无功补偿 方案,满足规划水平的大、小方式下潮流交换控制、调峰、调相、调压的要求。 (2)在编制年运行方式时,在预计负荷增长及新设备投运基础上,选择典型方式进行潮流计算,发 现电网中薄弱环节,供调度员日常调度控制参考,并对规划、基建部门提出改进网架结构,加快基建进度的建议。 (3)正常检修及特殊运行方式下的潮流计算,用于日运行方式的编制,指导发电厂开机方式
4、,有 功、无功调整方案及负荷调整方案,满足线路、变压器热稳定要求及电压质量要求。 (4)预想事故、设备退出运行对静态安全的影响分析及作出预想的运行方式调整方案。 总结为在电力系统运行方式和规划方案的研究中,都需要进行潮流计算以比较运行方式或规划供电方 案的可行性、可靠性和经济性。同时,为了实时监控电力系统的运行状态,也需要进行大量而快速的潮流计算。因此,潮流计算是电力系统中应用最广泛、最基本和 最重要的一种电气运算。在系统规划设计和安排系统的运行方式时,采用离线潮流计算;在电力系统运行状态的实时监控中,则采用在线潮流计算。1.2设计要求1)根据给定的运行条件,确定图中电力系统潮流计算时各节点的
5、类型、待求量;2)求节点导纳矩阵;3)给出潮流方程或功率方程的表达式;4)当用牛顿拉夫逊法计算潮流时,给出修正方程和迭代收敛条件;2.牛顿拉夫逊算法2.1牛顿算法数学原理:牛顿法 (Newton Method):解非线性方程f(x)=0的牛顿(Newton) 法,就是将非线性方程线性化的一种方法。它是解代数方程和超越方程的有效方法之一。设有单变量非线性方程,给出解的近似值,它与真解的误差为,则将满足,即 将上式左边的函数在附近展成泰勒级数,如果差值很小,二次及以上阶次的各项均可略去得:这是对于变量的修正量的线性方程式,成为修正方程,解此方程可得修正量用所求得的去修正近似解,便得修正后的近似解同
6、真解仍然有误差。为了进一步逼近真解,可以反复进行迭代计算,迭代计算通式是迭代过程的收敛判据为式中,和为预先给定的小正数。牛顿-拉夫逊法实质上就是切线法,是一种逐步线性化的方法,此法不仅用于求单变量方程,也适用于多变量非线性代数方程的有效方法。牛顿法至少是二阶收敛的,即牛顿法在单根附近至少是二阶收敛的,在重根附近是线性收敛的。 牛顿法收敛很快,而且可求复根,缺点是对重根收敛较慢,要求函数的一阶导数存在。2.2 直角坐标系下牛顿法潮流计算的原理采用直角坐标时,节点电压可表示为导纳矩阵元素则表示为将上述表示式代入的右端,展开并分出实部和虚部,便得 假定系统中的第1,2,3,m号节点为PQ节点,第i个
7、节点的给定功率设为和,对该节点可列写方程 (i=1,2,m) 假定系统中的第m+1,m+2,n-1号节点为PV节点,则对其中每一个节点可以列写方程(i=m+1,m+2,n-1)第n号节点为平衡点,其电压是给定的,故不参加迭代。以上两个方程组总共包含了2(n-1)个方程,待求的变量有也是2(n-1)个。我们还可看到,上面两个方程式已经具备了方程组的形式。因此,不难写出如下的修正方程式 式中上述方程中雅克比矩阵的各元素,可以对上式求偏导数获得。当时当时修正方程式还可以写成分块矩阵的形式式中,和都是二维列向量;是介方阵。对于PQ节点对于PV节点从以上表达式可以看到,雅克比矩阵有以下特点:(1) 雅克
8、比矩阵各元素都是节点电压的函数,它们的数值将在迭代过程中不断的改变。(2) 雅克比矩阵的子块中的元素的表达式只用到导纳矩阵中的对应元素。若,则必有。因此,式中分块形式的雅克比矩阵同节点导纳矩阵一样稀疏,修正方程的求解同样可以用稀疏矩阵的求解技巧。(3) 雅克比矩阵的元素或子块都不具有对称性。用牛顿-拉夫逊法计算潮流的流程:首先要输入网络的原始数据以及各节点的给定值并形成节点导纳矩阵。输入节点电压初值和,置迭代计数k=0。然后开始进入牛顿法的迭代过程。在进行第k+1次迭代时,其计算步骤如下:(1) 按上一次迭代计算出的节点电压值和,计算各类节点的不平衡量、和。(2) 按条件校验收敛,即 如果收敛
9、,迭代到此结束,转入计算各线路潮流和平衡节点的功率,并打印输出计算结果。不收敛则继续计算。(3)计算雅克比矩阵的各元素。(4)解修正方程式,求节点电压的修正量和。(5)修正各节点的电压(6)迭代计数加1,返回第一步继续迭代过程。输入原始数据形成节点导纳矩阵给定节点电压初值k=0计算是否计算雅克比矩阵各元素解修正方程式,求,计算平衡节点功率输出图1牛顿-拉夫逊法潮流计算程序框图3 详细设计过程3.1节点类型电力系统潮流计算中,节点一般分为如下几种类型:PQ节点:节点注入的有功功率无功功率是已知的PV节点:节点注入的有功功率已知,节点电压幅值恒定,一般由无功储备比较充足的电厂和电站充当;平衡节点:
10、节点的电压为1*exp(0),其注入的有功无功功率可以任意调节,一般由具有调频发电厂充当。更复杂的潮流计算,还有其他节点,或者是这三种节点的组合,在一定条件下可以相互转换。对于本题目,节点分析如下:节点1给出有功功率为2,无功功率为1, PQ节点。节点2给出有功功率为0.5,电压幅值为1.0,PV节点。节点3电压相位是0,电压幅值为1,平衡节点。3.2待求量节点1待求量是V,; 节点2待求量是Q,;节点3待求量是P,Q。3.3导纳矩阵导纳矩阵分为节点导纳矩阵、结点导纳矩阵、支路导纳矩阵、二端口导纳矩阵。结点导纳矩阵:对于一个给定的电路(网络),由其关联矩阵A与支路导纳矩阵Y所确定的矩阵。支路导
11、纳矩阵:表示一个电路中各支路导纳参数的矩阵。其行数和列数均为电路的支路总数。二端口导纳矩阵:对应y于二端口网络方程,由二端口参数组成节点导纳矩阵:以导纳的形式描述电力网络节点注入电流和节点电压关系的矩阵。它给出了电力网络连接关系和元件特性的全部信息,是潮流计算的基础方程式。 本例应用结点导纳矩阵具体计算时,根据如下公式:由题给出的导纳可求的节点导纳矩阵如下:进而节点导纳矩阵为: 3.4潮流方程网络方程是潮流计算的基础,如果给出电压源或电流源,便可解得电流电压分布。然而,潮流计算中,这些值都是无法准确给定的,这样,就需要列出潮流方程。对n个节点的网络,电力系统的潮流方程一般形式是 (i=1,2,
12、n)其中,即PQ分别为节点的有功功率无功功率。3.5修正方程计算节点1的不平衡量计算节点2的不平衡量节点3是平衡节点,其电压是给定的,故不参加迭代。根据给定的容许误差,按收敛判据进行校验,以上节点1、2的不平衡量都未满足收敛条件,于是继续以下计算。修正方程式为: (n=3)以上雅可比矩阵J中的各元素值是通过求偏导数获得的,对PQ节点来说,是给定的,因而可以写出 对PV节点来说,给定量是,因此可以列出当时, 雅可比矩阵中非对角元素为当时,雅可比矩阵中对角元素为:代入数值后的修正方程为:求解修正方程得:3.6收敛条件一轮迭代结束,根据收敛条件收敛判据,若等式成立,结果收敛,迭代结束,计算平衡节点的
13、功率和线路潮流计算,否则继续计算雅可比矩阵,解修正方程,直到满足收敛判据。4.程序设计4.1 节点导纳矩阵的形成导纳矩阵元素则表示为/*计算导纳矩阵*G11=1.25;B11=-5.5;G22=1.3;B22=-7;G33=1.55;B33=-6.5;G12=G21=-0.5;B12=B21=3;G13=G31=-0.75;B13=B31=2.5;G23=G32=-0.8;B23=B32=4;for(i=1;i4;i+)for(j=1;j4;j+)printf(%f+(%f)j,Gij,Bij);printf( );printf(n);/形成节点导纳矩阵/*printf(n);4.2 计算各节
14、点不平衡量假定系统中的第1,2,3,m号节点为PQ节点,第i个节点的给定功率设为和,对该节点可列写方程 (i=1,2,m) 假定系统中的第m+1,m+2,n-1号节点为PV节点,则对其中每一个节点可以列写方程 (i=m+1,m+2,n-1) 第n号节点为平衡点,其电压是给定的,故不参加迭代,其计算程序如下:/计算各节点不平衡量loop1:printf(迭代次数k1=%dn,k1);for (i=1;i3;i+)float a=0,b=0;for(j=1;j4;j+)a+=Gij*ej-Bij*fj; b+=Gij*fj+Bij*ej;Pi=Psi-(ei*a+fi*b);/计算有功功率的增量Q
15、i=Qsi-(fi*a-ei*b);/计算无功功率的增量V22=V2s*V2s-e2*e2;printf(有功功率增量P1=%f,P1); printf( ,);printf(n);printf(有功功率增量P2=%f,P2); printf( ,);printf(n);printf(无功功率增量Q1=%f,Q1); printf( ,);printf(n);printf(电压增量V22=%f,V22);printf(n)4.3 雅克比矩阵计算上述方程中雅克比矩阵的各元素,可以对计算各点不平衡量得公式中求偏导数获得。当时当时以下为程序:/*形成雅克比矩阵*for(j=1;j3;j+)if(1=
16、j)float c=0,d=0;int m;for(m=1;m4;m+)c+=G1m*em-B1m*fm; d+=G1m*fm+B1m*em;J1*N-1j*N-1=-c-G1j*e1-B1j*f1;J1*N-1j*N=-d+B1j*e1-G1j*f1;J1*Nj*N-1=d+B1j*e1-G1j*f1;J1*Nj*N=-c+G1j*e1+B1j*f1;elseJ1*N-1j*N-1=-G1j*e1-B1j*f1; J1*Nj*N=G1j*e1+B1j*f1; J1*N-1j*N=B1j*e1-G1j*f1; J1*Nj*N-1=B1j*e1-G1j*f1;for(j=1;j3;j+)if(2
17、=j)float c=0,d=0;int m;for(m=1;m4;m+)c+=G2m*em-B2m*fm; d+=G2m*fm+B2m*em;J2*N-1j*N-1=-c-G2j*e2-B2j*f2;J2*N-1j*N=-d+B2j*e2-G2j*f2;J2*Nj*N-1=-2*e2;J2*Nj*N=-2*f2;elseJ2*N-1j*N-1=-G2j*e2-B2j*f2;J2*Nj*N=0;J2*N-1j*N=B2j*e2-G2j*f2;J2*Nj*N-1=0;printf(雅克比矩阵是:n);for(i=1;i5;i+)for(j=1;j5;j+)printf(%f,Jij);print
18、f( );printf(n);4.4 LU分解法求修正方程LU分解,又称Gauss消去法,可把任意方阵分解成下三角矩阵的基本变换形式(行交换)和上三角矩阵的乘积。其数学表达式为:A=LU。其中L为下三角矩阵的基本变换形式,U为上三角矩阵。若有矩阵Ax=b 把矩阵LU分解,求AX=b的问题就等价于求出A=LU后:因为Ly=b可求y,再因为Ux=y,可求出x。原始的求法x=A(-1)*b,某些情况下,如果矩阵A中的数非常小,我认为不是因为大数除以小数误差大么,1/A算出的误差会很大。但LU可以把A分解成两个都比A大的矩阵的乘积,1/L的误差比1/A小的多。求修正方程的程序如下/*计算修正方程*fo
19、r(i=1;iM;i+)Lii=1;for(i=1;iM;i+)U1i=J1i;Li1=Ji1/U11;for(n=2;nM;n+)for(j=n;jM;j+)sigma1=0;for(s=0;s=n-1;s+)sigma1+=Lns*Usj;Unj=Jnj-sigma1;for(i=n;iM;i+)sigma2=0;for(s=0;s=n-1;s+)sigma2+=Lis*Usn;Lin=(Jin-sigma2)/Unn;b1=P1;b2=Q1;b3=P2;b4=V22;for(i=1;iM;i+)sigma1=0;for(n=1;n=1;i-)sigma2=0;for(n=i+1;nM;n
20、+)sigma2+=Uin*xn;xi=(yi-sigma2)/Uii;xe1=-x1;xe2=-x3; xf1=-x2;xf2=-x4; printf(节点电压:n);for(i=1;i3;i+)ei+=xei; fi+=xfi;for(i=1;i3;i+)printf(e%d=,i); printf(%f,ei); printf( ,);for(i=1;i3;i+)printf(f%d=,i); printf(%f,fi); printf( ,);printf(n)4.5 计算网络中功率分布最后要计算出平衡节点的功率和网络中的功率分布。5.结果分析给定节点电压初值,经过五次迭代过程后,得到
21、程序的显示结果如下(取):整理可得节点电压和不平衡功率的变化情况,分别于表1和表2所示:迭代计数k节点电压10.745335-j0.3611421.000000-j0.101537120.417760-j0.3509870.995147-j0.149334131.318158-j0.3801951.019448-j0.019812140.832411-j0.3642720.998876-j0.087212150.508103-j0.3541400.995799-j0.1353301表1 迭代过程中节点电压变化情况迭代计数k节点不平衡量0-2.000000-1.0000000.5000000.0
22、000001-0.148189-0.976948-0.0726420.0000002-0.086588-0.595284-0.0495680.0096833-0.653416-4.467996-0.365523-0.0392754-0.191594-1.288891-0.1011960.0022475-0.084434-0.585319-0.0496760.008383表2 迭代过程中节点不平衡量变化情况进行了五次迭代,结果仍然没有收敛。 经过查找相关的资料得到:“多年的实践证明,牛顿法具有很好的二次收敛性,是求解多元非线性方程的经典算法,至今仍是电力系统潮流计算的主流。因此,一般认为算法不是
23、导致不收敛的原因,潮流不收敛产生的主要原因是计算的初始条件给得不合理,导致潮流方程无解。” 中国自动化网. 改善调度员潮流计算收敛性的措施6.小结通过本次电力系统分析课程设计,使我了解了自己在哪些方面有缺陷。首先,在拿到本次课设的题目时,就看不懂题目!这就给了自己一个不小的打击。于是我认真地看电力系统分析下册有关潮流计算的牛顿-拉夫逊法!了解了何谓PQ节点,PV节点,平衡节点等。大体上知道了运用牛顿-拉夫逊法的各个步骤!其次,读题的过程中也遇到了一些麻烦:1.不知道图中节点二的“0.5”和“1”分别指代的是什么?2.各个节点对应的是什么节点?通过自己上网查资料,在网上看到了一些人有关的说法以及
24、相似的题目的解答,这给我不小的启发!我认识到了查找资料的重要性!经过了自己的努力,我知道了以上的答案:1.节点二中的“0.5”是有功功率,“1”代表的是电压幅值。2.节点1是PQ节点,节点2是PV节点,节点3是平衡节点。最后,遇到了最难难的地方:用程序来实现牛顿-拉夫逊算法!起初是想用matlab程序来进行程序的编写并进行仿真,但是查找了一些资料以后,由于自己对于matlab的了解并不深而且自己学习的知识也不够扎实,给自己带来了不小的麻烦最终无法完成牛顿-拉夫逊的算法。后来在网上找到了有关C语言的相关程序!经过了自己的仔细研读,了解了各个函数的作用。经过了自己的改造将程序完整的编辑了出来,并实
25、现的预期的功能!通过本次课程设计,我知道了自己学习的知识还不够扎实!很多方面只是应付考试,到了让你做东西的时候确实还是相当困难的!尤其是在编程方面的缺陷!现如今是一个软硬件相结合的时代,其中软件更具有竞争性。因此在今后的学习过程中要端正学习态度。做好每一个细节,不断完善自我,提高自身的学习的水平。为将来的学习和工作打下良好的基础!参考文献1 何仰赞等.电力系统分析上册M武汉:华中理工大学出版社.2 何仰赞等.电力系统分析下册M武汉:华中理工大学出版社.3 诸俊伟等.电力系统分析M.北京:中国电力出版社,1995.4 周全仁等.电网计算与程序设计M.长沙:湖南科学技术出版社,1983.5丁化成.
26、单片机应用技术A.北京:北京航空航天大学出版社,2000.附录:#include #include #include #define N 2#define M 5main()double G44,B44,J55;float e4=0,1,1,1,f4=0,P4,Q4,Ps4=0,-2,0.5,xe3,xf3;float Qs4=0,-1,V2s=1,float V22,max,P3,Q3;float a1=0,b1=0;int i,j,n,s,k1=0;float LMM=0,UMM=0,sigma1,sigma2,bM,yM,xM;/*计算导纳矩阵*G11=1.25;B11=-5.5;G22
27、=1.3;B22=-7;G33=1.55;B33=-6.5;G12=G21=-0.5;B12=B21=3;G13=G31=-0.75;B13=B31=2.5;G23=G32=-0.8;B23=B32=4;for(i=1;i4;i+)for(j=1;j4;j+)printf(%f+(%f)j,Gij,Bij);printf( );printf(n);/形成节点导纳矩阵/*printf(n);/*/计算各节点不平衡量loop1:printf(迭代次数k1=%dn,k1);for (i=1;i3;i+)float a=0,b=0;for(j=1;jfabs(P2)?fabs(P1):fabs(P2)
28、;max=maxfabs(Q1)?max:fabs(Q1);max=maxfabs(V22)?max:fabs(V22);printf(max=%fn,max);/*while (k1=4)/*形成雅克比矩阵*for(j=1;j3;j+)if(1=j)float c=0,d=0;int m;for(m=1;m4;m+)c+=G1m*em-B1m*fm; d+=G1m*fm+B1m*em;J1*N-1j*N-1=-c-G1j*e1-B1j*f1;J1*N-1j*N=-d+B1j*e1-G1j*f1;J1*Nj*N-1=d+B1j*e1-G1j*f1;J1*Nj*N=-c+G1j*e1+B1j*f
29、1;elseJ1*N-1j*N-1=-G1j*e1-B1j*f1; J1*Nj*N=G1j*e1+B1j*f1; J1*N-1j*N=B1j*e1-G1j*f1; J1*Nj*N-1=B1j*e1-G1j*f1;for(j=1;j3;j+)if(2=j)float c=0,d=0;int m;for(m=1;m4;m+)c+=G2m*em-B2m*fm; d+=G2m*fm+B2m*em;J2*N-1j*N-1=-c-G2j*e2-B2j*f2;J2*N-1j*N=-d+B2j*e2-G2j*f2;J2*Nj*N-1=-2*e2;J2*Nj*N=-2*f2;elseJ2*N-1j*N-1=-G
30、2j*e2-B2j*f2;J2*Nj*N=0;J2*N-1j*N=B2j*e2-G2j*f2;J2*Nj*N-1=0;printf(雅克比矩阵是:n);for(i=1;i5;i+)for(j=1;j5;j+)printf(%f,Jij);printf( );printf(n);/*计算修正方程*for(i=1;iM;i+)Lii=1;for(i=1;iM;i+)U1i=J1i;Li1=Ji1/U11;for(n=2;nM;n+)for(j=n;jM;j+)sigma1=0;for(s=0;s=n-1;s+)sigma1+=Lns*Usj;Unj=Jnj-sigma1;for(i=n;iM;i+
31、)sigma2=0;for(s=0;s=n-1;s+)sigma2+=Lis*Usn;Lin=(Jin-sigma2)/Unn;b1=P1;b2=Q1;b3=P2;b4=V22;for(i=1;iM;i+)sigma1=0;for(n=1;n=1;i-)sigma2=0;for(n=i+1;nM;n+)sigma2+=Uin*xn;xi=(yi-sigma2)/Uii;xe1=-x1;xe2=-x3; xf1=-x2;xf2=-x4; printf(节点电压:n);for(i=1;i3;i+)ei+=xei; fi+=xfi;for(i=1;i3;i+)printf(e%d=,i); printf(%f,ei); printf( ,);for(i=1;i3;i+)printf(f%d=,i); printf(%f,fi); printf( ,);printf(n);k1=k1+1;goto loop1;for(j=1;j4;j+)a1+=G3j*ej-B3j*fj; b1+=G3j*fj+B3j*ej;P3=e3*a1+f3*b1;Q3=f3*a1-e3*b1;printf(P3+jQ3=%f+j%f,P3,Q3);printf(n);