Programa para llenar un tanque de una cisterna por medio de un control de cámara sony. el sistema puede emitir sonidos por medio de un módulo de voz de Parallax EMIC.

Dependencies:   Pulse1 mbed

Fork of irda_Sony by Gustavo Ramirez

main.cpp

Committer:
tony63
Date:
2016-04-26
Revision:
4:150bc6a5f5b4
Parent:
3:82bebaf2a06a
Child:
5:3036b626379b

File content as of revision 4:150bc6a5f5b4:

#include "mbed.h"
#include <Pulse1.h>
#include "stdio.h" 
#include "math.h" 
//control remoto sony disparo camara
//puede convertir la trama en un entero
//para cualquier tecla
PulseInOut irda(PTD5);// en este puerto se pone el sensor infrarrojo
Serial pc(USBTX, USBRX);
DigitalOut led(LED1);
DigitalOut led2(LED2);
int header =0; //tiempo de cabecera pulso abajo
const int head_H = 2976; //+10% medida con osciloscopio en microsegundos
const int head_L = 1984;//-10%  medida con osciloscopio
int i=0, bin, potencia;
const int T_alto=1200;//ponga su tiempo de la prueba
const int T_bajo=639;//ponga su tiempo de la prueba
const int num_bits = 20;//ponga su numero de bits
int num[num_bits];//cadena para almacenar todos los tiempos que conforman los bits de datos
int dato; // tiempo de cada dato que se lee
int numero;
int binM[20];
int bin_max[20];



int main(){
while(1){
ini1: fflush( stdin );
      header=0;
      led2=1;
      led=1;
      header = irda.read_low_us();    //funcion para leer un pulso de caida o bajo en header
      if (header > head_L && header < head_H) goto seguir;//verificar que este en la tolerancia +-20%
      else goto ini1;
      
seguir:
       //leo los datos de la trama y se meten a un arreglo
      wait_us(400);// ES EL TIEMPO DE HEADER QUE NO SE Lee O EL ALTO 
      led2=1;
      for(i=0;i<(num_bits-1);++i){ // POR OSCILOSCOPIO se determina que llegan (num_bits),datos
      dato = irda.read_low_us(); //leer un bit de datos que es pulso arriba en este control
      num[i]=dato;
      wait_us(400);   
      }
      wait(0.5); //espero un poquito luego de leer todo el arreglo y ponerlo en pantalla 
      //pc.printf(",%d",header);
      for(i=0;i<(num_bits-1);++i){  
      //pc.printf(",%d",num[i]);
      }
      wait(0.1);  //espero e imprimo en binario 
      //pc.printf("\n\n");
      for(i=0;i<(num_bits-1);++i){  
       if(num[i] > ((T_alto+T_bajo)/2)){
        bin_max[i]=1;
        }
       else{
        bin_max[i]=0;
          }
       
      }   
      binM[0]=1;
      for(i=1;i<(num_bits-1);++i){   
       binM[i]=binM[i-1]*2;
       
       }
     numero=0;   
     for(i=0;i<(num_bits-1);++i){  
     
     numero=numero+(binM[i]*bin_max[i]);
             
      }
      pc.printf("numero=%d",numero);
      if (numero==466221){
          led2=0;
          wait(4);
          led2=1;
          goto ini1;
          }
      if (numero==466231){
          led=0;
          wait(4);
          led=1;
          goto ini1;
          }    
      }
      }