Power System Platform  2026w10a-beta
Loading...
Searching...
No Matches
Load Class Reference

Loas shunt power element. More...

#include <Load.h>

Inheritance diagram for Load:
Collaboration diagram for Load:

Public Member Functions

 Load (wxString name)
 
virtual ElementGetCopy ()
 Get a the element copy.
 
virtual bool AddParent (Element *parent, wxPoint2DDouble position)
 Add a parent to the element. This method must be used on power elements that connect to a bus, so the parent must be a bus. The element basic points are calculated in this method, so apply this when the element is being inserted.
 
virtual void DrawDC (wxPoint2DDouble translation, double scale, wxGraphicsContext *gc) const
 Draw the element using GDI+.
 
virtual void DrawDC (wxPoint2DDouble translation, double scale, wxDC &dc) const
 Draw the element using wxDC.
 
virtual void Rotate (bool clockwise=true)
 Rotate the element.
 
virtual bool GetContextMenu (wxMenu &menu)
 Get the element contex menu.
 
virtual wxString GetTipText () const
 Get the tip text.
 
virtual bool ShowForm (wxWindow *parent, Element *element)
 Show element data form.
 
LoadElectricalData GetElectricalData ()
 
LoadElectricalData GetPUElectricalData (double systemPowerBase)
 
void SetElectricalData (const LoadElectricalData &electricalData)
 
virtual bool GetPlotData (ElementPlotData &plotData, PlotStudy study=PlotStudy::STABILITY)
 Fill the plot data.
 
virtual rapidxml::xml_node * SaveElement (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementListNode)
 
virtual bool OpenElement (rapidxml::xml_node<> *elementNode, std::vector< Element * > parentList)
 
- Public Member Functions inherited from Shunt
virtual bool Contains (wxPoint2DDouble position) const
 Checks if the element contains a position.
 
virtual bool Intersects (wxRect2DDouble rect) const
 Check if the element's rect intersects other rect.
 
virtual void Move (wxPoint2DDouble position)
 Move the element other position.
 
virtual void MoveNode (Element *element, wxPoint2DDouble position)
 Move a node. StartMove(wxPoint2DDouble position) before start moving.
 
virtual void StartMove (wxPoint2DDouble position)
 Update the element attributes related to the movement.
 
virtual void RotateNode (Element *parent, bool clockwise=true)
 Rotate a node.
 
virtual void RemoveParent (Element *parent)
 Remove a parent.
 
virtual bool NodeContains (wxPoint2DDouble position)
 Check if a node contains a point. If contains, set the attributes related to node movement.
 
virtual bool SetNodeParent (Element *parent)
 Set a perent to the node. If all conditions are met, a new parent are added to the element and the points related to the nodes will be calculated.
 
virtual void UpdateNodes ()
 Update the nodes according to the parents. If a parent is removed, use this method.
 
- Public Member Functions inherited from PowerElement
 PowerElement ()
 Constructor.
 
virtual ~PowerElement ()
 Destructor.
 
virtual wxPoint2DDouble GetSwitchPoint (Element *parent, wxPoint2DDouble parentPoint, wxPoint2DDouble secondPoint) const
 Get the correct switch position.
 
virtual bool SwitchesContains (wxPoint2DDouble position) const
 Check if switch contains position.
 
virtual void UpdateSwitches ()
 Update the switch position.
 
virtual void DrawDCSwitches (wxGraphicsContext *gc) const
 Draw switch.
 
virtual void DrawDCSwitches (wxDC &dc) const
 
virtual void CalculatePowerFlowPts (std::vector< wxPoint2DDouble > edges)
 Calculate the points of the power flow arrows.
 
virtual void DrawDCPowerFlowPts (wxGraphicsContext *gc) const
 Draw power flow arrows.
 
virtual void DrawDCPowerFlowPts (wxDC &dc) const
 
virtual void SetNominalVoltage (std::vector< double > nominalVoltage, std::vector< ElectricalUnit > nominalVoltageUnit)
 Set nominal voltage of the element.
 
virtual void SetSwitchingData (SwitchingData data)
 Set the switching data of the element.
 
virtual SwitchingData GetSwitchingData ()
 Returns the switching data of the element.
 
virtual void SetPowerFlowDirection (PowerFlowDirection pfDirection)
 Set the direction of the power flow.
 
virtual PowerFlowDirection GetPowerFlowDirection () const
 Return the direction of the power flow.
 
virtual bool HaveDynamicEvent () const
 Check if the power element have dynamic event.
 
virtual void SetDynamicEvent (bool dynEvent=true)
 Set if the power element have dynamic event.
 
virtual double GetValueFromUnit (double value, ElectricalUnit valueUnit)
 
virtual void SaveCADProperties (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementNode)
 
virtual void SaveSwitchingData (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *electricalNode)
 
virtual bool OpenCADProperties (rapidxml::xml_node<> *elementNode, std::vector< Element * > parentList)
 
virtual bool OpenSwitchingData (rapidxml::xml_node<> *electricalNode)
 
