9#include <dpsim-models/DP/DP_Ph1_Capacitor.h>
12using namespace CPS::DP::Ph1;
24 auto copy = Capacitor::make(name,
mLogLevel);
39 Real omega = 2 * PI * frequency;
41 (**mIntfVoltage)(0, 0) = initialSingleVoltage(1) - initialSingleVoltage(0);
42 (**mIntfCurrent)(0, 0) = (**
mIntfVoltage)(0, 0) / impedance;
44 SPDLOG_LOGGER_INFO(
mSLog,
45 "\nCapacitance [F]: {:s}"
46 "\nImpedance [Ohm]: {:s}",
48 Logger::complexToString(impedance));
49 SPDLOG_LOGGER_INFO(
mSLog,
50 "\n--- Initialization from powerflow ---"
51 "\nVoltage across: {:s}"
53 "\nTerminal 0 voltage: {:s}"
54 "\nTerminal 1 voltage: {:s}"
55 "\n--- Initialization from powerflow finished ---",
58 Logger::phasorToString(initialSingleVoltage(0)),
59 Logger::phasorToString(initialSingleVoltage(1)));
64 Attribute<Matrix>::Ptr leftVector) {
68 Real prevVoltCoeffReal = 2.0 * **
mCapacitance / timeStep;
70 for (UInt freq = 0; freq <
mNumFreqs; freq++) {
72 mEquivCond(freq, 0) = {equivCondReal, equivCondImag};
77 -(**mIntfCurrent)(0, freq) +
79 (**mIntfCurrent)(0, freq) =
80 mEquivCond(freq, 0) * (**mIntfVoltage)(0, freq) +
84 SPDLOG_LOGGER_INFO(
mSLog,
85 "\n--- MNA initialization ---"
86 "\nInitial voltage {:s}"
87 "\nInitial current {:s}"
88 "\nEquiv. current {:s}"
89 "\n--- MNA initialization finished ---",
96void DP::Ph1::Capacitor::mnaCompInitializeHarm(
97 Real omega, Real timeStep,
98 std::vector<Attribute<Matrix>::Ptr> leftVectors) {
99 updateMatrixNodeIndices();
101 Real equivCondReal = 2.0 * **mCapacitance / timeStep;
102 Real prevVoltCoeffReal = 2.0 * **mCapacitance / timeStep;
104 for (UInt freq = 0; freq < mNumFreqs; freq++) {
105 Real equivCondImag = 2. * PI * mFrequencies(freq, 0) * **mCapacitance;
106 mEquivCond(freq, 0) = {equivCondReal, equivCondImag};
107 Real prevVoltCoeffImag = -2. * PI * mFrequencies(freq, 0) * **mCapacitance;
108 mPrevVoltCoeff(freq, 0) = {prevVoltCoeffReal, prevVoltCoeffImag};
110 mEquivCurrent(freq, 0) =
111 -(**mIntfCurrent)(0, freq) +
112 -mPrevVoltCoeff(freq, 0) * (**mIntfVoltage)(0, freq);
113 (**mIntfCurrent)(0, freq) =
114 mEquivCond(freq, 0) * (**mIntfVoltage)(0, freq) +
115 mEquivCurrent(freq, 0);
118 mMnaTasks.push_back(std::make_shared<MnaPreStepHarm>(*
this));
119 mMnaTasks.push_back(std::make_shared<MnaPostStepHarm>(*
this, leftVectors));
120 **mRightVector = Matrix::Zero(leftVectors[0]->get().rows(), mNumFreqs);
124 SparseMatrixRow &systemMatrix) {
125 for (UInt freq = 0; freq <
mNumFreqs; freq++) {
126 MNAStampUtils::stampAdmittance(
127 mEquivCond(freq, 0), systemMatrix, matrixNodeIndex(0),
128 matrixNodeIndex(1), terminalNotGrounded(0), terminalNotGrounded(1),
133void DP::Ph1::Capacitor::mnaCompApplySystemMatrixStampHarm(
134 SparseMatrixRow &systemMatrix, Int freqIdx) {
135 MNAStampUtils::stampAdmittance(mEquivCond(freqIdx, 0), systemMatrix,
136 matrixNodeIndex(0), matrixNodeIndex(1),
137 terminalNotGrounded(0), terminalNotGrounded(1),
142 for (UInt freq = 0; freq <
mNumFreqs; freq++) {
146 -(**mIntfCurrent)(0, freq) +
149 if (terminalNotGrounded(0))
150 Math::setVectorElement(rightVector, matrixNodeIndex(0),
152 if (terminalNotGrounded(1))
153 Math::setVectorElement(rightVector, matrixNodeIndex(1),
156 SPDLOG_LOGGER_DEBUG(
mSLog,
"MNA EquivCurrent {:f}+j{:f}",
159 if (terminalNotGrounded(0))
160 SPDLOG_LOGGER_DEBUG(
mSLog,
"Add {:f}+j{:f} to source vector at {:d}",
163 if (terminalNotGrounded(1))
164 SPDLOG_LOGGER_DEBUG(
mSLog,
"Add {:f}+j{:f} to source vector at {:d}",
170void DP::Ph1::Capacitor::mnaCompApplyRightSideVectorStampHarm(
171 Matrix &rightVector) {
172 for (UInt freq = 0; freq < mNumFreqs; freq++) {
175 mEquivCurrent(freq, 0) =
176 -(**mIntfCurrent)(0, freq) +
177 -mPrevVoltCoeff(freq, 0) * (**mIntfVoltage)(0, freq);
179 if (terminalNotGrounded(0))
180 Math::setVectorElement(rightVector, matrixNodeIndex(0),
181 mEquivCurrent(freq, 0), 1, 0, freq);
182 if (terminalNotGrounded(1))
183 Math::setVectorElement(rightVector, matrixNodeIndex(1),
184 -mEquivCurrent(freq, 0), 1, 0, freq);
188void DP::Ph1::Capacitor::mnaCompApplyRightSideVectorStampHarm(
189 Matrix &rightVector, Int freq) {
192 mEquivCurrent(freq, 0) = -(**mIntfCurrent)(0, freq) +
193 -mPrevVoltCoeff(freq, 0) * (**mIntfVoltage)(0, freq);
195 if (terminalNotGrounded(0))
196 Math::setVectorElement(rightVector, matrixNodeIndex(0),
197 mEquivCurrent(freq, 0));
198 if (terminalNotGrounded(1))
199 Math::setVectorElement(rightVector, matrixNodeIndex(1),
200 -mEquivCurrent(freq, 0));
204 AttributeBase::List &prevStepDependencies,
205 AttributeBase::List &attributeDependencies,
206 AttributeBase::List &modifiedAttributes) {
218 AttributeBase::List &prevStepDependencies,
219 AttributeBase::List &attributeDependencies,
220 AttributeBase::List &modifiedAttributes,
221 Attribute<Matrix>::Ptr &leftVector) {
222 attributeDependencies.push_back(leftVector);
228 Attribute<Matrix>::Ptr &leftVector) {
233void DP::Ph1::Capacitor::MnaPreStepHarm::execute(Real time, Int timeStepCount) {
234 mCapacitor.mnaCompApplyRightSideVectorStampHarm(**mCapacitor.mRightVector);
237void DP::Ph1::Capacitor::MnaPostStepHarm::execute(Real time,
239 for (UInt freq = 0; freq < mCapacitor.mNumFreqs; freq++)
240 mCapacitor.mnaCompUpdateVoltageHarm(**mLeftVectors[freq], freq);
241 mCapacitor.mnaCompUpdateCurrentHarm();
246 for (UInt freq = 0; freq <
mNumFreqs; freq++) {
247 (**mIntfVoltage)(0, freq) = 0;
248 if (terminalNotGrounded(1))
249 (**mIntfVoltage)(0, freq) = Math::complexFromVectorElement(
250 leftVector, matrixNodeIndex(1),
mNumFreqs, freq);
251 if (terminalNotGrounded(0))
252 (**mIntfVoltage)(0, freq) =
254 Math::complexFromVectorElement(leftVector, matrixNodeIndex(0),
257 SPDLOG_LOGGER_DEBUG(
mSLog,
"Voltage {:e}<{:e}",
263void DP::Ph1::Capacitor::mnaCompUpdateVoltageHarm(
const Matrix &leftVector,
266 (**mIntfVoltage)(0, freqIdx) = 0;
267 if (terminalNotGrounded(1))
268 (**mIntfVoltage)(0, freqIdx) =
269 Math::complexFromVectorElement(leftVector, matrixNodeIndex(1));
270 if (terminalNotGrounded(0))
271 (**mIntfVoltage)(0, freqIdx) =
272 (**mIntfVoltage)(0, freqIdx) -
273 Math::complexFromVectorElement(leftVector, matrixNodeIndex(0));
275 SPDLOG_LOGGER_DEBUG(mSLog,
"Voltage {:s}",
276 Logger::phasorToString((**mIntfVoltage)(0, freqIdx)));
280 for (UInt freq = 0; freq <
mNumFreqs; freq++) {
281 (**mIntfCurrent)(0, freq) =
282 mEquivCond(freq, 0) * (**mIntfVoltage)(0, freq) +
284 SPDLOG_LOGGER_DEBUG(
mSLog,
"Current {:s}",
289void DP::Ph1::Capacitor::mnaCompUpdateCurrentHarm() {
290 for (UInt freq = 0; freq < mNumFreqs; freq++) {
291 (**mIntfCurrent)(0, freq) =
292 mEquivCond(freq, 0) * (**mIntfVoltage)(0, freq) +
293 mEquivCurrent(freq, 0);
294 SPDLOG_LOGGER_DEBUG(mSLog,
"Current {:s}",
295 Logger::phasorToString((**mIntfCurrent)(0, freq)));
const CPS::Attribute< Real >::Ptr mCapacitance
Capacitance [F].
void mnaCompApplySystemMatrixStamp(SparseMatrixRow &systemMatrix) override
Stamps system matrix.
Capacitor(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name and logging level.
void mnaCompPreStep(Real time, Int timeStepCount) override
MNA pre step operations.
void mnaCompAddPreStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes) override
Add MNA pre step dependencies.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.
MatrixComp mPrevVoltCoeff
Coefficient in front of previous voltage value for harmonics.
void mnaCompAddPostStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes, Attribute< Matrix >::Ptr &leftVector) override
Add MNA post step dependencies.
void initialize(Matrix frequencies) override
Initialize components with correct network frequencies.
MatrixComp mEquivCurrent
DC equivalent current source for harmonics [A].
void mnaCompInitialize(Real omega, Real timeStep, Attribute< Matrix >::Ptr leftVector) override
Initializes internal variables of the component.
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Update interface voltage from MNA system result.
MatrixComp mEquivCond
Equivalent conductance for harmonics [S].
void mnaCompUpdateCurrent(const Matrix &leftVector) override
Update interface current from MNA system result.
void mnaCompApplyRightSideVectorStamp(Matrix &rightVector) override
Stamps right side (source) vector.
SimPowerComp< Complex >::Ptr clone(String name) override
Returns a modified copy of the component with the given suffix added to the name and without.
void mnaCompPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
String uid()
Returns unique id.
AttributeList::Ptr mAttributes
Attribute List.
void mnaUpdateCurrent(const Matrix &leftVector) final
void mnaUpdateVoltage(const Matrix &leftVector) final
MNASimPowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
Attribute< Matrix >::Ptr mRightVector
void mnaApplyRightSideVectorStamp(Matrix &rightVector) final
const Attribute< MatrixVar< Complex > >::Ptr mIntfCurrent
virtual void initialize(Matrix frequencies)
Initialize components with correct network frequencies.
const Attribute< MatrixVar< Complex > >::Ptr mIntfVoltage
void updateMatrixNodeIndices()
Logger::Level mLogLevel
Component logger control for internal variables.
Logger::Log mSLog
Component logger.