2019-10-14 12:48:35 -04:00
|
|
|
# A3XX Electrical System
|
|
|
|
# Copyright (c) 2019 Jonathan Redpath (legoboyvdlp)
|
|
|
|
|
|
|
|
# Local vars
|
|
|
|
var battery1_sw = 0;
|
|
|
|
var battery2_sw = 0;
|
|
|
|
var batt1_fail = 0;
|
|
|
|
var batt2_fail = 0;
|
|
|
|
var battery1_percent = 0;
|
|
|
|
var battery2_percent = 0;
|
|
|
|
var dc1 = 0;
|
|
|
|
var dc2 = 0;
|
|
|
|
|
|
|
|
# Main class
|
|
|
|
var ELEC = {
|
|
|
|
Bus: {
|
|
|
|
acEss: props.globals.getNode("/systems/electrical/bus/ac-ess"),
|
|
|
|
acEssShed: props.globals.getNode("/systems/electrical/bus/ac-ess-shed"),
|
|
|
|
ac1: props.globals.getNode("/systems/electrical/bus/ac-1"),
|
|
|
|
ac2: props.globals.getNode("/systems/electrical/bus/ac-2"),
|
|
|
|
dcBat: props.globals.getNode("/systems/electrical/bus/dc-bat"),
|
|
|
|
dcEss: props.globals.getNode("/systems/electrical/bus/dc-ess"),
|
|
|
|
dcEssShed: props.globals.getNode("/systems/electrical/bus/dc-ess-shed"),
|
|
|
|
dc1: props.globals.getNode("/systems/electrical/bus/dc-1"),
|
|
|
|
dc2: props.globals.getNode("/systems/electrical/bus/dc-2"),
|
|
|
|
dcHot1: props.globals.getNode("/systems/electrical/bus/dc-hot-1"),
|
|
|
|
},
|
|
|
|
Fail: {
|
|
|
|
acEssBusFault: props.globals.getNode("/systems/failures/electrical/ac-ess-bus"),
|
|
|
|
ac1BusFault: props.globals.getNode("/systems/failures/electrical/ac-1-bus"),
|
|
|
|
ac2BusFault: props.globals.getNode("/systems/failures/electrical/ac-2-bus"),
|
|
|
|
bat1Fault: props.globals.getNode("/systems/failures/electrical/bat-1"),
|
|
|
|
bat2Fault: props.globals.getNode("/systems/failures/electrical/bat-2"),
|
|
|
|
dcBatBusFault: props.globals.getNode("/systems/failures/electrical/dc-bat-bus"),
|
|
|
|
dcEssBusFault: props.globals.getNode("/systems/failures/electrical/dc-ess-bus"),
|
|
|
|
dc1BusFault: props.globals.getNode("/systems/failures/electrical/dc-1-bus"),
|
|
|
|
dc2BusFault: props.globals.getNode("/systems/failures/electrical/dc-2-bus"),
|
|
|
|
emerGenFault: props.globals.getNode("/systems/failures/electrical/emer-gen"),
|
|
|
|
essTrFault: props.globals.getNode("/systems/failures/electrical/ess-tr"),
|
|
|
|
gen1Fault: props.globals.getNode("/systems/failures/electrical/gen-1"),
|
|
|
|
gen2Fault: props.globals.getNode("/systems/failures/electrical/gen-2"),
|
|
|
|
genApuFault: props.globals.getNode("/systems/failures/electrical/apu"),
|
|
|
|
idg1Fault: props.globals.getNode("/systems/failures/electrical/idg-1"), # oil leak or low press
|
|
|
|
idg2Fault: props.globals.getNode("/systems/failures/electrical/idg-2"),
|
|
|
|
statInvFault: props.globals.getNode("/systems/failures/electrical/stat-inv"),
|
|
|
|
tr1Fault: props.globals.getNode("/systems/failures/electrical/tr-1"),
|
|
|
|
tr2Fault: props.globals.getNode("/systems/failures/electrical/tr-2"),
|
|
|
|
},
|
|
|
|
Generic: {
|
|
|
|
adf: props.globals.initNode("/systems/electrical/outputs/adf", 0, "DOUBLE"),
|
|
|
|
dme: props.globals.initNode("/systems/electrical/outputs/dme", 0, "DOUBLE"),
|
|
|
|
efis: props.globals.initNode("/systems/electrical/outputs/efis", 0, "DOUBLE"),
|
|
|
|
fcpPower: props.globals.initNode("/systems/electrical/outputs/fcp-power", 0, "DOUBLE"),
|
|
|
|
fuelPump0: props.globals.initNode("/systems/electrical/outputs/fuel-pump[0]", 0, "DOUBLE"),
|
|
|
|
fuelPump1: props.globals.initNode("/systems/electrical/outputs/fuel-pump[1]", 0, "DOUBLE"),
|
|
|
|
fuelPump2: props.globals.initNode("/systems/electrical/outputs/fuel-pump[2]", 0, "DOUBLE"),
|
|
|
|
gps: props.globals.initNode("/systems/electrical/outputs/gps", 0, "DOUBLE"),
|
|
|
|
mkViii: props.globals.initNode("/systems/electrical/outputs/mk-viii", 0, "DOUBLE"),
|
|
|
|
nav0: props.globals.initNode("/systems/electrical/outputs/nav[0]", 0, "DOUBLE"),
|
|
|
|
nav1: props.globals.initNode("/systems/electrical/outputs/nav[1]", 0, "DOUBLE"),
|
|
|
|
nav2: props.globals.initNode("/systems/electrical/outputs/nav[2]", 0, "DOUBLE"),
|
|
|
|
nav3: props.globals.initNode("/systems/electrical/outputs/nav[3]", 0, "DOUBLE"),
|
|
|
|
tacan: props.globals.initNode("/systems/electrical/outputs/tacan", 0, "DOUBLE"),
|
|
|
|
transponder: props.globals.initNode("/systems/electrical/outputs/transponder", 0, "DOUBLE"),
|
|
|
|
turnCoordinator: props.globals.initNode("/systems/electrical/outputs/turn-coordinator", 0, "DOUBLE"),
|
|
|
|
},
|
|
|
|
Light: {
|
|
|
|
},
|
|
|
|
Misc: {
|
|
|
|
},
|
|
|
|
Relay: {
|
|
|
|
essTrContactor: props.globals.getNode("/systems/electrical/relay/dc-ess-feed-tr/contact-pos"),
|
|
|
|
},
|
|
|
|
SomeThing: {
|
|
|
|
emerGenSignal: props.globals.getNode("/systems/electrical/some-electric-thingie/emer-gen-operate"),
|
|
|
|
},
|
|
|
|
Source: {
|
|
|
|
Bat1: {
|
|
|
|
amps: props.globals.getNode("/systems/electrical/sources/bat-1/amp"),
|
|
|
|
limiter: props.globals.getNode("/systems/electrical/sources/bat-1/limiter"),
|
|
|
|
percent: props.globals.getNode("/systems/electrical/sources/bat-1/percent"),
|
|
|
|
time: props.globals.getNode("/systems/electrical/sources/bat-1/time"),
|
|
|
|
},
|
|
|
|
Bat2: {
|
|
|
|
amps: props.globals.getNode("/systems/electrical/sources/bat-2/amp"),
|
|
|
|
limiter: props.globals.getNode("/systems/electrical/sources/bat-2/limiter"),
|
|
|
|
percent: props.globals.getNode("/systems/electrical/sources/bat-2/percent"),
|
|
|
|
time: props.globals.getNode("/systems/electrical/sources/bat-2/time"),
|
|
|
|
},
|
|
|
|
trEss: {
|
|
|
|
outputVolt: props.globals.getNode("/systems/electrical/sources/tr-ess/output-volt"),
|
|
|
|
outputAmp: props.globals.getNode("/systems/electrical/sources/tr-ess/output-amp"),
|
|
|
|
},
|
|
|
|
IDG1: {
|
|
|
|
gcrRelay: props.globals.getNode("/systems/electrical/sources/idg-1/gcr-relay"),
|
|
|
|
},
|
|
|
|
IDG2: {
|
|
|
|
gcrRelay: props.globals.getNode("/systems/electrical/sources/idg-1/gcr-relay"),
|
|
|
|
},
|
|
|
|
},
|
|
|
|
Switch: {
|
|
|
|
acEssFeed: props.globals.getNode("/controls/electrical/switches/ac-ess-feed"),
|
|
|
|
busTie: props.globals.getNode("/controls/electrical/switches/bus-tie"),
|
|
|
|
bat1: props.globals.getNode("/controls/electrical/switches/bat-1"),
|
|
|
|
bat2: props.globals.getNode("/controls/electrical/switches/bat-2"),
|
|
|
|
emerGenTest: props.globals.getNode("/controls/electrical/switches/emer-gen-test"),
|
|
|
|
extPwr: props.globals.getNode("/controls/electrical/switches/ext-pwr"),
|
|
|
|
galley: props.globals.getNode("/controls/electrical/switches/galley"),
|
|
|
|
gen1: props.globals.getNode("/controls/electrical/switches/gen-1"),
|
|
|
|
gen2: props.globals.getNode("/controls/electrical/switches/gen-2"),
|
|
|
|
genApu: props.globals.getNode("/controls/electrical/switches/apu"),
|
|
|
|
gen1Line: props.globals.getNode("/controls/electrical/switches/gen-1-line-contactor"),
|
|
|
|
idg1Disc: props.globals.getNode("/controls/electrical/switches/idg-1-disc"),
|
|
|
|
idg2Disc: props.globals.getNode("/controls/electrical/switches/idg-2-disc"),
|
|
|
|
emerElecManOn: props.globals.getNode("/controls/electrical/switches/emer-elec-man-on"), # non-reset
|
|
|
|
},
|
|
|
|
init: func() {
|
|
|
|
me.resetFail();
|
|
|
|
me.SomeThing.emerGenSignal.setBoolValue(0);
|
|
|
|
me.Switch.acEssFeed.setBoolValue(0);
|
|
|
|
me.Switch.bat1.setBoolValue(0);
|
|
|
|
me.Switch.bat2.setBoolValue(0);
|
|
|
|
me.Switch.busTie.setBoolValue(1);
|
|
|
|
me.Switch.emerGenTest.setBoolValue(0);
|
|
|
|
me.Switch.extPwr.setBoolValue(0);
|
|
|
|
me.Switch.galley.setBoolValue(1);
|
|
|
|
me.Switch.gen1.setBoolValue(1);
|
|
|
|
me.Switch.gen2.setBoolValue(1);
|
|
|
|
me.Switch.genApu.setBoolValue(1);
|
|
|
|
me.Switch.gen1Line.setBoolValue(0);
|
|
|
|
me.Switch.idg1Disc.setBoolValue(1);
|
|
|
|
me.Switch.idg2Disc.setBoolValue(1);
|
|
|
|
me.Switch.emerElecManOn.setBoolValue(0);
|
|
|
|
me.Source.Bat1.percent.setValue(math.round((rand() * 50) + 50 , 0.1)); # Random between 50 and 100
|
|
|
|
me.Source.Bat2.percent.setValue(math.round((rand() * 50) + 50 , 0.1)); # Random between 50 and 100
|
|
|
|
},
|
|
|
|
resetFail: func() {
|
|
|
|
me.Fail.acEssBusFault.setBoolValue(0);
|
|
|
|
me.Fail.ac1BusFault.setBoolValue(0);
|
|
|
|
me.Fail.ac2BusFault.setBoolValue(0);
|
|
|
|
me.Fail.bat1Fault.setBoolValue(0);
|
|
|
|
me.Fail.bat2Fault.setBoolValue(0);
|
|
|
|
me.Fail.dcBatBusFault.setBoolValue(0);
|
|
|
|
me.Fail.dcEssBusFault.setBoolValue(0);
|
|
|
|
me.Fail.dc1BusFault.setBoolValue(0);
|
|
|
|
me.Fail.dc2BusFault.setBoolValue(0);
|
|
|
|
me.Fail.emerGenFault.setBoolValue(0);
|
|
|
|
me.Fail.essTrFault.setBoolValue(0);
|
|
|
|
me.Fail.gen1Fault.setBoolValue(0);
|
|
|
|
me.Fail.gen2Fault.setBoolValue(0);
|
|
|
|
me.Fail.genApuFault.setBoolValue(0);
|
|
|
|
me.Fail.idg1Fault.setBoolValue(0);
|
|
|
|
me.Fail.idg2Fault.setBoolValue(0);
|
|
|
|
me.Fail.statInvFault.setBoolValue(0);
|
|
|
|
me.Fail.tr1Fault.setBoolValue(0);
|
|
|
|
me.Fail.tr2Fault.setBoolValue(0);
|
|
|
|
},
|
|
|
|
loop: func() {
|
|
|
|
battery1_sw = me.Switch.bat1.getValue();
|
|
|
|
battery2_sw = me.Switch.bat2.getValue();
|
|
|
|
batt1_fail = me.Fail.bat1Fault.getValue();
|
|
|
|
batt2_fail = me.Fail.bat2Fault.getValue();
|
|
|
|
battery1_percent = me.Source.Bat1.percent.getValue();
|
|
|
|
battery2_percent = me.Source.Bat2.percent.getValue();
|
|
|
|
battery1_amps = me.Source.Bat1.amps.getValue();
|
|
|
|
battery2_amps = me.Source.Bat2.amps.getValue();
|
|
|
|
battery1_time = me.Source.Bat1.time.getValue();
|
|
|
|
battery2_time = me.Source.Bat2.time.getValue();
|
|
|
|
dcbat = me.Bus.dcBat.getValue();
|
|
|
|
|
|
|
|
if (battery1_percent < 100 and dcbat > 25 and battery1_sw and !batt1_fail) {
|
|
|
|
if (battery1_time + 5 < getprop("/sim/time/elapsed-sec")) {
|
|
|
|
battery1_percent_calc = battery1_percent + 0.75; # Roughly 90 percent every 10 mins
|
|
|
|
if (battery1_percent_calc > 100) {
|
|
|
|
battery1_percent_calc = 100;
|
|
|
|
}
|
|
|
|
me.Source.Bat1.limiter.setBoolValue(1);
|
|
|
|
me.Source.Bat1.percent.setValue(battery1_percent_calc);
|
|
|
|
me.Source.Bat1.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
}
|
|
|
|
} else if (battery1_percent == 100 and dcbat > 25 and battery1_sw and !batt1_fail) {
|
|
|
|
me.Source.Bat1.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
me.Source.Bat1.limiter.setBoolValue(0);
|
|
|
|
} else if (battery1_amps > 0 and battery1_sw and !batt1_fail) {
|
|
|
|
if (battery1_time + 5 < getprop("/sim/time/elapsed-sec")) {
|
|
|
|
battery1_percent_calc = battery1_percent - 0.25; # Roughly 90 percent every 30 mins
|
2019-10-15 20:24:51 +01:00
|
|
|
if (battery1_percent_calc < 5) {
|
|
|
|
battery1_percent_calc = 5;
|
2019-10-14 12:48:35 -04:00
|
|
|
}
|
|
|
|
me.Source.Bat1.limiter.setBoolValue(1);
|
|
|
|
me.Source.Bat1.percent.setValue(battery1_percent_calc);
|
|
|
|
me.Source.Bat1.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
me.Source.Bat1.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
me.Source.Bat1.limiter.setBoolValue(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (battery2_percent < 100 and dcbat > 25 and battery2_sw and !batt2_fail) {
|
|
|
|
if (battery2_time + 5 < getprop("/sim/time/elapsed-sec")) {
|
|
|
|
battery2_percent_calc = battery2_percent + 0.75; # Roughly 90 percent every 10 mins
|
|
|
|
if (battery2_percent_calc > 100) {
|
|
|
|
battery2_percent_calc = 100;
|
|
|
|
}
|
|
|
|
me.Source.Bat2.limiter.setBoolValue(1);
|
|
|
|
me.Source.Bat2.percent.setValue(battery2_percent_calc);
|
|
|
|
me.Source.Bat2.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
}
|
|
|
|
} else if (battery2_percent == 100 and dcbat > 25 and battery2_sw and !batt2_fail) {
|
|
|
|
me.Source.Bat2.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
me.Source.Bat2.limiter.setBoolValue(0);
|
|
|
|
} else if (battery2_amps > 0 and battery2_sw and !batt1_fail) {
|
|
|
|
if (battery2_time + 5 < getprop("/sim/time/elapsed-sec")) {
|
|
|
|
battery2_percent_calc = battery2_percent - 0.25; # Roughly 90 percent every 30 mins
|
2019-10-15 20:24:51 +01:00
|
|
|
if (battery2_percent_calc < 5) {
|
|
|
|
battery2_percent_calc = 5;
|
2019-10-14 12:48:35 -04:00
|
|
|
}
|
|
|
|
me.Source.Bat2.limiter.setBoolValue(1);
|
|
|
|
me.Source.Bat2.percent.setValue(battery2_percent_calc);
|
|
|
|
me.Source.Bat2.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
me.Source.Bat2.time.setValue(getprop("/sim/time/elapsed-sec"));
|
|
|
|
me.Source.Bat2.limiter.setBoolValue(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
# Autopilot Disconnection routines
|
|
|
|
if (me.Bus.dcEssShed.getValue() < 25) {
|
|
|
|
if (getprop("/it-autoflight/output/ap1") == 1) {
|
|
|
|
libraries.apOff("hard", 1);
|
|
|
|
if (getprop("/it-autoflight/output/ap2") == 0) {
|
|
|
|
libraries.athrOff("hard"); # TODO - athr master FMGC logic
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (me.Bus.dc2.getValue() < 25) {
|
|
|
|
if (getprop("/it-autoflight/output/ap2") == 1) {
|
|
|
|
libraries.apOff("hard", 2);
|
|
|
|
if (getprop("/it-autoflight/output/ap1") == 0) {
|
|
|
|
libraries.athrOff("hard"); # TODO - athr master FMGC logic
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|