9#include <dpsim-models/SP/SP_Ph1_SynchronGeneratorTrStab.h>
12SP::Ph1::SynchronGeneratorTrStab::SynchronGeneratorTrStab(
13 String uid, String name, Logger::Level logLevel)
14 : Base::SynchronGenerator(mAttributes),
16 mEp(mAttributes->create<Complex>(
"Ep")),
17 mEp_abs(mAttributes->create<Real>(
"Ep_mag")),
18 mEp_phase(mAttributes->create<Real>(
"Ep_phase")),
19 mDelta_p(mAttributes->create<Real>(
"delta_r")),
20 mRefOmega(mAttributes->createDynamic<Real>(
"w_ref")),
21 mRefDelta(mAttributes->createDynamic<Real>(
"delta_ref")) {
22 setVirtualNodeNumber(2);
24 **mIntfVoltage = MatrixComp::Zero(1, 1);
25 **mIntfCurrent = MatrixComp::Zero(1, 1);
27 mStates = Matrix::Zero(10, 1);
31SimPowerComp<Complex>::Ptr
33 auto copy = SynchronGeneratorTrStab::make(name,
mLogLevel);
40 Real nomPower, Real nomVolt, Real nomFreq, Real Ll, Real Lmd, Real Llfd,
41 Real inertia, Real D) {
42 setBaseParameters(nomPower, nomVolt, nomFreq);
43 SPDLOG_LOGGER_INFO(
mSLog,
44 "\n--- Base Parameters ---"
51 mParameterType = ParameterType::statorReferred;
69 SPDLOG_LOGGER_INFO(
mSLog,
70 "\n--- Parameters ---"
79 Real nomPower, Real nomVolt, Real nomFreq, Int polePairNumber, Real Rs,
80 Real Lpd, Real inertiaJ, Real Kd) {
81 setBaseParameters(nomPower, nomVolt, nomFreq);
82 SPDLOG_LOGGER_INFO(
mSLog,
83 "\n--- Base Parameters ---"
89 mParameterType = ParameterType::statorReferred;
94 **
mInertia = calcHfromJ(inertiaJ, 2 * PI * nomFreq, polePairNumber);
99 SPDLOG_LOGGER_INFO(
mSLog,
100 "\n--- Parameters ---"
109 Real nomPower, Real nomVolt, Real nomFreq, Real Xpd, Real inertia, Real Rs,
111 setBaseParameters(nomPower, nomVolt, nomFreq);
112 SPDLOG_LOGGER_INFO(
mSLog,
113 "\n--- Base Parameters ---"
119 SPDLOG_LOGGER_INFO(
mSLog,
120 "\n--- Parameters Per-Unit ---"
121 "\n Xpd: {:f} [p.u.]",
125 mParameterType = ParameterType::statorReferred;
139 SPDLOG_LOGGER_INFO(
mSLog,
140 "\n--- Parameters ---"
143 "\nInertia: {:f} [s]"
149 Bool convertWithOmegaMech) {
152 SPDLOG_LOGGER_INFO(
mSLog,
153 "\n--- Model flags ---"
154 "\nconvertWithOmegaMech: {:s}",
158void SP::Ph1::SynchronGeneratorTrStab::setInitialValues(Complex elecPower,
160 mInitElecPower = elecPower;
161 mInitMechPower = mechPower;
174 MNA_SUBCOMP_TASK_ORDER::TASK_AFTER_PARENT,
175 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
182 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
191 (**mIntfVoltage)(0, 0) = initialSingleVoltage(0);
192 mInitElecPower = (mInitElecPower == Complex(0, 0))
195 mInitMechPower = (mInitElecPower == Complex(0, 0)) ? mInitElecPower.real()
199 (**mIntfCurrent)(0, 0) = std::conj(-mInitElecPower / (**
mIntfVoltage)(0, 0));
214 ((**mIntfVoltage)(0, 0) * std::conj(-(**
mIntfCurrent)(0, 0))).real();
216 ((**mIntfVoltage)(0, 0) * std::conj(-(**
mIntfCurrent)(0, 0))).imag();
230 SPDLOG_LOGGER_INFO(
mSLog,
231 "\n--- Initialize according to powerflow ---"
232 "\nTerminal 0 voltage: {:e}<{:e}"
233 "\nVoltage behind reactance: {:e}<{:e}"
234 "\ninitial electrical power: {:e}+j{:e}"
235 "\nactive electrical power: {:e}"
236 "\nreactive electrical power: {:e}"
237 "\nmechanical power: {:e}"
238 "\n--- End of powerflow initialization ---",
241 Math::phaseDeg(**
mEp), mInitElecPower.real(),
246void SP::Ph1::SynchronGeneratorTrStab::step(Real time) {
252 ((**mIntfVoltage)(0, 0) * std::conj(-(**mIntfCurrent)(0, 0))).real();
253 **mElecReactivePower =
254 ((**mIntfVoltage)(0, 0) * std::conj(-(**mIntfCurrent)(0, 0))).imag();
259 if (mConvertWithOmegaMech)
261 mNomOmega * mNomOmega / (2. * **mInertia * mNomPower * **mOmMech) *
262 (**mMechPower - **mElecActivePower - mKd * (**mOmMech - mNomOmega));
265 mNomOmega / (2. * **mInertia * mNomPower) *
266 (**mMechPower - **mElecActivePower - mKd * (**mOmMech - mNomOmega));
270 if (mBehaviour == Behaviour::MNASimulation)
271 **mOmMech = **mOmMech + mTimeStep * dOmMech;
275 Real dDelta_p = **mOmMech - (mUseOmegaRef ? **mRefOmega : mNomOmega);
279 if (mBehaviour == Behaviour::MNASimulation) {
280 **mDelta_p = **mDelta_p + mTimeStep * dDelta_p;
281 **mEp = Complex(**mEp_abs * cos(**mDelta_p), **mEp_abs * sin(**mDelta_p));
284 mStates << Math::abs(**mEp), Math::phaseDeg(**mEp), **mElecActivePower,
285 **mMechPower, **mDelta_p, **mOmMech, dOmMech, dDelta_p,
286 (**mIntfVoltage)(0, 0).real(), (**mIntfVoltage)(0, 0).imag();
287 SPDLOG_LOGGER_DEBUG(mSLog,
"\nStates, time {:f}: \n{:s}", time,
288 Logger::matrixToString(mStates));
292 Real omega, Real timeStep, Attribute<Matrix>::Ptr leftVector) {
295 mMnaTasks.push_back(std::make_shared<AddBStep>(*
this));
299 AttributeBase::List &prevStepDependencies,
300 AttributeBase::List &attributeDependencies,
301 AttributeBase::List &modifiedAttributes) {
308void SP::Ph1::SynchronGeneratorTrStab::mnaParentAddPostStepDependencies(
309 AttributeBase::List &prevStepDependencies,
310 AttributeBase::List &attributeDependencies,
311 AttributeBase::List &modifiedAttributes,
312 Attribute<Matrix>::Ptr &leftVector) {
313 attributeDependencies.push_back(leftVector);
314 modifiedAttributes.push_back(mIntfVoltage);
324void SP::Ph1::SynchronGeneratorTrStab::AddBStep::execute(Real time,
326 **mGenerator.mRightVector = mGenerator.mSubInductor->mRightVector->get() +
327 mGenerator.mSubVoltageSource->mRightVector->get();
330void SP::Ph1::SynchronGeneratorTrStab::mnaParentPostStep(
331 Real time, Int timeStepCount, Attribute<Matrix>::Ptr &leftVector) {
332 mnaCompUpdateVoltage(**leftVector);
333 mnaCompUpdateCurrent(**leftVector);
336void SP::Ph1::SynchronGeneratorTrStab::mnaCompUpdateVoltage(
337 const Matrix &leftVector) {
338 SPDLOG_LOGGER_DEBUG(mSLog,
"Read voltage from {:d}", matrixNodeIndex(0));
339 (**mIntfVoltage)(0, 0) =
340 Math::complexFromVectorElement(leftVector, matrixNodeIndex(0));
343void SP::Ph1::SynchronGeneratorTrStab::mnaCompUpdateCurrent(
344 const Matrix &leftVector) {
345 SPDLOG_LOGGER_DEBUG(mSLog,
"Read current from {:d}", matrixNodeIndex(0));
347 **mIntfCurrent = mSubInductor->mIntfCurrent->get();
350void SP::Ph1::SynchronGeneratorTrStab::setReferenceOmega(
351 Attribute<Real>::Ptr refOmegaPtr, Attribute<Real>::Ptr refDeltaPtr) {
352 mRefOmega->setReference(refOmegaPtr);
353 mRefDelta->setReference(refDeltaPtr);
356 SPDLOG_LOGGER_INFO(mSLog,
"Use of reference omega.");
Real mNomFreq
nominal frequency fn [Hz]
Real mTimeStep
Simulation time step.
Real mLmd
d-axis mutual inductance Lmd [H]
Real mLlfd
field leakage inductance Llfd [H]
const Attribute< Real >::Ptr mMechPower
mechanical Power Pm [W]
Real mNomVolt
nominal voltage Vn [V] (phase-to-phase RMS)
Real mBase_L
base stator inductance
Real mBase_Z
base stator impedance
const Attribute< Real >::Ptr mRs
stator resistance Rs [Ohm]
const Attribute< Real >::Ptr mElecReactivePower
Reactive part of the electrical power.
const Attribute< Real >::Ptr mElecActivePower
Active part of the electrical power.
StateType mStateType
specifies if the machine parameters are transformed to per unit
Real mNomOmega
nominal angular frequency wn [Hz]
const Attribute< Real >::Ptr mLl
leakage inductance Ll [H]
Real mLfd
field inductance Lfd [H]
const Attribute< Real >::Ptr mLd
d-axis inductance Ld [H]
Real mNomPower
nominal power Pn [VA]
const Attribute< Real >::Ptr mOmMech
rotor speed omega_r
const Attribute< Real >::Ptr mInertia
inertia constant H [s] for per unit or moment of inertia J [kg*m^2]
Base class for composite power components.
void addMNASubComponent(typename SimPowerComp< Complex >::Ptr subc, MNA_SUBCOMP_TASK_ORDER preStepOrder, MNA_SUBCOMP_TASK_ORDER postStepOrder, Bool contributeToRightVector)
const Attribute< String >::Ptr mName
Human readable name.
Complex mImpedance
Equivalent impedance for loadflow calculation.
void mnaParentPreStep(Real time, Int timeStepCount) override
MNA pre and post step operations.
Bool mConvertWithOmegaMech
Flag for usage of actual mechanical speed for torque conversion (otherwise mNomOmega is used)
Real mKd
Absolute damping coefficient.
SimPowerComp< Complex >::Ptr clone(String name) override
DEPRECATED: Delete method.
void initializeParentFromNodesAndTerminals(Real frequency) override
void setModelFlags(Bool convertWithOmegaMech)
Flags to modify model behavior.
void createSubComponents() override
Constructs and registers MNA subcomponents without emf value; idempotent.
std::shared_ptr< VoltageSource > mSubVoltageSource
Inner voltage source that represents the generator.
const Attribute< Complex >::Ptr mEp
True after createSubComponents() runs; prevents double-construction.
void setStandardParametersPU(Real nomPower, Real nomVolt, Real nomFreq, Real Xpd, Real inertia, Real Rs=0, Real D=0)
Initializes the machine parameters.
const Attribute< Real >::Ptr mDelta_p
Angle by which the emf Ep is leading the terminal voltage.
std::shared_ptr< Inductor > mSubInductor
Inner inductor that represents the generator impedance.
Real mLpd
Absolute d-axis transient inductance.
void mnaParentInitialize(Real omega, Real timeStep, Attribute< Matrix >::Ptr leftVector) override
Initializes variables of component.
const Attribute< Real >::Ptr mEp_abs
void setStandardParametersSI(Real nomPower, Real nomVolt, Real nomFreq, Int polePairNumber, Real Rs, Real Lpd, Real inertiaJ, Real Kd=0)
Initializes the machine parameters.
Real mXpd
Absolute d-axis transient reactance X'd.
void mnaParentAddPreStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes) override
void setFundamentalParametersPU(Real nomPower, Real nomVolt, Real nomFreq, Real Ll, Real Lmd, Real Llfd, Real inertia, Real D=0)
Initializes the machine parameters.
const Attribute< MatrixVar< Complex > >::Ptr mIntfCurrent
SimTerminal< Complex >::Ptr terminal(UInt index)
const Attribute< MatrixVar< Complex > >::Ptr mIntfVoltage
SimNode< Complex >::List mVirtualNodes
Logger::Level mLogLevel
Component logger control for internal variables.
Logger::Log mSLog
Component logger.