List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino Boards
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 8: Control Laws!!!!
my favorite part, designing the control laws to fly the quadcopter
I started with a simple PID control law based on both attitude (angles) and rates. What I have right now is controlling pitch and roll angle and for yaw controlling yaw rate. I'll include a more detailed diagram later, as well as the code.
Sunday, August 4, 2013
Part 7: Designing a shield for the Due
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 7: Designing a shield for the Due
I started this project using an Arduino Mega and I ripped the headers off and soldered straight to the board. This became a nightmare. I needed to move some of the wires to new pins but it was going to be impossible to get in there to desolder and resolder them. Here is a picture of the rats nest. Also my ground "plane" was a blob of solder that had like 12 wires going into it... this was quite the kluge. Tons of heat shrink and electrical tape wrapped around stuff. Scared me flying the thing, a wire could come loose at any second or something could short out.
I wanted to completely re-do all of the wiring. At the same time computational needs were pushing me towards the Due with the 84Mhz ARM 32-bit chip. This will be hundreds of times faster than the Mega.
To do things the right way I needed to build a custom shield to sit on top of the Due to solder all of my connections into. I wanted to include plenty of room for expansion also which means:
8 motors
9 channel reciever
4 Serial devices (GPS, SD card data logger, bluetooth interface, and a sensor device)
plenty of I2C devices (pressure sensor, IMU alternative to serial)
voltage regulator (ignore this for now, I have a use for it much later)
LEDs (red, yellow, green for status)
a buzzer for notifications (during quad testing I found this helpful)
spare set of 5 to 3.3 volt conversions in case a sensor is a 5v system
digital pin with a switch (I envision putting LED's that strobe or something around the frame but I want the option to turn it off)
maintain holes for as many other pins as possible.
With all of that in mind I set out to design a board. From what I read there is one standard software package for designing PCBs: Eagle. They have a freeware version that allows you to make small boards. The Arduino Due footprint falls within the freeware allowance. I must note I have no experience at all designing boards at all, never used eagle. I found it to be very easy to use. You just drop pin holes in and then draw the routing in the 2 layers. It ends up becoming a sort of puzzle to get everything laid out. I used mostly the top layer for routing, leaving the bottom layer almost completely a ground plane. I only had to use 1 set of vias. Here is the eagle board layout, note I later filled the bottom planes open spaces with ground.
For anyone who hasn't used Eagle and is scared away from designing your board, don't be. Its very easy to learn and use.
So after spending hours and hours laying all of that out... it was time to send it to get fabricated. There is a service called OSHpark that combines many peoples small projects together then has them fabricated on a giant panel. It helps reduce the cost for people like me doing simple prototype boards. Their pricing is fairly reasonable and only takes a couple weeks. Took my board only a couple days to be sent to fabrication. Then hopefully only a week for me to get it back in the mail.
Here is the render I got form OSHpark as to what the final board should look like:
[waiting for board to arrive from OSHpark, more to follow soon]
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 7: Designing a shield for the Due
I started this project using an Arduino Mega and I ripped the headers off and soldered straight to the board. This became a nightmare. I needed to move some of the wires to new pins but it was going to be impossible to get in there to desolder and resolder them. Here is a picture of the rats nest. Also my ground "plane" was a blob of solder that had like 12 wires going into it... this was quite the kluge. Tons of heat shrink and electrical tape wrapped around stuff. Scared me flying the thing, a wire could come loose at any second or something could short out.
I wanted to completely re-do all of the wiring. At the same time computational needs were pushing me towards the Due with the 84Mhz ARM 32-bit chip. This will be hundreds of times faster than the Mega.
To do things the right way I needed to build a custom shield to sit on top of the Due to solder all of my connections into. I wanted to include plenty of room for expansion also which means:
8 motors
9 channel reciever
4 Serial devices (GPS, SD card data logger, bluetooth interface, and a sensor device)
plenty of I2C devices (pressure sensor, IMU alternative to serial)
voltage regulator (ignore this for now, I have a use for it much later)
LEDs (red, yellow, green for status)
a buzzer for notifications (during quad testing I found this helpful)
spare set of 5 to 3.3 volt conversions in case a sensor is a 5v system
digital pin with a switch (I envision putting LED's that strobe or something around the frame but I want the option to turn it off)
maintain holes for as many other pins as possible.
With all of that in mind I set out to design a board. From what I read there is one standard software package for designing PCBs: Eagle. They have a freeware version that allows you to make small boards. The Arduino Due footprint falls within the freeware allowance. I must note I have no experience at all designing boards at all, never used eagle. I found it to be very easy to use. You just drop pin holes in and then draw the routing in the 2 layers. It ends up becoming a sort of puzzle to get everything laid out. I used mostly the top layer for routing, leaving the bottom layer almost completely a ground plane. I only had to use 1 set of vias. Here is the eagle board layout, note I later filled the bottom planes open spaces with ground.
So after spending hours and hours laying all of that out... it was time to send it to get fabricated. There is a service called OSHpark that combines many peoples small projects together then has them fabricated on a giant panel. It helps reduce the cost for people like me doing simple prototype boards. Their pricing is fairly reasonable and only takes a couple weeks. Took my board only a couple days to be sent to fabrication. Then hopefully only a week for me to get it back in the mail.
Here is the render I got form OSHpark as to what the final board should look like:
[waiting for board to arrive from OSHpark, more to follow soon]
Part 6: Discussion on Arduino Boards
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 6: Discussion on Arduino Boards
I started with an Arduino Uno since I had several laying around. Realistically I was planning to use an Arduino Mega. So I got one, I ripped the headers off and desoldered the little clips. I've read online people saying this is hard to do, its really not. It took me maybe an hour. Just take some pliers to those black headers and bend them right off. Theres 2 little prongs under there you can just desolder off.
The problem I ran into with using the Mega was the number of interrupt routines it can use. I wanted 6 channels, while its totally possible, it wasn't real clear how to do this on the Mega. The computing power, being 8bit is severely limited. I want to be able to use doubles and not have to worry!
So I finally got a Due and this thing is awesome. Its quick and each pin can have an interrupt. It has everything I've ever wanted in a micro controller.... except a lot of libraries are still a work in progress like something as simple as tone() doesn't work. I've found workarounds for everything though. I still love how fast this thing is compared to the mega. My kalman filter runs in microseconds, can't even measure things in millis() anymore, now its all micros(). I am hoping to run my control loop at 200hz or more now, previously on the mega I was struggling to make 50hz.
After experience with the Mega, i decided to build a shield for the Due rather than rip the headers off. The next part details the design of the shield.
[place holder]
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 6: Discussion on Arduino Boards
I started with an Arduino Uno since I had several laying around. Realistically I was planning to use an Arduino Mega. So I got one, I ripped the headers off and desoldered the little clips. I've read online people saying this is hard to do, its really not. It took me maybe an hour. Just take some pliers to those black headers and bend them right off. Theres 2 little prongs under there you can just desolder off.
The problem I ran into with using the Mega was the number of interrupt routines it can use. I wanted 6 channels, while its totally possible, it wasn't real clear how to do this on the Mega. The computing power, being 8bit is severely limited. I want to be able to use doubles and not have to worry!
So I finally got a Due and this thing is awesome. Its quick and each pin can have an interrupt. It has everything I've ever wanted in a micro controller.... except a lot of libraries are still a work in progress like something as simple as tone() doesn't work. I've found workarounds for everything though. I still love how fast this thing is compared to the mega. My kalman filter runs in microseconds, can't even measure things in millis() anymore, now its all micros(). I am hoping to run my control loop at 200hz or more now, previously on the mega I was struggling to make 50hz.
After experience with the Mega, i decided to build a shield for the Due rather than rip the headers off. The next part details the design of the shield.
[place holder]
Part 5: IMU - Kalman Filter Orientation Estimator
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 5: IMU - Kalman Filter Orientation Estimator
Part 5A: Quaternion based Kalman Filter design
The kalman filter is the optimal estimator but comes at the price of computational time. There is a lot of matrix math and a matrix inversion that has to be done. But with the Arduino Due I should have plenty of power to handle it.
Part 5B: Simulink/Matlab simulation testing/tuning
I designed the Kalman filer and tuned it in Matlab/Simulink. I recorded data from my sensors and built up a noise model. Then fed the data into a kalman flter block running the same C-code as I put on the Arduino.
Part 5C: Arduino Code
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 5: IMU - Kalman Filter Orientation Estimator
Part 5A: Quaternion based Kalman Filter design
The kalman filter is the optimal estimator but comes at the price of computational time. There is a lot of matrix math and a matrix inversion that has to be done. But with the Arduino Due I should have plenty of power to handle it.
Part 5B: Simulink/Matlab simulation testing/tuning
I designed the Kalman filer and tuned it in Matlab/Simulink. I recorded data from my sensors and built up a noise model. Then fed the data into a kalman flter block running the same C-code as I put on the Arduino.
Part 5C: Arduino Code
Part 4: Sensors (reading in raw data, applying calibration)
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 4: Sensors (reading in raw data, applying calibration)
Just a warning, this section is going to be long. And post Part 4 is only half of it. This part only covers getting the sensor up and running and then applying a calibration to the sensor data. Part 5 will then be on how to use that data to determine which way the quadcopter is pointing.
Originally I had wanted to use the ATmega328 on the 9dof IMU razor board to offload the arduino and do all of the sensor data processing there, but that was when I was planning to use an Arduino mega. Now that I already bought the thing and am using an Arduino due, I want to do all the heavy lifting on the due side. All the ATmega needs to do is query each sensor and then send that data to the Arduino. Pretty lame I know, i might use the ATmega328 to do some filtering of the data, but for now its just a pass through. In reality I should have bought this chip for 25 dollars less:https://www.sparkfun.com/products/10724
I recommend anyone reading this planning to use a Due to get this rather than the 9dof imu razor. Just cut out the middle man ATmega328. Let the Due query the sensors for data itself. But it is what it is. If you do go this way you can take most of my code that I put on the ATmega328 and just put it on the Due instead. It should be EXACTLY the same, then you can delete all the junk I had to make to set up serial communication between the Due and the ATmega328. Or if you just want to use my code without having to modify it, just go with the 9dof Razor... The last section in this part, Part 4C is important though, the data must be calibrated before you use it, and the calibration process is nontrivial.
Part 4A: i2c communication to each individual sensor chip, ftdi programming ATmega328
Part 4B: Getting data to the arduino (setting up serail comm between ATmega328 and Arduino)
Part 4C: Calibration of sensor data
Part 4D: Final code
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 4: Sensors (reading in raw data, applying calibration)
Just a warning, this section is going to be long. And post Part 4 is only half of it. This part only covers getting the sensor up and running and then applying a calibration to the sensor data. Part 5 will then be on how to use that data to determine which way the quadcopter is pointing.
Originally I had wanted to use the ATmega328 on the 9dof IMU razor board to offload the arduino and do all of the sensor data processing there, but that was when I was planning to use an Arduino mega. Now that I already bought the thing and am using an Arduino due, I want to do all the heavy lifting on the due side. All the ATmega needs to do is query each sensor and then send that data to the Arduino. Pretty lame I know, i might use the ATmega328 to do some filtering of the data, but for now its just a pass through. In reality I should have bought this chip for 25 dollars less:https://www.sparkfun.com/products/10724
I recommend anyone reading this planning to use a Due to get this rather than the 9dof imu razor. Just cut out the middle man ATmega328. Let the Due query the sensors for data itself. But it is what it is. If you do go this way you can take most of my code that I put on the ATmega328 and just put it on the Due instead. It should be EXACTLY the same, then you can delete all the junk I had to make to set up serial communication between the Due and the ATmega328. Or if you just want to use my code without having to modify it, just go with the 9dof Razor... The last section in this part, Part 4C is important though, the data must be calibrated before you use it, and the calibration process is nontrivial.
Part 4A: i2c communication to each individual sensor chip, ftdi programming ATmega328
Part 4B: Getting data to the arduino (setting up serail comm between ATmega328 and Arduino)
Part 4C: Calibration of sensor data
Part 4D: Final code
Saturday, August 3, 2013
Part 2: Integrating rc transmitter and receiver with Arduino
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino (boards and oddities)
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 2: Integrating transmitter and receiver with Arduino
The following video is ultimately what you should end up with after this post and the next (parts 2 and 3). Part 2 is the transmitter and receiver, part 3 will be the esc and motor setup. Basically what I have is the transmitter in my hand is sending signals to the receiver which then sends that to the Arduino mico controller which read it in then sends a command back out to the ESC which controls the motor. In this post I'll detail how to wire all of this up and also include the c-code that I used on the Arduino.
Part 2A: Wiring up Receiver -> Arduino
First thing that needs to be said is the Arduino Due is a 3.3volt system and the receiver is a 5v system. So a 0 signal from the receiver is 0 volts and a 1 signal is 5v's. This 5v signal will destroy the arduino Due, it requires 0 to 3.3v. This is very very important and there is a very simple way to step down the 5v signal to 3.3v because 3.3 = 5*2/3. So the following circuit will do the job:
Where R1 = half of R2. You can pick R1 = 10k ohms then R2 would be 20k. Or R1 = 5k ohms and R2 = 10k. Instead of doing this yourself, you can get these tiny logic level shifters from sparkfun that do exactly this. Beware they have made a mistake and use 10k Ohms for each. This will be close but not exact but I've used them for a while now and have had no issue with frying the due. But I later fixed this anyways. I basically did this for all 6 channels. Here is 2 channels with a logic level board from sparkfun wired up:
Here is how its wired to the arduino. Sorry for the messy image, this was taken from a graphic of the entire wiring diagram for the quad. Here green signals are 0to5v, yellow are 0to3.3, orange is 3.3volt power, red is 5v power, black is ground. (please don't hate me for the color inconsistency between this and the picture I took above...)
Part 2B: Arduino code for reading in data from rc receiver.
Some quick background. The signal from the receiver is a PWM (or actually more accurately PPM). The receiver sends a pulse for each channel every so often thats about 1000 to 2000 microseconds long. So for the throttle a pulse that lasts 1000 microseconds means zero throttle, 2000 microseconds means full. Same for all channels, so with Elevator and aileron sticks centered the receiver sends a signal every so often that is 1500 microseconds long. If you push up, it will go to 2000 microseconds long, 1000 if you pull back on the stick. Fairly simple. The problem is when we connect that to the Arduino. Who knows when that signal is going to arrive and we need to very accurately measure exactly when it started and when it ended then we can calculate how long it was. To do this we use interrupt routines. Basically what this does is any time that pin goes from 0 to 1, the arduino stops what its doing and tells us "hey this pin just changed" so then we record the time of that event. If it changes from 1 to 0, we know thats the end of the signal then we can calculate how long it lasted. Again fairly straight forward. Here is the code to implement this. I stole a lot of this code from: http://rcarduino.blogspot.com/2012/01/how-to-read-rc-receiver-with.html I recommend reading this guys blog. He explains it wayyy better than me. The basics are: attach interrupt, write a intrupt routine that checks if pin went high or low and records time, then some fancy volatile variable use to store the recorded variable (fanciness is incase you get interrupted while writing to the variable, you will write half then write other half but the 2 halfs might not match so you do some programming logic to stop that)
Here is the code: (for just throttle and pitch stick)
=======================================================================
#define THROTTLE_PIN 53 // thro receiver signal connected to pin 53
#define ELEV_PIN 49 // ELEV receiver signal connected to pin 49
volatile boolean bNewSignal_throttle = false; //Used to determine if a new command w
volatile boolean bNewSignal_pitch = false;
volatile unsigned long ulStartPeriod_throttle = 0;
volatile unsigned long ulStartPeriod_pitch = 0;
volatile int throttle_pos_v = 1000; // _v set in ISR, stored for use in throttle_pos without _v
volatile int pitch_pos_v = 1500;
static int throttle_pos = 1000; //actual variable to use in code as the command
static int pitch_pos = 1500;
void setup() {
Serial.begin(19200);
attachInterrupt(THROTTLE_PIN,ISR_throttle,CHANGE); //(Pin, code to run when triggered - see
// ...function at end named ISR_throttle, type of trigger ie when pin changes)
attachInterrupt(ELEV_PIN,ISR_pitch,CHANGE);
}
void loop() {
//Update Input commands (trickery to prevent being interrupted while writing to the same variable)
noInterrupts();
if(bNewSignal_throttle)
{
throttle_pos = throttle_pos_v;
bNewSignal_throttle = false;
}
if(bNewSignal_pitch)
{
pitch_pos = pitch_pos_v;
bNewSignal_pitch = false;
}
interrupts();
Serial.print("Throttle:");
Serial.print(throttle_pos);
Serial.print("\t");
Serial.print("Pitch:");
Serial.print(pitch_pos);
Serial.print("\t");
Serial.println();
}
// Interrupt Routines
void ISR_throttle() {
if(digitalRead(THROTTLE_PIN) == HIGH) //means it went 0 to 1
ulStartPeriod_throttle = micros();
else // it went from 0 to 1, thus end of pulse
{
if(ulStartPeriod_throttle && (bNewSignal_throttle == false))
{
throttle_pos_v = (int)(micros() - ulStartPeriod_throttle);
ulStartPeriod_throttle = 0;
bNewSignal_throttle = true;
} }}
void ISR_pitch() {
if(digitalRead(ELEV_PIN) == HIGH)
ulStartPeriod_pitch = micros();
else
{
if(ulStartPeriod_pitch && (bNewSignal_pitch == false))
{
pitch_pos_v = (int)(micros() - ulStartPeriod_pitch);
ulStartPeriod_pitch = 0;
bNewSignal_pitch = true;
} }}
============================================================
That should do it, you should see the data on the serial display. Copy and paste code to add the other channels. Next up, using that data to then send a command to spin the motor.
Part 3: ESC and Motor (wiring and code)
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino Boards
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 3: ESC and Motor (wiring and code)
Detailed in this section is flashing the ESC's, wiring them up, and sending commands from the Arduino to control the motors.
Part 3A: Flashing ESCs
Okay so in the video in Part 2, you can hear the high pitch noise from the motor. Yah thats annoying so to get rid of that you have to run the ESC at a higher rate. A guy by the name of SimonK has done this for us. He also has optimized the programming for quadcopters. His firmware is the standard for qaudcopters. Read about it here: http://www.rcgroups.com/forums/showthread.php?t=1513678
For the ESC's that I have I found a very nice page that details step by step on how to flash them:
http://www.rchacker.com/diy/simonk-esc-firmware-flashing
Following these steps from start to finish it took me maybe 45 minutes. Worked great. Now my motors spin nice and quiet and awesome.
Essentially what you do is you first have to buy an AVR programmer to connect your computer to the ESC via USB to the MOSI, MISO, etc pins on the ESC to reprogram the chip. Then use some software from here:
http://lazyzero.de/en/modellbau/kkmulticopterflashtool
which then flashes the ESC with the SimonK software.
Part 3B: Wiring ESC and Motors
Wiring for motors is simple.3 plugs on motor, 3 similar plugs on ESC (or in my case no plugs and I had to buy and solder some bullet plugs onto the wires). Just make sure the middle plug from the ESC goes into middle cable of motor. The outer wires can be swaped. If you put the left one into right most on motor, the motor will spin on way. Do opposite and motor spins the other way.
Connect battery red and black to the ESC red and black wires (i soldered mine to the base plate of my frame and added some plugs).
Then the ESC has a servo plug (red brown orange cable. plug the brown into the ground on the arduino so that they have a common ground. Then the orange wire needs to be connected to a digital pin on the arduino:
Part 3C: Arduino Code for ESC and Motors
Okay so the ESC is looking for a signal exactly like the signal from the receiver, a PPM. So we need to send a pulse out the is x microseconds long where x is 1000 to 2000, with 1000 essentially being a 0 and 2000 meaning spin motor at full speed. Here is the code to do this, luckily Arduino has a library called servo that writes these pulses for us very easily.
The following code is integrated with the receiver code from the previous section, so now the throttle on the transmitter should control all four motors
====================================================================
#include <Servo.h> //standard arduino library to send signals to ESC
#define THROTTLE_PIN 53
#define MOTOR_1_PIN 36
#define MOTOR_2_PIN 38
#define MOTOR_3_PIN 40
#define MOTOR_4_PIN 42
//Receiver variables
volatile boolean bNewSignal_throttle = false;
volatile unsigned long ulStartPeriod_throttle = 0;
volatile int throttle_pos_v = 1000;
static int throttle_pos = 1000;
// Motor Vars: FR = front right, FL = front left, BR = back right...
int motor_fr_cmd = 1000;
int motor_fl_cmd = 1000;
int motor_br_cmd = 1000;
int motor_bl_cmd = 1000;
Servo motor_FR;
Servo motor_FL;
Servo motor_BR;
Servo motor_BL;
void setup() {
// Receiver interrupt routines
attachInterrupt(THROTTLE_PIN,ISR_throttle,CHANGE)
//Motor Servos
motor_FR.attach(MOTOR_1_PIN);
motor_FL.attach(MOTOR_2_PIN);
motor_BR.attach(MOTOR_3_PIN);
motor_BL.attach(MOTOR_4_PIN);
}
void loop() {
noInterrupts();
if(bNewSignal_throttle)
{
throttle_pos = throttle_pos_v;
bNewSignal_throttle = false;
}
interrupts();
// Send commands to ESCs
motor_FR.writeMicroseconds(throttle_pos);
motor_FL.writeMicroseconds(throttle_pos);
motor_BR.writeMicroseconds(throttle_pos);
motor_BL.writeMicroseconds(throttle_pos);
delay(5);
}
// Interrupt Routines
void ISR_throttle() {
if(digitalRead(THROTTLE_PIN) == HIGH) //means it went 0 to 1
ulStartPeriod_throttle = micros();
else // it went from 0 to 1, thus end of pulse
{
if(ulStartPeriod_throttle && (bNewSignal_throttle == false))
{
throttle_pos_v = (int)(micros() - ulStartPeriod_throttle);
ulStartPeriod_throttle = 0;
bNewSignal_throttle = true;
} }}
====================================================================
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino Boards
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 3: ESC and Motor (wiring and code)
Detailed in this section is flashing the ESC's, wiring them up, and sending commands from the Arduino to control the motors.
Part 3A: Flashing ESCs
Okay so in the video in Part 2, you can hear the high pitch noise from the motor. Yah thats annoying so to get rid of that you have to run the ESC at a higher rate. A guy by the name of SimonK has done this for us. He also has optimized the programming for quadcopters. His firmware is the standard for qaudcopters. Read about it here: http://www.rcgroups.com/forums/showthread.php?t=1513678
For the ESC's that I have I found a very nice page that details step by step on how to flash them:
http://www.rchacker.com/diy/simonk-esc-firmware-flashing
Following these steps from start to finish it took me maybe 45 minutes. Worked great. Now my motors spin nice and quiet and awesome.
Essentially what you do is you first have to buy an AVR programmer to connect your computer to the ESC via USB to the MOSI, MISO, etc pins on the ESC to reprogram the chip. Then use some software from here:
http://lazyzero.de/en/modellbau/kkmulticopterflashtool
which then flashes the ESC with the SimonK software.
Part 3B: Wiring ESC and Motors
Wiring for motors is simple.3 plugs on motor, 3 similar plugs on ESC (or in my case no plugs and I had to buy and solder some bullet plugs onto the wires). Just make sure the middle plug from the ESC goes into middle cable of motor. The outer wires can be swaped. If you put the left one into right most on motor, the motor will spin on way. Do opposite and motor spins the other way.
Connect battery red and black to the ESC red and black wires (i soldered mine to the base plate of my frame and added some plugs).
Then the ESC has a servo plug (red brown orange cable. plug the brown into the ground on the arduino so that they have a common ground. Then the orange wire needs to be connected to a digital pin on the arduino:
Part 3C: Arduino Code for ESC and Motors
Okay so the ESC is looking for a signal exactly like the signal from the receiver, a PPM. So we need to send a pulse out the is x microseconds long where x is 1000 to 2000, with 1000 essentially being a 0 and 2000 meaning spin motor at full speed. Here is the code to do this, luckily Arduino has a library called servo that writes these pulses for us very easily.
The following code is integrated with the receiver code from the previous section, so now the throttle on the transmitter should control all four motors
====================================================================
#include <Servo.h> //standard arduino library to send signals to ESC
#define THROTTLE_PIN 53
#define MOTOR_1_PIN 36
#define MOTOR_2_PIN 38
#define MOTOR_3_PIN 40
#define MOTOR_4_PIN 42
//Receiver variables
volatile boolean bNewSignal_throttle = false;
volatile unsigned long ulStartPeriod_throttle = 0;
volatile int throttle_pos_v = 1000;
static int throttle_pos = 1000;
// Motor Vars: FR = front right, FL = front left, BR = back right...
int motor_fr_cmd = 1000;
int motor_fl_cmd = 1000;
int motor_br_cmd = 1000;
int motor_bl_cmd = 1000;
Servo motor_FR;
Servo motor_FL;
Servo motor_BR;
Servo motor_BL;
void setup() {
// Receiver interrupt routines
attachInterrupt(THROTTLE_PIN,ISR_throttle,CHANGE)
//Motor Servos
motor_FR.attach(MOTOR_1_PIN);
motor_FL.attach(MOTOR_2_PIN);
motor_BR.attach(MOTOR_3_PIN);
motor_BL.attach(MOTOR_4_PIN);
}
void loop() {
noInterrupts();
if(bNewSignal_throttle)
{
throttle_pos = throttle_pos_v;
bNewSignal_throttle = false;
}
interrupts();
// Send commands to ESCs
motor_FR.writeMicroseconds(throttle_pos);
motor_FL.writeMicroseconds(throttle_pos);
motor_BR.writeMicroseconds(throttle_pos);
motor_BL.writeMicroseconds(throttle_pos);
delay(5);
}
// Interrupt Routines
void ISR_throttle() {
if(digitalRead(THROTTLE_PIN) == HIGH) //means it went 0 to 1
ulStartPeriod_throttle = micros();
else // it went from 0 to 1, thus end of pulse
{
if(ulStartPeriod_throttle && (bNewSignal_throttle == false))
{
throttle_pos_v = (int)(micros() - ulStartPeriod_throttle);
ulStartPeriod_throttle = 0;
bNewSignal_throttle = true;
} }}
====================================================================
Part 1: Quadcopter Design
I've decided to document the design of my quadcopter and how I came to this design. I started with no knowledge of rc/quadcopters so I'll document some of what I have learned over the last couple months. One note is I designed most of the software myself, less so on the hardware side. Ultimately I'd like to 3D print a frame. But my day job is designing flight control laws for fighter jets and military type UAVs so that's where my main interest is as you may end up seeing in this design.
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino Boards
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 1: Quadcopter Design:
Part 1A: Sizing/design on paper
Okay so the first question to ask myself: how big of a quadcopter. Or maybe a hexcopter, or more...
Well with the plan to develop and test it within my single room apartment I figured a 330mm (diagonal distance) frame would be right for now. Eventually I want to move to FPV but for now just get it flying and prove out the design of the flight control systems. With 330mm frame, this puts the quadcopter in the range of using 8 to 9 inch props. On a 330mm (~13inchs) frame, the tips of adjacent 9 inch props will be missing each other by 0.19 inches. Not ideal but doable.
So frame = 330m, props = 8 or 9 inches. The other components to size take a bit of playing with numbers. For this I used:
http://www.ecalc.ch/xcoptercalc.htm?ecalc&lang=en
Basically it is a quadcopter sizing program.
Important pieces of quad:
Batteries: 3 numbers to look at when picking a battery. It will look something like this:
3S 2000mah 20C
Motor: I don't even know where to start on motors... So many different makers and sizes. the motors are generally numbers like this: 2812-1200kv. The first 2 numbers (28) have something to do with size. 35 motors are more powerful than 28 motors. I think its either diameter of motor or maybe its shaft length. Then the second 2 numbers (12) are another size, again larger is more powerful, but the primary size is the first 2 numbers. So: 2808 < 2812 < 3505 < 3520 and so on. (must admit I am not entirely sure on this part but to the best of my knowledge this what it means...) The last number is far more important, kv = rpm per volt (why k=rpm, I have no idea....). So a 1000kv motor with a 3S battery (11.1V) will be spinning at full at 11,100 rpm (in theory?).
Generally larger motors you spin slower. So a 35 motor will spin larger props at a slower speed. 22 motors will spin smaller props at high rpm.
Props: Number is usually shown as something like 9x45 or 9045. First number is diameter, last numbers are pitch. If you were spinning the prop through jello, each 360 degree spin of the propr would move you 4.5 inches forward (i think) not real important, 4.7 or 4.5 are fairly normal for 8 to 10 inch props.
3 choices of prop types. Nylon plastic: cheap and usually poorly balanced but good for early testing where you might flip or run into walls and break props. Carbon-plastic fold: these are good props, very stiff and good performacen without costing much. Carbon fiber: expensive but good, no ideal for early testing but once the quad is working, probably switch to these.
So now with this knowledge I played around with eCalc varying numbers until I got a good design. 330mm frame = ~150g, plus some more for a micro controller and cables/plugs and such I started with a no drive weight of 200g. For motors I started with using Turnigy motors because a lot are in the system and they are cheap as hell. I would recommend using them to at least start sizing. Then switch to better motors. My plan was to buy some cheap turnigy's and then switch to something like tiger motors later.
So here is what I ended up on eCalc:
Boxes in red are variables I tweaked. Blue are the numbers I was trying to optimize. In hover you want less than 50% throttle. Good rule of thumb, unless there is some reason you don't need good thrust to weight. Ideally I tried to get to a thrust to weight of 3:1, so 33%. Got close. Flight time is short but not to bad. all up weight ended up being about 800g's. The yellow box is to note I am using too much power at full throttle. its close enough. These are cheapo motors anyways, a couple W's won't do much harm (i hope). I suspect the motors might get hot if I run them at full power for a while. Eventually I plan to switch to tiger motors or some other non cheapo Chinese motors anyways. Couple other things to note, battery load is only 15.91C, so 20C should give me good buffer of safety. motors are 13A at full throttle. They do make 15A ESC's I think but I want some buffer here to so 20A will work well.
So thats my quad design I ended up with.
Part 1B: Pick out other required components
So above I covered frame size, props, motors, batteries and ESC. I'll list the actual pieces at the end that I bought. But theres a couple other parts need to be addressed.
First and probably more important than the ESC is an IMU. You need some sensors to know what orientation the quadcopter is in inorder to stabilize it. Need atleast a gyro and accelerometer. A magnetometer helps a lot also. I'll go into more details on the IMU in a later post but I went with a 9dof unit that includes all 3 pieces in one.
Next piece is a receiver and transmitter. Need at minimum 4 channels. There's a ton of brands. Spektrum and Futaba are good ones. I ended up getting a 6 channel transmitter, the Spektrum dx6i which is a VERY good transmitter. I got a 7 channel receiver, AR7010 (why 7? well... i found one for sale that was cheaper than the 6 also the 7 channel has a failsafe mode that allows you to program in a value for each channel incase you lose communication with the transmitter. So I can set that if it loses comm, put motors to 30%, normally they'd go to 0% but the AR7010 lets me specify it). I ended up putting more money into the transmitter and receiver than I planned. You can get by much cheaper than I did but in the end, this is a fairly critical piece so I'd spend a little more plus this will be used on all of my future quads. it s one time upfront buy so make it good.
One note, before buying ESC's make sure they are on this list:
http://wiki.openpilot.org/display/Doc/RapidESC+Database#RapidESCDatabase-ESCSpreadsheetbyTomSn0w
A later post I will go into flashing the ESCs, but you need to make sure to get ones that are capable of having the firmware flashed.
Final part: Flight controller. There's a bunch out there like the NAZA, KK2, the ArduCopter board (they really need to change their name since they aren't arduino based anymore, what a joke.). I wanted a true arduino based system so I could write all the software myself. I considered going with a linux based board like a Raspberry Pi or something but decided to stay with a microcontroller like an Arduino (an actual arduino unlike the px4 ARDUcopter boards now). I'll make another post on the arduino selection later but I ended up with an Arduino Due.
Part 1C: Buy parts
So to sum it all up, here is the final list. I ended up buying tons of other pieces you may see in this blog later like pressure sensors and a gps and a bluetooth module but here is the original parts list:
Quad components
Frame: DJI F330 (25$)
Props: 9x4.7 - 3 sets of (2xCW + 2xCCW) of nylon plastic + 1 set of carbon fold (~15$)
ESCs: Hobbyking 20A BlueSeries (4x10 = 40$)
Motors: Turnigy SK3-2826-1130kv (4x15 = 60$)
Battery: Turnigy 3s 3000mah 25C (25$)
Sensors: 9Dof Razor IMU from sparkfun (Bonus: has an Atmega328 on it!) (125$)
Transmitter: 6 Channel - Spektrum DX6i (140$)
Receiver: 7 Channel AR7010 (found one for 50$)
Flight controller: Arduino Due (50$)
Other
Battery Charger: Turnigy Accucel 6A + 6A AC-DC power cord adapter (30$)
Prop Balancer: not sure where I got it (~5$)
Jewelry weight scale: (~5$)
Connectors and cables: (10-20$)
Total = 550-600$
Other random parts I bought later that you may end up needing:
FTDI: to reprogram the ATmega328 on the 9dof IMU razor (link)
USBasp Programmer: for flashing the ESC's
Note you could save quite a bit here by not spending almost 200 on a transmitter and receiver and get by for like 80. Also a lot of this is 1 time costs. Like the battery charger and such. I just tell myself most of this can be reused on later quads. So quad#1 costs like 600$ but quad #2 might be much better and bigger but only be like another 250$.
In the next blogs I'll go into detail on assembling this all together. I'll also explain writing the software like calibrating the sensors and designing and kalman filter orientation estimator and then go into developing some of the control laws to fly the thing. I also recently designed my own shield to sit over the Arduino due to plug everything into, so I don't have a rats nest of wires.
List of parts to blog:
Part 1: Quadcopter Design
Part 2: Integrating rc Transmitter and Receiver with Arduino
Part 3: ESC and motors (wiring and code)
Part 4: Sensors (reading in raw data and applying calibration)
Part 5: IMU - Kalman Filter Orientation Estimator
Part 6: Discussion on Arduino Boards
Part 7: Designing a shield for the Due
Part 8: Control Laws!!!!!
Part 1: Quadcopter Design:
Part 1A: Sizing/design on paper
Okay so the first question to ask myself: how big of a quadcopter. Or maybe a hexcopter, or more...
Well with the plan to develop and test it within my single room apartment I figured a 330mm (diagonal distance) frame would be right for now. Eventually I want to move to FPV but for now just get it flying and prove out the design of the flight control systems. With 330mm frame, this puts the quadcopter in the range of using 8 to 9 inch props. On a 330mm (~13inchs) frame, the tips of adjacent 9 inch props will be missing each other by 0.19 inches. Not ideal but doable.
So frame = 330m, props = 8 or 9 inches. The other components to size take a bit of playing with numbers. For this I used:
http://www.ecalc.ch/xcoptercalc.htm?ecalc&lang=en
Basically it is a quadcopter sizing program.
Important pieces of quad:
Batteries: 3 numbers to look at when picking a battery. It will look something like this:
3S 2000mah 20C
- Number before S = # of Cells: basically the batteries have individual cells that each are about 3.7V (4.2V fully charged). The more cells, the more voltage, and thus more RPM from the motors. 3S = 11.1V, 4S = 14.8V
- mahs (milli-amps) you can think of as energy. The more mah the more energy the battery has and thus the longer you can fly for, but that comes at the steep cost of weight.
- 20C, this number is the discharge rating. If you take a huge battery and try to drain all of its energy within a few seconds it will probably overheat and start on fire or explode. The C number is basically a rating on how fast you can discharge. This will come from the sizing code. If it says its not high enough, then just up it until it works. Then add 5 or 10 for good measure...
Motor: I don't even know where to start on motors... So many different makers and sizes. the motors are generally numbers like this: 2812-1200kv. The first 2 numbers (28) have something to do with size. 35 motors are more powerful than 28 motors. I think its either diameter of motor or maybe its shaft length. Then the second 2 numbers (12) are another size, again larger is more powerful, but the primary size is the first 2 numbers. So: 2808 < 2812 < 3505 < 3520 and so on. (must admit I am not entirely sure on this part but to the best of my knowledge this what it means...) The last number is far more important, kv = rpm per volt (why k=rpm, I have no idea....). So a 1000kv motor with a 3S battery (11.1V) will be spinning at full at 11,100 rpm (in theory?).
Generally larger motors you spin slower. So a 35 motor will spin larger props at a slower speed. 22 motors will spin smaller props at high rpm.
Props: Number is usually shown as something like 9x45 or 9045. First number is diameter, last numbers are pitch. If you were spinning the prop through jello, each 360 degree spin of the propr would move you 4.5 inches forward (i think) not real important, 4.7 or 4.5 are fairly normal for 8 to 10 inch props.
3 choices of prop types. Nylon plastic: cheap and usually poorly balanced but good for early testing where you might flip or run into walls and break props. Carbon-plastic fold: these are good props, very stiff and good performacen without costing much. Carbon fiber: expensive but good, no ideal for early testing but once the quad is working, probably switch to these.
So now with this knowledge I played around with eCalc varying numbers until I got a good design. 330mm frame = ~150g, plus some more for a micro controller and cables/plugs and such I started with a no drive weight of 200g. For motors I started with using Turnigy motors because a lot are in the system and they are cheap as hell. I would recommend using them to at least start sizing. Then switch to better motors. My plan was to buy some cheap turnigy's and then switch to something like tiger motors later.
So here is what I ended up on eCalc:
Boxes in red are variables I tweaked. Blue are the numbers I was trying to optimize. In hover you want less than 50% throttle. Good rule of thumb, unless there is some reason you don't need good thrust to weight. Ideally I tried to get to a thrust to weight of 3:1, so 33%. Got close. Flight time is short but not to bad. all up weight ended up being about 800g's. The yellow box is to note I am using too much power at full throttle. its close enough. These are cheapo motors anyways, a couple W's won't do much harm (i hope). I suspect the motors might get hot if I run them at full power for a while. Eventually I plan to switch to tiger motors or some other non cheapo Chinese motors anyways. Couple other things to note, battery load is only 15.91C, so 20C should give me good buffer of safety. motors are 13A at full throttle. They do make 15A ESC's I think but I want some buffer here to so 20A will work well.
So thats my quad design I ended up with.
Part 1B: Pick out other required components
So above I covered frame size, props, motors, batteries and ESC. I'll list the actual pieces at the end that I bought. But theres a couple other parts need to be addressed.
First and probably more important than the ESC is an IMU. You need some sensors to know what orientation the quadcopter is in inorder to stabilize it. Need atleast a gyro and accelerometer. A magnetometer helps a lot also. I'll go into more details on the IMU in a later post but I went with a 9dof unit that includes all 3 pieces in one.
Next piece is a receiver and transmitter. Need at minimum 4 channels. There's a ton of brands. Spektrum and Futaba are good ones. I ended up getting a 6 channel transmitter, the Spektrum dx6i which is a VERY good transmitter. I got a 7 channel receiver, AR7010 (why 7? well... i found one for sale that was cheaper than the 6 also the 7 channel has a failsafe mode that allows you to program in a value for each channel incase you lose communication with the transmitter. So I can set that if it loses comm, put motors to 30%, normally they'd go to 0% but the AR7010 lets me specify it). I ended up putting more money into the transmitter and receiver than I planned. You can get by much cheaper than I did but in the end, this is a fairly critical piece so I'd spend a little more plus this will be used on all of my future quads. it s one time upfront buy so make it good.
One note, before buying ESC's make sure they are on this list:
http://wiki.openpilot.org/display/Doc/RapidESC+Database#RapidESCDatabase-ESCSpreadsheetbyTomSn0w
A later post I will go into flashing the ESCs, but you need to make sure to get ones that are capable of having the firmware flashed.
Final part: Flight controller. There's a bunch out there like the NAZA, KK2, the ArduCopter board (they really need to change their name since they aren't arduino based anymore, what a joke.). I wanted a true arduino based system so I could write all the software myself. I considered going with a linux based board like a Raspberry Pi or something but decided to stay with a microcontroller like an Arduino (an actual arduino unlike the px4 ARDUcopter boards now). I'll make another post on the arduino selection later but I ended up with an Arduino Due.
Part 1C: Buy parts
So to sum it all up, here is the final list. I ended up buying tons of other pieces you may see in this blog later like pressure sensors and a gps and a bluetooth module but here is the original parts list:
Quad components
Frame: DJI F330 (25$)
Props: 9x4.7 - 3 sets of (2xCW + 2xCCW) of nylon plastic + 1 set of carbon fold (~15$)
ESCs: Hobbyking 20A BlueSeries (4x10 = 40$)
Motors: Turnigy SK3-2826-1130kv (4x15 = 60$)
Battery: Turnigy 3s 3000mah 25C (25$)
Sensors: 9Dof Razor IMU from sparkfun (Bonus: has an Atmega328 on it!) (125$)
Transmitter: 6 Channel - Spektrum DX6i (140$)
Receiver: 7 Channel AR7010 (found one for 50$)
Flight controller: Arduino Due (50$)
Other
Battery Charger: Turnigy Accucel 6A + 6A AC-DC power cord adapter (30$)
Prop Balancer: not sure where I got it (~5$)
Jewelry weight scale: (~5$)
Connectors and cables: (10-20$)
Total = 550-600$
Other random parts I bought later that you may end up needing:
FTDI: to reprogram the ATmega328 on the 9dof IMU razor (link)
USBasp Programmer: for flashing the ESC's
Note you could save quite a bit here by not spending almost 200 on a transmitter and receiver and get by for like 80. Also a lot of this is 1 time costs. Like the battery charger and such. I just tell myself most of this can be reused on later quads. So quad#1 costs like 600$ but quad #2 might be much better and bigger but only be like another 250$.
In the next blogs I'll go into detail on assembling this all together. I'll also explain writing the software like calibrating the sensors and designing and kalman filter orientation estimator and then go into developing some of the control laws to fly the thing. I also recently designed my own shield to sit over the Arduino due to plug everything into, so I don't have a rats nest of wires.
Subscribe to:
Posts (Atom)