- Public Member Functions inherited from Element
 Element ()
 Constructor.
 
virtual ~Element ()
 Destructor.
 
void SetDragging (bool dragging=true)
 Set if the element are being dragged.
 
void SetHeight (double height)
 Set element height.
 
void SetPosition (const wxPoint2DDouble position)
 Set the element position and update the rectangle.
 
void SetSelected (bool selected=true)
 Set element selection.
 
void SetWidth (double width)
 Set element width.
 
void SetAngle (double angle)
 Set element angle.
 
void ShowPickbox (bool showPickbox=true)
 Set if the pickbox is shown.
 
void SetBorderSize (double borderSize)
 Set the size of the border (shown in selected elements).
 
bool SetOnline (bool online=true)
 Set if the element is online or offline.
 
virtual void SetPointList (std::vector< wxPoint2DDouble > pointList)
 Set the list of points that connect the element to the bus.
 
ElementType GetElementType ()
 
wxRect2DDouble GetRect () const
 Get the element rectangle.
 
wxPoint2DDouble GetPosition () const
 Get the element position.
 
bool IsDragging () const
 Checks if the element is being dragged.
 
double GetHeight () const
 Get the element height.
 
bool IsSelected () const
 Checks if the element is selected.
 
double GetWidth () const
 Get the element width.
 
double GetAngle () const
 Get the element angle.
 
double GetRotationAngle () const
 Get the angle of rotation.
 
bool IsPickboxShown () const
 Checks if the pickbox is shown.
 
bool IsOnline () const
 Checks if the element is online or offline.
 
virtual std::vector< wxPoint2DDouble > GetPointList () const
 Get the list of points that connect the element to bus.
 
virtual void AddParent (Element *parent)
 Add a parent to the element.
 
virtual void SetID (int id)
 Set the element ID.
 
virtual int GetID () const
 Get the element ID.
 
virtual void AddChild (Element *child)
 Add a child to the child list.
 
virtual void RemoveChild (Element *child)
 Remove a child from the list.
 
virtual void ReplaceChild (Element *oldChild, Element *newChild)
 Replace a child from the list.
 
virtual void AddPoint (wxPoint2DDouble point)
 Add point to the list of points that connect the element to the bus.
 
void SetParent (Element *parent, int num)
 
void SetChild (Element *child, int num)
 
virtual void ReplaceParent (Element *oldParent, Element *newParent)
 Replace a parent.
 
virtual bool PickboxContains (wxPoint2DDouble position)
 Check if a pickbox contains a point. If contains the attributes related to pickbox movement will be calculated.
 
virtual void MovePickbox (wxPoint2DDouble position)
 Move the pickbox.
 
virtual wxCursor GetBestPickboxCursor () const
 Get the best cursor to shown to the user when the mouse is above a pickbox.
 
virtual void ResetPickboxes ()
 Remove the pickboxes.
 
virtual void ResetNodes ()
 Remove the active nodes.
 
virtual wxPoint2DDouble WorldToScreen (wxPoint2DDouble translation, double scale, double offsetX=0.0, double offsetY=0.0) const
 Convert the element position to screen position.
 
virtual wxPoint2DDouble WorldToScreen (wxPoint2DDouble position, wxPoint2DDouble translation, double scale, double offsetX=0.0, double offsetY=0.0) const
 Convert a generic position to screen position.
 
virtual bool RotatedRectanglesIntersects (wxRect2DDouble rect1, wxRect2DDouble rect2, double angle1, double angle2) const
 Check if two roteted rectangles intersect.
 
virtual void DrawDCRectangle (wxPoint2DDouble position, double width, double height, double angle, wxDC &dc) const
 Draw a circle.
 
virtual void DrawDCRoundedRectRotated (wxDC &dc, const wxPoint2DDouble &center, double width, double height, double radius, double angleDeg, int arcSegments=8) const
 
virtual void DrawDCCircle (wxPoint2DDouble position, double radius, int numSegments, wxGraphicsContext *gc) const
 Draw a circle using device context.
 
virtual void DrawDCCircle (wxPoint2DDouble position, double radius, wxDC &dc) const
 
virtual void DrawDCArc (wxPoint2DDouble position, double radius, double initAngle, double finalAngle, int numSegments, wxGraphicsContext *gc) const
 
virtual void DrawDCArc (wxPoint2DDouble position, double radius, double initAngle, double finalAngle, wxDC &dc) const
 
virtual void DrawDCTriangle (std::vector< wxPoint2DDouble > points, wxGraphicsContext *gc) const
 Draw rectangle.
 
virtual void DrawDCTriangle (std::vector< wxPoint > points, wxDC &dc) const
 
virtual void DrawDCPickbox (wxPoint2DDouble position, wxGraphicsContext *gc) const
 Draw a point.
 
virtual wxPoint2DDouble RotateAtPosition (wxPoint2DDouble pointToRotate, double angle, bool degrees=true) const
 Rotate a point as element position being the origin.
 
virtual wxPoint2DDouble RotateLocal (wxPoint2DDouble local, double angleDeg) const
 
