9#include <dpsim-models/SP/SP_Ph1_Load.h>
25 SPDLOG_LOGGER_INFO(
mSLog,
"Create {} of type {}", **
mName, this->
type());
32void SP::Ph1::Load::setParameters(Real activePower, Real reactivePower,
33 Real nominalVoltage) {
34 **mActivePower = activePower;
35 **mReactivePower = reactivePower;
36 mNomVoltage = nominalVoltage;
40 "Active Power={} [W] Reactive Power={} [VAr] Nominal Voltage={} [V]",
41 **mActivePower, **mReactivePower, mNomVoltage);
44 mParametersSet =
true;
52 SPDLOG_LOGGER_INFO(
mSLog,
"#### Calculate Per Unit Parameters for {}",
54 mBaseApparentPower = baseApparentPower;
55 mBaseOmega = baseOmega;
56 SPDLOG_LOGGER_INFO(
mSLog,
"Base Power={} [VA] Base Omega={} [1/s]",
57 mBaseApparentPower, mBaseOmega);
61 SPDLOG_LOGGER_INFO(
mSLog,
"Active Power={} [pu] Reactive Power={} [pu]",
67 switch (powerflowBusType) {
68 case CPS::PowerflowBusType::PV:
69 throw std::invalid_argument(
70 " Power flow bus type error, load currently cannot be set as PVNode ");
72 case CPS::PowerflowBusType::PQ:
75 case CPS::PowerflowBusType::VD:
76 throw std::invalid_argument(
77 " Power flow bus type error, load cannot be set as VDNode ");
79 case CPS::PowerflowBusType::None:
82 throw std::invalid_argument(
" Invalid power flow bus type ");
92 Real wf =
mLoadProfile.weightingFactors.find(time)->second;
111 Real omega = 2. * PI * frequency;
115 setParameters(
mTerminals[0]->singleActivePower(),
117 std::abs(
mTerminals[0]->initialSingleVoltage()));
120 if (mNomVoltage == 0) {
123 "Nominal voltage of load {} is 0; resulting impedance will be "
124 "degenerate (zero resistance/inductance/capacitance).",
130 mResistance = std::pow(mNomVoltage, 2) / **
mActivePower;
131 mConductance = 1.0 / mResistance;
140 mSubResistor = std::make_shared<SP::Ph1::Resistor>(
141 **
mUID +
"_res", **
mName +
"_res", Logger::Level::off);
142 mSubResistor->setParameters(mResistance);
143 mSubResistor->connect({SimNode::GND,
mTerminals[0]->node()});
145 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
149 if (mReactance > 0) {
150 mInductance = mReactance / omega;
151 mSubInductor = std::make_shared<SP::Ph1::Inductor>(
152 **
mUID +
"_res", **
mName +
"_ind", Logger::Level::off);
153 mSubInductor->setParameters(mInductance);
154 mSubInductor->connect({SimNode::GND,
mTerminals[0]->node()});
156 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
157 }
else if (mReactance < 0) {
158 mCapacitance = -1. / omega / mReactance;
159 mSubCapacitor = std::make_shared<SP::Ph1::Capacitor>(
160 **
mUID +
"_res", **
mName +
"_cap", Logger::Level::off);
161 mSubCapacitor->setParameters(mCapacitance);
162 mSubCapacitor->connect({SimNode::GND,
mTerminals[0]->node()});
164 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
167 (**mIntfVoltage)(0, 0) =
mTerminals[0]->initialSingleVoltage();
172 SPDLOG_LOGGER_INFO(
mSLog,
173 "\n--- Initialization from powerflow ---"
174 "\nVoltage across: {:s}"
176 "\nTerminal 0 voltage: {:s}"
177 "\n--- Initialization from powerflow finished ---",
180 Logger::phasorToString(initialSingleVoltage(0)));
181 SPDLOG_LOGGER_INFO(
mSLog,
182 "Updated parameters according to powerflow:\n"
183 "Active Power={} [W] Reactive Power={} [VAr]",
191void SP::Ph1::Load::mnaParentAddPostStepDependencies(
192 AttributeBase::List &prevStepDependencies,
193 AttributeBase::List &attributeDependencies,
194 AttributeBase::List &modifiedAttributes,
195 Attribute<Matrix>::Ptr &leftVector) {
196 attributeDependencies.push_back(leftVector);
197 modifiedAttributes.push_back(mIntfCurrent);
198 modifiedAttributes.push_back(mIntfVoltage);
202 Attribute<Matrix>::Ptr &leftVector) {
208 (**mIntfVoltage)(0, 0) =
209 Math::complexFromVectorElement(leftVector, matrixNodeIndex(0));
213 (**mIntfCurrent)(0, 0) = 0;
216 (**mIntfCurrent)(0, 0) += subc->intfCurrent()(0, 0);
void addMNASubComponent(typename SimPowerComp< Complex >::Ptr subc, MNA_SUBCOMP_TASK_ORDER preStepOrder, MNA_SUBCOMP_TASK_ORDER postStepOrder, Bool contributeToRightVector)
CompositePowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
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.
String type()
Get component type (cross-platform)
const Attribute< String >::Ptr mUID
Unique identifier.
AttributeList::Ptr mAttributes
Attribute List.
PowerflowBusType mPowerflowBusType
Define the type of bus the component is modelled by.
const Attribute< Real >::Ptr mReactivePower
Reactive power [VAr].
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Updates internal voltage variable of the component.
void modifyPowerFlowBusType(PowerflowBusType powerflowBusType) override
Modify powerflow bus type.
const Attribute< Real >::Ptr mActivePower
Active power [Watt].
const Attribute< Real >::Ptr mReactivePowerPerUnit
Reactive power [pu].
Real getNomVoltage() const
Get nominal voltage.
PowerProfile mLoadProfile
Load profile data.
Load(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name and logging level.
void createSubComponents() override
Constructs and registers MNA subcomponents; idempotent.
void updatePQ(Real time)
Update PQ for this load for power flow calculation at next time step.
void mnaParentPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
const Attribute< Real >::Ptr mActivePowerPerUnit
Active power [pu].
void mnaCompUpdateCurrent(const Matrix &leftVector) override
Updates internal current variable of the component.
void calculatePerUnitParameters(Real baseApparentPower, Real baseOmega)
Calculates component's parameters in specified per-unit system.
void initializeParentFromNodesAndTerminals(Real frequency) override
Derives values from power flow data and pushes them to subcomponents.
const Attribute< MatrixVar< Complex > >::Ptr mIntfCurrent
SimTerminal< Complex >::List mTerminals
const Attribute< MatrixVar< Complex > >::Ptr mIntfVoltage
std::vector< std::shared_ptr< SimPowerComp< Complex > > > mSubComponents
bool mParametersSet
Flag indicating that parameters are set via setParameters() function.
Logger::Log mSLog
Component logger.