Alex fixes everything, re‑runs the full envelope: stalls, spins, engine‑out, crosswind landing. All pass.
import jsbsim fdm = jsbsim.FGFDMExec() fdm.load_model('x1') fdm['propulsion/engine[0]/running'] = 1 fdm['fcs/throttle-cmd-norm'] = 1.0 for t in range(1000): fdm.Run() if t == 200: fdm['fcs/elevator-cmd-norm'] = -0.3 # pitch up print(fdm['position/h-sl-ft'], fdm['attitude/theta-deg']) jsbsim tutorial
jsbsim --script=scripts/x1_test.xml The script: set prop/engine[0]/running 1 , set fcs/throttle-cmd-norm 0.7 , run 30 . Alex fixes everything, re‑runs the full envelope: stalls,