Temporary Connector Reversed Version
Dependencies: UniGraphic mbed vt100
afero_poc15_180403R , J1 のピン配置を反転させたヴァージョンです。
Color2系を使用するためには以下のピンをジャンパで接続してください。
J1-D7 <-> J1-D0
J1-D6 <-> J1-D1
(調査中) また、こちらでテストした範囲では、
FRDM-KL25Z の V3.3 を、Modulo2 の VCC_3V3 ピンに接続してやる必要がありました。
尚、J1-D1, D0 を使用するために UART を無効にしているため
ログは表示されません。
TFTモジュールについて
aitendoのTFTモジュールはデフォルトでは8bit bus モードになっています。

半田のジャンパを変えて、SPIの設定にしてください。

サーミスタについて
POC1.5 では サーミスタは 25℃の時に抵抗値が 50.0kΩになる502AT-11 が
4.95kΩのプルアップ(実際は10kΩx2の並列)で使用されていました。
今回の試作では抵抗値が 10.0kΩの 103AT-11 が
5.1kΩのプルアップで使用されていますので、係数を合わせるために
SMTC502AT-11 のコンストラクタを
R0 = 10.0
R1 = 5.1
B = 3435
T0 = 298.15
で呼ぶように変更しました。
sensors/VEML6040.cpp
- Committer:
- Rhyme
- Date:
- 2018-04-24
- Revision:
- 0:0b6732b53bf4
File content as of revision 0:0b6732b53bf4:
/*
* File description here
*/
#include "VEML6040.h"
#include "af_mgr.h"
/* VEML6075 SLAVE ADDRESS AND FUNCTION DESCRIPTION */
#define REG_COLOR_CONF 0x00
#define REG_Reserved1 0x01
#define REG_Reserved2 0x02
#define REG_Reserved3 0x03
#define REG_Reserved4 0x04
#define REG_Reserved5 0x05
#define REG_Reserved6 0x06
#define REG_Reserved7 0x07
#define REG_R_Data 0x08
#define REG_G_Data 0x09
#define REG_B_Data 0x0A
#define REG_W_Data 0x0B
// Following magic numbers are from
// VISHAY VEML6040 Application Note 84331
// Page 4
#define LUX_RESOLUTION_0 (0.25168)
#define LUX_RESOLUTION_1 (0.12584)
#define LUX_RESOLUTION_2 (0.06292)
#define LUX_RESOLUTION_3 (0.03146)
#define LUX_RESOLUTION_4 (0.01573)
#define LUX_RESOLUTION_5 (0.007865)
// Following magic numbers are from
// VISHAY VEML6040 Application Note 84331
// Page 9
#define CORR_COEFF_M0 (0.048403)
#define CORR_COEFF_M1 (0.183633)
#define CORR_COEFF_M2 (-0.253589)
#define CORR_COEFF_M3 (0.022916)
#define CORR_COEFF_M4 (0.176388)
#define CORR_COEFF_M5 (-0.183205)
#define CORR_COEFF_M6 (-0.077436)
#define CORR_COEFF_M7 (0.124541)
#define CORR_COEFF_M8 (0.032081)
// Following magic numbers are from
// VISHAY VEML6040 Application Note 84331
// Page 10
#define CCT_CONST (4278.6)
#define OFFSET_OPEN_AIR (0.5)
VEML6040::VEML6040(I2C *i2c, int addr) : m_addr(addr<<1) {
p_i2c = i2c ;
p_i2c->frequency(100000); /* 100kHz */
// activate the peripheral
}
VEML6040::~VEML6040() { }
/**
* set COLOR Config
* @param colorconf uint8_t 8bit register value
* @returns 0: success non-0: failure
* @note Command Code 0x00 is used to access CONF register
* @note bit[7] (reserved)
* @note bit[6:4] = IT[2:0] Integration Time Selector
* @note bit[3] (reserved)
* @note bit[2] TRIG Proceed one detcting cycle at manual force mode
* @note bit[1] AF 0: Auto mode 1: manual force mode
* @note bit[0] SD 0: normal 1: chip shutdown setting
*
* @note IT[2:0] 0=40ms, 1=80ms, 2=160ms, 3=320ms, 4=640ms, 5=1280ms
* @note as our WatchDog is set to 1sec, 1280ms is invalid
* @note and 640ms may not be practical
*/
int VEML6040::setCOLORConf(uint8_t colorconf)
{
int result ;
uint8_t data[3] ;
data[0] = REG_COLOR_CONF ;
data[1] = colorconf ;
data[2] = 0 ;
result = writeRegs(data, 3) ;
return( result ) ;
}
/**
* get COLOR Config
* @param *colorconf uint8_t refer to setCOLORConf for the value
* @returns 0: success non-0: failure
*/
int VEML6040::getCOLORConf(uint8_t *colorconf)
{
int result ;
uint8_t data[2] ;
result = readRegs(REG_COLOR_CONF, data, 2) ;
if (result == 0) {
*colorconf = data[0] ;
}
return( result ) ;
}
int VEML6040::getRData(uint16_t *rdata)
{
uint8_t data[2] ;
int result ;
result = readRegs(REG_R_Data, data, 2) ;
*rdata = (data[1]<<8) | data[0] ;
return( result ) ;
}
int VEML6040::getGData(uint16_t *gdata)
{
uint8_t data[2] ;
int result ;
result = readRegs(REG_G_Data, data, 2) ;
*gdata = (data[1]<<8) | data[0] ;
return( result ) ;
}
int VEML6040::getBData(uint16_t *bdata)
{
uint8_t data[2] ;
int result ;
result = readRegs(REG_B_Data, data, 2) ;
*bdata = (data[1]<<8) | data[0] ;
return( result ) ;
}
int VEML6040::getWData(uint16_t *wdata)
{
uint8_t data[2] ;
int result ;
result = readRegs(REG_W_Data, data, 2) ;
*wdata = (data[1]<<8) | data[0] ;
return( result ) ;
}
// usage
// fvalue = veml->getUVA() ;
// printf("%f", fvalue) ;
float VEML6040::getR(void)
{
uint16_t data ;
float value ;
getRData(&data) ;
value = (float)LUX_RESOLUTION_0 * (float)data ;
return( value ) ;
}
float VEML6040::getG(void)
{
uint16_t data ;
float value ;
getGData(&data) ;
value = (float)LUX_RESOLUTION_0 * (float)data ;
return( value ) ;
}
float VEML6040::getB(void)
{
uint16_t data ;
float value ;
getBData(&data) ;
value = (float)LUX_RESOLUTION_0 * (float)data ;
return( value ) ;
}
float VEML6040::getW(void)
{
uint16_t data ;
float value ;
getWData(&data) ;
value = (float)LUX_RESOLUTION_0 * (float)data ;
return( value ) ;
}
float VEML6040::getX(void)
{
uint16_t R ;
uint16_t G ;
uint16_t B ;
float value ;
getRData(&R) ;
getGData(&G) ;
getBData(&B) ;
value = (float)CORR_COEFF_M0 * (float)R + (float)CORR_COEFF_M1 * (float)G + (float)CORR_COEFF_M2 * (float)B ;
return( value ) ;
}
float VEML6040::getY(void)
{
uint16_t R ;
uint16_t G ;
uint16_t B ;
float value ;
getRData(&R) ;
getGData(&G) ;
getBData(&B) ;
value = (float)CORR_COEFF_M3 * (float)R + (float)CORR_COEFF_M4 * (float)G + (float)CORR_COEFF_M5 * (float)B ;
return( value ) ;
}
float VEML6040::getZ(void)
{
uint16_t R ;
uint16_t G ;
uint16_t B ;
float value ;
getRData(&R) ;
getGData(&G) ;
getBData(&B) ;
value = (float)CORR_COEFF_M6 * (float)R + (float)CORR_COEFF_M7 * (float)G + (float)CORR_COEFF_M8 * (float)B ;
return( value ) ;
}
float VEML6040::getCCTiData(void)
{
uint16_t rdata ;
uint16_t gdata ;
uint16_t bdata ;
float value ;
getRData(&rdata) ;
getGData(&gdata) ;
getBData(&bdata) ;
value = ((float)rdata - (float)bdata) / (float)gdata + (float)OFFSET_OPEN_AIR ;
return( value ) ;
}
float VEML6040::getCCTData(void)
{
// uint16_t cctidata ;
float cctidata ;
float value ;
cctidata = getCCTiData() ;
// getCCTiData(&cctidata) ;
value = (float)CCT_CONST * powf( cctidata, -1.2455 ) ;
return( value ) ;
}
float VEML6040::getCIEX(void)
{
float X ;
float Y ;
float Z ;
float value ;
X = getX() ;
Y = getY() ;
Z = getZ() ;
value = (float)X / ((float)X + (float)Y + (float)Z) ;
return( value ) ;
}
float VEML6040::getCIEY(void)
{
float X ;
float Y ;
float Z ;
float value ;
X = getX() ;
Y = getY() ;
Z = getZ() ;
value = (float)Y / ((float)X + (float)Y + (float)Z) ;
return( value ) ;
}
int VEML6040::readRegs(int addr, uint8_t * data, int len) {
char t[1] = {addr};
int result ;
__disable_irq() ; // Disable Interrupts
result = p_i2c->write(m_addr, t, 1, true);
if (result == 0) { // write success
result = p_i2c->read(m_addr, (char *)data, len, false);
}
__enable_irq() ; // Enable Interrupts
return(result) ;
}
int VEML6040::writeRegs(uint8_t * data, int len) {
int result ;
__disable_irq() ; // Disable Interrupts
result = p_i2c->write(m_addr, (char *)data, len);
__enable_irq() ; // Enable Interrupts
return(result) ;
}
La Suno