2019-10-14 16:48:35 +00:00
# A3XX IAE V2500 Engine
# Joshua Davidson (Octal450)
2020-04-18 05:36:46 +00:00
# Copyright (c) 2020 Josh Davidson (Octal450)
2019-10-14 16:48:35 +00:00
#####################
# Initializing Vars #
#####################
2020-02-07 16:10:54 +00:00
var engines = props.globals.getNode("engines").getChildren("engine");
2019-10-14 16:48:35 +00:00
var egt_min = 434;
var egt_start = 587;
var egt_max = 712;
var start_time = 10;
var egt_lightup_time = 4;
var egt_lightdn_time = 10;
var shutdown_time = 20;
var egt_shutdown_time = 20;
var eng_init = func {
2020-05-12 20:47:05 +00:00
setprop("/controls/engines/engine[0]/man-start", 0);
setprop("/controls/engines/engine[1]/man-start", 0);
2019-10-14 16:48:35 +00:00
eng_common_init();
}
# Trigger Startups and Stops
setlistener("/controls/engines/engine[0]/cutoff-switch", func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[0]/cutoff-switch") == 0) {
if (getprop("/systems/acconfig/autoconfig-running") == 1) {
2019-10-14 16:48:35 +00:00
fast_start_one();
} else {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[0]/man-start") == 0) {
2019-10-14 16:48:35 +00:00
start_one_check();
2020-05-12 20:47:05 +00:00
} else if (getprop("/controls/engines/engine[0]/man-start") == 1) {
2019-10-14 16:48:35 +00:00
eng_one_man_start.start();
}
}
2020-05-12 20:47:05 +00:00
} else if (getprop("/controls/engines/engine[0]/cutoff-switch") == 1) {
2019-10-14 16:48:35 +00:00
cutoff_one();
}
});
var cutoff_one = func {
eng_one_auto_start.stop();
eng_one_man_start.stop();
eng_one_n2_check.stop();
2020-05-12 20:47:05 +00:00
setprop("/controls/engines/engine[0]/igniter-a", 0);
setprop("/controls/engines/engine[0]/igniter-b", 0);
setprop("/controls/engines/engine[0]/man-start", 0);
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
setprop("/controls/engines/engine[0]/starter", 0);
setprop("/controls/engines/engine[0]/cutoff", 1);
setprop("/engines/engine[0]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[0].getNode("egt-actual"), 0, egt_shutdown_time);
eng_one_n2_check.stop();
}
var fast_start_one = func {
2020-05-12 20:47:05 +00:00
setprop("/controls/engines/engine[0]/cutoff", 0);
setprop("/engines/engine[0]/out-of-fuel", 0);
setprop("/engines/engine[0]/run", 1);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/cutoff", 0);
setprop("/engines/engine[0]/starter", 0);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/fdm/jsbsim/propulsion/set-running", 0);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/state", 3);
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
2019-10-14 16:48:35 +00:00
}
setlistener("/controls/engines/engine[0]/man-start", func {
start_one_mancheck();
});
var start_one_mancheck = func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[0]/man-start") == 1) {
if (getprop("/controls/engines/engine-start-switch") == 2 and (getprop("/controls/engines/engine[0]/cutoff-switch") == 1)) {
setprop("/systems/pneumatics/valves/starter-valve-1", 1);
2019-10-14 16:48:35 +00:00
settimer(start_one_mancheck_b, 0.5);
}
} else {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[0]/state") == 1 or getprop("/engines/engine[0]/state") == 2) {
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
setprop("/engines/engine[0]/state", 0);
setprop("/controls/engines/engine[0]/starter", 0);
2019-10-14 16:48:35 +00:00
}
}
}
var start_one_mancheck_b = func {
2020-05-12 21:03:29 +00:00
if (systems.PNEU.Psi.engine1.getValue() >= 25) {
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/state", 1);
setprop("/controls/engines/engine[0]/starter", 1);
2019-10-14 16:48:35 +00:00
}
}
var start_one_check = func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine-start-switch") == 2 and getprop("/controls/engines/engine[0]/cutoff-switch") == 0) {
setprop("/systems/pneumatics/valves/starter-valve-1", 1);
2019-10-14 16:48:35 +00:00
settimer(start_one_check_b, 0.5);
}
}
var start_one_check_b = func {
2020-06-03 18:20:10 +00:00
if (getprop("/controls/engines/engine-start-switch") == 2 and systems.PNEU.Psi.engine1.getValue() and !getprop("/controls/engines/engine[0]/cutoff-switch")) {
2019-10-14 16:48:35 +00:00
auto_start_one();
}
}
setlistener("/controls/engines/engine[1]/cutoff-switch", func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[1]/cutoff-switch") == 0) {
if (getprop("/systems/acconfig/autoconfig-running") == 1) {
2019-10-14 16:48:35 +00:00
fast_start_two();
} else {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[1]/man-start") == 0) {
2019-10-14 16:48:35 +00:00
start_two_check();
2020-05-12 20:47:05 +00:00
} else if (getprop("/controls/engines/engine[1]/man-start") == 1) {
2019-10-14 16:48:35 +00:00
eng_two_man_start.start();
}
}
2020-05-12 20:47:05 +00:00
} else if (getprop("/controls/engines/engine[1]/cutoff-switch") == 1) {
2019-10-14 16:48:35 +00:00
cutoff_two();
}
});
var cutoff_two = func {
eng_two_auto_start.stop();
eng_two_man_start.stop();
eng_two_n2_check.stop();
2020-05-12 20:47:05 +00:00
setprop("/controls/engines/engine[1]/igniter-a", 0);
setprop("/controls/engines/engine[1]/igniter-b", 0);
setprop("/controls/engines/engine[1]/man-start", 0);
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
setprop("/controls/engines/engine[1]/starter", 0);
setprop("/controls/engines/engine[1]/cutoff", 1);
setprop("/engines/engine[1]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[1].getNode("egt-actual"), 0, egt_shutdown_time);
}
var fast_start_two = func {
2020-05-12 20:47:05 +00:00
setprop("/controls/engines/engine[1]/cutoff", 0);
setprop("/engines/engine[1]/out-of-fuel", 0);
setprop("/engines/engine[1]/run", 1);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/cutoff", 0);
setprop("/engines/engine[1]/starter", 0);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/fdm/jsbsim/propulsion/set-running", 1);
2019-10-14 16:48:35 +00:00
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/state", 3);
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
2019-10-14 16:48:35 +00:00
}
setlistener("/controls/engines/engine[1]/man-start", func {
start_two_mancheck();
});
var start_two_mancheck = func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[1]/man-start") == 1) {
if (getprop("/controls/engines/engine-start-switch") == 2 and (getprop("/controls/engines/engine[1]/cutoff-switch") == 1)) {
setprop("/systems/pneumatics/valves/starter-valve-2", 1);
2019-10-14 16:48:35 +00:00
settimer(start_two_mancheck_b, 0.5);
}
} else {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[1]/state") == 1 or getprop("/engines/engine[1]/state") == 2) {
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
setprop("/engines/engine[1]/state", 0);
setprop("/controls/engines/engine[1]/starter", 0);
2019-10-14 16:48:35 +00:00
}
}
}
var start_two_mancheck_b = func {
2020-05-12 21:03:29 +00:00
if (systems.PNEU.Psi.engine1.getValue() >= 25) {
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/state", 1);
setprop("/controls/engines/engine[1]/starter", 1);
2019-10-14 16:48:35 +00:00
}
}
var start_two_check = func {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine-start-switch") == 2 and getprop("/controls/engines/engine[1]/cutoff-switch") == 0) {
setprop("/systems/pneumatics/valves/starter-valve-2", 1);
2019-10-14 16:48:35 +00:00
settimer(start_two_check_b, 0.5);
}
}
var start_two_check_b = func {
2020-06-03 18:20:10 +00:00
if (getprop("/controls/engines/engine-start-switch") == 2 and systems.PNEU.Psi.engine2.getValue() >= 25 and !getprop("/controls/engines/engine[1]/cutoff-switch")) {
2019-10-14 16:48:35 +00:00
auto_start_two();
}
}
# Start Engine One
var auto_start_one = func {
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/state", 1);
setprop("/controls/engines/engine[0]/starter", 1);
2019-10-14 16:48:35 +00:00
eng_one_auto_start.start();
}
var eng_one_auto_start = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n1Actual[0].getValue() >= 4.7) {
2019-10-14 16:48:35 +00:00
eng_one_auto_start.stop();
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/state", 2);
setprop("/controls/engines/engine[0]/cutoff", 0);
if (getprop("/controls/engines/engine[0]/last-igniter") == "B") {
setprop("/controls/engines/engine[0]/igniter-a", 1);
setprop("/controls/engines/engine[0]/igniter-b", 0);
setprop("/controls/engines/engine[0]/last-igniter", "A");
} else if (getprop("/controls/engines/engine[0]/last-igniter") == "A") {
setprop("/controls/engines/engine[0]/igniter-a", 0);
setprop("/controls/engines/engine[0]/igniter-b", 1);
setprop("/controls/engines/engine[0]/last-igniter", "B");
2019-10-14 16:48:35 +00:00
}
interpolate(engines[0].getNode("egt-actual"), egt_start, egt_lightup_time);
eng_one_egt_check.start();
eng_one_n2_check.start();
}
});
var eng_one_man_start = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[0].getValue() >= 16.7) {
2019-10-14 16:48:35 +00:00
eng_one_man_start.stop();
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[0]/state", 2);
setprop("/controls/engines/engine[0]/cutoff", 0);
setprop("/controls/engines/engine[0]/igniter-a", 1);
setprop("/controls/engines/engine[0]/igniter-b", 1);
2019-10-14 16:48:35 +00:00
interpolate(engines[0].getNode("egt-actual"), egt_start, egt_lightup_time);
eng_one_egt_check.start();
eng_one_n2_check.start();
}
});
var eng_one_egt_check = maketimer(0.5, func {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[0]/egt-actual") >= egt_start) {
2019-10-14 16:48:35 +00:00
eng_one_egt_check.stop();
interpolate(engines[0].getNode("egt-actual"), egt_min, egt_lightdn_time);
}
});
var eng_one_n2_check = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[0].getValue() >= 43.0) {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[0]/igniter-a") != 0) {
setprop("/controls/engines/engine[0]/igniter-a", 0);
2019-10-14 16:48:35 +00:00
}
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[0]/igniter-b") != 0) {
setprop("/controls/engines/engine[0]/igniter-b", 0);
2019-10-14 16:48:35 +00:00
}
}
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[0].getValue() >= 57.0) {
2019-10-14 16:48:35 +00:00
eng_one_n2_check.stop();
2020-05-12 20:47:05 +00:00
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
setprop("/engines/engine[0]/state", 3);
2019-10-14 16:48:35 +00:00
}
});
# Start Engine Two
var auto_start_two = func {
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/state", 1);
setprop("/controls/engines/engine[1]/starter", 1);
2019-10-14 16:48:35 +00:00
eng_two_auto_start.start();
}
var eng_two_auto_start = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n1Actual[1].getValue() >= 4.7) {
2019-10-14 16:48:35 +00:00
eng_two_auto_start.stop();
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/state", 2);
setprop("/controls/engines/engine[1]/cutoff", 0);
if (getprop("/controls/engines/engine[1]/last-igniter") == "B") {
setprop("/controls/engines/engine[1]/igniter-a", 1);
setprop("/controls/engines/engine[1]/igniter-b", 0);
setprop("/controls/engines/engine[1]/last-igniter", "A");
} else if (getprop("/controls/engines/engine[1]/last-igniter") == "A") {
setprop("/controls/engines/engine[1]/igniter-a", 0);
setprop("/controls/engines/engine[1]/igniter-b", 1);
setprop("/controls/engines/engine[1]/last-igniter", "B");
2019-10-14 16:48:35 +00:00
}
interpolate(engines[1].getNode("egt-actual"), egt_start, egt_lightup_time);
eng_two_egt_check.start();
eng_two_n2_check.start();
}
});
var eng_two_man_start = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[1].getValue() >= 16.7) {
2019-10-14 16:48:35 +00:00
eng_two_man_start.stop();
2020-05-12 20:47:05 +00:00
setprop("/engines/engine[1]/state", 2);
setprop("/controls/engines/engine[1]/cutoff", 0);
setprop("/controls/engines/engine[1]/igniter-a", 1);
setprop("/controls/engines/engine[1]/igniter-b", 1);
2019-10-14 16:48:35 +00:00
interpolate(engines[1].getNode("egt-actual"), egt_start, egt_lightup_time);
eng_two_egt_check.start();
eng_two_n2_check.start();
}
});
var eng_two_egt_check = maketimer(0.5, func {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[1]/egt-actual") >= egt_start) {
2019-10-14 16:48:35 +00:00
eng_two_egt_check.stop();
interpolate(engines[1].getNode("egt-actual"), egt_min, egt_lightdn_time);
}
});
var eng_two_n2_check = maketimer(0.5, func {
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[1].getValue() >= 43.0) {
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[1]/igniter-a") != 0) {
setprop("/controls/engines/engine[1]/igniter-a", 0);
2019-10-14 16:48:35 +00:00
}
2020-05-12 20:47:05 +00:00
if (getprop("/controls/engines/engine[1]/igniter-b") != 0) {
setprop("/controls/engines/engine[1]/igniter-b", 0);
2019-10-14 16:48:35 +00:00
}
}
2020-10-03 09:59:43 +00:00
if (pts.Engines.Engine.n2Actual[1].getValue() >= 57.0) {
2019-10-14 16:48:35 +00:00
eng_two_n2_check.stop();
2020-05-12 20:47:05 +00:00
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
setprop("/engines/engine[1]/state", 3);
2019-10-14 16:48:35 +00:00
}
});
# Various Other Stuff
setlistener("/controls/engines/engine-start-switch", func {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[0]/state") == 0) {
2019-10-14 16:48:35 +00:00
start_one_check();
start_one_mancheck();
}
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[1]/state") == 0) {
2019-10-14 16:48:35 +00:00
start_two_check();
start_two_mancheck();
}
2020-05-12 20:47:05 +00:00
if ((getprop("/controls/engines/engine-start-switch") == 0) or (getprop("/controls/engines/engine-start-switch") == 1)) {
if (getprop("/engines/engine[0]/state") == 1 or getprop("/engines/engine[0]/state") == 2) {
setprop("/controls/engines/engine[0]/starter", 0);
setprop("/controls/engines/engine[0]/cutoff", 1);
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
setprop("/engines/engine[0]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[0].getNode("egt-actual"), 0, egt_shutdown_time);
}
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[1]/state") == 1 or getprop("/engines/engine[1]/state") == 2) {
setprop("/controls/engines/engine[1]/starter", 0);
setprop("/controls/engines/engine[1]/cutoff", 1);
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
setprop("/engines/engine[1]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[1].getNode("egt-actual"), 0, egt_shutdown_time);
}
}
});
2020-05-12 20:47:05 +00:00
setlistener("/systems/pneumatics/psi/engine-1-psi", func {
2020-05-12 21:03:29 +00:00
if (systems.PNEU.Psi.engine1.getValue() < 24.5) {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[0]/state") == 1 or getprop("/engines/engine[0]/state") == 2) {
setprop("/controls/engines/engine[0]/starter", 0);
setprop("/controls/engines/engine[0]/cutoff", 1);
setprop("/systems/pneumatics/valves/starter-valve-1", 0);
setprop("/engines/engine[0]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[0].getNode("egt-actual"), 0, egt_shutdown_time);
}
2020-05-12 20:47:05 +00:00
}
}, 0, 0);
setlistener("/systems/pneumatics/psi/engine-2-psi", func {
2020-05-12 21:03:29 +00:00
if (systems.PNEU.Psi.engine2.getValue() < 24.5) {
2020-05-12 20:47:05 +00:00
if (getprop("/engines/engine[1]/state") == 1 or getprop("/engines/engine[1]/state") == 2) {
setprop("/controls/engines/engine[1]/starter", 0);
setprop("/controls/engines/engine[1]/cutoff", 1);
setprop("/systems/pneumatics/valves/starter-valve-2", 0);
setprop("/engines/engine[1]/state", 0);
2019-10-14 16:48:35 +00:00
interpolate(engines[1].getNode("egt-actual"), 0, egt_shutdown_time);
}
}
2020-07-25 20:04:38 +00:00
}, 0, 0);
setlistener("/engines/engine[0]/state", func() {
setprop("/sim/sound/shutdown[0]", getprop("/engines/engine[0]/state"));
}, 0, 0);
setlistener("/engines/engine[1]/state", func() {
setprop("/sim/sound/shutdown[1]", getprop("/engines/engine[1]/state"));
2020-05-12 20:47:05 +00:00
}, 0, 0);