virtual wxPoint RotateAround (const wxPoint2DDouble &p, const wxPoint2DDouble &center, double angleDeg) const
 
virtual std::vector< Element * > GetParentList () const
 Get the parent list.
 
virtual std::vector< Element * > GetChildList () const
 Get the Child list.
 
virtual void CalculateBoundaries (wxPoint2DDouble &leftUp, wxPoint2DDouble &rightBottom) const
 Calculate the element boundaries.
 
virtual void GeneralMenuItens (wxMenu &menu)
 Insert general itens to context menu.
 
virtual double PointToLineDistance (wxPoint2DDouble point, int *segmentNumber=nullptr) const
 Calculate the distance between a line (formed by point list) and a point.
 
bool IsInserted () const
 Check if the element is properly inserted in the workspace.
 
void SetInserted (bool inserted=true)
 Set if the element is properly inserted in the workspace.
 
virtual bool OpenElement (rapidxml::xml_node<> *elementNode)
 
void SaveCADProperties (rapidxml::xml_document<> &doc, rapidxml::xml_node<> *elementNode)
 
bool OpenCADProperties (rapidxml::xml_node<> *elementNode)
 

Protected Attributes

std::vector< wxPoint2DDouble > m_triangPts
 
LoadElectricalData m_electricalData
 
- Protected Attributes inherited from PowerElement
SwitchingData m_swData
 
std::vector< std::vector< wxPoint2DDouble > > m_powerFlowArrow
 
PowerFlowDirection m_pfDirection = PowerFlowDirection::PF_NONE
 
wxColour m_busColour
 
wxColour m_onlineElementColour
 
wxColour m_offlineElementColour
 
wxColour m_closedSwitchColour
 
wxColour m_openedSwitchColour
 
wxColour m_powerFlowArrowColour
 
wxColour m_dynamicEventColour
 
bool m_dynEvent = false
 
- Protected Attributes inherited from Element
ElementType m_elementType = ElementType::TYPE_NONE
 
int m_elementID = 0
 
std::vector< Element * > m_parentList
 
std::vector< Element * > m_childList
 
wxRect2DDouble m_rect
 
wxPoint2DDouble m_position
 
double m_width = 0.0
 
double m_height = 0.0
 
double m_angle = 0.0
 
double m_borderSize = 2.0
 
double m_rotationAngle = 45.0
 
double m_switchSize = 10.0
 
std::vector< wxRect2DDouble > m_switchRect
 
bool m_selected = false
 
bool m_dragging = false
 
bool m_showPickbox = false
 
bool m_inserted = false
 
int m_activePickboxID = ID_PB_NONE
 
int m_activeNodeID = 0
 
std::vector< wxPoint2DDouble > m_pointList
 
std::vector< wxPoint2DDouble > m_movePts
 
wxPoint2DDouble m_moveStartPt
 
wxPoint2DDouble m_movePos
 
bool m_online = true
 
wxColour m_selectionColour
 

Additional Inherited Members

- Static Public Member Functions inherited from Element
static bool DoubleFromString (wxWindow *parent, wxString strValue, double &value, wxString errorMsg)
 Get a double value from a string. Show a error message if the conversion fail.
 
static bool IntFromString (wxWindow *parent, wxString strValue, int &value, wxString errorMsg)
 Convert a string to int. Show a error message if the conversion fail.
 
static wxString StringFromDouble (double value, int minDecimal=1, int maxDecimals=13)
 Convert a double value to string.
 
- Protected Member Functions inherited from Shunt
void UpdateSwitchesPosition ()
 
void UpdatePowerFlowArrowsPosition ()
 
void DrawDCGround (wxPoint2DDouble position, wxGraphicsContext *gc) const
 
void DrawDCGround (wxPoint2DDouble position, wxDC &dc) const
 

Detailed Description

Loas shunt power element.

Author
Thales Lima Oliveira thale.nosp@m.s@uf.nosp@m.u.br
Date
06/10/2017

Definition at line 73 of file Load.h.

Constructor & Destructor Documentation

◆ Load() [1/2]

Load::Load ( )

Definition at line 20 of file Load.cpp.

20 : Shunt()
21{
22 m_elementType = TYPE_LOAD;
23}
Abstract class for shunt power elements.
Definition Shunt.h:32

◆ Load() [2/2]

Load::Load ( wxString  name)

Definition at line 25 of file Load.cpp.

25 : Shunt()
26{
27 m_elementType = TYPE_LOAD;
28 m_electricalData.name = name;
29}

◆ ~Load()

Load::~Load ( )

Definition at line 31 of file Load.cpp.

31{}

Member Function Documentation

◆ AddParent()

bool Load::AddParent ( Element parent,
wxPoint2DDouble  position 
)
virtual

Add a parent to the element. This method must be used on power elements that connect to a bus, so the parent must be a bus. The element basic points are calculated in this method, so apply this when the element is being inserted.

Parameters
parentElement parent.
positionNode position in the parent.

Reimplemented from Element.

Definition at line 33 of file Load.cpp.

