|
|
- /*
- EmonLiteESP
-
- Energy Monitor Library for ESP8266 based on EmonLib
- Currently only support current sensing
- */
-
- #include "Arduino.h"
- #include "EmonLiteESP.h"
-
- void EnergyMonitor::initCurrent(current_c callback, double ref, double ratio) {
-
- _currentCallback = callback;
- _referenceVoltage = ref;
- _currentRatio = ratio;
- _currentMidPoint = (ADC_COUNTS>>1);
-
- calculatePrecision();
-
- };
-
- void EnergyMonitor::calculatePrecision() {
- _currentFactor = _currentRatio * _referenceVoltage / ADC_COUNTS;
- _precision = 0;
- _multiplier = 1;
- while (_multiplier * _currentFactor < 1) {
- _multiplier *= 10;
- ++_precision;
- }
- --_precision;
- _multiplier /= 10;
- }
-
- void EnergyMonitor::setReference(double ref) {
- _referenceVoltage = ref;
- }
-
- void EnergyMonitor::setCurrentRatio(double ratio) {
- _currentRatio = ratio;
- }
-
- byte EnergyMonitor::getPrecision() {
- return _precision;
- }
-
- void EnergyMonitor::setPrecision(byte precision) {
- _precision = precision;
- _multiplier = 1;
- for (byte i=0; i<_precision; i++) _multiplier *= 10;
- }
-
- double EnergyMonitor::getCurrent(unsigned int samples) {
-
- int sample;
- double filtered;
- double sum;
-
- for (unsigned int n = 0; n < samples; n++) {
-
- // Read analog value
- sample = _currentCallback();
-
- // Digital low pass filter extracts the VDC offset
- _currentMidPoint = (_currentMidPoint + (sample - _currentMidPoint) / 10.0);
- filtered = sample - _currentMidPoint;
-
- // Root-mean-square method
- sum += (filtered * filtered);
-
- }
-
- double rms = int(sqrt(sum / samples) - 0.5);
- double current = _currentFactor * rms;
- current = round(current * _multiplier) / _multiplier;
- return current;
-
- };
|