#include <Adafruit_MPU6050.h>
#include <Adafruit_Sensor.h>
#include <Wire.h>
#include <DHT.h>
// Define pin numbers for traffic light
const int redPin = 4;
const int yellowPin = 3;
const int greenPin = 2;
// Define MPU6050 object
Adafruit_MPU6050 mpu;
// Define DHT sensor pin
#define DHTPIN 12
// Uncomment the type of sensor you're using
//#define DHTTYPE DHT11 // DHT 11
#define DHTTYPE DHT22 // DHT 22 (AM2302)
//#define DHTTYPE DHT21 // DHT 21 (AM2301)
DHT dht(DHTPIN, DHTTYPE);
// Function prototypes
void setupTrafficLight();
void setupMPU6050();
void setupDHT();
void updateTrafficLight();
void readMPU6050();
void readDHT();
void setup() {
Serial.begin(115200);
while (!Serial)
delay(10); // will pause Zero, Leonardo, etc until serial console opens
setupTrafficLight();
setupMPU6050();
setupDHT();
}
void loop() {
updateTrafficLight();
readMPU6050();
readDHT();
}
void setupTrafficLight() {
pinMode(redPin, OUTPUT);
pinMode(yellowPin, OUTPUT);
pinMode(greenPin, OUTPUT);
}
void setupMPU6050() {
Serial.println("Initializing MPU6050...");
if (!mpu.begin()) {
Serial.println("Failed to find MPU6050 chip");
while (1) {
delay(10);
}
}
Serial.println("MPU6050 Found!");
mpu.setAccelerometerRange(MPU6050_RANGE_8_G);
mpu.setGyroRange(MPU6050_RANGE_500_DEG);
mpu.setFilterBandwidth(MPU6050_BAND_5_HZ);
Serial.println("MPU6050 initialized successfully!");
delay(100);
}
void setupDHT() {
Serial.println("Initializing DHT sensor...");
dht.begin();
Serial.println("DHT sensor initialized successfully!");
}
void updateTrafficLight() {
digitalWrite(redPin, HIGH);
delay(15000);
digitalWrite(redPin, LOW);
for (int i = 0; i < 6; i++) {
digitalWrite(yellowPin, HIGH);
delay(1000);
digitalWrite(yellowPin, LOW);
delay(500);
}
digitalWrite(greenPin, HIGH);
delay(20000);
digitalWrite(greenPin, LOW);
for (int i = 0; i < 5; i++) {
digitalWrite(yellowPin, HIGH);
delay(1000);
digitalWrite(yellowPin, LOW);
delay(500);
}
}
void readMPU6050() {
sensors_event_t a, g, temp;
mpu.getEvent(&a, &g, &temp);
Serial.print("Acceleration X: ");
Serial.print(a.acceleration.x);
Serial.print(", Y: ");
Serial.print(a.acceleration.y);
Serial.print(", Z: ");
Serial.print(a.acceleration.z);
Serial.println(" m/s^2");
Serial.print("Rotation X: ");
Serial.print(g.gyro.x);
Serial.print(", Y: ");
Serial.print(g.gyro.y);
Serial.print(", Z: ");
Serial.print(g.gyro.z);
Serial.println(" rad/s");
Serial.print("Temperature: ");
Serial.print(temp.temperature);
Serial.println(" degC");
Serial.println("");
delay(500);
}
void readDHT() {
// Reading temperature or humidity takes about 250 milliseconds!
// Sensor readings may also be up to 2 seconds 'old' (it's a very slow sensor)
float h = dht.readHumidity();
float t = dht.readTemperature(); // Read temperature as Celsius
// Check if any reads failed and exit early (to try again).
if (isnan(h) || isnan(t)) {
Serial.println("Failed to read from DHT sensor!");
return;
}
// Print humidity and temperature
Serial.print("Humidity: ");
Serial.print(h);
Serial.print(" %\t");
Serial.print("Temperature: ");
Serial.print(t);
Serial.println(" °C");
}