.. note:: ¡Hola, bienvenido a la Comunidad de Entusiastas de SunFounder Raspberry Pi & Arduino & ESP32 en Facebook! Sumérgete más en Raspberry Pi, Arduino y ESP32 con otros entusiastas. **¿Por qué unirse?** - **Soporte Experto**: Resuelve problemas post-venta y desafíos técnicos con la ayuda de nuestra comunidad y equipo. - **Aprende y Comparte**: Intercambia consejos y tutoriales para mejorar tus habilidades. - **Preestrenos Exclusivos**: Obtén acceso anticipado a anuncios de nuevos productos y adelantos exclusivos. - **Descuentos Especiales**: Disfruta de descuentos exclusivos en nuestros productos más nuevos. - **Promociones y Sorteos Festivos**: Participa en sorteos y promociones navideñas. 👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo! .. _2.1.7_py: 2.1.7 Potenciómetro ======================= .. note:: .. image:: ../img/mcp3008_and_adc0834.jpg :width: 25% :align: left Dependiendo de la versión de su kit, identifique si tiene **ADC0834** o **MCP3008** y continúe con la sección correspondiente. Introducción ------------------ La función ADC puede usarse para convertir señales analógicas en señales digitales, y en este experimento se utiliza el ADC0834 para obtener la función que involucra ADC. Aquí, implementamos este proceso utilizando un potenciómetro. El potenciómetro cambia la cantidad física - voltaje, que es convertido por la función ADC. Componentes Necesarios ---------------------------- En este proyecto, necesitamos los siguientes componentes. .. image:: ../img/list_2.1.4_potentiometer.png Es definitivamente conveniente comprar un kit completo, aquí está el enlace: .. list-table:: :widths: 20 20 20 :header-rows: 1 * - Nombre - ITEMS IN THIS KIT - ENLACE * - Kit Raphael - 337 - |link_Raphael_kit| También puedes comprarlos por separado en los enlaces a continuación. .. list-table:: :widths: 30 20 :header-rows: 1 * - INTRODUCCIÓN DE COMPONENTES - ENLACE DE COMPRA * - :ref:`cpn_gpio_board` - |link_gpio_board_buy| * - :ref:`cpn_breadboard` - |link_breadboard_buy| * - :ref:`cpn_wires` - |link_wires_buy| * - :ref:`cpn_resistor` - |link_resistor_buy| * - :ref:`cpn_led` - |link_led_buy| * - :ref:`cpn_potentiometer` - |link_potentiometer_buy| * - :ref:`cpn_adc0834` - \- Diagrama Esquemático --------------------------- .. image:: ../img/image311.png .. image:: ../img/image312.png Procedimientos Experimentales --------------------------------- **Paso 1:** Construir el circuito. .. image:: ../img/image180.png .. note:: Coloca el chip refiriéndote a la posición correspondiente representada en la imagen. Nota que las ranuras en el chip deben estar a la izquierda cuando se coloque. **Paso 2:** Abrir el archivo de código .. raw:: html .. code-block:: cd ~/raphael-kit/python/ **Paso 3:** Ejecutar. .. raw:: html .. code-block:: sudo python3 2.1.7_Potentiometer.py Después de ejecutar el código, gira la perilla del potenciómetro, la intensidad del LED cambiará en consecuencia. **Código** .. note:: Puedes **Modificar/Restablecer/Copiar/Ejecutar/Detener** el código a continuación. Pero antes de eso, necesitas ir a la ruta del código fuente como ``raphael-kit/python``. Después de modificar el código, puedes ejecutarlo directamente para ver el efecto. .. raw:: html .. code-block:: python #!/usr/bin/env python3 import RPi.GPIO as GPIO import ADC0834 import time LedPin = 22 def setup(): global led_val # Configurar los modos GPIO a numeración BCM GPIO.setmode(GPIO.BCM) # Configurar todos los pines LedPin como salida y nivel inicial en alto (3.3v) GPIO.setup(LedPin, GPIO.OUT, initial=GPIO.HIGH) ADC0834.setup() # Configurar el led como canal pwm y frecuencia a 2KHz led_val = GPIO.PWM(LedPin, 2000) # Iniciar todo con valor 0 led_val.start(0) # Definir una función MAP para mapear valores. Por ejemplo, de 0~255 a 0~100 def MAP(x, in_min, in_max, out_min, out_max): return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min def destroy(): # Detener todos los canales pwm led_val.stop() # Liberar recursos GPIO.cleanup() def loop(): while True: res = ADC0834.getResult() print ('res = %d' % res) R_val = MAP(res, 0, 255, 0, 100) led_val.ChangeDutyCycle(R_val) time.sleep(0.2) if __name__ == '__main__': setup() try: loop() except KeyboardInterrupt: # Cuando se presione 'Ctrl+C', se ejecutará el programa destroy(). destroy() **Explicación del Código** .. code-block:: python import ADC0834 Importar la biblioteca ADC0834. Puedes comprobar el contenido de la biblioteca llamando al comando nano ADC0834.py. .. code-block:: python def setup(): global led_val # Configurar los modos GPIO a numeración BCM GPIO.setmode(GPIO.BCM) # Configurar todos los pines LedPin como salida y nivel inicial en alto (3.3v) GPIO.setup(LedPin, GPIO.OUT, initial=GPIO.HIGH) ADC0834.setup() # Configurar el led como canal pwm y frecuencia a 2KHz led_val = GPIO.PWM(LedPin, 2000) # Iniciar todo con valor 0 led_val.start(0) En setup(), define el método de numeración como BCM, configura LedPin como canal PWM y establece una frecuencia de 2Khz. **ADC0834.setup():** Inicializa ADC0834 y conecta los definidos CS, CLK, DIO de ADC0834 a GPIO17, GPIO18 y GPIO27 respectivamente. .. code-block:: python def loop(): while True: res = ADC0834.getResult() print ('res = %d' % res) R_val = MAP(res, 0, 255, 0, 100) led_val.ChangeDutyCycle(R_val) time.sleep(0.2) La función getResult() se utiliza para leer los valores analógicos de los cuatro canales del ADC0834. Por defecto, la función lee el valor de CH0, y si deseas leer otros canales, por favor introduce el número del canal en **( )**, ej. getResult(1). La función loop() primero lee el valor de CH0, luego asigna el valor a la variable res. Después de eso, llama a la función MAP para mapear el valor leído del potenciómetro a 0~100. Este paso se utiliza para controlar el ciclo de trabajo de LedPin. Ahora, puedes ver que el brillo del LED cambia con el valor del potenciómetro. Imagen del Fenómeno -------------------------- .. image:: ../img/image181.jpeg