Compare commits

...
Sign in to create a new pull request.

4 commits

Author SHA1 Message Date
GrafZ3pp3lin
0fa26e334d fix loading + htu21 sensor 2021-07-21 22:20:03 +02:00
GrafZ3pp3lin
beb41310c1 update 2021-07-10 09:32:32 +02:00
Johannes Gaiser
dadca72145
Merge pull request #2 from swablab/feature/GrafZ
corrected values + bme
2021-07-01 22:21:08 +02:00
Johannes Gaiser
17a00f8519
Merge pull request #1 from swablab/feature/GrafZ
add own library
2021-04-11 17:48:25 +02:00
2 changed files with 102 additions and 35 deletions

View file

@ -13,5 +13,6 @@ platform = atmelavr
board = nanoatmega328new board = nanoatmega328new
framework = arduino framework = arduino
lib_deps = lib_deps =
adafruit/Adafruit BME280 Library @ ^2.1.2 ; adafruit/Adafruit BME280 Library @ ^2.1.2
; miguel5612/MQUnifiedsensor @ ^2.0.1 ; miguel5612/MQUnifiedsensor @ ^2.0.1
sparkfun/SparkFun HTU21D Humidity and Temperature Sensor Breakout @ ^1.1.3

View file

@ -1,6 +1,6 @@
#include <Arduino.h> #include <Arduino.h>
#include <MQ135.h> #include <MQ135.h>
#include <Adafruit_BME280.h> #include <SparkFunHTU21D.h>
#define PIN_MQ135 A7 #define PIN_MQ135 A7
#define PIN_NOISE 2 #define PIN_NOISE 2
@ -11,17 +11,22 @@
#define PIN_LED_RED 7 #define PIN_LED_RED 7
#define PIN_LED_RED2 8 #define PIN_LED_RED2 8
void printValues(); void printValues(float ppm, float temp, float humidity);
const int maxCount = 10; const int maxCount = 10;
int count = 0; int count = 0;
bool noise = false; bool noise = false;
bool noiseActive = false; bool noiseActive = false;
float ppm; // loading
bool loading = true;
int firstRead;
const int loadingDelay = 200;
int loadingCount = 30000 / loadingDelay;
MQ135 co2_sensor(PIN_MQ135); MQ135 co2_sensor(PIN_MQ135);
Adafruit_BME280 bme; HTU21D envSensor;
void setup() { void setup() {
pinMode(PIN_LED_GREEN, OUTPUT); pinMode(PIN_LED_GREEN, OUTPUT);
@ -32,18 +37,83 @@ void setup() {
pinMode(PIN_LED_RED2, OUTPUT); pinMode(PIN_LED_RED2, OUTPUT);
pinMode(PIN_NOISE, OUTPUT); pinMode(PIN_NOISE, OUTPUT);
Serial.begin(9600); Serial.begin(9600);
co2_sensor.setR0(300); co2_sensor.setR0(200);
if (!bme.begin(0x76)) { // if (!bme.begin(0x76)) {
Serial.println(F("Could not find a valid BME280 sensor, check wiring!")); // Serial.println(F("Could not find a valid BME280 sensor, check wiring!"));
} // }
envSensor.begin();
} }
void loop() { void loop() {
if (loading) {
if (loadingCount <= 0) {
loading = false;
count = -1;
return;
}
int temp = analogRead(PIN_MQ135);
if (temp > firstRead) {
firstRead = temp;
}
else if (temp < (firstRead - 100) && loadingCount > 10) {
loadingCount = 10;
}
digitalWrite(PIN_LED_GREEN, 0);
digitalWrite(PIN_LED_GREEN2, 0);
digitalWrite(PIN_LED_YELLOW, 0);
digitalWrite(PIN_LED_YELLOW2, 0);
digitalWrite(PIN_LED_RED, 0);
digitalWrite(PIN_LED_RED2, 0);
switch (count)
{
case 1:
digitalWrite(PIN_LED_RED2, 1);
break;
case 2:
digitalWrite(PIN_LED_RED, 1);
digitalWrite(PIN_LED_RED2, 1);
break;
case 3:
digitalWrite(PIN_LED_RED, 1);
digitalWrite(PIN_LED_YELLOW2, 1);
break;
case 4:
digitalWrite(PIN_LED_YELLOW2, 1);
digitalWrite(PIN_LED_YELLOW, 1);
break;
case 5:
digitalWrite(PIN_LED_YELLOW, 1);
digitalWrite(PIN_LED_GREEN2, 1);
break;
case 6:
digitalWrite(PIN_LED_GREEN2, 1);
digitalWrite(PIN_LED_GREEN, 1);
break;
case 7:
digitalWrite(PIN_LED_GREEN, 1);
break;
case 10:
count = 0;
break;
default:
break;
}
loadingCount--;
count++;
delay(loadingDelay);
return;
}
if (count >= maxCount || count < 0) { if (count >= maxCount || count < 0) {
float temp = bme.readTemperature(); float temp = envSensor.readTemperature();
float humidity = bme.readHumidity(); float humidity = envSensor.readHumidity();
ppm = co2_sensor.getCorrectedCO2(temp, humidity); float ppm = co2_sensor.getCorrectedCO2(temp, humidity);
count = 0; count = 0;
noiseActive = false; noiseActive = false;
@ -54,52 +124,48 @@ void loop() {
digitalWrite(PIN_LED_RED, 0); digitalWrite(PIN_LED_RED, 0);
digitalWrite(PIN_LED_RED2, 0); digitalWrite(PIN_LED_RED2, 0);
if (ppm < 1000) { if (ppm < 900) {
digitalWrite(PIN_LED_GREEN, 1); digitalWrite(PIN_LED_GREEN, 1);
if (ppm > 750) {
digitalWrite(PIN_LED_GREEN2, 1);
}
} }
if (ppm > 1000 && ppm <= 2000) { if (ppm > 750 && ppm < 1100) {
digitalWrite(PIN_LED_GREEN2, 1);
}
if (ppm > 900 && ppm < 1900) {
digitalWrite(PIN_LED_YELLOW, 1); digitalWrite(PIN_LED_YELLOW, 1);
if (ppm > 1500) {
digitalWrite(PIN_LED_YELLOW2, 1);
}
} }
if (ppm > 2000) { if (ppm > 1500 && ppm < 2200) {
digitalWrite(PIN_LED_YELLOW2, 1);
}
if (ppm > 2000 && ppm < 2800) {
digitalWrite(PIN_LED_RED, 1); digitalWrite(PIN_LED_RED, 1);
if (ppm > 2500) { }
noiseActive = true; if (ppm > 2500) {
digitalWrite(PIN_LED_RED2, 1); digitalWrite(PIN_LED_RED2, 1);
} }
if (ppm > 3000) {
noiseActive = true;
} }
printValues(); printValues(ppm, temp, humidity);
} }
if (noiseActive) { if (noiseActive) {
noise = !noise; noise = !noise;
// digitalWrite(PIN_NOISE, noise); digitalWrite(PIN_NOISE, noise);
} }
else { else {
// digitalWrite(PIN_NOISE, 0); digitalWrite(PIN_NOISE, 0);
} }
delay(100); delay(100);
count++; count++;
} }
void printValues() { void printValues(float ppm, float temp, float humidity) {
float temp = bme.readTemperature();
float humidity = bme.readHumidity();
float ppm = co2_sensor.getCO2();
float cppm = co2_sensor.getCorrectedCO2(temp, humidity);
Serial.print("ppm: "); Serial.print("ppm: ");
Serial.println(ppm); Serial.println(ppm);
Serial.print("Temperature: "); Serial.print("Temperature: ");
Serial.println(temp); Serial.println(temp);
Serial.print("Humidity: "); Serial.print("Humidity: ");
Serial.println(humidity); Serial.println(humidity);
Serial.print("corrected ppm: ");
Serial.println(cppm);
} }