mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_Scripting: added airshow
and messages in schedules
This commit is contained in:
parent
41fbbd92bc
commit
40fdb22423
@ -24,7 +24,7 @@ AUTO missions.
|
|||||||
| 3 | Horizontal Rectangle | length | width | radius | bank angle | No |
|
| 3 | Horizontal Rectangle | length | width | radius | bank angle | No |
|
||||||
| 4 | Climbing Circle | radius | height | bank angle | | No |
|
| 4 | Climbing Circle | radius | height | bank angle | | No |
|
||||||
| 5 | vertical Box | length | height | radius | | No |
|
| 5 | vertical Box | length | height | radius | | No |
|
||||||
| 6 | Unused | | | | | No |
|
| 6 | Immelmann (FastRoll) | radius | | | | Yes |
|
||||||
| 7 | Straight Roll | length | num rolls | | | No |
|
| 7 | Straight Roll | length | num rolls | | | No |
|
||||||
| 8 | Rolling Circle | radius | num rolls | | | No |
|
| 8 | Rolling Circle | radius | num rolls | | | No |
|
||||||
| 9 | Half Cuban Eight | radius | | | | Yes |
|
| 9 | Half Cuban Eight | radius | | | | Yes |
|
||||||
@ -54,12 +54,13 @@ The following table gives the available pre-defined schedules. Each schedule has
|
|||||||
an ID number which is used in the AUTO mission or in the TRIKn_ID
|
an ID number which is used in the AUTO mission or in the TRIKn_ID
|
||||||
parameters (described below).
|
parameters (described below).
|
||||||
|
|
||||||
| ID | Name
|
| ID | Name
|
||||||
| -- | ------------------------
|
| -- | ------------------------
|
||||||
| 200 | Test Suite (dont fly!)
|
| 200 | Test Suite (dont fly!)
|
||||||
| 201 | NZ Clubman Schedule
|
| 201 | NZ Clubman Schedule
|
||||||
| 202 | FAI F3A P-23 (left to right)
|
| 202 | FAI F3A P-23 (left to right)
|
||||||
| 203 | FAI F3C Scale Example (left to right)
|
| 203 | FAI F3C Scale Example (left to right)
|
||||||
|
| 204 | AirShow
|
||||||
|
|
||||||
Note: ID's 202-203 are best flown with a mission start point 150m out from the pilot, with the prior and subsequent mission waypoints in a straight line with the model starting teh script flying down wind. ID 201 is best started in teh same manner, but the model positioned 100m out from the pilot.
|
Note: ID's 202-203 are best flown with a mission start point 150m out from the pilot, with the prior and subsequent mission waypoints in a straight line with the model starting teh script flying down wind. ID 201 is best started in teh same manner, but the model positioned 100m out from the pilot.
|
||||||
|
|
||||||
|
@ -32,6 +32,7 @@ ERR_CORR_D = bind_add_param('ERR_COR_D', 13, 2.8)
|
|||||||
AEROM_ENTRY_RATE = bind_add_param('ENTRY_RATE', 14, 60)
|
AEROM_ENTRY_RATE = bind_add_param('ENTRY_RATE', 14, 60)
|
||||||
AEROM_THR_LKAHD = bind_add_param('THR_LKAHD', 15, 1)
|
AEROM_THR_LKAHD = bind_add_param('THR_LKAHD', 15, 1)
|
||||||
AEROM_DEBUG = bind_add_param('DEBUG', 16, 0)
|
AEROM_DEBUG = bind_add_param('DEBUG', 16, 0)
|
||||||
|
ACRO_ROLL_RATE = Parameter("ACRO_ROLL_RATE")
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
Aerobatic tricks on a switch support - allows for tricks to be initiated outside AUTO mode
|
Aerobatic tricks on a switch support - allows for tricks to be initiated outside AUTO mode
|
||||||
@ -570,6 +571,7 @@ function path_composer(_name, _subpaths)
|
|||||||
local highest_i = 0
|
local highest_i = 0
|
||||||
local cache_i = -1
|
local cache_i = -1
|
||||||
local cache_sp = nil
|
local cache_sp = nil
|
||||||
|
local message = nil
|
||||||
|
|
||||||
-- return the subpath with index i. Used to cope with two ways of calling path_composer
|
-- return the subpath with index i. Used to cope with two ways of calling path_composer
|
||||||
function self.subpath(i)
|
function self.subpath(i)
|
||||||
@ -581,10 +583,12 @@ function path_composer(_name, _subpaths)
|
|||||||
if sp.name then
|
if sp.name then
|
||||||
-- we are being called with a list of Path objects
|
-- we are being called with a list of Path objects
|
||||||
cache_sp = sp
|
cache_sp = sp
|
||||||
|
message = nil
|
||||||
else
|
else
|
||||||
-- we are being called with a list function/argument tuples
|
-- we are being called with a list function/argument tuples
|
||||||
local args = subpaths[i][2]
|
local args = subpaths[i][2]
|
||||||
cache_sp = subpaths[i][1](args[1], args[2], args[3], args[4], start_pos[i], start_orientation[i])
|
cache_sp = subpaths[i][1](args[1], args[2], args[3], args[4], start_pos[i], start_orientation[i])
|
||||||
|
message = subpaths[i].message
|
||||||
end
|
end
|
||||||
return cache_sp
|
return cache_sp
|
||||||
end
|
end
|
||||||
@ -642,6 +646,9 @@ function path_composer(_name, _subpaths)
|
|||||||
local sp = self.subpath(i)
|
local sp = self.subpath(i)
|
||||||
if i > highest_i and t < 1.0 and t > 0 then
|
if i > highest_i and t < 1.0 and t > 0 then
|
||||||
highest_i = i
|
highest_i = i
|
||||||
|
if message ~= nil then
|
||||||
|
gcs:send_text(0, message)
|
||||||
|
end
|
||||||
if AEROM_DEBUG:get() > 0 then
|
if AEROM_DEBUG:get() > 0 then
|
||||||
gcs:send_text(0, string.format("starting %s[%d] %s", self.name, i, sp.name))
|
gcs:send_text(0, string.format("starting %s[%d] %s", self.name, i, sp.name))
|
||||||
end
|
end
|
||||||
@ -754,6 +761,17 @@ function immelmann_turn(r, arg2, arg3, arg4)
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- immelmann with max roll rate
|
||||||
|
function immelmann_turn_fast(r, arg2, arg3, arg4)
|
||||||
|
local rabs = math.abs(r)
|
||||||
|
local roll_time = 180.0 / ACRO_ROLL_RATE:get()
|
||||||
|
local roll_dist = target_groundspeed() * roll_time
|
||||||
|
return make_paths("immelmann_turn_fast", {
|
||||||
|
{ path_vertical_arc(r, 180), roll_angle(0) },
|
||||||
|
{ path_straight(roll_dist), roll_angle(180) },
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
function humpty_bump(r, h, arg3, arg4)
|
function humpty_bump(r, h, arg3, arg4)
|
||||||
assert(h >= 2*r)
|
assert(h >= 2*r)
|
||||||
local rabs = math.abs(r)
|
local rabs = math.abs(r)
|
||||||
@ -1162,6 +1180,31 @@ function f4c_example_l_r() -- positioned for a flight l
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
--[[
|
||||||
|
simple air show
|
||||||
|
--]]
|
||||||
|
|
||||||
|
function air_show1()
|
||||||
|
return path_composer("AirShow", {
|
||||||
|
{ loop, { 25, 0, 1 }},
|
||||||
|
{ straight_align, { 100, 0 } },
|
||||||
|
{ half_reverse_cuban_eight, { 25 }, message="HalfReverseCubanEight" },
|
||||||
|
{ straight_align, { 80 } },
|
||||||
|
{ scale_figure_eight, { -40, -30 }, message="ScaleFigureEight" },
|
||||||
|
{ immelmann_turn, { 30 }, message="Immelmann" },
|
||||||
|
{ straight_align, { -60, 0 } },
|
||||||
|
{ straight_roll, { 120, 2 }, message="Roll" },
|
||||||
|
{ straight_align, { 120, 0 } },
|
||||||
|
{ split_s, { 30 }, message="Split-S"},
|
||||||
|
{ straight_align, { 0 } },
|
||||||
|
{ rolling_circle, { -50, 3}, message="RollingCircle" },
|
||||||
|
{ straight_align, { -50, 0 } },
|
||||||
|
{ humpty_bump, { 20, 60 }, message="HumptyBump" },
|
||||||
|
{ straight_align, { 80, 0 } },
|
||||||
|
{ half_cuban_eight, { 25 }, message="HalfCubanEight" },
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
function test_all_paths()
|
function test_all_paths()
|
||||||
return path_composer("test_all_paths", {
|
return path_composer("test_all_paths", {
|
||||||
{ figure_eight, { 100, 45 } },
|
{ figure_eight, { 100, 45 } },
|
||||||
@ -1639,7 +1682,7 @@ command_table[2] = PathFunction(loop, "Loop")
|
|||||||
command_table[3] = PathFunction(horizontal_rectangle, "Horizontal Rectangle")
|
command_table[3] = PathFunction(horizontal_rectangle, "Horizontal Rectangle")
|
||||||
command_table[4] = PathFunction(climbing_circle, "Climbing Circle")
|
command_table[4] = PathFunction(climbing_circle, "Climbing Circle")
|
||||||
command_table[5] = PathFunction(vertical_aerobatic_box, "Vertical Box")
|
command_table[5] = PathFunction(vertical_aerobatic_box, "Vertical Box")
|
||||||
-- 6 was banked circle
|
command_table[6] = PathFunction(immelmann_turn_fast, "Immelmann Fast")
|
||||||
command_table[7] = PathFunction(straight_roll, "Axial Roll")
|
command_table[7] = PathFunction(straight_roll, "Axial Roll")
|
||||||
command_table[8] = PathFunction(rolling_circle, "Rolling Circle")
|
command_table[8] = PathFunction(rolling_circle, "Rolling Circle")
|
||||||
command_table[9] = PathFunction(half_cuban_eight, "Half Cuban Eight")
|
command_table[9] = PathFunction(half_cuban_eight, "Half Cuban Eight")
|
||||||
@ -1661,6 +1704,7 @@ command_table[200] = PathFunction(test_all_paths, "Test Suite")
|
|||||||
command_table[201] = PathFunction(nz_clubman, "NZ Clubman")
|
command_table[201] = PathFunction(nz_clubman, "NZ Clubman")
|
||||||
command_table[202] = PathFunction(f3a_p23_l_r, "FAI F3A P23 L to R")
|
command_table[202] = PathFunction(f3a_p23_l_r, "FAI F3A P23 L to R")
|
||||||
command_table[203] = PathFunction(f4c_example_l_r, "FAI F4C Example L to R")
|
command_table[203] = PathFunction(f4c_example_l_r, "FAI F4C Example L to R")
|
||||||
|
command_table[204] = PathFunction(air_show1, "AirShow")
|
||||||
|
|
||||||
-- get a location structure from a waypoint number
|
-- get a location structure from a waypoint number
|
||||||
function get_location(i)
|
function get_location(i)
|
||||||
|
Loading…
Reference in New Issue
Block a user