mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
SITL: Move SITL on hdwr scripts to Tools and simplify
This commit is contained in:
parent
3a49804703
commit
0a060aa520
@ -1,80 +0,0 @@
|
||||
# SITL-on-HW notes
|
||||
|
||||
## Compiling and flashing
|
||||
|
||||
Run the sitl-on-hw.sh script to compile and flash for MatekH743. Adjust for your own board if required before running. This script will configure a build ready for running SITL-on-hardware and attempt to upload it to a connected board. It includes a set of embedded parameters to configure the simulated sensors appropriately.
|
||||
|
||||
::
|
||||
|
||||
cd $HOME/ardupilot
|
||||
./libraries/SITL/examples/on-hardware/sitl-on-hw.py --board MatekH743 --vehicle copter
|
||||
|
||||
Plane can also be simulated:
|
||||
|
||||
::
|
||||
|
||||
cd $HOME/ardupilot
|
||||
./libraries/SITL/examples/on-hardware/sitl-on-hw.py --board MatekH743 --vehicle plane
|
||||
|
||||
and quadplane:
|
||||
|
||||
::
|
||||
|
||||
cd $HOME/ardupilot
|
||||
./libraries/SITL/examples/on-hardware/sitl-on-hw.py --board MatekH743 --vehicle plane --simclass QuadPlane
|
||||
|
||||
## Configuring
|
||||
|
||||
Wipe the parameters on the board; this can be done with a mavlink command, or by setting the FORMAT_VERSION parameter to 0.
|
||||
|
||||
For example:
|
||||
|
||||
::
|
||||
|
||||
STABILIZE> wipe_parameters IREALLYMEAANIT
|
||||
STABILIZE> Got COMMAND_ACK: PREFLIGHT_STORAGE: ACCEPTED
|
||||
AP: All parameters reset, reboot board
|
||||
reboot
|
||||
|
||||
You may need to power-cycle the board at this point.
|
||||
|
||||
::
|
||||
|
||||
Device /dev/serial/by-id/usb-ArduPilot_MatekH743_3A0019001051393036353035-if00 reopened OK
|
||||
link 1 OK
|
||||
heartbeat OK
|
||||
disabling flow control on serial 2
|
||||
AP: Calibrating barometer
|
||||
AP: Barometer 1 calibration complete
|
||||
AP: Barometer 2 calibration complete
|
||||
Init Gyro**
|
||||
AP: ArduPilot Ready
|
||||
Suggested EK3_BCOEF_* = 16.288, EK3_MCOEF = 0.208
|
||||
Home: -35.36326 149.1652 alt=584.0000m hdg=353.0000
|
||||
Smoothing reset at 0.001
|
||||
AP: RCOut: PWM:1-13
|
||||
AP: GPS 1: detected as SITL at 115200 baud
|
||||
Time has wrapped
|
||||
Time has wrapped 5577 368458
|
||||
AP: EKF3 IMU0 initialised
|
||||
AP: EKF3 IMU1 initialised
|
||||
AP: EKF3 IMU0 tilt alignment complete
|
||||
AP: EKF3 IMU1 tilt alignment complete
|
||||
AP: EKF3 IMU1 MAG0 initial yaw alignment complete
|
||||
AP: EKF3 IMU0 MAG0 initial yaw alignment complete
|
||||
AP: PERF: 0/3999 [2653:2349] F=400Hz sd=39 Ex=0
|
||||
AP: EKF3 IMU1 forced reset
|
||||
AP: EKF3 IMU1 initialised
|
||||
AP: EKF3 IMU0 forced reset
|
||||
AP: EKF3 IMU0 initialised
|
||||
AP: EKF3 IMU1 tilt alignment complete
|
||||
AP: EKF3 IMU0 tilt alignment complete
|
||||
AP: EKF3 IMU1 MAG0 initial yaw alignment complete
|
||||
AP: EKF3 IMU0 MAG0 initial yaw alignment complete
|
||||
AP: PreArm: 3D Accel calibration needed
|
||||
AP: PERF: 0/4000 [2631:2369] F=400Hz sd=5 Ex=0
|
||||
AP: EKF3 IMU0 origin set
|
||||
AP: EKF3 IMU1 origin set
|
||||
AP: PERF: 0/4000 [2639:2362] F=400Hz sd=7 Ex=0
|
||||
|
||||
Force
|
@ -1,59 +0,0 @@
|
||||
AHRS_EKF_TYPE 10
|
||||
|
||||
ATC_RAT_YAW_P 0.09
|
||||
ATC_RAT_YAW_I 0.009
|
||||
|
||||
BATT_MONITOR 0
|
||||
|
||||
COMPASS_OFS_X 5
|
||||
COMPASS_OFS_Y 13
|
||||
COMPASS_OFS_Z -18
|
||||
COMPASS_OFS2_X 5
|
||||
COMPASS_OFS2_Y 13
|
||||
COMPASS_OFS2_Z -18
|
||||
|
||||
FENCE_RADIUS 150
|
||||
|
||||
FRAME_TYPE 0
|
||||
FRAME_CLASS 1
|
||||
|
||||
FS_THR_ENABLE 1
|
||||
|
||||
RC7_OPTION 7
|
||||
|
||||
FLTMODE1 7
|
||||
FLTMODE2 9
|
||||
FLTMODE3 6
|
||||
FLTMODE4 3
|
||||
FLTMODE5 5
|
||||
FLTMODE6 0
|
||||
|
||||
GPS_TYPE 100
|
||||
|
||||
INS_ACCOFFS_X 0.001
|
||||
INS_ACCOFFS_Y 0.001
|
||||
INS_ACCOFFS_Z 0.001
|
||||
INS_ACCSCAL_X 1.001
|
||||
INS_ACCSCAL_Y 1.001
|
||||
INS_ACCSCAL_Z 1.001
|
||||
INS_ACC2OFFS_X 0.001
|
||||
INS_ACC2OFFS_Y 0.001
|
||||
INS_ACC2OFFS_Z 0.001
|
||||
INS_ACC2SCAL_X 1.001
|
||||
INS_ACC2SCAL_Y 1.001
|
||||
INS_ACC2SCAL_Z 1.001
|
||||
|
||||
MOT_THST_EXPO 0.65
|
||||
MOT_THST_HOVER 0.39
|
||||
MOT_BAT_VOLT_MIN 9.6
|
||||
MOT_BAT_VOLT_MAX 12.8
|
||||
|
||||
SCHED_DEBUG 0
|
||||
|
||||
SIM_MAG1_DEVID 97539
|
||||
SIM_BARO_RND 0
|
||||
|
||||
SIM_RATE_HZ 400
|
||||
SCHED_LOOP_RATE 400
|
||||
|
||||
BRD_RTC_TYPES 2
|
@ -1,48 +0,0 @@
|
||||
env SIM_ENABLED 1
|
||||
|
||||
define INS_MAX_INSTANCES 2
|
||||
define HAL_COMPASS_MAX_SENSORS 2
|
||||
|
||||
define HAL_NAVEKF2_AVAILABLE 0
|
||||
define EK3_FEATURE_BODY_ODOM 0
|
||||
define EK3_FEATURE_EXTERNAL_NAV 0
|
||||
define EK3_FEATURE_DRAG_FUSION 0
|
||||
define HAL_ADSB_ENABLED 0
|
||||
define HAL_MOUNT_ENABLED 0
|
||||
define HAL_PROXIMITY_ENABLED 0
|
||||
define HAL_VISUALODOM_ENABLED 0
|
||||
define HAL_GENERATOR_ENABLED 0
|
||||
# define HAL_LOGGING_ENABLED 0
|
||||
define HAL_CRSF_TELEM_ENABLED 0
|
||||
#define OSD_ENABLED 0
|
||||
define FRAME_HEXA 0
|
||||
define FRAME_OCTA 0
|
||||
define FRAME_DODECAHEXA 0
|
||||
define FRAME_Y6 0
|
||||
define FRAME_OCTAQUAD 0
|
||||
|
||||
define MODE_SMARTRTL_ENABLED 0
|
||||
define MODE_SPORT_ENABLED 0
|
||||
# define MODE_CIRCLE_ENABLED 0
|
||||
define MODE_THROW_ENABLED 0
|
||||
define MODE_TURTLE_ENABLED 0
|
||||
define MODE_ZIGZAG_ENABLED 0
|
||||
define MODE_FLOWHOLD 0
|
||||
define MODE_POSHOLD_ENABLED 0
|
||||
define MODE_SYSTEMID_ENABLED 0
|
||||
define MODE_ACRO_ENABLED 0
|
||||
define MODE_FOLLOW_ENABLED 0
|
||||
define MODE_FLIP_ENABLED 0
|
||||
define MODE_DRIFT_ENABLED 0
|
||||
define MODE_THROW_ENABLED 0
|
||||
|
||||
define AP_LANDINGGEAR_ENABLED 0
|
||||
define HAL_MSP_OPTICALFLOW_ENABLED 0
|
||||
define HAL_SUPPORT_RCOUT_SERIAL 0
|
||||
define HAL_HOTT_TELEM_ENABLED 0
|
||||
# define HAL_GYROFFT_ENABLED 0
|
||||
|
||||
|
||||
define HAL_HIGH_LATENCY2 0
|
||||
|
||||
define AP_SIM_INS_FILE_ENABLED 0
|
@ -1,51 +0,0 @@
|
||||
AHRS_EKF_TYPE 10
|
||||
|
||||
BATT_MONITOR 0
|
||||
|
||||
COMPASS_OFS_X 5
|
||||
COMPASS_OFS_Y 13
|
||||
COMPASS_OFS_Z -18
|
||||
COMPASS_OFS2_X 5
|
||||
COMPASS_OFS2_Y 13
|
||||
COMPASS_OFS2_Z -18
|
||||
|
||||
THR_FAILSAFE 1
|
||||
THR_FS_VALUE 950
|
||||
|
||||
RC7_OPTION 7
|
||||
|
||||
FLTMODE1 7
|
||||
FLTMODE2 9
|
||||
FLTMODE3 6
|
||||
FLTMODE4 3
|
||||
FLTMODE5 5
|
||||
FLTMODE6 0
|
||||
|
||||
GPS_TYPE 100
|
||||
|
||||
INS_ACCOFFS_X 0.001
|
||||
INS_ACCOFFS_Y 0.001
|
||||
INS_ACCOFFS_Z 0.001
|
||||
INS_ACCSCAL_X 1.001
|
||||
INS_ACCSCAL_Y 1.001
|
||||
INS_ACCSCAL_Z 1.001
|
||||
INS_ACC2OFFS_X 0.001
|
||||
INS_ACC2OFFS_Y 0.001
|
||||
INS_ACC2OFFS_Z 0.001
|
||||
INS_ACC2SCAL_X 1.001
|
||||
INS_ACC2SCAL_Y 1.001
|
||||
INS_ACC2SCAL_Z 1.001
|
||||
|
||||
SCHED_DEBUG 0
|
||||
|
||||
SIM_MAG1_DEVID 97539
|
||||
SIM_BARO_RND 0
|
||||
|
||||
SIM_RATE_HZ 400
|
||||
SCHED_LOOP_RATE 400
|
||||
|
||||
BRD_RTC_TYPES 2
|
||||
|
||||
SERVO3_MIN 1000
|
||||
SERVO3_TRIM 1000
|
||||
SERVO3_MAX 2000
|
@ -1,32 +0,0 @@
|
||||
env SIM_ENABLED 1
|
||||
|
||||
define INS_MAX_INSTANCES 2
|
||||
define HAL_COMPASS_MAX_SENSORS 2
|
||||
|
||||
define HAL_NAVEKF2_AVAILABLE 0
|
||||
define EK3_FEATURE_BODY_ODOM 0
|
||||
define EK3_FEATURE_EXTERNAL_NAV 0
|
||||
define EK3_FEATURE_DRAG_FUSION 0
|
||||
define HAL_ADSB_ENABLED 0
|
||||
define HAL_MOUNT_ENABLED 0
|
||||
define HAL_PROXIMITY_ENABLED 0
|
||||
define HAL_VISUALODOM_ENABLED 0
|
||||
define HAL_GENERATOR_ENABLED 0
|
||||
# define HAL_LOGGING_ENABLED 0
|
||||
define HAL_CRSF_TELEM_ENABLED 0
|
||||
#define OSD_ENABLED 0
|
||||
define FRAME_HEXA 0
|
||||
define FRAME_OCTA 0
|
||||
define FRAME_DODECAHEXA 0
|
||||
define FRAME_Y6 0
|
||||
define FRAME_OCTAQUAD 0
|
||||
|
||||
define AP_LANDINGGEAR_ENABLED 0
|
||||
define HAL_MSP_OPTICALFLOW_ENABLED 0
|
||||
define HAL_SUPPORT_RCOUT_SERIAL 0
|
||||
define HAL_HOTT_TELEM_ENABLED 0
|
||||
# define HAL_GYROFFT_ENABLED 0
|
||||
|
||||
define HAL_HIGH_LATENCY2 0
|
||||
|
||||
define AP_SIM_INS_FILE_ENABLED 0
|
@ -1,91 +0,0 @@
|
||||
#!/usr/bin/env python3
|
||||
'''
|
||||
script to build a firmware for SITL-on-hardware
|
||||
see https://ardupilot.org/dev/docs/sim-on-hardware.html
|
||||
'''
|
||||
|
||||
import subprocess
|
||||
import sys
|
||||
import os
|
||||
import tempfile
|
||||
|
||||
from argparse import ArgumentParser
|
||||
parser = ArgumentParser("SITL on hardware builder")
|
||||
parser.add_argument("--board", default=None, help="board type")
|
||||
parser.add_argument("--vehicle", default=None, help="vehicle type")
|
||||
parser.add_argument("--frame", default=None, help="frame type")
|
||||
parser.add_argument("--simclass", default=None, help="simulation class")
|
||||
parser.add_argument("--defaults", default=None, help="extra defaults file")
|
||||
parser.add_argument("--upload", action='store_true', default=False, help="upload firmware")
|
||||
|
||||
args, unknown_args = parser.parse_known_args()
|
||||
|
||||
extra_hwdef = None
|
||||
|
||||
def run_program(cmd_list):
|
||||
'''run a program from a command list'''
|
||||
print("Running (%s)" % " ".join(cmd_list))
|
||||
retcode = subprocess.call(cmd_list)
|
||||
if retcode != 0:
|
||||
print("FAILED: %s" % (' '.join(cmd_list)))
|
||||
global extra_hwdef
|
||||
if extra_hwdef is not None:
|
||||
extra_hwdef.close()
|
||||
os.unlink(extra_hwdef.name)
|
||||
sys.exit(1)
|
||||
|
||||
extra_hwdef = tempfile.NamedTemporaryFile(mode='w')
|
||||
extra_defaults = tempfile.NamedTemporaryFile(mode='w')
|
||||
|
||||
def hwdef_write(s):
|
||||
'''write to the hwdef temp file'''
|
||||
extra_hwdef.write(s)
|
||||
|
||||
def defaults_write(s):
|
||||
'''write to the hwdef temp file'''
|
||||
extra_defaults.write(s)
|
||||
|
||||
def sohw_path(fname):
|
||||
'''get path to a file in on-hardware directory'''
|
||||
return os.path.join(os.path.dirname(os.path.realpath(__file__)), fname)
|
||||
|
||||
if args.vehicle == "plane":
|
||||
extra_hwdef_base = "plane-extra-hwdef-sitl-on-hw.dat"
|
||||
defaults_base = "plane-default.param"
|
||||
else:
|
||||
extra_hwdef_base = "extra-hwdef-sitl-on-hw.dat"
|
||||
defaults_base = "default.param"
|
||||
|
||||
# add base hwdef to extra_hwdef
|
||||
hwdef_write(open(sohw_path(extra_hwdef_base), "r").read() + "\n")
|
||||
|
||||
# add base defaults to extra_defaults
|
||||
defaults_write(open(sohw_path(defaults_base), "r").read() + "\n")
|
||||
|
||||
if args.defaults:
|
||||
defaults_write(open(args.defaults,"r").read() + "\n")
|
||||
|
||||
if args.simclass:
|
||||
hwdef_write("define AP_SIM_FRAME_CLASS %s\n" % args.simclass)
|
||||
if args.frame:
|
||||
hwdef_write('define AP_SIM_FRAME_STRING "%s"\n' % args.frame)
|
||||
|
||||
extra_hwdef.flush()
|
||||
extra_defaults.flush()
|
||||
|
||||
configure_args = ["./waf", "configure",
|
||||
"--board=%s" % args.board,
|
||||
"--extra-hwdef=%s" % extra_hwdef.name,
|
||||
"--default-param=%s" % extra_defaults.name]
|
||||
configure_args.extend(unknown_args)
|
||||
run_program(configure_args)
|
||||
|
||||
build_cmd = ["./waf", args.vehicle]
|
||||
if args.upload:
|
||||
build_cmd.append("--upload")
|
||||
|
||||
run_program(build_cmd)
|
||||
|
||||
# cleanup
|
||||
extra_hwdef.close()
|
||||
|
@ -1,5 +0,0 @@
|
||||
rc 1 1500
|
||||
rc 2 1500
|
||||
rc 3 1000
|
||||
rc 4 1500
|
||||
rc 5 2000
|
Loading…
Reference in New Issue
Block a user