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;
104 setParameters(
mTerminals[0]->singleActivePower(),
106 std::abs(
mTerminals[0]->initialSingleVoltage()));
111 mResistance = std::pow(mNomVoltage, 2) / **
mActivePower;
112 mConductance = 1.0 / mResistance;
113 mSubResistor = std::make_shared<SP::Ph1::Resistor>(
114 **
mUID +
"_res", **
mName +
"_res", Logger::Level::off);
115 mSubResistor->setParameters(mResistance);
116 mSubResistor->connect({SimNode::GND,
mTerminals[0]->node()});
118 mSubResistor->initializeFromNodesAndTerminals(frequency);
120 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
129 if (mReactance > 0) {
130 mInductance = mReactance / (2 * PI * frequency);
131 mSubInductor = std::make_shared<SP::Ph1::Inductor>(
132 **
mUID +
"_res", **
mName +
"_ind", Logger::Level::off);
133 mSubInductor->setParameters(mInductance);
134 mSubInductor->connect({SimNode::GND,
mTerminals[0]->node()});
136 mSubInductor->initializeFromNodesAndTerminals(frequency);
138 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
139 }
else if (mReactance < 0) {
140 mCapacitance = -1 / (2 * PI * frequency) / mReactance;
141 mSubCapacitor = std::make_shared<SP::Ph1::Capacitor>(
142 **
mUID +
"_res", **
mName +
"_cap", Logger::Level::off);
143 mSubCapacitor->setParameters(mCapacitance);
144 mSubCapacitor->connect({SimNode::GND,
mTerminals[0]->node()});
146 mSubCapacitor->initializeFromNodesAndTerminals(frequency);
148 MNA_SUBCOMP_TASK_ORDER::TASK_BEFORE_PARENT,
false);
151 (**mIntfVoltage)(0, 0) =
mTerminals[0]->initialSingleVoltage();
156 SPDLOG_LOGGER_INFO(
mSLog,
157 "\n--- Initialization from powerflow ---"
158 "\nVoltage across: {:s}"
160 "\nTerminal 0 voltage: {:s}"
161 "\n--- Initialization from powerflow finished ---",
164 Logger::phasorToString(initialSingleVoltage(0)));
165 SPDLOG_LOGGER_INFO(
mSLog,
166 "Updated parameters according to powerflow:\n"
167 "Active Power={} [W] Reactive Power={} [VAr]",
175void SP::Ph1::Load::mnaParentAddPostStepDependencies(
176 AttributeBase::List &prevStepDependencies,
177 AttributeBase::List &attributeDependencies,
178 AttributeBase::List &modifiedAttributes,
179 Attribute<Matrix>::Ptr &leftVector) {
180 attributeDependencies.push_back(leftVector);
181 modifiedAttributes.push_back(mIntfCurrent);
182 modifiedAttributes.push_back(mIntfVoltage);
186 Attribute<Matrix>::Ptr &leftVector) {
192 (**mIntfVoltage)(0, 0) =
193 Math::complexFromVectorElement(leftVector, matrixNodeIndex(0));
197 (**mIntfCurrent)(0, 0) = 0;
200 (**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.
void initializeFromNodesAndTerminals(Real frequency) override
Initializes component from power flow data.
PowerProfile mLoadProfile
Load profile data.
Load(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name and logging level.
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.
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.