34{
35 if (parent) {
36 m_parentList.push_back(parent);
37 parent->AddChild(this);
38 wxPoint2DDouble parentPt =
39 parent->RotateAtPosition(position, -parent->GetAngle()); // Rotate click to horizontal position.
40 parentPt.m_y = parent->GetPosition().m_y; // Centralize on bus.
41 parentPt = parent->RotateAtPosition(parentPt, parent->GetAngle()); // Rotate back.
42
43 m_position = parentPt + wxPoint2DDouble(0.0, 100.0); // Shifts the position to the down of the bus.
44 m_width = m_height = 20.0;
45 m_rect = wxRect2DDouble(m_position.m_x - 10.0, m_position.m_y - 10.0, m_width, m_height);
46
47 m_pointList.push_back(parentPt);
48 m_pointList.push_back(GetSwitchPoint(parent, parentPt, m_position));
49 m_pointList.push_back(m_position + wxPoint2DDouble(0.0, -20.0));
50 m_pointList.push_back(m_position + wxPoint2DDouble(0.0, -10.0));
51
52 m_triangPts.push_back(wxPoint2DDouble(-m_width / 2.0, -m_height / 2.0));
53 m_triangPts.push_back(wxPoint2DDouble(m_width / 2.0, -m_height / 2.0));
54 m_triangPts.push_back(wxPoint2DDouble(0.0, m_height / 2.0));
55
56 m_inserted = true;
57
58 wxRect2DDouble genRect(0, 0, 0, 0);
59 m_switchRect.push_back(genRect); // Push a general rectangle.
62 UpdatePowerFlowArrowsPosition();
63
64 return true;
65 }
66 return false;
67}
wxPoint2DDouble GetPosition() const
Get the element position.
Definition Element.h:186
double GetAngle() const
Get the element angle.
Definition Element.h:211
virtual wxPoint2DDouble RotateAtPosition(wxPoint2DDouble pointToRotate, double angle, bool degrees=true) const
Rotate a point as element position being the origin.
Definition Element.cpp:292
virtual void AddChild(Element *child)
Add a child to the child list.
Definition Element.cpp:566
virtual void UpdateSwitches()
Update the switch position.
virtual wxPoint2DDouble GetSwitchPoint(Element *parent, wxPoint2DDouble parentPoint, wxPoint2DDouble secondPoint) const
Get the correct switch position.
Here is the call graph for this function:

◆ DrawDC() [1/2]

void Load::DrawDC ( wxPoint2DDouble  translation,
double  scale,
wxDC &  dc 
) const
virtual

Draw the element using wxDC.

Parameters
translationTranslation of the system.
scaleScale of the system.
dcDevice context.

Reimplemented from Element.

Definition at line 199 of file Load.cpp.

200{
201 wxColour elementColour;
202 if (m_online) {
203 if (m_dynEvent)
204 elementColour = m_dynamicEventColour;
205 else
206 elementColour = m_onlineElementColour;
207 }
208 else
209 elementColour = m_offlineElementColour;
210
211 std::vector<wxPoint> pointListInt;
212 for (auto& pt : m_pointList) {
213 pointListInt.emplace_back(static_cast<int>(pt.m_x), static_cast<int>(pt.m_y));
214 }
215 wxPoint pos = wxPoint(static_cast<int>(m_position.m_x), static_cast<int>(m_position.m_y));
216
217 if (m_inserted) {
218 // Draw Selection (layer 1).
219 if (m_selected) {
220 dc.SetPen(wxPen(m_selectionColour, 2 + m_borderSize * 2.0));
221 dc.SetBrush(*wxTRANSPARENT_BRUSH);
222
223 dc.DrawLines(pointListInt.size(), &pointListInt[0]);
224
225 dc.SetPen(*wxTRANSPARENT_PEN);
226 dc.SetBrush(wxBrush(m_selectionColour));
227
228 wxPoint2DDouble p;
229 wxPoint selTriangPts[3];
230 p = m_triangPts[0] + m_position + wxPoint2DDouble(-m_borderSize / scale, -m_borderSize / scale);
231 selTriangPts[0] = RotateAround(p, m_position, m_angle);
232 p = m_triangPts[1] + m_position + wxPoint2DDouble(m_borderSize / scale, -m_borderSize / scale);
233 selTriangPts[1] = RotateAround(p, m_position, m_angle);
234 p = m_triangPts[2] + m_position + wxPoint2DDouble(0.0, m_borderSize / scale);
235 selTriangPts[2] = RotateAround(p, m_position, m_angle);
236
237 dc.DrawPolygon(3, selTriangPts);
238
239 // Draw node selection.
240 DrawDCCircle(m_pointList[0], 5.0 + m_borderSize / scale, dc);
241 }
242
243 // Draw Load (layer 2).
244 dc.SetPen(wxPen(elementColour, 2));
245 dc.SetBrush(*wxTRANSPARENT_BRUSH);
246 dc.DrawLines(pointListInt.size(), &pointListInt[0]);
247
248 // Draw node.
249 dc.SetPen(*wxTRANSPARENT_PEN);
250 dc.SetBrush(wxBrush(elementColour));
251 DrawDCCircle(m_pointList[0], 5.0, dc);
252
253 DrawDCSwitches(dc);
255
256 wxPoint2DDouble p;
257 wxPoint triangPts[3];
258
259 //std::vector<wxPoint2DDouble> triangPts;
260 for (int i = 0; i < 3; i++) {
261 p = m_triangPts[i] + m_position;
262 triangPts[i] = RotateAround(p, m_position, m_angle);
263 }
264 dc.SetPen(*wxTRANSPARENT_PEN);
265 dc.SetBrush(wxBrush(elementColour));
266 dc.DrawPolygon(3, triangPts);
267 }
268}
virtual void DrawDCCircle(wxPoint2DDouble position, double radius, int numSegments, wxGraphicsContext *gc) const
Draw a circle using device context.
Definition Element.cpp:177
virtual void DrawDCSwitches(wxGraphicsContext *gc) const
Draw switch.
virtual void DrawDCPowerFlowPts(wxGraphicsContext *gc) const
Draw power flow arrows.
Here is the call graph for this function:

