jueves, 1 de septiembre de 2011

Proyecto Final

links para revisar:
http://www.youtube.com/watch?v=ywz7vN0GF_Y


Para el proyecto final de la clase me gustaría realizar un "cubo musical".
Sería un dispositivo de madera posiblemente (u otro material) con forma de cubo, y en cada cara tendrá un sensor que accionara un sonido. La idea es que al tomar el cubo y tocar las caras de este conforme una melodía.
Decidí hacer este proyecto como una continuación del primer proyecto que construí para mi examen de Tecnologías Aplicadas, el cual consistía en unos dispositivos que actuaban como teclas y al apretar cada una sonaba un pedazo de una canción. Mi objetivo es llevar esta idea a una nueva versión, construir un dispositivo mas formal y si es posible añadir nuevos elementos.
Quiero realizar este proyecto para poder aprender más sobre los sensores de presión u otros componentes de arduino.
La melodía que resulte de este cubo busca crear una atmósfera de reflexión, admiración y calma como la que se forma con los cantos gregorianos de la época medieval.

Aquí se puede escuchar unos ejemplos:








*Como hacer el proyecto:

Yo creo que para realizar este proyecto debería establecer una conexión entre Arduino y MaxMSP. Realice un ejercicio en el cual conecte dos sensores (los que tenía) un potenciómetro lineal y un sensor flex a MaxMSP y al activar los sensores estos intervinieran una onda de sonido que la controlaba el programa MaxMSP.
Para realizar esto cargue el código StandardFirmata en Arduino y conecte los sensores. Luego con Maxuino hice la conexión entre los sensores de MaxMSP.

*Como conectar los sensores:

-Potenciómetro: conectar un cable desde 5v hasta la pata izquierda del sensor. Conectar un cable desde GND hasta la pata derecha del sensor. Conectar un cable desde A2 hasta la pata central del sensor.

-Sensor flex: conectar un cable desde 5v hasta la pata derecha del sensor. Conectar un cable desde GND a la linea azul del breadboard, conectar una resistencia desde la linea azul hasta la linea H. Conectar un cable desde un extremo de la resistencia hasta el A0 y conectar un cable al lado del cable de A0 hasta la pata izquierda del sensor.





*Programa MaxMSP y conexiones con Arduino:


 Código para Arduino:
Se puede encontrar en Exmaple, Firmata, StandardFirmata


/*
  Copyright (C) 2006-2008 Hans-Christoph Steiner.  All rights reserved.

  This library is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 of the License, or (at your option) any later version.

  See file LICENSE.txt for further informations on licensing terms.

  formatted using the GNU C formatting and indenting
*/

/*
 * TODO: use Program Control to load stored profiles from EEPROM
 */

#include <Servo.h>
#include <Firmata.h>

/*==============================================================================
 * GLOBAL VARIABLES
 *============================================================================*/

/* analog inputs */
int analogInputsToReport = 0; // bitwise array to store pin reporting

/* digital input ports */
byte reportPINs[TOTAL_PORTS];       // 1 = report this port, 0 = silence
byte previousPINs[TOTAL_PORTS];     // previous 8 bits sent

/* pins configuration */
byte pinConfig[TOTAL_PINS];         // configuration of every pin
byte portConfigInputs[TOTAL_PORTS]; // each bit: 1 = pin in INPUT, 0 = anything else
int pinState[TOTAL_PINS];           // any value that has been written

/* timer variables */
unsigned long currentMillis;        // store the current value from millis()
unsigned long previousMillis;       // for comparison with currentMillis
int samplingInterval = 19;          // how often to run the main loop (in ms)

Servo servos[MAX_SERVOS];

/*==============================================================================
 * FUNCTIONS
 *============================================================================*/

void outputPort(byte portNumber, byte portValue, byte forceSend)
{
  // pins not configured as INPUT are cleared to zeros
  portValue = portValue & portConfigInputs[portNumber];
  // only send if the value is different than previously sent
  if(forceSend || previousPINs[portNumber] != portValue) {
    Firmata.sendDigitalPort(portNumber, portValue);
    previousPINs[portNumber] = portValue;
  }
}

