From d468b51afcb4ce9f7e61dcf2dd73ef2760886cee Mon Sep 17 00:00:00 2001 From: Punuy <67164516+Punuy@users.noreply.github.com> Date: Thu, 15 Dec 2022 20:29:52 +0700 Subject: [PATCH] Upload MLX90614 Libraries --- Libraries/MLX90614_Demo.zip | Bin 0 -> 2608 bytes Libraries/MLX90614_Demo/MLX90614.cpp | 103 ++++++++++++++++++++++ Libraries/MLX90614_Demo/MLX90614.h | 34 +++++++ Libraries/MLX90614_Demo/MLX90614_Demo.ino | 40 +++++++++ 4 files changed, 177 insertions(+) create mode 100644 Libraries/MLX90614_Demo.zip create mode 100644 Libraries/MLX90614_Demo/MLX90614.cpp create mode 100644 Libraries/MLX90614_Demo/MLX90614.h create mode 100644 Libraries/MLX90614_Demo/MLX90614_Demo.ino diff --git a/Libraries/MLX90614_Demo.zip b/Libraries/MLX90614_Demo.zip new file mode 100644 index 0000000000000000000000000000000000000000..664fd484a253051c814d473a306ee3422e242b7b GIT binary patch literal 2608 zcmai$2{=^!7stoQk`T=dqKryq-;!OH##jcSAx7E9k~I{`QnKVl7;Bg$!ib?lg{&DP zOPGvpLiTO!OGWuly{~_sw|~$7cb|LDJ@+~He4gib?m72sgrMIC2K-nZuin9b-u!c6 zr&$Aib44jRX<2I++TByq=$}|-fHN)j$Sfp%mL32oU;zMle~aCHQ^MZMtJusnu3H`a zZRqWe*A)=yokSU0BdI4B$m@HJExss9L#B*ACWR}X6a?F>z2%g5uuq)8lL5fqT2S1S z_CxXRP-PyL5)YDYH*`&JuO6tPW|DigpRCVguA!`JQ^w|fN7YM3(M|HRiwSkO zyw~YuMVJrz!QJ}&<)#8XoADqsAU;UP2IeuF-1bSk-Ira)0$IQ9t2k@WJcXGtTlbs~ z3Y3p`UOlG7!*&{UwA{`qfEzl@J}g{j=TsdW!kVsZbok&$et(TR7mUgp{|43#n(;>D zLwi>+WT34}0}_y)e{6D9>U;fm_GTt}G-ZWc><4?IqMhEj6B94QNY>dNEN@E8Jf zIG-rKEZivwbLAhMXx+vm^)$V;ruMZmv;zG1x2^Ydi*e5JNNs0&^ZWSdHiV%F7kpFN z8{8o;30T|9O=7oY4n?O))dOd^OCcb^>T!J|(5awB9yfjN8RnA?oF;vFw*DB8WA_EW z$CH$YKMBtBYmdrARu{;y8R|+UggfwEosIFG+n-(VfI z<3eX)@7(1-JS|`jwle?7!m zuqTO}ykK=_tJ=a3rME`UR$`vS=1yud;0nz&oE79I{YtrK*KgE9 zLO`Z9{X23?YSpZ3HsEu_c*_v`oDqD`vDAKH#)~Ew441+NQ0mqP913~LQGU%4StTa& zFODi1W8Z*GRoJ;l$V|JQg*4wedyexf83nR zNnu^PZ||8zo`Hn}dgstPK&|iyN26P?UV>lP#`Rj;TaJl- zxWU18q2lqGWIkO*Ozs%GC~!na|%*j=ZFMyVp)TD!%)ZI6S1pZjGC1r9)&t8aZ8V^t3W- ztI~`hCb*~!#}_-#UIVq}AwDURUn)J#&s})FJnv;WI_)==elT__rS05x)z%Lvg9i04 zf<6|S9TvTFWA`Bx$_TSWshUuRv|>4Eo0G4|oz#`Zu5R#r05EpBPqHo~F2?Qny$$Me z8fWu6r(~Z`#+1|B_L7fxeic7fr4?TM9n>&KD}D&A_|QKV|L2cI!o|b0*aYD@pw3Za zIjR{VP-d}ScZW|L| z9fBoE0;-M$;V%T-@F8bH{ps>!~+7n$0m1VVLVMtR~UL z@N=gTxqdNupqY8^*`YQ~l1Ggn)Z}#_`yZEtk<9XqjQNl~qAgkk-RS{?9 z4wL=&L)+{Y$V<(1cHN;9Lt%NEm9~8<2SQPUlOgB^!xmMG+TKpaKq#)8Cmy5k!@xJ} z5}vJ7_WbCRTsFg~Qv3BVFd@91+Bb>P$tZ+px{9zUw~xFIFi$}E#XXK%R&YWL$iBXD z;oK(l9lkfVoDlrA)=$PGt5}m56 z5ZK}#lr(vz(7z?Y55lTo$a8|2 ze>5MXMrnHR#B|1YZX*O8Pz~@W(IH6tR(>pwzs7SJ$0;?ZlWy0V z$tM2vf93yQLS;Aqk33?ub62SREpc|eAF^dHO8`q + +// RAM +#define MLX90614_RAWIR1 0x04 +#define MLX90614_RAWIR2 0x05 +#define MLX90614_TA 0x06 // Ambient Temperature +#define MLX90614_TOBJ1 0x07 // Object Temperature 1 +#define MLX90614_TOBJ2 0x08 // Object Temperature 2 +// EEPROM +#define MLX90614_TOMAX 0x20 // Object Temperature Max. +#define MLX90614_TOMIN 0x21 // Object Temperature Min. +#define MLX90614_PWMCTRL 0x22 +#define MLX90614_TARANGE 0x23 +#define MLX90614_EMISS 0x24 +#define MLX90614_CONFIG 0x25 +#define MLX90614_ADDR 0x2E // I2C Address +#define MLX90614_ID1 0x3C +#define MLX90614_ID2 0x3D +#define MLX90614_ID3 0x3E +#define MLX90614_ID4 0x3F + +static uint8_t _crc8( uint8_t *data, uint16_t len ); + +using namespace esl; + +MLX90614::MLX90614( uint8_t slave_addr ) + : i2c_addr(slave_addr), crc_error(false) +{ + // empty +} + +void MLX90614::init( ) { + digitalWrite( SDA, 0 ); // disable pull-up on SDA + digitalWrite( SCL, 0 ); // dsiable pull-up on SCL +} + +uint8_t MLX90614::readSlaveAddress() { + uint8_t addr = read_reg( MLX90614_ADDR ); + return addr; +} + +uint16_t MLX90614::read_reg( uint8_t reg_addr ) { + uint16_t ret; + uint16_t count = 0; + crc_error = false; + Wire.beginTransmission( i2c_addr ); + Wire.write( reg_addr ); + Wire.endTransmission(false); + Wire.requestFrom( i2c_addr, (uint8_t) 3 ); + uint8_t data[6]; + while( Wire.available() < 3 ) { + if ( count++ > 100 ) break; + delayMicroseconds(100); + } + data[0] = (i2c_addr << 1); + data[1] = reg_addr; + data[2] = (i2c_addr << 1) | 1; + for (uint8_t i=0; i < 3; i++) { + data[i+3] = Wire.read(); + } + Wire.endTransmission(); + ret = data[3]; // low byte + ret |= data[4] << 8; // high byte + if ( _crc8( data, 5 ) != data[5] ) { + // Serial.println( "CRC error!"); + ret = 0; + crc_error = true; + } + return ret; +} + +float MLX90614::readAmbientTemperature() { + //temp = read_reg( MLX90614_TA ); + //temp *= 0.02; // 0.02 degrees per LSB (measurement resolution of the MLX90614) + //temp -= 273.15; // Kelvin + uint32_t t = read_reg( MLX90614_TA ); + return ((t*2) - 27315) /100.0; +} + +float MLX90614::readObjectTemperature() { + uint32_t t = read_reg( MLX90614_TOBJ1 ); + return ((t*2) - 27315) /100.0; +} + +static uint8_t _crc8( uint8_t *data, uint16_t len ) { + uint8_t crc = 0x00; + uint8_t b; + while ( len-- > 0 ) { + b = *data++; + b = b ^ crc; + for (uint8_t i=0; i < 8; i++) { + if (b & 0x80) + b = (b << 1) ^ 0x07; + else + b = (b << 1); + } + crc = b; + } + return crc; +} +////////////////////////////////////////////////////////////////////////// diff --git a/Libraries/MLX90614_Demo/MLX90614.h b/Libraries/MLX90614_Demo/MLX90614.h new file mode 100644 index 0000000..211d725 --- /dev/null +++ b/Libraries/MLX90614_Demo/MLX90614.h @@ -0,0 +1,34 @@ +////////////////////////////////////////////////////////////////////////// +// Author: RSP @ Embedded System Lab (ESL), KMUTNB, Thailand +// File: MAX6675.h +// Last Modified: 2014-06-24 +// Note: +// A C++ class for Arduino that provides methods for read ambient +// and object temperature values from the MLX90614 Infrared Thermometer chip. +////////////////////////////////////////////////////////////////////////// +#ifndef __MLX90614_H +#define __MLX90614_H + +#include +#include + +namespace esl { + class MLX90614 { + public: + MLX90614( uint8_t slave_addr = 0x5A ); + void init(); + uint8_t readSlaveAddress(); + float readAmbientTemperature(); + float readObjectTemperature(); + uint16_t read_reg( uint8_t reg_addr ); + inline boolean is_crc_error() { return crc_error; } + + private: + boolean crc_error; + uint8_t i2c_addr; + + }; // end class +} // end namespace + +#endif // __MLX90614_H +////////////////////////////////////////////////////////////////////////// diff --git a/Libraries/MLX90614_Demo/MLX90614_Demo.ino b/Libraries/MLX90614_Demo/MLX90614_Demo.ino new file mode 100644 index 0000000..6dc7dc8 --- /dev/null +++ b/Libraries/MLX90614_Demo/MLX90614_Demo.ino @@ -0,0 +1,40 @@ +////////////////////////////////////////////////////////////////////////////// +/* + * Author: RSP @Embedded System Lab (ESL), KMUTNB, Bangkok/Thailand + * Date: 2015-06-11 + * + * GY-906 MLX90614-BAA (B=3V version, A=single zone, A=filter inside) + * -> Connect Vcc=+3.3V, SDA = A4, SCL = A5, and GND to the Arduino Uno + */ +////////////////////////////////////////////////////////////////////////////// + +#include +#include "MLX90614.h" + +esl::MLX90614 mlx90614; + +void setup() { + Serial.begin(115200); + while (!Serial) ; // for Leonardo or Pro Micro + Wire.begin(); + mlx90614.init( ); + Serial.print( "Address = 0x" ); + Serial.println( mlx90614.readSlaveAddress(), HEX ); +} + +void loop() { + float f; + Serial.print( "Ambient temp. (Ta): " ); + f = mlx90614.readAmbientTemperature(); // ambient temperature + if ( !mlx90614.is_crc_error() ) { + Serial.println(f); + } + Serial.print( "Object1 temp. (To): " ); + f = mlx90614.readObjectTemperature(); // object1 temperature + if ( !mlx90614.is_crc_error() ) { + Serial.println(f); + } + delay(1000); +} + +//////////////////////////////////////////////////////////////////////////////