@ECHO OFF REM Run script as administrator %1 mshta vbscript:CreateObject("Shell.Application").ShellExecute("cmd.exe","/c ""%~s0"" ::","","runas",1)(window.close)&&exit REM Set the path of the RflySim tools if not defined PSP_PATH ( SET PSP_PATH=E:\PX4PSP SET PSP_PATH_LINUX=/mnt/e/PX4PSP ) REM Start index of vehicle number (should larger than 0) REM This option is useful for simulation with multi-computers SET /a START_INDEX=4 REM Set the start UDP port for SIMULINK/OFFBOARD API REM This option should not be modified for swarm simulation SET /a UDP_START_PORT=20100 REM Set use DLL model name or not, use number index or name string REM This option is useful for simulation with other types of vehicles instead of multicopters set DLLModel=CarNoCtrl REM Check if DLLModel is a name string, if yes, copy the DLL file to CopterSim folder SET /A DLLModelVal=DLLModel if %DLLModelVal% NEQ %DLLModel% ( REM Copy the latest dll file to CopterSim folder copy /Y "%~dp0"\%DLLModel%.dll %PSP_PATH%\CopterSim\external\model\%DLLModel%.dll ) REM Set the simulation mode on CopterSim, use number index or name string REM e.g., SimMode=2 equals to SimMode=PX4_SITL_RFLY set SimMode=2 REM Set the vehicle-model (airframe) of PX4 SITL simulation, the default airframe is a quadcopter: iris REM Check folder Firmware\ROMFS\px4fmu_common\init.d-posix for supported airframes (Note: You can also create your airframe file here) REM E.g., fixed-wing aircraft: PX4SitlFrame=plane; small cars: PX4SitlFrame=rover set PX4SitlFrame=r1_rover REM Set the map, use index or name of the map on CopterSim REM e.g., UE4_MAP=1 equals to UE4_MAP=Grasslands SET UE4_MAP=OldFactory REM Set the origin x,y position (m) and yaw angle (degree) at the map SET /a ORIGIN_POS_X=-250 SET /a ORIGIN_POS_Y=-119 SET /a ORIGIN_YAW=0 REM Set the interval between two vehicle, unit:m SET /a VEHICLE_INTERVAL=3 REM Set broadcast to other computer; 0: only this computer, 1: broadcast; or use IP address to increase speed REM e.g., IS_BROADCAST=0 equals to IS_BROADCAST=127.0.0.1, IS_BROADCAST=1 equals to IS_BROADCAST=255.255.255.255 SET IS_BROADCAST=0 REM Set UDP data mode; 0: UDP_FULL, 1:UDP_Simple, 2: Mavlink_Full, 3: Mavlink_simple. input number or string REM e.g., UDPSIMMODE=1 equals to UDPSIMMODE=UDP_Simple SET UDPSIMMODE=1 :Top ECHO. ECHO --------------------------------------- REM Max vehicle number 50 SET /a MAX_VEHICLE=50 REM SET /P VehicleNum=Please input UAV swarm number: SET /A VehicleNum=3 SET /A Evaluated=VehicleNum if %Evaluated% EQU %VehicleNum% ( IF %VehicleNum% GTR 0 ( IF %VehicleNum% GTR %MAX_VEHICLE% ( ECHO The vehicle number is too large, which may cause a crash pause ) GOTO StartSim ) ECHO Not a positive integer GOTO Top ) ELSE ( ECHO Not a integer GOTO Top ) :StartSim SET /A VehicleTotalNum=%VehicleNum% + %START_INDEX% - 1 if not defined TOTOAL_COPTER ( SET /A TOTOAL_COPTER=%VehicleTotalNum% ) set /a sqrtNum=1 set /a squareNum=1 :loopSqrt set /a squareNum=%sqrtNum% * %sqrtNum% if %squareNum% EQU %TOTOAL_COPTER% ( goto loopSqrtEnd ) if %squareNum% GTR %TOTOAL_COPTER% ( goto loopSqrtEnd ) set /a sqrtNum=%sqrtNum%+1 goto loopSqrt :loopSqrtEnd REM QGCPath REM tasklist|find /i "QGroundControl.exe" || start %PSP_PATH%\QGroundControl\QGroundControl.exe ECHO Start QGroundControl REM UE4Path cd %PSP_PATH%\RflySim3D REM tasklist|find /i "RflySim3D.exe" || start %PSP_PATH%\RflySim3D\RflySim3D.exe REM choice /t 5 /d y /n >nul REM tasklist|find /i "CopterSim.exe" && taskkill /im "CopterSim.exe" ECHO Kill all CopterSims REM CptSmPath cd /d %PSP_PATH%\CopterSim set /a cntr=%START_INDEX% set /a endNum=%VehicleTotalNum%+1 set /a portNum=%UDP_START_PORT%+((%START_INDEX%-1)*2) :loopBegin set /a PosXX=((%cntr%-1) / %sqrtNum%)*%VEHICLE_INTERVAL% + %ORIGIN_POS_X% set /a PosYY=((%cntr%-1) %% %sqrtNum%)*%VEHICLE_INTERVAL% + %ORIGIN_POS_Y% start /realtime CopterSim.exe 1 %cntr% %portNum% %DLLModel% %SimMode% %UE4_MAP% %IS_BROADCAST% %PosXX% %PosYY% %ORIGIN_YAW% 1 %UDPSIMMODE% choice /t 1 /d y /n >nul set /a cntr=%cntr%+1 set /a portNum=%portNum%+2 if %cntr% EQU %endNum% goto loopEnd goto loopBegin :loopEnd REM Set ToolChainType 1:Win10WSL 3:Cygwin SET /a ToolChainType=1 if "%IS_BROADCAST%" == "0" ( SET IS_BROADCAST=0 ) else ( SET IS_BROADCAST=1 ) SET WINDOWSPATH=%PATH% if %ToolChainType% EQU 1 ( wsl echo Starting PX4 Build; cd %PSP_PATH_LINUX%/Firmware; ./BkFile/EnvOri.sh; export PATH=$HOME/ninja:$HOME/gcc-arm-none-eabi-7-2017-q4-major/bin:$PATH;make px4_sitl_default; ./Tools/sitl_multiple_run_rfly.sh %VehicleNum% %START_INDEX% %PX4SitlFrame%;echo Press any key to exit; read -n 1 ) else ( REM CYGPath cd %PSP_PATH%\CygwinToolchain CALL setPX4Env.bat bash -l -i -c 'echo Starting SITL SIMULATION; cd %PSP_PATH_LINUX%/Firmware; ./BkFile/EnvOri.sh; pwd; make px4_sitl_default; ./Tools/sitl_multiple_run_rfly.sh %VehicleNum% %START_INDEX% %PX4SitlFrame%;echo Press any key to exit; read -n 1; pkill -x px4 || true;' ) SET PATH=%WINDOWSPATH% REM kill all applications when press a key tasklist|find /i "CopterSim.exe" && taskkill /im "CopterSim.exe" tasklist|find /i "QGroundControl.exe" && taskkill /f /im "QGroundControl.exe" tasklist|find /i "RflySim3D.exe" && taskkill /f /im "RflySim3D.exe" ECHO Start End.