/* -----------------------------------------------------------------------------
 * check all the active digital inputs for change of state, then add any events
 * to the Serial output queue using Serial.print() */
void checkDigitalInputs(void)
{
  /* Using non-looping code allows constants to be given to readPort().
   * The compiler will apply substantial optimizations if the inputs
   * to readPort() are compile-time constants. */
  if (TOTAL_PORTS > 0 && reportPINs[0]) outputPort(0, readPort(0, portConfigInputs[0]), false);
  if (TOTAL_PORTS > 1 && reportPINs[1]) outputPort(1, readPort(1, portConfigInputs[1]), false);
  if (TOTAL_PORTS > 2 && reportPINs[2]) outputPort(2, readPort(2, portConfigInputs[2]), false);
  if (TOTAL_PORTS > 3 && reportPINs[3]) outputPort(3, readPort(3, portConfigInputs[3]), false);
  if (TOTAL_PORTS > 4 && reportPINs[4]) outputPort(4, readPort(4, portConfigInputs[4]), false);
  if (TOTAL_PORTS > 5 && reportPINs[5]) outputPort(5, readPort(5, portConfigInputs[5]), false);
  if (TOTAL_PORTS > 6 && reportPINs[6]) outputPort(6, readPort(6, portConfigInputs[6]), false);
  if (TOTAL_PORTS > 7 && reportPINs[7]) outputPort(7, readPort(7, portConfigInputs[7]), false);
  if (TOTAL_PORTS > 8 && reportPINs[8]) outputPort(8, readPort(8, portConfigInputs[8]), false);
  if (TOTAL_PORTS > 9 && reportPINs[9]) outputPort(9, readPort(9, portConfigInputs[9]), false);
  if (TOTAL_PORTS > 10 && reportPINs[10]) outputPort(10, readPort(10, portConfigInputs[10]), false);
  if (TOTAL_PORTS > 11 && reportPINs[11]) outputPort(11, readPort(11, portConfigInputs[11]), false);
  if (TOTAL_PORTS > 12 && reportPINs[12]) outputPort(12, readPort(12, portConfigInputs[12]), false);
  if (TOTAL_PORTS > 13 && reportPINs[13]) outputPort(13, readPort(13, portConfigInputs[13]), false);
  if (TOTAL_PORTS > 14 && reportPINs[14]) outputPort(14, readPort(14, portConfigInputs[14]), false);
  if (TOTAL_PORTS > 15 && reportPINs[15]) outputPort(15, readPort(15, portConfigInputs[15]), false);
}

// -----------------------------------------------------------------------------
/* sets the pin mode to the correct state and sets the relevant bits in the
 * two bit-arrays that track Digital I/O and PWM status
 */
void setPinModeCallback(byte pin, int mode)
{
  if (IS_PIN_SERVO(pin) && mode != SERVO && servos[PIN_TO_SERVO(pin)].attached()) {
    servos[PIN_TO_SERVO(pin)].detach();
  }
  if (IS_PIN_ANALOG(pin)) {
    reportAnalogCallback(PIN_TO_ANALOG(pin), mode == ANALOG ? 1 : 0); // turn on/off reporting
  }
  if (IS_PIN_DIGITAL(pin)) {
    if (mode == INPUT) {
      portConfigInputs[pin/8] |= (1 << (pin & 7));
    } else {
      portConfigInputs[pin/8] &= ~(1 << (pin & 7));
    }
  }
  pinState[pin] = 0;
  switch(mode) {
  case ANALOG:
    if (IS_PIN_ANALOG(pin)) {
      if (IS_PIN_DIGITAL(pin)) {
        pinMode(PIN_TO_DIGITAL(pin), INPUT); // disable output driver
        digitalWrite(PIN_TO_DIGITAL(pin), LOW); // disable internal pull-ups
      }
      pinConfig[pin] = ANALOG;
    }
    break;
  case INPUT:
    if (IS_PIN_DIGITAL(pin)) {
      pinMode(PIN_TO_DIGITAL(pin), INPUT); // disable output driver
      digitalWrite(PIN_TO_DIGITAL(pin), LOW); // disable internal pull-ups
      pinConfig[pin] = INPUT;
    }
    break;
  case OUTPUT:
    if (IS_PIN_DIGITAL(pin)) {
      digitalWrite(PIN_TO_DIGITAL(pin), LOW); // disable PWM
      pinMode(PIN_TO_DIGITAL(pin), OUTPUT);
      pinConfig[pin] = OUTPUT;
    }
    break;
  case PWM:
    if (IS_PIN_PWM(pin)) {
      pinMode(PIN_TO_PWM(pin), OUTPUT);
      analogWrite(PIN_TO_PWM(pin), 0);
      pinConfig[pin] = PWM;
    }
    break;
  case SERVO:
    if (IS_PIN_SERVO(pin)) {
      pinConfig[pin] = SERVO;
      if (!servos[PIN_TO_SERVO(pin)].attached()) {
          servos[PIN_TO_SERVO(pin)].attach(PIN_TO_DIGITAL(pin));
      } else {
        Firmata.sendString("Servo only on pins from 2 to 13");
      }
    }
    break;
  case I2C:
    pinConfig[pin] = mode;
    Firmata.sendString("I2C mode not yet supported");
    break;
  default:
    Firmata.sendString("Unknown pin mode"); // TODO: put error msgs in EEPROM
  }
  // TODO: save status to EEPROM here, if changed
}

