Python プログラムを使用して、PSS/E でバスの負荷を変更しようとしています。そこで、PSS/E の 2 つのバス間で負荷を異なる値に変更できるスクリプトを Python で作成しようとしています。
4 に答える
PSSE で負荷を処理するためにこのクラスを作成しました...最初は SQL 錬金術で送信されたため、削除した余分なものがいくつかあります。
class Load():
def __init__(self,busnumber,loadID):
# Initialize the Branch Class Instance Variables to a Default 0; Except for the From,To and Circuit ID
self.bus = Bus(busnumber)
self.busI = busnumber
self.loadID = loadID
self.status = 0
self.Pload = 0.0
self.Qload = 0.0
self.errorList = []
self.init()
def init(self):
# Setup the load from the case
# Check to see if bus exists
busOk = self.bus.init()
if not busOk[0]:
return (False,self.bus.number,"The bus number %d is invalid or does not exist..." % self.bus.number)
if psspy.loddt2(self.bus.number,self.loadID,'TOTAL','ACT')[0] != 0:
return (False,False)
Scomplex = self.check(psspy.loddt2(self.bus.number,self.loadID,'TOTAL','ACT'),'loddt2','ACT') # Grab the S vector/phasor from the power flow case for the load specified at the BUS number
self.Pload = Scomplex.real
self.Qload = Scomplex.imag
self.status = self.check(psspy.lodint(self.bus.number,self.loadID,'STATUS'),'lodint','STATUS') # Grab the Status of the Load
return (True,self.bus.number)
def check(self,tuple,funName,subFun):
# Define Error Messages that should be accesable by the end-user and developer
loddt2 = {
0:'No error; P and Q or CMPVAL returned',
1:'Bus not found; P and Q or CMPVAL unchanged.',
2:'Load not found; P and Q or CMPVAL unchanged.',
3:'Bus type code is not 1, 2 or 3; P and Q or CMPVAL returned.',
4:'Load out-of-service; P and Q or CMPVAL returned.',
5:'Invalid value of STRING1 or STRING2; P and Q or CMPVAL unchanged.'
}
lodint = {
0:'No error; IVAL returned.',
1:'Bus not found; IVAL unchanged.',
2:'Load not found; IVAL unchanged.',
3:'Bus type code is not 1, 2 or 3; IVAL returned.',
4:'Load out-of-service; IVAL returned.',
5:'Invalid value of STRING; IVAL unchanged.'
}
funDic = {
'loddt2':loddt2,
'lodint':lodint
}
# Retrieve the Right Error Message
list = funDic[funName]
msg = list[tuple[0]]
if tuple[0] > 0:
logging.debug("Function Name: %s Sub Function Name: %s Error Message: %s"%(funName,subFun,msg))
return tuple[1]
def setLoad(self,loadP):
self.Pload = loadP
def updateCase(self):
# Setup Defaults
_i = psspy.getdefaultint()
_f = psspy.getdefaultreal()
cDef = psspy.getdefaultchar()
psspy.load_data_3(self.bus.number,self.loadID,[self.status,_i,_i,_i,_i],[self.Pload, self.Qload,_f,_f,_f,_f])
# To String Method
def __repr__(self):
return "%d %s %d %d" %(self.bus.number,self.loadID,self.Pload,self.Qload)
# printf Statement that Dumps information to CMD line...Homeage to C and C++
def printf(self):
print "\n Bus: %d \n Load ID: %s \n MW Value: %d \n MVAR Value: %d \n" % (self.bus.number,self.loadID,self.Pload,self.Qload)
「updateCase」という名前の関数を呼び出すと、ロード オブジェクトに保存されている値をすべて取得し、PSSE ケースを更新します。
「LOAD_CHNG_4」という API ルーチンを使用できます (API.pdf ドキュメントでこのルーチンを検索してください)。このルーチンは、一連のロード データ指定関数に属します。作業ケースの既存の荷重のデータを変更するために使用できます。
PSSE python API の第 II 章を見てください。変化する電力潮流データを完全にカバーします。ロードデータは、バス番号とロード ID で参照できます。荷重データ自体を手動で入力すると、銘板に表示されるすべてのパラメータを変更できます。以下のこの機能を使用して、負荷を変更します。
ierr = psspy.load_chang(bus_number, load_id, intgar,realar)
詳細については、API マニュアルの 728 ページを参照してください。
http://www.whit.com.au/blog/2011/07/run-psse-from-python-and-not-other-way/
I found this blog post about how to run Python command from PSSE. I don't think that your question has anything to do with ASP.NET though.