#include <Adafruit_MPU6050.h>
#include <Adafruit_Sensor.h>
#include <Wire.h>
#define encoderPinA 2
#define encoderPinB 3
volatile int encoderPos = 0;
int previousPos = 0;
unsigned long previousTime = 0;
unsigned long currentTime = 0;
float speed = 0;
float decelerationThreshold = -1;
Adafruit_MPU6050 mpu;
void setup(void) {
Serial.begin(9600);
while (!Serial)
delay(10); // will pause Zero, Leonardo, etc until serial console opens
Serial.println("Adafruit MPU6050 test!");
// 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_2000_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;
}
Serial.println("");
delay(100);
// encoder
// Set encoder pins as inputs
pinMode(encoderPinA, INPUT);
pinMode(encoderPinB, INPUT);
// Enable internal pull-up resistors
digitalWrite(encoderPinA, HIGH);
digitalWrite(encoderPinB, HIGH);
// Attach interrupt service routine to encoder pins
attachInterrupt(digitalPinToInterrupt(encoderPinA), encoderISR, CHANGE);
attachInterrupt(digitalPinToInterrupt(encoderPinB), encoderISR, CHANGE);
}
void loop() {
sensors_event_t a, g, temp;
mpu.getEvent(&a, &g, &temp);
int yey = a.acceleration.y;
if (yey < 0) {
Serial.print("percepatan y = "); Serial.print(yey);
Serial.println(" ke kiri");
}
else if (yey > 0) {
Serial.print("percepatan y = "); Serial.print(yey);
Serial.println(" ke kanan");
}
else {
Serial.print("percepatan y = "); Serial.print(yey);
Serial.println(" lurusss");
}
Serial.print("Temperature: ");
Serial.print(temp.temperature);
Serial.println(" degC");
Serial.println("");
delay(500);
// Calculate speed
currentTime = millis();
float deltaTime = (currentTime - previousTime) / 1000.0;
float deltaPos = encoderPos - previousPos;
speed = deltaPos / deltaTime;
// Check for deceleration
if (speed < decelerationThreshold) {
Serial.println("Mobil melambat");
}
// Print speed to serial monitor
Serial.print("Speed: ");
Serial.print(speed);
Serial.println(" RPM");
// Update previous position and time
previousPos = encoderPos;
previousTime = currentTime;
// Add a delay to reduce the frequency of speed measurements
delay(100);
}
// Interrupt service routine for rotary encoder
void encoderISR() {
if (digitalRead(encoderPinA) == digitalRead(encoderPinB)) {
encoderPos++;
} else {
encoderPos--;
}
}