122 lines
3.6 KiB
C
Raw Normal View History

2022-09-07 15:20:03 +02:00
#pragma once
// FILE: INA219.h
// AUTHOR: Rob Tillaart
2023-09-24 11:25:28 +02:00
// VERSION: 0.1.5
2022-09-07 15:20:03 +02:00
// DATE: 2021-05-18
// PURPOSE: Arduino library for INA219 voltage, current and power sensor
// URL: https://github.com/RobTillaart/INA219
//
2023-03-31 20:30:08 +02:00
// Read the datasheet for the details how to connect!
2022-09-07 15:20:03 +02:00
//
#include "Arduino.h"
#include "Wire.h"
2023-09-24 11:25:28 +02:00
#define INA219_LIB_VERSION (F("0.1.5"))
2022-09-07 15:20:03 +02:00
class INA219
{
public:
// address between 0x40 and 0x4F
explicit INA219(const uint8_t address, TwoWire *wire = &Wire);
#if defined (ESP8266) || defined(ESP32)
bool begin(const uint8_t sda, const uint8_t scl);
2023-06-13 13:21:10 +02:00
#elif defined (ARDUINO_ARCH_RP2040) && !defined(__MBED__)
bool begin(const uint8_t sda, const uint8_t scl);
2022-09-07 15:20:03 +02:00
#endif
bool begin();
bool isConnected();
2023-03-31 20:30:08 +02:00
// CORE FUNCTIONS // Register
float getShuntVoltage(); // 01
float getBusVoltage(); // 02
float getPower(); // 03
float getCurrent(); // 04
bool getMathOverflowFlag(); // 02
bool getConversionFlag(); // 02
2022-09-07 15:20:03 +02:00
2023-06-13 13:21:10 +02:00
// SCALE HELPERS - milli range
2022-09-07 15:20:03 +02:00
float getBusVoltage_mV() { return getBusVoltage() * 1e3; };
float getShuntVoltage_mV() { return getShuntVoltage() * 1e3; };
float getCurrent_mA() { return getCurrent() * 1e3; };
float getPower_mW() { return getPower() * 1e3; };
2023-06-13 13:21:10 +02:00
// SCALE HELPERS - micro range
float getBusVoltage_uV() { return getBusVoltage() * 1e6; };
2022-09-07 15:20:03 +02:00
float getShuntVoltage_uV() { return getShuntVoltage() * 1e6; };
float getCurrent_uA() { return getCurrent() * 1e6; };
float getPower_uW() { return getPower() * 1e6; };
// CONFIGURATION
// need improvement API wise.
void reset();
// voltage = 16, 32 (values below 32 are rounded to 16 or 32)
bool setBusVoltageRange(uint8_t voltage = 16);
uint8_t getBusVoltageRange(); // returns 16 or 32.
// factor = 1, 2, 4, 8
bool setGain(uint8_t factor = 1);
uint8_t getGain();
2023-09-24 11:25:28 +02:00
// mask
2022-09-07 15:20:03 +02:00
bool setBusADC(uint8_t mask = 0x03);
uint8_t getBusADC();
bool setShuntADC(uint8_t mask = 0x03);
uint8_t getShuntADC();
2023-06-13 13:21:10 +02:00
2022-09-07 15:20:03 +02:00
// Operating mode = 0..7
bool setMode(uint8_t mode = 7);
uint8_t getMode();
bool shutDown() { return setMode(0); };
bool setModeShuntTrigger() { return setMode(1); };
bool setModeBusTrigger() { return setMode(2); };
bool setModeShuntBusTrigger() { return setMode(3); };
bool setModeADCOff() { return setMode(4); };
bool setModeShuntContinuous() { return setMode(5); };
bool setModeBusContinuous() { return setMode(6); };
2023-03-31 20:30:08 +02:00
bool setModeShuntBusContinuous() { return setMode(7); }; // default.
2022-09-07 15:20:03 +02:00
2023-09-24 11:25:28 +02:00
2022-09-07 15:20:03 +02:00
// CALIBRATION
// mandatory to set these! read datasheet.
// maxCurrent >= 0.001
// shunt >= 0.001
2023-09-24 11:25:28 +02:00
bool setMaxCurrentShunt(float maxCurrent = 3.4,
2022-09-07 15:20:03 +02:00
float shunt = 0.002);
bool isCalibrated() { return _current_LSB != 0.0; };
// these return zero if not calibrated!
float getCurrentLSB() { return _current_LSB; };
float getCurrentLSB_mA() { return _current_LSB * 1e3; };
float getCurrentLSB_uA() { return _current_LSB * 1e6; };
float getShunt() { return _shunt; };
float getMaxCurrent() { return _maxCurrent; };
2022-11-14 17:31:55 +01:00
// DEBUG
2022-09-07 15:20:03 +02:00
uint16_t getRegister(uint8_t reg) { return _readRegister(reg); };
private:
2023-09-24 11:25:28 +02:00
2022-09-07 15:20:03 +02:00
uint16_t _readRegister(uint8_t reg);
uint16_t _writeRegister(uint8_t reg, uint16_t value);
float _current_LSB;
float _shunt;
float _maxCurrent;
uint8_t _address;
TwoWire * _wire;
};
2023-03-31 20:30:08 +02:00
// -- END OF FILE --
2022-09-07 15:20:03 +02:00