2021-05-16 13:21:38 +02:00
|
|
|
#pragma once
|
|
|
|
//
|
|
|
|
// FILE: LTC2991.h
|
|
|
|
// AUTHOR: Rob Tillaart
|
2023-09-23 19:56:21 +02:00
|
|
|
// VERSION: 0.1.6
|
2021-05-16 13:21:38 +02:00
|
|
|
// DATE: 2021-05-10
|
|
|
|
// PURPOSE: Library for LTC2991 temperature and voltage control IC
|
|
|
|
// URL: https://github.com/RobTillaart/LTC2991
|
|
|
|
|
|
|
|
|
|
|
|
#include "Arduino.h"
|
|
|
|
#include "Wire.h"
|
|
|
|
|
2023-01-23 13:59:35 +01:00
|
|
|
|
2023-09-23 19:56:21 +02:00
|
|
|
#define LTC2991_LIB_VERSION (F("0.1.6"))
|
|
|
|
|
|
|
|
//
|
|
|
|
// DEFINES for readability
|
|
|
|
//
|
|
|
|
#define LTC2991_NEW_DATA 0x01
|
|
|
|
#define LTC2991_NO_DATA 0x00
|
|
|
|
|
|
|
|
#define LTC2991_BUSY 0x01
|
|
|
|
#define LTC2991_IDLE 0x00
|
|
|
|
|
|
|
|
#define LTC2991_TRIGGER_ENABLED 0x01
|
|
|
|
#define LTC2991_TRIGGER_DISABLED 0x00
|
|
|
|
|
|
|
|
#define LTC2991_FILTER_ENABLED 0x01
|
|
|
|
#define LTC2991_FILTER_DISABLED 0x00
|
|
|
|
|
|
|
|
#define LTC2991_VOLTAGE_DIFF 0x01
|
|
|
|
#define LTC2991_VOLTAGE_NORMAL 0x00
|
|
|
|
|
|
|
|
#define LTC2991_PWM_INVERTED 0x01
|
|
|
|
#define LTC2991_PWM_NORMAL 0x00
|
|
|
|
|
|
|
|
#define LTC2991_PWM_ENABLED 0x01
|
|
|
|
#define LTC2991_PWM_DISABLED 0x00
|
|
|
|
|
|
|
|
#define LTC2991_MODE_REPEAT 0x01
|
|
|
|
#define LTC2991_MODE_SINGLE 0x00
|
|
|
|
|
|
|
|
#define LTC2991_TINTERN_ENABLED 0x01
|
|
|
|
#define LTC2991_TINTERN_DISABLED 0x00
|
|
|
|
|
|
|
|
#define LTC2991_TINTERN_FILTER_ENABLED 0x01
|
|
|
|
#define LTC2991_TINTERN_FILTER_DISABLED 0x00
|
|
|
|
|
|
|
|
#define LTC2991_KELVIN 0x01
|
|
|
|
#define LTC2991_CELSIUS 0x00
|
2021-05-16 13:21:38 +02:00
|
|
|
|
|
|
|
|
|
|
|
class LTC2991
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit LTC2991(const int8_t address, TwoWire *wire = &Wire);
|
|
|
|
|
|
|
|
#if defined (ESP8266) || defined(ESP32)
|
2021-05-17 15:43:01 +02:00
|
|
|
bool begin(const uint8_t sda, const uint8_t scl);
|
2021-05-16 13:21:38 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
bool begin();
|
|
|
|
bool isConnected();
|
2023-03-06 18:46:47 +01:00
|
|
|
uint8_t getAddress();
|
2021-05-16 13:21:38 +02:00
|
|
|
|
2023-01-23 13:59:35 +01:00
|
|
|
//
|
|
|
|
// CORE functions
|
|
|
|
//
|
|
|
|
// channel = 1..8
|
|
|
|
bool new_data(uint8_t channel); // external
|
|
|
|
bool new_temperature(); // internal
|
|
|
|
bool new_voltage(); // VCC
|
2021-05-16 13:21:38 +02:00
|
|
|
bool is_busy();
|
|
|
|
|
2021-05-17 15:43:01 +02:00
|
|
|
|
2021-05-16 13:21:38 +02:00
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// EXTERNAL CHANNELS (8 voltage, 4 differentials or 4 temperature)
|
2021-05-16 13:21:38 +02:00
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// n = 1 ==> V1 V2 T1
|
|
|
|
// n = 2 ==> V3 V4 T2
|
|
|
|
// n = 3 ==> V5 V6 T3
|
|
|
|
// n = 4 ==> V7 V8 T4
|
2023-03-06 18:46:47 +01:00
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
void trigger_conversion(uint8_t n); // wrapper around enable()
|
2021-05-17 15:43:01 +02:00
|
|
|
void trigger_conversion_all();
|
2021-05-16 13:21:38 +02:00
|
|
|
void enable(uint8_t n, bool enable);
|
|
|
|
bool is_enabled(uint8_t n);
|
|
|
|
|
2021-05-17 15:43:01 +02:00
|
|
|
|
2023-03-06 18:46:47 +01:00
|
|
|
// n: 1..4 see above
|
2021-05-16 13:21:38 +02:00
|
|
|
void enable_filter(uint8_t n, bool enable);
|
|
|
|
bool is_enabled_filter(uint8_t n);
|
2023-01-23 13:59:35 +01:00
|
|
|
|
|
|
|
void set_Kelvin(uint8_t n); // implicit set_mode_temperature
|
|
|
|
void set_Celsius(uint8_t n); // implicit set_mode_temperature
|
2021-05-17 15:43:01 +02:00
|
|
|
void set_temp_scale(uint8_t n, bool Kelvin = true);
|
2023-01-23 13:59:35 +01:00
|
|
|
char get_temp_scale(uint8_t n); // returns 'C' or 'K'
|
2021-05-16 13:21:38 +02:00
|
|
|
void set_mode_temperature(uint8_t n);
|
2023-01-23 13:59:35 +01:00
|
|
|
|
2021-05-16 13:21:38 +02:00
|
|
|
void set_mode_voltage_differential(uint8_t n);
|
|
|
|
void set_mode_voltage_normal(uint8_t n);
|
2023-01-23 13:59:35 +01:00
|
|
|
uint8_t get_operational_mode(uint8_t n); // enumeration?
|
2021-05-16 13:21:38 +02:00
|
|
|
uint8_t get_differential_mode(uint8_t n);
|
2023-01-23 13:59:35 +01:00
|
|
|
float get_value(uint8_t channel); // chan = 1..8
|
2021-05-16 13:21:38 +02:00
|
|
|
|
|
|
|
|
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// PWM functions
|
2021-05-16 13:21:38 +02:00
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// value = 0..511
|
2021-05-17 15:43:01 +02:00
|
|
|
void set_PWM(uint16_t value = 0);
|
2023-01-23 13:59:35 +01:00
|
|
|
void set_PWM_fast(uint16_t value = 0); // less resolution
|
2021-05-16 13:21:38 +02:00
|
|
|
uint16_t get_PWM();
|
2021-05-17 15:43:01 +02:00
|
|
|
void invert_PWM(bool invert = false);
|
2021-05-16 13:21:38 +02:00
|
|
|
bool is_inverted_PWM();
|
|
|
|
void enable_PWM(bool enable);
|
|
|
|
bool is_enabled_PWM();
|
|
|
|
|
|
|
|
|
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// CONFIGURATION
|
2021-05-16 13:21:38 +02:00
|
|
|
//
|
|
|
|
void set_acquisition_repeat();
|
|
|
|
void set_acquisition_single();
|
|
|
|
uint8_t get_acquisition_mode();
|
|
|
|
|
|
|
|
|
|
|
|
//
|
2023-01-23 13:59:35 +01:00
|
|
|
// INTERNAL SENSORS
|
2021-05-16 13:21:38 +02:00
|
|
|
//
|
|
|
|
void enable_Tintern_Vcc(bool enable);
|
|
|
|
bool is_enabled_Tintern_Vcc();
|
|
|
|
void enable_filter_Tintern(bool enable);
|
|
|
|
bool is_enabled_filter_Tintern();
|
2023-01-23 13:59:35 +01:00
|
|
|
|
|
|
|
void set_Kelvin_Tintern();
|
|
|
|
void set_Celsius_Tintern();
|
2021-05-16 13:21:38 +02:00
|
|
|
void set_temp_scale_Tintern(bool Kelvin = true);
|
2023-03-06 18:46:47 +01:00
|
|
|
char get_temp_scale_Tintern(); // returns 'C' or 'K'
|
2021-05-16 13:21:38 +02:00
|
|
|
float get_Tintern();
|
|
|
|
float get_VCC();
|
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
uint8_t _writeRegister(const uint8_t reg, const uint8_t value);
|
|
|
|
uint8_t _readRegister(const uint8_t reg);
|
|
|
|
uint16_t _readRegister16(const uint8_t reg);
|
|
|
|
|
|
|
|
|
2023-03-06 18:46:47 +01:00
|
|
|
void _setRegisterMask(const uint8_t reg, uint8_t mask);
|
|
|
|
void _clrRegisterMask(const uint8_t reg, uint8_t mask);
|
|
|
|
uint8_t _getRegisterMask(const uint8_t reg, uint8_t mask);
|
2021-05-16 13:21:38 +02:00
|
|
|
|
|
|
|
uint8_t _address;
|
|
|
|
TwoWire * _wire;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2021-12-20 20:24:00 +01:00
|
|
|
|
2023-01-23 13:59:35 +01:00
|
|
|
// -- END OF FILE --
|
2021-12-20 20:24:00 +01:00
|
|
|
|