f19be28e89
This useful when using X forwarding, as mavproxy can start to quickly, and then break the sim enviorment. If the argument isn't used there is no change in behaviour
467 lines
11 KiB
Bash
Executable File
467 lines
11 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# home location lat, lon, alt, heading
|
|
LOCATION="CMAC"
|
|
TRACKER_LOCATION="CMAC_PILOTSBOX"
|
|
VEHICLE=""
|
|
BUILD_TARGET="sitl"
|
|
FRAME=""
|
|
NUM_PROCS=1
|
|
SPEEDUP="1"
|
|
|
|
# check the instance number to allow for multiple copies of the sim running at once
|
|
INSTANCE=0
|
|
USE_VALGRIND=0
|
|
USE_GDB=0
|
|
USE_GDB_STOPPED=0
|
|
DEBUG_BUILD=0
|
|
USE_MAVLINK_GIMBAL=0
|
|
CLEAN_BUILD=0
|
|
START_ANTENNA_TRACKER=0
|
|
WIPE_EEPROM=0
|
|
REVERSE_THROTTLE=0
|
|
NO_REBUILD=0
|
|
START_HIL=0
|
|
EXTRA_ARGS=""
|
|
EXTERNAL_SIM=0
|
|
MODEL=""
|
|
BREAKPOINT=""
|
|
OVERRIDE_BUILD_TARGET=""
|
|
DELAY_START=0
|
|
|
|
usage()
|
|
{
|
|
cat <<EOF
|
|
Usage: sim_vehicle.sh [options] [mavproxy_options]
|
|
Options:
|
|
-v VEHICLE vehicle type (ArduPlane, ArduCopter or APMrover2)
|
|
vehicle type defaults to working directory
|
|
-I INSTANCE instance of simulator (default 0)
|
|
-V enable valgrind for memory access checking (very slow!)
|
|
-G use gdb for debugging ardupilot
|
|
-g use gdb for debugging ardupilot, but don't auto-start
|
|
-D build with debugging
|
|
-B add a breakpoint at given location in debugger
|
|
-T start an antenna tracker instance
|
|
-A pass arguments to SITL instance
|
|
-t set antenna tracker start location
|
|
-L select start location from Tools/autotest/locations.txt
|
|
-l set the custom start location from -L
|
|
-c do a make clean before building
|
|
-N don't rebuild before starting ardupilot
|
|
-w wipe EEPROM and reload parameters
|
|
-R reverse throttle in plane
|
|
-M enable MAVLink gimbal
|
|
-f FRAME set aircraft frame type
|
|
for copters can choose +, X, quad or octa
|
|
for planes can choose elevon or vtail
|
|
-b BUILD_TARGET override SITL build target
|
|
-j NUM_PROC number of processors to use during build (default 1)
|
|
-H start HIL
|
|
-e use external simulator
|
|
-S SPEEDUP set simulation speedup (1 for wall clock time)
|
|
-d TIME delays the start of mavproxy by the number of seconds
|
|
|
|
mavproxy_options:
|
|
--map start with a map
|
|
--console start with a status console
|
|
--out DEST start MAVLink output to DEST
|
|
|
|
Note:
|
|
eeprom.bin in the starting directory contains the parameters for your
|
|
simulated vehicle. Always start from the same directory. It is recommended that
|
|
you start in the main vehicle directory for the vehicle you are simulating,
|
|
for example, start in the ArduPlane directory to simulate ArduPlane
|
|
EOF
|
|
}
|
|
|
|
|
|
# parse options. Thanks to http://wiki.bash-hackers.org/howto/getopts_tutorial
|
|
while getopts ":I:VgGcj:TA:t:L:l:v:hwf:RNHeMS:DB:b:d:" opt; do
|
|
case $opt in
|
|
v)
|
|
VEHICLE=$OPTARG
|
|
;;
|
|
I)
|
|
INSTANCE=$OPTARG
|
|
;;
|
|
V)
|
|
USE_VALGRIND=1
|
|
;;
|
|
N)
|
|
NO_REBUILD=1
|
|
;;
|
|
H)
|
|
START_HIL=1
|
|
NO_REBUILD=1
|
|
;;
|
|
T)
|
|
START_ANTENNA_TRACKER=1
|
|
;;
|
|
A)
|
|
EXTRA_ARGS="$OPTARG"
|
|
;;
|
|
R)
|
|
REVERSE_THROTTLE=1
|
|
;;
|
|
G)
|
|
USE_GDB=1
|
|
;;
|
|
D)
|
|
DEBUG_BUILD=1
|
|
;;
|
|
d)
|
|
DELAY_START="$OPTARG"
|
|
;;
|
|
B)
|
|
BREAKPOINT="$OPTARG"
|
|
;;
|
|
M)
|
|
USE_MAVLINK_GIMBAL=1
|
|
;;
|
|
g)
|
|
USE_GDB=1
|
|
USE_GDB_STOPPED=1
|
|
;;
|
|
L)
|
|
LOCATION="$OPTARG"
|
|
;;
|
|
l)
|
|
CUSTOM_LOCATION="$OPTARG"
|
|
;;
|
|
f)
|
|
FRAME="$OPTARG"
|
|
;;
|
|
S)
|
|
SPEEDUP="$OPTARG"
|
|
;;
|
|
t)
|
|
TRACKER_LOCATION="$OPTARG"
|
|
;;
|
|
c)
|
|
CLEAN_BUILD=1
|
|
;;
|
|
j)
|
|
NUM_PROCS=$OPTARG
|
|
;;
|
|
w)
|
|
WIPE_EEPROM=1
|
|
;;
|
|
e)
|
|
EXTERNAL_SIM=1
|
|
;;
|
|
b)
|
|
OVERRIDE_BUILD_TARGET="$OPTARG"
|
|
;;
|
|
h)
|
|
usage
|
|
exit 0
|
|
;;
|
|
\?)
|
|
# allow other args to pass on to mavproxy
|
|
break
|
|
;;
|
|
:)
|
|
echo "Option -$OPTARG requires an argument." >&2
|
|
usage
|
|
exit 1
|
|
esac
|
|
done
|
|
shift $((OPTIND-1))
|
|
|
|
# kill existing copy if this is the '0' instance only
|
|
kill_tasks()
|
|
{
|
|
[ "$INSTANCE" -eq "0" ] && {
|
|
for pname in JSBSim lt-JSBSim ArduPlane.elf ArduCopter.elf APMrover2.elf AntennaTracker.elf JSBSIm.exe MAVProxy.exe; do
|
|
pkill "$pname"
|
|
done
|
|
pkill -f runsim.py
|
|
}
|
|
}
|
|
|
|
if [ $START_HIL == 0 ]; then
|
|
kill_tasks
|
|
fi
|
|
|
|
trap kill_tasks SIGINT
|
|
|
|
# setup ports for this instance
|
|
MAVLINK_PORT="tcp:127.0.0.1:"$((5760+10*$INSTANCE))
|
|
SIMIN_PORT="127.0.0.1:"$((5502+10*$INSTANCE))
|
|
SIMOUT_PORT="127.0.0.1:"$((5501+10*$INSTANCE))
|
|
FG_PORT="127.0.0.1:"$((5503+10*$INSTANCE))
|
|
|
|
[ -z "$VEHICLE" ] && {
|
|
CDIR="$PWD"
|
|
rpath=$(which realpath)
|
|
[ -n "$rpath" ] && {
|
|
CDIR=$(realpath $CDIR)
|
|
}
|
|
VEHICLE=$(basename $CDIR)
|
|
}
|
|
|
|
[ -z "$FRAME" -a "$VEHICLE" = "APMrover2" ] && {
|
|
FRAME="rover"
|
|
}
|
|
|
|
[ -z "$FRAME" -a "$VEHICLE" = "ArduPlane" ] && {
|
|
FRAME="jsbsim"
|
|
}
|
|
[ -z "$FRAME" -a "$VEHICLE" = "ArduCopter" ] && {
|
|
FRAME="quad"
|
|
}
|
|
[ -z "$FRAME" -a "$VEHICLE" = "AntennaTracker" ] && {
|
|
FRAME="tracker"
|
|
}
|
|
|
|
EXTRA_PARM=""
|
|
|
|
check_jsbsim_version()
|
|
{
|
|
jsbsim_version=$(JSBSim --version)
|
|
if [[ $jsbsim_version != *"ArduPilot"* ]]
|
|
then
|
|
cat <<EOF
|
|
=========================================================
|
|
You need the latest ArduPilot version of JSBSim installed
|
|
and in your \$PATH
|
|
|
|
Please get it from git://github.com/tridge/jsbsim.git
|
|
See
|
|
http://dev.ardupilot.com/wiki/simulation-2/sitl-simulator-software-in-the-loop/setting-up-sitl-on-linux/
|
|
for more details
|
|
=========================================================
|
|
EOF
|
|
exit 1
|
|
fi
|
|
}
|
|
|
|
|
|
# modify build target based on copter frame type
|
|
case $FRAME in
|
|
+|quad)
|
|
BUILD_TARGET="sitl"
|
|
MODEL="+"
|
|
;;
|
|
X)
|
|
BUILD_TARGET="sitl"
|
|
EXTRA_PARM="param set FRAME 1;"
|
|
MODEL="X"
|
|
;;
|
|
octa*)
|
|
BUILD_TARGET="sitl-octa"
|
|
MODEL="$FRAME"
|
|
;;
|
|
heli*)
|
|
BUILD_TARGET="sitl-heli"
|
|
MODEL="$FRAME"
|
|
;;
|
|
heli-dual)
|
|
BUILD_TARGET="sitl-heli-dual"
|
|
EXTRA_SIM="$EXTRA_SIM --frame=heli-dual"
|
|
MODEL="heli-dual"
|
|
;;
|
|
heli-compound)
|
|
BUILD_TARGET="sitl-heli-compound"
|
|
EXTRA_SIM="$EXTRA_SIM --frame=heli-compound"
|
|
MODEL="heli-compound"
|
|
;;
|
|
IrisRos)
|
|
BUILD_TARGET="sitl"
|
|
;;
|
|
Gazebo)
|
|
BUILD_TARGET="sitl"
|
|
EXTRA_SIM="$EXTRA_SIM --frame=Gazebo"
|
|
MODEL="$FRAME"
|
|
;;
|
|
CRRCSim|last_letter*)
|
|
BUILD_TARGET="sitl"
|
|
MODEL="$FRAME"
|
|
;;
|
|
jsbsim*)
|
|
BUILD_TARGET="sitl"
|
|
MODEL="$FRAME"
|
|
check_jsbsim_version
|
|
;;
|
|
*-heli)
|
|
BUILD_TARGET="sitl-heli"
|
|
MODEL="$FRAME"
|
|
;;
|
|
*)
|
|
MODEL="$FRAME"
|
|
;;
|
|
esac
|
|
|
|
if [ $DEBUG_BUILD == 1 ]; then
|
|
BUILD_TARGET="$BUILD_TARGET-debug"
|
|
fi
|
|
|
|
if [ -n "$OVERRIDE_BUILD_TARGET" ]; then
|
|
BUILD_TARGET="$OVERRIDE_BUILD_TARGET"
|
|
fi
|
|
|
|
autotest="../Tools/autotest"
|
|
[ -d "$autotest" ] || {
|
|
# we are not running from one of the standard vehicle directories. Use
|
|
# the location of the sim_vehicle.sh script to find the path
|
|
autotest=$(dirname $(readlink -e $0))
|
|
}
|
|
VEHICLEDIR="$autotest/../../$VEHICLE"
|
|
[ -d "$VEHICLEDIR" ] || {
|
|
VEHICLEDIR=$(dirname $(readlink -e $VEHICLEDIR))
|
|
}
|
|
pushd $VEHICLEDIR || {
|
|
echo "Failed to change to vehicle directory for $VEHICLEDIR"
|
|
usage
|
|
exit 1
|
|
}
|
|
AUTOTEST=$autotest
|
|
export AUTOTEST
|
|
VEHICLEDIR=$(pwd)
|
|
|
|
if [ $NO_REBUILD == 0 ]; then
|
|
if [ $CLEAN_BUILD == 1 ]; then
|
|
echo "Building clean"
|
|
make clean
|
|
fi
|
|
echo "Building $BUILD_TARGET"
|
|
make $BUILD_TARGET -j$NUM_PROCS || {
|
|
make clean
|
|
make $BUILD_TARGET -j$NUM_PROCS || {
|
|
echo >&2 "$0: Build failed"
|
|
exit 1
|
|
}
|
|
}
|
|
fi
|
|
popd
|
|
|
|
# get the location information
|
|
if [ -z $CUSTOM_LOCATION ]; then
|
|
SIMHOME=$(cat $autotest/locations.txt | grep -i "^$LOCATION=" | cut -d= -f2)
|
|
else
|
|
SIMHOME=$CUSTOM_LOCATION
|
|
LOCATION="Custom_Location"
|
|
fi
|
|
|
|
[ -z "$SIMHOME" ] && {
|
|
echo "Unknown location $LOCATION"
|
|
usage
|
|
exit 1
|
|
}
|
|
echo "Starting up at $LOCATION : $SIMHOME"
|
|
|
|
TRACKER_HOME=$(cat $autotest/locations.txt | grep -i "^$TRACKER_LOCATION=" | cut -d= -f2)
|
|
[ -z "$TRACKER_HOME" ] && {
|
|
echo "Unknown tracker location $TRACKER_LOCATION"
|
|
usage
|
|
exit 1
|
|
}
|
|
|
|
|
|
if [ $START_ANTENNA_TRACKER == 1 ]; then
|
|
pushd $autotest/../../AntennaTracker
|
|
if [ $CLEAN_BUILD == 1 ]; then
|
|
make clean
|
|
fi
|
|
make sitl-debug -j$NUM_PROCS || {
|
|
make clean
|
|
make sitl-debug -j$NUM_PROCS
|
|
}
|
|
TRACKER_INSTANCE=1
|
|
TRACKER_UARTA="tcp:127.0.0.1:"$((5760+10*$TRACKER_INSTANCE))
|
|
cmd="nice /tmp/AntennaTracker.build/AntennaTracker.elf -I1 --model=tracker --home=$TRACKER_HOME"
|
|
$autotest/run_in_terminal_window.sh "AntennaTracker" $cmd || exit 1
|
|
popd
|
|
fi
|
|
|
|
cmd="$VEHICLEDIR/$VEHICLE.elf -S -I$INSTANCE --home $SIMHOME"
|
|
if [ $WIPE_EEPROM == 1 ]; then
|
|
cmd="$cmd -w"
|
|
fi
|
|
|
|
cmd="$cmd --model $MODEL --speedup=$SPEEDUP $EXTRA_ARGS"
|
|
|
|
case $VEHICLE in
|
|
ArduPlane)
|
|
PARMS="ArduPlane.parm"
|
|
;;
|
|
ArduCopter)
|
|
PARMS="copter_params.parm"
|
|
;;
|
|
APMrover2)
|
|
PARMS="Rover.parm"
|
|
;;
|
|
*)
|
|
PARMS=""
|
|
;;
|
|
esac
|
|
|
|
if [ $USE_MAVLINK_GIMBAL == 1 ]; then
|
|
echo "Using MAVLink gimbal"
|
|
cmd="$cmd --gimbal"
|
|
fi
|
|
|
|
if [ $START_HIL == 0 ]; then
|
|
if [ $USE_VALGRIND == 1 ]; then
|
|
echo "Using valgrind"
|
|
$autotest/run_in_terminal_window.sh "ardupilot (valgrind)" valgrind $cmd || exit 1
|
|
elif [ $USE_GDB == 1 ]; then
|
|
echo "Using gdb"
|
|
tfile=$(mktemp)
|
|
[ $USE_GDB_STOPPED == 0 ] && {
|
|
if [ -n "$BREAKPOINT" ]; then
|
|
echo "b $BREAKPOINT" >> $tfile
|
|
fi
|
|
echo r >> $tfile
|
|
}
|
|
$autotest/run_in_terminal_window.sh "ardupilot (gdb)" gdb -x $tfile --args $cmd || exit 1
|
|
else
|
|
$autotest/run_in_terminal_window.sh "ardupilot" $cmd || exit 1
|
|
fi
|
|
fi
|
|
|
|
if [ $START_HIL == 1 ]; then
|
|
$autotest/run_in_terminal_window.sh "JSBSim" $autotest/jsb_sim/runsim.py --home $SIMHOME --speedup=$SPEEDUP || exit 1
|
|
fi
|
|
|
|
trap kill_tasks SIGINT
|
|
|
|
# mavproxy.py --master tcp:127.0.0.1:5760 --sitl 127.0.0.1:5501 --out 127.0.0.1:14550 --out 127.0.0.1:14551
|
|
options=""
|
|
if [ $START_HIL == 0 ]; then
|
|
options="--master $MAVLINK_PORT --sitl $SIMOUT_PORT"
|
|
fi
|
|
|
|
# If running inside of a vagrant guest, then we probably want to forward our mavlink out to the containing host OS
|
|
if [ $USER == "vagrant" ]; then
|
|
options="$options --out 10.0.2.2:14550"
|
|
fi
|
|
options="$options --out 127.0.0.1:14550 --out 127.0.0.1:14551"
|
|
extra_cmd1=""
|
|
if [ $WIPE_EEPROM == 1 ]; then
|
|
extra_cmd="param forceload $autotest/$PARMS; $EXTRA_PARM; param fetch"
|
|
fi
|
|
if [ $START_ANTENNA_TRACKER == 1 ]; then
|
|
options="$options --load-module=tracker"
|
|
extra_cmd="$extra_cmd module load map; tracker set port $TRACKER_UARTA; tracker start;"
|
|
fi
|
|
if [ $START_HIL == 1 ]; then
|
|
options="$options --load-module=HIL"
|
|
fi
|
|
if [ $USE_MAVLINK_GIMBAL == 1 ]; then
|
|
options="$options --load-module=gimbal"
|
|
fi
|
|
if [ $DELAY_START != 0 ]; then
|
|
sleep $DELAY_START
|
|
fi
|
|
|
|
if [ -f /usr/bin/cygstart ]; then
|
|
cygstart -w "/cygdrive/c/Program Files (x86)/MAVProxy/mavproxy.exe" $options --cmd="$extra_cmd" $*
|
|
else
|
|
mavproxy.py $options --cmd="$extra_cmd" $*
|
|
fi
|
|
if [ $START_HIL == 0 ]; then
|
|
kill_tasks
|
|
fi
|