◆ DrawDC() [2/2]

void Load::DrawDC ( wxPoint2DDouble  translation,
double  scale,
wxGraphicsContext *  gc 
) const
virtual

Draw the element using GDI+.

Parameters
translationTranslation of the system.
scaleScale of the system.
gcGraphics context

Reimplemented from Element.

Definition at line 130 of file Load.cpp.

131{
132 wxColour elementColour;
133 if (m_online) {
134 if (m_dynEvent)
135 elementColour = m_dynamicEventColour;
136 else
137 elementColour = m_onlineElementColour;
138 }
139 else
140 elementColour = m_offlineElementColour;
141
142 if (m_inserted) {
143 // Draw Selection (layer 1).
144 if (m_selected) {
145 gc->SetPen(wxPen(m_selectionColour, 2 + m_borderSize * 2.0));
146 gc->SetBrush(*wxTRANSPARENT_BRUSH);
147
148 gc->StrokeLines(m_pointList.size(), &m_pointList[0]);
149
150 gc->SetPen(*wxTRANSPARENT_PEN);
151 gc->SetBrush(wxBrush(m_selectionColour));
152
153 std::vector<wxPoint2DDouble> selTriangPts;
154 selTriangPts.push_back(m_triangPts[0] + m_position +
155 wxPoint2DDouble(-m_borderSize / scale, -m_borderSize / scale));
156 selTriangPts.push_back(m_triangPts[1] + m_position +
157 wxPoint2DDouble(m_borderSize / scale, -m_borderSize / scale));
158 selTriangPts.push_back(m_triangPts[2] + m_position + wxPoint2DDouble(0.0, m_borderSize / scale));
159
160 // Push the current matrix on stack.
161 gc->PushState();
162 // Rotate the matrix around the object position.
163 gc->Translate(m_position.m_x, m_position.m_y);
164 gc->Rotate(wxDegToRad(m_angle));
165 gc->Translate(-m_position.m_x, -m_position.m_y);
166 DrawDCTriangle(selTriangPts, gc);
167 gc->PopState();
168
169 // Draw node selection.
170 DrawDCCircle(m_pointList[0], 5.0 + m_borderSize / scale, 10, gc);
171 }
172
173 // Draw Load (layer 2).
174 gc->SetPen(wxPen(elementColour, 2));
175 gc->SetBrush(*wxTRANSPARENT_BRUSH);
176 gc->StrokeLines(m_pointList.size(), &m_pointList[0]);
177
178 // Draw node.
179 gc->SetPen(*wxTRANSPARENT_PEN);
180 gc->SetBrush(wxBrush(elementColour));
181 DrawDCCircle(m_pointList[0], 5.0, 10, gc);
182
183 DrawDCSwitches(gc);
185
186 std::vector<wxPoint2DDouble> triangPts;
187 for (int i = 0; i < 3; i++) { triangPts.push_back(m_triangPts[i] + m_position); }
188 gc->PushState();
189 gc->Translate(m_position.m_x, m_position.m_y);
190 gc->Rotate(wxDegToRad(m_angle));
191 gc->Translate(-m_position.m_x, -m_position.m_y);
192 gc->SetPen(*wxTRANSPARENT_PEN);
193 gc->SetBrush(wxBrush(elementColour));
194 DrawDCTriangle(triangPts, gc);
195 gc->PopState();
196 }
197}
virtual void DrawDCTriangle(std::vector< wxPoint2DDouble > points, wxGraphicsContext *gc) const
Draw rectangle.
Definition Element.cpp:237
Here is the call graph for this function:

◆ GetContextMenu()

bool Load::GetContextMenu ( wxMenu &  menu)
virtual

Get the element contex menu.

Parameters
menumenu that will be inserted the element itens.
Returns
True if was possible to build the menu, false otherwise.

Reimplemented from Element.

Definition at line 283 of file Load.cpp.

