Class Library of "INA226 CURRENT/POWER MONITOR with I2C"
Dependents: INA226TEST Logger_V1 RS485R_2 SOUDA_YOKUTAN_R ... more
INA226 I2Cディジタル電流・電圧・電力計モジュールのクラスライブラリ
ストロベリー・リナックスから販売されてる電流・電圧計モジュールのクラスライブラリです
http://strawberry-linux.com/catalog/items?code=12031
この写真では,INA226 を使って自作GPSロガーの電圧と電流を測定しています.
電圧と電流を同時に測定できますので,電源電圧の確認や,消費電力の計算に使えるでしょう.
テストプログラム
このクラスライブラリを使用したテストプログラムを公開しています.
Import programINA226TEST
INA226 Test Program. Using INA226 class library.
注意点
- ストロベリーリナックスのマニュアルによると,「16ビットの電流の測定値に1.25を掛けたものがそのまま mA の直読になります.」とあるのですが,キャリブレーションレジスタに 0x0A00 を書き込んだ場合は,1.25 を掛ける必要は無さそうです.電圧は常に 1.25 を掛けます.
- INA226 はキャリブレーションレジスタに書き込みを行わないと電流値は0のままです.電流を読み取る場合は,必ずキャリブレーションレジスタに値を書き込んでください.ストロベリーリナックスのモジュールであれば,シャント抵抗は 0.002Ω(2mΩ)と言う事で,INA226 の標準的な抵抗の様ですから,キャリブレーション値は 0x0A00 とおもいます.このクラスライブラリでは,キャリブレーション値の省略値は 0x0A00 にしています.
- 持っているテスター(A&D AD-5518T)と測り比べをしてみました.電圧・電流共に,10〜20ミリ程の差がありそうです.
追記
mbed M0 (黄mbed) でも再コンパイルするだけで動きます.
INA226.hpp
- Committer:
- tosihisa
- Date:
- 2012-11-24
- Revision:
- 2:8950b0f31d73
- Parent:
- 1:e0ebc6af5e04
File content as of revision 2:8950b0f31d73:
/** * @section LICENSE * Released under the MIT License: http://mbed.org/license/mit * Copyright (C) 2012 tosihisa * * @section DESCRIPTION * INA226 - Bi-Directional CURRENT/POWER MONITOR with I2C * http://strawberry-linux.com/catalog/items?code=12031 * */ #ifndef __INA226_INCLUDE // { #define __INA226_INCLUDE #include "mbed.h" /** * INA226 Class. */ class INA226 { public: /** * Constructor. * * @param i2c_ instance of I2C. * @param addr_ I2C slave address. * @param freq_ I2C frequency. */ INA226(I2C &i2c_,int addr_ = 0x80,int freq_ = 100000); /** * Check INA226 exist. * * @param none * @return 0:NOT EXIST / !0:EXIST */ int isExist(void); /** * INA226 raw level read. * * @param pointer_addr INA226 pointer address. * @param val_ read value. * @return 0:Read OK / !0:Read NG */ int rawRead(char pointer_addr,unsigned short *val_); /** * INA226 raw level write. * * @param pointer_addr INA226 pointer address. * @param val_ write value. * @return 0:Read OK / !0:Read NG */ int rawWrite(char pointer_addr,unsigned short val_); /** * Get voltage. * * @param V_ read value; * @return 0:Read OK / !0:Read NG */ int getVoltage(double *V_); /** * Get current. * * @param I_ read value; * @return 0:Read OK / !0:Read NG */ int getCurrent(double *I_); /** * Set current calibration. * * @param val write value; * @return 0:Read OK / !0:Read NG */ int setCurrentCalibration(unsigned short val = 0x0A00); private: I2C &i2c; int i2c_addr; int freq; }; #endif // }