2022-12-21 21:16:14 +01:00
|
|
|
//
|
|
|
|
// FILE: DMM.cpp
|
|
|
|
// AUTHOR: Rob Tillaart
|
2023-02-04 14:10:04 +01:00
|
|
|
// VERSION: 0.1.2
|
2022-12-21 21:16:14 +01:00
|
|
|
// DATE: 2022-12-19
|
|
|
|
// PURPOSE: Library for a DMM class for Arduino UNO.
|
|
|
|
// URL: https://github.com/RobTillaart/DMM
|
|
|
|
|
|
|
|
|
|
|
|
#include "DMM.h"
|
|
|
|
|
|
|
|
|
|
|
|
DMM::DMM()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void DMM::begin(uint8_t pin, float maxVoltage, uint16_t maxSteps)
|
|
|
|
{
|
|
|
|
_pin = pin;
|
|
|
|
_maxVoltage = maxVoltage;
|
|
|
|
_maxSteps = maxSteps;
|
|
|
|
_voltageStep = _maxVoltage/_maxSteps;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void DMM::setMaxVoltage(float maxVoltage)
|
|
|
|
{
|
|
|
|
_maxVoltage = maxVoltage;
|
|
|
|
_voltageStep = _maxVoltage/_maxSteps;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::getMaxVoltage()
|
|
|
|
{
|
|
|
|
return _maxVoltage;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void DMM::setGain(float factor)
|
|
|
|
{
|
|
|
|
_gain = factor;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::getGain()
|
|
|
|
{
|
|
|
|
return _gain;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-02-04 14:10:04 +01:00
|
|
|
/////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// READ VOLTAGE
|
|
|
|
//
|
2022-12-21 21:16:14 +01:00
|
|
|
float DMM::readVolts(uint8_t times)
|
|
|
|
{
|
|
|
|
uint32_t total = 0;
|
2023-02-04 14:10:04 +01:00
|
|
|
if (times == 0)
|
|
|
|
{
|
|
|
|
times = 1;
|
|
|
|
}
|
2022-12-21 21:16:14 +01:00
|
|
|
for (int i = 0; i < times; i++)
|
|
|
|
{
|
|
|
|
total += analogRead(_pin);
|
|
|
|
}
|
2023-02-04 14:10:04 +01:00
|
|
|
float volts = (total * _voltageStep) / times;
|
2022-12-21 21:16:14 +01:00
|
|
|
|
2023-02-04 14:10:04 +01:00
|
|
|
if (_gain != 1.0)
|
|
|
|
{
|
|
|
|
volts *= _gain;
|
|
|
|
}
|
|
|
|
return volts;
|
2022-12-21 21:16:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::readMilliVolts(uint8_t times)
|
|
|
|
{
|
|
|
|
return readVolts(times) * 1000.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::readNoise(uint8_t times)
|
|
|
|
{
|
|
|
|
uint16_t maxV = 0;
|
|
|
|
uint16_t minV = _maxSteps;
|
|
|
|
|
|
|
|
if (times == 0) times = 1;
|
|
|
|
for (int i = 0; i < times; i++)
|
|
|
|
{
|
|
|
|
uint16_t x = analogRead(_pin);
|
|
|
|
if (x > maxV) maxV = x;
|
|
|
|
if (x < minV) minV = x;
|
|
|
|
}
|
|
|
|
float v = ((maxV - minV) * _voltageStep) / times;
|
|
|
|
|
|
|
|
if (_gain != 1.0) v *= _gain;
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2023-02-04 14:10:04 +01:00
|
|
|
/////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// READ OHM
|
|
|
|
//
|
|
|
|
void DMM::setReferenceR(float ohm)
|
|
|
|
{
|
|
|
|
_ReferenceR = ohm;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::readOhm(uint8_t times)
|
|
|
|
{
|
|
|
|
float voltage = readVolts(times);
|
|
|
|
|
|
|
|
float R = _ReferenceR / voltage * _maxVoltage - _ReferenceR;
|
|
|
|
// float R = (_maxVoltage - voltage) * _ReferenceR / voltage;
|
|
|
|
return R;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
float DMM::readKiloOhm(uint8_t times)
|
|
|
|
{
|
|
|
|
return readOhm(times) * 0.001;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2022-12-21 21:16:14 +01:00
|
|
|
// -- END OF FILE --
|
|
|
|
|
|
|
|
|