void analogWriteCallback(byte pin, int value)
{
  if (pin < TOTAL_PINS) {
    switch(pinConfig[pin]) {
    case SERVO:
      if (IS_PIN_SERVO(pin))
        servos[PIN_TO_SERVO(pin)].write(value);
        pinState[pin] = value;
      break;
    case PWM:
      if (IS_PIN_PWM(pin))
        analogWrite(PIN_TO_PWM(pin), value);
        pinState[pin] = value;
      break;
    }
  }
}

void digitalWriteCallback(byte port, int value)
{
  byte pin, lastPin, mask=1, pinWriteMask=0;

  if (port < TOTAL_PORTS) {
    // create a mask of the pins on this port that are writable.
    lastPin = port*8+8;
    if (lastPin > TOTAL_PINS) lastPin = TOTAL_PINS;
    for (pin=port*8; pin < lastPin; pin++) {
      // do not disturb non-digital pins (eg, Rx & Tx)
      if (IS_PIN_DIGITAL(pin)) {
        // only write to OUTPUT and INPUT (enables pullup)
        // do not touch pins in PWM, ANALOG, SERVO or other modes
        if (pinConfig[pin] == OUTPUT || pinConfig[pin] == INPUT) {
          pinWriteMask |= mask;
          pinState[pin] = ((byte)value & mask) ? 1 : 0;
        }
      }
      mask = mask << 1;
    }
    writePort(port, (byte)value, pinWriteMask);
  }
}


// -----------------------------------------------------------------------------
/* sets bits in a bit array (int) to toggle the reporting of the analogIns
 */
//void FirmataClass::setAnalogPinReporting(byte pin, byte state) {
//}
void reportAnalogCallback(byte analogPin, int value)
{
  if (analogPin < TOTAL_ANALOG_PINS) {
    if(value == 0) {
      analogInputsToReport = analogInputsToReport &~ (1 << analogPin);
    } else {
      analogInputsToReport = analogInputsToReport | (1 << analogPin);
    }
  }
  // TODO: save status to EEPROM here, if changed
}

void reportDigitalCallback(byte port, int value)
{
  if (port < TOTAL_PORTS) {
    reportPINs[port] = (byte)value;
  }
  // do not disable analog reporting on these 8 pins, to allow some
  // pins used for digital, others analog.  Instead, allow both types
  // of reporting to be enabled, but check if the pin is configured
  // as analog when sampling the analog inputs.  Likewise, while
  // scanning digital pins, portConfigInputs will mask off values from any
  // pins configured as analog
}

/*==============================================================================
 * SYSEX-BASED commands
 *============================================================================*/

