9#include <dpsim-models/EMT/EMT_Ph3_NetworkInjection.h>
14 Logger::Level logLevel)
16 mVoltageRef(
mAttributes->createDynamic<MatrixComp>(
"V_ref")),
17 mSrcFreq(
mAttributes->createDynamic<Real>(
"f_src")) {
18 mPhaseType = PhaseType::ABC;
19 setVirtualNodeNumber(0);
24 SPDLOG_LOGGER_INFO(
mSLog,
"Create {} {}", this->
type(), name);
28 std::make_shared<EMT::Ph3::VoltageSource>(**
mName +
"_vs",
mLogLevel);
30 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
31 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
true);
32 SPDLOG_LOGGER_INFO(
mSLog,
"Electrical subcomponents: ");
34 SPDLOG_LOGGER_INFO(
mSLog,
"- {}", subcomp->name());
36 mSubVoltageSource->mVoltageRef->setReference(mVoltageRef);
37 mSubVoltageSource->mSrcFreq->setReference(mSrcFreq);
41 auto copy = NetworkInjection::make(name,
mLogLevel);
42 copy->setParameters(**mVoltageRef);
50 mSubVoltageSource->setParameters(voltageRef, srcFreq);
52 SPDLOG_LOGGER_INFO(
mSLog,
53 "\nVoltage Ref={:s} [V]"
54 "\nFrequency={:s} [Hz]",
55 Logger::matrixCompToString(voltageRef),
56 Logger::realToString(srcFreq));
60 Real freqStart, Real rocof,
61 Real timeStart, Real duration,
65 mSubVoltageSource->setParameters(voltageRef, freqStart, rocof, timeStart,
66 duration, smoothRamp);
70 "\nVoltage Ref={:s} [V]"
71 "\nInitial frequency={:s} [Hz]"
72 "\nRamp ROCOF={:s} [Hz/s]"
73 "\nRamp duration={:s} [s]"
74 "\nRamp nadir={:s} [Hz]",
75 Logger::matrixCompToString(voltageRef), Logger::realToString(freqStart),
76 Logger::realToString(rocof), Logger::realToString(duration),
77 Logger::realToString(freqStart + rocof * duration));
81 Real modulationFrequency,
82 Real modulationAmplitude,
87 mSubVoltageSource->setParameters(voltageRef, modulationFrequency,
88 modulationAmplitude, baseFrequency, zigzag);
90 SPDLOG_LOGGER_INFO(
mSLog,
91 "\nVoltage Ref={:s} [V]"
92 "\nFrequency={:s} [Hz]",
93 Logger::matrixCompToString(voltageRef),
94 Logger::realToString(baseFrequency));
100 mSubVoltageSource->connect({SimNode::GND,
node(0)});
105 subcomp->initializeFromNodesAndTerminals(frequency);
111 Matrix &rightVector) {
112 SPDLOG_LOGGER_DEBUG(
mSLog,
"Right Side Vector: {:s}",
113 Logger::matrixToString(rightVector));
117 AttributeBase::List &prevStepDependencies,
118 AttributeBase::List &attributeDependencies,
119 AttributeBase::List &modifiedAttributes) {
131 AttributeBase::List &prevStepDependencies,
132 AttributeBase::List &attributeDependencies,
133 AttributeBase::List &modifiedAttributes,
134 Attribute<Matrix>::Ptr &leftVector) {
135 attributeDependencies.push_back(leftVector);
141 Real time, Int timeStepCount, Attribute<Matrix>::Ptr &leftVector) {
147 const Matrix &leftVector) {
152 const Matrix &leftVector) {
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)
void mnaParentApplyRightSideVectorStamp(Matrix &rightVector) override
Stamps right side (source) vector.
void setParameters(MatrixComp voltageRef, Real srcFreq=50.0)
Setter for reference voltage parameters.
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Updates voltage across component.
void mnaParentAddPostStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes, Attribute< Matrix >::Ptr &leftVector) override
Add MNA post step dependencies.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.
void mnaCompUpdateCurrent(const Matrix &leftVector) override
Returns current through the component.
void mnaParentPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
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 mnaParentPreStep(Real time, Int timeStepCount) override
MNA pre step operations.
void mnaParentAddPreStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes) override
Add MNA pre step dependencies.
NetworkInjection(String uid, String name, Logger::Level loglevel=Logger::Level::off)
Defines UID, name, component parameters and logging level.
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
SimNode< Real >::Ptr node(UInt index)
const Attribute< MatrixVar< Real > >::Ptr mIntfVoltage
std::vector< std::shared_ptr< SimPowerComp< Real > > > mSubComponents
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.