2015-01-12 09:52:41 +01:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 PHYTEC Messtechnik GmbH
|
2019-08-16 14:18:12 +02:00
|
|
|
* 2017 - 2019 HAW Hamburg
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @defgroup drivers_tmp00x TMP006/TMP007 Infrared Thermopile Sensor
|
2015-09-25 21:06:17 +02:00
|
|
|
* @ingroup drivers_sensors
|
2018-06-12 10:35:56 +02:00
|
|
|
* @ingroup drivers_saul
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief Driver for the Texas Instruments TMP00X sensor.
|
2017-06-09 22:17:02 +02:00
|
|
|
*
|
2019-08-16 14:18:12 +02:00
|
|
|
* The TI TMP00X (Infrared Thermopile Contactless Temperature Sensor) measures
|
2017-06-09 22:17:02 +02:00
|
|
|
* the temperature of an object without need of direct contact with the object.
|
|
|
|
* After initialization the sensor can be set active for periodic measurements.
|
|
|
|
* <br> The conversion duration depends on oversample ratio. The oversample
|
|
|
|
* ratio can be determined by sensor initialization. The target object
|
|
|
|
* temperature can be calculated as follows:<br><br>
|
|
|
|
* Temperature of sensor's die (2 times right shifting and devide-by 32):
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* T_{\mathrm{DIE}} &=& \frac{T_{\mathrm{RAW}}}{128}
|
|
|
|
* \f}
|
|
|
|
* Difference Temperature in Kelvin:
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* T_{\mathrm{DIFF}} &=& T_{\mathrm{DIE}} - T_{\mathrm{REF}}
|
|
|
|
* \f}
|
|
|
|
* Sensitivity of the thermopile sensor, with \f$S_{\mathrm{0}}\f$ as
|
|
|
|
* calibration factor:
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* S &=& S_{\mathrm{0}} \cdot ( 1 + a_1 \cdot T_{\mathrm{DIFF}}
|
|
|
|
* + a_2 \cdot T_{\mathrm{DIFF}}^2 ) \\
|
|
|
|
* \f}
|
|
|
|
* Sensor's voltage (the LSB size is \f$ 156.25\,\mathrm{nV} \f$):
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* V_{\mathrm{OBJ}} &=& V_{\mathrm{RAW}} \cdot 156.25\,\mathrm{nV}
|
|
|
|
* \f}
|
|
|
|
* Offset voltage:
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* V_{OS} &=& b_0 + b_1 \cdot T_{\mathrm{DIFF}}
|
|
|
|
* + b_2 \cdot T_{\mathrm{DIFF}}^2 \\
|
|
|
|
* \f}
|
|
|
|
* Seebeck coefficients of the thermopile:
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* f(V_{\mathrm{OBJ}}) &=& (V_{\mathrm{OBJ}} - V_{O\mathrm{S}})
|
|
|
|
* + c_2 \cdot (V_{\mathrm{OBJ}}
|
|
|
|
* - V_{\mathrm{OS}})^2 \\
|
|
|
|
* \f}
|
|
|
|
* Temperature of the target object:
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* T_{\mathrm{OBJ}} &=& \sqrt[4]{T_{\mathrm{DIE}}^4
|
|
|
|
* + \frac{f(V_{\mathrm{OBJ}})}{S}} \\
|
|
|
|
* \f}
|
|
|
|
* Constants:<br>
|
|
|
|
* \f{eqnarray*}{
|
|
|
|
* a_{\mathrm{1}} &=& 1.75 \cdot 10^{-3} \\
|
|
|
|
* a_{\mathrm{2}} &=& -1.678 \cdot 10^{-5} \\
|
|
|
|
* T_{\mathrm{REF}} &=& 298.15\,\mathrm{K} \\
|
|
|
|
* b_{\mathrm{0}} &=& -2.94 \cdot 10^{-5} \\
|
|
|
|
* b_{\mathrm{1}} &=& -5.7 \cdot 10^{-7} \\
|
|
|
|
* b_{\mathrm{2}} &=& 4.63 \cdot 10^{-9} \\
|
|
|
|
* c_{\mathrm{2}} &=& 13.4
|
|
|
|
* \f}
|
|
|
|
*
|
2019-08-16 14:18:12 +02:00
|
|
|
* The calculation and constants are wrapped from TI TMP00X User's Guide SBOU107.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
2018-06-12 10:35:56 +02:00
|
|
|
* This driver provides @ref drivers_saul capabilities.
|
2015-01-12 09:52:41 +01:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief Interface definition for the TMP00X sensor driver.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @author Johann Fischer <j.fischer@phytec.de>
|
2017-06-09 22:17:02 +02:00
|
|
|
* @author Sebastian Meiling <s@mlng.net>
|
2019-08-16 14:18:12 +02:00
|
|
|
* @author Jannes Volkens <jannes.volkens@haw-hamburg.de>
|
2015-01-12 09:52:41 +01:00
|
|
|
*/
|
|
|
|
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_H
|
|
|
|
#define TMP00X_H
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "periph/i2c.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
2019-08-16 14:18:12 +02:00
|
|
|
#define BUS (dev->p.i2c) /**< BUS */
|
|
|
|
#define ADDR (dev->p.addr) /**< ADDR */
|
|
|
|
|
2017-06-09 22:17:02 +02:00
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief TMP00X Default Address
|
2017-06-09 22:17:02 +02:00
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_I2C_ADDRESS
|
|
|
|
#define TMP00X_I2C_ADDRESS (0x40)
|
2015-01-12 09:52:41 +01:00
|
|
|
#endif
|
|
|
|
|
2017-06-09 22:17:02 +02:00
|
|
|
/**
|
|
|
|
* @brief Default Conversion Time in us
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_CONVERSION_TIME
|
|
|
|
#define TMP00X_CONVERSION_TIME (1E6)
|
2015-01-12 09:52:41 +01:00
|
|
|
#endif
|
|
|
|
|
2017-11-06 09:04:50 +01:00
|
|
|
/**
|
|
|
|
* @brief Default low power mode
|
|
|
|
*
|
|
|
|
* If set to 0, the device will be always-on
|
|
|
|
* If set to 1, the device will be put in low power mode between measurements.
|
2019-08-16 14:18:12 +02:00
|
|
|
* This adds a @c TMP00X_CONVERSION_TIME us delay to each measurement call
|
2017-11-06 09:04:50 +01:00
|
|
|
* for bringing the device out of standby.
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_USE_LOW_POWER
|
|
|
|
#define TMP00X_USE_LOW_POWER (0)
|
2017-11-06 09:04:50 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Default raw value mode
|
|
|
|
*
|
|
|
|
* If set to 0, measurements will be converted to Celsius.
|
|
|
|
* If set to 1, raw adc readings will be returned.
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_USE_RAW_VALUES
|
|
|
|
#define TMP00X_USE_RAW_VALUES (0)
|
2017-11-06 09:04:50 +01:00
|
|
|
#endif
|
|
|
|
|
2017-06-09 22:17:02 +02:00
|
|
|
/**
|
|
|
|
* @name Conversion rate and AVG sampling configuration
|
|
|
|
* @{
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#define TMP00X_CONFIG_CR_AS1 (0x00) /**< Conversion Time 0.25s, AVG Samples: 1 */
|
|
|
|
#define TMP00X_CONFIG_CR_AS2 (0x01) /**< Conversion Time 0.5s, AVG Samples: 2 */
|
|
|
|
#define TMP00X_CONFIG_CR_AS4 (0x02) /**< Conversion Time 1s, AVG Samples: 4 */
|
|
|
|
#define TMP00X_CONFIG_CR_AS8 (0x03) /**< Conversion Time 2s, AVG Samples: 8 */
|
|
|
|
#define TMP00X_CONFIG_CR_AS16 (0x04) /**< Conversion Time 4s, AVG Samples: 16 */
|
|
|
|
#define TMP00X_CONFIG_CR_DEF TMP00X_CONFIG_CR_AS4 /**< Default for Testing */
|
2015-01-12 09:52:41 +01:00
|
|
|
|
2017-06-09 22:17:02 +02:00
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @name Constants for TMP00X calibration
|
2017-06-09 22:17:02 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
#ifndef TMP00X_CCONST_S0
|
|
|
|
#define TMP00X_CCONST_S0 (6.4E-14) /**< Calibration Factor */
|
2015-01-12 09:52:41 +01:00
|
|
|
#endif
|
2019-08-16 14:18:12 +02:00
|
|
|
#define TMP00X_CCONST_A1 (1.75E-3) /**< Constant \f$a_{\mathrm{1}}\f$ */
|
|
|
|
#define TMP00X_CCONST_A2 (-1.678E-5) /**< Constant \f$a_{\mathrm{2}}\f$ */
|
|
|
|
#define TMP00X_CCONST_TREF (298.15) /**< Constant \f$T_{\mathrm{REF}}\f$ */
|
|
|
|
#define TMP00X_CCONST_B0 (-2.94E-5) /**< Constant \f$b_{\mathrm{0}}\f$ */
|
|
|
|
#define TMP00X_CCONST_B1 (-5.7E-7) /**< Constant \f$b_{\mathrm{1}}\f$ */
|
|
|
|
#define TMP00X_CCONST_B2 (4.63E-9) /**< Constant \f$b_{\mathrm{2}}\f$ */
|
|
|
|
#define TMP00X_CCONST_C2 (13.4) /**< Constant \f$c_{\mathrm{2}}\f$ */
|
|
|
|
#define TMP00X_CCONST_LSB_SIZE (156.25E-9) /**< Sensor Voltage Register LSB Size */
|
2017-06-09 22:17:02 +02:00
|
|
|
/** @} */
|
2015-01-12 09:52:41 +01:00
|
|
|
|
2017-06-09 22:17:02 +02:00
|
|
|
/**
|
|
|
|
* @brief Parameters needed for device initialization
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
i2c_t i2c; /**< I2C device, the sensor is connected to */
|
|
|
|
uint8_t addr; /**< the sensor's slave address on the I2C bus */
|
|
|
|
uint8_t rate; /**< number of averaged samples */
|
2019-08-16 14:18:12 +02:00
|
|
|
} tmp00x_params_t;
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief Device descriptor for TMP00X sensors.
|
2015-01-12 09:52:41 +01:00
|
|
|
*/
|
|
|
|
typedef struct {
|
2019-08-16 14:18:12 +02:00
|
|
|
tmp00x_params_t p; /**< Configuration parameters */
|
|
|
|
} tmp00x_t;
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief TMP00X specific return values
|
2015-01-12 09:52:41 +01:00
|
|
|
*/
|
2017-06-09 22:17:02 +02:00
|
|
|
enum {
|
2019-08-16 14:18:12 +02:00
|
|
|
TMP00X_OK, /**< Success, no error */
|
|
|
|
TMP00X_ERROR_BUS, /**< I2C bus error */
|
|
|
|
TMP00X_ERROR_DEV, /**< internal device error */
|
|
|
|
TMP00X_ERROR_CONF, /**< invalid device configuration */
|
|
|
|
TMP00X_ERROR, /**< general error */
|
2017-06-09 22:17:02 +02:00
|
|
|
};
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief Initialize the TMP00X sensor driver.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor of sensor to initialize
|
2017-06-09 22:17:02 +02:00
|
|
|
* @param[in] params configuration parameters
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @return 0 on success
|
2019-08-16 14:18:12 +02:00
|
|
|
* @return -TMP00X_ERROR_BUS on I2C bus error
|
|
|
|
* @return -TMP00X_ERROR_DEV if sensor test failed
|
|
|
|
* @return -TMP00X_ERROR_CONF if sensor configuration failed
|
2015-01-12 09:52:41 +01:00
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_init(tmp00x_t *dev, const tmp00x_params_t *params);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2019-08-16 14:18:12 +02:00
|
|
|
* @brief Reset the TMP00X sensor, afterwards it should be reinitialized.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[out] dev device descriptor of sensor
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_reset(const tmp00x_t *dev);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2017-06-09 22:17:02 +02:00
|
|
|
* @brief Set active mode, this enables periodic measurements.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_set_active(const tmp00x_t *dev);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2017-06-09 22:17:02 +02:00
|
|
|
* @brief Set standby mode.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_set_standby(const tmp00x_t *dev);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2017-06-09 22:17:02 +02:00
|
|
|
* @brief Read sensor's data.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
* @param[out] rawv object voltage value
|
|
|
|
* @param[out] rawt raw die temperature
|
|
|
|
* @param[out] drdy data ready, 0 if a conversion is in progress
|
|
|
|
*
|
|
|
|
* @return 0 on success
|
|
|
|
* @return -1 on error
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_read(const tmp00x_t *dev, int16_t *rawv, int16_t *rawt, uint16_t *drdy);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
|
|
|
/**
|
2017-06-09 22:17:02 +02:00
|
|
|
* @brief Convert raw sensor values to temperature.
|
2015-01-12 09:52:41 +01:00
|
|
|
*
|
|
|
|
* @param[in] rawv object voltage value
|
|
|
|
* @param[in] rawt raw die temperature value
|
|
|
|
* @param[out] tamb converted ambient temperature
|
|
|
|
* @param[out] tobj converted object temperature
|
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
void tmp00x_convert(int16_t rawv, int16_t rawt, float *tamb, float *tobj);
|
2015-01-12 09:52:41 +01:00
|
|
|
|
2017-06-09 23:03:54 +02:00
|
|
|
/**
|
2017-08-29 18:00:46 +02:00
|
|
|
* @brief Convenience function to get ambient and object temperatures in [°C]
|
2017-06-09 23:03:54 +02:00
|
|
|
*
|
2017-08-29 18:00:46 +02:00
|
|
|
* @note Temperature scaled by x100 for accuracy and avoid floats
|
2017-06-09 23:03:54 +02:00
|
|
|
*
|
|
|
|
* @param[in] dev device descriptor of sensor
|
|
|
|
* @param[out] ta converted ambient temperature
|
|
|
|
* @param[out] to converted object temperature
|
2019-10-27 16:49:30 +01:00
|
|
|
*
|
|
|
|
* @return TMP00X_OK on success
|
|
|
|
* @return -TMP00X_ERROR if data read not ready
|
|
|
|
* @return -TMP00X_ERROR_BUS on I2C error
|
2017-06-09 23:03:54 +02:00
|
|
|
*/
|
2019-08-16 14:18:12 +02:00
|
|
|
int tmp00x_read_temperature(const tmp00x_t *dev, int16_t *ta, int16_t *to);
|
2017-06-09 23:03:54 +02:00
|
|
|
|
2015-01-12 09:52:41 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-08-16 14:18:12 +02:00
|
|
|
#endif /* TMP00X_H */
|
2015-01-12 09:52:41 +01:00
|
|
|
/** @} */
|