📄 fm_cong.gms
字号:
$title GAMS/PSAT interface for solving the electricty market problem$onempty$offlisting$offupper$if exist psatglobs.gms $include psatglobs.gmsset B /1*%nBus%/, L /1*%nLine%/, G /1*%nPs%/, C /1*%nPd%/, W /1*%nSW%/, U /1*%nPV%/, busref(B) /%nBusref%/;set supply /Ps0, Psmax, Psmin, Csa, Csb, Csc, Dsa, Dsb, Dsc, ksu, RGup, RGdw/, demand /Pd0, Pdmax, Pdmin, tgphi, Cda, Cdb, Cdc, Dda, Ddb, Ddc, RDup, RDdw/, data /V0, t0, Pg0, Qg0, Pl0, Ql0, Qgmax, Qgmin, Vmax, Vmin, ksw, kpv/, lines /g, b, g0, b0, Pijmax, Pjimax/, vsc /lmin, lmax, omega, line/; alias (BB,B);parameter S(G,supply) //, D(C,demand) //, X(B,data) //, N(L,lines) //, lambda(vsc) //, Ps_idx(B,G) //, Psc_idx(B,G) //, Psm_idx(B,G) //, Pd_idx(B,C) //, SW_idx(B,W) //, PV_idx(B,U) //, Li(L,B) //, Lj(L,B) //, Gh(B,BB) //, Bh(B,BB) //, Ghc(B,BB) //, Bhc(B,BB) //;scalar MLC /0/, pi /3.1416/; $if exist psatdata.gms $include psatdata.gms* =========================================================================* ==================== C O M M O N V A R I A B L E S ===================* =========================================================================variables obj, Pij(L), Pji(L), V(B), a(B), Ps(G), Pd(C), Qg(B), Pijc(L), Pjic(L), DPGup(G), DPGdw(G), DPDup(C), DPDdw(C), Vc(B), ac(B), Qgc(B), kg, lambdac;* -------------------------------------------------------------------------* initial values* -------------------------------------------------------------------------Qg.l(B) = X(B,'Qg0');V.l(B) = X(B,'V0');a.l(B) = X(B,'t0');Ps.l(G) = S(G,'Psmin');Pd.l(C) = D(C,'Pdmin');Qgc.l(B) = X(B,'Qg0');Vc.l(B) = X(B,'V0');ac.l(B) = X(B,'t0');kg.l = 0;* -------------------------------------------------------------------------* limits* -------------------------------------------------------------------------* Bid BlocksPs.up(G) = S(G,'Psmax');Pd.up(C) = D(C,'Pdmax');Ps.lo(G) = S(G,'Psmin');Pd.lo(C) = D(C,'Pdmin');* Voltages & Voltage LimitsV.up(B) = X(B,'Vmax');V.lo(B) = X(B,'Vmin');a.up(B) = pi;a.lo(B) = -pi;* power variationsDPGup.lo(G) = 0;DPGdw.lo(G) = 0;DPDup.lo(C) = 0;DPDdw.lo(C) = 0;DPGup.up(G) = S(G,'Psmax');DPGdw.up(G) = S(G,'Psmax');DPDup.up(C) = D(C,'Pdmax');DPDdw.up(C) = D(C,'Pdmax');* Generator Reactive Power LimitsQg.up(B) = X(B,'Qgmax');Qg.lo(B) = X(B,'Qgmin');* Flow limits on transmission linesPij.up(L) = N(L,'Pijmax');Pij.lo(L) = -N(L,'Pijmax');Pji.up(L) = N(L,'Pijmax');Pji.lo(L) = -N(L,'Pijmax');* Voltages & Voltage LimitsVc.up(B) = X(B,'Vmax');Vc.lo(B) = X(B,'Vmin');ac.up(B) = pi;ac.lo(B) = -pi;kg.lo = -1;kg.up = 1;* Generator Reactive Power LimitsQgc.up(B) = X(B,'Qgmax');Qgc.lo(B) = X(B,'Qgmin');* Flow limits on transmission linesPijc.up(L) = N(L,'Pijmax');Pijc.lo(L) = -N(L,'Pijmax');Pjic.up(L) = N(L,'Pijmax');Pjic.lo(L) = -N(L,'Pijmax');lambdac.up = lambda('lmax');lambdac.lo = lambda('lmin');* -------------------------------------------------------------------------* define equations* -------------------------------------------------------------------------equations cost, Pseq(G), Pdeq(C), Peq(B), Qeq(B), Thetaref(B), Pceq(B), Qceq(B), Thetacref(B);$if %flow% == 0 $goto noflowsequations Pijeq(L), Pjieq(L), Pijceq(L), Pjiceq(L);$label noflows* =========================================================================* ====== V O L T A G E S T A B I L I T Y C O N S T R A I N E D ======* ================== O P T I M A L P O W E R F L O W =================* =========================================================================* -------------------------------------------------------------------------* objective functioncost.. obj =e= sum(G,DPGup(G)*S(G,'RGup'))+ sum(G,DPGdw(G)*S(G,'RGdw'))+ sum(C,DPDup(C)*D(C,'RDup'))+ sum(C,DPDdw(C)*D(C,'RDdw'));* -------------------------------------------------------------------------Pseq(G).. Ps(G) =e= S(G,'Ps0') + DPGup(G) - DPGdw(G); Pdeq(C).. Pd(C) =e= D(C,'Pd0') + DPDup(C) - DPDdw(C); Peq(B).. sum(G,Ps_idx(B,G)*Ps(G)) - sum(C,Pd_idx(B,C)*Pd(C)) + X(B,'Pg0') - X(B,'Pl0') - V(B)*sum(BB,V(BB)*(Gh(B,BB)*cos(a(B)-a(BB)) + Bh(B,BB)*sin(a(B)-a(BB)))) =e= 0;Qeq(B).. Qg(B) - X(B,'Ql0') - sum(C,Pd_idx(B,C)*(D(C,'tgphi')*Pd(C))) - V(B)*sum(BB,V(BB)*(Gh(B,BB)*sin(a(B)-a(BB)) - Bh(B,BB)*cos(a(B)-a(BB)))) =e= 0;Thetaref(B)$busref(B).. a(B) =e= 0;Pceq(B).. (1+lambdac+kg)*(sum(G,Psc_idx(B,G)*(S(G,'ksu')*Ps(G))) + X(B,'Pg0')) + (sum(W,SW_idx(B,W)*(X(B,'ksw')*X(B,'Pg0')))) + (sum(U,PV_idx(B,U)*(X(B,'kpv')*X(B,'Pg0')))) + sum(G,Psm_idx(B,G)*S(G,'Psmax')) - (1+lambdac)*(sum(C,Pd_idx(B,C)*Pd(C)) + X(B,'Pl0')) - Vc(B)*sum(BB,Vc(BB)*(Ghc(B,BB)*cos(ac(B)-ac(BB)) + Bhc(B,BB)*sin(ac(B)-ac(BB)))) =e= 0;* (sum(G,Ps_idx(B,G)*(S(G,'ksu')*Ps(G)))) +Qceq(B).. Qgc(B) - (1+lambdac)*(X(B,'Ql0') + sum(C,Pd_idx(B,C)*(D(C,'tgphi')*Pd(C)))) - Vc(B)*sum(BB,Vc(BB)*(Ghc(B,BB)*sin(ac(B)-ac(BB)) - Bhc(B,BB)*cos(ac(B)-ac(BB)))) =e= 0;Thetacref(B)$busref(B).. ac(B) =e= 0;$if %flow% == 0 $goto solvestat$if %flow% == 1 $goto iflows$if %flow% == 2 $goto pflows$if %flow% == 3 $goto sflows$label pflowsPijeq(L).. Pij(L) =e= N(L,'g0')*sum(B,Li(L,B)*V(B)*V(B)) - N(L,'b')*sum(B,Li(L,B)*V(B)*sin(a(B)))* sum(B,Lj(L,B)*V(B)*cos(a(B))) + N(L,'b')*sum(B,Li(L,B)*V(B)*cos(a(B)))* sum(B,Lj(L,B)*V(B)*sin(a(B))) - N(L,'g')*sum(B,Li(L,B)*V(B)*cos(a(B)))* sum(B,Lj(L,B)*V(B)*cos(a(B))) - N(L,'g')*sum(B,Li(L,B)*V(B)*sin(a(B)))* sum(B,Lj(L,B)*V(B)*sin(a(B)));Pjieq(L).. Pji(L) =e= N(L,'g0')*sum(B,Lj(L,B)*V(B)*V(B)) - N(L,'b')*sum(B,Lj(L,B)*V(B)*sin(a(B)))* sum(B,Li(L,B)*V(B)*cos(a(B))) + N(L,'b')*sum(B,Lj(L,B)*V(B)*cos(a(B)))* sum(B,Li(L,B)*V(B)*sin(a(B))) - N(L,'g')*sum(B,Lj(L,B)*V(B)*cos(a(B)))* sum(B,Li(L,B)*V(B)*cos(a(B))) - N(L,'g')*sum(B,Lj(L,B)*V(B)*sin(a(B)))* sum(B,Li(L,B)*V(B)*sin(a(B)));N(L,'b')$(ord(L) eq lambda('line')) = -1E-6;N(L,'g')$(ord(L) eq lambda('line')) = 0;N(L,'b0')$(ord(L) eq lambda('line')) = 0;N(L,'g0')$(ord(L) eq lambda('line')) = 0;Pijceq(L).. Pijc(L) =e= N(L,'g0')*sum(B,Li(L,B)*Vc(B)*Vc(B)) - N(L,'b')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))* sum(B,Lj(L,B)*Vc(B)*cos(ac(B))) + N(L,'b')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))* sum(B,Lj(L,B)*Vc(B)*sin(ac(B))) - N(L,'g')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))* sum(B,Lj(L,B)*Vc(B)*cos(ac(B))) - N(L,'g')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))* sum(B,Lj(L,B)*Vc(B)*sin(ac(B)));Pjiceq(L).. Pjic(L) =e= N(L,'g0')*sum(B,Lj(L,B)*Vc(B)*Vc(B)) - N(L,'b')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))* sum(B,Li(L,B)*Vc(B)*cos(ac(B))) + N(L,'b')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))* sum(B,Li(L,B)*Vc(B)*sin(ac(B))) - N(L,'g')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))* sum(B,Li(L,B)*Vc(B)*cos(ac(B))) - N(L,'g')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))* sum(B,Li(L,B)*Vc(B)*sin(ac(B)));$goto solvestat$label iflowsPijeq(L).. Pij(L) =e= sqrt( sqr(N(L,'g')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'g')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Li(L,B)*V(B)*sin(a(B)))+ N(L,'b')*sum(B,Lj(L,B)*V(B)*sin(a(B)))- N(L,'b0')*sum(B,Li(L,B)*V(B)*sin(a(B))))+ sqr(N(L,'b')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Lj(L,B)*V(B)*cos(a(B)))+ N(L,'g')*sum(B,Li(L,B)*V(B)*sin(a(B)))- N(L,'g')*sum(B,Lj(L,B)*V(B)*sin(a(B)))+ N(L,'b0')*sum(B,Li(L,B)*V(B)*cos(a(B)))));Pjieq(L).. Pji(L) =e= sqrt( sqr(N(L,'g')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'g')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Lj(L,B)*V(B)*sin(a(B)))+ N(L,'b')*sum(B,Li(L,B)*V(B)*sin(a(B)))- N(L,'b0')*sum(B,Lj(L,B)*V(B)*sin(a(B))))+ sqr(N(L,'b')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Li(L,B)*V(B)*cos(a(B)))+ N(L,'g')*sum(B,Lj(L,B)*V(B)*sin(a(B)))- N(L,'g')*sum(B,Li(L,B)*V(B)*sin(a(B)))+ N(L,'b0')*sum(B,Lj(L,B)*V(B)*cos(a(B)))));N(L,'b')$(ord(L) eq lambda('line')) = -1E-6;N(L,'g')$(ord(L) eq lambda('line')) = 0;N(L,'b0')$(ord(L) eq lambda('line')) = 0;N(L,'g0')$(ord(L) eq lambda('line')) = 0;Pijceq(L).. Pijc(L) =e= sqrt( sqr(N(L,'g')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'g')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))- N(L,'b0')*sum(B,Li(L,B)*Vc(B)*sin(ac(B))))+ sqr(N(L,'b')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))+ N(L,'g')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))- N(L,'g')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b0')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))));Pjiceq(L).. Pjic(L) =e= sqrt( sqr(N(L,'g')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'g')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))- N(L,'b0')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B))))+ sqr(N(L,'b')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))+ N(L,'g')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))- N(L,'g')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b0')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))));$goto solvestat$label sflowsPijeq(L).. Pij(L) =e= sum(B,Li(L,B)*V(B))*sqrt( sqr(N(L,'g')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'g')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Li(L,B)*V(B)*sin(a(B)))+ N(L,'b')*sum(B,Lj(L,B)*V(B)*sin(a(B)))- N(L,'b0')*sum(B,Li(L,B)*V(B)*sin(a(B))))+ sqr(N(L,'b')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Lj(L,B)*V(B)*cos(a(B)))+ N(L,'g')*sum(B,Li(L,B)*V(B)*sin(a(B)))- N(L,'g')*sum(B,Lj(L,B)*V(B)*sin(a(B)))+ N(L,'b0')*sum(B,Li(L,B)*V(B)*cos(a(B)))));Pjieq(L).. Pji(L) =e= sum(B,Lj(L,B)*V(B))*sqrt( sqr(N(L,'g')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'g')*sum(B,Li(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Lj(L,B)*V(B)*sin(a(B)))+ N(L,'b')*sum(B,Li(L,B)*V(B)*sin(a(B)))- N(L,'b0')*sum(B,Lj(L,B)*V(B)*sin(a(B))))+ sqr(N(L,'b')*sum(B,Lj(L,B)*V(B)*cos(a(B)))- N(L,'b')*sum(B,Li(L,B)*V(B)*cos(a(B)))+ N(L,'g')*sum(B,Lj(L,B)*V(B)*sin(a(B)))- N(L,'g')*sum(B,Li(L,B)*V(B)*sin(a(B)))+ N(L,'b0')*sum(B,Lj(L,B)*V(B)*cos(a(B)))));N(L,'b')$(ord(L) eq lambda('line')) = -1E-6;N(L,'g')$(ord(L) eq lambda('line')) = 0;N(L,'b0')$(ord(L) eq lambda('line')) = 0;N(L,'g0')$(ord(L) eq lambda('line')) = 0;Pijceq(L).. Pijc(L) =e= sum(B,Li(L,B)*Vc(B))*sqrt( sqr(N(L,'g')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'g')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))- N(L,'b0')*sum(B,Li(L,B)*Vc(B)*sin(ac(B))))+ sqr(N(L,'b')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))+ N(L,'g')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))- N(L,'g')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b0')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))));Pjiceq(L).. Pjic(L) =e= sum(B,Lj(L,B)*Vc(B))*sqrt( sqr(N(L,'g')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'g')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))- N(L,'b0')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B))))+ sqr(N(L,'b')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))- N(L,'b')*sum(B,Li(L,B)*Vc(B)*cos(ac(B)))+ N(L,'g')*sum(B,Lj(L,B)*Vc(B)*sin(ac(B)))- N(L,'g')*sum(B,Li(L,B)*Vc(B)*sin(ac(B)))+ N(L,'b0')*sum(B,Lj(L,B)*Vc(B)*cos(ac(B)))));$goto solvestat* -------------------------------------------------------------------------* Solve Market Problem* -------------------------------------------------------------------------$label solvestatmodel market /all/;option nlp = minos;option iterlim = 50000;solve market using nlp minimizing obj;scalar mstatus /0/;scalar sstatus /0/;if ((market.modelstat eq 1), mstatus = 1;);if ((market.modelstat eq 2), mstatus = 2;);if ((market.modelstat eq 3), mstatus = 3;);if ((market.modelstat eq 4), mstatus = 4;);if ((market.modelstat eq 5), mstatus = 5;);if ((market.modelstat eq 6), mstatus = 6;);if ((market.modelstat eq 7), mstatus = 7;);if ((market.modelstat eq 8), mstatus = 8;);if ((market.modelstat eq 9), mstatus = 9;);if ((market.modelstat eq 10), mstatus = 10;);if ((market.modelstat eq 11), mstatus = 11;);if ((market.modelstat eq 12), mstatus = 12;);if ((market.modelstat eq 13), mstatus = 13;);if ((market.solvestat eq 1), sstatus = 1;);if ((market.solvestat eq 2), sstatus = 2;);if ((market.solvestat eq 3), sstatus = 3;);if ((market.solvestat eq 4), sstatus = 4;);if ((market.solvestat eq 5), sstatus = 5;);if ((market.solvestat eq 6), sstatus = 6;);if ((market.solvestat eq 7), sstatus = 7;);if ((market.solvestat eq 8), sstatus = 8;);if ((market.solvestat eq 9), sstatus = 9;);if ((market.solvestat eq 10), sstatus = 10;);if ((market.solvestat eq 11), sstatus = 11;);if ((market.solvestat eq 12), sstatus = 12;);if ((market.solvestat eq 13), sstatus = 13;);$libinclude psatout Ps.l G$libinclude psatout Pd.l C$libinclude psatout DPGup.l G$libinclude psatout DPGdw.l G$libinclude psatout DPDup.l C$libinclude psatout DPDdw.l C$libinclude psatout V.l B$libinclude psatout a.l B$libinclude psatout Qg.l B$libinclude psatout Peq.m B$libinclude psatout Pij.l L$libinclude psatout Pji.l L$libinclude psatout V.m B$libinclude psatout Pij.m L$libinclude psatout Pji.m L$libinclude psatout lambdac.l$libinclude psatout kg.l$libinclude psatout Vc.l B$libinclude psatout ac.l B$libinclude psatout Qgc.l B$libinclude psatout Pijc.l L$libinclude psatout Pjic.l L$libinclude psatout Pceq.m B$libinclude psatout lambdac.m$libinclude psatout mstatus$libinclude psatout sstatus
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -