SCH MME NIBP ref. code

Dependencies:   Adafruit_GFX

Committer:
schmme
Date:
Mon Nov 09 00:33:42 2020 +0000
Revision:
0:8edd7b830280
Child:
1:63bc0088a8ed
SCH MME NIBP ref. code

Who changed what in which revision?

UserRevisionLine numberNew contents of line
schmme 0:8edd7b830280 1 #include <mbed.h>
schmme 0:8edd7b830280 2
schmme 0:8edd7b830280 3 /*=========================================================================
schmme 0:8edd7b830280 4 I2C ADDRESS/BITS
schmme 0:8edd7b830280 5 -----------------------------------------------------------------------*/
schmme 0:8edd7b830280 6 #define ADS1115_ADDRESS (0x49) // 100 1001 (ADDR = VDD)
schmme 0:8edd7b830280 7 /*=========================================================================*/
schmme 0:8edd7b830280 8
schmme 0:8edd7b830280 9 /*=========================================================================
schmme 0:8edd7b830280 10 CONVERSION DELAY (in mS)
schmme 0:8edd7b830280 11 -----------------------------------------------------------------------*/
schmme 0:8edd7b830280 12 #define ADS1115_CONVERSIONDELAY (8)
schmme 0:8edd7b830280 13 /*=========================================================================*/
schmme 0:8edd7b830280 14
schmme 0:8edd7b830280 15 /*=========================================================================
schmme 0:8edd7b830280 16 POINTER REGISTER
schmme 0:8edd7b830280 17 -----------------------------------------------------------------------*/
schmme 0:8edd7b830280 18 #define ADS1115_REG_POINTER_MASK (0x03)
schmme 0:8edd7b830280 19 #define ADS1115_REG_POINTER_CONVERT (0x00)
schmme 0:8edd7b830280 20 #define ADS1115_REG_POINTER_CONFIG (0x01)
schmme 0:8edd7b830280 21 #define ADS1115_REG_POINTER_LOWTHRESH (0x02)
schmme 0:8edd7b830280 22 #define ADS1115_REG_POINTER_HITHRESH (0x03)
schmme 0:8edd7b830280 23 /*=========================================================================*/
schmme 0:8edd7b830280 24
schmme 0:8edd7b830280 25 /*=========================================================================
schmme 0:8edd7b830280 26 CONFIG REGISTER
schmme 0:8edd7b830280 27 -----------------------------------------------------------------------*/
schmme 0:8edd7b830280 28 #define ADS1115_REG_CONFIG_OS_MASK (0x8000)
schmme 0:8edd7b830280 29 #define ADS1115_REG_CONFIG_OS_SINGLE (0x8000) // Write: Set to start a single-conversion
schmme 0:8edd7b830280 30 #define ADS1115_REG_CONFIG_OS_BUSY (0x0000) // Read: Bit = 0 when conversion is in progress
schmme 0:8edd7b830280 31 #define ADS1115_REG_CONFIG_OS_NOTBUSY (0x8000) // Read: Bit = 1 when device is not performing a conversion
schmme 0:8edd7b830280 32
schmme 0:8edd7b830280 33 #define ADS1115_REG_CONFIG_MUX_MASK (0x7000)
schmme 0:8edd7b830280 34 #define ADS1115_REG_CONFIG_MUX_DIFF_0_1 (0x0000) // Differential P = AIN0, N = AIN1 (default)
schmme 0:8edd7b830280 35 #define ADS1115_REG_CONFIG_MUX_DIFF_0_3 (0x1000) // Differential P = AIN0, N = AIN3
schmme 0:8edd7b830280 36 #define ADS1115_REG_CONFIG_MUX_DIFF_1_3 (0x2000) // Differential P = AIN1, N = AIN3
schmme 0:8edd7b830280 37 #define ADS1115_REG_CONFIG_MUX_DIFF_2_3 (0x3000) // Differential P = AIN2, N = AIN3
schmme 0:8edd7b830280 38 #define ADS1115_REG_CONFIG_MUX_SINGLE_0 (0x4000) // Single-ended AIN0
schmme 0:8edd7b830280 39 #define ADS1115_REG_CONFIG_MUX_SINGLE_1 (0x5000) // Single-ended AIN1
schmme 0:8edd7b830280 40 #define ADS1115_REG_CONFIG_MUX_SINGLE_2 (0x6000) // Single-ended AIN2
schmme 0:8edd7b830280 41 #define ADS1115_REG_CONFIG_MUX_SINGLE_3 (0x7000) // Single-ended AIN3
schmme 0:8edd7b830280 42
schmme 0:8edd7b830280 43 #define ADS1115_REG_CONFIG_PGA_MASK (0x0E00)
schmme 0:8edd7b830280 44 #define ADS1115_REG_CONFIG_PGA_6_144V (0x0000) // +/-6.144V range = Gain 2/3
schmme 0:8edd7b830280 45 #define ADS1115_REG_CONFIG_PGA_4_096V (0x0200) // +/-4.096V range = Gain 1
schmme 0:8edd7b830280 46 #define ADS1115_REG_CONFIG_PGA_2_048V (0x0400) // +/-2.048V range = Gain 2 (default)
schmme 0:8edd7b830280 47 #define ADS1115_REG_CONFIG_PGA_1_024V (0x0600) // +/-1.024V range = Gain 4
schmme 0:8edd7b830280 48 #define ADS1115_REG_CONFIG_PGA_0_512V (0x0800) // +/-0.512V range = Gain 8
schmme 0:8edd7b830280 49 #define ADS1115_REG_CONFIG_PGA_0_256V (0x0A00) // +/-0.256V range = Gain 16
schmme 0:8edd7b830280 50
schmme 0:8edd7b830280 51 #define ADS1115_REG_CONFIG_MODE_MASK (0x0100)
schmme 0:8edd7b830280 52 #define ADS1115_REG_CONFIG_MODE_CONTIN (0x0000) // Continuous conversion mode
schmme 0:8edd7b830280 53 #define ADS1115_REG_CONFIG_MODE_SINGLE (0x0100) // Power-down single-shot mode (default)
schmme 0:8edd7b830280 54
schmme 0:8edd7b830280 55 #define ADS1115_REG_CONFIG_DR_MASK (0x00E0)
schmme 0:8edd7b830280 56 #define ADS1115_REG_CONFIG_DR_8SPS (0x0000) // 8SPS
schmme 0:8edd7b830280 57 #define ADS1115_REG_CONFIG_DR_16SPS (0x0020) // 16SPS
schmme 0:8edd7b830280 58 #define ADS1115_REG_CONFIG_DR_32SPS (0x0040) // 32SPS
schmme 0:8edd7b830280 59 #define ADS1115_REG_CONFIG_DR_64SPS (0x0060) // 64SPS
schmme 0:8edd7b830280 60 #define ADS1115_REG_CONFIG_DR_128SPS (0x0080) // 128SPS (default)
schmme 0:8edd7b830280 61 #define ADS1115_REG_CONFIG_DR_475SPS (0x00A0) // 475SPS
schmme 0:8edd7b830280 62 #define ADS1115_REG_CONFIG_DR_860SPS (0x00C0) // 860SPS
schmme 0:8edd7b830280 63
schmme 0:8edd7b830280 64 #define ADS1115_REG_CONFIG_CMODE_MASK (0x0010)
schmme 0:8edd7b830280 65 #define ADS1115_REG_CONFIG_CMODE_TRAD (0x0000) // Traditional comparator with hysteresis (default)
schmme 0:8edd7b830280 66 #define ADS1115_REG_CONFIG_CMODE_WINDOW (0x0010) // Window comparator
schmme 0:8edd7b830280 67
schmme 0:8edd7b830280 68 #define ADS1115_REG_CONFIG_CPOL_MASK (0x0008)
schmme 0:8edd7b830280 69 #define ADS1115_REG_CONFIG_CPOL_ACTVLOW (0x0000) // ALERT/RDY pin is low when active (default)
schmme 0:8edd7b830280 70 #define ADS1115_REG_CONFIG_CPOL_ACTVHI (0x0008) // ALERT/RDY pin is high when active
schmme 0:8edd7b830280 71
schmme 0:8edd7b830280 72 #define ADS1115_REG_CONFIG_CLAT_MASK (0x0004) // Determines if ALERT/RDY pin latches once asserted
schmme 0:8edd7b830280 73 #define ADS1115_REG_CONFIG_CLAT_NONLAT (0x0000) // Non-latching comparator (default)
schmme 0:8edd7b830280 74 #define ADS1115_REG_CONFIG_CLAT_LATCH (0x0004) // Latching comparator
schmme 0:8edd7b830280 75
schmme 0:8edd7b830280 76 #define ADS1115_REG_CONFIG_CQUE_MASK (0x0003)
schmme 0:8edd7b830280 77 #define ADS1115_REG_CONFIG_CQUE_1CONV (0x0000) // Assert ALERT/RDY after one conversions
schmme 0:8edd7b830280 78 #define ADS1115_REG_CONFIG_CQUE_2CONV (0x0001) // Assert ALERT/RDY after two conversions
schmme 0:8edd7b830280 79 #define ADS1115_REG_CONFIG_CQUE_4CONV (0x0002) // Assert ALERT/RDY after four conversions
schmme 0:8edd7b830280 80 #define ADS1115_REG_CONFIG_CQUE_NONE (0x0003) // Disable the comparator and put ALERT/RDY in high state (default)
schmme 0:8edd7b830280 81 /*=========================================================================*/
schmme 0:8edd7b830280 82
schmme 0:8edd7b830280 83 typedef enum {
schmme 0:8edd7b830280 84 GAIN_TWOTHIRDS = ADS1115_REG_CONFIG_PGA_6_144V,
schmme 0:8edd7b830280 85 GAIN_ONE = ADS1115_REG_CONFIG_PGA_4_096V,
schmme 0:8edd7b830280 86 GAIN_TWO = ADS1115_REG_CONFIG_PGA_2_048V,
schmme 0:8edd7b830280 87 GAIN_FOUR = ADS1115_REG_CONFIG_PGA_1_024V,
schmme 0:8edd7b830280 88 GAIN_EIGHT = ADS1115_REG_CONFIG_PGA_0_512V,
schmme 0:8edd7b830280 89 GAIN_SIXTEEN = ADS1115_REG_CONFIG_PGA_0_256V
schmme 0:8edd7b830280 90 } adsGain_t;
schmme 0:8edd7b830280 91
schmme 0:8edd7b830280 92 uint8_t m_i2cAddress;
schmme 0:8edd7b830280 93 uint8_t m_conversionDelay;
schmme 0:8edd7b830280 94 uint8_t m_bitShift;
schmme 0:8edd7b830280 95 adsGain_t m_gain;
schmme 0:8edd7b830280 96 I2C* m_i2c;
schmme 0:8edd7b830280 97
schmme 0:8edd7b830280 98 void ADS1115_Init(I2C* i2c, uint8_t i2cAddress)
schmme 0:8edd7b830280 99 {
schmme 0:8edd7b830280 100 // shift 7 bit address 1 left: read expects 8 bit address, see I2C.h
schmme 0:8edd7b830280 101 m_i2cAddress = i2cAddress << 1;
schmme 0:8edd7b830280 102 m_conversionDelay = ADS1115_CONVERSIONDELAY;
schmme 0:8edd7b830280 103 m_gain = GAIN_TWOTHIRDS; /* +/- 6.144V range (limited to VDD +0.3V max!) */
schmme 0:8edd7b830280 104 m_i2c = i2c;
schmme 0:8edd7b830280 105 }
schmme 0:8edd7b830280 106
schmme 0:8edd7b830280 107 uint16_t ADS1115_readRegister(uint8_t i2cAddress, uint8_t reg)
schmme 0:8edd7b830280 108 {
schmme 0:8edd7b830280 109 char data[2];
schmme 0:8edd7b830280 110 data[0] = reg; // temporary use this to send address to conversion register
schmme 0:8edd7b830280 111 m_i2c->write(i2cAddress, data, 1);
schmme 0:8edd7b830280 112 m_i2c->read(i2cAddress, data, 2);
schmme 0:8edd7b830280 113 return (data[0] << 8 | data [1]);
schmme 0:8edd7b830280 114 }
schmme 0:8edd7b830280 115
schmme 0:8edd7b830280 116 void ADS1115_writeRegister(uint8_t i2cAddress, uint8_t reg, uint16_t value)
schmme 0:8edd7b830280 117 {
schmme 0:8edd7b830280 118 char cmd[3];
schmme 0:8edd7b830280 119 cmd[0] = (char)reg;
schmme 0:8edd7b830280 120 cmd[1] = (char)(value>>8);
schmme 0:8edd7b830280 121 cmd[2] = (char)(value & 0xFF);
schmme 0:8edd7b830280 122 m_i2c->write(i2cAddress, cmd, 3);
schmme 0:8edd7b830280 123 }
schmme 0:8edd7b830280 124
schmme 0:8edd7b830280 125
schmme 0:8edd7b830280 126 uint16_t ADS1115_setConti_ADC_SingleEnded(uint8_t channel)
schmme 0:8edd7b830280 127 {
schmme 0:8edd7b830280 128 if (channel > 3) {
schmme 0:8edd7b830280 129 return 0;
schmme 0:8edd7b830280 130 }
schmme 0:8edd7b830280 131
schmme 0:8edd7b830280 132 // Start with default values
schmme 0:8edd7b830280 133 uint16_t config = ADS1115_REG_CONFIG_CQUE_1CONV | // Assert ALERT/RDY after one conversions
schmme 0:8edd7b830280 134 ADS1115_REG_CONFIG_CLAT_NONLAT | // Non-latching (default val)
schmme 0:8edd7b830280 135 ADS1115_REG_CONFIG_CPOL_ACTVLOW | // Alert/Rdy active low (default val)
schmme 0:8edd7b830280 136 ADS1115_REG_CONFIG_CMODE_TRAD | // Traditional comparator (default val)
schmme 0:8edd7b830280 137 ADS1115_REG_CONFIG_DR_475SPS | // 475SPS
schmme 0:8edd7b830280 138 ADS1115_REG_CONFIG_MODE_CONTIN; // Countinuous-conversion mode
schmme 0:8edd7b830280 139
schmme 0:8edd7b830280 140 // Set PGA/voltage range
schmme 0:8edd7b830280 141 config |= m_gain;
schmme 0:8edd7b830280 142
schmme 0:8edd7b830280 143 // Set single-ended input channel
schmme 0:8edd7b830280 144 switch (channel) {
schmme 0:8edd7b830280 145 case (0):
schmme 0:8edd7b830280 146 config |= ADS1115_REG_CONFIG_MUX_SINGLE_0;
schmme 0:8edd7b830280 147 break;
schmme 0:8edd7b830280 148 case (1):
schmme 0:8edd7b830280 149 config |= ADS1115_REG_CONFIG_MUX_SINGLE_1;
schmme 0:8edd7b830280 150 break;
schmme 0:8edd7b830280 151 case (2):
schmme 0:8edd7b830280 152 config |= ADS1115_REG_CONFIG_MUX_SINGLE_2;
schmme 0:8edd7b830280 153 break;
schmme 0:8edd7b830280 154 case (3):
schmme 0:8edd7b830280 155 config |= ADS1115_REG_CONFIG_MUX_SINGLE_3;
schmme 0:8edd7b830280 156 break;
schmme 0:8edd7b830280 157 }
schmme 0:8edd7b830280 158 ADS1115_writeRegister(m_i2cAddress, ADS1115_REG_POINTER_LOWTHRESH, 0x7fff);
schmme 0:8edd7b830280 159 ADS1115_writeRegister(m_i2cAddress, ADS1115_REG_POINTER_HITHRESH, 0x8000);
schmme 0:8edd7b830280 160 ADS1115_writeRegister(m_i2cAddress, ADS1115_REG_POINTER_CONFIG, config);
schmme 0:8edd7b830280 161
schmme 0:8edd7b830280 162 return 0;
schmme 0:8edd7b830280 163 }
schmme 0:8edd7b830280 164
schmme 0:8edd7b830280 165 int16_t ADS1115_getConti_ADC_SingleEnded()
schmme 0:8edd7b830280 166 {
schmme 0:8edd7b830280 167 uint16_t res = ADS1115_readRegister(m_i2cAddress, ADS1115_REG_POINTER_CONVERT);
schmme 0:8edd7b830280 168 return (int16_t)res;
schmme 0:8edd7b830280 169 }