void sysexCallback(byte command, byte argc, byte *argv)
{
  switch(command) {
  case SERVO_CONFIG:
    if(argc > 4) {
      // these vars are here for clarity, they'll optimized away by the compiler
      byte pin = argv[0];
      int minPulse = argv[1] + (argv[2] << 7);
      int maxPulse = argv[3] + (argv[4] << 7);

      if (IS_PIN_SERVO(pin)) {
        // servos are pins from 2 to 13, so offset for array
        if (servos[PIN_TO_SERVO(pin)].attached())
          servos[PIN_TO_SERVO(pin)].detach();
        servos[PIN_TO_SERVO(pin)].attach(PIN_TO_DIGITAL(pin), minPulse, maxPulse);
        setPinModeCallback(pin, SERVO);
      }
    }
    break;
  case SAMPLING_INTERVAL:
    if (argc > 1)
      samplingInterval = argv[0] + (argv[1] << 7);
    else
      Firmata.sendString("Not enough data");
    break;
  case EXTENDED_ANALOG:
    if (argc > 1) {
      int val = argv[1];
      if (argc > 2) val |= (argv[2] << 7);
      if (argc > 3) val |= (argv[3] << 14);
      analogWriteCallback(argv[0], val);
    }
    break;
  case CAPABILITY_QUERY:
    Serial.write(START_SYSEX);
    Serial.write(CAPABILITY_RESPONSE);
    for (byte pin=0; pin < TOTAL_PINS; pin++) {
      if (IS_PIN_DIGITAL(pin)) {
        Serial.write((byte)INPUT);
        Serial.write(1);
        Serial.write((byte)OUTPUT);
        Serial.write(1);
      }
      if (IS_PIN_ANALOG(pin)) {
        Serial.write(ANALOG);
        Serial.write(10);
      }
      if (IS_PIN_PWM(pin)) {
        Serial.write(PWM);
        Serial.write(8);
      }
      if (IS_PIN_SERVO(pin)) {
        Serial.write(SERVO);
        Serial.write(14);
      }
      Serial.write(127);
    }
    Serial.write(END_SYSEX);
    break;
  case PIN_STATE_QUERY:
    if (argc > 0) {
      byte pin=argv[0];
      Serial.write(START_SYSEX);
      Serial.write(PIN_STATE_RESPONSE);
      Serial.write(pin);
      if (pin < TOTAL_PINS) {
        Serial.write((byte)pinConfig[pin]);
Serial.write((byte)pinState[pin] & 0x7F);
if (pinState[pin] & 0xFF80) Serial.write((byte)(pinState[pin] >> 7) & 0x7F);
if (pinState[pin] & 0xC000) Serial.write((byte)(pinState[pin] >> 14) & 0x7F);
      }
      Serial.write(END_SYSEX);
    }
    break;
  case ANALOG_MAPPING_QUERY:
    Serial.write(START_SYSEX);
    Serial.write(ANALOG_MAPPING_RESPONSE);
    for (byte pin=0; pin < TOTAL_PINS; pin++) {
      Serial.write(IS_PIN_ANALOG(pin) ? PIN_TO_ANALOG(pin) : 127);
    }
    Serial.write(END_SYSEX);
    break;
  }
}


/*==============================================================================
 * SETUP()
 *============================================================================*/
void setup()
{
  byte i;

  Firmata.setFirmwareVersion(2, 2);

  Firmata.attach(ANALOG_MESSAGE, analogWriteCallback);
  Firmata.attach(DIGITAL_MESSAGE, digitalWriteCallback);
  Firmata.attach(REPORT_ANALOG, reportAnalogCallback);
  Firmata.attach(REPORT_DIGITAL, reportDigitalCallback);
  Firmata.attach(SET_PIN_MODE, setPinModeCallback);
  Firmata.attach(START_SYSEX, sysexCallback);

  // TODO: load state from EEPROM here

  /* these are initialized to zero by the compiler startup code
  for (i=0; i < TOTAL_PORTS; i++) {
    reportPINs[i] = false;
    portConfigInputs[i] = 0;
    previousPINs[i] = 0;
  }
  */
  for (i=0; i < TOTAL_PINS; i++) {
    if (IS_PIN_ANALOG(i)) {
      // turns off pullup, configures everything
      setPinModeCallback(i, ANALOG);
    } else {
      // sets the output to 0, configures portConfigInputs
      setPinModeCallback(i, OUTPUT);
    }
  }
  // by defult, do not report any analog inputs
  analogInputsToReport = 0;

  Firmata.begin(57600);

  /* send digital inputs to set the initial state on the host computer,
   * since once in the loop(), this firmware will only send on change */
  for (i=0; i < TOTAL_PORTS; i++) {
    outputPort(i, readPort(i, portConfigInputs[i]), true);
  }
}

