mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-08 17:08:28 -04:00
autotest: Add test for soaring speed-to-fly feature
This commit is contained in:
parent
719aa4bc53
commit
75ee4b07fe
9
Tools/autotest/ArduPlane_Tests/SpeedToFly/CMAC-soar.txt
Normal file
9
Tools/autotest/ArduPlane_Tests/SpeedToFly/CMAC-soar.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
QGC WPL 110
|
||||||
|
0 1 0 16 0.000000 0.000000 0.000000 0.000000 -35.362938 149.165085 584.409973 1
|
||||||
|
1 0 3 22 15.000000 0.000000 0.000000 0.000000 -35.361164 149.163986 28.110001 1
|
||||||
|
2 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.359467 149.161697 400.000000 1
|
||||||
|
3 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.366333 149.162659 400.000000 1
|
||||||
|
4 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.366131 149.164581 400.000000 1
|
||||||
|
5 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.359272 149.163757 400.000000 1
|
||||||
|
6 0 3 177 2.000000 -1.000000 0.000000 0.000000 0.000000 0.000000 0.000000 1
|
||||||
|
7 0 3 16 0.000000 0.000000 0.000000 0.000000 -35.359272 149.163757 400.000000 1
|
@ -2246,6 +2246,103 @@ function'''
|
|||||||
|
|
||||||
self.progress("Mission OK")
|
self.progress("Mission OK")
|
||||||
|
|
||||||
|
def fly_soaring_speed_to_fly(self):
|
||||||
|
|
||||||
|
model = "plane-soaring"
|
||||||
|
|
||||||
|
self.customise_SITL_commandline(
|
||||||
|
[],
|
||||||
|
model=model,
|
||||||
|
defaults_filepath=self.model_defaults_filepath(model),
|
||||||
|
wipe=True)
|
||||||
|
|
||||||
|
self.load_mission('CMAC-soar.txt', strict=False)
|
||||||
|
|
||||||
|
# Turn of environmental thermals.
|
||||||
|
self.set_parameter("SIM_THML_SCENARI", 0)
|
||||||
|
|
||||||
|
# Get thermalling RC channel
|
||||||
|
rc_chan = 0
|
||||||
|
for i in range(8):
|
||||||
|
rcx_option = self.get_parameter('RC{0}_OPTION'.format(i+1))
|
||||||
|
if rcx_option == 88:
|
||||||
|
rc_chan = i+1
|
||||||
|
break
|
||||||
|
|
||||||
|
if rc_chan == 0:
|
||||||
|
raise NotAchievedException("Did not find soaring enable channel option.")
|
||||||
|
|
||||||
|
# Disable soaring
|
||||||
|
self.set_rc(rc_chan, 1100)
|
||||||
|
|
||||||
|
self.set_current_waypoint(1)
|
||||||
|
self.change_mode('AUTO')
|
||||||
|
self.wait_ready_to_arm()
|
||||||
|
self.arm_vehicle()
|
||||||
|
|
||||||
|
# Wait for to 400m before starting.
|
||||||
|
self.wait_altitude(390, 400, timeout=600, relative=True)
|
||||||
|
|
||||||
|
# Wait 10s to stabilize.
|
||||||
|
self.delay_sim_time(30)
|
||||||
|
|
||||||
|
# Enable soaring (no automatic thermalling)
|
||||||
|
self.set_rc(rc_chan, 1500)
|
||||||
|
|
||||||
|
# Enable speed to fly.
|
||||||
|
self.set_parameter("SOAR_CRSE_ARSPD", -1)
|
||||||
|
|
||||||
|
# Set appropriate McCready.
|
||||||
|
self.set_parameter("SOAR_VSPEED", 1)
|
||||||
|
self.set_parameter("SIM_WIND_SPD", 0)
|
||||||
|
|
||||||
|
# Wait a few seconds before determining the "trim" airspeed.
|
||||||
|
self.delay_sim_time(20)
|
||||||
|
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
trim_airspeed = m.airspeed
|
||||||
|
|
||||||
|
min_airspeed = self.get_parameter("ARSPD_FBW_MIN")
|
||||||
|
max_airspeed = self.get_parameter("ARSPD_FBW_MAX")
|
||||||
|
|
||||||
|
# Add updraft
|
||||||
|
self.set_parameter("SIM_WIND_SPD", 1)
|
||||||
|
self.set_parameter('SIM_WIND_DIR_Z', 90)
|
||||||
|
self.delay_sim_time(20)
|
||||||
|
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
|
||||||
|
if not m.airspeed < trim_airspeed and trim_airspeed > min_airspeed:
|
||||||
|
raise NotAchievedException("Airspeed did not reduce in updraft")
|
||||||
|
|
||||||
|
# Add downdraft
|
||||||
|
self.set_parameter('SIM_WIND_DIR_Z', -90)
|
||||||
|
self.delay_sim_time(20)
|
||||||
|
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
|
||||||
|
if not m.airspeed > trim_airspeed and trim_airspeed < max_airspeed:
|
||||||
|
raise NotAchievedException("Airspeed did not increase in downdraft")
|
||||||
|
|
||||||
|
# Zero the wind and increase McCready.
|
||||||
|
self.set_parameter("SIM_WIND_SPD", 0)
|
||||||
|
self.set_parameter("SOAR_VSPEED", 2)
|
||||||
|
self.delay_sim_time(20)
|
||||||
|
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
|
||||||
|
if not m.airspeed > trim_airspeed and trim_airspeed < max_airspeed:
|
||||||
|
raise NotAchievedException("Airspeed did not increase with higher SOAR_VSPEED")
|
||||||
|
|
||||||
|
# Reduce McCready.
|
||||||
|
self.set_parameter("SOAR_VSPEED", 0)
|
||||||
|
self.delay_sim_time(20)
|
||||||
|
m = self.mav.recv_match(type='VFR_HUD', blocking=True)
|
||||||
|
|
||||||
|
if not m.airspeed < trim_airspeed and trim_airspeed > min_airspeed:
|
||||||
|
raise NotAchievedException("Airspeed did not reduce with lower SOAR_VSPEED")
|
||||||
|
|
||||||
|
# Disarm
|
||||||
|
self.disarm_vehicle()
|
||||||
|
|
||||||
|
self.progress("Mission OK")
|
||||||
|
|
||||||
def test_airspeed_drivers(self):
|
def test_airspeed_drivers(self):
|
||||||
airspeed_sensors = [
|
airspeed_sensors = [
|
||||||
("MS5525", 3, 1),
|
("MS5525", 3, 1),
|
||||||
@ -3500,6 +3597,10 @@ function'''
|
|||||||
"Test MSP DJI serial output",
|
"Test MSP DJI serial output",
|
||||||
self.test_msp_dji),
|
self.test_msp_dji),
|
||||||
|
|
||||||
|
("SpeedToFly",
|
||||||
|
"Test soaring speed-to-fly",
|
||||||
|
self.fly_soaring_speed_to_fly),
|
||||||
|
|
||||||
("LogUpload",
|
("LogUpload",
|
||||||
"Log upload",
|
"Log upload",
|
||||||
self.log_upload),
|
self.log_upload),
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
ARSPD_FBW_MAX 20
|
ARSPD_FBW_MAX 20
|
||||||
ARSPD_FBW_MIN 6
|
ARSPD_FBW_MIN 8
|
||||||
|
|
||||||
FLIGHT_OPTIONS 2
|
FLIGHT_OPTIONS 2
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user