DPsim
Loading...
Searching...
No Matches
EMT_Ph1_PiLine.h
1/* Author: Christoph Wirtz <christoph.wirtz@fgh-ma.de>
2 * SPDX-FileCopyrightText: 2025 FGH e.V.
3 * SPDX-License-Identifier: MPL-2.0
4 */
5
6#pragma once
7
8#include <dpsim-models/Base/Base_Ph1_PiLine.h>
9#include <dpsim-models/CompositePowerComp.h>
10#include <dpsim-models/EMT/EMT_Ph1_Capacitor.h>
11#include <dpsim-models/EMT/EMT_Ph1_Inductor.h>
12#include <dpsim-models/EMT/EMT_Ph1_Resistor.h>
13#include <dpsim-models/Solver/MNATearInterface.h>
14
15namespace CPS {
16namespace EMT {
17namespace Ph1 {
22class PiLine : public CompositePowerComp<Real>,
23 public MNATearInterface,
24 public Base::Ph1::PiLine,
25 public SharedFactory<PiLine> {
26protected:
29 std::shared_ptr<Inductor> mSubSeriesInductor;
31 std::shared_ptr<Resistor> mSubSeriesResistor;
33 std::shared_ptr<Resistor> mSubParallelResistor0;
34 // Parallel Capacitor submodel at Terminal 0
35 std::shared_ptr<Capacitor> mSubParallelCapacitor0;
37 std::shared_ptr<Resistor> mSubParallelResistor1;
38 // Parallel capacitor submodel at Terminal 1
39 std::shared_ptr<Capacitor> mSubParallelCapacitor1;
41 std::vector<const Matrix *> mRightVectorStamps;
42
43public:
45 PiLine(String uid, String name, Logger::Level logLevel = Logger::Level::off);
47 PiLine(String name, Logger::Level logLevel = Logger::Level::off)
48 : PiLine(name, name, logLevel) {}
49
50 SimPowerComp<Real>::Ptr clone(String copySuffix) override;
51
52 // #### General ####
54 void createSubComponents() override;
56 void initializeParentFromNodesAndTerminals(Real frequency) override;
57
58 // #### MNA section ####
60 void mnaCompUpdateCurrent(const Matrix &leftVector) override;
62 void mnaCompUpdateVoltage(const Matrix &leftVector) override;
64 void mnaParentPreStep(Real time, Int timeStepCount) override;
66 void mnaParentPostStep(Real time, Int timeStepCount,
67 Attribute<Matrix>::Ptr &leftVector) override;
70 AttributeBase::List &prevStepDependencies,
71 AttributeBase::List &attributeDependencies,
72 AttributeBase::List &modifiedAttributes) override;
74 void
75 mnaParentAddPostStepDependencies(AttributeBase::List &prevStepDependencies,
76 AttributeBase::List &attributeDependencies,
77 AttributeBase::List &modifiedAttributes,
78 Attribute<Matrix>::Ptr &leftVector) override;
79
80 MNAInterface::List mnaTearGroundComponents() override;
81 void mnaTearInitialize(Real omega, Real timeStep) override;
82 void mnaTearApplyMatrixStamp(SparseMatrixRow &tearMatrix) override;
83 void mnaTearApplyVoltageStamp(Matrix &voltageVector) override;
84 void mnaTearPostStep(Complex voltage, Complex current) override;
85};
86} // namespace Ph1
87} // namespace EMT
88} // namespace CPS
CompositePowerComp(String uid, String name, Bool hasPreStep, Bool hasPostStep, Logger::Level logLevel)
void mnaParentPostStep(Real time, Int timeStepCount, Attribute< Matrix >::Ptr &leftVector) override
MNA post step operations.
std::shared_ptr< Inductor > mSubSeriesInductor
std::vector< const Matrix * > mRightVectorStamps
solver
void mnaCompUpdateVoltage(const Matrix &leftVector) override
Updates internal voltage variable of the component.
std::shared_ptr< Resistor > mSubParallelResistor1
Parallel resistor submodel at Terminal 1.
void mnaParentAddPostStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes, Attribute< Matrix >::Ptr &leftVector) override
Add MNA post step dependencies.
void createSubComponents() override
Constructs and registers MNA subcomponents; idempotent.
void mnaCompUpdateCurrent(const Matrix &leftVector) override
Updates internal current variable of the component.
std::shared_ptr< Resistor > mSubSeriesResistor
Series Resistor submodel.
void mnaParentAddPreStepDependencies(AttributeBase::List &prevStepDependencies, AttributeBase::List &attributeDependencies, AttributeBase::List &modifiedAttributes) override
Add MNA pre step dependencies.
PiLine(String name, Logger::Level logLevel=Logger::Level::off)
Defines name and logging level.
SimPowerComp< Real >::Ptr clone(String copySuffix) override
DEPRECATED: Delete method.
std::shared_ptr< Resistor > mSubParallelResistor0
Parallel Resistor submodel at Terminal 0.
PiLine(String uid, String name, Logger::Level logLevel=Logger::Level::off)
Defines UID, name and logging level.
void initializeParentFromNodesAndTerminals(Real frequency) override
Derives values from power flow data and pushes them to subcomponents.
void mnaParentPreStep(Real time, Int timeStepCount) override
MNA pre step operations.
String uid()
Returns unique id.