/*==============================================================================
 * LOOP()
 *============================================================================*/
void loop()
{
  byte pin, analogPin;

  /* DIGITALREAD - as fast as possible, check for changes and output them to the
   * FTDI buffer using Serial.print()  */
  checkDigitalInputs();

  /* SERIALREAD - processing incoming messagse as soon as possible, while still
   * checking digital inputs.  */
  while(Firmata.available())
    Firmata.processInput();

  /* SEND FTDI WRITE BUFFER - make sure that the FTDI buffer doesn't go over
   * 60 bytes. use a timer to sending an event character every 4 ms to
   * trigger the buffer to dump. */

  currentMillis = millis();
  if (currentMillis - previousMillis > samplingInterval) {
    previousMillis += samplingInterval;
    /* ANALOGREAD - do all analogReads() at the configured sampling interval */
    for(pin=0; pin<TOTAL_PINS; pin++) {
      if (IS_PIN_ANALOG(pin) && pinConfig[pin] == ANALOG) {
        analogPin = PIN_TO_ANALOG(pin);
        if (analogInputsToReport & (1 << analogPin)) {
          Firmata.sendAnalog(analogPin, analogRead(analogPin));
        }
      }
    }
  }
}



*Los siguientes pasos son:

-Encontrar la forma de conectar el sensor de presión al programa.
-Encontrar los sonidos que usare.
-Configurar el programa de manera que al apretar el sensor suene la melodia (o parte de ella).
-Elegir los materiales para el dispositivo.
-Como construir el interior de la caja, como pasar las conexiones de los sensores y Arduino desde la breadboard hasta el proyecto final.
********************************************************************************

Finalmente conecte los sensores de presión a Arduino y luego use MAXDUINO para ocupar Max/Msp y al presionar el sensor suene una melodía. Falto crear una interfaz más concreta, pero tengo los sensores y programa funcionando. Es posible que el dispositivo cambie de forma y también en el contenido de la música.

Foto finales del programa funcionando:









Video:

miércoles, 31 de agosto de 2011

Al mide Luz


En este ejercicio se usa una fotocélula que es un sensor de luz el cual varia su resistencia dependiendo de la luz. Conectamos la fotocélula a Arduino y vemos en el serial monitor diferentes valores dependiendo de la intensidad de la luz que capta el sensor.

*Conectar un cable desde 5v hasta la pata derecha del sensor. Conectar un cable desde GND hasta la pata izquierda del sensor. Conectar una resistencia desde la pata izquierda del sensor y en su otro extremo conectar un cable hasta A5.

*Cargar el siguiente código:

int potPin = A5; // Pin Analogo
int val = 0;

void setup() {
Serial.begin(9600); // Serial.begin para comenzar a comunicar a 9600 baudios
}

void loop() {
val = analogRead(potPin);
Serial.println(val); // Imprimir un valor separado en lineas
delay(1000); // cada segundo
}







Play Piezo Buzzer


En este ejercicio se utiliza el buzzer o piezo para crear música según las secuencias programadas y teniendo en cuenta el uso de los tiempos para hacer que suenen los tonos. El calculo de los todos esta hecho según la siguiente operación matemática:

timeHigh = 1/(2 * toneFrequency) = period / 2

*Conectar un cable desde GND hasta la linea azul. Conectar un cable desde la linea azul hasta la pata izquierda del LED. Poner una resistencia en la pata derecha del LED y el otro extremo conectarlo a un cable hasta el pin digital 13. Conectar un cable desde el pin digital 9 hasta la pata derecha del buzzer. Conectar una resistencia en la pata izquierda y desde el otro extremo añadir un cable hasta la linea azul.

*Cargar el siguiente código:


