This is a fork of the Betaflight flight control software. For up-to-date general information about Betaflight, visit the upstream github.
I'm a newcomer to the drone community, where I came together with my son.
My objective is to understand the way the flight controller works in order to be able to extend it with new control algorithms. The medium-term objective I have is to be able to allow my quad drone to maintain a stick in equilibrium on top of it. This is a form of inverted pendulum, and a nice ersatz for the basic control problems behind space launchers.
For now, I have managed to:
- Order the hardware and build the drone.
- Sort out the initial communication and configuration problems (charging a battery, assigning aux channels...). All of this is new for me.
- Recompile betaflight and flash it (and the drone still works!).
- Recompilation is done under full control, with my own scripts extracted from the automated compilation process.
- Identify the basic elements of the computer hardware and software of my SpeedyBee f405 v4 flight controller stack:
- determine exactly what files get compiled for my configuration, and under which options...
- interrupt vectors, and I determined which vectors are non-empty. For instance SpeedyBee does not use SVC. The result of this analysis is under tasks-and-interrupts.txt.
- tasks (and periods, priorities, functions to call...). The data is also under tasks-and-interrupts.txt.
- the PID controller, which is one of the tasks.
- I don't yet have the link from interrupts to tasks (and I did not yet understand the scheduling algorithm).
- Start to understand the basics of rate adjusting (for throttle, pitch, roll, yaw), which will allow me at some point to achieve stable flight indoors. The drone I bought is a tad too powerful. But I needed it this way, in order to support, when the project is completed, the inverted pendulum stick. This means that the learning curve for piloting is steep (I already learned to have a lot of respect for the propellers, after one of them tried to grind one of my fingers).
- I have started to play with the configuration of the rates, but the result is not yet intuitive to me, even though I have drastically reduced the max power on throttle and the 3 degrees of freedom.
- Add ibus telemetry, following the instruction of this page. This required a diode, a resistor, and some soldering. I am really impressed at how easy it was to re-configure the drone afterwards using the configurator app.
The next steps, not necessarily in order:
- General drone management and control objectives:
- Flash to the FS-I6 transmitter and the fs-ai6b receiver to add 10 channels (under ibus protocol).
- Further tune the rates to allow indoors stable non-jittery flight. My next tests try will use very small rates (already programmed into the drone).
- Add the propeller protections.
- Advanced drone management and control objectives:
- Study if it is possible to control the emitter (or the drone, directly) using a PC. I wonder if it is possible to use PC-based Machine Learning to control the drone.
- Add a small echolocator or LIDAR to measure distance to ground and then maintain altitude in a given mode without having to push throttle, or simply add a ceiling and make it so throttle cannot force breaking the ceiling.
- Objectives necessitating advanced changes of betaflight itself
- Add a UART-based tracing mechanism separate from the blackbox subsystem. As far as I understand, the blackbox subsystem is optimized for tracing key variables during normal execution, not for debugging or for tracing select internal variables with chosen precision. For now, it would seem that UARTs do not use DMAs for RX or TX.
- On my drone FC, 4 UARTs seem to be easily accessible through pins:
- UART1 - meant for use with the VTX
- UART2 - meant for use with the receiver
- UART3 - meant for use with the FPV cam
- UART6 - meant for use with GPS and compass
- Of these, I already use UART2 and plan to use UART6 for the intended purposes. However, for now I do not plan on using the VTX or the camera for now, so I can use their UARTs temporarily for debugging.
- What I plan, with either UART1 or UART3, is to enable it from the configurator, and then use it directly from the scheduler routine to log a small amount of data that will allow me to better understand the functioning of the scheduler.
- The initialization and serial communication routines can be found here. The first objective is to manage to transmit data between the
scheduler
function and the PC (and to add the needed wires in a way that allows disconnecting).
- On my drone FC, 4 UARTs seem to be easily accessible through pins:
- Better understand the SW and HW architecture, to see if I can modify the code in meaningful ways. The first step will be to fully determine which code is executed and which interrupts trigger it, and when:
- Determine whether the application uses preemptive scheduling. For now, I could not find any kind of context switch in the vector handlers. There is some code that is likely part of the HASH/HMAC peripheral/accelerator, but nothing in the .S files.
- If no context switch code is used, the software organization should be pretty simple. Some form of periodic control loop, plus some (non-preemptable) code on various interrupts. And I cannot have long tasks. Or maybe the Cortex M architecture has a separate set of registers for each vector?
- Determine how the scheduler works.
- Determine how the various devices trigger extra interrupts, most notably timers and DMAs.
- Determine how and when timers and DMAs are triggered.
- Imagine a new control law.
- Add a UART-based tracing mechanism separate from the blackbox subsystem. As far as I understand, the blackbox subsystem is optimized for tracing key variables during normal execution, not for debugging or for tracing select internal variables with chosen precision. For now, it would seem that UARTs do not use DMAs for RX or TX.
- As long-term objective, being a full-time embedded systems researcher, I would like to see if modern software design methods for embedded control systems (like those used for commercial aircraft control software) can be applied here.
In any case, I'm starting slow, one step at a time.