uses BBC micro:bit to measure and display indoor air quality using Bosch BME680 and/or Sensirion SGP30

Dependencies:   microbit

uses Bosch BME680 and/or Sensirion SGP30 sensors to measure indor air quality

sensors should be connected to BBC micro:bit using i2c

commands are received and data is being sent using uBit / nordic radio protocol

display ---

last line always indicates: - first dot: bme680 detected - second dot: sgp30 detected - third dot: sgp 30 setting humidity/temperature - fourth dor: sgp30 measuring - fith dot: bme680 measuring

the detect dots should be in a stable state (not blinking) the measuring dots should be blinking (constant light means: measurement failed)

if only one bme680 is present: - first 3 lines indicate gas resistence (air quality / more dots == worse quality) - fourth line indicates humidity level

if only sgp30 is present: - first two lines indicate SGP30 VOC level - third and fourth line indicate sgp30 CO2 level

if both sensors are present: - first line indicates SGP30 VOC level - second line line indicates sgp30 CO2 level - third line indicates bme680 gas resistence (air quality) - fourth line indicates bme 680 humidity level

buttons - B display state, switches betweeen - full bright - low light - display off

AB reset sgp30 baseline in non volatile storage

data logging -- during measurements the minimum and mximum values for each measured value (temperature, air pressure, humidity,gas resistance, VOC, CO2) are being stored in non volatile storage those (and the last measurement results) are being shown when btn A has been pressed

Committer:
jsa1969
Date:
Tue Feb 12 15:06:55 2019 +0000
Revision:
34:069c4f6d5b2c
Parent:
33:af2dfab24ca9
Child:
38:0f29a0ea64ca
code cleanup

Who changed what in which revision?

UserRevisionLine numberNew contents of line
jsa1969 11:6844a5578b4f 1 #include "mbed.h"
jsa1969 11:6844a5578b4f 2 #include "MicroBit.h"
jsa1969 11:6844a5578b4f 3
jsa1969 11:6844a5578b4f 4 #ifndef NVSTORE_H
jsa1969 11:6844a5578b4f 5 #define NVSTORE_H
jsa1969 11:6844a5578b4f 6
jsa1969 33:af2dfab24ca9 7 class MovingAverage;
jsa1969 11:6844a5578b4f 8
jsa1969 11:6844a5578b4f 9 class NvStore {
jsa1969 11:6844a5578b4f 10 public:
jsa1969 12:96eb06e837f4 11 NvStore(MicroBit* uBit);
jsa1969 33:af2dfab24ca9 12 ~NvStore();
jsa1969 17:a2c4dd192146 13
jsa1969 12:96eb06e837f4 14 void resetNvStore();
jsa1969 17:a2c4dd192146 15
jsa1969 27:cb75a0c5c52a 16 void updateGas(const uint32_t gas, const uint32_t humidity);
jsa1969 27:cb75a0c5c52a 17 uint32_t getGasMax(const uint32_t humidity);
jsa1969 14:71060505061e 18 uint32_t getGasMin();
jsa1969 17:a2c4dd192146 19
jsa1969 19:52e19461e867 20 void updateTemp(const int16_t temperature);
jsa1969 19:52e19461e867 21 int16_t getTempMax();
jsa1969 19:52e19461e867 22 int16_t getTempMin();
jsa1969 14:71060505061e 23
jsa1969 17:a2c4dd192146 24 void updatePress(const uint32_t pressure);
jsa1969 17:a2c4dd192146 25 uint32_t getPressMax();
jsa1969 17:a2c4dd192146 26 uint32_t getPressMin();
jsa1969 14:71060505061e 27
jsa1969 17:a2c4dd192146 28 void updateHumidity(const uint32_t humidity);
jsa1969 17:a2c4dd192146 29 uint32_t getHumMax();
jsa1969 17:a2c4dd192146 30 uint32_t getHumMin();
jsa1969 12:96eb06e837f4 31
jsa1969 18:c4ac93e01027 32 void updateVoc(const uint32_t voc);
jsa1969 18:c4ac93e01027 33 uint32_t getVocMax();
jsa1969 18:c4ac93e01027 34
jsa1969 18:c4ac93e01027 35 void updateCo(const uint32_t co);
jsa1969 18:c4ac93e01027 36 uint32_t getCoMax();
jsa1969 18:c4ac93e01027 37
jsa1969 12:96eb06e837f4 38 private:
jsa1969 12:96eb06e837f4 39 MicroBit* _uBit;
jsa1969 33:af2dfab24ca9 40
jsa1969 33:af2dfab24ca9 41 MovingAverage* _movingAverage;
jsa1969 33:af2dfab24ca9 42
jsa1969 19:52e19461e867 43 int16_t _tempMax, _tempMin;
jsa1969 27:cb75a0c5c52a 44 uint32_t _maxGas[10], _minGas,
jsa1969 17:a2c4dd192146 45 _pressMax, _pressMin,
jsa1969 18:c4ac93e01027 46 _humMax, _humMin,
jsa1969 30:2958c6c803b9 47 _vocMax,
jsa1969 30:2958c6c803b9 48 _coMax;
jsa1969 14:71060505061e 49
jsa1969 34:069c4f6d5b2c 50 bool gasWithinReasonableRangeFromAverage(const uint32_t gas);
jsa1969 14:71060505061e 51 uint32_t getStored(const char* key, const uint32_t defaultVal);
jsa1969 19:52e19461e867 52 int16_t getStored16(const char * key, const int16_t defaultVal);
jsa1969 14:71060505061e 53 void update(const uint32_t value, uint32_t* maxVal, uint32_t* minVal, const char* maxKey, const char* minKey);
jsa1969 27:cb75a0c5c52a 54 static char getIndex(const uint32_t humidity);
jsa1969 27:cb75a0c5c52a 55 static char* createIndexedKey(const char index, const char* initialKey);
jsa1969 11:6844a5578b4f 56 };
jsa1969 11:6844a5578b4f 57
jsa1969 11:6844a5578b4f 58 #endif // NVSTORE_H