summaryrefslogtreecommitdiffstats
path: root/Project/SyncMotor.cpp
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;
}