10#ifndef M5_UNIT_ANADIG_UNIT_ADS11XX_HPP
11#define M5_UNIT_ANADIG_UNIT_ADS11XX_HPP
12#include <M5UnitComponent.hpp>
13#include <m5_utility/stl/extension.hpp>
14#include <m5_utility/container/circular_buffer.hpp>
30enum class PGA : uint8_t {
42 std::array<uint8_t, 2>
raw{};
51 return (int16_t)m5::types::big_uint16_t(
raw[0],
raw[1]).get();
59 static const int32_t min_code_table[4];
68class UnitADS11XX :
public Component,
public PeriodicMeasurementAdapter<UnitADS11XX, ads11xx::Data> {
72 explicit UnitADS11XX(
const uint8_t addr = DEFAULT_ADDRESS)
73 : Component(addr), _data{
new m5::container::CircularBuffer<ads11xx::Data>(1)}
75 auto ccfg = component_config();
76 ccfg.clock = 400 * 1000U;
77 component_config(ccfg);
83 virtual bool begin()
override;
84 virtual void update(
const bool force =
false)
override;
91 return !empty() ? oldest().differentialValue() : 0;
96 return !empty() ? oldest().differentialVoltage() : std::numeric_limits<float>::quiet_NaN();
126 bool start_periodic_measurement(
const uint8_t cfg_value);
127 bool start_periodic_measurement();
128 bool stop_periodic_measurement();
130 bool measure_singleshot(
ads11xx::Data& data,
const uint8_t cfg_value);
133 bool read_config(uint8_t& v);
134 bool write_config(
const uint8_t v);
135 bool read_measurement(uint8_t v[2]);
136 bool is_data_ready();
138 virtual bool read_if_ready_in_periodic(uint8_t v[2]);
139 virtual uint32_t get_interval(
const uint8_t )
144 M5_UNIT_COMPONENT_PERIODIC_MEASUREMENT_ADAPTER_HPP_BUILDER(UnitADS11XX, ads11xx::Data);
147 std::unique_ptr<m5::container::CircularBuffer<ads11xx::Data>> _data{};
154 inline uint8_t rate()
const
156 return (value >> 2) & 0x03;
162 inline bool continuous()
const
164 return value & (1U << 4);
166 inline bool single()
const
168 return !continuous();
170 inline bool st()
const
174 return (value & 0x80);
177 inline void rate(
const uint8_t rate)
179 value = (value & ~(0x03 << 2)) | ((rate & 0x03) << 2);
183 value = (value & ~0x03) | m5::stl::to_underlying(pga);
185 inline void continuous(
bool enable)
187 value = (value & ~(1U << 4)) | ((enable ? 0 : 1) << 4);
189 inline void single(
bool enable)
193 inline void st(
const bool b)
195 value = (value & ~0x80) | (b ? 0x80 : 0x00);
Base class of ADS1100,ADS1110.
Definition unit_ADS11xx.hpp:68
bool writePGA(const ads11xx::PGA pga)
Write the PGA.
Definition unit_ADS11xx.cpp:158
float differentialVoltage() const
Oldest measured differential voltage(mV)
Definition unit_ADS11xx.hpp:94
virtual bool generalReset()
General reset.
Definition unit_ADS11xx.cpp:173
int16_t differentialValue() const
Oldest measured differential value.
Definition unit_ADS11xx.hpp:89
bool readPGA(ads11xx::PGA &pga)
Read the PGA.
Definition unit_ADS11xx.cpp:148
Top level namespace of M5stack.
Definition unit_ADS11xx.hpp:153
Measurement data group.
Definition unit_ADS11xx.hpp:41
std::array< uint8_t, 2 > raw
Raw.
Definition unit_ADS11xx.hpp:42
float differentialVoltage() const
Gets the differential voltage(mV)
Definition unit_ADS11xx.hpp:54
PGA pga
PGA.
Definition unit_ADS11xx.hpp:44
uint8_t rate
SPS (Value and content depend on derived class)
Definition unit_ADS11xx.hpp:43
float vdd
VDD(mV)
Definition unit_ADS11xx.hpp:45
int16_t differentialValue() const
!
Definition unit_ADS11xx.hpp:49
float factor
Correction factor.
Definition unit_ADS11xx.hpp:46
PGA
Programmable Gain Amplifier.
Definition unit_ADS11xx.hpp:30