Note
Go to the end to download the full example code.
Aircraft Trajectory Calculation
Example of BADA3 and BADA4 trajectory using TCL
acName model engineType ... Hd_turbo CPSFC P
0 Dummy-TWIN Dummy-TWIN JET ... NaN NaN NaN
1 Dummy-TBP Dummy-TBP TURBOPROP ... NaN NaN NaN
2 Dummy-TWIN-plus Dummy-TWIN-plus JET ... NaN NaN NaN
3 Dummy-PST Dummy-PST PISTON ... 0.0 3.5521 300.0
[4 rows x 65 columns]
Hp TAS ... ROT comment
0 318.000000 131.894226 ... 0.0 Climb_const_CAS_MCMB
1 1000.000000 133.206507 ... 0.0 Climb_const_CAS_MCMB
2 1499.000000 134.178652 ... 0.0 Climb_const_CAS_MCMB
3 1499.000000 134.178652 ... 0.0 Climb_acc_CAS
4 1525.790112 139.340234 ... 0.0 Climb_acc_CAS
.. ... ... ... ... ...
190 1000.000000 128.449564 ... 0.0 Descent_dec_CAS_slopetarget
191 965.471118 123.315978 ... 0.0 Descent_dec_CAS_slopetarget
192 965.237411 123.279755 ... 0.0 Descent_dec_CAS_slopetarget
193 965.237411 123.279755 ... 0.0 Descent_const_Slope_CAS
194 318.000000 122.124993 ... 0.0 Descent_const_Slope_CAS
[195 rows x 22 columns]
from dataclasses import dataclass
import matplotlib.pyplot as plt
from pyBADA import atmosphere as atm
from pyBADA import conversions as conv
from pyBADA import TCL as TCL
from pyBADA.flightTrajectory import FlightTrajectory as FT
from pyBADA.bada3 import Bada3Aircraft
from pyBADA.bada4 import Bada4Aircraft
from pyBADA.bada4 import Parser as Bada4Parser
from pyBADA.bada3 import Parser as Bada3Parser
@dataclass
class target:
ROCDtarget: float = None
slopetarget: float = None
acctarget: float = None
ESFtarget: float = None
# initialization of BADA3/4
# uncomment for testing different BADA family if available
badaVersion = "DUMMY"
# allData = Bada3Parser.parseAll(badaVersion=badaVersion)
allData = Bada4Parser.parseAll(badaVersion=badaVersion)
print(allData)
AC = Bada3Aircraft(badaVersion=badaVersion, acName="J2H", allData=allData)
AC = Bada4Aircraft(
badaVersion=badaVersion,
acName="Dummy-TWIN",
allData=allData,
)
# Example loading models from files on disk
# AC = Bada4Aircraft(
# badaVersion=badaVersion,
# acName="A320-232",
# filePath="/home/<USER>/ec/pybada-models/models/BADA4/4.3",
# )
# create a Flight Trajectory object to store the output from TCL segment calculations
ft = FT()
# default parameters
speedType = "CAS" # {M, CAS, TAS}
wS = 0 # [kt] wind speed
ba = 0 # [deg] bank angle
DeltaTemp = 0 # [K] delta temperature from ISA
# Initial conditions
m_init = AC.OEW + 0.7 * (AC.MTOW - AC.OEW) # [kg] initial mass
CAS_init = 170 # [kt] Initial CAS
Hp_RWY = 318.0 # [ft] CDG RWY26R elevation
# take-off conditions
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(Hp_RWY), DeltaTemp=DeltaTemp
) # atmosphere properties at RWY altitude
[cas_cl1, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(Hp_RWY),
mass=m_init,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
) # [m/s] take-off CAS
Hp_CR = 33000 # [ft] CRUISing level
# BADA speed schedule
[Vcl1, Vcl2, Mcl] = AC.flightEnvelope.getSpeedSchedule(
phase="Climb"
) # BADA Climb speed schedule
[Vcr1, Vcr2, Mcr] = AC.flightEnvelope.getSpeedSchedule(
phase="Cruise"
) # BADA Cruise speed schedule
[Vdes1, Vdes2, Mdes] = AC.flightEnvelope.getSpeedSchedule(
phase="Descent"
) # BADA Descent speed schedule
# ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
# CLIMB to threshold altitude 1500ft at take-off speed
# ------------------------------------------------
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=conv.ms2kt(cas_cl1),
Hp_init=Hp_RWY,
Hp_final=1499,
m_init=m_init,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for below 3000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(2999), DeltaTemp=DeltaTemp
)
[cas_cl2, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(2999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas_cl2),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to threshold altitude 3000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=2999,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for below 4000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(3999), DeltaTemp=DeltaTemp
)
[cas_cl3, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(3999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas_cl3),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to threshold altitude 4000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=3999,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for below 5000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(4999), DeltaTemp=DeltaTemp
)
[cas_cl4, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(4999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas_cl4),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to threshold altitude 5000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=4999,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for below 6000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(5999), DeltaTemp=DeltaTemp
)
[cas_cl5, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(5999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas_cl5),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to threshold altitude 6000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=5999,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for below 10000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(9999), DeltaTemp=DeltaTemp
)
[cas_cl6, speedUpdated] = AC.ARPM.climbSpeed(
h=conv.ft2m(9999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas_cl6),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to threshold altitude 10000ft
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=9999,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# accelerate according to BADA ARPM for above 10000ft and below crossover altitude
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(Vcl2),
Hp_init=Hp,
control=None,
phase="Climb",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CLIMB to crossover altitude
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# calculate the crosover altitude for climb phase
crossoverAltitude = conv.m2ft(atm.crossOver(Vcl2, Mcl))
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=crossoverAltitude,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# climb at M from crossover altitude
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="M",
v=Mcl,
Hp_init=Hp,
Hp_final=Hp_CR,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# if not at CR speed -> adapt the speed first (acc/dec)
# ------------------------------------------------
# current values
Hp, m_final, M_final = ft.getFinalValue(AC, ["Hp", "mass", "M"])
if M_final < Mcr:
control = target(acctarget=0.5)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="M",
v_init=M_final,
v_final=Mcr,
Hp_init=Hp,
control=control,
phase="Cruise",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CRUISE for 200 NM
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedLevel(
AC=AC,
lengthType="distance",
length=200,
speedType="M",
v=Mcr,
Hp_init=Hp,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# CRUISE Step for 300 NM
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedLevel(
AC=AC,
lengthType="distance",
length=200,
step_length=50,
maxRFL=36000,
speedType="M",
v=Mcr,
Hp_init=Hp,
m_init=m_final,
stepClimb=True,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# acc/dec to DESCENT speed during the descend
# ------------------------------------------------
# current values
Hp, m_final, M_final = ft.getFinalValue(AC, ["Hp", "mass", "M"])
flightTrajectory = TCL.accDec(
AC=AC,
speedType="M",
v_init=M_final,
v_final=Mdes,
Hp_init=Hp,
phase="Descent",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend to crossover altitude
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
# calculate the crosover altitude for descend phase
crossoverAltitude = conv.m2ft(atm.crossOver(Vdes2, Mdes))
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="M",
v=Mdes,
Hp_init=Hp,
Hp_final=crossoverAltitude,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend to FL100
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=conv.ms2kt(Vdes2),
Hp_init=Hp,
Hp_final=10000,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# decelerate according to BADA ARPM for below FL100
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(9999), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(9999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
phase="Descent",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend to 6000ft
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=conv.ms2kt(cas),
Hp_init=Hp,
Hp_final=6000,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# decelerate according to BADA ARPM for below 6000
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(5999), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(5999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
phase="Descent",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend to 5000ft
# ------------------------------------------------
# current values
Hp, m_final = ft.getFinalValue(AC, ["Hp", "mass"])
flightTrajectory = TCL.constantSpeedRating(
AC=AC,
speedType="CAS",
v=conv.ms2kt(cas),
Hp_init=Hp,
Hp_final=5000,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope to next altitude threshold
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
if AC.BADAFamily.BADA3:
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=3700,
slopetarget=-3.0,
config="AP",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
elif AC.BADAFamily.BADA4:
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=3000,
slopetarget=-3.0,
config=None,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope while decelerating
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(2999), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(2999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
control = target(slopetarget=-3.0)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config="AP",
speedBrakes={"deployed": True, "value": 0.03},
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope to next altitude threshold
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
if Hp > 2000:
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=2000,
slopetarget=-3.0,
config=None,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope while decelerating
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(1999), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(1999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
control = target(slopetarget=-3.0)
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config="LD",
speedBrakes={"deployed": True, "value": 0.03},
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope to next altitude threshold
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
if Hp > 1500:
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=1500,
slopetarget=-3.0,
config="LD",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope while decelerating
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(1499), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(1499),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
control = target(slopetarget=-3.0)
if AC.BADAFamily.BADA3:
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config="LD",
speedBrakes={"deployed": True, "value": 0.03},
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
elif AC.BADAFamily.BADA4:
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config="LD",
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope to next altitude threshold
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
if Hp > 1000:
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=1000,
slopetarget=-3.0,
config=None,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope while decelerating
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
# get BADA target speed from BADA ARPM procedure for the altitude bracket below
[theta, delta, sigma] = atm.atmosphereProperties(
h=conv.ft2m(999), DeltaTemp=DeltaTemp
)
[cas, speedUpdated] = AC.ARPM.descentSpeed(
h=conv.ft2m(999),
mass=m_final,
theta=theta,
delta=delta,
DeltaTemp=DeltaTemp,
)
control = target(slopetarget=-3.0)
if AC.BADAFamily.BADA3:
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config=None,
speedBrakes={"deployed": True, "value": 0.03},
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
elif AC.BADAFamily.BADA4:
flightTrajectory = TCL.accDec(
AC=AC,
speedType="CAS",
v_init=CAS_final,
v_final=conv.ms2kt(cas),
Hp_init=Hp,
control=control,
phase="Descent",
config=None,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# descend on ILS with 3deg glideslope to next altitude threshold
# ------------------------------------------------
# current values
Hp, m_final, CAS_final = ft.getFinalValue(AC, ["Hp", "mass", "CAS"])
flightTrajectory = TCL.constantSpeedSlope(
AC=AC,
speedType="CAS",
v=CAS_final,
Hp_init=Hp,
Hp_final=Hp_RWY,
slopetarget=-3.0,
config=None,
m_init=m_final,
wS=wS,
bankAngle=ba,
DeltaTemp=DeltaTemp,
)
ft.append(AC, flightTrajectory)
# print and plot final trajectory
df = ft.getFT(AC=AC)
print(df)
# Plotting the graph Hp=f(dist)
plt.figure(1, figsize=(8, 6))
plt.plot(df["dist"], df["Hp"], linestyle="-", color="b")
plt.grid(True)
plt.xlabel("Distance [NM]")
plt.ylabel("Pressure Altitude [ft]")
plt.title("Pressure Altitude as a Function of Distance")
# Plot for Calibrated Airspeed (CAS)
plt.figure(2, figsize=(8, 6))
plt.plot(df["dist"], df["CAS"], linestyle="-", color="r")
plt.grid(True)
plt.xlabel("Distance [NM]")
plt.ylabel("CAS [kt]")
plt.title("Calibrated Airspeed (CAS) as a Function of Distance")
# Display the plot
plt.show()
# save the output to a CSV/XLSX file
# ------------------------------------------------
# ft.save2csv(os.path.join(grandParentDir, "flightTrajectory_export"), separator=",")
# ft.save2xlsx(os.path.join(grandParentDir, "flightTrajectory_export"))
Total running time of the script: (0 minutes 0.894 seconds)