9#include <dpsim-models/EMT/EMT_Ph3_CurrentSource.h>
14 Logger::Level logLevel)
16 mCurrentRef(
mAttributes->create<MatrixComp>(
"I_ref")),
17 mSrcFreq(
mAttributes->createDynamic<Real>(
"f_src")),
18 mSigOut(
mAttributes->createDynamic<Complex>(
"sigOut")) {
19 mPhaseType = PhaseType::ABC;
20 setVirtualNodeNumber(0);
26 auto copy = CurrentSource::make(name,
mLogLevel);
34 auto srcSigSine = Signal::SineWaveGenerator::make(**
mName +
"_sw");
36 srcSigSine->setParameters(Complex(1, 0), srcFreq);
39 **mCurrentRef = currentRef;
40 mSrcFreq->setReference(mSrcSig->mFreq);
42 SPDLOG_LOGGER_INFO(
mSLog,
43 "\nCurrent reference phasor [I]: {:s}"
44 "\nFrequency [Hz]: {:s}",
45 Logger::matrixCompToString(currentRef),
46 Logger::realToString(srcFreq));
53 mSLog,
"\n--- Initialization from node voltages and terminal ---");
56 Signal::SineWaveGenerator::make(**
mName +
"_sw", Logger::Level::off);
58 srcSigSine->setParameters(Complex(1, 0), frequency);
61 Complex v_ref = initialSingleVoltage(1) - initialSingleVoltage(0);
65 Complex i_ref = std::conj(s_ref / v_ref / sqrt(3.));
68 mSrcFreq->setReference(mSrcSig->attributeTyped<Real>(
"freq"));
70 SPDLOG_LOGGER_INFO(
mSLog,
71 "\nReference current: {:s}"
72 "\nReference voltage: {:s}"
73 "\nReference power: {:s}"
74 "\nTerminal 0 voltage: {:s}"
75 "\nTerminal 1 voltage: {:s}"
76 "\nTerminal 0 power: {:s}"
77 "\nTerminal 1 power: {:s}",
78 Logger::phasorToString(i_ref),
79 Logger::phasorToString(v_ref),
80 Logger::complexToString(s_ref),
81 Logger::phasorToString(initialSingleVoltage(0)),
82 Logger::phasorToString(initialSingleVoltage(1)),
83 Logger::complexToString(
terminal(0)->singlePower()),
84 Logger::complexToString(
terminal(1)->singlePower()));
88 "\nInitialization from node voltages and terminal omitted (parameter "
90 "\nReference voltage: {:s}",
94 mSLog,
"\n--- Initialization from node voltages and terminal ---");
99 Real omega, Real timeStep, Attribute<Matrix>::Ptr leftVector) {
104 Matrix &rightVector) {
105 if (terminalNotGrounded(1)) {
106 Math::setVectorElement(rightVector, matrixNodeIndex(1, 0),
108 Math::setVectorElement(rightVector, matrixNodeIndex(1, 1),
110 Math::setVectorElement(rightVector, matrixNodeIndex(1, 2),
113 if (terminalNotGrounded(0)) {
114 Math::setVectorElement(rightVector, matrixNodeIndex(0, 0),
116 Math::setVectorElement(rightVector, matrixNodeIndex(0, 1),
118 Math::setVectorElement(rightVector, matrixNodeIndex(0, 2),
123void EMT::Ph3::CurrentSource::updateCurrent(Real time) {
124 if (mSrcSig !=
nullptr) {
126 for (
int i = 0; i < 3; i++) {
127 (**mIntfCurrent)(i, 0) = RMS_TO_PEAK * Math::abs((**mCurrentRef)(i, 0)) *
128 cos(Math::phase(mSrcSig->getSignal()) +
129 Math::phase((**mCurrentRef)(i, 0)));
132 **mIntfCurrent = RMS_TO_PEAK * (**mCurrentRef).real();
134 SPDLOG_LOGGER_DEBUG(mSLog,
"\nUpdate current: {:s}",
135 Logger::matrixToString(**mIntfCurrent));
139 AttributeBase::List &prevStepDependencies,
140 AttributeBase::List &attributeDependencies,
141 AttributeBase::List &modifiedAttributes) {
142 attributeDependencies.push_back(mCurrentRef);
153 AttributeBase::List &prevStepDependencies,
154 AttributeBase::List &attributeDependencies,
155 AttributeBase::List &modifiedAttributes,
156 Attribute<Matrix>::Ptr &leftVector) {
157 attributeDependencies.push_back(leftVector);
162 Real time, Int timeStepCount, Attribute<Matrix>::Ptr &leftVector) {
169 if (terminalNotGrounded(1)) {
170 (**mIntfVoltage)(0, 0) =
171 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 0));
172 (**mIntfVoltage)(1, 0) =
173 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 1));
174 (**mIntfVoltage)(2, 0) =
175 Math::realFromVectorElement(leftVector, matrixNodeIndex(1, 2));
177 if (terminalNotGrounded(0)) {
178 (**mIntfVoltage)(0, 0) =
180 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 0));
181 (**mIntfVoltage)(1, 0) =
183 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 1));
184 (**mIntfVoltage)(2, 0) =
186 Math::realFromVectorElement(leftVector, matrixNodeIndex(0, 2));
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Returns voltage through the component.
CurrentSource(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name and logging level.
void setParameters(MatrixComp currentRef, Real srcFreq=50.0)
Setter for reference current.
void mnaCompApplyRightSideVectorStamp(Matrix &rightVector) override
Stamps right side (source) vector.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.
void mnaCompAddPostStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes, Attribute< Matrix >::Ptr &leftVector) override
Add MNA post step dependencies.
void mnaCompAddPreStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes) override
Add MNA pre step dependencies.
SimPowerComp< Real >::Ptr clone(String name) override
Returns a modified copy of the component with the given suffix added to the name and without.
void mnaCompInitialize(Real omega, Real timeStep, Attribute< Matrix >::Ptr leftVector) override
Initializes internal variables of the component.
void mnaCompPreStep(Real time, Int timeStepCount) override
MNA pre step operations.
void mnaCompPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
const Attribute< String >::Ptr mName
Human readable name.
Attribute< T >::Ptr attributeTyped(const String &name) const
Return pointer to an attribute.
String uid()
Returns unique id.
AttributeList::Ptr mAttributes
Attribute List.
MNASimPowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
Attribute< Matrix >::Ptr mRightVector
static MatrixComp singlePhaseVariableToThreePhase(Complex var_1ph)
To convert single phase complex variables (voltages, currents) to symmetrical three phase ones.
const Attribute< MatrixVar< Real > >::Ptr mIntfCurrent
SimTerminal< Real >::Ptr terminal(UInt index)
const Attribute< MatrixVar< Real > >::Ptr mIntfVoltage
void updateMatrixNodeIndices()
Logger::Level mLogLevel
Component logger control for internal variables.
bool mParametersSet
Flag indicating that parameters are set via setParameters() function.
Logger::Log mSLog
Component logger.