/* Play Melody
 * -----------
 *
 * Program to play melodies stored in an array, it requires to know
 * about timing issues and about how to play tones.
 *
 * The calculation of the tones is made following the mathematical
 * operation:
 *
 *       timeHigh = 1/(2 * toneFrequency) = period / 2
 *
 * where the different tones are described as in the table:
 *
 * note frequency period PW (timeHigh)
 * c        261 Hz        3830 1915
 * d        294 Hz        3400 1700
 * e        329 Hz        3038 1519
 * f        349 Hz        2864 1432
 * g        392 Hz        2550 1275
 * a        440 Hz        2272 1136
 * b        493 Hz        2028 1014
 * C        523 Hz        1912 956
 *
 * (cleft) 2005 D. Cuartielles for K3
 */

int ledPin = 13;
int speakerOut = 9;            
byte names[] = {'c', 'd', 'e', 'f', 'g', 'a', 'b', 'C'};
int tones[] = {1915, 1700, 1519, 1432, 1275, 1136, 1014, 956};
byte melody[] = "2d2a1f2c2d2a2d2c2f2d2a2c2d2a1f2c2d2a2a2g2p8p8p8p";
// count length: 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0
//                                10                  20                  30
int count = 0;
int count2 = 0;
int count3 = 0;
int MAX_COUNT = 24;
int statePin = LOW;

void setup() {
 pinMode(ledPin, OUTPUT);
}

void loop() {
  analogWrite(speakerOut, 0);  
  for (count = 0; count < MAX_COUNT; count++) {
    statePin = !statePin;
    digitalWrite(ledPin, statePin);
    for (count3 = 0; count3 <= (melody[count*2] - 48) * 30; count3++) {
      for (count2=0;count2<8;count2++) {
        if (names[count2] == melody[count*2 + 1]) {    
          analogWrite(speakerOut,500);
          delayMicroseconds(tones[count2]);
          analogWrite(speakerOut, 0);
          delayMicroseconds(tones[count2]);
        }
        if (melody[count*2 + 1] == 'p') {
          // make a pause of a certain size
          analogWrite(speakerOut, 0);
          delayMicroseconds(500);
        }
      }
    }
  }
}






Conexión en serie


El circuito en serie es cuando la terminal de salida de un dispositivo se conecta a la terminal de entrada del dispositivo siguiente.

Ejercicio que prende los LED's al mismo tiempo utilizando un circuito en serie.

Conectar un cable desde GND hasta la linea azul del breadboard. Conectar un cable desde pin digital 6 hasta un punto en la linea I, conectar tres cables uno al lado del otro en las lineas siguientes h, g, f y cada cable conectado a la pata izquierda de un LED. Conectar un resistencia a la pata derecha de cada cable desde la linea azul.

*Cargar el siguiente código:

int cadenaLeds[]={6,7,8,9};
int tiempo=200;
int n=0;

void setup (){
for(n=0;n<4;n++){
pinMode(cadenaLeds[n],OUTPUT);
}
}
void secuencia(){
for(n=0;n<4;n++){
digitalWrite(cadenaLeds[n],HIGH);//Envia 5V a la salida digital cuyo n se encuentre
delay(tiempo); // en la posicion de la lista definida por el valor de n (enciende el LED)
digitalWrite(cadenaLeds[n],LOW); //Envia 0V a la salida digital cuyo n se encuentre
} // en la posicion de la lista definida por el valor de n (apaga el LED)

}
void loop(){
secuencia();
}





Semáforo 2


En este ejercicio se prenden 3 LED's con un delay de 2500 ms, las luces simulan un semáforo.

*Conectar un cable desde GND a la lina azul del protoboard. Conectar un cable desde el pin digital 2 hasta la pata izquierda del LED y una resistencia desde la linea azul hasta la para derecha del LED. Repetir lo mismo con el pin digital 3 y 4.

*Cargar el siguiente código:



int pinRedLed = 2;
int pinYelLed = 3;
int pinGrnLed = 4;
int lightState = 0;

void setup() {
    pinMode(pinRedLed, OUTPUT);    /* Set the LED pins to output */
    pinMode(pinYelLed, OUTPUT);
    pinMode(pinGrnLed, OUTPUT);
    digitalWrite(pinRedLed, HIGH);  /* Turn the RED light on, so we don't cause any traffic accidents while we initialise <img src="http://s.wordpress.com/wp-includes/images/smilies/icon_smile.gif" alt=":)" class="wp-smiley">  */
}

