☆ ☆ ☆
If you like madflight, please give it a ☆ star
or fork it and contribute!
☆ ☆ ☆
madflight is a toolbox to build high performance flight controllers with Aduino IDE or PlatformIO for ESP32-S3 / ESP32 / RP2350 / RP2040 / STM32. A functional DIY flight controller can be build for under $10 from readily available development boards and sensor breakout boards.
Get started with the Arduino IDE or PlatformIO
Flight tested example programs for quadcopter and airplane are included. The example programs are only a couple hundred lines long, but contain the full flight controller logic. The nitty-gritty low-level sensor and input/output management is done by the madflight library.
The source code and website have extensive documentation explaning what the settings and functions do.
If you clone/download this repository you get the DEVELOPMENT version, which is BLEEDING EDGE - not flight tested at all, might not even compile, and will completely change in the next hour...
Use a release version if you want something that actually has logged flight hours.
- Development board:
- RP2350/RP2040 (e.g. Raspberry Pi Pico/Pico2)
- ESP32-S3/ESP32 (e.g. Espressiv ESP32/ESP32-S3 DevKitC)
- STM32 (e.g. Black Pill or a commercial flight controller)
- SPI/I2C IMU sensor (BMI270, MPU9250, MPU6500, MPU6000, MPU6050 or MPU9150)
- RC Receiver: MAVLink, ELRS, CRSF, SBUS, DMSX, or PPM
- BEC or DC-DC converter to power your board from a battery
- ESC (OneShot125 or 50-490Hz PWM) and/or servos (50-490Hz PWM)
- GPS Module (Serial)
- Barometer (I2C BMP390, BMP388, BMP280, MS5611)
- Magnetometer (I2C QMC5883L)
- Current/Voltage Sensor (ADC or I2C INA226, INA228)
- Optical Flow Sensor (I2C)
- Connect the required hardware (see below) to your controller board:
- See RP2350/RP2040 pinout and instructions
- -or- ESP32-S3/ESP32 pinout and instructions
- -or- STM32 pinout and instructions
- Connect your IMU (gyro/acceleration) sensor as shown here.
- Connect your radio receiver according to the configured pins.
- Install the madflight library in Arduino IDE. (Menu Tools->Manage Libraries, then search for madflight)
- Open Examples for custom libraries->madflight->Quadcopter.ino in the Arduino IDE.
- Edit the HARDWARE CONFIG section in madflight_config.h to enable the connected peripherals.
- If you're not using the default pinout then setup your board pinout in the CUSTOM PINS CONFIG section.
- Compile Quadcopter.ino and upload it to your board. Connect the Serial Monitor at 115200 baud and check the messages. Type
help
to see the available CLI commands. - Type
calradio
and follow the prompts to setup your RC radio receiver. - IMPORTANT: Use CLI
calimu
andcalmag
to calibate the sensors. - Use CLI commands
pimu
,pahr
,prcl
,pmot
, etc. and check that IMU sensor, AHRS and RC Receiver are working correctly. - Connect motors (no props) and battery and check that motors are spinning correctly.
- Mount props, go to an wide open space, and FLY!
For additional help see Discussions
This code is a shared, open source flight controller for small micro aerial vehicles and is intended to be modified to suit your needs. It is NOT intended to be used on manned vehicles. I do not claim any responsibility for any damage or injury that may be inflicted as a result of the use of this code. Use and modify at your own risk. More specifically put:
THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Logo image copyright (c) 1975 Deutsches MAD Magazine. This project is not associated with MAD Magazine.