Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
documentation:microcontroleurs:arduino:modules:ina219_va_meter:index [2025/05/01 13:48] – f1sls | documentation:microcontroleurs:arduino:modules:ina219_va_meter:index [2025/05/04 14:42] (Version actuelle) – f1sls | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ====== Voltmètre / Ampèremètre INA219 ====== | + | ====== Voltmètre / Ampèremètre INA219/ |
{{: | {{: | ||
\\ | \\ | ||
Ligne 10: | Ligne 10: | ||
* 0.1 ohm 1% 2W Current Sense Resistor: The module uses a 0.1-ohm shunt resistor with a 1% tolerance and 2W power rating for current sensing. The low resistance value minimizes power loss, while the 1% tolerance ensures measurement accuracy. The 2W power rating indicates its robustness, supporting current measurements up to ±3.2A. | * 0.1 ohm 1% 2W Current Sense Resistor: The module uses a 0.1-ohm shunt resistor with a 1% tolerance and 2W power rating for current sensing. The low resistance value minimizes power loss, while the 1% tolerance ensures measurement accuracy. The 2W power rating indicates its robustness, supporting current measurements up to ±3.2A. | ||
+ | ===== I2C ===== | ||
+ | The INA219 uses the I2C protocol to communicate with microcontrollers, | ||
+ | |||
+ | The address can be changed if you want to use multiple INA219 sensors on the same I2C bus. The INA219 allows up to 16 different I2C addresses, ranging from 0x40 to 0x4F. This is achieved by configuring the states of the two address pins A0 and A1. On the INA219 module, these two pins, A0 and A1, are often found with solder pads or jumpers. By default, they are connected to the Ground (GND) which corresponds to the default address 0x40. | ||
+ | |||
+ | ^ A1 ^ A0 ^ Slave Address (Hex) ^ | ||
+ | | GND | GND | 0x40 | | ||
+ | | GND | | 0x41 | | ||
+ | | GND | SDA | 0x42 | | ||
+ | | GND | SCL | 0x43 | | ||
+ | | GND | | 0x44 | | ||
+ | | | | 0x45 | | ||
+ | | SDA | | 0x46 | | ||
+ | | SCL | | 0x47 | | ||
+ | | SDA | GND | 0x48 | | ||
+ | | SDA | | 0x49 | | ||
+ | | SDA | SDA | 0x4A | | ||
+ | | SDA | SCL | 0x4B | | ||
+ | | SCL | GND | 0x4C | | ||
+ | | SCL | | 0x4D | | ||
+ | | SCL | SDA | 0x4E | | ||
+ | | SCL | SCL | 0x4F | | ||
+ | |||
+ | You can change the I2C address by changing the connections of these pins to either GND, SDA, SCL, or leaving them floating (not connected). For instance, if you connect the A0 pin to SDA and A1 to GND, the address will be 0x48. | ||
+ | |||
+ | So, if you want to have multiple INA219 modules in the same system, you just need to set a unique address for each one by configuring the A0 and A1 pins accordingly. Remember, any time you change the I2C address, you must update the address in your microcontroller’s software so it knows where to find each INA219 on the I2C bus. | ||
+ | |||
+ | ===== REGISTERS & VALUES CALCULATIONS ===== | ||
+ | |||
+ | The INA219 has a set of internal registers that hold measurement data and control settings. They can be accessed via the I2C interface to configure the chip, initiate measurements, | ||
+ | {{: | ||
+ | |||
+ | ==== Configuration Register (Address = 00h) ==== | ||
+ | This register is used to control various aspects of the INA219, such as the bus voltage range, PGA gain, ADC resolution/ | ||
+ | |||
+ | ==== Shunt Voltage Register (Address = 01h) ==== | ||
+ | This register holds the raw measurement result for the shunt voltage. It can be read to obtain the shunt voltage measurement, | ||
+ | |||
+ | Shunt voltage (in volts) is calculated by taking the raw reading from the Shunt Voltage Register and multiplying it by 10 µV. The formula is: | ||
+ | |||
+ | '' | ||
+ | |||
+ | ==== Bus Voltage Register (Address = 02h) ==== | ||
+ | This register holds the raw measurement result for the bus voltage. It can be read to obtain the bus voltage measurement, | ||
+ | |||
+ | Bus voltage (in volts) is calculated by taking the raw reading from the Bus Voltage Register and multiplying it by 4 mV. The formula is: | ||
+ | |||
+ | '' | ||
+ | |||
+ | ==== Power Register (Address = 03h) ==== | ||
+ | This register holds the calculated power value. It can be read to obtain the power measurement, | ||
+ | |||
+ | Power (in watts) is calculated by taking the raw reading from the Power Register and multiplying it by the Power_LSB value (defined when the calibration register is set). The formula is: | ||
+ | |||
+ | '' | ||
+ | |||
+ | ==== Current Register (Address = 04h) ==== | ||
+ | This register holds the calculated current value. It can be read to obtain the current measurement, | ||
+ | |||
+ | Current (in amperes) is calculated by taking the raw reading from the Current Register and multiplying it by the Current_LSB value (defined when the calibration register is set). The formula is: | ||
+ | |||
+ | '' | ||
+ | |||
+ | ==== Calibration Register (Address = 05h) ==== | ||
+ | This register is used to set the calibration value for the current and power calculations. It can be read or written to set the correct calibration value. | ||
===== PINOUT ===== | ===== PINOUT ===== | ||
{{: | {{: | ||
- | * VCC: This pin is used to supply the operating voltage to the INA219 module. It can handle an input voltage of 3.3V to 5.5V. | + | |
- | * GND: This is the Ground pin. | + | |
- | * SCL: This pin is used for the clock line of the I2C interface. | + | |
- | * SDA: This pin is used for the data line of the I2C interface. | + | |
- | * Vin-: This pin connects to the negative terminal of the voltage supply that you want to measure. This pin is also where the shunt resistor is placed and is used for current sensing. | + | |
- | * Vin+: This pin connects to the positive terminal of the voltage supply that you want to measure. | + | |
+ | ===== WIRING ===== | ||
+ | {{: | ||
+ | {{: | ||
===== Librairie(s) ===== | ===== Librairie(s) ===== | ||
* [[https:// | * [[https:// | ||
Ligne 29: | Ligne 97: | ||
==== ARDUINO CODE ==== | ==== ARDUINO CODE ==== | ||
<code cpp> | <code cpp> | ||
+ | #include < | ||
+ | #include < | ||
+ | |||
+ | Adafruit_INA219 ina219; | ||
+ | |||
+ | void setup(void) | ||
+ | { | ||
+ | Serial.begin(9600); | ||
+ | while (!Serial) | ||
+ | { | ||
+ | delay(1); | ||
+ | } | ||
+ | |||
+ | // Initialize the INA219. | ||
+ | if (! ina219.begin()) | ||
+ | { | ||
+ | Serial.println(" | ||
+ | while (1) | ||
+ | { | ||
+ | delay(10); | ||
+ | } | ||
+ | } | ||
+ | // To use a slightly lower 32V, 1A range (higher precision on amps): | ||
+ | // | ||
+ | // Or to use a lower 16V, 400mA range, call: | ||
+ | // | ||
+ | |||
+ | Serial.println(" | ||
+ | } | ||
+ | |||
+ | void loop(void) | ||
+ | { | ||
+ | float shuntvoltage = 0; | ||
+ | float busvoltage = 0; | ||
+ | float current_mA = 0; | ||
+ | float loadvoltage = 0; | ||
+ | float power_mW = 0; | ||
+ | |||
+ | shuntvoltage = ina219.getShuntVoltage_mV(); | ||
+ | busvoltage = ina219.getBusVoltage_V(); | ||
+ | current_mA = ina219.getCurrent_mA(); | ||
+ | power_mW = ina219.getPower_mW(); | ||
+ | loadvoltage = busvoltage + (shuntvoltage / 1000); | ||
+ | |||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.println("" | ||
+ | |||
+ | delay(1000); | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | <code cpp> | ||
+ | #include " | ||
+ | #include " | ||
+ | |||
+ | Adafruit_INA219 ina219; | ||
+ | |||
+ | void setup() { | ||
+ | // Open serial communications and wait for port to open: | ||
+ | Serial.begin(9600); | ||
+ | while (!Serial) { | ||
+ | ; // wait for serial port to connect. Needed for native USB port only | ||
+ | } | ||
+ | |||
+ | if (! ina219.begin()) { | ||
+ | Serial.println(" | ||
+ | while (1) { delay(10); } | ||
+ | } | ||
+ | |||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.print(" | ||
+ | Serial.println(" | ||
+ | } | ||
+ | |||
+ | void loop() { | ||
+ | float shuntvoltage = 0; | ||
+ | float busvoltage = 0; | ||
+ | float current_mA = 0; | ||
+ | float loadvoltage = 0; | ||
+ | float power_mW = 0; | ||
+ | |||
+ | shuntvoltage = ina219.getShuntVoltage_mV(); | ||
+ | busvoltage = ina219.getBusVoltage_V(); | ||
+ | current_mA = ina219.getCurrent_mA(); | ||
+ | power_mW = ina219.getPower_mW(); | ||
+ | loadvoltage = busvoltage + (shuntvoltage / 1000); | ||
+ | |||
+ | Serial.print(busvoltage); | ||
+ | Serial.print(shuntvoltage); | ||
+ | Serial.print(loadvoltage); | ||
+ | Serial.print(current_mA); | ||
+ | Serial.println(power_mW); | ||
+ | |||
+ | delay(1000); | ||
+ | } | ||
</ | </ |