PSS®E Static
Introduction
The PSS®E Static Node performs static study simulations which are powered by PSS®E, a 3rd party power systems software. It leverages the following PSS®E modules:
- Power Flow
- Short Circuit
This Node is typically used for the following:
- Completing static studies (e.g. investigating thermal loading of an asset pre and post a variety of contingencies).
- Setting up cases for dynamic studies (e.g. creating a case for a specific active power set point as part of a test).
Check our system requirements page for information on which PSS®E versions are currently supported.
User inputs
Select model
Model
Defines the input directory and file name of the PSS®E Case file, including the .sav
file extension.
Example:
sunny-solar-farm\SMIB.sav
File paths are relative to the Engine's 'inputs' directory, as defined by the Engine configuration parameter dirs.inputs
. For example, if dirs.inputs
was set as C:\Users\johnsmith\gridmo\Inputs\
:
Absolute file path | Relative file path (required by gridmo) |
---|---|
C:\Users\johnsmith\gridmo\Inputs\sunny-solar-farm\SMIB.sav | sunny-solar-farm\SMIB.sav |
Define simulation
This allows you to merge your Model into a network model. If enabled, this merge process is completed before the Commands are applied.
Network model
Defines the input directory and file name of the PSS®E Case file, including the .sav
file extension.
Example:
network-model/case.sav
Model: Bus number
Defines the bus number in the Model at which the network model is merged.
Example:
100
Network model: Bus number
Defines the bus number in the Network model at which the model is merged.
Example:
30000
Commands
Defines the Commands which configure the static simulation.
Supported Commands:
- ADD: Adds a new type of network element (e.g. load).
- SET: Sets the status or value of a network element (e.g. bus, line, generator).
- CONTROL: Controls a network element.
- SOLVE: Solves the static case, considering all previous
SET
andCONTROL
Commands. - OUTPUT: Outputs a value as an Internode Variable.
All SET
and CONTROL
Commands preceding a SOLVE
Command are applied at the same time when the SOLVE
Command is used. Multiple SOLVE
Commands are supported and can be used when you want to apply SET
and CONTROL
Commands sequentially. For example:
SET COMMAND 1
SET COMMANDS 2
CONTROL COMMAND 1
SOLVE
CONTROL COMMAND 2
SOLVE
This following two static solves will occur:
- Solve considering
SET COMMAND 1
,SET COMMAND 2
andCONTROL COMMAND 1
; then - Solve considering
CONTROL COMMAND 2
.
Advanced
PSS®E version
Defines the PSS®E version used for the Node. Defaults to Engine configuration.
PSS®E Python API
Defines the PSS®E API version used for the Node. Defaults to Engine configuration.
Advanced Parameters
Advanced Parameters allow users to configure test details which are not commonly used. Advanced Parameters are often specific to each Node type.
Each line represents a new Advanced Parameter and is entered as a=b
format, where a
is the name of the Parameter and b
is the corresponding value. All Advanced Parameters are set to their default values if they are not included in the Advanced Parameters field.
Example: Set Advanced Parameter, sample.parameter
to a value of 5
.
sample.parameter=5
API Reference
This section details the Commands and Advanced Parameters specific to the Node.
Lines are defined using the following syntax: from->to#id. When completing SMIB studies, we recommend always having the 'to' bus closer to the connection point. Note that the 'from' and 'to' definitions used in Commands (i.e. from->to#id) don't necessarily need to match the .sav case.
ADD
Command
Add load
ADD, TYPE=LOAD, BUS=, P=, Q=, YP=, YQ=
Adds a load network element at a bus.
Arguments:
- ADD
- TYPE (
str
): Network element type. Set asLOAD
. - BUS (
int
): Bus number. - P (
float
): Constant active power [MW]. - Q (
float
): Constant reactive power [MVAr]. - YP (
float
): Constant admittance active power [MW]. - YQ (
float
): Constant admittance reactive power [MVAr].
At least one of P=
, Q=
, YP=
or YQ=
must be specified. Any unspecified values default to 0.
Example: Add a 25 MW, 5 MVAr load at bus 400.
ADD, TYPE=LOAD, BUS=400, P=25, Q=5
Added loads have a PSS®E ID of Gx
where x
is an integer. For example:
- The Command
ADD, BUS=100, P=10
creates a load with identifier100#G1
. - If a second
ADD, BUS=100, P=10
Command was used, a new load with identifier100#G2
would be created.
SET
Command
Set bus
SET, BUS=, [BUS=], STATUS=
Sets the status of a bus.
Arguments:
- SET
- BUS (
int
): Bus number. - BUS (
int
)[Optional]: Additional bus numbers. - STATUS (
str
): Bus status. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.STATUS=1
: Explicitly set bus type code as 1 (i.e. Non-Gen Bus).STATUS=2
: Explicitly set bus type code as 2 (i.e. Generator Bus).STATUS=3
: Explicitly set bus type code as 3 (i.e. Swing bus).STATUS=4
: Explicitly set bus type code as 4 (i.e. Disconnected).
We recommend using STATUS=IN
and STATUS=OUT
Arguments. Explicitly setting the bus type code is not recommended since it doesn't consider what assets are connected to the selected bus.
Example: Set bus 100 out of service.
SET, BUS=100, STATUS=OUT
Set line
SET, LINE=, [LINE=], STATUS=, [SCR=, XR=]
Sets the status and impedance of a line.
Arguments:
- SET
- LINE (
pas
): Line definition. Lines are defined using the following syntax:from->to#id
. - LINE (
pas
)[Optional]: Additional line definitions (only if usingSTATUS=
,SCR=
andXR=
arguments only support one line) - STATUS (
str
): Line status. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.
- SCR (
float
)[Optional]:SCR=X
(whereX
is a number): Sets the impedance of the given line to the equivalent Thévenin impedance based on the Project's rated active power [MW], the line voltage and the specified SCR and X/R ratio.SCR=INF
: Sets the impedance of the given line to the minimum impedance value applicable in PSS®E (i.e. 1e-5 on system base).XR=
Argument is ignored.
- XR (
float
)[Optional]: Sets the impedance of the given line to the equivalent Thévenin impedance based on the Project's rated active power [MW], the line voltage and the specified SCR and X/R ratio.
SCR
and XR
Arguments must be used together. These Arguments are typically only used in SMIB studies and are used to calculate the Thévenin equivalent source impedance of the infinite generator.
Example: Set the impedance of the line from bus 800 to bus 900 which has an ID of 1. The line impedance should represent the system Thévenin equivalent impedance for an SCR of 3 and X/R ratio of 2.
SET, LINE=800->900#1, STATUS=IN, SCR=3, XR=2
Example: Set the impedance of the line from bus 1000 to bus 999 with ID 1 to near-zero impedance (infinite system strength), noting that XR=
Argument is ignored.
SET, LINE=1000->999#1, STATUS=IN, SCR=INF, XR=1
Set transformer
SET, TX=, [STATUS=, TAPRATIO=, WINDING=]
Sets the status of a transformer.
Arguments:
- SET
- TX (
pas
): Transformer definition. Transformers are defined using the following syntax:bus1->bus2#id
(two-winding transformer) orbus1->bus2->bus3#id
(three-winding transformer). - STATUS (
str
)[Optional]: Transformer status. If not specified, transformer status is not changed from the current state. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.
- TAPRATIO (
float
)[Optional]: Sets the tap ratio of the specified winding number. The control mode of the transformer will be set to "None" to ensure the set tap ratio is maintained irrespective of whetherSOLVE, LOCKTAPS=NO
is used. - WINDING (
int
)[Optional]: The winding number used when setting the tap ratio. Options:WINDING=1
: Winding number 1.WINDING=2
: Winding number 2.WINDING=3
: Winding number 3 (only applicable for three-winding transformers).
Example: Set the three-winding transformer in-service which is located between bus 100, bus 200, and bus 300 and which has an ID of 1.
SET, TX=100->200->300#1, STATUS=IN
Example: Set the tap position of winding one of the two-winding transformer to 0.975 which is located between bus 100 and bus 200 and which has an ID of 1.
SET, TX=100->200#1, TAPRATIO=0.975, WINDING=1
Setting the tap ratio assumes that the transformer winding I/O code is in p.u., not kV.
Set generator
SET, GEN=, [GEN=], STATUS=
Sets the status or active/reactive power limits of a generator.
Arguments:
- SET
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. - STATUS (
str
): Generator status. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.
- QMAX (
float
)[Optional]: Maximum reactive power capability of the generator [MVAr]. - QMIN (
float
)[Optional]: Minimum reactive power capability of the generator [MVAr]. - PMAX (
float
)[Optional]: Maximum active power capability of the generator [MW]. - PMIN (
float
)[Optional]: Minimum active power capability of the generator [MW]. - MBASE (
float
)[Optional]: Base MVA of the generator [MVA] - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toQMAX
,QMIN
,PMAX
andPMIN
(i.e.PMAX
xVALSCALE
). Default value is 1.
Example: Set the generator out of service which is located at bus 100 which has an ID of 1.
SET, GEN=100#1, STATUS=OUT
Example: Set the aggregated generator at bus 150
with id 1
active power min and maximum range to -1.5
MW (for example, to represent a synchronous machine operating in synchronous condenser mode).
SET, GEN=150#1, PMIN=-1.5, PMAX=-1.5
Set load
SET, LOAD=, STATUS=
Sets the status of a load.
Arguments:
- SET
- LOAD (
pas
): Load definition. Loads are defined using the following syntax:bus#id
. - STATUS (
str
): Load status. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.
Example: Set the load out of service which is located at bus 100 and which has an ID of 2.
SET, LOAD=100#2, STATUS=OUT
Set fixed shunt
SET, FSHUNT=, STATUS=
Sets the status of a fixed shunt.
Arguments:
- SET
- FSHUNT (
pas
): Fixed shunt definition. Fixed shunts are defined using the following syntax:bus#id
. - STATUS (
str
): Fixed shunt status. Options:STATUS=IN
: Status is in-service.STATUS=OUT
: Status is out of service.
In PSS®E, fixed shunts are different network elements to loads.
Example: Set the fixed shunt out of service which is located at bus 200 and which has an ID of 3.
SET, FSHUNT=200#3, STATUS=OUT
CONTROL
Command
Control Commands are additional solution requirements added to the convergence algorithm which is initiated by the SOLVE
Command. These Commands typically cover functionality which is not natively supported by PSS®E. A SOLVE
Command is required for preceding CONTROL
Commands to be considered.
CONTROL
Commands are reset after each SOLVE
Command is used. If you want a CONTROL
Command to be used it must precede each SOLVE
Command. For a Node with multiple SOLVE
Commands, this may require repeating the CONTROL
Command. For example:
SET COMMAND 1
CONTROL COMMAND 1
SOLVE
SET COMMAND 2
SOLVE
CONTROL COMMAND 1
SOLVE
This following three static solves will occur:
- Solve considering
SET COMMAND 1
andCONTROL COMMAND 1
; then - Solve considering
SET COMMAND 2
; then - Solve considering
CONTROL COMMAND 1
.
You can control multiple generators by using multiple GEN=
arguments. If more than one generator specified, the active/reactive power requirement will be shared between the generators based on the ratio of the respective generators' rated MVA.
Control generator - Direct voltage control
CONTROL, GEN=, Q=VDIRECT, QMIN=, QMAX=, ATBUS=, [VALSCALE=1], VTARGET=
Controls one generator using direct voltage control (not voltage droop control).
Arguments:
- CONTROL
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. Generators are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asVDIRECT
. - QMIN (
float
): Minimum reactive power capability of the generator [MVAr]. - QMAX (
float
): Maximum reactive power capability of the generator [MVAr]. - ATBUS (
int
): Bus number which has the target voltage. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toVTARGET
(i.e.VTARGET
xVALSCALE
). Default value is 1. - VTARGET (
float
)[Optional]: Target voltage set point [p.u.]. Default value is the voltage specified in theSchedu Voltage
field (withinPlant Data
) for the specified generator.
Example: Control the generator at bus 100 which has an ID of 1. The control is direct voltage control of bus 300 with a target voltage of 1.01 [p.u.]. The generator can supply reactive power between -10 MVAr and +15 MVAr.
CONTROL, GEN=100#1, Q=VDIRECT, QMIN=-10, QMAX=15, ATBUS=300, VTARGET=1.01
Control generator - Droop voltage control
CONTROL, GEN=, [GEN=], Q=VDROOP, QBASE=, DROOP%=, DEADBAND=, [QMIN=, QMAX=], ATBUS=, ATLINE=, [METERBUS =, VALSCALE=1], VTARGET=, [CONSIDER_EXISTING_DISPATCH=YES]
Controls one or more generators using voltage droop control. If the measured voltage is larger/smaller than the voltage target + deadband, the specified generators will be controlled to absorb/supply reactive power equal to the droop percentage of QBASE for every 1% the measured voltage is above the voltage target + deadband.
Arguments:
- CONTROL
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. Generators are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asVDROOP
. - QBASE (
float
): Base reactive power [MVAr]. - DROOP% (
float
): Droop percentage [%]. - DEADBAND (
float
): Voltage deadband [p.u.]. - QMIN (
int
)[Optional]: Minimum reactive power limit at theATLINE=
line [MVAr]. Default value is -∞. - QMAX (
int
)[Optional]: Maximum reactive power limit at theATLINE=
line [MVAr]. Default value is ∞. - ATBUS (
int
): Bus number which has the target voltage. - ATLINE (
pas
): Line which is used for measuring the reactive power. Lines are defined using the following syntax:from->to#id
. - METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toVTARGET
(i.e.VTARGET
xVALSCALE
). Default value is 1. - VTARGET (
float
): Target voltage set point [p.u.]. Default value is the voltage specified in theSchedu Voltage
field (withinPlant Data
) for the specified generator. - CONSIDER_EXISTING_DISPATCH (
bool
)[Optional]: Defaults toYES
. Options:CONSIDER_EXISTING_DISPATCH=YES
: The static controller logic considers the existing reactive power dispatch values in the case file (i.e. Qgen) for the controlled generators. If the existing dispatch values are not distributed equally amongst the controlled generators according to their machine MVA ratings, they will likely remain unequal.CONSIDER_EXISTING_DISPATCH=NO
: The existing dispatch values are ignored and dispatch values are forced to be distributed equally amongst the controlled generators according to their machine MVA ratings.
Example: A PPC exists between bus 600 and bus 700 (ID=1) and is controlling a generator at bus 100 which has an ID of 1. The PPC is acting in voltage droop control with a target voltage of 1.01 [p.u.] at bus 600, a QBASE of 50 MVAr, a droop percentage of 4% and a voltage deadband of 0.01 [p.u.].
CONTROL, GEN=100#1, Q=VDROOP, QBASE=50, DROOP%=4, DEADBAND=0.01, ATBUS=600, ATLINE=600->700#1, VTARGET=1.01
Example: A PPC exists between bus 600 and bus 700 (ID=1) and is controlling two generators at bus 100 which has an ID of 1 and at bus 200 which has an ID of 1. The PPC is controlling two generators with equal machine base (which represent two aggregated collector groups of a wind farm). The PPC is acting in voltage droop control with a target voltage of 1.01 [p.u.] at bus 600, a QBASE of 50 MVAr, a droop percentage of 4% and a voltage deadband of 0.01 [p.u.]. The static controller logic should not consider the existing dispatch files in the case file and should ensure that the reactive power dispatch is shared equally across the two generators.
CONTROL, GEN=100#1, GEN=200#1, Q=VDROOP, QBASE=50, DROOP%=4, DEADBAND=0.01, ATBUS=600, ATLINE=600->700#1, VTARGET=1.01, CONSIDER_EXISTING_DISPATCH=NO
Control generator - Fixed reactive power control
CONTROL, GEN=, [GEN=], Q=FIXED, ATLINE=, [METERBUS=, VALSCALE=1], QTARGET=, [CONSIDER_EXISTING_DISPATCH=YES]
Controls one or more generators using fixed reactive power control. The reactive power target will be applied across the specified line.
Arguments:
- CONTROL
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. Generators are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asFIXED
. - ATLINE: Location of the target reactive power. Options:
ATLINE=TERMINALS
: Reactive power target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Reactive power target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toQTARGET
(i.e.QTARGET
xVALSCALE
). Default value is 1. - QTARGET (
float
): Target reactive power set point [MVAr]. - CONSIDER_EXISTING_DISPATCH (
bool
)[Optional]: Defaults toYES
. Options:CONSIDER_EXISTING_DISPATCH=YES
: The static controller logic considers the existing reactive power dispatch values in the case file (i.e. Qgen) for the controlled generators. If the existing dispatch values are not distributed equally amongst the controlled generators according to their machine MVA ratings, they will likely remain unequal.CONSIDER_EXISTING_DISPATCH=NO
: The existing dispatch values are ignored and dispatch values are forced to be distributed equally amongst the controlled generators according to their machine MVA ratings.
Example: Control the generator at bus 100 which has an ID of 1. The control mode is fixed reactive power control regulating -20 MVAr across the line from bus 400 to bus 500 (measured at the 'to-side') which has an ID of 1.
CONTROL, GEN=100#1, Q=FIXED, ATLINE=400->500#1, METERBUS=500, QTARGET=-20
Example: Control two generators. The first generator has a machine base of 100MVA and is at bus 1500 with ID of 1. The second generator has a machine base of 100MVA and is at bus 1505 with ID of 2. The control mode is fixed reactive power control regulating -20 MVAr across the line from bus 400 to bus 500 (measured at the 'to-side') which has an ID of 1. The static controller logic should not consider the existing dispatch files in the case file and should ensure that the reactive power dispatch is shared equally across the two generators.
CONTROL, GEN=1500#1, GEN=#1505#2, Q=FIXED, ATLINE=400->500#1, METERBUS=500, QTARGET=-20, CONSIDER_EXISTING_DISPATCH=NO
Control generator - Power factor control
CONTROL, GEN=, [GEN=], Q=PF, ATLINE=, [METERBUS=, VALSCALE=1], PFTARGET=, [CONSIDER_EXISTING_DISPATCH=YES]
Controls one or more generators using power factor power control.
Arguments:
- CONTROL
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. Generators are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asPF
. - ATLINE: Location of the target power factor. Options:
ATLINE=TERMINALS
: Power factor target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Power factor target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toPFTARGET
(i.e.PFTARGET
xVALSCALE
). Default value is 1. - PFTARGET (
float
): Target power factor set point. - CONSIDER_EXISTING_DISPATCH (
bool
)[Optional]: Defaults toYES
. Options:CONSIDER_EXISTING_DISPATCH=YES
: The static controller logic considers the existing reactive power dispatch values in the case file (i.e. Qgen) for the controlled generators. If the existing dispatch values are not distributed equally amongst the controlled generators according to their machine MVA ratings, they will likely remain unequal.CONSIDER_EXISTING_DISPATCH=NO
: The existing dispatch values are ignored and dispatch values are forced to be distributed equally amongst the controlled generators according to their machine MVA ratings.
Example: Control the generator at bus 100 which has an ID of 1. The control is power factor control of -0.97 at the generator terminals.
CONTROL, GEN=100#1, Q=PF, ATLINE=TERMINALS, PFTARGET=-0.97
Control generator - Active power control
CONTROL, GEN=, [GEN=], ATLINE=, [METERBUS=, VALSCALE=1], P=, [CONSIDER_EXISTING_DISPATCH=YES]
Controls the active power of one or more generators.
Arguments:
- CONTROL
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - GEN (
pas
)[Optional]: Additional generator definitions. Generators are defined using the following syntax:bus#id
. - ATLINE Location of the target active power. Options:
ATLINE=TERMINALS
: Active power target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Active power target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toP
(i.e.P
xVALSCALE
). Default value is 1. - P (
float
): Active power target [MW]. - CONSIDER_EXISTING_DISPATCH (
bool
)[Optional]: Defaults toYES
. Options:CONSIDER_EXISTING_DISPATCH=YES
: The static controller logic considers the existing active power dispatch values in the case file (i.e. Pgen) for the controlled generators. If the existing dispatch values are not distributed equally amongst the controlled generators according to their machine MVA ratings, they will likely remain unequal.CONSIDER_EXISTING_DISPATCH=NO
: The existing dispatch values are ignored and dispatch values are forced to be distributed equally amongst the controlled generators according to their machine MVA ratings.
Example: A PPC has a target active power set point and is controlling two generators at bus 100 (ID=1) and bus 200 (ID=1). The active power set point is 95 MW and is applied across the line from bus 400 to bus 500 (measured at the 'from-side') which has an ID of 1.
CONTROL, GEN=100#1, GEN=200#1, ATLINE=400->500#1, P=95
Control load - Fixed reactive power control
CONTROL, LOAD=, Q=FIXED, ATLINE=, [METERBUS=, VALSCALE=1], QTARGET/YQTARGET=
Controls a load/shunt using fixed reactive power control.
Arguments:
- CONTROL
- LOAD (
pas
): Load/shunt definition. Loads and shunts are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asFIXED
. - Target reactive power set point. Options:
- QTARGET= (
float
): Target reactive power set point [MVAr] for constant power load; or - YQTARGET= (
float
): Target reactive power set point [MVAr] for constant admittance load.
- QTARGET= (
- ATLINE Location of the target active power. Options:
ATLINE=TERMINALS
: Reactive power target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Reactive power target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toQTARGET
(i.e.QTARGET
xVALSCALE
). Default value is 1.
Only one LOAD=
argument is supported per Command.
Example: Control the load at bus 100 which has an ID of 1. The control mode is fixed reactive power control of -10 MVAr across the line from bus 400 to bus 500 (measured at the 'from-side') which has an ID of 1.
CONTROL, LOAD=100#1, Q=FIXED, ATLINE=400->500#1, QTARGET=-10
Control load - Power factor control
CONTROL, LOAD=, Q=PF, ATLINE=, [METERBUS=, VALSCALE=1], PFTARGET=
Controls a load/shunt using power factor control.
Arguments:
- CONTROL
- LOAD (
pas
): Load/shunt definition. Loads and shunts are defined using the following syntax:bus#id
. - Q (
str
): Reactive power control methodology. Set asPF
. - ATLINE Location of the target power factor. Options:
ATLINE=TERMINALS
: Power factor target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Power factor target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toPFTARGET
(i.e.PFTARGET
xVALSCALE
). Default value is 1. - PFTARGET (
float
): Target power factor power set point.
Only one LOAD=
argument is supported per Command.
Example: Control the load at bus 100 which has an ID of 1. The control is power factor control of -0.97 at the load terminals.
CONTROL, LOAD=100#1, Q=PF, ATLINE=TERMINALS, PFTARGET=-0.97
Control load - Active power control
CONTROL, LOAD=, ATLINE=, [METERBUS=, VALSCALE=1], P/YP=
Controls the active power of a load/shunt.
Arguments:
- CONTROL
- LOAD (
pas
): Load/shunt definition. Loads and shunts are defined using the following syntax:bus#id
. - Load setpoint. Options:
- P (
float
): Active power target [MW] for constant power load; or - YP (
float
): Active power target [MW] for constant admittance load.
- P (
- ATLINE Location of the target active power. Options:
ATLINE=TERMINALS
: Active power target is regulated at the generator terminals.ATLINE=from->to#id
(pas
): Active power target is regulated across the specified line. Lines are defined using the following syntax:from->to#id
.
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied toP
(i.e.P
xVALSCALE
). Default value is 1.
Only one LOAD=
argument is supported per Command.
Example: Control the load at bus 100 which has an ID of 1. The active power set point is 22 MW and is applied across load terminals.
CONTROL, LOAD=100#1, ATLINE=TERMINALS, P=22
SOLVE
Command
SOLVE, [LOCKTAPS=, LOCKSHUNTS=]
Solves the static case, considering all previous SET and CONTROL Commands.
Arguments:
- SOLVE
- LOCKTAPS (
str
)[Optional]: Solution option specifying whether the position of transformer taps may change during the solution. Defaults toNO
. Options:LOCKTAPS=YES
: Transformer taps are locked.LOCKTAPS=NO
: Transformer taps are unlocked (stepped taps).
- LOCKSHUNTS (
str
)[Optional]: Solution option specifying whether the position of switched shunts may change during the solution. Defaults toNO
. Options:LOCKSHUNTS=YES
: Switched shunt positions are locked.LOCKSHUNTS=NO
: Switched shunt positions are unlocked (stepped shunt steps).
Example: Solve the case where transformer taps are not locked and where switched shunt positions are locked.
SOLVE, LOCKTAPS=NO, LOCKSHUNTS=YES
OUTPUT
Command
Only one value can be output per OUTPUT
Command.
The Node automatically outputs .sav
cases ready for use by connected PSS®E Dynamic Nodes. Therefore, you don't need to specify this output.
Output bus value
OUTPUT, BUS=, VAL=, [VALSCALE=1], NAME=
Outputs a value from a bus.
Arguments:
- OUTPUT
- BUS (
int
): Bus number. - VAL (
str
): Bus value. Options:VAL=V
: Voltage [p.u.].VAL=VKV
: Voltage [kV].VAL=ANGLE
: Angle [degrees].
- VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied to the output value (i.e. scaled_output =VAL
xVALSCALE
). Default value is 1. - NAME (
str
): Output name. Output names must be unique within a Node.
Example: Output the voltage [p.u] at bus 100 and name the Internode Variable 'busvolts'.
OUTPUT, BUS=100, VAL=V, NAME=i_busvolts
Output line value
OUTPUT, LINE=, VAL=, [METERBUS=, VALSCALE=1], NAME=
Outputs a value from a line.
Arguments:
- OUTPUT
- LINE (
pas
): Line definition. Lines are defined using the following syntax:from->to#id
. Values are output at the 'from-side' of the line. - VAL (
str
): Line value. Options:VAL=P
: Active power [MW].VAL=Q
: Reactive power [MVAr].VAL=S
: Apparent power [MVA].VAL=PF
: Power factor (generator convention,P/S
) [unitless]. Click here for details on how gridmo calculates power factor.VAL=LOAD%
: Thermal loading using the 'RATE1' field [%].
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theLINE=
line. Default value is the 'from' bus number as per theLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied to the output value (i.e. scaled_output =VAL
xVALSCALE
). Default value is 1. - NAME (
str
): Output name. Output names must be unique within a Node.
Example: Output the active power flowing through the line from bus 100 to bus 200 (measured at the 'from-side') which has an ID of 1. Name the Internode Variable 'p_at_line'.
OUTPUT, LINE=100->200#1, VAL=P, NAME=i_p_at_line
Output transformer value
OUTPUT, TX=, VAL=, [METERBUS=, VALSCALE=1], NAME=
Outputs a value from a transformer.
Arguments:
- OUTPUT
- TX (
pas
): Transformer definition. Transformers are defined using the following syntax:bus1->bus2#id
(two-winding transformer) orbus1->bus2->bus3#id
(three-winding transformer). - VAL (
str
): Transformer value. Options:VAL=P
: Active power [MW].VAL=Q
: Reactive power [MVAr].VAL=S
: Apparent power [MVA].VAL=PF
: Power factor (generator convention,P/S
) [unitless]. Click here for details on how gridmo calculates power factor.VAL=TAPRATIO
: Tap ratio of the winding with the highest base voltage - as this is most likely where the tap changer is present (decimal, such as 0.90 meaning 90% of default tap) [unitless].VAL=LOAD%
: Thermal loading using the 'RATE1' field [%].
- METERBUS (
int
)[Optional]: Bus number which is the metering point for theTX=
line. Default value is the 'from' bus number as per theTX=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied to the output value (i.e. scaled_output =VAL
xVALSCALE
). Default value is 1. - NAME (
str
): Output name. Output names must be unique within a Node.
Example: Output the apparent power flowing through the transformer located between bus 100 to bus 200 which has an ID of 2. Name the Internode Variable i_tx_sload
.
OUTPUT, TX=100->200#2, VAL=S, NAME=i_tx_sload
Output generator value
OUTPUT, GEN=, VAL=, [VALSCALE=1], NAME=
Outputs a value from a generator.
Arguments:
- OUTPUT
- GEN (
pas
): Generator definition. Generators are defined using the following syntax:bus#id
. - VAL (
str
): Generator value. Options:VAL=P
: Active power [MW].VAL=Q
: Reactive power [MVAr].VAL=S
: Apparent power [MVA].VAL=PF
: Power factor (generator convention,P/S
) [unitless]. Click here for details on how gridmo calculates power factor.VAL=LOAD%
: Thermal loading using the 'RATE1' field [%].
- VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied to the output value (i.e. scaled_output =VAL
xVALSCALE
). Default value is 1. - NAME (
str
): Output name. Output names must be unique within a Node.
Example: Output the reactive power flowing through the generator located at bus 100 which has an ID of 1. Name the Internode Variable 'generator-Q'.
OUTPUT, GEN=100#1, VAL=Q, NAME=i_gen_terminal_q
Output voltage droop target value
OUTPUT, VAL=VDROOPTARGET, QBASE=, DROOP%=, DEADBAND=, QMIN=, QMAX=, ATBUS=, ATLINE=, [METERBUS=, VALSCALE=1], NAME=
Outputs the expected target voltage set point [p.u.] for a pre-defined voltage droop characteristic.
Arguments:
- OUTPUT
- VAL (
str
): Voltage droop characteristic value. Options:VAL=VDROOPTARGET
: Target voltage set point [p.u.].
- QBASE (
float
): Base reactive power [MVAr]. - DROOP% (
float
): Droop percentage [%]. - DEADBAND (
float
): Voltage deadband [p.u.]. - QMIN (
float
): Minimum reactive power limit at theATLINE=
line [MVAr]. - QMAX (
float
): Maximum reactive power limit at theATLINE=
line [MVAr]. - ATBUS (
int
): Bus number which has the target voltage. - ATLINE (
pas
): Line which is used for measuring the reactive power. Lines are defined using the following syntax:from->to#id
. - METERBUS (
int
)[Optional]: Bus number which is the metering point for theATLINE=
line. Default value is the 'from' bus number as per theATLINE=
argument. - VALSCALE (
float
)[Optional]: Multiplicative scaling factor applied to the output value (i.e. scaled_output =VAL
xVALSCALE
). Default value is 1. - NAME (
str
): Output name. Output names must be unique within a Node.
Example: Output the voltage droop target given the measured voltage at bus 500, the reactive power flow from bus 400 to 500 (id 1) metered at the bus 500 end, using 80 MVAr as the reactive power base, QMAX of 60 MVAr, QMIN of -60 MVAr and with a droop of 6%. Name the Internode Variable i_poc_vdroop_target
.
OUTPUT, VAL=VDROOPTARGET, QBASE=80, DROOP%=6, DEADBAND=0, QMIN=-60, QMAX=60, ATBUS=500, ATLINE=400->500#1, METERBUS=500, NAME=i_poc_vdroop_target
Advanced Parameters
node.convergence.gain
- Description: Defines the proportional gain used by the convergence algorithm. Large generators connected to weak networks with low droop percentages may require a gain lower than default to converge.
- Type:
float
- Units: N/A
- Default: 0.2
- Range: 0.001 - 0.5
node.convergence.gain=value
node.convergence.mva
- Description: Defines the acceptable tolerance error in the convergence algorithm. A load/generator is deemed converged when the absolute value of the difference (between actual and target values) is less than this value.
- Type:
float
- Units: MW or MVAr
- Default: 0.001
- Range: 0.001 - 5
node.convergence.mva=value
node.convergence.converge_at_limit
- Description: Defines if a generator in a
CONTROL
Command, which cannot achieve the control target due to hitting its minimum or maximum reactive power limit (as per the PSS®E Case file), is considered converged. For example, a generator is asked to regulate to 22 MVAr, but it can only inject 20 MVAr. If this Advanced Parameter is set toYes
, the generator is treated as converged. If this Advanced Parameter is set toNo
the generator will prevent the static study solution from converging. Regardless of the setting, an Engine warning is raised if a generator reaches its minimum or maximum reactive power capability. - Type:
bool
- Units: N/A
- Default: Yes
- Range: Yes, No
node.convergence.converge_at_limit=value
system.convergence.mva
- Description: Defines the acceptable whole-network MVA mismatch. A network is deemed converged and stable when the mismatch is less than this value.
- Type:
float
- Units: MVA
- Default: 0.5
- Range: >=0.1
system.convergence.mva=value
max_iter
- Description: Defines the acceptable number of iterations during Case file and generator/load control mode convergence. Very sensitive control modes (low droop % values) or weak networks may require higher than default max_iter to converge.
- Type:
int
- Units: N/A
- Default: 500
- Range: 50 - 10000
max_iter=value
voltages.tolerance
- Description: Defines the acceptable voltage tolerance for the static study. Voltage regulation schemes are considered on target when the actual voltage is within this value (+/- the voltage tolerance).
- Type:
float
- Units: p.u.
- Default: 1e-5
- Range: 0 - 1
voltages.tolerance=value
voltages.lower
- Description: Defines the acceptable lower voltage bound for the static study. Any buses with voltage lower than this value will prevent the case from converging. A network is deemed converged and stable when all in-service buses have per unit voltage higher than this value.
- Type:
float
- Units: p.u.
- Default: 0.85
- Range: 0 - 0.99
voltages.lower=value
voltages.higher
- Description: Defines the acceptable upper voltage bound for the static study. Any buses with voltage higher than this value will prevent the case from converging. A network is deemed converged and stable when all in-service buses have per unit voltage lower than this value.
- Type:
float
- Units: p.u.
- Default: 1.15
- Range: 1.01 - 2
voltages.higher=value
system.swingbus.ignorevolt
- Description: Should the swing bus (type 3 bus in PSS®E model) be excluded from the
voltages.lower
andvoltages.higher
checks? This value defaults toYes
which is typically appropriate for SMIB studies. For full system model studies, setting this value to NO is recommended. - Type:
bool
- Units: N/A
- Default: Yes
- Range: Yes / No
system.swingbus.ignorevolt=value
low.scr.mode
To use low SCR mode, the PSS®E Static Node must have:
- Exactly one
SOLVE
command. - Exactly one
SET, LINE=, SCR=, XR=
command. - A
VDIRECT
command for the Thévenin equivalent source regulating the connection point voltage.
By setting low.scr.mode=Yes
, the gridmo Engine will convert your SOLVE
into a multi-step solve to converged your SMIB model to very low SCR values.
Specifically, the first series of iterations solves the case at a relatively high SCR (of 25). The second solve is a two-stage iterative process, quadratically ramping the Thévenin equivalent impedance until the target SCR is reached. The point of connection voltage is then adjusted to ensure the target voltage is maintained. The final solve is a single iteration to ensure the case remains in a converged state.
- Description: Enables a low SCR mode where impedance changes (via
SET, LINE=, SCR=, XR=
) are slowly ramped during aSOLVE
command. - Type:
bool
- Units: N/A
- Default: No
- Range: Yes / No
low.scr.mode=value