void loop() {

    lightState++;
    if (lightState > 3) {            // If the light state > 3, reset it to 0 (red).
      lightState = 0;
    }    

  delay(2500);

  /* Display correct light sequence */
  if (lightState == 0) { // Red
    digitalWrite(pinRedLed, HIGH);
    lightOff(pinYelLed);
    lightOff(pinGrnLed);
  }
  if (lightState == 1) { // Red and Amber
    digitalWrite(pinRedLed, HIGH);
    digitalWrite(pinYelLed, HIGH);
    lightOff(pinGrnLed);
  }
  if (lightState == 2) { // Green
    digitalWrite(pinGrnLed, HIGH);
    lightOff(pinYelLed);
    lightOff(pinRedLed);
  }
  if (lightState == 3) { // Amber-only
    digitalWrite(pinYelLed, HIGH);
    lightOff(pinRedLed);
    lightOff(pinGrnLed);
  }

}

void lightOff(int pin) {
  digitalWrite(pin, LOW);
}








*Video semáforo 2:

Semaforo 1 - conexión paralela


En este ejercicio se prenden 4 LED's con intervalos de 200ms. Utilice resistencias de 150 ohms porque con ellas los LED's brillaban más. Este ejercicio es una conexión paralela.

*Conectar un cable desde GND a la linea azul del protoboard. Conectar un cable desde el pin digital 6 hasta la pata izquierda del LED y una resistencia desde la linea azul hasta la pata derecha del LED. Conectar de la misma forma con los pin digital 7, 8 y 9.

*Cargar el siguiente código:


int cadenaLeds[]={6,7,8,9};
 int tiempo=200;
 int n=0;

 void setup (){
   for(n=0;n<4;n++){
     pinMode(cadenaLeds[n],OUTPUT);
   }
 }
 void secuencia(){
   for(n=0;n<4;n++){
    digitalWrite(cadenaLeds[n],HIGH);//Envia 5V a la salida digital cuyo n se encuentre
    delay(tiempo);                   // en la posicion de la lista definida por el valor de n (enciende el LED)
    digitalWrite(cadenaLeds[n],LOW); //Envia 0V a la salida digital cuyo n se encuentre
   }                                 // en la posicion de la lista definida por el valor de n (apaga el LED)

 }
 void loop(){
   secuencia();
 }






*Video Semaforo 1:



domingo, 28 de agosto de 2011

IR sensor

Sensor IR...

Conectar un cable desde la pata izquierda al analog pin 0. Conectar un cable desde la pata derecha a 5v. Conectar un cable desde la pata del centro hasta GND.

Cargar el siguiente código:


byte sensorPin=0;
int latestVal=0;
int maxVal=0;
int minVal=1024;

void setup() {
  Serial.begin(9600);
  Serial.println("in setup");
}

void loop() {
  //Serial.println("In loop");
  latestVal = analogRead(sensorPin);
  if(latestVal < minVal) {
    minVal = latestVal;
  }
  if(latestVal > maxVal) {
    maxVal = latestVal;
  }
  Serial.print("Max: ");
  Serial.print(maxVal);
  Serial.print(" Min: ");
  Serial.print(minVal);
  Serial.print(" Latest: ");
  Serial.println(latestVal);
  delay(1000);
}







Digital In lectura de un pulsador 2


En este ejercicio al apretar el botón se enciende el LED que estaba apagado y al soltar el botón el LED se apaga.

Conectar un cable desde la pata izquierda del botón a GND. Conectar un cable desde la J al frente de la pata derecha del botón al pin 2. Conectar un cable desde la linea azul al frente de la pata izquierda del botón hasta 5v. Colocar una resistencia de 10k desde la pata derecha del botón hasta el cable que esta en la linea azul.

Cargar el siguiente código:


int ledPin = 13; // Escoge el pin para el led
int inPin = 2; // Escoge el pin para el pulsador
int val = 0; // variable para leer el estado del pin

