.. note::
¡Hola, bienvenido a la Comunidad de Entusiastas de SunFounder Raspberry Pi & Arduino & ESP32 en Facebook! Sumérgete en el mundo de Raspberry Pi, Arduino y ESP32 junto a otros entusiastas.
**¿Por qué unirse?**
- **Soporte experto**: Resuelve problemas postventa y desafíos técnicos con la ayuda de nuestra comunidad y equipo.
- **Aprender y compartir**: Intercambia consejos y tutoriales para mejorar tus habilidades.
- **Preestrenos exclusivos**: Obtén acceso anticipado a nuevos anuncios de productos y adelantos.
- **Descuentos especiales**: Disfruta de descuentos exclusivos en nuestros productos más recientes.
- **Promociones y sorteos festivos**: Participa en sorteos y promociones especiales de temporada.
👉 ¿Listo para explorar y crear con nosotros? Haz clic en [|link_sf_facebook|] y únete hoy mismo.
.. _2.2.2_py_pi5_mcp3008:
2.2.2 Termistor (MCP3008)
=========================
.. note::
.. image:: ../img/mcp3008_and_adc0834.jpg
:width: 25%
:align: left
Dependiendo de la versión de tu kit, identifica si tienes **ADC0834** o **MCP3008** y procede con la sección correspondiente.
Introducción
------------
Así como un fotorresistor puede detectar la luz, un termistor es un dispositivo electrónico sensible a la temperatura que puede usarse para implementar funciones de control de temperatura, como una alarma de sobrecalentamiento.
Componentes requeridos
----------------------
En este proyecto, necesitamos los siguientes componentes.
.. image:: ../python_pi5/img/list2_2.2.2_thermistor.png
Es definitivamente conveniente comprar un kit completo, aquí tienes el enlace:
.. list-table::
:widths: 20 20 20
:header-rows: 1
* - Nombre
- ELEMENTOS EN ESTE KIT
- ENLACE
* - Kit Raphael
- 337
- |link_Raphael_kit|
También puedes comprarlos por separado en los siguientes enlaces.
.. list-table::
:widths: 30 20
:header-rows: 1
* - INTRODUCCIÓN DEL COMPONENTE
- 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_thermistor`
- |link_thermistor_buy|
* - :ref:`cpn_mcp3008`
- \-
Diagrama esquemático
--------------------
.. .. image:: ../python_pi5/img/2.2.2_thermistor_schematic_1.png
.. list-table::
:widths: 30 30 30 30
:header-rows: 1
* - Nombre
- T-Board
- WiringPi
- BCM
* - SPICE0
- pin24
- 10
- 8
* - SPIMOSI
- pin19
- 12
- 10
* - SPIMISO
- pin21
- 13
- 9
* - SPISCLK
- pin23
- 14
- 11
.. image:: ../python_pi5/img/schematic_2.2.2_thermistor_mcp3008.png
Procedimientos experimentales
-----------------------------
**Paso 1:** Construye el circuito.
.. image:: ../python_pi5/img/july24_2.2.2_thermistor_mcp3008.png
**Paso 2:** Configura la interfaz SPI e instala la librería ``spidev`` (consulta :ref:`spi_configuration` para instrucciones detalladas).
Si ya has completado estos pasos, puedes omitirlos.
**Paso 3:** Ve a la carpeta del código.
.. raw:: html
.. code-block::
cd ~/raphael-kit/python-pi5
**Paso 4:** Ejecuta el archivo
.. raw:: html
.. code-block::
sudo python3 2.2.2-2_Thermistor_zero.py
Cuando el código se esté ejecutando, el termistor detectará la temperatura ambiente, la cual será impresa en la pantalla después de finalizar el cálculo.
.. warning::
Si aparece el error ``RuntimeError: Cannot determine SOC peripheral base address``, consulta :ref:`faq_soc`
Código
------
.. note::
Puedes **Modificar/Restablecer/Copiar/Ejecutar/Detener** el siguiente código.
Pero antes, necesitas ir a la ruta del código fuente como ``raphael-kit/python-pi5``.
Después de modificar el código, puedes ejecutarlo directamente para ver el efecto.
.. raw:: html
.. code-block:: python
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import spidev
import time
import math
# Inicializar SPI para MCP3008 (Bus 0, CE0)
spi = spidev.SpiDev()
spi.open(0, 0) # Bus 0, Dispositivo 0 (CE0)
spi.max_speed_hz = 1000000 # 1 MHz
def read_adc(channel):
"""
Leer valor analógico del canal MCP3008 (0–7)
"""
if channel < 0 or channel > 7:
return -1
# Formato de comunicación MCP3008
adc = spi.xfer2([1, (8 + channel) << 4, 0])
value = ((adc[1] & 0x03) << 8) | adc[2]
return value
try:
while True:
# Leer valor analógico desde CH0 del MCP3008
analogVal = read_adc(0)
# Convertir a voltaje (referencia de 3.3V)
Vr = 3.3 * analogVal / 1023.0
# Calcular resistencia del termistor
Rt = 10000.0 * Vr / (3.3 - Vr)
# Calcular temperatura en Kelvin usando la aproximación Steinhart–Hart
tempK = 1.0 / (((math.log(Rt / 10000.0)) / 3950.0) + (1.0 / (273.15 + 25.0)))
# Convertir a Celsius y Fahrenheit
Cel = tempK - 273.15
Fah = Cel * 1.8 + 32
# Imprimir la temperatura
print('Celsius: %.2f °C Fahrenheit: %.2f °F' % (Cel, Fah))
# Esperar antes de la siguiente lectura
time.sleep(0.2)
except KeyboardInterrupt:
spi.close()
Explicación del código
----------------------
#. Se importan los módulos ``spidev`` para la comunicación con el ADC MCP3008 mediante SPI, ``time`` para los retardos y ``math`` para cálculos logarítmicos usados en la conversión de temperatura.
.. code-block:: python
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import spidev
import time
import math
#. Se inicializa la interfaz SPI para el MCP3008 en el bus 0 y dispositivo 0 (CE0), configurando la velocidad máxima de reloj a 1 MHz.
.. code-block:: python
spi = spidev.SpiDev()
spi.open(0, 0)
spi.max_speed_hz = 1000000
#. Se define una función para leer valores analógicos de un canal específico (0–7) del MCP3008 usando el protocolo SPI. Devuelve un entero de 10 bits (0–1023).
.. code-block:: python
def read_adc(channel):
if channel < 0 or channel > 7:
return -1
adc = spi.xfer2([1, (8 + channel) << 4, 0])
value = ((adc[1] & 0x03) << 8) | adc[2]
return value
#. Se implementa un bucle que lee continuamente valores analógicos del termistor conectado al CH0, los convierte a voltaje (referencia de 3.3V), luego a resistencia y finalmente a temperatura usando la ecuación Steinhart–Hart. Se imprime la temperatura en Celsius y Fahrenheit. Se incluye una pequeña pausa entre lecturas.
.. code-block:: python
try:
while True:
analogVal = read_adc(0)
Vr = 3.3 * analogVal / 1023.0
Rt = 10000.0 * Vr / (3.3 - Vr)
tempK = 1.0 / (((math.log(Rt / 10000.0)) / 3950.0) + (1.0 / (273.15 + 25.0)))
Cel = tempK - 273.15
Fah = Cel * 1.8 + 32
print('Celsius: %.2f °C Fahrenheit: %.2f °F' % (Cel, Fah))
time.sleep(0.2)
#. Se captura la interrupción del teclado (Ctrl+C) para finalizar el programa de forma correcta cerrando la interfaz SPI.
.. code-block:: python
except KeyboardInterrupt:
spi.close()