1 #include <SoftwareSerial.h>
2 #include <LiquidCrystal.h>
5 const int rx_pin = 2; // connect to TX on MHZ19
6 const int tx_pin = 3; // connect to RX on MHZ19
8 const int led_green_pin = 4;
9 const int led_yellow_pin = 5;
10 const int led_red_pin = 6;
12 const int buzzer_pin = 13;
14 const int co2_warning_thr = 1000;
15 const int co2_alarm_thr = 1500;
17 const unsigned long warmuptime = 60000; // 1 min.
19 MHZ19 mhz19 = MHZ19(rx_pin,tx_pin);
20 LiquidCrystal lcd(7, 8, 9, 10, 11, 12);
27 void buzz(unsigned long pause, int count) {
28 for (int i = 0; i <= count; i++) {
29 digitalWrite(buzzer_pin, HIGH);
31 digitalWrite(buzzer_pin, LOW);
32 if (i < count - 1) delay(pause);
39 Serial.println("Time,CO2,Temp");
42 mhz19.begin(rx_pin, tx_pin);
47 lcd.print("Airing Butler");
49 lcd.print("says hello!");
52 pinMode(led_green_pin, OUTPUT);
53 pinMode(led_yellow_pin, OUTPUT);
54 pinMode(led_red_pin, OUTPUT);
55 digitalWrite(led_green_pin, HIGH);
57 digitalWrite(led_green_pin, LOW);
58 digitalWrite(led_yellow_pin, HIGH);
60 digitalWrite(led_yellow_pin, LOW);
61 digitalWrite(led_red_pin, HIGH);
63 digitalWrite(led_red_pin, LOW);
66 pinMode(buzzer_pin, OUTPUT);
76 measurement_t m = mhz19.getMeasurement();
86 digitalWrite(led_red_pin, co2 >= co2_alarm_thr);
87 digitalWrite(led_yellow_pin, co2 >= co2_warning_thr && co2 < co2_alarm_thr);
88 digitalWrite(led_green_pin, co2 < co2_warning_thr);
90 if (co2 >= co2_alarm_thr && lastppm < co2_alarm_thr) {
94 if (co2 >= co2_warning_thr && lastppm < co2_warning_thr) {
101 if (time < warmuptime && (co2 == -1 || co2 == 410)) {
108 lcd.print(" C +/- ");