void setup()
{
  pinMode(ledPin, OUTPUT); // declara el LED como salida
  pinMode(inPin, INPUT); // declara el pulsador como entrada
}

void loop()
{
  val = digitalRead(inPin); // Lee el valor del pulsador
  if (val == HIGH) // verifica si la entrada es HIGH (Pulsador sin presionar)
  {
    digitalWrite(ledPin, LOW); // apaga el LED
  }
  else
  {
    digitalWrite(ledPin, HIGH); // Enciende el LED
  }
}






Digital In lectura de un pulsador


En este ejercicio al apretar el botón se apaga el LED que esta encendido y al soltar el botón se vuelve a prender.

Conectar el un cable desde la pata izquierda del botón hasta GND. Conectar un cable desde la linea J en la pata derecha del botón hasta el pin 10. Conectar un cable desde la linea azul al frente de la pata izquierda del botón hasta 5v. Entre la pata derecha y el cable en la linea azul colocar una resistencia de 10k.
Conectar el LED al pin 13.

Cargar el siguiente código:


/* Pulsador
*/
 int ledPin = 13;                    // PIN del LED
 int inPin = 10;                     // PIN del pulsador
 int value = 0;                      // Valor del pulsador
void setup() {
  pinMode(ledPin, OUTPUT);          // Inicializa el pin 13 como salida digital
  pinMode(inPin, INPUT);            // Inicializa el pin 10 como entrada digital
}
void loop() {
  value = digitalRead(inPin);       // Lee el valor de la entrada digital
  digitalWrite(ledPin, value);        
}





viernes, 19 de agosto de 2011

Analog In Potenciometro y comserial


Con este ejercicio se puede controlar la intensidad de luz de un LED con un potenciometro. A diferencia del ejercicio anterior el LED no parpadea.

*Conectar el potenciometro a Arduino. Un cable desde 5v a la pata izquierda del potenciometro, un cable desde GND a la pata derecha y un cable desde el puerto análogo A2 (indicando en el código que es A2) hasta la pata central del potenciometro.
*Conectar un LED. Un cable desde GND hasta la pata izquierda, un cable desde el puerto digital 9 (que es PWM) conectado por medio de una resistencia hasta la pata derecha del LED.



Código :


int potPin = 2;     // pin A/I para pot
int potValue = 0;   // vlor leirdo desde el pot
int led = 9;     // pin PWM con LED.

void setup() {
   // inicializar comunicación serial a 9600 bps:
  Serial.begin(9600);
}
void loop() {
  potValue = analogRead(potPin); // lee valor de pot
  analogWrite(led, potValue/4); // PWM el LED con valor de pot
// (dividido en 4 para que calce en un byte)
  Serial.println(potValue);     // imprime el valor del pot
delay(10);                     // espera 10 milliseg antes del prox loop
}

jueves, 18 de agosto de 2011

Analog In Potenciometro


En este ejercicio se conecta un potenciometro para que controle la velocidad en que el LED se prendera y apagara parpadeando.


Descripción:
El potenciometro es un dispositivo electromecánico que consta de una resistencia de valor fijo sobre la que se desplaza un contacto deslizante, el cursor, que la divide eléctricamente.

Se conecta el potenciometro a Arduino. Un cable conectado a 5v hacia la pata izquierda del potenciometro, un cable de GND a la pata derecha y un cable de A2 a la pata central del potenciometro.
Se conecta un LED a Arduino. Un cable desde GND hasta la pata izquierda del LED, un cable desde Pin 13 a través de una resistencia a la pata derecha del LED.




Código:

int potPin = 2; // seleccionar el pin de entrada analogico para el potenciometro

int ledPin = 13; // seleccionar el pin de salida digital para el LED

int val = 0; // variable para almacenar el valor capturado desde el sensor

void setup() {

  pinMode(ledPin, OUTPUT);  // declara el ledPin en modo salida

}

void loop() {

  val = analogRead(potPin);    // lee el valor del sensor
  digitalWrite(ledPin, HIGH);  // enciende LED
  delay(val);             // detiene el programa por un tiempo determinado por la variable
  digitalWrite(ledPin, LOW);   // apaga el LED
  delay(val);            // detiene el programa por un tiempo determinado por la variable