1
0
Fork 0

Fix bugs with approach, protection bars fully work, go-around still buggy

This commit is contained in:
Matthew Maring 2020-04-12 13:37:15 -04:00
parent b163a833cf
commit 30497a8cf2
4 changed files with 5512 additions and 5479 deletions

View file

@ -1687,9 +1687,9 @@ var canvas_MCDU_base = {
} else { } else {
me["Simple_L1"].setText("SELECTED"); me["Simple_L1"].setText("SELECTED");
if (getprop("it-autoflight/input/kts-mach")) { if (getprop("it-autoflight/input/kts-mach")) {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
} else { } else {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
} }
me.fontLeft(0, 0, 0, default, 0, 0); me.fontLeft(0, 0, 0, default, 0, 0);
} }
@ -1830,9 +1830,9 @@ var canvas_MCDU_base = {
} else { } else {
me["Simple_L1"].setText("SELECTED"); me["Simple_L1"].setText("SELECTED");
if (getprop("it-autoflight/input/kts-mach")) { if (getprop("it-autoflight/input/kts-mach")) {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
} else { } else {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
} }
me.fontLeft(0, 0, 0, default, 0, 0); me.fontLeft(0, 0, 0, default, 0, 0);
} }
@ -1980,9 +1980,9 @@ var canvas_MCDU_base = {
} else { } else {
me["Simple_L1"].setText("SELECTED"); me["Simple_L1"].setText("SELECTED");
if (getprop("it-autoflight/input/kts-mach")) { if (getprop("it-autoflight/input/kts-mach")) {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-mach")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-mach"))));
} else { } else {
me["Simple_L4"].setText(sprintf(" %3.0f", num(getprop("it-autoflight/input/spd-kts")))); me["Simple_L4"].setText(sprintf(" %d", int(getprop("it-autoflight/input/spd-kts"))));
} }
me.fontLeft(0, 0, 0, default, 0, 0); me.fontLeft(0, 0, 0, default, 0, 0);
} }

View file

