move sds018 to class
This commit is contained in:
parent
1693a84cf3
commit
be57f730b4
4 changed files with 234 additions and 151 deletions
155
include/sensor_sds018.cpp
Normal file
155
include/sensor_sds018.cpp
Normal file
|
@ -0,0 +1,155 @@
|
||||||
|
#include "sensor_sds018.h"
|
||||||
|
|
||||||
|
// SDS018 example: https://github.com/crystaldust/sds018/blob/master/sds018.ino
|
||||||
|
|
||||||
|
//SDS18 dust sensor for 2.5µm and 10µm
|
||||||
|
//Needs 5V
|
||||||
|
|
||||||
|
|
||||||
|
Sensor_SDS018::Sensor_SDS018(int prx,int ptx)
|
||||||
|
{
|
||||||
|
pin_rx=prx;
|
||||||
|
pin_tx=ptx;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sensor_SDS018::init() //Things to be done during setup()
|
||||||
|
{
|
||||||
|
Serial.println("initializing sds018");
|
||||||
|
sds018_swSerial->begin(BAUD_RATE_SDS018, SWSERIAL_8N1, pin_rx, pin_tx, false, 256);
|
||||||
|
init_ok=true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Also called during setup()
|
||||||
|
void Sensor_SDS018::setSettings_pm10(float minchange, unsigned long senddelaymax, unsigned long readdelay)
|
||||||
|
{
|
||||||
|
data_pm10.minchange=minchange;
|
||||||
|
data_pm10.senddelaymax=senddelaymax;
|
||||||
|
data_pm10.readdelay=readdelay;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sensor_SDS018::setSettings_pm25(float minchange, unsigned long senddelaymax, unsigned long readdelay)
|
||||||
|
{
|
||||||
|
data_pm25.minchange=minchange;
|
||||||
|
data_pm25.senddelaymax=senddelaymax;
|
||||||
|
data_pm25.readdelay=readdelay;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//Called during setup
|
||||||
|
void Sensor_SDS018::advertise(HomieNode& p_sensorNode)
|
||||||
|
{
|
||||||
|
sensorNode = &p_sensorNode;
|
||||||
|
sensorNode->advertise("dust_pm25");
|
||||||
|
sensorNode->advertise("dust_pm10");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sensor_SDS018::sensorloop()
|
||||||
|
{
|
||||||
|
if (init_ok) {
|
||||||
|
loop_pm10();
|
||||||
|
loop_pm25();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void Sensor_SDS018::loop_pm25()
|
||||||
|
{
|
||||||
|
sensordata &d=data_pm25;
|
||||||
|
|
||||||
|
bool _changed=false;
|
||||||
|
if (millis() >= (d.lastreadtime+d.readdelay)) {
|
||||||
|
if (millis() >= (lastread_sds018+d.readdelay)) {
|
||||||
|
readSDS018(); //reads values into data_pm10 and data_pm25
|
||||||
|
}
|
||||||
|
if (fabs(d.lastsentvalue-d.value)>=d.minchange){
|
||||||
|
_changed=true;
|
||||||
|
}
|
||||||
|
d.lastreadtime=millis();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_changed || millis() >= (d.lastsent+d.senddelaymax)) {
|
||||||
|
Serial.print("Sending SDS018_pm25. reason=");
|
||||||
|
if (_changed) Serial.println("change"); else Serial.println("time");
|
||||||
|
|
||||||
|
Homie.getLogger() << "read pm25: " << d.value << " status=" << sds018_dustok << endl;
|
||||||
|
if (sds018_dustok){ //send no dust values if sensor not ok
|
||||||
|
sensorNode->setProperty("dust_pm25").send(String(d.value));
|
||||||
|
}else{
|
||||||
|
Homie.getLogger() << "sds018 dust not ok. didnt sent" << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
d.lastsentvalue=d.value;
|
||||||
|
|
||||||
|
d.lastsent=millis();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void Sensor_SDS018::loop_pm10()
|
||||||
|
{
|
||||||
|
sensordata &d=data_pm10;
|
||||||
|
|
||||||
|
bool _changed=false;
|
||||||
|
if (millis() >= (d.lastreadtime+d.readdelay)) {
|
||||||
|
if (millis() >= (lastread_sds018+d.readdelay)) {
|
||||||
|
readSDS018(); //reads values into data_pm10 and data_pm25
|
||||||
|
}
|
||||||
|
if (fabs(d.lastsentvalue-d.value)>=d.minchange){
|
||||||
|
_changed=true;
|
||||||
|
}
|
||||||
|
d.lastreadtime=millis();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_changed || millis() >= (d.lastsent+d.senddelaymax)) {
|
||||||
|
Serial.print("Sending SDS018_pm10. reason=");
|
||||||
|
if (_changed) Serial.println("change"); else Serial.println("time");
|
||||||
|
|
||||||
|
Homie.getLogger() << "read pm10: " << d.value << " status=" << sds018_dustok << endl;
|
||||||
|
if (sds018_dustok){ //send no dust values if sensor not ok
|
||||||
|
sensorNode->setProperty("dust_pm10").send(String(d.value));
|
||||||
|
}else{
|
||||||
|
Homie.getLogger() << "sds018 dust not ok. didnt sent" << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
d.lastsentvalue=d.value;
|
||||||
|
|
||||||
|
d.lastsent=millis();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sensor_SDS018::readSDS018()
|
||||||
|
{
|
||||||
|
lastread_sds018=millis();
|
||||||
|
// https://github.com/crystaldust/sds018/blob/master/sds018.ino
|
||||||
|
uint8_t mData = 0;
|
||||||
|
uint8_t mPkt[10] = {0};
|
||||||
|
uint8_t mCheck = 0;
|
||||||
|
while( sds018_swSerial->available() > 0 ) {
|
||||||
|
//Serial.println("serial available");
|
||||||
|
for( int i=0; i<10; ++i ) {
|
||||||
|
mPkt[i] = sds018_swSerial->read();
|
||||||
|
//Serial.println( mPkt[i], HEX );
|
||||||
|
}
|
||||||
|
if( 0xC0 == mPkt[1] ) {
|
||||||
|
Serial.println("read density");
|
||||||
|
// Read dust density.
|
||||||
|
// Check
|
||||||
|
uint8_t sum = 0;
|
||||||
|
for( int i=2; i<=7; ++i ) {
|
||||||
|
sum += mPkt[i];
|
||||||
|
}
|
||||||
|
if( sum == mPkt[8] ) {
|
||||||
|
uint8_t pm25Low = mPkt[2];
|
||||||
|
uint8_t pm25High = mPkt[3];
|
||||||
|
uint8_t pm10Low = mPkt[4];
|
||||||
|
uint8_t pm10High = mPkt[5];
|
||||||
|
|
||||||
|
data_pm25.value = ( ( pm25High * 256.0 ) + pm25Low ) / 10.0;
|
||||||
|
data_pm10.value = ( ( pm10High * 256.0 ) + pm10Low ) / 10.0;
|
||||||
|
|
||||||
|
sds018_dustok=true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sds018_swSerial->flush();
|
||||||
|
}
|
||||||
|
}
|
52
include/sensor_sds018.h
Normal file
52
include/sensor_sds018.h
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
#ifndef SENSOR_SDS018_H
|
||||||
|
#define SENSOR_SDS018_H
|
||||||
|
|
||||||
|
#include "sensordata.h"
|
||||||
|
#include <Homie.h>
|
||||||
|
|
||||||
|
|
||||||
|
#include <SoftwareSerial.h>
|
||||||
|
|
||||||
|
|
||||||
|
class Sensor_SDS018
|
||||||
|
{
|
||||||
|
|
||||||
|
private:
|
||||||
|
HomieNode *sensorNode; //reference to HomieNode
|
||||||
|
|
||||||
|
struct sensordata data_pm25;
|
||||||
|
struct sensordata data_pm10;
|
||||||
|
|
||||||
|
int pin_rx;
|
||||||
|
int pin_tx;
|
||||||
|
|
||||||
|
bool init_ok;
|
||||||
|
|
||||||
|
#define BAUD_RATE_SDS018 9600
|
||||||
|
SoftwareSerial *sds018_swSerial;
|
||||||
|
|
||||||
|
bool sds018_dustok;
|
||||||
|
|
||||||
|
unsigned long lastread_sds018=0; //to save last read time for both readings
|
||||||
|
|
||||||
|
void readSDS018();
|
||||||
|
|
||||||
|
void loop_pm25();
|
||||||
|
void loop_pm10();
|
||||||
|
void readSDS018();
|
||||||
|
|
||||||
|
public:
|
||||||
|
Sensor_SDS018(int prx, int ptx);
|
||||||
|
|
||||||
|
void init();
|
||||||
|
void setSettings_pm10(float minchange, unsigned long senddelaymax, unsigned long readdelay);
|
||||||
|
void setSettings_pm25(float minchange, unsigned long senddelaymax, unsigned long readdelay);
|
||||||
|
void advertise(HomieNode& p_sensorNode);
|
||||||
|
void sensorloop();
|
||||||
|
|
||||||
|
bool mhz19calibrationHandler(const HomieRange& range, const String& value);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -151,10 +151,10 @@ build_flags =
|
||||||
-D SENSOR_MHZ19B_readdelay=10*1000
|
-D SENSOR_MHZ19B_readdelay=10*1000
|
||||||
|
|
||||||
-D SENSOR_SDS018
|
-D SENSOR_SDS018
|
||||||
-D SDS018_SERIAL_RX=D7
|
-D SENSOR_SDS018_SERIAL_RX=D7
|
||||||
-D SDS018_SERIAL_TX=D8
|
-D SENSOR_SDS018_SERIAL_TX=D8
|
||||||
-D dataSDS018_pm25_minchange=4
|
-D SENSOR_SDS018_PM10_minchange=4
|
||||||
-D dataSDS018_pm10_minchange=4
|
-D SENSOR_SDS018_PM25_minchange=4
|
||||||
|
|
||||||
lib_deps =
|
lib_deps =
|
||||||
klevytskyi/MHZ19@0.0.1
|
klevytskyi/MHZ19@0.0.1
|
||||||
|
|
170
src/main.cpp
170
src/main.cpp
|
@ -205,29 +205,26 @@
|
||||||
|
|
||||||
|
|
||||||
#ifdef SENSOR_SDS018
|
#ifdef SENSOR_SDS018
|
||||||
struct sensordata dataSDS018_pm25;
|
#include "sensor_sds018.cpp"
|
||||||
struct sensordata dataSDS018_pm10;
|
Sensor_SDS018 sensor_sds018(SENSOR_SDS018_SERIAL_RX,SENSOR_SDS018_SERIAL_TX);
|
||||||
|
#ifndef SENSOR_SDS018_PM10_minchange
|
||||||
// SDS018 example: https://github.com/crystaldust/sds018/blob/master/sds018.ino
|
#define SENSOR_SDS018_PM10_minchange 10.0
|
||||||
|
#endif
|
||||||
//SDS18 dust sensor for 2.5µm and 10µm
|
#ifndef SENSOR_SDS018_PM10_senddelaymax
|
||||||
//Needs 5V
|
#define SENSOR_SDS018_PM10_senddelaymax 1000*60*5
|
||||||
|
#endif
|
||||||
bool sds018_dustok=false;
|
#ifndef SENSOR_SDS018_PM10_readdelay
|
||||||
float value_pm25=-1;
|
#define SENSOR_SDS018_PM10_readdelay 1000*10
|
||||||
float value_pm10=-1;
|
#endif
|
||||||
|
#ifndef SENSOR_SDS018_PM25_minchange
|
||||||
#ifndef SOFTWARESERIAL_H
|
#define SENSOR_SDS018_PM25_minchange 10.0
|
||||||
#include <SoftwareSerial.h>
|
#endif
|
||||||
#define SOFTWARESERIAL_H
|
#ifndef SENSOR_SDS018_PM25_senddelaymax
|
||||||
|
#define SENSOR_SDS018_PM25_senddelaymax 1000*60*5
|
||||||
|
#endif
|
||||||
|
#ifndef SENSOR_SDS018_PM25_readdelay
|
||||||
|
#define SENSOR_SDS018_PM25_readdelay 1000*10
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SoftwareSerial sds018_swSerial;
|
|
||||||
#define BAUD_RATE_SDS018 9600
|
|
||||||
|
|
||||||
unsigned long lastread_sds018=0; //to save last read time for both readings
|
|
||||||
|
|
||||||
void readSDS018();
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SENSOR_TCS34725
|
#ifdef SENSOR_TCS34725
|
||||||
|
@ -384,14 +381,9 @@ void setup() {
|
||||||
|
|
||||||
|
|
||||||
#ifdef SENSOR_SDS018
|
#ifdef SENSOR_SDS018
|
||||||
Serial.println("initializing sds018");
|
sensor_sds018.init();
|
||||||
sds018_swSerial.begin(BAUD_RATE_SDS018, SWSERIAL_8N1, SDS018_SERIAL_RX, SDS018_SERIAL_TX, false, 256);
|
sensor_sds018.setSettings_pm10(SENSOR_SDS018_PM10_minchange,SENSOR_SDS018_PM10_senddelaymax,SENSOR_SDS018_PM10_readdelay);
|
||||||
#ifdef dataSDS018_pm25_minchange
|
sensor_sds018.setSettings_pm25(SENSOR_SDS018_PM25_minchange,SENSOR_SDS018_PM25_senddelaymax,SENSOR_SDS018_PM25_readdelay);
|
||||||
dataSDS018_pm25.minchange=dataSDS018_pm25_minchange;
|
|
||||||
#endif
|
|
||||||
#ifdef dataSDS018_pm10_minchange
|
|
||||||
dataSDS018_pm10.minchange=dataSDS018_pm10_minchange;
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SENSOR_TCS34725
|
#ifdef SENSOR_TCS34725
|
||||||
|
@ -516,8 +508,7 @@ void setup() {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SENSOR_SDS018
|
#ifdef SENSOR_SDS018
|
||||||
sensorNode.advertise("dust_pm25");
|
sensor_sds018.advertise(sensorNode);
|
||||||
sensorNode.advertise("dust_pm10");
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SENSOR_TCS34725
|
#ifdef SENSOR_TCS34725
|
||||||
|
@ -555,75 +546,6 @@ void loop() {
|
||||||
Homie.loop();
|
Homie.loop();
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SENSOR_SDS018
|
|
||||||
void loop_SDS018_pm25()
|
|
||||||
{
|
|
||||||
sensordata &d=dataSDS018_pm25;
|
|
||||||
|
|
||||||
bool _changed=false;
|
|
||||||
if (millis() >= (d.lastreadtime+d.readdelay)) {
|
|
||||||
if (millis() >= (lastread_sds018+d.readdelay)) {
|
|
||||||
readSDS018(); //reads values into value_pm25 und value_pm10
|
|
||||||
}
|
|
||||||
//Homie.getLogger() << "read pm25: " << value_pm25 << ".read pm10: " << value_pm10 << " status=" << dust_ok << endl;
|
|
||||||
if (fabs(d.lastsentvalue-value_pm25)>=d.minchange){
|
|
||||||
_changed=true;
|
|
||||||
}
|
|
||||||
d.lastreadtime=millis();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_changed || millis() >= (d.lastsent+d.senddelaymax)) {
|
|
||||||
Serial.print("Sending SDS018_pm25. reason=");
|
|
||||||
if (_changed) Serial.println("change"); else Serial.println("time");
|
|
||||||
checkESPStatus();
|
|
||||||
|
|
||||||
Homie.getLogger() << "read pm25: " << value_pm25 << " status=" << sds018_dustok << endl;
|
|
||||||
if (sds018_dustok){ //send no dust values if sensor not ok
|
|
||||||
sensorNode.setProperty("dust_pm25").send(String(value_pm25));
|
|
||||||
}else{
|
|
||||||
Homie.getLogger() << "sds018 dust not ok. didnt sent" << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
d.lastsentvalue=value_pm25;
|
|
||||||
|
|
||||||
d.lastsent=millis();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
void loop_SDS018_pm10()
|
|
||||||
{
|
|
||||||
sensordata &d=dataSDS018_pm10;
|
|
||||||
|
|
||||||
bool _changed=false;
|
|
||||||
if (millis() >= (d.lastreadtime+d.readdelay)) {
|
|
||||||
if (millis() >= (lastread_sds018+d.readdelay)) {
|
|
||||||
readSDS018(); //reads values into value_pm25 und value_pm10
|
|
||||||
}
|
|
||||||
//Homie.getLogger() << "read pm25: " << value_pm25 << ".read pm10: " << value_pm10 << " status=" << dust_ok << endl;
|
|
||||||
if (fabs(d.lastsentvalue-value_pm10)>=d.minchange){
|
|
||||||
_changed=true;
|
|
||||||
}
|
|
||||||
d.lastreadtime=millis();
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_changed || millis() >= (d.lastsent+d.senddelaymax)) {
|
|
||||||
Serial.print("Sending SDS018_pm10. reason=");
|
|
||||||
if (_changed) Serial.println("change"); else Serial.println("time");
|
|
||||||
checkESPStatus();
|
|
||||||
|
|
||||||
Homie.getLogger() << "read pm10: " << value_pm10 << " status=" << sds018_dustok << endl;
|
|
||||||
if (sds018_dustok){ //send no dust values if sensor not ok
|
|
||||||
sensorNode.setProperty("dust_pm10").send(String(value_pm10));
|
|
||||||
}else{
|
|
||||||
Homie.getLogger() << "sds018 dust not ok. didnt sent" << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
d.lastsentvalue=value_pm10;
|
|
||||||
|
|
||||||
d.lastsent=millis();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef SENSOR_TCS34725
|
#ifdef SENSOR_TCS34725
|
||||||
void loop_TCS34725_lux()
|
void loop_TCS34725_lux()
|
||||||
{
|
{
|
||||||
|
@ -952,52 +874,6 @@ void checkESPStatus()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#ifdef SENSOR_SDS018
|
|
||||||
void readSDS018()
|
|
||||||
{
|
|
||||||
lastread_sds018=millis();
|
|
||||||
// https://github.com/crystaldust/sds018/blob/master/sds018.ino
|
|
||||||
uint8_t mData = 0;
|
|
||||||
uint8_t mPkt[10] = {0};
|
|
||||||
uint8_t mCheck = 0;
|
|
||||||
while( sds018_swSerial.available() > 0 ) {
|
|
||||||
//Serial.println("serial available");
|
|
||||||
for( int i=0; i<10; ++i ) {
|
|
||||||
mPkt[i] = sds018_swSerial.read();
|
|
||||||
//Serial.println( mPkt[i], HEX );
|
|
||||||
}
|
|
||||||
if( 0xC0 == mPkt[1] ) {
|
|
||||||
Serial.println("read density");
|
|
||||||
// Read dust density.
|
|
||||||
// Check
|
|
||||||
uint8_t sum = 0;
|
|
||||||
for( int i=2; i<=7; ++i ) {
|
|
||||||
sum += mPkt[i];
|
|
||||||
}
|
|
||||||
if( sum == mPkt[8] ) {
|
|
||||||
uint8_t pm25Low = mPkt[2];
|
|
||||||
uint8_t pm25High = mPkt[3];
|
|
||||||
uint8_t pm10Low = mPkt[4];
|
|
||||||
uint8_t pm10High = mPkt[5];
|
|
||||||
|
|
||||||
value_pm25 = ( ( pm25High * 256.0 ) + pm25Low ) / 10.0;
|
|
||||||
value_pm10 = ( ( pm10High * 256.0 ) + pm10Low ) / 10.0;
|
|
||||||
|
|
||||||
sds018_dustok=true;
|
|
||||||
|
|
||||||
/*Serial.print( "PM2.5: " );
|
|
||||||
Serial.print( pm25 );
|
|
||||||
Serial.print( "\nPM10 :" );
|
|
||||||
Serial.print( pm10 );
|
|
||||||
Serial.println();*/
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sds018_swSerial.flush();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef SENSOR_ANEMOMETER
|
#ifdef SENSOR_ANEMOMETER
|
||||||
|
|
Loading…
Reference in a new issue