Melexis MLX90614 library

Dependents:   IR_temperature IR_temperature IR_temperature UserIntefaceLCD ... more

Committer:
aquahika
Date:
Thu Jun 09 13:41:09 2011 +0000
Revision:
3:eb618e916622
Parent:
2:01d333d06727
Child:
4:dcd4fe76bd13

        

Who changed what in which revision?

UserRevisionLine numberNew contents of line
aquahika 1:4a60d3f1e91e 1 #include "mbed.h"
aquahika 1:4a60d3f1e91e 2
aquahika 1:4a60d3f1e91e 3 //Melexis Infrared Thermometer MLX90614 Library
aquahika 1:4a60d3f1e91e 4
aquahika 1:4a60d3f1e91e 5 //*****************************************************************
aquahika 1:4a60d3f1e91e 6 // Build : 2011-06-08 Hikaru Sugiura
aquahika 1:4a60d3f1e91e 7 // Only read thermo data.
aquahika 1:4a60d3f1e91e 8 //
aquahika 1:4a60d3f1e91e 9 // This program is based on Mr.Mitesh Patel's "mlx90614".
aquahika 1:4a60d3f1e91e 10 // http://mbed.org/users/mitesh2patel/programs/mlx90614/lqnetj
aquahika 1:4a60d3f1e91e 11 //
aquahika 1:4a60d3f1e91e 12 // This program does not check CRC.
aquahika 1:4a60d3f1e91e 13 // If you want to check CRC, please do it your self :)
aquahika 1:4a60d3f1e91e 14 //****************************************************************//
aquahika 1:4a60d3f1e91e 15
aquahika 3:eb618e916622 16 /**An Interface for MLX90614
aquahika 3:eb618e916622 17 *
aquahika 3:eb618e916622 18 * @code
aquahika 2:01d333d06727 19 * //Print temperature data
aquahika 2:01d333d06727 20 * #include "mbed.h"
aquahika 2:01d333d06727 21 * #include "mlx90614.h"
aquahika 2:01d333d06727 22 *
aquahika 2:01d333d06727 23 * I2C i2c(p28,p27); //sda,scl
aquahika 2:01d333d06727 24 * MLX90614 thermometer(&i2c);
aquahika 2:01d333d06727 25 *
aquahika 2:01d333d06727 26 * void main(void){
aquahika 2:01d333d06727 27 * if(thermo.getTemp(&temp)){
aquahika 2:01d333d06727 28 * printf("Temperature : %f \r\n",temp);
aquahika 2:01d333d06727 29 * }
aquahika 2:01d333d06727 30 * wait(0.5);
aquahika 2:01d333d06727 31 *
aquahika 2:01d333d06727 32 * }
aquahika 3:eb618e916622 33 * @endcode
aquahika 3:eb618e916622 34 */
aquahika 2:01d333d06727 35
aquahika 2:01d333d06727 36
aquahika 1:4a60d3f1e91e 37 class MLX90614{
aquahika 1:4a60d3f1e91e 38
aquahika 1:4a60d3f1e91e 39 public:
aquahika 2:01d333d06727 40 /** Create MLX90614 interface, initialize with selected I2C port and address.
aquahika 2:01d333d06727 41 *
aquahika 2:01d333d06727 42 * @param i2c I2C device pointer
aquahika 2:01d333d06727 43 * @param addr Device address(default=0xB4)
aquahika 2:01d333d06727 44 */
aquahika 1:4a60d3f1e91e 45 MLX90614(I2C* i2c,int addr=0xB4);
aquahika 2:01d333d06727 46
aquahika 2:01d333d06727 47 /** Get Temperature data from MLX90614.
aquahika 2:01d333d06727 48 *
aquahika 2:01d333d06727 49 * @param temp_val return valiable pointer
aquahika 2:01d333d06727 50 * @return 0 on success (ack), or non-0 on failure (nack)
aquahika 2:01d333d06727 51 */
aquahika 1:4a60d3f1e91e 52 bool getTemp(float* temp_val);
aquahika 1:4a60d3f1e91e 53
aquahika 1:4a60d3f1e91e 54 private:
aquahika 1:4a60d3f1e91e 55 I2C* i2c;
aquahika 1:4a60d3f1e91e 56 int i2caddress;
aquahika 1:4a60d3f1e91e 57
aquahika 0:9237d31f0d03 58 };