Gabriel Aviña
/
Multimetro2
Holis
Diff: main.cpp
- Revision:
- 0:abd749cef631
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/main.cpp Thu Mar 06 20:36:07 2014 +0000 @@ -0,0 +1,64 @@ +#include "mbed.h" +#define MEDIDA 10 //Declaracion de una constante para decir el tamaño del arreglo + +AnalogIn Volt_Out(A5); +AnalogIn Volt_Ohmetro(A4); +DigitalOut Led_Prueba(LED1); +Serial pc(USBTX, USBRX); +Timer reloj;//Declaracion de varibales, timer y puerto serial +DigitalIn boton_Volt(A3); +DigitalIn boton_Resitencia(A2); + +float Volt_In, Tiempo_Led, Tiempo,Promedio, Vout_val,Ohms; +float Voltajes_por_seg[]= {0}; +float Ohms_por_seg[] = {0}; //Inicializacion de un arreglo con 0 en cada lugar + +float promedio (float arreglo[MEDIDA]) //Funcion para sacar el promedio dentro de los valores de un arreglo mediante un contador +{ + float acumulado = 0; + for (int count = 0; count < MEDIDA; count++) { //Aumento de lugar en el Arreglo + acumulado += Voltajes_por_seg[count]; //Suma del valor en el lugar count del arreglo + } + return acumulado/MEDIDA; //Regresa el promedio como un valor float +} + +int main() +{ + reloj.start(); //Comienzo del timer + Tiempo_Led = reloj.read(); //Inicializar una variable que sera la lectura del timer + while (Tiempo_Led <= 1.5) { //Al oprimir el boton reset prendera un led rojo durante 1.5segundos como medida de seguridad para saber que no quemamos nuestra tarjeta + Tiempo_Led = reloj.read(); + Led_Prueba = 0; + } + Led_Prueba = 1; + reloj.reset(); //El timer se resetea para tomar las medidas para el voltaje + while(1) { + if(boton_Volt==1 && boton_Resitencia==0) { + Vout_val = Volt_Out*5; //Una variable que tendra el valor del voltaje de salida y lo, se multiplica por 5 ya que los puertos analogicos dan lecturas de 0 a 1 y con 5 volts fue alimentada esta practica + Tiempo = reloj.read(); + if(Tiempo > 0 && Tiempo < 0.5 ) { //Cada 0.5 segundos tomara las mediciones + for (int indice = 0; indice < MEDIDA; indice++) { //Ciclo que introduce cada valor del voltaje a cada espacio en el arreglo + Voltajes_por_seg[indice]= Voltajes_por_seg[indice+1]; //Se suma al indice un 1 para el lugar siguiente en el arreglo + Volt_In = ((Volt_Out*10330)/10000)*5; //Al voltaje de salida se multiplica por la suma de R1+R2 y se divide entre R1, se multiplica de nuevo por 5 por ser el voltaje con que alimentamos + Voltajes_por_seg[MEDIDA-1]= Volt_In; //Elmininamos el primer valor y lo sustituimos por el siguiente + reloj.reset(); //El timer se resetea para hacer de nuevo mediciones + } + Promedio=promedio(Voltajes_por_seg); //Uso del promedio para saber el voltaje de entrada + pc.printf("Voltaje en promedio es %f \n",Promedio*28/5); //Saber que voltaje de entrada tengo a 28 volts de alimentacion¡ + } + + } else if(boton_Volt==0 && boton_Resitencia==1) { + Tiempo = reloj.read(); + if(Tiempo > 0 && Tiempo < 0.5 ) { //Cada 0.5 segundos tomara las mediciones + for (int indice = 0; indice < MEDIDA; indice++) { + Ohms_por_seg[indice]= Ohms_por_seg[indice+1]; + Ohms = 1/(1/(Volt_Ohmetro*3.3/.005-560)-1/100);//Resistencia, conociendo Vo //Ciclo que introduce cada valor del voltaje a cada espacio en el arreglo + Ohms_por_seg[MEDIDA-1]= Ohms; //Elmininamos el primer valor y lo sustituimos por el siguiente + reloj.reset(); //El timer se resetea para hacer de nuevo mediciones + } + Promedio=promedio(Ohms_por_seg); + pc.printf("Resistencia 2 en promedio es %f \n",Promedio*3.3); + } + } + } +}