9#include <dpsim-models/EMT/EMT_Ph3_RxLine.h>
19 mPhaseType = PhaseType::ABC;
20 setVirtualNodeNumber(1);
23 SPDLOG_LOGGER_INFO(
mSLog,
"Create {} {}", this->
type(), name);
32 auto copy = RxLine::make(name,
mLogLevel);
40 Real omega = 2. * PI * frequency;
41 MatrixComp impedance = MatrixComp::Zero(3, 3);
52 MatrixComp vInitABC = MatrixComp::Zero(3, 1);
54 mVirtualNodes[0]->initialSingleVoltage() - initialSingleVoltage(0);
55 vInitABC(1, 0) = vInitABC(0, 0) * SHIFT_TO_PHASE_B;
56 vInitABC(2, 0) = vInitABC(0, 0) * SHIFT_TO_PHASE_C;
58 **
mIntfCurrent = (impedance.inverse() * vInitABC).real();
62 MatrixComp vInitTerm0 = MatrixComp::Zero(3, 1);
63 vInitTerm0(0, 0) = initialSingleVoltage(0);
64 vInitTerm0(1, 0) = vInitTerm0(0, 0) * SHIFT_TO_PHASE_B;
65 vInitTerm0(2, 0) = vInitTerm0(0, 0) * SHIFT_TO_PHASE_C;
75 mSubResistor->initializeFromNodesAndTerminals(frequency);
77 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
83 mSubInductor->initializeFromNodesAndTerminals(frequency);
85 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
true);
88 std::make_shared<EMT::Ph3::Resistor>(**
mName +
"_snubber_res",
mLogLevel);
89 Matrix defaultSnubRes = Matrix::Zero(3, 1);
90 defaultSnubRes << 1e6, 0, 0, 0, 1e6, 0, 0, 0, 1e6;
95 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
96 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
98 SPDLOG_LOGGER_INFO(
mSLog,
99 "\n--- Initialization from powerflow ---"
100 "\nVoltage across: {:s}"
102 "\nTerminal 0 voltage: {:s}"
103 "\nTerminal 1 voltage: {:s}"
104 "\n--- Initialization from powerflow finished ---",
107 Logger::phasorToString(initialSingleVoltage(0)),
108 Logger::phasorToString(initialSingleVoltage(1)));
111void EMT::Ph3::RxLine::mnaParentAddPreStepDependencies(
112 AttributeBase::List &prevStepDependencies,
113 AttributeBase::List &attributeDependencies,
114 AttributeBase::List &modifiedAttributes) {
115 modifiedAttributes.push_back(mRightVector);
118void EMT::Ph3::RxLine::mnaParentAddPostStepDependencies(
119 AttributeBase::List &prevStepDependencies,
120 AttributeBase::List &attributeDependencies,
121 AttributeBase::List &modifiedAttributes,
122 Attribute<Matrix>::Ptr &leftVector) {
123 attributeDependencies.push_back(leftVector);
124 modifiedAttributes.push_back(mIntfCurrent);
125 modifiedAttributes.push_back(mIntfVoltage);
132void EMT::Ph3::RxLine::mnaParentPostStep(Real time, Int timeStepCount,
133 Attribute<Matrix>::Ptr &leftVector) {
134 mnaCompUpdateVoltage(**leftVector);
135 mnaCompUpdateCurrent(**leftVector);
138void EMT::Ph3::RxLine::mnaCompUpdateVoltage(
const Matrix &leftVector) {
140 **mIntfVoltage = Matrix::Zero(3, 1);
141 if (terminalNotGrounded(1)) {
142 (**mIntfVoltage)(0, 0) =
143 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 0));
144 (**mIntfVoltage)(1, 0) =
145 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 1));
146 (**mIntfVoltage)(2, 0) =
147 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 2));
149 if (terminalNotGrounded(0)) {
150 (**mIntfVoltage)(0, 0) =
151 (**mIntfVoltage)(0, 0) -
152 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 0));
153 (**mIntfVoltage)(1, 0) =
154 (**mIntfVoltage)(1, 0) -
155 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 1));
156 (**mIntfVoltage)(2, 0) =
157 (**mIntfVoltage)(2, 0) -
158 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 2));
162void EMT::Ph3::RxLine::mnaCompUpdateCurrent(
const Matrix &leftVector) {
163 **mIntfCurrent = mSubInductor->intfCurrent();
const Attribute< Matrix >::Ptr mSeriesRes
Resistance along the line [ohms].
const Attribute< Matrix >::Ptr mSeriesInd
Inductance along the line [H].
void addMNASubComponent(typename SimPowerComp< Real >::Ptr subc, MNA_SUBCOMP_TASK_ORDER preStepOrder, MNA_SUBCOMP_TASK_ORDER postStepOrder, Bool contributeToRightVector)
void mnaCompApplyRightSideVectorStamp(Matrix &rightVector) override
CompositePowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
std::shared_ptr< Resistor > mSubResistor
Resistor submodel.
std::shared_ptr< Inductor > mSubInductor
Inductance submodel.
RxLine(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name, logging level.
void mnaParentPreStep(Real time, Int timeStepCount) override
MNA pre and post step operations.
SimPowerComp< Real >::Ptr clone(String name) override
DEPRECATED: Delete method.
std::shared_ptr< Resistor > mInitialResistor
Inductor end to ground resistor to facilitate initialization.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.
const Attribute< String >::Ptr mName
Human readable name.
String uid()
Returns unique id.
String type()
Get component type (cross-platform)
AttributeList::Ptr mAttributes
Attribute List.
Attribute< Matrix >::Ptr mRightVector
const Attribute< MatrixVar< Real > >::Ptr mIntfCurrent
SimTerminal< Real >::List mTerminals
const Attribute< MatrixVar< Real > >::Ptr mIntfVoltage
SimNode< Real >::List mVirtualNodes
Logger::Level mLogLevel
Component logger control for internal variables.
Logger::Log mSLog
Component logger.