Hello,
i have a problem with the Color Click Board. It is attached to a small developerboard connected to a NXP LPC1758 processor.
I have tried several Clickboards before (HDC1000, Relay, DALI, etc.) they are working great with the NXP. But the Color click does not.
The communication with I2C works fine, i am able to read the Device ID and it is correct. But when i try to read the High and Low Registers for each Color (RGBC) it seems that these values are not correct. I used the example Code from LibStock, but when i place for example a green card 1 cm over the sensor i am getting values like C=28000 R=10500 G=11300 B=6580.
So the Red and Blue values are much to high.
The code is running in a task under FreeRTOS and the color should be read every second or minute depending on the settings.
Does anybody know what I'm doing wrong? Maybe the initialization of the TCS347 is wrong?
Thank you!
/*
* color_click.c
*/
#include "color_click.h"
#include "FreeRTOS.h"
#include "task.h"
#include "lpc17xx_i2c.h"
#include "lpc17xx_pinsel.h"
#include "lpc17xx_gpio.h"
#include "busyWait.h"
#include "string.h"
#include "debug.h"
#include "stdbool.h"
#define sensor_TASK_PRIORITY ( tskIDLE_PRIORITY + 1 )
#define BUFFER_SIZE 0x3 //16
// Find maximal floating point value
#define MAX_FLOAT(a, b) (((a) > (b)) ? (a) : (b))
// Find minimal floating point value
#define MIN_FLOAT(a, b) (((a) < (b)) ? (a) : (b))
// Color flags
#define PURPLE_FLAG 1
#define BLUE_FLAG 2
#define CYAN_FLAG 3
#define GREEN_FLAG 4
#define PINK_FLAG 5
#define RED_FLAG 6
#define ORANGE_FLAG 7
#define YELLOW_FLAG 8
xTaskHandle xHandle_color = NULL;
bool color_isactive = false;
int colorport = 1;
int LED_R_PIN = 31;
int LED_R_PORT = 1;
int LED_G_PIN = 2;
int LED_B_PIN = 4;
int COLOR_INT_PIN = 3;
I2C_M_SETUP_Type transferMCfg;
uint8_t Master_Buf[BUFFER_SIZE];
void setup_color() {
if (colorport == 1) {
LED_R_PIN = 31;
LED_R_PORT = 1;
LED_G_PIN = 2;
LED_B_PIN = 4;
COLOR_INT_PIN = 3;
} else if (colorport == 2) {
LED_R_PIN = 25;
LED_R_PORT = 0;
LED_G_PIN = 7;
LED_B_PIN = 5;
COLOR_INT_PIN = 6;
}
PINSEL_CFG_Type PinCfg;
/*Set Pins for I2C*/
PinCfg.Funcnum = 3;
PinCfg.Portnum = 0;
PinCfg.Pinnum = 0;
PINSEL_ConfigPin(&PinCfg);
PinCfg.Pinnum = 1;
PINSEL_ConfigPin(&PinCfg);
/*Set LED PINS*/
PinCfg.Funcnum = 0;
PinCfg.Portnum = LED_R_PORT;
PinCfg.Pinnum = LED_R_PIN;
PINSEL_ConfigPin(&PinCfg);
PinCfg.Portnum = 2;
PinCfg.Pinnum = LED_G_PIN;
PINSEL_ConfigPin(&PinCfg);
PinCfg.Portnum = 2;
PinCfg.Pinnum = LED_B_PIN;
PINSEL_ConfigPin(&PinCfg);
PinCfg.Portnum = 2;
PinCfg.Pinnum = COLOR_INT_PIN;
PINSEL_ConfigPin(&PinCfg);
I2C_Init(LPC_I2C1, 400000);
I2C_Cmd(LPC_I2C1, I2C_MASTER_MODE, ENABLE);
busyWaitMs(100);
/*Set LED PINS as GPIO Output*/
GPIO_SetDir(LED_R_PORT, (1 << LED_R_PIN), 1);
GPIO_SetDir(2, (1 << LED_G_PIN), 1);
GPIO_SetDir(2, (1 << LED_B_PIN), 1);
}
void i2c_write(int length) {
transferMCfg.sl_addr7bit = COLOR_I2C_ADDR;
transferMCfg.tx_data = Master_Buf;
transferMCfg.tx_length = length;
transferMCfg.rx_data = NULL;
transferMCfg.rx_length = 0;
transferMCfg.retransmissions_max = 2;
I2C_MasterTransferData(LPC_I2C1, &transferMCfg, I2C_TRANSFER_POLLING);
}
uint8_t i2c_read(int length) {
//uint8_t value = 0;
transferMCfg.sl_addr7bit = COLOR_I2C_ADDR;
transferMCfg.tx_data = NULL;
transferMCfg.tx_length = 0;
transferMCfg.rx_data = Master_Buf;
transferMCfg.rx_length = length;
transferMCfg.retransmissions_max = 2;
I2C_MasterTransferData(LPC_I2C1, &transferMCfg, I2C_TRANSFER_POLLING);
return Master_Buf[0];
}
void ledOn() {
GPIO_SetValue(LED_R_PORT, (1 << LED_R_PIN));
GPIO_SetValue(2, (1 << LED_G_PIN));
GPIO_SetValue(2, (1 << LED_B_PIN));
}
void ledOff() {
GPIO_ClearValue(LED_R_PORT, (1 << LED_R_PIN));
GPIO_ClearValue(2, (1 << LED_G_PIN));
GPIO_ClearValue(2, (1 << LED_B_PIN));
}
float RGB_To_HSL(float red, float green, float blue) {
float volatile fmax, fmin, hue, saturation, luminance;
fmax = MAX_FLOAT(MAX_FLOAT(red, green), blue);
fmin = MIN_FLOAT(MIN_FLOAT(red, green), blue);
luminance = fmax;
if (fmax > 0)
saturation = (fmax - fmin) / fmax;
else
saturation = 0;
if (saturation == 0)
hue = 0;
else {
if (fmax == red)
hue = (green - blue) / (fmax - fmin);
else if (fmax == green)
hue = 2 + (blue - red) / (fmax - fmin);
else
hue = 4 + (red - green) / (fmax - fmin);
hue = hue / 6;
if (hue < 0)
hue += 1;
}
return hue;
}
void convertcolor(float color_value) {
char color_detected = 0, color_flag = 0;
if ((color_value >= 0.992) && (color_value <= 0.999)) {
color_detected = 1;
if (color_flag != ORANGE_FLAG) {
color_flag = ORANGE_FLAG;
printToUart("Orange\r\n");
}
}
// Red color range
else if ((color_value >= 0.9750) && (color_value <= 0.9919)) {
color_detected = 1;
if (color_flag != RED_FLAG) {
color_flag = RED_FLAG;
printToUart("Red\r\n");
}
}
// Pink color range
else if ((color_value >= 0.920) && (color_value <= 0.9749)) {
color_detected = 1;
if (color_flag != PINK_FLAG) {
color_flag = PINK_FLAG;
printToUart("Pink\r\n");
}
}
// Purple color range
else if ((color_value >= 0.6201) && (color_value <= 0.919)) {
color_detected = 1;
if (color_flag != PURPLE_FLAG) {
color_flag = PURPLE_FLAG;
printToUart("Purple\r\n");
}
}
// Blue color range
else if ((color_value >= 0.521) && (color_value <= 0.6200)) {
color_detected = 1;
if (color_flag != BLUE_FLAG) {
color_flag = BLUE_FLAG;
printToUart("Blue\r\n");
}
}
// Cyan color range
else if ((color_value >= 0.470) && (color_value < 0.520)) {
color_detected = 1;
if (color_flag != CYAN_FLAG) {
color_flag = CYAN_FLAG;
printToUart("Cyan\r\n");
}
}
// Green color range
else if ((color_value >= 0.210) && (color_value <= 0.469)) {
color_detected = 1;
if (color_flag != GREEN_FLAG) {
color_flag = GREEN_FLAG;
printToUart("Green\r\n");
}
}
// Yellow color range
else if ((color_value >= 0.0650) && (color_value <= 0.1800)) {
color_detected = 1;
if (color_flag != YELLOW_FLAG) {
color_flag = YELLOW_FLAG;
printToUart("Yellow\r\n");
}
}
// Color not in range
else {
if (color_detected == 0) {
color_flag = 0;
busyWaitMs(500);
printToUart("Color not in range.\r\n");
} else {
color_detected = 0;
}
}
}
void Color_Init() {
Master_Buf[0] = 0x80;
Master_Buf[1] = 0x1B;
i2c_write(2);
}
void setGAIN2() {
Master_Buf[0] = 0x8F;
Master_Buf[1] = 0x10;
i2c_write(2);
}
void setAcquisition() {
Master_Buf[0] = 0x81;
Master_Buf[1] = 0x00;
i2c_write(2);
}
uint8_t Color_Read(uint8_t address) {
Master_Buf[0] = address;
i2c_write(1);
return i2c_read(2);
}
uint8_t getDeviceID2() {
Master_Buf[0] = 0x92;
i2c_write(1);
return i2c_read(1);
}
unsigned int Color_Read_value(char reg) {
unsigned short low_byte;
unsigned int Out_color;
switch (reg) {
case 'C':
low_byte = Color_Read(_CDATA);
Out_color = Color_Read(_CDATAH);
Out_color = (Out_color << ;
Out_color = (Out_color | low_byte);
return Out_color;
break;
case 'R':
low_byte = Color_Read(_RDATA);
Out_color = Color_Read(_RDATAH);
Out_color = (Out_color << ;
Out_color = (Out_color | low_byte);
return Out_color;
break;
case 'G':
low_byte = Color_Read(_GDATA);
Out_color = Color_Read(_GDATAH);
Out_color = (Out_color << ;
Out_color = (Out_color | low_byte);
return Out_color;
break;
case 'B':
low_byte = Color_Read(_BDATA);
Out_color = Color_Read(_BDATAH);
Out_color = (Out_color << ;
Out_color = (Out_color | low_byte);
return Out_color;
break;
default:
return 0;
}
}
static void Color_Sensor_Task(void *pvParameters) {
int i;
uint8_t deviceID = 0;
unsigned int Clear, Red, Green, Blue;
float color_value, color_value_sum;
float Red_Ratio, Green_Ratio, Blue_Ratio;
printToUart("Color_Sensor_Task running..\r\n");
setup_color();
Color_Init();
setGAIN2();
setAcquisition();
ledOn();
for (;;) {
color_value_sum = 0;
deviceID = getDeviceID2();
for (i = 0; i < 16; i++) {
// Read Clear, Red, Green and Blue channel register values
Clear = Color_Read_value('C');
Red = Color_Read_value('R');
Green = Color_Read_value('G');
Blue = Color_Read_value('B');
// Divide Red, Green and Blue values with Clear value
Red_Ratio = ((float) Red / (float) Clear);
Green_Ratio = ((float) Green / (float) Clear);
Blue_Ratio = ((float) Blue / (float) Clear);
// Convert RGB values to HSL values
color_value = RGB_To_HSL(Red_Ratio, Green_Ratio, Blue_Ratio);
// Sum the color values
color_value_sum = color_value_sum + color_value;
}
color_value = color_value_sum / 16.0;
convertcolor(color_value);
vTaskDelay(700);
}
}
void init_color_sensor(int i) {
color_isactive = true;
colorport = i;
xTaskCreate(Color_Sensor_Task, (signed char * )"Color_Sensor", 240, NULL,
sensor_TASK_PRIORITY, &xHandle_color);
}
void deinit_color_sensor() {
ledOff();
color_isactive = false;
I2C_Cmd(LPC_I2C1, I2C_MASTER_MODE, DISABLE);
I2C_DeInit(LPC_I2C1);
vTaskDelete(xHandle_color);
}
Color Click Problem
Discussion on projects that are created by users and posted on mikroElektronika website.
Author
Message
-
- Posts: 2
- Joined: 02 Oct 2015 11:21
Re: Color Click Problem
#2 Post by filip » 06 Oct 2015 09:23
Hi,
The color value depends on various thing, light intensity and direction, distance from the sensor to the object.
You should experimentally test this.
Regards,
Filip.
The color value depends on various thing, light intensity and direction, distance from the sensor to the object.
You should experimentally test this.
Regards,
Filip.
Jump to
- NECTO Studio
- ↳ IDE
- ↳ IDE General
- ↳ IDE Beta Testing
- ↳ IDE Wish List
- ↳ ARM AI Compilers
- ↳ mikroC AI for ARM
- ↳ mikroC AI for ARM General
- ↳ mikroC AI for ARM Beta Testing
- ↳ mikroC AI for ARM Wish List
- ↳ PIC AI compilers
- ↳ mikroC AI for PIC
- ↳ mikroC AI for PIC General
- ↳ mikroC AI for PIC Beta Testing
- ↳ mikroC AI for PIC Wish List
- ↳ PIC32 AI Compilers
- ↳ mikroC AI for PIC32
- ↳ mikroC AI for PIC32 General
- ↳ mikroC AI for PIC32 Beta Testing
- ↳ mikroC AI for PIC32 Wish List
- ↳ dsPIC AI Compilers
- ↳ mikroC AI for dsPIC
- ↳ mikroC AI for dsPIC General
- ↳ mikroC AI for dsPIC Beta Testing
- ↳ mikroC AI for dsPIC Wish List
- ↳ AVR AI Compilers
- ↳ mikroC AI for AVR
- ↳ mikroC AI for AVR General
- ↳ mikroC AI for AVR Beta Testing
- ↳ mikroC AI for AVR Wish List
- ↳ Additional Software
- ↳ Visual TFT AI
- ↳ Visual TFT AI General
- ↳ Visual TFT AI Beta Testing
- ↳ Visual TFT AI Wish List
- PRO Compilers
- ↳ PIC PRO Compilers
- ↳ PIC Compilers General
- ↳ mikroC PRO for PIC
- ↳ mikroC PRO for PIC General
- ↳ mikroC PRO for PIC Beta Testing
- ↳ mikroC PRO for PIC Wish List
- ↳ mikroBasic PRO compiler for PIC
- ↳ mikroBasic PRO for PIC General
- ↳ mikroBasic PRO for PIC Beta Testing
- ↳ mikroBasic PRO for PIC Wish List
- ↳ mikroPascal PRO for PIC
- ↳ mikroPascal PRO for PIC General
- ↳ mikroPascal PRO for PIC Beta Testing
- ↳ mikroPascal PRO for PIC Wish List
- ↳ dsPIC PRO Compilers
- ↳ dsPIC Compilers General
- ↳ mikroC PRO for dsPIC30/33 and PIC24
- ↳ mikroC PRO for dsPIC30/33 and PIC24 General
- ↳ mikroC PRO for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroC PRO for dsPIC30/33 and PIC24 Wish List
- ↳ mikroBasic PRO for dsPIC30/33 and PIC24
- ↳ mikroBasic PRO for dsPIC30/33 and PIC24 General
- ↳ mikroBasic PRO for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroBasic PRO for dsPIC30/33 and PIC24 Wish List
- ↳ mikroPascal PRO for dsPIC30/33 and PIC24
- ↳ mikroPascal PRO for dsPIC30/33 and PIC24 General
- ↳ mikroPascal PRO for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroPascal PRO for dsPIC30/33 and PIC24 Wish List
- ↳ PIC32 PRO Compilers
- ↳ PIC32 Compilers General
- ↳ mikroC PRO for PIC32
- ↳ mikroC PRO for PIC32 General
- ↳ mikroC PRO for PIC32 Beta Testing
- ↳ mikroC PRO for PIC32 Wish List
- ↳ mikroBasic PRO for PIC32
- ↳ mikroBasic PRO for PIC32 General
- ↳ mikroBasic PRO for PIC32 Beta Testing
- ↳ mikroBasic PRO for PIC32 Wish List
- ↳ mikroPascal PRO for PIC32
- ↳ mikroPascal PRO for PIC32 General
- ↳ mikroPascal PRO for PIC32 Beta Testing
- ↳ mikroPascal PRO for PIC32 Wish List
- ↳ AVR PRO Compilers
- ↳ AVR Compilers General
- ↳ mikroC PRO for AVR
- ↳ mikroC PRO for AVR General
- ↳ mikroC PRO for AVR Beta Testing
- ↳ mikroC PRO for AVR Wish List
- ↳ mikroBasic PRO compiler for AVR
- ↳ mikroBasic PRO for AVR General
- ↳ mikroBasic PRO for AVR Beta Testing
- ↳ mikroBasic PRO for AVR Wish List
- ↳ mikroPascal PRO for AVR
- ↳ mikroPascal PRO for AVR General
- ↳ mikroPascal PRO for AVR Beta Testing
- ↳ mikroPascal PRO for AVR Wish List
- ↳ FT90x PRO Compilers
- ↳ FT90x Compilers General
- ↳ mikroC PRO for FT90x
- ↳ mikroC PRO for FT90x General
- ↳ mikroC PRO for FT90x Beta Testing
- ↳ mikroC PRO for FT90x Wish List
- ↳ mikroBasic PRO compiler for FT90x
- ↳ mikroBasic PRO for FT90x General
- ↳ mikroBasic PRO for FT90x Beta Testing
- ↳ mikroBasic PRO for FT90x Wish List
- ↳ mikroPascal PRO for FT90x
- ↳ mikroPascal PRO for FT90x General
- ↳ mikroPascal PRO for FT90x Beta Testing
- ↳ mikroPascal PRO for FT90x Wish List
- ↳ 8051 PRO Compilers
- ↳ 8051 Compilers General
- ↳ mikroC PRO for 8051
- ↳ mikroC PRO for 8051 General
- ↳ mikroC PRO for 8051 Beta Testing
- ↳ mikroC PRO for 8051 Wish List
- ↳ mikroBasic PRO compiler for 8051
- ↳ mikroBasic PRO for 8051 General
- ↳ mikroBasic PRO for 8051 Beta Testing
- ↳ mikroBasic PRO for 8051 Wish List
- ↳ mikroPascal PRO for 8051
- ↳ mikroPascal PRO for 8051 General
- ↳ mikroPascal PRO for 8051 Beta Testing
- ↳ mikroPascal PRO for 8051 Wish List
- ↳ ARM PRO Compilers
- ↳ ARM Compilers General
- ↳ mikroC PRO for ARM
- ↳ mikroC PRO for ARM General
- ↳ mikroC PRO for ARM Beta Testing
- ↳ mikroC PRO for ARM Wish List
- ↳ mikroBasic PRO for ARM
- ↳ mikroBasic PRO for ARM General
- ↳ mikroBasic PRO for ARM Beta Testing
- ↳ mikroBasic PRO for ARM Wish List
- ↳ mikroPascal PRO for ARM
- ↳ mikroPascal PRO for ARM General
- ↳ mikroPascal PRO for ARM Beta Testing
- ↳ mikroPascal PRO for ARM Wish List
- ↳ Older versions of Compilers
- ↳ Older versions of mikroC Compilers
- ↳ mikroC for PIC
- ↳ mikroC General
- ↳ mikroC Beta Testing
- ↳ mikroC Wish List
- ↳ mikroC for dsPIC30/33 and PIC24
- ↳ mikroC for dsPIC30/33 and PIC24 General
- ↳ mikroC for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroC for dsPIC30/33 and PIC24 Wish List
- ↳ RSC-4x mikroC
- ↳ RSC-4x mikroC General
- ↳ RSC-4x mikroC Wish List
- ↳ mikroC Beta testing
- ↳ Older versions of mikroBasic Compilers
- ↳ mikroBasic compiler for PIC
- ↳ mikroBasic General
- ↳ mikroBasic Beta Testing
- ↳ mikroBasic Wish List
- ↳ mikroBasic compiler for dsPIC30/33 and PIC24
- ↳ mikroBasic for dsPIC30/33 and PIC24 General
- ↳ mikroBasic for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroBasic for dsPIC30/33 and PIC24 Wish List
- ↳ mikroBasic for dsPIC30/33 and PIC24 Bug List
- ↳ Obsolete Project: mikroBasic compiler for AVR
- ↳ mikroBasic for AVR General
- ↳ mikroBasic for AVR Wish List
- ↳ mikroBasic Beta testing
- ↳ Older versions of mikroPascal Compilers
- ↳ mikroPascal compiler for PIC
- ↳ mikroPascal FAQ
- ↳ mikroPascal General
- ↳ mikroPascal Beta Testing
- ↳ mikroPascal Wish List
- ↳ mikroPascal Bug List
- ↳ mikroPascal compiler for dsPIC30/33 and PIC24
- ↳ mikroPascal for dsPIC30/33 and PIC24 General
- ↳ mikroPascal for dsPIC30/33 and PIC24 Beta Testing
- ↳ mikroPascal for dsPIC30/33 and PIC24 Wish List
- ↳ mikroPascal for dsPIC30/33 and PIC24 Bug List
- ↳ Obsolete Project: mikroPascal compiler for AVR
- ↳ mikroPascal for AVR General
- ↳ mikroPascal for AVR Wish List
- ↳ mikroPascal Beta testing
- ↳ Library Development Discussion
- ↳ Code Requests
- Additional Software
- ↳ Visual TFT Software
- ↳ Visual TFT General
- ↳ Visual TFT Beta Testing
- ↳ Visual TFT Wish List
- ↳ Visual GLCD Software
- ↳ Visual GLCD General
- ↳ Visual GLCD Beta Testing
- ↳ Visual GLCD Wish List
- ↳ Package Manager Software
- ↳ Package Manager General
- ↳ Package Manager Beta Testing
- ↳ Package Manager Wishlist
- ↳ GLCD Font Creator Software
- ↳ SpeakUp Software
- ↳ Timer Calculator
- ↳ CAN Calculator
- ↳ mikroBootloader
- Hardware
- ↳ Development Boards
- ↳ CODEGRIP programmer and debugger
- ↳ Mikromedia
- ↳ mikroProg™ programmer and debugger
- ↳ Development Boards Wishlist
- ↳ Review
- ↳ Click Boards release
- ↳ Hexiwear
- Website & Forums
- ↳ Libstock Discussion
- ↳ Product Announcements
- ↳ Website & Forums General Discussion
- ↳ Website & Forums Wishlist
- ↳ User Projects