Unidad VI LA FUNCIÓN DE CONVERCIÓN DIGITAL / ANALOGICO (DAC) Y ANALÓGICO / DIGITAL (ADC) CON MICROCONTROLADORES DE USO DEDICADO. 6.1 INTRODUCCIÓN Las señales analógicas también son llamadas señales del mundo real, debido a que muchas señales físicas son analógicas por naturaleza. Actualmente gran cantidad de aplicaciones para computadoras y otros sistemas digitales, requieren de señales de entrada del mundo real, tales como temperatura, presión, flujo, nivel. Incluso señales que pueden incluir imágenes y voz. Actualmente los sistemas digitales están siendo usados para controlar o manipular señales en el mundo real, ya sea, en la industria, en autotransportes o en electrodomésticos entre otros. 6.1.1Señales analógicas y digitales Una señal analógica es aquella que tiene valores continuos sobre un rango dado, en contraste al número determinado de valores discretos que presentaría una señal digital para el mismo rango. Ejemplo 6 - 1 Tengamos en cuenta una fuente variable de voltaje, que tiene un voltaje de salida en un rango de escala de 0 a 12 Volts, ajustable con un potenciómetro. Luego entonces será posible tener un voltaje de salida con un número infinito de valores continuos. Una fuente de voltaje digital con el mismo rango de escala pero con valores específicos de salida 0, 5, 10, y 12 V tendrá solamente 4 valores discretos. Ejemplo 6 - 2 Consideremos la grafica de una señal analógica de entre 0 y 5 volts y veamos la diferencia con la misma señal pero con una representación digital de 4 bits. Se puede observar que en la grafica analógica la curva tiene un numero infinito de valores entre 0 y 5 Volts tanto en el eje vertical como en el horizontal que representa el tiempo en segundos. Mientras que en la representación digital solamente se tienen 16 valores diferentes para mostrar el eje vertical y 36 instantes de toma de lectura o medición lo que da como resultado solamente algunos puntos discretos sobre la curva analógica obviamente si se usara una representación digital de mas Bits, digamos 8 , se tendría en el eje vertical hasta 256 valores diferente , es decir , el numero de valores depende directamente del numero de n bits que se usen. Numero de valores diferentes = 2n Figura 6-1 Representación de una señal analógica Figura 6-2. Representación de una señal Digital 6.1.2 Interfase con el mundo real Para poder realizar la interfase entre el mundo analógico y el digital se requiere de dos procesos básicos. La conversión analógica / digital ADC (por sus siglas en ingles Analog Digital Converter) y la conversión digital / analógica DAC (Digital Analog Converter). Ejemplo 6 - 3. Termostato digital para el control de la temperatura en un cuarto de habitación. Figura 6-3 Diagrama a bloques de un termostato para el control de temperatura que usa un ADC. La temperatura del cuarto produce en un sensor de termopar un voltaje que es proporcional a la temperatura del cuarto, este voltaje es acondicionado por un amplificador operacional y aplicado a la entrada de un ADC, donde es convertida a una señal digital y periódicamente muestreada por un microprocesador . Por ejemplo supongamos que la temperatura del cuarto es de 17 ° C . Un voltaje especifico a esta temperatura aparece a la entrada del convertidor ADC de 8 bits y en su salida el convertidor da una señal digital correspondiente digamos de 01000011 en código binario de 8 bits. Internamente, el microprocesador compara este numero binario con un numero, también binario, que representa la temperatura deseada supóngase 01001000 para 23 ° C, Que es el valor deseado de temperatura que previamente se ha introducido a través de un teclado y almacenado en un registro. Como resultado de la comparación, en que para este ejemplo el el cuarto tiene una temperatura actual menor que el valor deseado, el microprocesador comanda a la unidad de control a que se encienda el dispositivo calentador del cuarto. Como el microprocesador continuara monitoreando la temperatura del cuarto vía el convertidor ADC , cuando la temperatura del cuarto iguale ó exceda la temperatura deseada el microcontrolador apagará el dispositivo calentador. Ejemplo 6 - 4 Grabadora / Reproductora Digital de Audio (GDA) En este ejemplo se usan ambos convertidores DAC y ADC, con un diagrama muy elemental explicaremos este ejemplo. Figura 6-4 Diagrama a bloques de una Grabadora / Reproductora Digital de Audio (GDA) Una señal de audio, es desde luego una señal analógica. Cuando se está en el modo de grabación esta señal de audio que puede provenir de un micrófono ó algún otro dispositivo, se acondiciona con amplificadores operacionales y se pasa a través del ADC con lo cual se produce una señal digital susceptible de ser grabada en una cinta digital. En el modo de reproducción cuando la señal proviene de una cinta de grabación digital, la señal es procesada con un microcontrolador, convertida con un DAC y finalmente amplificada para ser enviada al sistema de bocinas de reproducción del audio. 6.2 Convertidores Digital / Analógico DAC. En esta sección examinaremos las características básicas de los convertidores DAC que es, el dispositivo que transduce información digital a una cantidad continua, es decir un ADC acepta una palabra digital y entrega una cantidad proporcional al valor numérico representado por la palabra. 6.2.1 El ADC básico. En la figura 6-5 se muestra el diagrama simplificado de un DAC básico. Este dispositivo convierte en una corriente cada bit de su entrada de datos digitales cuyo valor binario sea 1, y suma tales corrientes en ISUM como su salida analógica la cual puede ser aprovechada a través de RSALIDA en VSUM que será un voltaje proporcional al valor de la palabra digital de entrada. Cada conmutador, S, controla una fuente de corriente, I, cuando un conmutador esta en 1, su fuente contribuye a la corriente de salida I SUM, que de esta forma se vuelve proporcional a la entrada en paralelo de la palabra de datos digitales. Figura 6-5 Diagrama simplificado de un convertidor básico Digital / Analógico con 4 bits.Las entradas de datos digitales del bit 1 al bit 4 controlan los estados de los conmutadores S1 a S4. Las entradas de datos digitales del bit 1 al bit 4 controlan los estados de los conmutadores S1 a S4. En la figura 6-6 se muestra un diagrama de bloques simplificado de un DAC completo. El registro de entrada o BUFFER asegura que los bits de entrada estén presentes en forma simultánea y que se mantengan durante la conversión. Con la señal de intermitencia o STROBE, se controla que los registros de entrada se transfieran simultáneamente a la salida de los registros de salida, las cuales se conectan a las entradas del convertidor de digital a analógico. El voltaje de referencia V REF es una fuente de voltaje estable que suministra las corrientes a las fuentes de corriente. El amplificador operacional convierte la salida de corriente del convertidor en un voltaje de salida proporcional, VSALIDA . Figura 6-6. Diagrama de bloques simplificado de un sistema DAC completo. 6.2.2 DAC de resistencia binaria ponderada. Este convertidor consta de los cuatro elementos siguientes: 1).- Una red de resistencia ponderada en la cual los valores de la resistencia se incrementan en un factor de 2 para cada bit, el valor para la resistencia en la posición del digito más significativo ó bMs es R bMs = R x 20 En las posiciónes siguientes al bMs, el valor es Rx 21 , Rx 22, …. Rx 2n-1 Siendo el último termino el valor de la resistencia para el bit menos significativo bms 2).- Un total de n conmutadores, uno para cada bit aplicado al DAC. 3).- Un voltaje de referencia estable, VREF. 4).- Un elemento sumador, el cual debe sumar las corrientes que fluyan de la red resistiva. Luego entonces la corriente debida a al bit 1 ( bMs) en el 1 lógico es, VREF / 1 R; la corriente debida al bit 2 en el 1 lógico es VREF / 2 R, etc.; la corriente más pequeña se debe al bit bms y es: I bms = VREF / 2n-1 x R Y la corriente I SUM es la suma de todas las aportaciones de corriente por cada bit. Ejemplo 6 – 5. En la figura 7-7 se muestra un ADC con entradas de resistencia binaria ponderada con un amplificador operacional como elemento sumador. Cada una de las resistencias de entrada tienen o no corriente dependiendo del valor de entrada ya se valor ALTO ( 1 lógico) o Bajo (0 lógico). Si la entrada es el binario 1, la cantidad de corriente que entra al circuito depende del valor del resistor colocado a su entrada, que de acuerdo a los valores mostrados cada uno difiere de otro en un valor de 2n, como se muestra en la figura. Puesto que prácticamente no entra corriente al amplificador operacional por su entrada inversora, toda la corriente pasara a través de RF por lo que el VSALIDA será = IFRF. Figura 7-7 6-ADC con entradas de resistencia binaria ponderada con un amplificador operacional como elemento sumador Una desventaja de este tipo de convertidor es la gran cantidad de resistores con valor diferente que se requieren, además que su estabilidad y rango de tolerancia deberá ser mejor del 0.5 %. Ejemplo 6 – 6. Determinar el voltaje de salida para el DAC mostrado en la figura 6-8(a) Si se aplica ,a las entradas una secuencia de números binarios de 4 bits representados con las formas de onda mostradas en la figura 6-8(b). Figura 6-8 (a) ejemplo 6-6 Figura 6-8(b) formas de onda para el ejemplo 6-6 Solución. Primero determinamos el valor de la corriente por cada una de las entradas de resistencia ponderada. Dado que la entrada (-) del amplificador operacional (amop) es 0 V ( tierra virtual ). Y el binario 1 corresponde a +5V , aplicando ley de ohm tenemos: I0 = 5 V / 40 Kohm = 0.125 mA I1 = 5 V / 20 Kohm = 0.25 mA I2 = 5 V / 10 Kohm = 0.5 mA I 3 = 5 V / 5 Kohm = 1.0 mA Asumiendo que no fluye corriente por el amplificador operacional debido a su muy alta impedancia y que entonces toda la corriente fluye a través de RF . Y dado que un extremo de esta resistencia tiene un voltaje de 0 V (tierra virtual), y por el otro deberá tener un voltaje igual al voltaje de salida y que será negativo respecto a la tierra virtual tenemos: VSALIDA (D0) = ( 1 k ohm) ( - 0.125 mA ) = - 0.125 V VSALIDA (D1) = ( 1 k ohm) ( - 0.25 mA ) = - 0.25 V VSALIDA (D2) = ( 1 k ohm) ( - 0.5 mA ) = - 0.5 V VSALIDA (D3) = ( 1 k ohm) ( - 1.0 mA ) = - 1.0 V En la figura 6-8 (b) Podemos observar que el primer código binario de entrada es 0000 que produce un voltaje de salida de 0 V, El siguiente código es 0001 que produce un voltaje de salida de -0.125 V. El siguiente código es 0010 que produce un voltaje de salida de -0.25 V, El siguiente código es 0011 que produce un voltaje de salida de -0.125 V + -0.25 V = -0.375 V. Cada código binario sucesivo incrementa el Voltaje en -0.125 V, la salida de voltaje tiene para este ejemplo una forma de onda de escalera invertida que va de 0 V a -1.875 V en pasos de -0.125 V su grafica se muestra en la figura 6-9. Figura 6-9. Grafica del voltaje de salida para el circuito del ejemplo 6-6 ---. 6.2.3 Características de comportamiento para los convertidores D/A. 6.2.3.1 Factor de Multiplicación Como la salida de un DAC es directamente proporcional al VREF Para obtener un voltaje de salida preciso entre V SALIDA y la entrada digital se requiere que el VREF sea fijo y estable. Sin embargo supóngase que VREF es una fuente de voltaje analógica cambiante. En tal caso el voltaje de salida del DAC es proporcional al producto de una entrada analógica y una entrada digital. Por lo tanto se puede usar el DAC como un amplificador o atenuador controlado digitalmente, en el cual la ganancia será determinada por la entrada digital. En la referencia bibliográfica (revista UPIICSA de tecnología) se publica una aplicación muy interesante de esta cualidad de los DAC en el diseño de un sistema en el que el dispositivo se usa como modulador de amplitud para transmitir de señales. 6.2.3.1 Resolución La resolución de un DAC es el reciproco del número máximo de pasos discretos que se pueden tener a la salida del DAC, es igual a 2n- 1, donde n es el numero de bits de entrada. Obviamente la resolución depende del número de los bits de entrada. Ejemplo 6-7 Determinar la resolución de un DAC de 4 bits de entrada. Solución Resolución = 1 / (24 - 1 ) = 1 / 15 que también puede ser expresada en porcentaje de resolución = (1/15)100 = 6.67% como % 6.2.3.2 Exactitud. La exactitud es la comparación de la salida real de DAC con la salida esperadas expresa como un porcentaje del voltaje de salida a escala completa, o máximo voltaje de salida. Por ejemplo si el convertidor tiene un voltaje de salida a escala completa de 10 V y la exactitud es de 0.1 %, entonces el máximo error de cualquier voltaje de salida es igual a (10 V)(0.001) = 10 mV. Idealmente, la exactitud deberá ser, a lo más, + o - ½ del bit menos significativo bms. Para un DAC de 8 bits , 1 bms es 1/256 = 0.0039 (0.39 %de la escala completa ) . La exactitud debiera ser de + o – 0.2 %. 6.2.3.3 Linealidad El error por linealidad o mas propiamente por la no linealidad, es una medida de cómo la linealidad de la salida analógica se relaciona con la entrada digital en todo el intervalo de operación. Es la desviación de la recta esperada, como se muestra en la figura pag. 447 fig 15 – 12 libro copias. Figura 6-10 (a) No linealidad de 1 bms con la ganancia ajustada para un error cero en la escala completa. Figura 6-10 (b) No linealidad de + o – ½ bms con la ganancia ajustada a un mínimo error pico. 6.2.3.4 Linealidad diferencial La no linealidad diferencial es una medida del cambio en la salida analógica por cada cambio de 1 bit en la entrada digital. Idealmente, cada paso debe ser de la misma magnitud en todo el intervalo de la operación, pero debido a las imperfecciones del circuito, los cambios reales no son iguales, lo que se ilustra en la figura 6-11. Figura 6-11 No linealidad diferencial 6.2.3.5 Tiempo de estabilización. El tiempo de estabilización (settling time) o conocida también como la velocidad a la que opera, el es el tiempo que toma el DAC en alcanzar la estabilidad dentro de + o – ½ bms de su valor final cuando un cambio ocurre en el código de entrada. Los valores típicos se settling time se encuentran en el rango de 10 uS a 50 nS 6.2.3.6 Monotoneidad. Un DAC es monótono cuando la salida aumenta( o permanece constante) dada una entrada creciente. En la figura 6-11se muestra un DAC no monótono, en la que se muestra un deterioro en el funcionamiento del DAC. Figura 6-11. Grafica de salida para un DAC no monótono 6.2.3.7 Voltaje de desajuste (Offset) Teóricamente la salida de un DAC debiera ser cero cuando todas las entradas binarias son ceros. Sin embargo en la práctica esto no ocurre ya que siempre existen pequeños voltajes de salida . Esto se conoce como error de desajuste (offset), el cual deberá reajustarse por medios externos en caso de así requerirse. 6.3 Diseño del DAC con microcontroladores El diseño de un sistema con microcontroladores que requiera de la conversión de señal con código digital a señal analógica es muy simple de implementar pues los DAC requieren solamente la señal de código digital de entrada y dos o solamente una señal de control. Primero se mostrara como se conecta un DAC cuando se requieren dos señales de control C S y WR. En la figura 6-12. figura 6-12 Diagrama a bloque de un convertidor D/A . En la figura 6-12 se muestran los detalles de operación de un convertidor digital a analógico con entrada almacenada en registro de 8 bits. La entrada de 8 bits se pone en un registro interno hasta que concluya la siguiente conversión. Los datos se guardan en el registro cuando la ACTIVACION CS es alta; se dice que el almacén al registro es transparente cuando la señal de ACTIVACIÓN CS es baja. El registro mantiene la señal hasta que llegue otra que la reemplace. Cuando un CAD tiene un registro de entrada de datos se puede conectar en forma directa con el bus de datos de un microprocesador y este los considerará como una señal digital para la entrada de datos al CAD. Un CAD sin registro de almacén de datos se debe de conectar a través de un adaptador de interfase periférico Figura 6-13 conexión de un DAC con un Microcontrolador en operación unipolar. En la figura 6-13 se muestra como se debe de conectar un DAC con un microcontrolador cuando es necesario que la salida sea un voltaje que varié entre cero y el voltaje de referencia VREF , lo cual se denomina operación unipolar. Si VREF = 5 v el voltaje de salida de + 5 V cuando R1 es de 8 kohm y R2 = 8 Kohm; el rango es de +10V cuando R1 = 16 Kohm y R2 = 5.33 Kohm. En la figura 6-14 se muestra el DAC AD7524 que es fabricado por Analog Devices y que es compatible con microprocesadores de 8 bits tales como 6800, 8085, z 80 y con microcontroladores como 68hc11, PIC 16c84, Intel 8051. a través del uso de las señales de control CS y WR. Los modos de operación que se pueden tener se presentan en la tabla de la figura pag 63 ramakan. Figura 6-14 diagrama del DAC AD7524 fabricado por Analog Devices Un DAC multiplicador es un DAC diseñado para operar no solamente con un voltaje fijo de referencia VREF sino también con una entrada analógica Vi en lugar de la entrada fija de VREF; El CAD AD7524 puede ser configurado como se muestra en la figura 6-14. Cambiando el circuito externo. La salida del DAC Multiplicador estará representada por Vo = Vi X donde Vi es la señal de entrada y X es la fracción asociada con la entrada digital. Si se sume que tanto Vi como X pueden tener polaridad, a esta forma de operación se le llama de cuarto cuadrante. En contraste cuando Vi = Vref. es decir un Voltaje fijo se llama operación en segundo cuadrante. 6.4 Un DAC práctico El CAD de Nacional Semiconductors AD0808. El AD0808 es un convertidor digital a analógico de 8 bits el cual muestra dentro de sus características principales un tiempo de asentamiento (settling time) de 150 nS con una presición de +0.19 %.. Este convertidor es de tipo DIP y posee 16 pines que se distribuyen de la siguiente manera Figura 6-15 Descripción de pines del DAC 0808 Figura 6-16 Pines del DAC 0808 Figura 6-17 Características eléctricas del DAC 0808 Este dispositivo AD0808 es muy sencillo de operar pues únicamente se debe de tener cuidado en dos cosas; primero que los valores de entrada VIH y VIL para el “1” y “0” lógicos estén dentro de los valores especificados, y segundo que el voltaje de salida Vo este debidamente acoplado en su impedancia de salida. En la figura se muestra como se puede conectar un AD0808 de Nacional Semiconductors Figura 6-18 Diagrama eléctrico de la conexión del AD 0808 Descripción del circuito La salida de datos D0 a D7 del microprocesador o microcontrolador según sea el caso, se acopla directamente a las entradas A1 a A8 pines 5 a 12 del DAC 0808, conectando el pin 20 Vcc a +5V y los Pines 1 DIR y 19 OE de acuerdo al modo de operación que se desee La salida del DAC pin 4 se acopla en impedancia a través del AmOp LM 741, en este circuito se usa una configuración de amplificador inversor con ganancia ajustable, El +VREF pin 14 se conecta a +5 V a través de una resistencia de 4.7 kohms y el –VREF pin 15 a tierra a través también de una resistencia de 4.7 kohms, el -VEE pin 3 a -12 V y finalmente la COMP pin 16 a través de un capacitor de 0.1 uf a +5 V Programa de control para el circuito El programa de control únicamente requiere de poner en el puerto de salida D0 a D7 del microcontrolador el código de datos que se desea convertir a analógico. 6.5 Otros tipos de DACs Otro tipo de DAC que se fabrica más comúnmente es el que se llama de redes escalonadas resistivas R/2R. En la figura 6-19 se muestra un DAC de resistencia ponderada binaria con 6 bits y amplificador operacional como elemento sumador de corriente. Los conmutadores muestran una entrada binaria de 101010. En este ejemplo el valor de la resistencia para el bit bMs es de 5 k, mientras que el del bit bms es de 160 k. Debido a que el valor de las resistencias cambia en un factor de 2 para cada bit, un DAC de alta resolución tendría una gran gama de diferentes valores de resistencias para el bMs y el bms. En tal DAC se presentarían algunas dificultades. En primer lugar, sería difícil fabricar un conjunto de resistencias de tan amplio intervalo de resistencias que no obstante, contara con razones exactas y que no alteren su valor con los cambios de temperatura. Segundo, las corrientes en las posiciones cercanas al bms serían muy bajas debido a las altas resistencias. Tales corrientes bajas Hacen muy sensible al DAC a corrientes de ruido que pudieran ser de la misma magnitud. Figura 6-19 Diagrama de un DAC de resistencia ponderada binaria con 6 bits de resolución Figura 6-20 DAC en escalera R/2R Otro método para realizar la conversión D/A es utilizar la red escalonada R/2R, como se muestra en la Figura 6-20 para el caso de 4 bits, este método resuelve uno de los problemas del DAC con ponderación binaria pues solo requiere dos valores de resistencias. Asumiendo que la entrada D, esta a nivel alto (+5V) y las demás a nivel BAJO (tierra, 0 V) esta condición representa el código binario 1000 y haciendo un análisis del circuito se puede observar que cada entrada de menor peso sucesiva produce una tensión de salida que es la mitad de la anterior, por lo que la tensión de salida es proporcional al peso binario de los bits de entrada. El DAC AD 0808 mostrado en el punto anterior es un ejemplo de un DAC en escalera R/2R . 6.6 Convertidor Analógico / Digital ADC. La conversión analógica a digital es el proceso por el cual una señal analógica se convierte a código digital. La conversión A/D es necesaria cuando se requiere expresar una magnitud analógica producto de una medición en un código digital para poder ser procesada en una computadora, presentarla en un display o almacenarla en un archivo digital. A continuación se analizaran varios tipos de convertidores analógico / digitales 6.7 Parámetros de rendimiento del ADC Entre las características de los convertidores A/D destacan las siguientes: 6.7.1 Resolución La resolución de un ADC es el más pequeño paso digital con el cual es posible aproximar el voltaje analógico de entrada. Ejemplo 6-8 El voltaje de entrada de escala completa de un ADC de 8 bits es +5 V. Calcular el menor paso de voltaje analógico que puede reconocer el convertidor. Solución . Ocho bits representan 28= 256 pasos. Un paso en un voltaje de entrada de escala completa de 5 V representa 5 / 256 V = 19.53 mV 6.7.2 Tiempo de Conversión La conversión de un valor sobre una forma de onda analógica a una cantidad digital, no es instantánea, esta requiere de un tiempo de conversión que va de algunos uS para las conversiones más rápidas a mS para los dispositivos más lentos. Este concepto se ilustra en la figura 6-21 Figura 6-21 tiempo de conversión A / D 6.8 Circuitos componentes de los ADC. En esta sección se analizaran dos circuitos analógicos que se usan frecuentemente en los ADC. El comparador de voltaje y el circuito de muestreo y retención. 6.8.1 Circuito comparador de voltaje Los comparadores de voltaje analógicos son circuitos que comparan dos señales VA y VB de manera que si VA > VB entonces la salida es BAJO o de 0 V y para el caso de que VA < VB entonces la salida es ALTO o mayor de +3V. El tiempo de respuesta de un comparador de voltaje analógico es el tiempo entre la aplicación de un voltaje de entrada y el instante en que el voltaje de salida cruza el voltaje critico lógico. Fig. comparador de voltaje analógico Fig. tiempos de respuesta de circuitos comparadores de voltaje Figura 6-22. Comparador de voltaje analógico (a) Símbolo eléctrico (b) Voltaje de salida como función del voltaje de entrada (c) Voltaje de salida como función del voltaje de entrada con histéresis 6.8.2 Circuitos de muestreo y retención (Sample and Hold). En los ADC estos circuitos se utilizan para muestrear durante un breve intervalo de el valor dependiente del tiempo de un voltaje analógico de entrada y luego retener constante el valor muestreado durante la conversión. En la figura se muestra un diagrama simplificado de un circuito de muestreo y retención. La necesidad de muestrear una señal analógica surge del tiempo de conversión diferente de cero de un ADC; si durante la conversión la señal de entrada analógica ,cambia más que la resolución del ADC , la salida digital de este pudiera no ser representativa de su entrada analógica. Figura 6-23. Diagrama simplificado de un circuito de muestreo y retención 6.9 Tipos de convertidores Analógico / Digitales. 6.9.1 Convertidor Analógico/Digital Flash o Paralelo El método flash utiliza comparadores que comparan una serie de tensiones de referencia con la tensión de entrada analógica. Cuando la tensión analógica sobrepasa a la tensión de referencia de un comparador determinado, se genera un nivel Altota figura 6-24 Figura 6-24 Convertidor A/D tipo Flash de 8 bits que usa 7 convertidores La figura 6-24 muestra un convertidor de 8 bits que usa 7 convertidores, no se requiere convertidor para el caso en que todas las comparaciones sean cero En general se requieren 2n-1 comparadores para la conversión a un código binario de n bits. La salida de cada convertidor se aplica un circuito codificador de prioridad, en el cual el código binario queda determinado por la entrada de mayor orden que se encuentre a nivel alto. Referencia bibliografica . floyd Su principal ventaja de este comparador es su alta velocidad de muestreo que se puede alcanzar, aunque presenta la desventaja de que se necesitan muchos comparadores para un ADC de un número binario de tamaño razonable. La velocidad de muestreo determina la precisión con la que la secuencia de códigos digitales representa la entrada analógica del ADC. Cuando más muestras se toman en una unidad de tiempo, más precisa es la señal digital que representa a la señal analógica. Aquí cabe una pregunta: ¿Con que velocidad se debe muestrear una señal analógica, es decir cuantas veces por unidad de tiempo es lo mínimo con que se requiere muestrear una señal analógica ? La teoría propuesta por Nyquist Referencia bibliografica Operational Amplifiers Floyd establece que una señal de entrada variante con el tiempo puede reproducirse con fidelidad si la velocidad de muestreo es por lo menos dos veces tan alta como la mayor componente de la frecuencia de la señal. Ejemplo 6 – 10 Ilustración de varios muestreos por ciclo La mayor componente de la frecuencia de una señal analógica es de 3500 Hz. Determina la mínima velocidad de muestreo. Solución: La mínima velocidad de muestreo requerida es 2 X 3500 = 7000 muestras por segundo. 6.9.2 ADC de aproximaciones sucesivas. Este tipo de convertidor es el que sigue en menor tiempo de conversión al convertidor con método Flash. La figura 6-25 muestra el diagrama a bloques básico de un convertidor ADC por aproximaciones sucesivas de 4 bits Figura 6-25 Diagrama a bloques básico de un convertidor ADC por aproximaciones sucesivas de 4 bits Descripción del circuito Esta formado por un DAC, un registro de aproximaciones sucesivas (SAR, successive-aproximation r+egister) y un comparador. Los bits de entrada al DAC se habilitan a ALTO, de uno en uno sucesivamente. Comenzando por el bit más significativo (bMs). Cada vez que se habilita un bit, el comparador produce una salida que indica si la tensión analógica de entrada es mayor o menor que la salida del DAC. Si la salida del DAC es mayor que la entrada analógica, la salida del comparador esta a nivel BAJO, haciendo que el bit en el registro pase a cero. Si la salida es menor que la entrada analógica el bit 1 se mantiene en el registro. El sistema realizara esta operación primero con em bMs, luego con el siguiente bit más significativo, después con el siguiente, y así sucesivamente. Después de que todos los bits del DAC hayan sido aplicados, el ciclo de conversión esta completo. Referencia floyd. 6.9.3 ADC de contador de rampa en escalera. El método de rampa en escalera para la conversión A/D se conoce también como método de Rampa digital o método contador. Se emplea un DAC y un contador binario para generar el valor digital correspondiente a una entrada analógica. La figura 6-26 presenta un diagrama de este tipo de convertidor. . Figura 6-26 Convertidor A/D tipo rampa de 8 bits El método de rampa en escalera es más lento que el método flash porque, en caso de entrada máxima, el contador debe pasar a través del número máximo de estados antes de realizar la conversión. Para una conversión de 8 bits, esto significa un máximo de 256 estados y cado estado consume un cierto tiempo La figura 6-27 ilustra una secuencia de conversión con 4 bits. Obsérvese que, para cada muestra, el contador debe contar desde cero hasta el escalón en el que la tensión de referencia alcanza a la tensión de entrada analógica. El tiempo de conversión es variable, en función de la tensión analógica. La figura 6-27 ilustra una secuencia de conversión con 4 bits 6.9.4 ADC de rastreo o seguimiento El método de seguimiento utiliza un contador ascendente / descendente y es más rápido que el método de rampa digital, porque el contador no se pone a cero después de cada muestreo sino que sigue a la entrada analógica La figura 6-28 muestra un típico ADC de seguimiento de 8 bits. figura 6-28 Típico ADC de seguimiento de 8 bits. La salida del comparador se aplica al modo del control del contador, cuando esta BAJO ( 0 lógico), hace que el contador cuente progresivamente, y , recíprocamente, cuando esta ALTO (1 lógico), hace que el contador cuente en forma descendente. En la figura 6-29 se muestra que cuando el ADC de rastreo a alcanzado el intervalo idóneo, entonces el convertidor puede seguir de forma continua el voltaje analógico. La rapidez de rastreo no es ningún problema a medida que las variaciones de la entrada sean relativamente lentas. A fin de reducir el error inicial de las primeras conversiones suele fijarse el contador a media escala, es decir, en 100…000. Figura 6-29 ADC de seguimiento 6.9.5. ADC de pendiente simple A diferencia de los métodos de rampa en escalera y seguimiento, el convertidor de pendiente simple no requiere un DAC. Se utiliza un generador de rampa lineal para generar una tensión de referencia de pendiente constante. En la figura 6-30 se muestra el diagrama del ADC de pendiente simple. Al comienzo del ciclo de conversión, el contador esta en estado RESET y la salida del generador de rampa es 0 V. En esta situación, la entrada analógica es mayor que la tensión de referencia y, por tanto , se produce un nivel ALTO en la salida del comparador. Este nivel alto habilita la señal del reloj para el contador y arranca el generador de rampa Figura 6-30 Diagrama del ADC de pendiente simple 6.9.6 ADC de doble pendiente El funcionamiento del ADC de doble pendiente es similar al de pendiente simple, excepto en que se utiliza una rampa de pendiente variable y otra de pendiente fija. Este tipo de convertidor se utiliza comúnmente en voltímetros digitales y otros tipos de instrumentos de medida. Se utiliza un generador de rampa (integrador), A1, para generar las característica de pendiente doble. En la figura 6-31 se presenta el esquema de un ADC de pendiente doble como referencia. Figura 6-31 Esquema de un ADC de pendiente doble como referencia. 6.10 Un ADC práctico. 6.10.1 En la figura 6-32 se presenta el diagrama de conexión del DAC TSC 7116 de Teledyne Semiconductors, en el que ya están todas sus componentes integradas para hacer la conversión A/D y proporcionar la salida de datos en código de 7 segmentos para operar directamente un display de 3 ½ LEDs, que es muy utilizado en aplicaciones de instrumentos que requieren exhibir datos en un display tales como medidores de RPM, corriente de armadura, medidores de voltaje, es decir cualquier entrada analógica. figura 6-32 Diagrama de conexión del DAC TSC 7116 6.10.2 El ADC 0804 es un ejemplo de A/D por aproximaciones sucesivas. En la Figura 6-32 se presenta el diagrama a bloques este dispositivo funciona con una alimentación de +5 V y tiene una resolución de 8 bits, con un tiempo de conversión de 100 uS también garantiza la característica de monotonicidad y dispone de un generador de reloj interno. La salida de datos triestado sirven para realizar las comunicaciones internas con el sistema de buses de un microprocesador. Figura 6-32 Convertidor analógico digital ADC0804 6-10.3 El ADC 0809 Este convertidor es un dispositivo monolítico de tecnología CMOS con un multiplexor de 8 canales, un convertidor A/D de 8 bits y un control lógico compatible con microprocesador. El multiplexor de 8 canales se controla por medio de un decodificador de direcciones de 3 bits para poder seleccionar cualquiera de los 8 canales de manera individual conectando de manera directa al convertidor A/D el canal deseado. Este tipo de convertidor se caracteriza por poseer un divisor de voltaje de 256 R con un bloque de conmutadores analógicos y un registro de aproximaciones sucesivas. La versatilidad de este dispositivo hace que se elimine la necesidad de utilizar arreglos de circuitos para ajustar el cero externo y la escala completa. Ofrece alta velocidad, alta precisión, dependencia mínima a los cambios de temperatura así como un mínimo consumo de potencia. El encapsulado es tipo DIP y tiene 28 pines que se describen en la siguiente figura 6-33 Figura 6-33 Descripción de pines del ADC0809 En la figura 6-34 se muestra en diagrama como se pude conectar el ADC 0809 a un microprocesador a través de una Interfase Periférica Programable PPI (por sus siglas en ingles), de Intel 8255 . Figura 6-34 Diagrama de conexión del adc0809 a un bus de PC Descripción del circuito El circuito consta de un Tranceptor de bus de 8 canales el 74LS245, el cual se usa como buffer para el PPI 8255, el que a su ves se usa como interfase y proporciona una salida multiplexada de 3 puertos de I/O entre el bus de de la PC y el Convertidor ADC 0809. El circuito 74lS138 se utiliza como decodificador de direcciones. El ADC se conecta al puerto A del PPI y sus señales de control al puerto C. En la siguiente unidad VII se da un ejemplo de cómo puede ser el programa para la operación de una tarjeta de conversión A/D diseñada y construida en base a este diagrama. 6.11 Diseño de un ADC con microcontroladores. El termino Microcontrolador se usa para describir un sistema encapsulado en un chip de silicón que incluye un mínimo de partes para su funcionamiento autónomo. Como pueden ser , la unidad de procesamiento central CPU, la unidad de control CU, memoria de programa, memoria de datos, y puertos de entrada/salida I/O. algunos microcontroladores incluyen en forma adicional componentes tales como atemorizadores, contadores, convertidores analógico/digitales . En esta sección vamos a considerar los microcontroladores que incluyen convertidores A/D. 6.11.1 Arquitectura de microcontroladores. Básicamente, existen dos tipos de arquitecturas en microcontroladores( referencia bibliografica microcontroladores PIC): Arquitectura de Von Neumann y Arquitectura Hardvard. La arquitectura de de Von Neumann se caracteriza porque la CPU se conecta con una memoria única, donde existen datos e instrucciones, se comunica a través de un sistema de buses ver figura 6-35. Figura 6-35 Esquema de la arquitectura de << Von Neuman >> En la arquitectura Harvard son independientes la memoria de instrucciones y la memoria de datos y cada una dispone de su propio sistema de buses ver figura 6-36. Esta dualidad además de propiciar el paralelismo, permite la adecuación del tamaño de las palabras y los buses a los requerimientos específicos de las instrucciones y de los datos. También la capacidad de cada memoria puede ser diferente. Actualmente se alcanza un alto rendimiento y elevada velocidad, en los actuales procesadores debido a la conjunción de tres tecnicas : Arquitectura Harvard. Arquitectura RISC, y Segmentación o pipe line. Los microcontroladores PIC son un buen ejemplo de estos procesadores. Figura 6-36 Esquema de la arquitectura << Hardvard >> 6.11.3 Microcontroladores PIC. En el mercado existen varios tipos de microcontroladores y con características diferentes que dependen principalmente de los fabricantes como son entre otros: Motorola, Intel, Nacional, Texas Instruyen, Microchip. Las familias de microcontroladores PIC es desarrollada por Microchip Technology Inc. ( http://www.microchip.com)Y tiene ventas de estas familias de PIC del orden de 120 millones de dispositivos al año. Entre todos estos fabricantes es muy difícil escoger el “mejor” microcontrolador. En realidad no existe, porque en cada aplicación son sus características especificas las que determinan el más conveniente. La popularidad de los PICs se debe entre otras razones a su sencillez de manejo, buena información disponible, precio, buen promedio de parámetros entre otros, velocidad, consumo de potencia, alimentación código compacto, etc. Así como herramientas de desarrollo fáciles y baratas además de permitir un diseño rápido. Básicamente todos los PICs ofrecen las siguientes características Conjunto con alrededor de 35 de instrucciones RISC. Puertos digitales I/O Circuito de reloj Temporizadores Perro guardián (watchdog) Sistema de protección ante fallos de la alimentación. Estado de reposo. Reinicio (Reset) Modos de dirección, directo indirecto y relativo. Interfase para reloj externa Memoria de datos RAM Memoria de programa EPROM Canales de entrada analógica Comparadores analógicos Microchip dispone de cuatro familias de microcontroladores PIC. Familia pequeña PIC12C(F)XXX Son de bajo costo, La letra C designa memoria de programa EPROM, La letra F designa memoria de programa tipo FLASH, encapsulado de 8 pines, trabajan a 2.5 a 5 V y 4 MHz. Tienen un repertorio de 32 a 35 instrucciones. En la figura 6-37 se muestra un diagrama de este PIC. Figura 6-37 digrama de conexiones de los PIC12CXXX Y en la figura 6-38 Una tabla con las principales características de esta familia Figura 6-38 Una tabla con las principales características de la familia PIC12CXXX Familia baja o Básica PIC16C(F)XXX. Es una familia de bajo costo pero con prestaciones limitadas, en encapsulado con 18 a 28 pines. En la figura 2.4 FED se muestra un PIC ejemplo de esta familia Figura 6-37 Diagrama de conexiones de los PIC16CXXX Figura 6-39 Tabla con las principales características de la familia PIC16CXXX Familia media PIC16C8F9XXX Es la familia más variada y completa de PICs. Abarca modelos con 18 hasta 64 pines, esta el más popular de los PIC el 16C(F)84 En la figura 6-40 se muestra el diagrama del PIC16C74 Figura 6-40 Esquema del PIC16C74 En la figura 6-41 se Muestra una tabla con las principales características de la familia media. Figura 6-41 Tabla con las principales características de la familia PIC16CXXX Familia alta PIC17CXXX Se alcanzan las 58 instrucciones, y quizás la característica más destaca es la posibilidad de ampliar el microcontrolador con elementos externos, pues este microcontrolador saca por sus pines las líneas de los buses de datos, direcciones y control, a las que se conectan memorias o controladores de periféricos. Figura 6-42 se Muestra una tabla con las principales características de la familia alta Figura 6-42 Tabla con las principales características de la familia PIC17Cxxx. 6.11.4 Herramientas para el desarrollo de proyectos. El desarrollo de proyectos con PIC requiere de varias herramientas que dependen del tipo de aplicación y microcontrolador a usar. En general las siguientes herramientas son apropiadas: Un lenguaje ensamblador o un lenguaje de alto nivel específicos Un dispositivo programador de PIC, existen muchos en el mercado uno de ellos vende directamente la empresa Microchip (www.microchip.com) que es económico y muy completo en lo que a información se refiere. Un borrador de EPROM Una PC para el desarrollo de los programas, La velocidad del CPU no es importante para su empleo en este propósito Una tablilla para conexiones Y dependiendo de la aplicación, resistores, capacitares, LEDs, displays, y otros componentes. Si bien es cierto, usar lenguaje ensamblador para la programación de PICs, representa un considerable ahorro de código en la confección de los programas, lo que es muy importante dada la estricta limitación de la capacidad de la memoria de instrucciones. Y que los programas bien realizados en lenguaje ensamblador optimizan el tamaño de la memoria que ocupan y su ejecución es muy rápida. Pero su principal desventaja es que cada microcontrolador tiene su propio ensamblador y hacer programas en este lenguaje es muy complejo y frecuentemente difícil de darles mantenimiento. Existen en el mercado Lenguajes de alto nivel desarrollados específicamente para la programación de las familias de PICs. En esta sección se usara uno de los compiladores en C desarrollados para este propósito, el compilador conocido como FED C; desarrollado por Forest Electronic Developments (www.fored.co.uk y con e-mail: info@fored.co.uk). Compilador FED C Algunas de las razones para escoger este compilador son El compilador FED C es dedicado y muy eficiente para desarrollar programas de todas las series PIC 16XXX y 12XXX. Editor integrado con ayudas para corregir sintaxis. Incluye un simulador. Un gran numero de funciones de librería. Soporta aritmética de punto flotante. Disponibilidad de un gran numero de funciones matemáticas. Soporte directo para LCD. Información y tutórales muy completos en la pagina web. Y sobre todo está fácilmente disponible y a bajo costo. El ciclo de desarrollo de programas para PICs es relativamente sencillo. Los programas se editan con una PC. El código puede ser simulado y corregido antes de ser cargado en la memoria del PIC que dependerá del tipo de memoria, ya sea Flash o EPROM, que tenga el microcontrolador a usar. Las variables, instrucciones, etc. se usan en forma similar a los lenguajes de programación tradicionales como Turbo C o Microsoft C. Se recomienda estudiar detalladamente el tutorial Learn to Use C Whit the Forest Electronic Developments PIC C Compiler que se puede obtener en forma gratuita en la dirección http://www.fored.co.uk Estructura de un programa basado en el compilador FED C para microcontroladores. La estructura de un programa desarrollado con este compilador es básicamente la misma estructura de un programa C estándar, con algunos cambios menores. La estructura típica para el programa de un microcontrolador PIC se muestra a continuación. /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * PROYECTO: Darle nombré al proyecto * ARCHIVO: Darle nombre al archivo con la extensión .C * FECHA: Indicar la fecha * PROCESADOR: Indicar el tipo de PIC a usar * COMPILADOR: Compilador a usar * * * Describir lo que el programa hace … * * **************************************************** #include <P16f84.h> #include………….. int i , j , ………. char x, ….. void func( ) { // comentarios …… ………………… …………………. } void main ( ) { // comentarios…. ……………… …………….. …………….. } // incluir enunciados // variables globales // uso de funciones // programa principal Ejemplo 6 - 11 Escribir un programa con FED C que prenda y apague un LED conectado al bit 0 del puerto B de un PIC16F84 . Deberá mantenerse un segundo en cada estado de salida. Solucion. El diagrama del circuito para este ejemplo se muestra en la figura 6-43. El reloj se genera usando un cristal de 4Mhz. Un LED se conecta al bit 0 del puerto B a través de una resistencia de 470 ohm, como limitadora de corriente. Figura 6-43 Diagrama para el ejemplo 6-11 Los pines del puerto B se configuran como salida con la instrucción TRIB 0 0.Un loop sin final es formada con el enunciado de control while y el LED es apagado y encendido dentro de este loop . El enunciado de espera wait se usa para generar un tiempo de espera de un segundo entre cada salida. El listado del programa se muestra a continuación: /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * PROYECTO: Proyecto 1 * ARCHIVO: proye1.C * FECHA: enero 2003 * PROCESADOR: PIC16F84 * COMPILADOR: FED C * * * Este programa enciende (ON) y apaga (OFF) un LED conectado al bit 0 del puerto B del microcontrolador. Un retrazo de 1 S es insertado entre cada salida. * * **************************************************** #include <P16f84.h> #include <delays.h>………….. void main ( ) { TRISB=0; while(1) { PB.B0=0 ; Wait(1000) ; PB.B0=1; Wait(1000) ; } } // programa principal //pone los pines del puerto B como salida // loop sin fin // pone el bit 0 del puerto B OFF //retrazo de 1000 mS // pone el bit 0 del puerto B ON // retrazo 1000 mS Los microcontroladores tipo PIC pueden ser directamente conectados a través de sus puertos de salida ya sea con una PC ó con algún display LCD según se requiera; ya sea almacenar los datos adquiridos para su posterior análisis y procesamiento, y/o exhibir el resultado directamente en un display LCD. Para este propósito se puede usar un diseño basado en el siguiente diagrama de bloques, en el que se muestra un sistema para la medición de temperatura con termopar tipo K . Figura 6- 44 diagrama de bloques, en el medición de temperatura con termopar tipo K . que se muestra un sistema para la Los display LCD son muy empleados en los proyectos con PICs para exhibir inmediatamente los resultados obtenidos por el microcontrolador en el ejemplo 6-12. Siguente se ilustra como se puede hacer una interface simple entre el PIC y el display LCD Ejemplo 6 -12 Asumir que se usará un PIC 16F84 como base de un proyecto, y que se desea enviar mensajes tipo texto a un display marca HITACHI modelo HD44780 tipo LCD. Conectar el display al puerto B del microcontrolador y desarrollar un programa en C para enviar el mensaje “PIC LCD” a la línea 1 del LCD. Solución. El diagrama del circuito para este proyecto se muestra en la figura 6-46, el LCD se conecta al PIC de acuerdo con su configuración que se muestra en la tabla de la figura 6-45. El reloj se proporciona con un cristal de cuarzo de 4 MHz . Un potenciometro de 20 k se usa para ajustar el contraste en el LCD. Figura 6-45 Tabla de configuración del modulo LCD HD44780 Figura 6-48 Diagrama eléctrico para el ejemplo 6-12 En la siguiente descripción del programa (DDP), se describe la s funciones que se realizaran BEGIN Inicializa LCD Limpia LCD pone cursor en posición home Se envia el texto “PIC LCD” al LCD END Listado del programa para el ejemplo 6-12, elaborado con el compilador FED C /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * PROYECTO: Proyecto 2 * ARCHIVO: proye2.C * FECHA: enero 2003 * PROCESADOR: PIC16F84 * COMPILADOR: FED C * * * Este programa envía el mensaje de texto “PIC LCD” a la linea 1 de un display *LCD conectado al puerto B de un PIC16F84. * * ************************************************* #include <P16f84.h> #include <displays.h>………….. const int LCDPORT=&PORTB; void main ( ) { LCD(-1) ; LCD(257) ; LCDString (*PIC LCD*) ; while(1) { } //define el puerto B como puerto LCD // programa principal //Inicializa LCD en línea 1 //Limpia cursor y lo manda a home //Envia texto a LCD // loop sin fin, espera por siempre } El encabezado “P16F84.h” define los registros y puertos del PIC16F84 . El encabezado “displays.h”define los parámetros para la configuración del LCD. El programa define que el LCD esta conectado al puerto B del micro. El LCD es inicializado, limpiado el display y el cursor posiciónado en home en la línea 1. El mensaje de texto “PIC LCD” es enviado al LCD usndo el comando LCDString. Finalmente, un loop sin fin hace que el programa espere permanentemente. EJEMPLO 6 – 12 PROYECTO Como una muestra de la potencialidad y comodidad de uso del compilador FED C se presenta el siguiente proyecto: Diseñar un sistema completo para medir temperatura usando un termistor como sensor . Hacer los cálculos para determinar la temperatura en ° Celsius y presentar los resultados en un display LCD cada 1 segundo. Especificaciones para el sistema Temperatura de medición Error de auto calentamiento Tipo de display Formato del display Frecuencia de lectura en el Display Sistema Diseño del sistema 0° C a +100° C menor que 0.5° C LCD “nn.m C” 1 lectura cada segundo Basado en Microcontrolador Existen en el mercado muchos termistores que puden ser seleccionados que satisfacen las especificaciones. El termistor que se determino para este diseño es el KED103BY, fabricado por Bbowthorpe thermistors. Este dispositivo es tipo miniatura y tiene las siguientes características R25° = 10 K B = 4400 dTH = 9 mW /°C Figura 6-49 grafica temperatura – resistencia para el termistor KED103BY Se asume que se usa una fuente constante de voltaje para el circuito del termistor. De la grafica de relación temperatura – resistencia de este termistor se obtiene A 0° C la resistencia de RT = 40 K A 100° C La RT = 500 ohm Disipación por autocalentamiento Si se asume que un máximo de 100uA circulan por el termistor, la máxima potencia de disipación dentro del rango de operación será: P = I2R esto es P = (100 x 10-6 )2 x 40 x 103 = 0.4 mW Con una constante de disipación de 9 mW / °C, el máximo autocalentamiento estará alrededor de 0.4/9 = 0.04 °C que esta dentro de lo que se pide en las especificaciones. A =°C el votaje a través del termistor es: 100 x 10-6 x 40 x 103 = 4V entonces el valor de RS = ( 5 – 4) / (100 x 10-6) = 10K a 100 °C, RT = 500 ohm y asumiendo una fuente constante de voltaje de +5, el voltaje a traves del termistor es: VT = VS ( RT / ( RS + RT) ) voltaje a través del termistor. esto es, VT = 5 ( (0.5 / (0.5 +40) ) = 0.0617 que es el mínimo Si se usa un convertidor A / D de 8 bit con una fuente de 5 V entonces un 1 mbs = 5000 / 256 = 19.6mV. que supera fácilmente el voltaje mínimo requerido por el termistor. Diagrama del circuito propuesto: El diagrama a bloque del circuito propuesto para este proyecto se muestra en la figura 6-50 . Se usara un microcontrolador PIC 16f877. Figura 6-50 Diagrama a bloques de un medidor de temperatura con termistor 5.11 FED En la figura 6.50 se muestra el diagrama completo del circuito. El termistor se conecta a una fuente de voltaje constante y su salida directamente a la entrada AN 0 del PIC. Al puerto B se conecta e l LCD en el que se mostrara la temperatura cada segundo en °C Figura 6-51 Diagrama eléctrico de un medidor de temperatura con termistor Descripción de la operación del circuito El voltaje a través del termistor es convertido a código digital y la resistencia del termistor (RT)| en función de de VT y VS es: RT = (VT x RS) / (VS – VT) donde VT es el voltaje a través del termistor , VS = 5 V, y RS = 10K. Entonces: RT = (104 x VT) / (5 – VT) ohm La temperatura del termistor en función de B es: TT = 1 / (1/B Ln(RT/R25) +1/T25 Donde TT es la temperatura medida en (°K), RT es la resistencia del termistor (ohm), B = 4400, T25 = 298.15 °K, y R25 es 10 K. Entonces: TT = 1 / (1/4400 Ln(RT/10 000) + 1/298.15) esta temperatura expresada en °C es : TT = 1 /(2.272 x 10-4)Ln(0.0001RT) + 3.354 x10-3 ) – 273.15 Esta ecuación se pude usar para calcular TT, puesto que RT esta determinada en función de VT. En la siguiente DDP se describe la operación del programa: BEGIN Inicializa el LCD Inicializa el microcontrolador DO FOREVER READ el voltaje del termistor y convierte a código digital Calcula la resistencia RT Calcula la temperatura TT Muestra la temperatura en °C en LCD Espera por 1 segundo ENDDO END Listado del programa El listado completo del programa se muestra en seguida. Se usan las variables de punto flotante tv y tr para el voltaje del termistor y su resistencia respectivamente. Después de inicializar el LCD y el microcontrolador, para que en todo momento se lleve a cabo la converción A/D para la medición de la temperatura se forma un LOOP sin fin. El convertidor es de 10 bit . Los 2 bit superiores de la conversión son almacenados en el PIC en el registro ADRESH. Los restantes 8 bit en el registro ADRESHLL. El voltaje del termistor tv se calcula multiplicando ADRESHH por 256 y sumándole ADRESHL. El voltaje se convertido a milivolts multiplicandolo por el factor de escala 5000/1054 ( 5000 mV a escala completa en 10 bit). La resistencia del termistor trse calcula con la ecuación anteriormente definida para RT. Finalmente la temperatura medida se calcula usando la ecuación también definida anteriormente para TT almacenando el resultado en la variable temp que es de punto flotante. Esta variable se configura con dos y un dígitos para antes y después del punto decimal (nn.m) y se convierte a una cadena callada temperatura. El carácter “C” es adicionado al final de la cadena, mostrándose en el LCD el resultado final obtenido de temperatura cada segundo. Listado completo para el medidor de temperatura con termistor /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * PROYECTO: Proyecto 3 * ARCHIVO: proye3.C * FECHA: enero 2003 * PROCESADOR: PIC16F877 * COMPILADOR: FED C * * * En este proyecto se mide la temperatura con un termistor y se muestra en un LCD cada * segundo con el formato “nn . m C”. * * ************************************************* #include <P16f877.h> #include <displays.h> #include <delays.h> #include <strings.h> #include <maths.h> const int LCDPORT=&PORTB; const float LSB = 5000/1024; //define el puerto B como puerto LCD // LSB en mV void main ( ) { float tv, tr, temp, y; int msd, lsd; char temperatura[6]; /* Inicializando el LCD // programa principal LCD(-1) ; LCD(257) ; /* */ //Inicializa LCD en línea 1 //Limpia cursor y lo manda a home Inicializando el microcontrolador */ ADCON1 = 0x80 ; ADCON0 = 0 ; ADCON0 = 0x41 ; while(1) //pone los 6 bMs a cero // se selecciona a AN0 como entrada //habilita el oscilador del A/D //DO FOREVER { /* Inicia la conversión A/D */ ADCON0 = 0x45 ; // inicia la conversión A/D while(ADCON0 & 1 == 0) ; // espera la conversión tv = 256*ADRESH + ADRESHL ; // Captura el voltaje del termistor tv=tv*LSB ; // escala del voltaje del termistor /* Calculo de la resistencia del termistor tr */ tr = 5.0*tv*10000.0/(5.0-tv) ; /* calculo de la temperatura temp */ y = log (0.0001*tr) ; y = 3.354*1e-3+y*2.272*1e-4 ; temp = 1.0/y ; /* Formato para el display LCD */ LCD(257) ; //Limpia LCD y pone cursor en “home” msd=temp ; //digito msd lsd=10.0*(temp-lsd) ; // digito lsd iPrtSring(temperatura,msd) ; //msd /* Inserta “.” , digito lsd, y el character “C” */ temperatura[2] = ‘.’ ; cPrtString(temperatura+3) ; temperatura[4] = ‘ ’ ; temperatura[5] = ‘C’ ; /* Muestra la temperatura como “nn.m C” */ LCDString(temperatura) ; /* Una segunda espera de un segundo */ wait(1000) ; } //ENDDO } Ejercicios 1.- Explicar las diferencias entre un microprocesador y un microcontrolador 2.-explique la diferencia entre memoria EPROM y memoria Flash EEPROM . Que memoria recomienda para almacenar datos no-volatiles 3.-Escriba un programa en C para un microcontrolador PIC 16F84 que lea el bit 2 del puerto By envie este dato a un led conetado en el bit 0 del mismo puerto. 4.- ( LEDs se conectan al puerto B del microcontrolador PIC16F84, con sus resistencias limitadoras apropiadas. Escriba un programa que cuente en binario desde 0 a 255 y que la cuenta se muestre en los LEDs. Inserte un retraso de 500ms entre cada cuenta de salida. 5.-Un display de cristal liquido LCD modelo HD44780 de Hitachi tipo conección paralelo se conecta a un microcontrolador PIC16F84. Escriba un programa que cuente de 0 a 255 y que envie la cuenta al display LCD. Incerte un retrazo de 800ms entre cada cuenta. 6.- Lleve a cabo el proyecto presentado en el ejemplo 6 -12 para medir temperatura con un sensor de thermistor, Microcontrolador PIC16f84 y el display LCD. BIBLIOGRAFIA 1.-MICROCONTROLLER BASED TEMPERATURE MONITORING AND CONTROL Dogan Ibrain Editorial Newnes 2002 2.- ANALOG AND DIGITAL CONTROL SYSTEMS Gayakwod, Ramakant editorial Prentice Hall 1988 2.- BASIC OPERATIONAL AMPLIFIERS AN LINEAR INTEGRATED CIRCUITS Floyd, Thomas L. Editorial Merrill – Mc Millan 1994 3 DATA ADQUISITION AND PROCESS CONTROL WITH THE M68HC.11 Driscoll, Frederick F.editorial Merrill Mc Millan 1994