284{
285 menu.Append(ID_EDIT_ELEMENT, _("Edit Load"));
286
287 wxMenu* textMenu = new wxMenu();
288
289 textMenu->Append(ID_TXT_NAME, _("Name"));
290 textMenu->Append(ID_TXT_ACTIVE_POWER, _("Active power"));
291 textMenu->Append(ID_TXT_REACTIVE_POWER, _("Reactive power"));
292 textMenu->SetClientData(menu.GetClientData());
293
294
295 menu.AppendSubMenu(textMenu, _("Add text"));
296
297 GeneralMenuItens(menu);
298 return true;
299}
@ ID_EDIT_ELEMENT
Definition Element.h:75
virtual void GeneralMenuItens(wxMenu &menu)
Insert general itens to context menu.
Definition Element.cpp:457
Here is the call graph for this function:

◆ GetCopy()

Element * Load::GetCopy ( )
virtual

Get a the element copy.

Returns
Copy of the element.

Reimplemented from Element.

Definition at line 350 of file Load.cpp.

351{
352 Load* copy = new Load();
353 *copy = *this;
354 return copy;
355}
Loas shunt power element.
Definition Load.h:74

◆ GetElectricalData()

LoadElectricalData Load::GetElectricalData ( )
inline

Definition at line 89 of file Load.h.

89{ return m_electricalData; }

◆ GetPlotData()

bool Load::GetPlotData ( ElementPlotData plotData,
PlotStudy  study = PlotStudy::STABILITY 
)
virtual

Fill the plot data.

Parameters
plotDataPlot data to be filled.
Returns
true if the plot data was successfully filled, false otherwise.

Reimplemented from PowerElement.

Definition at line 412 of file Load.cpp.

413{
414 if (!m_electricalData.plotLoad) return false;
415 plotData.SetName(m_electricalData.name);
416 plotData.SetCurveType(ElementPlotData::CurveType::CT_LOAD);
417
418 std::vector<double> absVoltage, activePower, reactivePower, current;
419 for (unsigned int i = 0; i < m_electricalData.voltageVector.size(); ++i) {
420 absVoltage.push_back(std::abs(m_electricalData.voltageVector[i]));
421 activePower.push_back(std::real(m_electricalData.electricalPowerVector[i]));
422 reactivePower.push_back(std::imag(m_electricalData.electricalPowerVector[i]));
423 current.push_back(std::abs(std::complex<double>(activePower[i], -reactivePower[i]) /
424 std::conj(m_electricalData.voltageVector[i])));
425 }
426
427 plotData.AddData(absVoltage, _("Voltage"));
428 plotData.AddData(activePower, _("Active power"));
429 plotData.AddData(reactivePower, _("Reactive power"));
430 plotData.AddData(current, _("Current"));
431
432 return true;
433}

◆ GetPUElectricalData()

LoadElectricalData Load::GetPUElectricalData ( double  systemPowerBase)

Definition at line 311 of file Load.cpp.

312{
313 LoadElectricalData data = m_electricalData;
314 switch (data.activePowerUnit) {
316 data.activePower = data.activePower / systemPowerBase;
317 data.activePowerUnit = ElectricalUnit::UNIT_PU;
318 } break;
320 data.activePower = (data.activePower * 1e3) / systemPowerBase;
321 data.activePowerUnit = ElectricalUnit::UNIT_PU;
322 } break;
324 data.activePower = (data.activePower * 1e6) / systemPowerBase;
325 data.activePowerUnit = ElectricalUnit::UNIT_PU;
326 } break;
327 default:
328 break;
329 }
330 switch (data.reactivePowerUnit) {
332 data.reactivePower = data.reactivePower / systemPowerBase;
333 data.reactivePowerUnit = ElectricalUnit::UNIT_PU;
334 } break;
336 data.reactivePower = (data.reactivePower * 1e3) / systemPowerBase;
337 data.reactivePowerUnit = ElectricalUnit::UNIT_PU;
338 } break;
340 data.reactivePower = (data.reactivePower * 1e6) / systemPowerBase;
341 data.reactivePowerUnit = ElectricalUnit::UNIT_PU;
342 } break;
343 default:
344 break;
345 }
346
347 return data;
348}

◆ GetTipText()

wxString Load::GetTipText ( ) const
virtual

Get the tip text.

Returns
Tip text.

Reimplemented from Element.

Definition at line 357 of file Load.cpp.

