Can somebody give me a hand and see what I can do to make this work? Readings from MPU6050 are not correct regardless of what I try.
#include "Wire.h"
#include "I2Cdev.h"
#include "math.h"
#include <Adafruit_MPU6050.h>
#include <Adafruit_Sensor.h>
const int IN1 = 9;
const int IN2 = 8;
const int IN3 = 10;
const int IN4 = 11;
const int ENA = 5;
const int ENB = 6;
#define Kp 100
#define Kd 0.05
#define Ki 40
#define sampleTime 0.005
#define targetAngle -2.5
Adafruit_MPU6050 mpu;
int x, count, time;
float motorPower, currentAngle, accAngle, gyroRate, gyroAngle, prevAngle, error, errorSum, A, B, C;
sensors_event_t a, g, temp;
void setup() {
// MOTOR SETUP
Serial.begin(9600);
while (!Serial)
delay(10); // will pause Zero, Leonardo, etc until serial console opens
pinMode (IN1, OUTPUT);
pinMode (IN2, OUTPUT);
pinMode (IN3, OUTPUT);
pinMode (IN4, OUTPUT);
pinMode (ENA, OUTPUT);
pinMode (ENB, OUTPUT);
analogWrite(ENA, 0);
analogWrite(ENB, 0);
digitalWrite(IN1, LOW);
digitalWrite(IN2, HIGH);
digitalWrite(IN3, LOW);
digitalWrite(IN4, HIGH);
//END MOTOR SETUP
//CONFIGURA O PINO DO LED
pinMode(13, OUTPUT);
// Try to initialize!
if (!mpu.begin()) {
Serial.println("Failed to find MPU6050 chip");
while (1) {
delay(10);
}
}
Serial.println("MPU6050 Found!");
mpu.setAccelerometerRange(MPU6050_RANGE_8_G);
Serial.print("Accelerometer range set to: ");
switch (mpu.getAccelerometerRange()) {
case MPU6050_RANGE_2_G:
Serial.println("+-2G");
break;
case MPU6050_RANGE_4_G:
Serial.println("+-4G");
break;
case MPU6050_RANGE_8_G:
Serial.println("+-8G");
break;
case MPU6050_RANGE_16_G:
Serial.println("+-16G");
break;
}
mpu.setGyroRange(MPU6050_RANGE_500_DEG);
Serial.print("Gyro range set to: ");
switch (mpu.getGyroRange()) {
case MPU6050_RANGE_250_DEG:
Serial.println("+- 250 deg/s");
break;
case MPU6050_RANGE_500_DEG:
Serial.println("+- 500 deg/s");
break;
case MPU6050_RANGE_1000_DEG:
Serial.println("+- 1000 deg/s");
break;
case MPU6050_RANGE_2000_DEG:
Serial.println("+- 2000 deg/s");
break;
}
mpu.setFilterBandwidth(MPU6050_BAND_21_HZ);
Serial.print("Filter bandwidth set to: ");
switch (mpu.getFilterBandwidth()) {
case MPU6050_BAND_260_HZ:
Serial.println("260 Hz");
break;
case MPU6050_BAND_184_HZ:
Serial.println("184 Hz");
break;
case MPU6050_BAND_94_HZ:
Serial.println("94 Hz");
break;
case MPU6050_BAND_44_HZ:
Serial.println("44 Hz");
break;
case MPU6050_BAND_21_HZ:
Serial.println("21 Hz");
break;
case MPU6050_BAND_10_HZ:
Serial.println("10 Hz");
break;
case MPU6050_BAND_5_HZ:
Serial.println("5 Hz");
break;
}
delay(200);
// initialize PID sampling loop
// init_PID();
}
void motor_forward(){
digitalWrite(IN1, LOW);
digitalWrite(IN2, HIGH);
digitalWrite(IN3, LOW);
digitalWrite(IN4, HIGH);
}
void motor_backward(){
digitalWrite(IN1, HIGH);
digitalWrite(IN2, LOW);
digitalWrite(IN3, HIGH);
digitalWrite(IN4, LOW);
}
void alter_direction(){
analogWrite(ENA, 0);
analogWrite(ENB, 0);
if (digitalRead( IN1 ) == HIGH){
Serial.println("IF");
motor_forward();
}else{
Serial.println("ELSE");
motor_backward();
}
time = 1;
delay(100);
}
// The ISR will be called every 5 milliseconds
void calculate()
{
// calculate the angle of inclination
accAngle = atan2(A, B)*RAD_TO_DEG;
gyroRate = map(C, -32768, 32767, -250, 250);
gyroAngle = (float)gyroRate*sampleTime;
currentAngle = 0.9934*(prevAngle + gyroAngle) + 0.0066*(accAngle);
Serial.println("MEASUREMENT: ");
Serial.print(currentAngle);
error = currentAngle - targetAngle;
errorSum = errorSum + error;
errorSum = constrain(errorSum, -300, 300);
//calculate output from P, I and D values
motorPower = Kp*(error) + Ki*(errorSum)*sampleTime - Kd*(currentAngle-prevAngle)/sampleTime;
prevAngle = currentAngle;
// toggle the led on pin13 every second
count++;
if(count == 5) {
count = 0;
digitalWrite(13, !digitalRead(13));
}
}
void loop() {
if(millis() - time >= 5){
calculate();
time = millis();
}
/* Get new sensor events with the readings */
mpu.getEvent(&a, &g, &temp);
A = a.acceleration.x;
B = a.acceleration.z;
C = g.gyro.y;
// set motor power after constraining it
motorPower = constrain(motorPower, 150, 255);
if(currentAngle>0){
motor_forward();
}else{
motor_backward();
}
analogWrite(ENA, motorPower);
analogWrite(ENB, motorPower);
}
