版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、<p><b> 目 錄</b></p><p> 一、電力系統(tǒng)潮流計算概述1</p><p> 二、節(jié)點導(dǎo)納矩陣1</p><p> 1.節(jié)點導(dǎo)納矩陣及其各元素的物理意義1</p><p> 2.節(jié)點導(dǎo)納矩陣的特點1</p><p><b>
2、3.算法推導(dǎo)2</b></p><p> 3.1勵磁支路2</p><p> 3.2線路支路2</p><p> 3.3變壓器支路3</p><p> 4.程序?qū)崿F(xiàn)方法和技巧3</p><p> 4.1變量說明3</p><p> 4.2支路參數(shù)
3、設(shè)置技巧4</p><p><b> 5.程序框圖5</b></p><p> 6.矩陣輸出格式控制6</p><p> 三、潮流計算的原理及實現(xiàn)方法6</p><p> 1.牛頓—拉夫遜法(直角、極坐標)6</p><p> 1.1牛頓—拉夫遜法簡介6</p
4、><p> 1.2算法推導(dǎo)8</p><p><b> a.直角坐標8</b></p><p><b> b.極坐標11</b></p><p> 1.3程序?qū)崿F(xiàn)方法和技巧12</p><p> 1.4直角坐標和極坐標的比較13</p>
5、<p> 1.5程序框圖14</p><p> 2.高斯—塞得爾法15</p><p> 2.1高斯—塞得爾法簡介15</p><p> 2.2算法推導(dǎo)15</p><p> 2.3程序框圖17</p><p> 3.P-Q分解法18</p><p&g
6、t; 3.1P-Q分解法簡介18</p><p> 3.2算法推導(dǎo)18</p><p> 3.3程序框圖21</p><p> 4.節(jié)點功率、功率分布及網(wǎng)損計算22</p><p> 4.1節(jié)點功率22</p><p> 4.2支路功率22</p><p>
7、 a.變壓器支路23</p><p> b.線路支路24</p><p> c.勵磁支路24</p><p> 4.3網(wǎng)絡(luò)損耗24</p><p> 四、主程序結(jié)構(gòu)圖25</p><p> 五、程序清單26</p><p> 六、程序計算實例47</
8、p><p> 1.實例內(nèi)容47</p><p> 2.程序初值47</p><p> 3.運行結(jié)果48</p><p> 3.1節(jié)點導(dǎo)納矩陣48</p><p> 3.2牛頓極坐標48</p><p> 3.3牛頓直角坐標49</p><p&g
9、t; 3.4高斯塞得爾50</p><p> 3.5P-Q分解法51</p><p> 4.運行界面51</p><p> 七、畢業(yè)設(shè)計的成果、經(jīng)驗和不足55</p><p> 1.程序設(shè)計的優(yōu)點55</p><p> 2.程序中的不足55</p><p>
10、 3.畢業(yè)設(shè)計成果56</p><p> 4.畢業(yè)設(shè)計體會56</p><p><b> 參考書目57</b></p><p><b> 電力系統(tǒng)潮流計算</b></p><p> 電力系統(tǒng)潮流計算概述</p><p> 潮流計算是電力系統(tǒng)中最基本的計算,
11、它在給定電網(wǎng)結(jié)構(gòu)、參數(shù)及決定電力系統(tǒng)運行狀態(tài)的邊界條件的情況下,通過計算來確定電力系統(tǒng)的運行狀態(tài)。如各母線上的電壓(幅值和相角)、網(wǎng)絡(luò)中的功率分布及功率損耗等。潮流計算是電力系統(tǒng)運行、規(guī)劃、以及安全性、可靠性分析和優(yōu)化的基礎(chǔ),也是各種電磁瞬時過程和機電瞬時過程分析的基礎(chǔ)和出發(fā)點。潮流計算一般分為在線計算和離線計算。在這里主要是進行離線潮流計算的問題。</p><p> 潮流計算的方法通常有阻抗法和導(dǎo)納法。隨著計
12、算機的應(yīng)用發(fā)展,采用稀疏矩陣技術(shù)和節(jié)點優(yōu)化編號技術(shù)使牛頓-拉夫遜法得到了非常廣泛的應(yīng)用,成為潮流計算中廣泛采用的優(yōu)秀算法。導(dǎo)納法也就因其稀疏性的特點逐步取代了阻抗法。70 年代中期,Stott 在大量實踐的基礎(chǔ)上提出了快速分解潮流計算方法(P_Q分解法),使潮流計算在內(nèi)存容量和計算速度上得到了大大的提高,可用于在線計算,是目前最常用的一種方法。</p><p><b> 節(jié)點導(dǎo)納矩陣</b&g
13、t;</p><p> 節(jié)點導(dǎo)納矩陣及其各元素的物理意義</p><p> 由歐姆定律可知:,也即,其中系數(shù)矩陣Y即稱為節(jié)點導(dǎo)納矩陣。對于n個節(jié)點的電力網(wǎng)絡(luò)來說,方程組的系數(shù)矩陣:</p><p><b> ?。?- 1)</b></p><p> 顯然可知其中各元素的物理意義:</p><p&
14、gt; 導(dǎo)納矩陣中第i列對角元素Yii ,即節(jié)點i的自導(dǎo)納,在數(shù)值上等于節(jié)點i加單位電壓,其它節(jié)點都接地時,節(jié)點i向電力網(wǎng)絡(luò)注入的電流。</p><p> 導(dǎo)納矩陣中第i列非對角元素Yij ,即節(jié)點i與節(jié)點j間的互導(dǎo)納,在數(shù)值上等于節(jié)點i加單位電壓,其它節(jié)點都接地時,節(jié)點j向電力網(wǎng)絡(luò)注入的電流。</p><p><b> 節(jié)點導(dǎo)納矩陣的特點</b></p&
15、gt;<p> 導(dǎo)納矩陣是稀疏矩陣,矩陣的階數(shù)等于電力網(wǎng)的節(jié)點數(shù)。</p><p> 各行非對角元素的個數(shù)等于對應(yīng)節(jié)點所連的不接地支路數(shù)。</p><p> 導(dǎo)納矩陣是一個對稱的方陣,非對角元素Yij=Yji 。</p><p> 對角線元素即自導(dǎo)納等于i 節(jié)點所有支路導(dǎo)納值的總和,即 Yii=∑yii 。</p><p&g
16、t; 非對角線元素即互導(dǎo)納等于i、j 節(jié)點間支路導(dǎo)納的負值,即 Yij=-yij 。</p><p><b> 算法推導(dǎo)</b></p><p> 電力網(wǎng)中常見的有三種類型的支路:勵磁支路、線路支路、變壓器支路。在節(jié)點導(dǎo)納矩陣程序中,采用逐條支路追加法。而對于各種支路處理方法略有不同,下面就分別作以推導(dǎo)。</p><p><b>
17、; 勵磁支路</b></p><p> 如圖1所示,勵磁支路的另一節(jié)點是接地點0,因此當(dāng)追加勵磁支路時,只需要修正節(jié)點i的自導(dǎo)納。</p><p><b> ?。?- 2)</b></p><p><b> 線路支路</b></p><p> 如圖2所示,當(dāng)追加線路支路時,節(jié)點i
18、、節(jié)點j的自導(dǎo)納以及它們之間的互導(dǎo)納都需要修改。</p><p><b> (2- 3)</b></p><p><b> ?。?- 4)</b></p><p><b> ?。?- 5)</b></p><p> 圖 1 勵磁支路
19、 圖 2 線路支路</p><p><b> 變壓器支路</b></p><p> 變壓器一共有四種模型,在這里采用如圖3所示的模型,而其它的三種情況均可以化作此模型(詳見后一節(jié))。對于圖3的模型,有:</p><p><b> ?。?- 6)</b></p><p><b>
20、; ?。?- 7)</b></p><p><b> (2- 8)</b></p><p><b> 化簡后:</b></p><p><b> ?。?- 9)</b></p><p><b> ?。?- 10)</b></p>
21、<p> 圖 3 變壓器支路</p><p><b> 程序?qū)崿F(xiàn)方法和技巧</b></p><p><b> 變量說明</b></p><p> YG、YB分別存放節(jié)點導(dǎo)納矩陣的實部和虛部;</p><p><b> m 存放循環(huán)數(shù);</b>&
22、lt;/p><p> ?。╥、j、r、x、k)存放支路參數(shù)</p><p> i 、j分別存放支路的節(jié)點號,如果是接地點則存為0;</p><p> r 、x 分別存放支路參數(shù)的實部和虛部;</p><p> k 存放變比(變壓器支路)或接地容納(線路支路);</p><p><b> 支路參數(shù)設(shè)置技巧&
23、lt;/b></p><p> ?。?)如何區(qū)別支路類型</p><p> 當(dāng)其為勵磁支路時,令接地端的節(jié)點號為0,這樣判斷就是勵磁支路;</p><p> 當(dāng)其為變壓器支路時,令靠近變壓器的一端為負值,這樣判斷則是變壓器支路;</p><p> 因而判斷就是線路支路。</p><p> ?。?)如何解決變
24、壓器四種模型的統(tǒng)一</p><p> 對于圖4所示的模型,令,當(dāng)程序判斷時, 節(jié)點號互換;</p><p> 對于圖5所示的模型,令,當(dāng)程序判斷時,作 ;</p><p> 對于圖6所示的模型,同時做上述兩步;</p><p> 這樣一來就可以把模型統(tǒng)一到圖3所對應(yīng)的計算公式。</p><p> 圖 4
25、 圖 5 圖 6</p><p> (3)如何讓線路支路與變壓器支路用同一套計算公式</p><p> 把線路支路的對地容納存入變量中,當(dāng)程序處理線路支路時,首先用以下兩個公式(2-11)和(2-12)把容納加入節(jié)點的自導(dǎo)納中,然后置,這樣即把線路支路看作變比的變壓器支路。</p>&l
26、t;p><b> ?。?- 11)</b></p><p><b> ?。?- 12)</b></p><p><b> 程序框圖</b></p><p><b> 矩陣輸出格式控制</b></p><p> 由于節(jié)點導(dǎo)納矩陣的輸出中,有實部和
27、虛部之分、又有正負號,要把字符j輸出到虛部的正負號之前,而且要把整個矩陣用一屏輸完,就需要進行一定的處理。對于實部照直輸出即可,對于虛部則先判斷其正負,輸出或,然后對其取絕對值輸出。如果階數(shù)比較大,還可以用printf(“%.NUMf”,變量名);來控制輸出數(shù)據(jù)的小數(shù)點位數(shù)。其中NUM是希望輸出的小數(shù)點位數(shù)。</p><p> 潮流計算的原理及實現(xiàn)方法</p><p> 如上所述,節(jié)點
28、電流與電壓之間的關(guān)系可以通過節(jié)點方程式來表述:</p><p><b> ?。?- 1)</b></p><p> 上式寫成展開的形式:</p><p><b> (3- 2)</b></p><p> 為了求解潮流問題,必須利用節(jié)點功率與電流之間的關(guān)系:</p><p&g
29、t;<b> ?。?- 3)</b></p><p> 其中分別為節(jié)點向網(wǎng)絡(luò)注入的有功功率及無功功率,當(dāng)點為負荷節(jié)點時,本身應(yīng)帶負號。將式(3- 3)代入式(3- 2),可得到:</p><p><b> ?。?- 4)</b></p><p> 式(3-4)中有n個非線性復(fù)數(shù)方程式,是潮流計算問題的基本方程式,對這個
30、方程式的不同應(yīng)用和處理,就形成了不同的潮流程序??傮w上可分為:牛頓—拉夫遜法、高斯—塞得爾法、P—Q分解法。以下對各種跌代方法作一一說明。</p><p> 牛頓—拉夫遜法(直角、極坐標)</p><p><b> 牛頓—拉夫遜法簡介</b></p><p> 牛頓—拉夫遜法是把非線性方程式的求解過程變成反復(fù)對相應(yīng)的線性方程式的求解過程,
31、從幾何意義上看實質(zhì)是切線法、是一種逐步線性化的方法,這是牛頓—拉夫遜法的核心所在。</p><p> 設(shè)有變量的非線性聯(lián)立方程組: </p><p><b> ?。?- 5)</b></p><p> 其近似為,設(shè)近似解與精確解分別相差,則如下的方程式成立:</p><p><b&g
32、t; ?。?- 6)</b></p><p> 上式中任何一式都可按泰勒級數(shù)展開,并省略二次以上高次項,可得:</p><p><b> (3- 7)</b></p><p> 或簡寫為: </p><p><b> ?。?- 8)</b><
33、;/p><p> 式中,稱為函數(shù)的雅可比矩陣;</p><p> 將代入式(3-7),可得中,然后求解,從而經(jīng)過第一次迭代后的新值。再將求得的代入,如此循環(huán),直到。(這里為預(yù)先給定的滿足一定精度要求的正整數(shù))</p><p><b> 算法推導(dǎo)</b></p><p><b> 直角坐標</b>
34、</p><p> 基本方程式: </p><p><b> (3- 9)</b></p><p> 將式(3-2)代入式(3-9),并展開功率方程式得:</p><p><b> (3- 10)</b></p><p>
35、 節(jié)點電壓以直角坐標表示時,有、,將實部和虛部分列,可得:</p><p><b> ?。?- 11)</b></p><p> 對于PQ節(jié)點,Pis ,Qis是給定的,因而有:</p><p><b> (3- 12)</b></p><p> 對于PV節(jié)點,Pis ,Vis是給定的,因而有
36、:</p><p><b> ?。?- 13)</b></p><p><b> 其中令:</b></p><p><b> ?。?- 14)</b></p><p> 則式(3-12)和(3-13)可簡化為:</p><p><b>
37、(3- 15)</b></p><p><b> ?。?- 16)</b></p><p><b> 建立修正方程式:</b></p><p><b> ?。?- 17)</b></p><p> 其中用式(3-15)求出,用式(3-16)求出;</p&g
38、t;<p> 而雅可比矩陣各元素按下式求得:</p><p><b> 時, </b></p><p><b> ?。?- 18) </b></p><p><b> (3- 19)</b></p><p><b> ?。?- 20)</b
39、></p><p><b> ?。?- 21)</b></p><p><b> 時,</b></p><p><b> ?。?- 22)</b></p><p><b> ?。?- 23)</b></p><p> ?。?
40、- 24) </p><p><b> ?。?- 25)</b></p><p> ?。?- 26) </p><p> ?。?- 27) </p><p> 為了求解修正方程式,必須對雅可比矩陣作一定的處理,可以用高斯消去法、三角分解法、因子表法,而在本程序中采用直接求逆
41、的方法。求逆后有:</p><p><b> ?。?- 28)</b></p><p> 通過式(3-28)求出,再修正各節(jié)點電壓,即:</p><p><b> (3- 29)</b></p><p> 這樣節(jié)點電壓就離精確值更近了一步。再運用新的電壓值進行下一次迭代,直到滿足精度要求。&l
42、t;/p><p><b> 極坐標</b></p><p> 如上所述,當(dāng)節(jié)點電壓以極坐標表示時,有</p><p><b> ?。?- 30)</b></p><p> 把式(3-30)代入式(3-10),再將實部、虛部分開,得功率方程式:</p><p><b&g
43、t; (3- 31)</b></p><p> 式中 (3- 32)</p><p> 在計算中通常將式(3-31)寫成:</p><p><b> ?。?- 33)</b></p><p> 在建立修正方程式時,由于PV節(jié)點的電壓幅值是給定的,不在作為變量,同時,該點不能預(yù)先給定無功功率Qis ,這
44、樣,方程式中也就失去了約束作用。因此,在迭代過程中應(yīng)取消與PV節(jié)點有關(guān)的無功功率方程式。</p><p> 設(shè)節(jié)點總數(shù)為n,PV節(jié)點數(shù)為r,則:</p><p><b> (3- 34)</b></p><p> 為了程序上處理方便,把修正方程式排列成下列形式:</p><p><b> ?。?- 35)
45、</b></p><p> 式中,雅可比矩陣個元素用下式計算:</p><p><b> 時</b></p><p><b> ?。?- 36)</b></p><p><b> ?。?- 37)</b></p><p><b>
46、; ?。?- 38)</b></p><p><b> (3- 39)</b></p><p><b> 時,</b></p><p><b> (3- 40)</b></p><p><b> ?。?- 41)</b></p>
47、;<p><b> ?。?- 42)</b></p><p><b> ?。?- 43)</b></p><p> 同上,用直接求逆法處理雅可比矩陣,解出、,再修正各節(jié)點電壓:</p><p><b> ?。?- 44)</b></p><p> 如此循環(huán)直到
48、滿足精度要求為止。</p><p><b> 程序?qū)崿F(xiàn)方法和技巧</b></p><p> 直角坐標法:式(3-15)、(3-16)及式(3-22)~(3-25)中都含有節(jié)點注入電流的分量、,因而求解、及雅可比矩陣中對角線元素、、、的主要運算集中在求、上。節(jié)點注入電流的分量、只與行導(dǎo)納矩陣及相應(yīng)節(jié)點的電壓分量有關(guān)(見式3-14),因此即可先運算得到、,從而減小運算
49、量、提高計算精度。</p><p> 另外,在直角坐標和極坐標中,當(dāng)時,都有、,如此就可以只作兩個子函數(shù)H(i,j)、N(i,j)來進行調(diào)用,這樣也減小了程序的運算量,同時增加程序的可讀性。</p><p> 注:為了程序計算的方便,把PV節(jié)點的電壓存放于無功功率Q的數(shù)組中。</p><p> 直角坐標和極坐標的比較</p><p>&
50、lt;b> 表格 1</b></p><p><b> 程序框圖</b></p><p><b> 高斯—塞得爾法</b></p><p><b> 高斯—塞得爾法簡介</b></p><p> 與牛頓法不同的是高斯—塞得爾法把迭代計算所求得的最新值
51、立即用于計算下一個變量的新值而不是等到這一輪迭代結(jié)束之后。這就是高斯—塞得爾法思想的核心所在。通常高斯—塞得爾法迭代的次數(shù)很多,為了加速收斂,可以引入加速因子。</p><p><b> 算法推導(dǎo)</b></p><p> 如果取,則有功方程式:</p><p><b> ?。?- 45)</b></p>
52、<p><b> 把實部和虛部分開:</b></p><p><b> ?。?- 46)</b></p><p> 令: (3- 47)</p><p> 因此式(3-46)可簡化為:</p><p><b> (3- 48)</b>&l
53、t;/p><p> 從式(3-4)可以解出:</p><p><b> ?。?- 49)</b></p><p> 將其展開,并寫成高—塞法的迭代格式:</p><p><b> (3- 50)</b></p><p><b> 最后引入加速因子:</b&
54、gt;</p><p><b> (3- 51)</b></p><p> 這就是高斯迭代的基本公式。</p><p> A.對于PQ節(jié)點,節(jié)點功率是給定的,因此可以直接應(yīng)用式(3-50)和式(3-51)進行迭代計算。</p><p> B.對于PV節(jié)點,電壓幅值是給定的,而無功功率又需要在迭代過程中逐次地求出,
55、因此PV節(jié)點必須作以下幾項計算。</p><p><b> 修正節(jié)點電壓</b></p><p><b> ?。?- 52)</b></p><p> 用式(3-48)計算節(jié)點無功功率</p><p><b> 無功功率越限檢查</b></p><p&
56、gt; 檢驗 (3- 53)</p><p> 作完上述三項計算后,就可以用式(3-50)和式(3-51)計算節(jié)點電壓的新值。</p><p> C.平衡節(jié)點不必進行迭代</p><p> 另外,高斯—塞得爾法的收斂判據(jù)是:</p><p><b> ?。?- 54)</b></p><p
57、><b> 程序框圖</b></p><p><b> P-Q分解法</b></p><p><b> P-Q分解法簡介</b></p><p> P-Q分解法(改進牛頓法)是從改進和簡化牛頓法潮流程序的基礎(chǔ)上提出來的。它的基本思想是:把節(jié)點功率表示為電壓向量的極坐標方程式,抓住主要矛盾
58、,以有功功率誤差作為修正電壓向量角度的依據(jù),以無功功率誤差作為修正電壓幅值的依據(jù),把有功功率和無功功率迭代分開來進行。即:</p><p><b> (3- 55)</b></p><p> 這樣由于把2n階的方程組變成了二個n階的方程組,因而計算量和內(nèi)存方面都有所改善。P-Q分解法的另一個簡化是將式(3-55)中的系數(shù)矩陣化作在迭代過程中不變的對稱矩陣。迭代過程
59、中不需要反復(fù)求解系數(shù)矩陣。</p><p> 以上兩點就是P-Q分解法與其它方法的最明顯的區(qū)別。</p><p><b> 算法推導(dǎo)</b></p><p><b> 如上所述,有:</b></p><p><b> ?。?- 56)</b></p><
60、;p> 由于線路兩端電壓的相角差不太大(一般10°~20°),因此近似認為、,且近似認為。作此近似后,可以將式(3-56)系數(shù)矩陣中的元素表示式從式(3-36)、(3-39)、(3-40)、(3-43)簡化為:</p><p><b> (3- 57)</b></p><p> 將式(3-57)寫成矩陣的形式有:</p>
61、<p><b> (3- 58)</b></p><p> 再將式(3-58)代入式(3-56)中,并利用矩陣相乘,得:</p><p><b> ?。?- 59)</b></p><p><b> (3- 60)</b></p><p> 進一步化簡后可以得
62、到:</p><p><b> (3- 61)</b></p><p><b> ?。?- 62)</b></p><p> 式(3-61)和式(3-62)也可以簡寫成:</p><p><b> ?。?- 63)</b></p><p><b
63、> (3- 64)</b></p><p> ***注意:這里的與的階數(shù)是不同的。</p><p> 以上兩式就是P-Q分解法的修正方程式,其中系數(shù)矩陣與只不過是系統(tǒng)導(dǎo)納矩陣的虛部,因而是對稱矩陣,而且在迭代過程中維持不變。它們與功率誤差方程式(3-65):</p><p><b> (3- 65)</b></p
64、><p> 構(gòu)成了P-Q分解法迭代過程中基本計算公式。</p><p> 至于其迭代過程,與牛頓極坐標法相類似,這里就不再熬述了。</p><p><b> 程序框圖</b></p><p> 節(jié)點功率、功率分布及網(wǎng)損計算</p><p><b> 節(jié)點功率</b>&l
65、t;/p><p> 要計算的節(jié)點功率有PV節(jié)點的無功功率,平衡節(jié)點的有功和無功功率。</p><p> 電壓取直角坐標時,用下式計算:</p><p><b> ?。?- 66)</b></p><p> 電壓取極坐標時,則有:</p><p><b> ?。?- 67)</b&
66、gt;</p><p><b> 支路功率</b></p><p> 如圖7所示,支路功率基本方程式:</p><p><b> ?。?- 68)</b></p><p><b> 也即:</b></p><p><b> (3- 69
67、)</b></p><p> 圖 7 圖 8</p><p> 下面對各種支路分別討論:</p><p><b> 變壓器支路</b></p><p> 在這里仍然采用節(jié)點導(dǎo)納程序中的變壓器模型,如圖8所示,即有:</p&
68、gt;<p><b> ?。?- 70)</b></p><p> 又由于式(2-6),所以上式可以寫成:</p><p><b> (3- 71)</b></p><p> 當(dāng)電壓取直角坐標時,并把實部、虛部分開,有:</p><p><b> ?。?- 72)<
69、;/b></p><p><b> ?。?- 73)</b></p><p> 當(dāng)電壓取極坐標時,并把實部、虛部分開,有:</p><p><b> ?。?- 74)</b></p><p><b> ?。?- 75)</b></p><p>
70、 而又考慮到式(3-36)和(3-37),、,則式(3-74)和式(3-75)可進一步化簡為:</p><p><b> (3- 76) </b></p><p><b> ?。?- 77)</b></p><p> 如此一來,就只需多次調(diào)用H1( int i, int j )和N1(int i , int j)兩個子
71、函數(shù),這樣就使程序得到了很大的簡化,也增強了程序的可讀性。</p><p><b> 線路支路</b></p><p> 對于線路支路,可以把接地導(dǎo)納(數(shù)值存放于變量k中)先行加入線路功率之中,即:</p><p><b> (3- 78)</b></p><p> 然后把置變量k=1。這樣
72、就可以把剩下的線路支路看作是變比為1的變壓器支路來處理。</p><p><b> 勵磁支路</b></p><p> 勵磁支路的功率用下式計算:</p><p><b> (3- 79)</b></p><p><b> 網(wǎng)絡(luò)損耗</b></p><
73、;p> 網(wǎng)絡(luò)損耗用下式計算:</p><p><b> ?。?- 80)</b></p><p><b> 主程序結(jié)構(gòu)圖</b></p><p><b> 程序清單</b></p><p> # include"stdio.h"</p&g
74、t;<p> # include"math.h"</p><p> # define N 5 /* 定義節(jié)點數(shù) */</p><p> # define PI 3.14159</p><p> static float YG[N+1][N+1], YB[N+1][N+1];</p>
75、<p> static float J[2*N+1][2*N+1],JPQ[2*N+1];</p><p> static float P[N+1],Q[N+1],DP[N+1],DQ[N+1];</p><p> static float V[N+1],Sita[N+1],DV[N+1],DSita[N+1];</p><p>
76、 static float e[N+1],f[N+1],De[N+1],Df[N+1];</p><p> static float P_x[N+1][N+1],Q_x[N+1][N+1];</p><p> /* 計算P、Q的子函數(shù)*/</p><p> float P1(int i)</p><p><b>
77、 {int j;</b></p><p> float P1=0,tempa=0;</p><p> for(j=1;j<=N;j++)</p><p><b> {</b></p><p> if(i==j) continue;</p><p> tempa+=(V
78、[j]*(YG[i][j]*cos(Sita[i]-Sita[j])+YB[i][j]*sin(Sita[i]-Sita[j])));</p><p><b> }</b></p><p> P1=tempa*V[i];</p><p> return(P1);</p><p><b> }</b
79、></p><p> float Q1(int i)</p><p><b> {int j;</b></p><p> float Q1=0,tempb=0;</p><p> for(j=1;j<=N;j++)</p><p><b> {</b>
80、</p><p> if(i==j) continue;</p><p> tempb+=(V[j]*(YG[i][j]*sin(Sita[i]-Sita[j])-YB[i][j]*cos(Sita[i]-Sita[j])));</p><p><b> }</b></p><p> Q1=V[i]*tempb;
81、</p><p> return(Q1);</p><p><b> }</b></p><p> /* 計算雅可比矩陣元素的子函數(shù) */</p><p> float H1(int i,int j)</p><p><b> {</b></p>&
82、lt;p><b> float H1;</b></p><p> H1=-V[i]*V[j]*(YG[i][j]*sin(Sita[i]-Sita[j])-YB[i][j]*cos(Sita[i]-Sita[j]));</p><p> return(H1);</p><p><b> }</b></p
83、><p> float N1(int i,int j)</p><p> {float N1;</p><p> N1=-V[i]*V[j]*(YG[i][j]*cos(Sita[i]-Sita[j])+YB[i][j]*sin(Sita[i]-Sita[j]));</p><p> return(N1);</p><
84、;p><b> }</b></p><p> float H2(int i,int j)</p><p><b> {</b></p><p> float H2=0;</p><p> H2=(YB[i][j]*e[i]-YG[i][j]*f[i]);</p><
85、;p> return(H2);</p><p><b> }</b></p><p> float N2(int i,int j)</p><p><b> {</b></p><p> float N2=0;</p><p> N2=(-1)*(YG[i]
86、[j]*e[i]+YB[i][j]*f[i]);</p><p> return(N2);</p><p><b> }</b></p><p><b> /* 主程序 */</b></p><p><b> main()</b></p><p>
87、;<b> {</b></p><p> int i,j,m,a,t=0,tt=0;</p><p> int flag1,flag[N+1];</p><p> int Kp,Kq;</p><p> float r,x,k,b;</p><p> float
88、p1,q1,sita1,v1;</p><p> float e1,f1,DV_2;</p><p> float A[N+1],B[N+1];</p><p> float E[N+1],F[N+1];</p><p> float DP_V[N+1],DQ_V[N+1],DSita_V[N+1];</p>&
89、lt;p> float temp1,temp2,temp3,temp;</p><p> float tempa1=0.0,tempa2=0.0;</p><p> float Q_max=5.0 , Q_min=-5.0 ; /* 定義無功越限檢查的上、下限 */</p><p> float B1[N+1][N+1],B2[N+1]
90、[N+1];</p><p> float max1=0.0,max2=0.0;</p><p> float dP,dQ; /* 定義網(wǎng)損變量 */</p><p> float speed; /* 定義加速因子 */</p><p> FILE *fp1,*fp2;</p><
91、;p> int R; /* 定義PV節(jié)點數(shù)變量 */</p><p> int select; /* 定義程序的選擇變量 */</p><p> /* 打開支路參數(shù)原始數(shù)據(jù)文件 */</p><p> if((fp1=fopen("lqp","r"))==NULL)&
92、lt;/p><p><b> {</b></p><p> printf("The file can not open");</p><p><b> exit(0);</b></p><p><b> }</b></p><p>
93、; /* 讀取數(shù)據(jù)并計算節(jié)點導(dǎo)納矩陣 */</p><p> while(!feof(fp1))</p><p><b> {</b></p><p> fscanf(fp1,"%d%d%f%f%f\n",&i,&j,&r,&x,&k);</p><p>
94、; if(i*j==0)</p><p><b> {</b></p><p><b> if(i==0)</b></p><p><b> {</b></p><p> a=i;i=j;j=a;</p><p><b> }<
95、;/b></p><p> YG[i][i]+=r;</p><p> YB[i][i]-=x;</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p>
96、<p><b> if(i*j>0)</b></p><p><b> {</b></p><p> YB[i][i]+=k;</p><p> YB[j][j]+=k;</p><p><b> k=1;</b></p><p&
97、gt;<b> }</b></p><p><b> else</b></p><p><b> {</b></p><p><b> if(j<0)</b></p><p><b> {</b></p>
98、<p> a=i;i=j;j=a;</p><p><b> }</b></p><p><b> if(k<0)</b></p><p><b> k=-1/k;</b></p><p><b> }</b></p>
99、;<p> i=fabs(i);</p><p> b=r*r+x*x;</p><p> YG[i][j]=YG[j][i]=(-1)*r/(k*b);</p><p> YB[i][j]=YB[j][i]=x/(k*b); </p><p> YG[j][j]+=r/b;</p><p>
100、 YB[j][j]-=x/b;</p><p> YG[i][i]+=r/(k*k*b);</p><p> YB[i][i]-=x/(k*k*b);</p><p><b> }</b></p><p><b> }</b></p><p> fclose(fp1
101、);</p><p> start: clrscr(); </p><p> /* 計算方法選擇 */</p><p> printf(" 電力系統(tǒng)潮流計算\n\n\n\n\n");</p><p> printf("請選擇要使用的計算方
102、法:\n\n");</p><p> printf("1---牛頓--拉夫遜法(極坐標)\n\n");</p><p> printf("2---牛頓--拉夫遜法(直角坐標)\n\n");</p><p> printf("3---高斯--塞得爾法\n\n");</p><
103、;p> printf("4---P--Q分解法\n\n\n");</p><p> printf("please enter the number :");</p><p> scanf("%d",&select);</p><p> switch(select)</p>
104、<p><b> {</b></p><p> case 1: printf(" 牛頓--拉夫遜法(極坐標)運行結(jié)果:\n"); goto label1;</p><p> case 2: printf(" 牛頓--拉夫遜法(直角坐標)運行結(jié)果:\n"); goto la
105、bel2;</p><p> case 3: {</p><p> printf("請輸入加速因子的值(1~1.5)(best for 1.44):"); </p><p> scanf("%f",&speed);</p><p> printf(" 高斯--塞
106、得爾法 運行結(jié)果:\n"); goto label3;</p><p><b> }</b></p><p> case 4: printf(" P--Q分解法 運行結(jié)果:\n"); goto label4;</p><p><b>
107、 } </b></p><p> goto end_all;</p><p> /* 牛頓極坐標程序入口 */</p><p><b> label1: </b></p><p> /* 打開節(jié)點原始數(shù)據(jù)文件并讀取 */</p><p> if((fp2=fopen(&q
108、uot;lqp2","r"))==NULL)</p><p><b> {</b></p><p> printf("The file cann't be opened");</p><p><b> exit(0);</b></p><
109、p><b> }</b></p><p><b> R=0;</b></p><p> while(!feof(fp2))</p><p><b> {</b></p><p> fscanf(fp2,"%d%d%f%f%f%f",&
110、i,&flag1,&p1,&q1,&v1,&sita1);</p><p> flag[i]=flag1;</p><p> if(flag[i]==-1) R++;</p><p><b> P[i]=p1;</b></p><p><b> Q[i]=q1;
111、</b></p><p><b> V[i]=v1;</b></p><p> Sita[i]=sita1;</p><p><b> }</b></p><p> fclose(fp2);</p><p> /* 進行主循環(huán) */</p>
112、<p><b> t=0;</b></p><p><b> do</b></p><p><b> {</b></p><p> /* 求功率誤差DP、DQ */</p><p> for(i=1;i<=N-1;i++)</p>&l
113、t;p><b> {</b></p><p> DP[i]=P[i]-V[i]*V[i]*YG[i][i]-P1(i);</p><p> JPQ[2*i-1]=DP[i];</p><p><b> }</b></p><p> for(i=1;i<=N-R-1;i++)&l
114、t;/p><p><b> {</b></p><p> DQ[i]=Q[i]+V[i]*V[i]*YB[i][i]-Q1(i);</p><p> JPQ[2*i]=DQ[i];</p><p><b> }</b></p><p> /* 計算雅可比矩陣各元素 */
115、</p><p> for(i=1;i<=N-R-1;i++) </p><p> for(j=1;j<=N-1;j++)</p><p><b> {</b></p><p><b> if(i!=j)</b></p><p><b>
116、; {</b></p><p> if(j<=N-R-1)</p><p><b> {</b></p><p> J[2*i-1][2*j-1]=H1(i,j);</p><p> J[2*i-1][2*j]=N1(i,j);</p><p> J[2*i][2*j
117、-1]=(-1)*N1(i,j);</p><p> J[2*i][2*j]=H1(i,j);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> J[2*i
118、-1][2*j-1]=H1(i,j);</p><p> J[2*i][2*j-1]=(-1)*N1(i,j);</p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p&g
119、t;<b> {</b></p><p> J[2*i-1][2*j-1]=Q1(i);</p><p> J[2*i-1][2*j]=-2*V[i]*V[i]*YG[i][i]-P1(i);</p><p> J[2*i][2*j-1]=-P1(i);</p><p> J[2*i][2*j]=2*V[i]*
120、V[i]*YB[i][i]-Q1(i);</p><p><b> }</b></p><p><b> }</b></p><p> for(i=N-R;i<=N-1;i++) </p><p> for(j=1;j<=N-1;j++)</p><
121、p><b> {</b></p><p><b> if(i!=j)</b></p><p><b> {</b></p><p> if(j<=N-R-1)</p><p><b> {</b></p><p&g
122、t; J[2*i-1][2*j-1]=H1(i,j);</p><p> J[2*i-1][2*j]=N1(i,j);</p><p><b> }</b></p><p> else </p><p> J[2*i-1][2*j-1]=H1(i,j); </p><p&g
123、t;<b> }</b></p><p><b> else</b></p><p> J[2*i-1][2*j-1]=Q1(i); </p><p><b> }</b></p><p> /* 求逆雅可比矩陣 */ </p>
124、<p> for(m=1;m<=2*(N-1)-R;m++)</p><p><b> {</b></p><p> for(i=1;i<=2*(N-1)-R;i++)</p><p> for(j=1;j<=2*(N-1)-R;j++)</p><p> if(i!=m &
125、& j!=m)</p><p> J[i][j]=J[i][j]-J[i][m]*J[m][j]/J[m][m];</p><p> for(j=1;j<=2*(N-1)-R;j++)</p><p><b> if(j!=m)</b></p><p> J[m][j]=(-1)*J[m][j]/J
126、[m][m];</p><p> for(i=1;i<=2*(N-1)-R;i++)</p><p><b> if(i!=m)</b></p><p> J[i][m]=(-1)*J[i][m]/J[m][m];</p><p> J[m][m]=(-1)/J[m][m];</p><
127、p><b> }</b></p><p> for(i=1;i<=2*(N-1)-R;i++)</p><p> for(j=1;j<=2*(N-1)-R;j++)</p><p> J[i][j]=(-1)*J[i][j];</p><p> /* 解修正方程式 */ </p>
128、<p> for(i=1;i<=2*(N-1)-R;i++)</p><p><b> {</b></p><p> int tt=(i+1)/2;</p><p> float temp=0;</p><p> for(j=1;j<=2*(N-1)-R;j++)</p>
129、<p><b> {</b></p><p> temp+=J[i][j]*JPQ[j];</p><p> if(i%2==1)</p><p> DSita[tt]=-temp;</p><p><b> else</b></p><p> DV[
130、tt]=-temp*V[tt];</p><p><b> }</b></p><p><b> }</b></p><p><b> max1=0;</b></p><p> for(i=1;i<N;i++)</p><p><b&
131、gt; {</b></p><p> if(max1<fabs(DSita[i])) max1=fabs(DSita[i]);</p><p> if(max1<fabs(DV[i])) max1=fabs(DV[i]);</p><p><b> }</b></p><
132、;p> /* 修正各節(jié)點電壓 */ </p><p> for(i=1;i<N;i++)</p><p><b> {</b></p><p> Sita[i]=Sita[i]+DSita[i];</p><p> V[i]=V[i]+DV[i];</p><p><b
133、> }</b></p><p><b> t++;</b></p><p> }while(max1>1e-5);</p><p> goto calculate;</p><p> /* 牛頓直角坐標程序入口*/</p><p><b> label
134、2: </b></p><p> if((fp2=fopen("lqp2","r"))==NULL)</p><p><b> {</b></p><p> printf("Can not open ");</p><p><b>
135、 exit(0);</b></p><p><b> }</b></p><p> while(!feof(fp2))</p><p><b> {</b></p><p> fscanf(fp2,"%d%d%f%f%f%f\n",&i,&f
136、lag1,&p1,&q1,&e1,&f1);</p><p> flag[i]=flag1;</p><p><b> P[i]=p1;</b></p><p><b> Q[i]=q1;</b></p><p> if(flag[i]==-1) /* 把P
137、V節(jié)點的電壓存放到無功數(shù)組中 */</p><p><b> Q[i]=e1;</b></p><p><b> e[i]=e1;</b></p><p><b> f[i]=f1;</b></p><p><b> }</b></p>
138、<p> fclose(fp2);</p><p> /* 進行主循環(huán) */</p><p><b> t=0;</b></p><p><b> do</b></p><p><b> {</b></p><p> for(i
139、=1;i<N;i++)</p><p><b> {</b></p><p> float tempa=0,tempb=0;</p><p> for(j=1;j<=N;j++)</p><p><b> {</b></p><p> tempa+=YG
140、[i][j]*e[j]-YB[i][j]*f[j];</p><p> tempb+=YG[i][j]*f[j]+YB[i][j]*e[j];</p><p><b> }</b></p><p> A[i]=tempa;</p><p> B[i]=tempb;</p><p> /*
141、 處理PQ節(jié)點 */</p><p> if(flag[i]==1)</p><p><b> {</b></p><p> DP[i]=P[i]-(e[i]*A[i]+f[i]*B[i]);</p><p> DQ[i]=Q[i]-(f[i]*A[i]-e[i]*B[i]);</p><p&
142、gt; for(j=1;j<N;j++)</p><p><b> {</b></p><p><b> if(j==i)</b></p><p><b> {</b></p><p> J[2*i-1][2*j-1]=H2(i,j)-B[i];</p&g
143、t;<p> J[2*i-1][2*j]=N2(i,j)-A[i];</p><p> J[2*i][2*j-1]=(-1)*N2(i,j)-A[i];</p><p> J[2*i][2*j]=H2(i,j)+B[i];</p><p><b> }</b></p><p><b>
144、else</b></p><p><b> {</b></p><p> J[2*i-1][2*j-1]=H2(i,j);</p><p> J[2*i-1][2*j]=N2(i,j);</p><p> J[2*i][2*j-1]=(-1)*N2(i,j);</p><p>
145、 J[2*i][2*j]=H2(i,j);</p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> /* 處理PV節(jié)點 */</p><p> if(flag[i]=
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 電力系統(tǒng)潮流計算c程序
- 電力系統(tǒng)潮流計算課程設(shè)計
- 電力系統(tǒng)潮流計算課程設(shè)計
- 電力系統(tǒng)課程設(shè)計-- 潮流計算
- 電力系統(tǒng)課程設(shè)計-----潮流計算
- 電力系統(tǒng)潮流計算課程設(shè)計
- 電力系統(tǒng)分析課程設(shè)計-- 電力系統(tǒng)潮流計算
- 電力系統(tǒng)分析課程設(shè)計--電力系統(tǒng)潮流計算
- 電力系統(tǒng)潮流計算課程設(shè)計
- 基于matlab的電力系統(tǒng)潮流計算
- 電力系統(tǒng)潮流計算課程設(shè)計
- 電力系統(tǒng)潮流計算課程設(shè)計
- 畢業(yè)設(shè)計--電力系統(tǒng)潮流計算
- 電力系統(tǒng)課程設(shè)計--潮流計算
- 電力系統(tǒng)全局潮流計算研究.pdf
- 電力系統(tǒng)潮流計算畢業(yè)論文
- 潮流計算課程設(shè)計--基于matlab的電力系統(tǒng)潮流計算
- 9節(jié)點電力系統(tǒng)潮流計算
- 電力系統(tǒng)綜合課程設(shè)計--電力系統(tǒng)的潮流計算和故障分析
- 電力系統(tǒng)穩(wěn)態(tài)潮流計算課程設(shè)計
評論
0/150
提交評論