358{
359 wxString tipText = m_electricalData.name;
360
361 // TODO: Avoid power calculation.
362 double activePower = m_electricalData.activePower;
363 double reactivePower = m_electricalData.reactivePower;
364 if (!m_online) {
365 activePower = 0.0;
366 reactivePower = 0.0;
367 }
368 if (m_online && m_electricalData.loadType == CONST_IMPEDANCE) {
369 std::complex<double> v = static_cast<Bus*>(m_parentList[0])->GetElectricalData().voltage;
370 reactivePower *= std::pow(std::abs(v), 2);
371 activePower *= std::pow(std::abs(v), 2);
372 }
373 tipText += "\n";
374 tipText += _("\nP = ") + wxString::FromDouble(activePower, 5);
375 switch (m_electricalData.activePowerUnit) {
377 tipText += _(" p.u.");
378 } break;
380 tipText += _(" W");
381 } break;
383 tipText += _(" kW");
384 } break;
386 tipText += _(" MW");
387 } break;
388 default:
389 break;
390 }
391 tipText += _("\nQ = ") + wxString::FromDouble(reactivePower, 5);
392 switch (m_electricalData.reactivePowerUnit) {
394 tipText += _(" p.u.");
395 } break;
397 tipText += _(" var");
398 } break;
400 tipText += _(" kvar");
401 } break;
403 tipText += _(" Mvar");
404 } break;
405 default:
406 break;
407 }
408
409 return tipText;
410}
Node for power elements. All others power elements are connected through this.
Definition Bus.h:86

◆ OpenElement()

bool Load::OpenElement ( rapidxml::xml_node<> *  elementNode,
std::vector< Element * >  parentList 
)
virtual

Reimplemented from PowerElement.

Definition at line 481 of file Load.cpp.

482{
483 if (!OpenCADProperties(elementNode, parentList)) return false;
484 // The load have to insert the points that define his triangle
485 m_triangPts.push_back(wxPoint2DDouble(-m_width / 2.0, -m_height / 2.0));
486 m_triangPts.push_back(wxPoint2DDouble(m_width / 2.0, -m_height / 2.0));
487 m_triangPts.push_back(wxPoint2DDouble(0.0, m_height / 2.0));
488
489 auto electricalProp = elementNode->first_node("ElectricalProperties");
490 if (!electricalProp) return false;
491
492 SetOnline(XMLParser::GetNodeValueInt(electricalProp, "IsOnline"));
493 m_electricalData.name = electricalProp->first_node("Name")->value();
494 m_electricalData.activePower = XMLParser::GetNodeValueDouble(electricalProp, "ActivePower");
495 m_electricalData.activePowerUnit =
496 static_cast<ElectricalUnit>(XMLParser::GetAttributeValueInt(electricalProp, "ActivePower", "UnitID"));
497 m_electricalData.reactivePower = XMLParser::GetNodeValueDouble(electricalProp, "ReactivePower");
498 m_electricalData.reactivePowerUnit =
499 static_cast<ElectricalUnit>(XMLParser::GetAttributeValueInt(electricalProp, "ReactivePower", "UnitID"));
500 m_electricalData.loadType = static_cast<LoadType>(XMLParser::GetNodeValueInt(electricalProp, "LoadType"));
501 // Stability
502 auto stability = electricalProp->first_node("Stability");
503 if (stability) {
504 m_electricalData.plotLoad = XMLParser::GetNodeValueInt(stability, "PlotLoad");
505 m_electricalData.useCompLoad = XMLParser::GetNodeValueInt(stability, "UseCompositeLoad");
506 auto activePowerComp = stability->first_node("ActivePowerComposition");
507 m_electricalData.constImpedanceActive = XMLParser::GetNodeValueDouble(activePowerComp, "ConstantImpedance");
508 m_electricalData.constCurrentActive = XMLParser::GetNodeValueDouble(activePowerComp, "ConstantCurrent");
509 m_electricalData.constPowerActive = XMLParser::GetNodeValueDouble(activePowerComp, "ConstantPower");
510 auto reactivePowerComp = stability->first_node("ReactivePowerComposition");
511 m_electricalData.constImpedanceReactive = XMLParser::GetNodeValueDouble(reactivePowerComp, "ConstantImpedance");
512 m_electricalData.constCurrentReactive = XMLParser::GetNodeValueDouble(reactivePowerComp, "ConstantCurrent");
513 m_electricalData.constPowerReactive = XMLParser::GetNodeValueDouble(reactivePowerComp, "ConstantPower");
514 }
515
516 if (!OpenSwitchingData(electricalProp)) return false;
517 if (m_swData.swTime.size() != 0) SetDynamicEvent(true);
518
519 m_inserted = true;
520
521 return true;
522}
ElectricalUnit
Electrical units.
bool SetOnline(bool online=true)
Set if the element is online or offline.
Definition Element.cpp:447
virtual void SetDynamicEvent(bool dynEvent=true)
Set if the power element have dynamic event.
std::vector< double > swTime

◆ Rotate()

void Load::Rotate ( bool  clockwise = true)
virtual

Rotate the element.

Parameters
clockwiseTrue to rotate clockwise, false to rotate counter-clockwise.

Reimplemented from Element.

Definition at line 270 of file Load.cpp.

271{
272 double rotAngle = m_rotationAngle;
273 if (!clockwise) rotAngle = -m_rotationAngle;
274
275 m_angle += rotAngle;
276 if (m_angle >= 360 || m_angle <= -360) m_angle = 0.0;
277 m_pointList[2] = RotateAtPosition(m_pointList[2], rotAngle);
278 m_pointList[3] = RotateAtPosition(m_pointList[3], rotAngle);
279 UpdateSwitchesPosition();
280 UpdatePowerFlowArrowsPosition();
281}
Here is the call graph for this function:

