|
|
- // -----------------------------------------------------------------------------
- // Eergy monitor sensor
- // -----------------------------------------------------------------------------
-
- #pragma once
-
- #include "Arduino.h"
- #include "BaseSensor.h"
- #include "EmonSensor.h"
-
- class EmonAnalogSensor : public EmonSensor {
-
- public:
-
- EmonAnalogSensor(unsigned char gpio, double voltage, unsigned char bits, double ref, double ratio): EmonSensor(voltage, bits, ref, ratio) {
-
- // Cache
- _gpio = gpio;
- _count = 4;
-
- // Prepare GPIO
- pinMode(gpio, INPUT);
-
- // warmup
- read(_gpio);
-
- }
-
- // Descriptive name of the sensor
- String name() {
- char buffer[20];
- snprintf(buffer, sizeof(buffer), "EMON @ GPIO%d", _gpio);
- return String(buffer);
- }
-
- // Descriptive name of the slot # index
- String slot(unsigned char index) {
- return name();
- }
-
- // Type for slot # index
- magnitude_t type(unsigned char index) {
- _error = SENSOR_ERROR_OK;
- if (index == 0) return MAGNITUDE_CURRENT;
- if (index == 1) return MAGNITUDE_POWER_APPARENT;
- if (index == 2) return MAGNITUDE_ENERGY;
- if (index == 3) return MAGNITUDE_ENERGY_DELTA;
- _error = SENSOR_ERROR_OUT_OF_RANGE;
- return MAGNITUDE_NONE;
- }
-
- // Current value for slot # index
- double value(unsigned char index) {
-
- _error = SENSOR_ERROR_OK;
-
- // Cache the value
- static unsigned long last = 0;
- static double current = 0;
- static unsigned long energy_delta = 0;
-
- if ((last == 0) || (millis() - last > 1000)) {
- current = read(_gpio);
- energy_delta = current * _voltage * (millis() - last) / 1000;
- _energy += energy_delta;
- last = millis();
- }
-
- if (index == 0) return current;
- if (index == 1) return current * _voltage;
- if (index == 2) return _energy;
- if (index == 3) return energy_delta;
-
- _error = SENSOR_ERROR_OUT_OF_RANGE;
- return 0;
-
- }
-
- protected:
-
- unsigned int readADC(unsigned char channel) {
- return analogRead(channel);
- }
-
- unsigned char _gpio;
- unsigned long _energy = 0;
-
-
- };
|