11#include <dpsim-models/Base/Base_Ph1_Switch.h>
12#include <dpsim-models/Definitions.h>
13#include <dpsim-models/Logger.h>
14#include <dpsim-models/MNASimPowerComp.h>
15#include <dpsim-models/Solver/MNASwitchInterface.h>
16#include <dpsim-models/Solver/MNAVariableCompInterface.h>
33 Switch(String
uid, String name, Logger::Level loglevel = Logger::Level::off);
35 Switch(String name, Logger::Level logLevel = Logger::Level::off)
36 :
Switch(name, name, logLevel) {}
38 SimPowerComp<Complex>::Ptr
clone(String name)
override;
45 void mnaCompInitialize(Real omega, Real timeStep,
46 Attribute<Matrix>::Ptr leftVector)
override;
57 Attribute<Matrix>::Ptr &leftVector)
override;
61 AttributeBase::List &attributeDependencies,
62 AttributeBase::List &modifiedAttributes,
63 Attribute<Matrix>::Ptr &leftVector)
override;
70 SparseMatrixRow &systemMatrix,
71 Int freqIdx)
override;
Dynamic Phasor Three-Phase Switch.
String uid()
Returns unique id.
MNASimPowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
MNA interface to be used by switching devices.
MNA interface to be used by elements that require recomputing of the system matrix.
Bool mnaIsClosed() override
Check if switch is closed.
void mnaCompApplySwitchSystemMatrixStamp(Bool closed, SparseMatrixRow &systemMatrix, Int freqIdx) override
Stamps system matrix considering the defined switch position.
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 mnaCompAddPostStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes, Attribute< Matrix >::Ptr &leftVector) override
Add MNA post step dependencies.
Switch(String uid, String name, Logger::Level loglevel=Logger::Level::off)
Defines UID, name, component parameters and logging level.
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Update interface voltage from MNA system result.
Switch(String name, Logger::Level logLevel=Logger::Level::off)
Defines name, component parameters and logging level.
void mnaCompUpdateCurrent(const Matrix &leftVector) override
Update interface current from MNA system result.
void mnaCompApplySystemMatrixStamp(SparseMatrixRow &systemMatrix) override
Stamps system matrix.
void mnaCompPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
Bool hasParameterChanged() override
Returns true if one of the element paramters has changed.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.