Update README.rst
[PyCIM.git] / CIM14 / ENTSOE / Equipment / Wires / PhaseTapChanger.py
blob109c8f2810eac915f0b7072aa8f09ae1fe682e4b
1 # Copyright (C) 2010-2011 Richard Lincoln
3 # Permission is hereby granted, free of charge, to any person obtaining a copy
4 # of this software and associated documentation files (the "Software"), to
5 # deal in the Software without restriction, including without limitation the
6 # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
7 # sell copies of the Software, and to permit persons to whom the Software is
8 # furnished to do so, subject to the following conditions:
10 # The above copyright notice and this permission notice shall be included in
11 # all copies or substantial portions of the Software.
13 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14 # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15 # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16 # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17 # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
18 # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
19 # IN THE SOFTWARE.
21 from CIM14.ENTSOE.Equipment.Wires.TapChanger import TapChanger
23 class PhaseTapChanger(TapChanger):
24 """A specialization of a voltage tap changer that has detailed modeling for phase shifting capabilities. A phase shifting tap changer is also in general a voltage magnitude transformer. The symmetrical and asymmetrical transformer tap changer models are defined here.- The attribute ltcflag specifies whether or not a TapChanger has load tap changing capabilities. If the ltcFlag is true, the attributes “highStep”, “lowStep”, “neutralStep”, “normalStep” and 'stepPhaseShiftIncrement' are all required. - The attributes voltageStepIncrementOutOfPhase, windingConnectionAngle, xStepMax, and xStepMin are not required.
25 """
27 def __init__(self, nominalVoltageOutOfPhase=0.0, windingConnectionAngle=0.0, phaseTapChangerType="asymmetrical", xStepMin=0.0, xStepMax=0.0, stepPhaseShiftIncrement=0.0, voltageStepIncrementOutOfPhase=0.0, TransformerWinding=None, *args, **kw_args):
28 """Initialises a new 'PhaseTapChanger' instance.
30 @param nominalVoltageOutOfPhase: Similar to TapChanger.nominalVoltage, but this is the nominal voltage in the out of phase winding at the nominal tap step. A typical case may have zero voltage at the nominal step, indicating no phase shift at the nominal voltage.
31 @param windingConnectionAngle: The phase angle between the in-phase winding and the out-of -phase winding used for creating phase shift. It is only possible to have a symmemtrical transformer if this angle is 90 degrees.
32 @param phaseTapChangerType: The type of phase shifter construction. Values are: "asymmetrical", "symmetrical", "unknown"
33 @param xStepMin: The reactance at the minimum tap step.
34 @param xStepMax: The reactance at the maximum tap step.
35 @param stepPhaseShiftIncrement: Phase shift per step position. A positive value indicates a positive phase shift from the winding where the tap is located to the other winding (for a two-winding transformer). The actual phase shift increment might be more accurately computed from the symmetrical or asymmetrical models or a tap step table lookup if those are available.
36 @param voltageStepIncrementOutOfPhase: The voltage step increment on the out of phase winding. This voltage step on the out of phase winding of the phase shifter. Similar to TapChanger.voltageStepIncrement, but it is applied only to the out of phase winding.
37 @param TransformerWinding: The transformer winding to which the phase tap changer belongs.
38 """
39 #: Similar to TapChanger.nominalVoltage, but this is the nominal voltage in the out of phase winding at the nominal tap step. A typical case may have zero voltage at the nominal step, indicating no phase shift at the nominal voltage.
40 self.nominalVoltageOutOfPhase = nominalVoltageOutOfPhase
42 #: The phase angle between the in-phase winding and the out-of -phase winding used for creating phase shift. It is only possible to have a symmemtrical transformer if this angle is 90 degrees.
43 self.windingConnectionAngle = windingConnectionAngle
45 #: The type of phase shifter construction. Values are: "asymmetrical", "symmetrical", "unknown"
46 self.phaseTapChangerType = phaseTapChangerType
48 #: The reactance at the minimum tap step.
49 self.xStepMin = xStepMin
51 #: The reactance at the maximum tap step.
52 self.xStepMax = xStepMax
54 #: Phase shift per step position. A positive value indicates a positive phase shift from the winding where the tap is located to the other winding (for a two-winding transformer). The actual phase shift increment might be more accurately computed from the symmetrical or asymmetrical models or a tap step table lookup if those are available.
55 self.stepPhaseShiftIncrement = stepPhaseShiftIncrement
57 #: The voltage step increment on the out of phase winding. This voltage step on the out of phase winding of the phase shifter. Similar to TapChanger.voltageStepIncrement, but it is applied only to the out of phase winding.
58 self.voltageStepIncrementOutOfPhase = voltageStepIncrementOutOfPhase
60 self._TransformerWinding = None
61 self.TransformerWinding = TransformerWinding
63 super(PhaseTapChanger, self).__init__(*args, **kw_args)
65 _attrs = ["nominalVoltageOutOfPhase", "windingConnectionAngle", "phaseTapChangerType", "xStepMin", "xStepMax", "stepPhaseShiftIncrement", "voltageStepIncrementOutOfPhase"]
66 _attr_types = {"nominalVoltageOutOfPhase": float, "windingConnectionAngle": float, "phaseTapChangerType": str, "xStepMin": float, "xStepMax": float, "stepPhaseShiftIncrement": float, "voltageStepIncrementOutOfPhase": float}
67 _defaults = {"nominalVoltageOutOfPhase": 0.0, "windingConnectionAngle": 0.0, "phaseTapChangerType": "asymmetrical", "xStepMin": 0.0, "xStepMax": 0.0, "stepPhaseShiftIncrement": 0.0, "voltageStepIncrementOutOfPhase": 0.0}
68 _enums = {"phaseTapChangerType": "PhaseTapChangerKind"}
69 _refs = ["TransformerWinding"]
70 _many_refs = []
72 def getTransformerWinding(self):
73 """The transformer winding to which the phase tap changer belongs.
74 """
75 return self._TransformerWinding
77 def setTransformerWinding(self, value):
78 if self._TransformerWinding is not None:
79 self._TransformerWinding._PhaseTapChanger = None
81 self._TransformerWinding = value
82 if self._TransformerWinding is not None:
83 self._TransformerWinding.PhaseTapChanger = None
84 self._TransformerWinding._PhaseTapChanger = self
86 TransformerWinding = property(getTransformerWinding, setTransformerWinding)