@ -215,7 +215,7 @@ var canvas_PFD_base = {
getKeys: func() { getKeys: func() {
return ["FMA_man","FMA_manmode","FMA_flxmode","FMA_flxtemp","FMA_thrust","FMA_lvrclb","FMA_pitch","FMA_pitcharm","FMA_pitcharm2","FMA_roll","FMA_rollarm","FMA_combined","FMA_ctr_msg","FMA_catmode","FMA_cattype","FMA_nodh","FMA_dh","FMA_dhn","FMA_ap","FMA_fd","FMA_athr", return ["FMA_man","FMA_manmode","FMA_flxmode","FMA_flxtemp","FMA_thrust","FMA_lvrclb","FMA_pitch","FMA_pitcharm","FMA_pitcharm2","FMA_roll","FMA_rollarm","FMA_combined","FMA_ctr_msg","FMA_catmode","FMA_cattype","FMA_nodh","FMA_dh","FMA_dhn","FMA_ap","FMA_fd","FMA_athr",
"FMA_man_box","FMA_flx_box","FMA_thrust_box","FMA_pitch_box","FMA_pitcharm_box","FMA_roll_box","FMA_rollarm_box","FMA_combined_box","FMA_catmode_box","FMA_cattype_box","FMA_cat_box","FMA_dh_box","FMA_ap_box","FMA_fd_box","FMA_athr_box","FMA_Middle1", "FMA_man_box","FMA_flx_box","FMA_thrust_box","FMA_pitch_box","FMA_pitcharm_box","FMA_roll_box","FMA_rollarm_box","FMA_combined_box","FMA_catmode_box","FMA_cattype_box","FMA_cat_box","FMA_dh_box","FMA_ap_box","FMA_fd_box","FMA_athr_box","FMA_Middle1",
"FMA_Middle2","ALPHA_MAX","ALPHA_PROT","ALPHA_SW","VLS_min","ASI_max","ASI_scale","ASI_target","ASI_mach","ASI_mach_decimal","ASI_trend_up","ASI_trend_down","ASI_digit_UP","ASI_digit_DN","ASI_decimal_UP","ASI_decimal_DN","ASI_index","ASI_error","ASI_group","ASI_frame","AI_center","AI_bank", "FMA_Middle2","ALPHA_MAX","ALPHA_PROT","ALPHA_SW","ALPHA_clip","VLS_min","ASI_max","ASI_scale","ASI_target","ASI_mach","ASI_mach_decimal","ASI_trend_up","ASI_trend_down","ASI_digit_UP","ASI_digit_DN","ASI_decimal_UP","ASI_decimal_DN","ASI_index","ASI_error","ASI_group","ASI_frame","AI_center","AI_bank",
"AI_bank_lim","AI_bank_lim_X","AI_pitch_lim","AI_pitch_lim_X","AI_slipskid","AI_horizon","AI_horizon_ground","AI_horizon_sky","AI_stick","AI_stick_pos","AI_heading","AI_agl_g","AI_agl","AI_error","AI_group","FD_roll","FD_pitch","ALT_box_flash","ALT_box","ALT_box_amber", "AI_bank_lim","AI_bank_lim_X","AI_pitch_lim","AI_pitch_lim_X","AI_slipskid","AI_horizon","AI_horizon_ground","AI_horizon_sky","AI_stick","AI_stick_pos","AI_heading","AI_agl_g","AI_agl","AI_error","AI_group","FD_roll","FD_pitch","ALT_box_flash","ALT_box","ALT_box_amber",
"ALT_scale","ALT_target","ALT_target_digit","ALT_one","ALT_two","ALT_three","ALT_four","ALT_five","ALT_digits","ALT_tens","ALT_digit_UP","ALT_digit_DN","ALT_error","ALT_group","ALT_group2","ALT_frame","VS_pointer","VS_box","VS_digit","VS_error","VS_group","QNH","QNH_setting", "ALT_scale","ALT_target","ALT_target_digit","ALT_one","ALT_two","ALT_three","ALT_four","ALT_five","ALT_digits","ALT_tens","ALT_digit_UP","ALT_digit_DN","ALT_error","ALT_group","ALT_group2","ALT_frame","VS_pointer","VS_box","VS_digit","VS_error","VS_group","QNH","QNH_setting",
"QNH_std","QNH_box","LOC_pointer","LOC_scale","GS_scale","GS_pointer","CRS_pointer","HDG_target","HDG_scale","HDG_one","HDG_two","HDG_three","HDG_four","HDG_five","HDG_six","HDG_seven","HDG_digit_L","HDG_digit_R","HDG_error","HDG_group","HDG_frame", "QNH_std","QNH_box","LOC_pointer","LOC_scale","GS_scale","GS_pointer","CRS_pointer","HDG_target","HDG_scale","HDG_one","HDG_two","HDG_three","HDG_four","HDG_five","HDG_six","HDG_seven","HDG_digit_L","HDG_digit_R","HDG_error","HDG_group","HDG_frame",
@ -1106,6 +1106,10 @@ var canvas_PFD_1 = {
me["ASI_error"].hide(); me["ASI_error"].hide();
me["ASI_frame"].setColor(1,1,1); me["ASI_frame"].setColor(1,1,1);
me["ASI_group"].show(); me["ASI_group"].show();
me["VLS_min"].hide();
me["ALPHA_PROT"].hide();
me["ALPHA_MAX"].hide();
me["ALPHA_SW"].hide();
if (ind_spd <= 30) { if (ind_spd <= 30) {
me.ASI = 0; me.ASI = 0;
@ -1136,7 +1140,7 @@ var canvas_PFD_1 = {
} else { } else {
me.VLSmin = me.FMGC_vls - 30 - me.ASI; me.VLSmin = me.FMGC_vls - 30 - me.ASI;
} }
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/vls_min") * 0.95; me.FMGC_prot = getprop("FMGC/internal/computed-speeds/alpha_prot");
if (me.FMGC_prot <= 30) { if (me.FMGC_prot <= 30) {
me.ALPHAprot = 0 - me.ASI; me.ALPHAprot = 0 - me.ASI;
} else if (me.FMGC_prot >= 420) { } else if (me.FMGC_prot >= 420) {
@ -1144,7 +1148,7 @@ var canvas_PFD_1 = {
} else { } else {
me.ALPHAprot = me.FMGC_prot - 30 - me.ASI; me.ALPHAprot = me.FMGC_prot - 30 - me.ASI;
} }
me.FMGC_max = getprop("FMGC/internal/computed-speeds/vls_min") * 0.90; me.FMGC_max = getprop("FMGC/internal/computed-speeds/alpha_max");
if (me.FMGC_max <= 30) { if (me.FMGC_max <= 30) {
me.ALPHAmax = 0 - me.ASI; me.ALPHAmax = 0 - me.ASI;
} else if (me.FMGC_max >= 420) { } else if (me.FMGC_max >= 420) {
@ -1154,8 +1158,8 @@ var canvas_PFD_1 = {
} }
me["VLS_min"].setTranslation(0, me.VLSmin * -6.6); me["VLS_min"].setTranslation(0, me.VLSmin * -6.6);
me["VLS_min"].show(); me["VLS_min"].show();
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6); #CHANGE LATER me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6);
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6); #CHANGE LATER me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6);
if (getprop("it-fbw/law") == 0) { if (getprop("it-fbw/law") == 0) {
me["ALPHA_PROT"].show(); me["ALPHA_PROT"].show();
me["ALPHA_MAX"].show(); me["ALPHA_MAX"].show();
@ -1165,15 +1169,10 @@ var canvas_PFD_1 = {
me["ALPHA_MAX"].hide(); me["ALPHA_MAX"].hide();
me["ALPHA_SW"].show(); me["ALPHA_SW"].show();
} }
} else {
me["VLS_min"].hide();
me["ALPHA_PROT"].hide();
me["ALPHA_MAX"].hide();
me["ALPHA_SW"].hide();
} }
if (managed_spd.getValue() == 1) { if (managed_spd.getValue() == 1) {
if (FMGCphase.getValue() == 5) { if (getprop("FMGC/internal/decel") == 1) {
vapp = getprop("FMGC/internal/computed-speeds/vapp"); vapp = getprop("FMGC/internal/computed-speeds/vapp");
tgt_ias = vapp; tgt_ias = vapp;
tgt_kts = vapp; tgt_kts = vapp;
@ -1809,6 +1808,10 @@ var canvas_PFD_2 = {
me["ASI_error"].hide(); me["ASI_error"].hide();
me["ASI_frame"].setColor(1,1,1); me["ASI_frame"].setColor(1,1,1);
me["ASI_group"].show(); me["ASI_group"].show();
me["VLS_min"].hide();
me["ALPHA_PROT"].hide();
me["ALPHA_MAX"].hide();
me["ALPHA_SW"].hide();
if (ind_spd <= 30) { if (ind_spd <= 30) {
me.ASI = 0; me.ASI = 0;
@ -1839,7 +1842,7 @@ var canvas_PFD_2 = {
} else { } else {
me.VLSmin = me.FMGC_vls - 30 - me.ASI; me.VLSmin = me.FMGC_vls - 30 - me.ASI;
} }
me.FMGC_prot = getprop("FMGC/internal/computed-speeds/vls_min") * 0.95; me.FMGC_prot = getprop("FMGC/internal/computed-speeds/alpha_prot");
if (me.FMGC_prot <= 30) { if (me.FMGC_prot <= 30) {
me.ALPHAprot = 0 - me.ASI; me.ALPHAprot = 0 - me.ASI;
} else if (me.FMGC_prot >= 420) { } else if (me.FMGC_prot >= 420) {
@ -1847,7 +1850,7 @@ var canvas_PFD_2 = {
} else { } else {
me.ALPHAprot = me.FMGC_prot - 30 - me.ASI; me.ALPHAprot = me.FMGC_prot - 30 - me.ASI;
} }
me.FMGC_max = getprop("FMGC/internal/computed-speeds/vls_min") * 0.90; me.FMGC_max = getprop("FMGC/internal/computed-speeds/alpha_max");
if (me.FMGC_max <= 30) { if (me.FMGC_max <= 30) {
me.ALPHAmax = 0 - me.ASI; me.ALPHAmax = 0 - me.ASI;
} else if (me.FMGC_max >= 420) { } else if (me.FMGC_max >= 420) {
@ -1857,8 +1860,8 @@ var canvas_PFD_2 = {
} }
me["VLS_min"].setTranslation(0, me.VLSmin * -6.6); me["VLS_min"].setTranslation(0, me.VLSmin * -6.6);
me["VLS_min"].show(); me["VLS_min"].show();
me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6); #CHANGE LATER me["ALPHA_PROT"].setTranslation(0, me.ALPHAprot * -6.6);
me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6); #CHANGE LATER me["ALPHA_MAX"].setTranslation(0, me.ALPHAmax * -6.6);
if (getprop("it-fbw/law") == 0) { if (getprop("it-fbw/law") == 0) {
me["ALPHA_PROT"].show(); me["ALPHA_PROT"].show();
me["ALPHA_MAX"].show(); me["ALPHA_MAX"].show();
@ -1868,15 +1871,10 @@ var canvas_PFD_2 = {
me["ALPHA_MAX"].hide(); me["ALPHA_MAX"].hide();
me["ALPHA_SW"].show(); me["ALPHA_SW"].show();
} }
} else {
me["VLS_min"].hide();
me["ALPHA_PROT"].hide();
me["ALPHA_MAX"].hide();
me["ALPHA_SW"].hide();
} }
if (managed_spd.getValue() == 1) { if (managed_spd.getValue() == 1) {
if (FMGCphase.getValue() == 5) { if (getprop("FMGC/internal/decel") == 1) {
vapp = getprop("FMGC/internal/computed-speeds/vapp"); vapp = getprop("FMGC/internal/computed-speeds/vapp");
tgt_ias = vapp; tgt_ias = vapp;
tgt_kts = vapp; tgt_kts = vapp;

File diff suppressed because it is too large Load diff

Before

Width:  |  Height:  |  Size: 364 KiB

After

Width:  |  Height:  |  Size: 361 KiB

View file

@ -246,30 +246,32 @@ var masterFMGC = maketimer(0.2, func {
setprop("systems/pressurization/mode", "DE"); setprop("systems/pressurization/mode", "DE");
} }
if (aglalt < 7200 and (phase == "4" or mode == "G/S" or mode == "LAND" or mode == "FLARE")) { if (!wowl and !wowr and aglalt < 7200 and (phase == "4" or mode == "G/S" or mode == "LAND" or mode == "FLARE")) {
setprop("FMGC/status/phase", 5); setprop("FMGC/status/phase", 5);
} }
if (getprop("autopilot/route-manager/route/num") > 0 and getprop("autopilot/route-manager/active") == 1 and getprop("autopilot/route-manager/distance-remaining-nm") <= 15) { if (getprop("autopilot/route-manager/route/num") > 0 and getprop("autopilot/route-manager/active") == 1 and getprop("autopilot/route-manager/distance-remaining-nm") <= 15) {
setprop("FMGC/internal/decel", 1); setprop("FMGC/internal/decel", 1);
setprop("FMGC/status/phase", 5);
} else if (getprop("FMGC/internal/decel") == 1 and (phase == 0 or phase == 6)) { } else if (getprop("FMGC/internal/decel") == 1 and (phase == 0 or phase == 6)) {
setprop("FMGC/internal/decel", 0); setprop("FMGC/internal/decel", 0);
} }
if (phase == "5" and state1 == "TOGA" and state2 == "TOGA") { #handle go-around
if ((phase == "5" or phase == "7") and state1 == "TOGA" and state2 == "TOGA") {
setprop("FMGC/status/phase", 6); setprop("FMGC/status/phase", 6);
# set speed to green dot here
setprop("systems/pressurization/mode", "TO"); setprop("systems/pressurization/mode", "TO");
setprop("it-autoflight/input/toga", 1); setprop("it-autoflight/input/toga", 1);
} }
#handle go-around
if (phase == "6" and alt >= reduc_agl_ft) { if (phase == "6" and alt >= reduc_agl_ft) {
setprop("FMGC/status/phase", 2); setprop("FMGC/status/phase", 2);
} }
if (wowl and wowr and gs <= 40 and (phase == "2" or phase == "3" or phase == "4" or phase == "5" or phase == "6") and ap1 == 0 and ap2 == 0) { if (wowl and wowr and (phase == "2" or phase == "3" or phase == "4" or phase == "5" or phase == "6")) {
setprop("FMGC/status/phase", 7);
}
if (wowl and wowr and gs <= 40 and phase == "7" and ap1 == 0 and ap2 == 0) {
reset_FMGC(); reset_FMGC();
} }
@ -321,6 +323,15 @@ var masterFMGC = maketimer(0.2, func {
} }
} }
aoa_prot = 15;
aoa_max = 17.5;
aoa_0 = -5;
aoa = getprop("systems/navigation/adr/output/aoa-1");
cas = getprop("systems/navigation/adr/output/cas-1");
alpha_prot = cas * math.sqrt((aoa - aoa_0)/(aoa_prot - aoa_0));
alpha_max = cas * math.sqrt((aoa - aoa_0)/(aoa_max - aoa_0));
# predicted to speeds # predicted to speeds
clean_to = 2 * tow * 0.45359237 + 85; clean_to = 2 * tow * 0.45359237 + 85;
if (altitude > 20000) { if (altitude > 20000) {
@ -374,6 +385,8 @@ var masterFMGC = maketimer(0.2, func {
setprop("FMGC/internal/computed-speeds/flap3", flap3); setprop("FMGC/internal/computed-speeds/flap3", flap3);
setprop("FMGC/internal/computed-speeds/vls", vls); setprop("FMGC/internal/computed-speeds/vls", vls);
setprop("FMGC/internal/computed-speeds/vapp", vapp); setprop("FMGC/internal/computed-speeds/vapp", vapp);
setprop("FMGC/internal/computed-speeds/alpha_prot", alpha_prot);
setprop("FMGC/internal/computed-speeds/alpha_max", alpha_max);
setprop("FMGC/internal/computed-speeds/vs1g_clean_to", vs1g_clean_to); setprop("FMGC/internal/computed-speeds/vs1g_clean_to", vs1g_clean_to);
setprop("FMGC/internal/computed-speeds/vs1g_conf_2_to", vs1g_conf_2_to); setprop("FMGC/internal/computed-speeds/vs1g_conf_2_to", vs1g_conf_2_to);
@ -393,6 +406,17 @@ var masterFMGC = maketimer(0.2, func {
setprop("FMGC/internal/computed-speeds/vls_appr", vls_appr); setprop("FMGC/internal/computed-speeds/vls_appr", vls_appr);
setprop("FMGC/internal/computed-speeds/vapp_appr", vapp_appr); setprop("FMGC/internal/computed-speeds/vapp_appr", vapp_appr);
# Need info on these, also correct for height at altitude...
# https://www.pprune.org/archive/index.php/t-587639.html
if (getprop("FMGC/status/to-state") == 1) {
if (flap == 0) { # 0
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.28);
} else if (flap == 1) { # 1
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_1 * 1.23);
} else { # 1+F
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.13);
}
} else {
if (flap == 0) { # 0 if (flap == 0) { # 0
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.23); setprop("FMGC/internal/computed-speeds/vls_min", vs1g_clean * 1.23);
} else if (flap == 1) { # 1 } else if (flap == 1) { # 1
@ -406,6 +430,7 @@ var masterFMGC = maketimer(0.2, func {
} else if (flap == 5) { # FULL } else if (flap == 5) { # FULL
setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_full * 1.23); setprop("FMGC/internal/computed-speeds/vls_min", vs1g_conf_full * 1.23);
} }
}
if (flap == 0) { # 0 if (flap == 0) { # 0
setprop("FMGC/internal/minspeed", clean); setprop("FMGC/internal/minspeed", clean);