English | 日本語
This repository is a simulation environment for drone plant models that can be integrated with PX4. This simulation environment accurately models drone behavior based on physical equations and is implemented in C language.
- Features
- Environment
- Preliminary Preparations
- Installation Instructions for hakoniwa-px4sim
- Installation Instructions for Hakoniwa
- Simulation Execution Instructions
- Integration with MATLAB
- Effects from the Environment
- Headless Simulation
- Log Replay
- Support for AR Devices
- Support for Battery
- Community and Support
- About This Repository and License
- Contribution Guidelines
-
Physics-based Plant Model: Drone behavior is represented by high-precision models based on physics. Developed in C language, it seamlessly integrates with PX4. For more details, please refer here. It is capable of simulating physical reactions in real-time during collisions with obstacles (
v1.1.0
). For more details, see here. -
Visualization via Game Engines: The visual representation of drones is realized using game engines. This visualization serves as an aid to physical simulations, primarily aimed at visualization purposes. Visual representation of collisions with obstacles is also possible (
v1.1.0
). For more details, see here. -
Engine Flexibility: Currently supports the Unity engine, but the architecture is designed to enable integration with other game engines as well. A plugin for integration with Unreal Engine is available here (
v1.1.0
). -
Compatibility with MATLAB/Simulink: The physics model can be integrated with models created in MATLAB/Simulink. For more details, see here.
-
Sensor Model Organization: Sensor models are organized within the architecture based on clear specifications. This allows users to exchange sensor models according to the specifications. For each sensor specification, please refer here. For instructions on how to create sensors for each vendor, please refer to here.
-
Headless Support: Simulation can be run without Unity. This enables simulation execution in environments that do not require a graphical interface. For more details, see here.
-
Support for Automated Testing: Enables test scenario-based automated testing. This makes it possible to automate repeated and consecutive tests, thereby streamlining the development process. For more details, please refer here.
-
External Parameterization of Aircraft Characteristics: The characteristics of the drone can be parameterized externally. This allows for simulations tailored to various aircraft characteristics, enabling support for a wider range of test scenarios. For an example of parameter settings, see here.
-
Multi-Aircraft Support: By preparing multiple sets of drone airframe characteristic parameters, it is possible to simulate several aircraft simultaneously. For details, see here.
-
Python API Support: It's possible to control the aircraft via the Python API without using PX4 or QGC. For details, see here. Additionally, you can control the drone using a PS4 controller. For more details, please visit here. For an explanation of the control program driven by the Python API, please refer to here.
-
Log Replay: You can replay the flight trajectory of the drones from the log data recorded during the drone simulation execution. For more details, see here.
-
Support for Environmental Factors: The drone simulation includes environmental factors such as wind, temperature, and humidity. These factors can be externally defined, allowing disturbances like wind to affect the drone's trajectory. Environmental factors can be configured according to the simulation scenario. For sample implementations and configuration files for the environmental models, refer to this document.
-
Support for AR Devices: By wearing an AR device, you can experience the drone being simulated in Hakoniwa in real-time right in front of you. For more details, see here.
-
Web Browser Support: You can visualize the Hakoniwa Drone Simulation in a web browser. The visualization is made possible by registering the Hakoniwa Web Server as a Hakoniwa asset. The Hakoniwa Web Server shares Hakoniwa PDU data (such as the drone’s position information) through WebSocket, allowing real-time visualization of the data in a web browser. For setup and usage instructions for the Hakoniwa Web Server, see here.
-
Support for Battery: It is possible to simulate the battery voltage model for Hakoniwa drones. The battery voltage model can be configured using the aircraft parameters. When the battery level drops below a certain threshold, the drone's flight becomes restricted. For details on how to configure the battery voltage model see here.
- Supported OS:
- Arm-based Macs (M1 Mac, M2 Mac)
- Windows 10/11
- Windows WSL2
- Ubuntu 22.0.4
- Required Environment:
- Python 3.12
- jq
- cmake
- googletest
- For Arm-based Macs:
- Recommended to install via pyenv for python version control
- Jinja2 (
pip install -U jinja2
)
- For WSL:
- Follow the same setup as the Hakoniwa configuration example for WSL.
- Check Script:
- To verify that all the required environments are correctly installed, you can use the following command:
bash hako-setup-check.bash
- To verify that all the required environments are correctly installed, you can use the following command:
- Drones to Use:
- https://github.com/toppers/hakoniwa-unity-drone-model/tree/main
- Please clone in the same directory structure as this repository:
hakoniwa-unity-drone-model/ hakoniwa-px4sim/
Clone two repositories:
git clone --recursive https://github.com/toppers/hakoniwa-px4sim.git
git clone --recursive https://github.com/toppers/hakoniwa-unity-drone-model.git
For the installation instructions of hakoniwa-unity-drone-model, please refer to the following:
https://github.com/toppers/hakoniwa-unity-drone-model
Follow the steps below to install PX4:
https://github.com/toppers/hakoniwa-px4sim/tree/main/px4
Follow the steps below to install Hakoniwa:
https://github.com/toppers/hakoniwa-px4sim/tree/main/hakoniwa
Prepare two terminals:
- Terminal A: For running the PX4 simulator
- Terminal B: For running Hakoniwa
Navigate to the PX4-Autopilot directory:
cd hakoniwa-px4sim/px4/PX4-Autopilot
Launch PX4 on SITL:
For Windows:
bash ../sim/win-simstart.bash
not Windows:
bash ../sim/simstart.bash
Upon successful execution, it will wait for a connection on a TCP port as follows.
% bash ../sim/simstart.bash
[0/1] launching px4 none_iris (SYS_AUTOSTART=10016)
______ __ __ ___
| ___ \ \ \ / / / |
| |_/ / \ V / / /| |
| __/ / \ / /_| |
| | / /^\ \ \___ |
\_| \/ \/ |_/
px4 starting.
INFO [px4] startup script: /bin/sh etc/init.d-posix/rcS 0
env SYS_AUTOSTART: 10016
INFO [param] selected parameter default file parameters.bson
INFO [param] importing from 'parameters.bson'
INFO [parameters] BSON document size 568 bytes, decoded 568 bytes (INT32:14, FLOAT:13)
INFO [param] selected parameter backup file parameters_backup.bson
INFO [dataman] data manager file './dataman' size is 7868392 bytes
INFO [init] PX4_SIM_HOSTNAME: localhost
INFO [simulator_mavlink] Waiting for simulator to accept connection on TCP port 4560
Continuing from the previous step, we now switch to Terminal B.
Navigate to the Hakoniwa directory:
cd hakoniwa-px4sim/hakoniwa
If you are using WSL, enter the Docker container with the following command:
bash docker/run.bash <path/to/hakoniwa-unity-drone-model>
Execute the script to launch Hakoniwa:
bash run.bash
Upon successful execution, it will proceed as follows.
% bash run.bash
HAKO_CAPTURE_SAVE_FILEPATH : ./capture.bin
HAKO_BYPASS_IPADDR : 127.0.0.1
HAKO_CUSTOM_JSON_PATH : ../config/custom.json
DRONE_CONFIG_PATH : ../config/drone_config.json
HAKO_BYPASS_PORTNO : 54001
INFO: shmget() key=255 size=1129352
INFO: hako_master_init() success
Robot: DroneAvator, PduWriter: DroneAvator_drone_motor
channel_id: 0 pdu_size: 88
INFO: DroneAvator create_lchannel: logical_id=0 real_id=0 size=88
Robot: DroneAvator, PduWriter: DroneAvator_drone_pos
channel_id: 1 pdu_size: 48
INFO: DroneAvator create_lchannel: logical_id=1 real_id=1 size=48
WAIT START
INFO: px4 reciver start
INFO: COMMAND_LONG ack sended
At this point, on Terminal A, you may see messages regarding poll timeouts like the following, but this is not a cause for concern.
ERROR [simulator_mavlink] poll timeout 0, 111
ERROR [simulator_mavlink] poll timeout 0, 111
ERROR [simulator_mavlink] poll timeout 0, 111
In this state, please start the Unity simulation.
Then, by pressing the START
button, the simulation will begin.
At this time, Terminal A will enter a ready state as follows.
INFO [lockstep_scheduler] setting initial absolute time to 1699681315573127 us
INFO [commander] LED: open /dev/led0 failed (22)
WARN [health_and_arming_checks] Preflight Fail: ekf2 missing data
INFO [mavlink] mode: Normal, data rate: 4000000 B/s on udp port 18570 remote port 14550
INFO [mavlink] mode: Onboard, data rate: 4000000 B/s on udp port 14580 remote port 14540
INFO [mavlink] mode: Onboard, data rate: 4000 B/s on udp port 14280 remote port 14030
INFO [mavlink] mode: Gimbal, data rate: 400000 B/s on udp port 13030 remote port 13280
INFO [logger] logger started (mode=all)
INFO [logger] Start file log (type: full)
INFO [logger] [logger] ./log/2023-11-11/05_41_55.ulg
INFO [logger] Opened full log file: ./log/2023-11-11/05_41_55.ulg
INFO [mavlink] MAVLink only on localhost (set param MAV_{i}_BROADCAST = 1 to enable network)
INFO [mavlink] MAVLink only on localhost (set param MAV_{i}_BROADCAST = 1 to enable network)
INFO [px4] Startup script returned successfully
pxh> INFO [tone_alarm] home set
INFO [tone_alarm] notify negative
INFO [commander] Ready for takeoff!
At this point, please execute the following command in Terminal A:
commander takeoff
Upon success, the drone in Unity will start hovering.
To stop the simulation, please follow these steps in order:
- Stop the Unity simulation.
- Stop the PX4 simulation with CTRL+C.
- Stop the Hakoniwa simulation with CTRL+C.
By installing QGroundControl, you can control the aircraft from QGC.
After launching QGC, you need to set up the connection with PX4.
Click on the logo at the top right of the screen to access the "Application Settings," as shown in the image below.
Next, click on "Comm Links" and then press the "Add" button.
Make the necessary settings.
Set the following:
- Name:
hakoniwa
(you can specify any name you like) - Type:
UDP
- Port:
18570
- Server Address: The setting differs depending on the OS
- For WSL: On WSL2, check and set the IP address of eth0.
- For non-WSL: Check and set the IP address of your ethernet.
Example of how to check the IP address:
$ ifconfig eth0
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST> mtu 1500
inet 172.29.246.4 netmask 255.255.240.0 broadcast 172.29.255.255
inet6 fe80::215:5dff:feae:5d59 prefixlen 64 scopeid 0x20<link>
ether 00:15:5d:ae:5d:59 txqueuelen 1000 (Ethernet)
RX packets 2104410 bytes 2461696811 (2.4 GB)
RX errors 0 dropped 0 overruns 0 frame 0
TX packets 1152573 bytes 1569239960 (1.5 GB)
TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
After setting up, press the "Add Server" button and then click the "OK" button.
Finally, clicking the "Connect" button will complete the setup.
Below is an example of operating QGC:
qgc-op.mp4
- Takeoff
- Move east
- Move north
From version v2.0.0 onwards, the feature to generate code from models created in MATLAB/Simulink and simulate them on Hakoniwa has been supported.
Currently, the supported features are as follows:
- Drone Physics Model
- Sensor Model
- Actuator Model
The process of migrating models from MATLAB/Simulink to the Hakoniwa simulation environment is as illustrated below.
Currently, the flow involves constructing drone physics models for a predefined C interface in Hakoniwa. Future updates are planned to develop the workflow further, including interface definitions and incorporating sensors/actuators.
- MATLAB/Simulink Hakoniwa Templates
- MATLAB/Simulink Process
- With the Hakoniwa input/output interfaces defined in the template, create a model that converts input data to output data.
- Simulate and check the created model in MATLAB.
- After verifying the simulation in MATLAB, generate C code.
- Hakoniwa Simulation Process
- Place the generated C code under
matlab-if
in hakoniwa-px4sim. - Edit the
CMakeLists.txt
undermatlab-if
to include it in the build targets (inside theHAKONIWA_MATLAB_BUILD
block). - Compile according to the Hakoniwa build process.
- Once compilation is successful, proceed with the simulation according to the Hakoniwa simulation execution process.
- Place the generated C code under
From version v1.1.0 onwards, it is possible for the drone in the simulation environment to be affected by external environmental factors.
For instance, using a game engine, it is possible to simulate in real-time the physical impact of a drone colliding with an obstacle.
The current support situation is as follows:
- Collision with obstacles
- Impact of wind
- Effects of direct sunlight
By placing obstacles within the game engine, information about the aircraft's interaction with these obstacles can be fed back to the physical model.
To use this feature, set the collision_detection
parameter in droneDynamics
to true
.
Example of settings:
"droneDynamics": {
"physicsEquation": "BodyFrame",
"collision_detection": true,
"manual_control": false,
"airFrictionCoefficient": [ 0.0001, 0.0 ],
"inertia": [ 0.0000625, 0.00003125, 0.00009375 ],
"mass_kg": 0.1,
"body_size": [ 0.1, 0.1, 0.01 ],
"position_meter": [ 0, 0, 0 ],
"angle_degree": [ 0, 0, 0 ]
},
Example of execution:
2024-01-26.7.21.53.mov
In Hakoniwa, drones can be tested for PID control without the use of Unity and PX4 (headless simulation). This is convenient for checking the operation of the drone dynamics you have created.
Here are the two methods for creating programs with headless simulation:
- Method of building and integrating with the sandbox build process
- Method of integrating as a loadable module
By preparing multiple sets of drone airframe characteristic parameters, it is possible to simulate several aircraft simultaneously.
To simulate multiple aircraft simultaneously, the following preliminary preparations are required:
Example: For two aircraft
hakoniwa/config
├── drone_config_0.json
└── drone_config_1.json
The format for the airframe parameter files should be as follows:
drone_config_<index>.json
<index>
should be a sequential number starting from 0.
For each aircraft's parameters, please set the following items appropriately:
- name
- Match the name with the Unity aircraft name. Example: DroneAvatar1
- components.droneDynamics.position_meter
- Set the initial position of the aircraft. Specify a location that does not overlap with other aircraft.
- In the Unity editor, place drone avatars for each set of aircraft parameters. The drone avatar name and the "name" in the aircraft parameters must match.
- In the Unity editor, execute
Generate
, then copy and place the generatedcustom.json
fromhakoniwa-unity-drone-model
intohakoniwa/config/custom.json
.
To launch PX4 in multiple instances, you need to prepare the PX4 filesystem for each aircraft.
Copy and place the existing build directory as follows:
Example: For two aircraft
cd px4/PX4-Autopilot
cp -rp build build-0
cp -rp build build-1
The format for the build directory name should be:
build-<index>
<index>
should be a sequential number starting from 0.
Add port numbers for the second and subsequent aircraft in the communication link settings.
The port number should be 18570 + <index>
, where <index>
is a sequential number starting from 0.
The method for running the simulation is the same as for a single aircraft.
However, PX4 needs to be launched for each aircraft, so please start it with the following command, specifying the aircraft number:
bash ../sim/simstart.bash <index>
Example: For the first aircraft
bash ../sim/simstart.bash 0
Example: For the second aircraft
bash ../sim/simstart.bash 1
In the Hakoniwa Drone Simulator, logs are recorded for each drone during simulation execution.
The log file is located at hakoniwa-px4sim/hakoniwa/drone_log0/drone_dynamics.csv
.
Using this log information, you can replay the flight trajectory of the drones.
The log replay should be executed in the same directory where the simulation was run (hakoniwa-px4sim/hakoniwa
).
Additionally, it is assumed that hakoniwa-unity-drone-model
is in the same directory hierarchy as hakoniwa-px4sim
.
.
├── hakoniwa-unity-drone-model
└── hakoniwa-px4sim
To execute the log replay, follow these steps:
bash replay.bash
Start Unity for hakoniwa-unity-drone-model
and begin the simulation. The drones will replicate the movements from the original simulation.
Using an AR device, you can visualize the drone being simulated in real-time, allowing you to experience its behavior in the physical space right in front of you. This enables users to directly observe the simulation results, creating a unique interaction between the simulated and real-world environments.
- Oculus Quest 3 or another supported AR device
- PC (with Unity development environment installed)
- Hakoniwa Drone Simulator (AR-supported version)
To experience the drone simulation using an AR device, you will need to create a dedicated app. For instructions and required settings, please refer to the links below:
You can simulate the battery voltage model for Hakoniwa drones. The battery voltage model can be configured through the aircraft parameters. When the battery level falls below a certain threshold, the drone's flight will be restricted.
The following steps outline how to configure the battery voltage model:
"battery": {
"vendor": "None",
"model": "linear",
"BatteryModelCsvFilePath": "./config/battery_model.csv",
"VoltageLevelGreen": 12.1,
"VoltageLevelYellow": 11.1,
"CapacityLevelYellow": 3,
"NominalVoltage": 14.8,
"NominalCapacity": 4.0,
"EODVoltage": 3.0
}
The model
parameter allows you to choose from three types of battery voltage models:
constant
: A model where the voltage remains constant.linear
: A model where the voltage decreases linearly.custom
: A model defined using a CSV file.
If you select the custom
model, specify the path to the CSV file in BatteryModelCsvFilePath
.
VoltageLevelGreen
: Minimum value [V] for the Green voltage level.VoltageLevelYellow
: Minimum value [V] for the Yellow voltage level.CapacityLevelYellow
: Minimum capacity [Ah] for the Yellow capacity level.
NominalVoltage
: Nominal voltage [V], the standard operating voltage of the battery.NominalCapacity
: Nominal capacity [Ah], the theoretical amount of charge the battery can supply.EODVoltage
: End-of-discharge voltage [V].
If you select custom
for the model
, define the battery voltage model in the file specified by BatteryModelCsvFilePath
.
Example Configuration:
Temperature (°C) | Discharge Capacity (Ah) | Voltage (V) |
---|---|---|
45 | 0.0 | 14.8 |
45 | 0.1 | 14.6 |
45 | 0.2 | 14.5 |
45 | 0.3 | 14.4 |
45 | 0.4 | 14.3 |
Questions and discussions about this project take place on the Hakoniwa Community Forum. Here, you can resolve doubts about the project, share ideas, and provide feedback. Information on the latest news and updates about the project is also shared here.
If you have questions or suggestions about the project, or if you want to exchange opinions with other users facing the same issues, please feel free to post here.
The content of this repository is open under the license specified in each file. For content that is not specifically licensed, it is published under the TOPPERS License.
The TOPPERS License is a license for open-source projects, setting conditions for the use, modification, and distribution of software. For details about the license, please refer to the link above.
Thank you for your interest in contributing to this project. Contributions of various forms are welcomed. Below are guidelines for contributing to the project.
- Please use GitHub Issues to report bugs or suggest new features.
- Before creating an issue, check if there is already an existing issue on the same topic.
- When creating an issue, provide as much information as possible, including steps to reproduce, expected behavior, actual behavior, and your environment.
- Contributions related to code, such as adding new features or fixing bugs, should be made through pull requests.
- For adding new features or making significant changes, it is recommended to discuss it in a related issue beforehand.
- Please follow the existing code style and coding standards to maintain consistency.
- Use Discussions for project-related discussions and questions.
- Communicate with other contributors with respect.
- Improvements to documentation and translations, among other non-code contributions, are also welcome.