matlab电力系统快速解耦法潮流计算及短路计算程序精品资料.doc
《matlab电力系统快速解耦法潮流计算及短路计算程序精品资料.doc》由会员分享,可在线阅读,更多相关《matlab电力系统快速解耦法潮流计算及短路计算程序精品资料.doc(34页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、电力系统快速解耦法潮流分析及短路计算 一程序设计的基本思想:(1) 由于电力系统潮流分析中要利用到矩阵运算,复数运算,故采用matlab编程。采用文件输入,将系统的各个参数以文件的形式输入,便于程序的通用化。(2) 本程序共有两个输入文件,分别为线路参数的文件,和已知的节点状态文件(PQ)(3) 为了使程序不仅仅局限于计算9节点网络,在形成节点导纳的函数Yn()中,利用循环,找出线路首节点中的最大编号数,自动确定节点导纳矩阵的维数。故对于任意n节点网络,均可以计算出节点导纳矩阵(4) 在(3)的前提下,为了使程序支持系统增加节点,增加负荷等造成的PQ参数改变,或者PQ表的加长。对程序做了如下优
2、化。首先,程序执行的基础是PQ表中平衡节点在第一行,接下来是PV节点,最后是PQ节点,如果系统添加节点,或者删除节点,均在PQ表的末端操作,会造成PQ表的顺序不是平衡节点、PV节点、PQ节点的顺序。故引入了seqencing()函数,其作用就是不论输入的PQ表是什么顺序,在程序读入后均按平衡-PV-PQ的顺序排列。其次,顺序打乱的PQ表必须与支路参数表对应,故在Yn()函数中加入了两段循环体,使之对应(见相应函数体注释)(5) 在满足了上述4个条件后,程序便可以通用化了。当然,由于水平有限,且程序未能由大量数据测试,故缺陷在所难免,这里仅是做了通用化的尝试。在本文最末附加了该程序通用化的实例。
3、二、潮流计算框图输入系统的支路参数和PQ参数计算节点导纳矩阵设置初始电压值U0设置收敛条件及最大迭代次数Kmax判断是否收敛求解修正方程得到U和对U0进行修正,U0=U0+UKKmax ?NY输出结果结束输出潮流不收敛信息YN开始三定义相应的函数1.形成节点导纳矩阵的函数Yn()function Y=Yn(x,y) %定义一名为Yn的函数,其功能是自动识别输入表中节点的个数,形成相应的节点导纳矩阵fid,message=fopen(x,r) ; %从x文件中读入支路参数if fid=-1; %判断文件是否正确打开 error(message);end;HeadPoint,HeadNumber,
4、 EndPoint,EndNumber,R,X,B,k=textread(x,%s %d %s %d %f %f %f %f); %将读入的参数处理为以列为向量的数组fclose(fid);%关闭文件L=length(HeadNumber); %确定输入表的行数 Pointstyle,PointNumber,Ps,Qs,Uk,Ok=seqencing(y); %调用seqencing函数,引入y文件中的PQ参数A=PointNumber;for i=1:L; %通过以下两循环体,实现PQ参数与支路参数的编号对应 for j=1:L; if HeadNumber(i)=j; HeadNumber
5、(i)=A(j); break; end; end;end;for i=1:L; for j=1:L; if EndNumber(i)=j; EndNumber(i)=A(j); break; end; end;end;Y=zeros(L,L); %根据txt文件中数据表的长度建立空的节点导纳矩阵for i=1:L m=HeadNumber(i);n=EndNumber(i); if k(i)=0; %判断是否何种元件,为输电线元件 if n=0; Y(m,m)=Y(m,m)+1j*B(i)+1/(R(i)+1j*X(i); Y(n,n)=Y(n,n)+1j*B(i)+1/(R(i)+1j*X
6、(i); Y(m,n)=Y(m,n)-1/(R(i)+1j*X(i); Y(n,m)=Y(n,m)-1/(R(i)+1j*X(i); else Y(m,m)=Y(m,m)+R(i)+1j*X(i); end; else %为变压器元件 if n=0; Y(m,m)=Y(m,m)+1/(R(i)+1j*X(i); Y(m,n)=Y(m,n)-1/(k(i)*(R(i)+1j*X(i); Y(n,n)=Y(n,n)+1/(k(i)*k(i)*(R(i)+1j*X(i); Y(n,m)=Y(n,m)-1/(k(i)*(R(i)+1j*X(i); else Y(m,m)=Y(m,m)+R(i)+1j*
7、X(i); end; end; end;maxm=HeadNumber(1);%通过下面两个循环体,确定输入表中节点编号的最大值,及为节点导纳矩阵的维数for i=1:L; if maxm=HeadNumber(i); maxm=HeadNumber(i); end;end;maxn=EndNumber(1);for i=1:L; if maxnPointstyle(j+1); t=Pointstyle(j+1); Pointstyle(j+1)=Pointstyle(j); Pointstyle(j)=t; t=PointNumber(j+1); PointNumber(j+1)=Point
8、Number(j); PointNumber(j)=t; t=Ps(j+1); Ps(j+1)=Ps(j); Ps(j)=t; t=Qs(j+1); Qs(j+1)=Qs(j); Qs(j)=t; t=Uk(j+1); Uk(j+1)=Uk(j); Uk(j)=t; end; end;end; 3、形成解耦算法B矩阵的函数 formB1()function B1=formB1(x,y)%定义名为B1的函数形成解耦算法中的B矩阵,得到的B矩阵用B1表示fid,message=fopen(x,r) ; %从x文件中读入支路参数if fid=-1; %判断文件是否正确打开 error(message
9、);end;HeadPoint,HeadNumber,EndPoint,EndNumber,R,X,B,k=textread(x,%s %d %s %d %f %f %f %f); %将读入的参数处理为以列为向量的数组fclose(fid);L=length(HeadNumber); Pointstyle,PointNumber,Ps,Qs,Uk,Ok=seqencing(y);%调用seqencing函数,引入y文件中的PQ参数A=PointNumber;%通过以下两循环体,实现PQ参数与支路参数的编号对应for i=1:L; for j=1:L; if HeadNumber(i)=j; H
10、eadNumber(i)=A(j); break; end; end;end;for i=1:L; for j=1:L; if EndNumber(i)=j; EndNumber(i)=A(j); break; end; end;end;B1=zeros(L,L);for i=1:L %以行为单位,通过循环,用支路参数对B1进行修改,形成B矩阵 m=HeadNumber(i);n=EndNumber(i); B1(m,m)=B1(m,m)-1/X(i); B1(n,n)=B1(n,n)-1/X(i); B1(m,n)=B1(m,n)+1/X(i); B1(n,m)=B1(n,m)+1/X(i)
11、;endmaxm=HeadNumber(1);for i=1:L; if maxm=HeadNumber(i); maxm=HeadNumber(i); end;end;maxn=EndNumber(1);for i=1:L; if maxn=EndNumber(i); maxn=EndNumber(i); end;end;B1=B1(2:max(maxm,maxn),2:max(maxm,maxn); %形成B矩阵 4、形成解耦算法B矩阵的函数 formB11()function B11=formB11(x,y)%定义名为B11的函数形成解耦算法中B矩阵,用B11表示从x文件中读入支路参数确
12、定Y,从y文件中读入PQ参数确定B11的维数,即除去平衡节点和pv节点,此处要求PQ参数录入时,将平衡节点和PQ节点放在前排,这一要求在Yn函数中通过seqencing函数已经满足Y=Yn(x,y);B=imag(Y);Pointstyle,PointNumber,Ps,Qs,Uk,Ok=seqencing(y);i=1;j=1;while Pointstyle(i)=1; i=i+1; j=j+1;end;B11=B(j:end,j:end); %形成B矩阵5、计算正常情况下系统节点电压的函数 powerflow()function U0,O0=powerflow(x,y)%定义名为powe
13、rflow的函数,利用快速解耦算法来计算正常情况下系统内各个节点的电压和相角Pointstyle,PointNumber,Ps,Qs,Uk,Ok=seqencing(y);% 调用seqencing函数对PQ参数表进行排序 Y=Yn(x,y); %形成节点导纳矩阵,Yn为n维 B1=formB1(x,y); %形成解耦算法中的B矩阵,B1为n-1维 B11=formB11(x,y); %形成解耦算法中的B矩阵,B为m维 G=real(Y); %取Y的实部 B=imag(Y); %取Y的虚部 U0=Uk; O0=Ok; L=length(PointNumber); P=zeros(L,1); Q
14、=zeros(L,1); dP=zeros(L,1); dQ=zeros(L,1); number=1; i=1;k=1; while Pointstyle(i)=1; %通过k值确定系统中PQ节点的个数 i=i+1; k=k+1;end; while number100 %定义迭代次数上限为100次for i=2:L; sum1=0; for j=1:L; sum1=sum1+U0(j)*(G(i,j)*cos(O0(i)-O0(j)+B(i,j)*sin(O0(i)-O0(j); %潮流方程,n-1维 end; dP(i)=Ps(i)-U0(i)*sum1;endfor i=k:L; su
15、m2=0; for j=1:L; sum2=sum2+U0(j)*(G(i,j)*sin(O0(i)-O0(j)-B(i,j)*cos(O0(i)-O0(j); %潮流方程,m维 end; dQ(i)=Qs(i)-U0(i)*sum2;end dP1=dP(2:L)./U0(2:L); dQ1=dQ(k:L)./U0(k:L); a=max(norm(dP1,inf); b=max(norm(dQ1,inf); if max(a,b)0.00001 %判断是否收敛 break;disp(迭代)disp(k);disp(次后收敛); else %如不收敛, dO=-inv(B1)*dP1; %d
16、O为n-1维 dU=-inv(B11)*dQ1; %dU为m维 zero1=zeros(k-1,1); zero2=0; DU=zero1;dU; DO=zero2;dO; U0=U0+DU; O0=O0+DO; number=number+1; end; if number=100; disp(迭代100次后不收敛,迭代结束); end;end;四对相应的系统进行潮流分析和短路计算定义完上述函数之后,可直接调用函数形成导纳矩阵,计算正常情况下的节点电压,进行短路计算计算短路电流,短路后各个节点电压以及支路潮流分布。程序的输入表共有三个,为network.txt ,network2.txt ,
17、PQ参数.txt。其中network.txt存放不含发电机节点导纳和负荷导纳的系统支路参数,network2.txt存放含发电机节点导纳和负荷导纳的系统支路参数,PQ参数.txt存放系统的PQ参数,现列表如下第一列:首节点名称 第二列:首节点编号 第三列:尾节点名称 第四列:尾节点编号第五列:支路参数R 第六列:支路参数X 第七列:支路参数B/2 第八列:变比K第一列:节点类型,0-平衡节点,1-PV节点,2-PQ节点 第二列:节点编号第三列:节点的有功P 第四列:节点的无功Q 第五列:节点电压,PQ节点置为0第六列:节点电压的相角,初始值为0程序代码如下:%正常情况下节点导纳矩阵Y=Yn(n
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- matlab电力系统快速解耦法潮流计算及短路计算程序 精品资料 matlab 电力系统 快速 解耦法 潮流 计算 短路 程序 精品 资料
限制150内