En este proyecto nos proponemos a monitorizar la temperatura de algun medio con un termistor tipo NTC y usando una plataforma Arduino.
Primeramente se hará un repaso de la teoria de funcionamiento del termistor y el por qué de su configuracion.
Teoria Termistor:
El termistor es uno de los elementos electrónicos mas flexibles y usados en la electrónica.
Se trata de un resistor cuyo valor varia de manera significativa con la variación de la temperatura de
una manera mayor que las resistencias comunes.
Por el tipo de encapsulado y formato, existen una gran variedad de termistores, tal como se muestra en la siguiente imagen y su seleccion dependera del uso, la precision, etc:
Asi pues, segun su tecnologia también se diferencian diferentes tipos de termistores, los mas comunes son los llamados NTC ( Negative Temperature Coefficient ) y los PTC ( Positive Temperatue Coefficient ).
Cuando la temperatura aumenta, los tipo PTC aumentan la resistencia, y en los NTC a la inversa, es decir, disminuye. El simbolo electrónico del termistor es el siguiente:
El funcionamiento y las ecuaciones que gobiernan el termistor pueden ser consultadas en el siguiente enlace:
Esquema del circuito:
El esquema del circuito es bastante sencillo. La idea básica es la configuración del "divisor de tension", que se trata de una configuración de circuito eléctrico.
El circuito en si es como se muestra a continuación:
Asi pues, teniendo en cuenta que la salida Vout sera la señal que procesara Arduino en su entrada analogica, podemos diseñar nuestro circuito eléctrico. En este caso se ha realizado con el software "Fritzing", que resulta bastante cómodo para nuestro proposito.
En este caso se ha utilizado una resistencia R2 de 10 k ya que mi termistor es de aproximadamente 10 k. Para este proyecto he usado un termistor extraido de un dispositivo electrónico reciclado, asi que tuve que realizar las medidas oportunas para obtener los datos característicos del termistor, ya que trabajé sin datasheet ( se explicará ), pero es recomendable comprar uno que este documentado.
Un ejemplo es este termistor de Epcos a 10 K. Si observamos el datasheet, nos viene totalmente documentado el valor de Beta y demas valores, asi como el comportamiento del temistor segun la temperatura.
Asi pues, el esquema de montaje electrico es como se muestra a continuación:
Cálculos y medidas:
Primeramente, debemos saber el valor de Beta del termistor que vamos a usar, que habitualmente será proporcionado por el fabricante en su datasheet junto con demás valores de interés. Si es este nuestro caso, pasaremos al apartado de "Formulas".
Si, en cambio, os pasa como a mi, que reciclando algunos componentes obtuve un termistor para mi proyecto, deberemos hacer algunas medidas previas, que que el calculo de Beta se obtiene con las temperaturas de 2 extremos, en nuestro caso 0º y 100 º.
Beta = ( Log ( Rt2 / Rt1 ) ) / ( ( 1 / T2 ) - ( 1 / T1 ) )
Donde
T1 = Temperatura medida en Kelvin ( aprox 0 º )
T2 = Temperatura medida en Kelvin ( aprox 100º )
Rt1 = Valor de Resistencia a T1
Rt2 = Valor de Resistenica a T2
Con lo que una vez realizadas las medidas, se introducen en la formula de Beta. En este caso podriamos introducir los valores medidos y realizar los calculos o introducir el valor de Beta directamente.
Código de Arduino
Ahora, solamente quedaria comprobar el margen de error con el que funcionaria nuestro termistor, y listo!!/* Termistor NTC con arduino Monitorizacion de temperatura con sensor NTC sobre plataforma Arduino. Algortimo de calculo de temperatura en: http://en.wikipedia.org/wiki/Thermistor En este proyecto usamos una Beta conocida, de lo contrario se podría calcular de la siguiente maneta: Beta=(log(RT1/RT2))/((1/T1)-(1/T2)); */ #include <math.h> #include <stdio.h> // Datos para las ecuaciones algoritmo termistor int analogPin=1; // [V] Entrada analogica de medida del termistor float Vin=5.0; // [V] Voltage de entrada en el divisor de tension float Raux=10000; // [ohm] Valor de la resistencia del divisor de tension float Rntc=100000; // [ohm] Valor de resistencia del termistor (NTC) a 25ºC float T0=298.15; // [K] (25ºC) float Vout=0.0; // [V] Voltage given by the Voltage-Divider float Rout=0.0; // [ohm] Resistencia actual del Termistor (NTC) float Beta=0.0; // [K] Parametro Beta float Rinf=0.0; // [ohm] Parametros Rinf float TempK=0.0; // [K] Temperatura de salida en grados Kelvin float TempC=0.0; // [ºC] Temperatura de salida en grados Celsius int iCont; // Contador de ciclos, para calculo de temperatura media float cTemp1; // Variable temporal para acumular las temperaturas leidas // Declaracion de entrada analógica int analogPin1 = 1; // [Boole] Entrada analógica 1 de Arduino //----------------------------------------------- //--------------- Configuracion ------------- //----------------------------------------------- void setup() { // Puerto Serie Serial.begin(115200); // Configuramos el pin del Arduino en entrada pinMode(analogPin, INPUT); // Parametros de calculo Beta = 4380; Rinf=Rntc*exp(-Beta/T0); } //----------------------------------------------- //------------ Fin Configuracion ----------- //----------------------------------------------- //----------------------------------------------- //--------------- Loop Principal ---------------- //----------------------------------------------- void loop() // Bucle de programa principal { double TempC; double temp = Termistor(analogRead(1)); // Read sensor TempC=temp; Serial.print("Celsius:"); Serial.print(TempC,1); Serial.println(""); delay(1000); } //----------------------------------------------- //-----------Fin Loop Principal ---------------- //----------------------------------------------- //************************************************ //********* Funcion Termistor lectura ********** //************************************************ double Termistor(int RawADC) { // Cálculo del valor de la resistencia termistor (NTC) a través de Vout Vout=Vin*((float)(RawADC)/1024.0); Rout=(Raux*Vout/(Vin-Vout)); // Calculo de la temperatura en grados Kelvin TempK=(Beta/log(Rout/Rinf)); // Calculo de la temperatura en grados Celsius TempC=TempK-273.15; // Almacenamos la temperatura (Celsius) actual para después obtener la media cTemp1 = cTemp1 + TempC; // Hacemos una pausa de 10 milisegundos delay(10); } //************************************************ //******* Fin Funcion Termistor lectura ******** //************************************************
No hay comentarios:
Publicar un comentario