/*
|
|
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;
|
|
|
|
};
|