blob: 13ea5e4ea1aefa5a97f41da55138cf0b10eb0e25 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
#include "SyncMachineForm.h"
#include "SyncMotor.h"
SyncMotor::SyncMotor() : Machines() {}
SyncMotor::SyncMotor(wxString name) : Machines() { m_electricalData.name = name; }
SyncMotor::~SyncMotor() {}
void SyncMotor::DrawSymbol() const { DrawArc(m_position, 12, 30, 330, 10, GL_LINE_STRIP); }
bool SyncMotor::GetContextMenu(wxMenu& menu)
{
menu.Append(ID_EDIT_SYNCMOTOR, _("Edit Synchronous Condenser"));
GeneralMenuItens(menu);
return true;
}
bool SyncMotor::ShowForm(wxWindow* parent, Element* element)
{
SyncMachineForm* syncMotorForm = new SyncMachineForm(parent, this);
syncMotorForm->SetTitle(_("Synchronous Condenser"));
if(syncMotorForm->ShowModal() == wxID_OK) {
syncMotorForm->Destroy();
return true;
}
syncMotorForm->Destroy();
return false;
}
SyncMotorElectricalData SyncMotor::GetPUElectricalData(double systemPowerBase)
{
SyncMotorElectricalData data = m_electricalData;
switch(data.activePowerUnit) {
case UNIT_W: {
data.activePower = data.activePower / systemPowerBase;
data.activePowerUnit = UNIT_PU;
} break;
case UNIT_kW: {
data.activePower = (data.activePower * 1e3) / systemPowerBase;
data.activePowerUnit = UNIT_PU;
} break;
case UNIT_MW: {
data.activePower = (data.activePower * 1e6) / systemPowerBase;
data.activePowerUnit = UNIT_PU;
} break;
default:
break;
}
switch(data.reactivePowerUnit) {
case UNIT_VAr: {
data.reactivePower = data.reactivePower / systemPowerBase;
data.reactivePowerUnit = UNIT_PU;
} break;
case UNIT_kVAr: {
data.reactivePower = (data.reactivePower * 1e3) / systemPowerBase;
data.reactivePowerUnit = UNIT_PU;
} break;
case UNIT_MVAr: {
data.reactivePower = (data.reactivePower * 1e6) / systemPowerBase;
data.reactivePowerUnit = UNIT_PU;
} break;
default:
break;
}
switch(data.maxReactiveUnit) {
case UNIT_VAr: {
data.maxReactive = data.maxReactive / systemPowerBase;
data.maxReactiveUnit = UNIT_PU;
} break;
case UNIT_kVAr: {
data.maxReactive = (data.maxReactive * 1e3) / systemPowerBase;
data.maxReactiveUnit = UNIT_PU;
} break;
case UNIT_MVAr: {
data.maxReactive = (data.maxReactive * 1e6) / systemPowerBase;
data.maxReactiveUnit = UNIT_PU;
} break;
default:
break;
}
switch(data.minReactiveUnit) {
case UNIT_VAr: {
data.minReactive = data.minReactive / systemPowerBase;
data.minReactiveUnit = UNIT_PU;
} break;
case UNIT_kVAr: {
data.minReactive = (data.minReactive * 1e3) / systemPowerBase;
data.minReactiveUnit = UNIT_PU;
} break;
case UNIT_MVAr: {
data.minReactive = (data.minReactive * 1e6) / systemPowerBase;
data.minReactiveUnit = UNIT_PU;
} break;
default:
break;
}
return data;
}
Element* SyncMotor::GetCopy()
{
SyncMotor* copy = new SyncMotor();
*copy = *this;
return copy;
}
|