.. 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