Operácie

Acrob043: Rozdiel medzi revíziami

Z SensorWiki

(2. Color Matching Demo software)
 
(17 medziľahlých úprav od rovnakého používateľa nie je zobrazených.)
Riadok 1: Riadok 1:
== Software for Color Sensors ==
+
= Software for Color Sensors =
  
 +
== 1. Basic demonstration ==
  
== Demo software ==
+
* TCS230 sensor:  [http://senzor.robotika.sk/sscim/code/TCS230Demo01.bs2  BASIC Stamp II code]
 +
* ColorPAL sensor: http://senzor.robotika.sk/sscim/code/ColorPalDemo01.ino Arduino code]
 +
* TCS3200 sensor:  [http://senzor.robotika.sk/sscim/code/TCS3200demo01.ino  Arduino code]
 +
* TCS2300 description https://www.waveshare.com/wiki/Color_Sensor
 +
 
 +
Poznamka: ak chceme pri senzore TCS3200 pouzit R,G a B hodnoty v obvyklom rozsahu 0-255, pouzijeme
 +
funkciu map():
 +
 
 +
    //Remaping the value of the frequency to the RGB Model of 0 to 255
 +
      frequency = map(frequency, 25,70,255,0);
 +
 
 +
== 2. Color Matching Demo software ==
  
 
Following Arduino code works with an original Parallax (or PhiPi) ColorDemo.exe program available at
 
Following Arduino code works with an original Parallax (or PhiPi) ColorDemo.exe program available at
the following address: http://www.parallax.com/Portals/0/Downloads/docs/prod/sens/ColorPAL_programs.zip
+
the following address: https://www.parallax.com/sites/default/files/downloads/28380-ColorPAL-Color-Matching-Program-BS-Sample-Files.zip
 +
 
 +
 
 +
* TCS230 sensor: [http://senzor.robotika.sk/sscim/code/TCS230Demo02.bs2  BASIC Stamp II code]
 +
* ColorPAL sensor [http://senzor.robotika.sk/sscim/code/ColorPalDemo02.ino Arduino code]
 +
* 2014: [http://learn.parallax.com/colorpal-arduino-demo Arduino demo + code]
 +
* 2014: [http://parallax.com/downloads/colorpal-color-matching-program-and-basic-stamp-sample-files Demo pre BS2]
 +
 
 +
 
 +
[[Obrázok:ColorMatchDemoExe.png|center]]
 +
 
 +
== 4. Calculations ==
  
[[Obrázok:ColorPAL_demo.png|center]]
 
  
<source lang="c">
+
=== TCS230 ===
/*====================================================
 
/ Connect ColorPAL SIG signal to Arduino pin 2 and 3
 
/ Baud Rate = 9600 kbps
 
/ Works with Arduino 0.20, not with 1.00 and above?
 
/====================================================*/
 
  
#include <SoftwareSerial.h>
 
  
SoftwareSerial ColorPAL(2, 3); // rx = 2, tx = 3
+
Because even the completely black surface reflex some light under white LED illumination, the light response from a completely black subject will be non-zero. For this reason, the black response for each color component has to be determined experimentally, so that it, too, can be subtracted from the overall response. The three components thus measured (with an ambient reference subtracted), Kr, Kg, and Kb, are known as the “black reference”. A black reference is typically obtained only once before each measurement session.
  
int red, grn, blu;
+
The TCS230 light sensor colored photodiodes does not respond equally to the red, green, and blue wavelengths. So, in addition to the ambient reference and black reference, it is also necessary to take a “white reference”, wherein the TCS230 is presented with a completely white surface. Again, after subtracting the ambient lighting, the red, green, and blue components of this reference will be called, Wr, Wg, and Wb. Now we have a way of determining a subject’s actual color as a percentage of the difference between the white and black references. This percentage can be expressed as a value between 0 (0%) and 255 (100%), as follows for red, say:
 +
Cr = 255 . (Ur – Kr) / (Wr – Kr),
 +
where Ur is the uncorrected (except for ambient) reading, and Cr is the corrected reading.
  
int gotcolor = 0;
 
int letter;
 
  
char colorByte[9];
+
=== ColorPAL ===
  
void setup(){
+
The sensor outputs a voltage proportional to all the light that it sees, weighted by the above curve. Therefore, when a subject is illuminated with a red LED only, it will respond with a voltage proportional to the red component of the subject’s color, and similarly with blue and green. When there is ambient light mixed in with the LED’s illumination, its effect can be eliminated by sampling first without any LEDs turned on, then subtracting this reading, in turn, from each of the red, green, and blue components. This reference measurement should be taken before each color measurement to eliminate any effects from varying ambient conditions. In the paragraphs that follow, it will be assumed that an ambient reference is taken and subtracted from each measurement discussed.
  
  // for colordemo 9600,
+
Because the LED and sensor sit next to each other on the ColorPAL’s circuit board, and because the plastic snorkel itself reflects some light back (primarily from its threads), the light response from a completely black subject will be non-zero. For this reason, the black response for each color component has to be determined experimentally, so that it, too, can be subtracted from the overall response. The three components thus measured (with an ambient reference subtracted), Kr, Kg, and Kb, are known as the “black reference”. A black reference is typically obtained only once before each measurement session. The TSL13T light sensor does not respond equally to the red, green, and blue LEDs, and those LEDs don’t put out equal amounts of light at the red, green, and blue wavelengths. So, in addition to the ambient reference and black reference, it is also necessary to take a “white reference”, wherein the ColorPAL is presented with a completely white surface. Again, after subtracting the ambient lighting, the red, green, and blue components of this reference will be called, Wr, Wg, and Wb. Now we have a way of determining a subject’s actual color as a percentage of the difference between the white and black references. This percentage can be expressed as a value between 0 (0%) and 255 (100%), as follows for red, say:
Serial.begin(9600); // Start communication with serial port read value
+
Cr = 255 . (Ur – Kr) / (Wr – Kr),
ColorPAL.begin(4800); // Send signal to led to read value
+
where Ur is the uncorrected (except for ambient) reading, and Cr is the corrected reading.
  
pinMode(2,INPUT); // serial pin out from color pal
 
pinMode(3,INPUT); // from same serial pin, signal pulls up, sends, pulls down, reads
 
digitalWrite(2,HIGH); // Enable the pull-up resistor
 
digitalWrite(3,HIGH); // Enable the pull-up resistor
 
  
pinMode(2,OUTPUT); // send signal out
+
=== Color Matching ===
pinMode(3,OUTPUT);
 
digitalWrite(2,LOW); // turn pin off so pin 3 can go high
 
digitalWrite(3,LOW);
 
  
pinMode(2,INPUT); // Input signal to print
+
'''Color matching''' is done using a "minimax" approach in the RGB color space. In this method, the distance between two colors is the absolute value of the difference between the RGB component that differs most:
pinMode(3,INPUT);
 
  
delay(20);
+
Di = max{|R - Ri|, |G - Gi|, |B - Bi|}
  
while( digitalRead(2) != HIGH || digitalRead(3) != HIGH ) {
+
where R, G and B are the red, green, and blue coordinates of the color being scanned; and Ri, Gi and Bi are the coordinates of stored color. The color with the closest match is taken to be the one whose is the smallest, i.e. minimizing the maximum difference. Hence the term "minimax".
delay(50);
 
}
 
  
 +
== 3. Processing software ==
  
pinMode(2,OUTPUT);
+
* PC software: [http://ap.urpi.fei.stuba.sk/sscim/code/ColorSensorDemo03.pde  Processing code]
pinMode(3,OUTPUT);
+
* TCS230 sensor: [http://ap.urpi.fei.stuba.sk/sscim/code/TCS230Demo03.bs2  BASIC Stamp II code]
digitalWrite(2,LOW);
+
* ColorPAL sensor [http://ap.urpi.fei.stuba.sk/sscim/code/ColorPalDemo03.ino Arduino code]
digitalWrite(3,LOW);
 
delay(100); // spec is 80, but not all ColorPAL units work with 80
 
  
pinMode(2,INPUT);
+
[[Obrázok:ColorProcessingDemo.png|center]]
pinMode(3,OUTPUT);
 
delay(100);
 
  
 +
<source lang="c">
 +
// Demonstration program for Color Sensors
 +
// TCS 230 sensor requires TCS230_Demo03_SS_CIM.bs2
 +
// ColorPAL sensor requires ColorPAL_Demo03_SS_CIM.ino with line 78 uncommented
 +
//
 +
// SS_CIM 2013
 +
// Richard Balogh
  
  delay(20);
+
import processing.serial.*;
  ColorPAL.begin(4800);
 
  ColorPAL.print("= (00 $ m) !"); // set up loop to continuously send color data
 
  pinMode(3,INPUT);
 
  
 +
int lf = 10;    // Line Feed in ASCII
 +
int cr = 13;    // Carriage Returin in ASCII
  
 +
int val = 0;    // To store data from serial port, used to color background
 +
int r,g,b,c;    // Used to color background
 +
Serial port;    // The serial port object
 +
 +
void setup() {
 +
  size(200,200);            // Size of canvas
 +
 
 +
println(Serial.list());    // List of available ports
 +
 
 +
                            // Use the port (CHANGE THIS according YOUR PC!)
 +
port = new Serial(this, Serial.list()[3], 9600);
 
}
 
}
  
// This oscillates back and forth on one wire to turn off led, send signal,
+
void draw() {
// turn on led, read signal. very fast strobe read - arduino is not capable of
+
        // The serial data is used to color the background.  
// one wire signal communication over digital ports, so this is a way around
+
background(r,g,b);
// that over 2 wires communicating with 1 pin on the sensor.
+
}
//---------------------------------
 
 
 
void loop()
 
{
 
  
  readColor();
 
  gotcolor = 0;
 
  delay(100);
 
  
}  /* End of loop()  */
 
  
  
/* ***************************************** */
+
// Called whenever there is something available to read
/* Function readColor()                      */
 
/* Reads ColorPAL, putting results in the    */
 
/*      red, grn, blu variables            */
 
/* ***************************************** */
 
void readColor()
 
{
 
  char rByte[9];
 
  char dummy[4];
 
  
//  delay(20);
+
void serialEvent(Serial port) {
//  ColorPAL.begin(4800);
 
//  ColorPAL.print("= (00 $ m) !"); // set up loop to continuously send color data
 
  
   pinMode(3,INPUT);
+
   // Data from the Serial port is read in serialEvent()  
  gotcolor = 0;
+
   // using the readStringUntil() function with LF as
   while (gotcolor == 0)
+
  // the end character.
  {
 
    rByte[0] = ColorPAL.read();
 
    if( rByte[0] == '$' )
 
      {
 
      gotcolor = 1;
 
      for (int i=0; i<9; i++)
 
          {
 
          rByte[i] = ColorPAL.read();
 
          }
 
  
    Serial.print("R0");
+
  String input = port.readStringUntil(lf);  
    Serial.print(rByte[0]);
+
 
    Serial.print(rByte[1]);
+
  if (input != null) {
    Serial.print(rByte[2]);
+
    // Print message received
    Serial.print(" G0");
+
    println( "Receiving:" + input);
    Serial.print(rByte[3]);
+
   
    Serial.print(rByte[4]);
+
  // The data is split into an array of Strings with
    Serial.print(rByte[5]);
+
  // a comma as a delimiter and converted into an
     Serial.print(" B0");
+
  // array of integers.
     Serial.print(rByte[6]);
+
  int[] vals = int(splitTokens(input, ","));
     Serial.print(rByte[7]);
+
   
     Serial.print(rByte[8]);
+
    // Fill r,g,b variables
    Serial.println();    
+
    r = vals[0];
 +
    g = vals[1];
 +
    b = vals[2];
 +
    c = vals[3];
 +
 
 +
    /* ************************************* */
 +
    /*                                      */
 +
    /*    Here is place for Your code!!!    */
 +
    /*                                      */
 +
    /* ************************************* */
 +
   
 +
     println( "R:" + r);
 +
     println( "G:" + g);
 +
     println( "B:" + b);
 +
     println( "C:" + c);
  
    }
+
  }
  }
+
}  
}  /* End of function readColor() */
 
 
</source>
 
</source>

Aktuálna revízia z 22:23, 23. marec 2019

Software for Color Sensors

1. Basic demonstration

Poznamka: ak chceme pri senzore TCS3200 pouzit R,G a B hodnoty v obvyklom rozsahu 0-255, pouzijeme funkciu map():

    //Remaping the value of the frequency to the RGB Model of 0 to 255
     frequency = map(frequency, 25,70,255,0);

2. Color Matching Demo software

Following Arduino code works with an original Parallax (or PhiPi) ColorDemo.exe program available at the following address: https://www.parallax.com/sites/default/files/downloads/28380-ColorPAL-Color-Matching-Program-BS-Sample-Files.zip



ColorMatchDemoExe.png

4. Calculations

TCS230

Because even the completely black surface reflex some light under white LED illumination, the light response from a completely black subject will be non-zero. For this reason, the black response for each color component has to be determined experimentally, so that it, too, can be subtracted from the overall response. The three components thus measured (with an ambient reference subtracted), Kr, Kg, and Kb, are known as the “black reference”. A black reference is typically obtained only once before each measurement session.

The TCS230 light sensor colored photodiodes does not respond equally to the red, green, and blue wavelengths. So, in addition to the ambient reference and black reference, it is also necessary to take a “white reference”, wherein the TCS230 is presented with a completely white surface. Again, after subtracting the ambient lighting, the red, green, and blue components of this reference will be called, Wr, Wg, and Wb. Now we have a way of determining a subject’s actual color as a percentage of the difference between the white and black references. This percentage can be expressed as a value between 0 (0%) and 255 (100%), as follows for red, say:

Cr = 255 . (Ur – Kr) / (Wr – Kr), 

where Ur is the uncorrected (except for ambient) reading, and Cr is the corrected reading.


ColorPAL

The sensor outputs a voltage proportional to all the light that it sees, weighted by the above curve. Therefore, when a subject is illuminated with a red LED only, it will respond with a voltage proportional to the red component of the subject’s color, and similarly with blue and green. When there is ambient light mixed in with the LED’s illumination, its effect can be eliminated by sampling first without any LEDs turned on, then subtracting this reading, in turn, from each of the red, green, and blue components. This reference measurement should be taken before each color measurement to eliminate any effects from varying ambient conditions. In the paragraphs that follow, it will be assumed that an ambient reference is taken and subtracted from each measurement discussed.

Because the LED and sensor sit next to each other on the ColorPAL’s circuit board, and because the plastic snorkel itself reflects some light back (primarily from its threads), the light response from a completely black subject will be non-zero. For this reason, the black response for each color component has to be determined experimentally, so that it, too, can be subtracted from the overall response. The three components thus measured (with an ambient reference subtracted), Kr, Kg, and Kb, are known as the “black reference”. A black reference is typically obtained only once before each measurement session. The TSL13T light sensor does not respond equally to the red, green, and blue LEDs, and those LEDs don’t put out equal amounts of light at the red, green, and blue wavelengths. So, in addition to the ambient reference and black reference, it is also necessary to take a “white reference”, wherein the ColorPAL is presented with a completely white surface. Again, after subtracting the ambient lighting, the red, green, and blue components of this reference will be called, Wr, Wg, and Wb. Now we have a way of determining a subject’s actual color as a percentage of the difference between the white and black references. This percentage can be expressed as a value between 0 (0%) and 255 (100%), as follows for red, say:

Cr = 255 . (Ur – Kr) / (Wr – Kr), 

where Ur is the uncorrected (except for ambient) reading, and Cr is the corrected reading.


Color Matching

Color matching is done using a "minimax" approach in the RGB color space. In this method, the distance between two colors is the absolute value of the difference between the RGB component that differs most:

Di = max{|R - Ri|, |G - Gi|, |B - Bi|}

where R, G and B are the red, green, and blue coordinates of the color being scanned; and Ri, Gi and Bi are the coordinates of stored color. The color with the closest match is taken to be the one whose is the smallest, i.e. minimizing the maximum difference. Hence the term "minimax".

3. Processing software

ColorProcessingDemo.png
// Demonstration program for Color Sensors
// TCS 230 sensor requires TCS230_Demo03_SS_CIM.bs2
// ColorPAL sensor requires ColorPAL_Demo03_SS_CIM.ino with line 78 uncommented
//
// SS_CIM 2013
// Richard Balogh

import processing.serial.*;

int lf = 10;    // Line Feed in ASCII
int cr = 13;    // Carriage Returin in ASCII

int val = 0;    // To store data from serial port, used to color background
int r,g,b,c;    // Used to color background
Serial port;    // The serial port object

void setup() {
  size(200,200);             // Size of canvas
  
 println(Serial.list());     // List of available ports
  
                             // Use the port (CHANGE THIS according YOUR PC!)
 port = new Serial(this, Serial.list()[3], 9600); 
}

void draw() {
        // The serial data is used to color the background.   
 background(r,g,b); 
}




// Called whenever there is something available to read

void serialEvent(Serial port) {

  // Data from the Serial port is read in serialEvent() 
  // using the readStringUntil() function with LF as 
  // the end character.

  String input = port.readStringUntil(lf); 
  
  if (input != null) {
    // Print message received
    println( "Receiving:" + input);
    
   // The data is split into an array of Strings with 
   // a comma as a delimiter and converted into an 
   // array of integers.
   int[] vals = int(splitTokens(input, ",")); 
    
    // Fill r,g,b variables
    r = vals[0];
    g = vals[1];
    b = vals[2];
    c = vals[3];
  
    /* ************************************* */
    /*                                       */
    /*    Here is place for Your code!!!     */
    /*                                       */
    /* ************************************* */
    
     println( "R:" + r);
     println( "G:" + g);
     println( "B:" + b);
     println( "C:" + c);

  }
}