ROSplane is limited-feature fixed-wing autopilot built around ROS. It is intended to be flown with ROSflight as the hardware I/O or in the Gazebo simulation environment. It is built according to the method published in Small Unmanned Aircraft: Theory and Practice by Beard and McLain, so as to allow anyone to easily understand, modify and use the code. This framework is inherently modular and extensively documented so as to aid the user in understanding and extending for personal use.
This repository features three ROS packages: rosplane, rosplane_msgs, and rosplane_sim. The contents of each of these three packages are described below.
To fly in hardware, ROSplane is intended to be used with ROSflight and a flip32/naze32 running the ROSflight firmware.
To fly in simulation, simply build these packages in a catkin workspace and launch fixedwing.launch:
$ roslaunch rosplane_sim fixedwing.launch
rosplane contains the principal nodes behind the ROSplane autopilot. Each node is separated into a _base.h/.cpp and a _example.h/.cpp in an attempt to abstract the ROS code from the guidance and control code covered in Small Unmanned Aircraft: Theory and Practice. Each node is described below.
The estimator is a standard ekf, as defined mostly in the way in the reference above. It has a attitude filter and a position filter for gps smoothing. We are estimating position, velocity, and attitude. The state is then published in the rosplane_msgs/msg/State.msg.
Implements a nested PID controller according to the revefereance above. Requires State and Controller_Commands messages to be published. Altitude is controlled in a longitudinal state machine including take-off, climb, desend, and hold zones. Controller can be tuned using rqt_reconfigure.
Gets the aircraft onto a Current_Path using vector fields. Chi_inf along with K_path and K_orbit gains can also be tuned using rqt_reconfigure.
Receives Waypoint messages and creates a path (straight line, fillet, or Dubins) to acheive all the waypoints.
rosplane_msgs is a ROS package containing the custom message types for ROSplane. These message types include Controller_Commands, Controller_internals, Current_Path, State, and Waypoint.
rosplane_sim contains all the necessary plugins to fly the ROSplane autopilot in the Gazebo simulation. Fixedwing.launch launches a basic simulation with the ROSplane autopilot. rosflight_sil.launch launches a software-in-the-loop simulation for a fixedwing running the ROSflight firmware. An example .yaml file is also included for the simulated airframe.