◆ SaveElement()

rapidxml::xml_node * Load::SaveElement ( rapidxml::xml_document<> &  doc,
rapidxml::xml_node<> *  elementListNode 
)
virtual

Reimplemented from Element.

Definition at line 435 of file Load.cpp.

436{
437 auto elementNode = XMLParser::AppendNode(doc, elementListNode, "Load");
438 XMLParser::SetNodeAttribute(doc, elementNode, "ID", m_elementID);
439
440 SaveCADProperties(doc, elementNode);
441
442 auto electricalProp = XMLParser::AppendNode(doc, elementNode, "ElectricalProperties");
443 auto isOnline = XMLParser::AppendNode(doc, electricalProp, "IsOnline");
444 XMLParser::SetNodeValue(doc, isOnline, m_online);
445 auto name = XMLParser::AppendNode(doc, electricalProp, "Name");
446 XMLParser::SetNodeValue(doc, name, m_electricalData.name);
447 auto activePower = XMLParser::AppendNode(doc, electricalProp, "ActivePower");
448 XMLParser::SetNodeValue(doc, activePower, m_electricalData.activePower);
449 XMLParser::SetNodeAttribute(doc, activePower, "UnitID", static_cast<int>(m_electricalData.activePowerUnit));
450 auto reactivePower = XMLParser::AppendNode(doc, electricalProp, "ReactivePower");
451 XMLParser::SetNodeValue(doc, reactivePower, m_electricalData.reactivePower);
452 XMLParser::SetNodeAttribute(doc, reactivePower, "UnitID", static_cast<int>(m_electricalData.reactivePowerUnit));
453 auto loadType = XMLParser::AppendNode(doc, electricalProp, "LoadType");
454 XMLParser::SetNodeValue(doc, loadType, m_electricalData.loadType);
455
456 auto stability = XMLParser::AppendNode(doc, electricalProp, "Stability");
457 auto plotLoad = XMLParser::AppendNode(doc, stability, "PlotLoad");
458 XMLParser::SetNodeValue(doc, plotLoad, m_electricalData.plotLoad);
459 auto useCompLoad = XMLParser::AppendNode(doc, stability, "UseCompositeLoad");
460 XMLParser::SetNodeValue(doc, useCompLoad, m_electricalData.useCompLoad);
461 auto activePowerCompl = XMLParser::AppendNode(doc, stability, "ActivePowerComposition");
462 auto pzl = XMLParser::AppendNode(doc, activePowerCompl, "ConstantImpedance");
463 XMLParser::SetNodeValue(doc, pzl, m_electricalData.constImpedanceActive);
464 auto pil = XMLParser::AppendNode(doc, activePowerCompl, "ConstantCurrent");
465 XMLParser::SetNodeValue(doc, pil, m_electricalData.constCurrentActive);
466 auto ppl = XMLParser::AppendNode(doc, activePowerCompl, "ConstantPower");
467 XMLParser::SetNodeValue(doc, ppl, m_electricalData.constPowerActive);
468 auto reactivePowerCompl = XMLParser::AppendNode(doc, stability, "ReactivePowerComposition");
469 auto qzl = XMLParser::AppendNode(doc, reactivePowerCompl, "ConstantImpedance");
470 XMLParser::SetNodeValue(doc, qzl, m_electricalData.constImpedanceReactive);
471 auto qil = XMLParser::AppendNode(doc, reactivePowerCompl, "ConstantCurrent");
472 XMLParser::SetNodeValue(doc, qil, m_electricalData.constCurrentReactive);
473 auto qpl = XMLParser::AppendNode(doc, reactivePowerCompl, "ConstantPower");
474 XMLParser::SetNodeValue(doc, qpl, m_electricalData.constPowerReactive);
475
476 SaveSwitchingData(doc, electricalProp);
477
478 return elementNode;
479}

◆ SetElectricalData()

void Load::SetElectricalData ( const LoadElectricalData electricalData)
inline

Definition at line 91 of file Load.h.

91{ m_electricalData = electricalData; }

◆ ShowForm()

bool Load::ShowForm ( wxWindow *  parent,
Element element 
)
virtual

Show element data form.

Parameters
parentForm parent
elementElement that will be edited.
Returns
True if the form is shown, false otherwise.

Reimplemented from Element.

Definition at line 301 of file Load.cpp.

302{
303 LoadForm loadForm(parent, this);
304 loadForm.CenterOnParent();
305 if (loadForm.ShowModal() == wxID_OK) {
306 return true;
307 }
308 return false;
309}
Form to edit the load power data.
Definition LoadForm.h:33

Member Data Documentation

◆ m_electricalData

LoadElectricalData Load::m_electricalData
protected

Definition at line 99 of file Load.h.

◆ m_triangPts

std::vector<wxPoint2DDouble> Load::m_triangPts
protected

Definition at line 98 of file Load.h.


The documentation for this class was generated from the following files: