Pista Para Relevos
Enlace para la descarga de la Pista Relevos
En esta publicación se utilizara la herramienta en linea CircuitVerse para ilustrar el funcionamiento de las compuertas lógicas complementarias
La explicación de la compuertas lógicas principales y sus complementarias esta en el siguiente video .
Esta es la descripción de la compuerta lógica NAND en CircuitVerse, el circuito esta como publico y puede copiarse.
Esta es la descripción de la compuerta lógica NOR en CircuitVerse, el circuito esta como publico y puede copiarse.
Esta es la descripción de la compuerta lógica XOR en CircuitVerse, el circuito esta como publico y puede copiarse.
Esta es la descripción de la compuerta lógica XNOR en CircuitVerse, el circuito esta como publico y puede copiarse.
Este diagrama muestra de forma agrupada y comparativa de las compuertas lógicas basicas y complementarias. Ademas esta los elementos buffer y las negativas OR y AND.
En esta publicación se utilizara la herramienta en linea CircuitVerse para hacer una introducción a las compuertas lógicas
La explicación de la compuertas lógicas principales y sus complementarias esta en el siguiente video .
Esta es la descripción de la compuerta lógica NOT en CircuitVerse, el circuito esta como publico y puede copiarse.
Esta es la descripción de la compuerta lógica AND en CircuitVerse, el circuito esta como publico y puede copiarse.
Esta es la descripción de la compuerta lógica OR en CircuitVerse, el circuito esta como publico y puede copiarse.
En este ejemplo se describe como se conecta la pantalla Nextion al puerto serie de una placa Arduino de manera que se pueda controlar el encendido y apagado de un Led.
En este montaje se ha conectado un Led en el terminal 2 de la placa Arduino con una resistencia de 470 ohm que puede ser también de 330 ohm o 220 ohm. En la conexión de la alimentación den la pantalla es muy importante no invertir los terminales de alimentación que es muy probable dañar la pantalla de esta manera.
Los terminales de comunicación serial se conectan de forma cruzada, es decir TX-RX y RX-TX tal como se muestra en la siguiente figura.
| Arduino | Dispositivo |
|---|---|
| Terminal 2 | Led - 470 ohm |
| Terminal RX | Pantalla TX - Cable amarillo |
| Terminal TX | Pantalla RX - Cable azul |
| Terminal 5V | Pantalla 5V - Cable rojo |
| Terminal GND | Pantalla GND - Cable negro |
Para este ejemplo solo se emplea un botón, las siguientes imágenes corresponden a los estados de encendido y apagado.
En el botón de ON se emplearon los eventos de presionar botón y soltar botón para cambiar de pagina y enviar el carácter "1" por el puerto serie. Las instrucciones empleadas se observan en las siguientes figuras.
Para la acción de presionar se ejecuta la instrucción de enviar el carácter 1 con la instrucción prints "1",1
Para la acción de soltar se ejecuta la instrucción de cambiar de pagina con la instrucción page 1
En el botón de OFF se emplearon los eventos de presionar botón y soltar botón para cambiar de pagina y enviar el carácter "0" por el puerto serie. Las instrucciones empleadas se observan en las siguientes figuras.
Para la acción de presionar se ejecuta la instrucción de enviar el carácter 0 con la instrucción prints "0",1
Para la acción de soltar se ejecuta la instrucción de cambiar de pagina con la instrucción page 0
El programa realizado no emplea ninguna librería por lo que puede emplearse como base para la realización de otros programas en plataformas microcontroladas o microprocesadas como la Raspberry Pi.
En el video presentado al inicio de esta publicación se explica en mas detalle el funcionamiento del código y la prueba realizada en el monitor serie.
Una manera rápida de introducirse al mondo del internet de las cosas es por medio de una pagina que nos provea el servicio de captura y visualización de datos, en este tutorial se ha elegido Ubidots por se una plataforma fácil de configurar y que provee una plantilla de código para trabajar con las placas basadas en el Soc ESP8266 o ESP32.
MQTT es un protocolo abierto el cual posibilita la comunicación entre sí y continua de dos o más
dispositivos enfocado directamente en la conectividad M2M (Machine-to-Machine) que opera con una
arquitectura publicación-suscripción tal como se ve en la siguiente figura.Para el ejemplo a desarrollar
el cliente que publica es la placa Node MCU, el broker sera Ubidots y la visualización sera por medio
del dash board de Ubidots.
MQTT utiliza el paradigma de publicación-suscripción que refiere a que cualquiera de los clientes
puede suscribirse a determinados tópicos o temas y de esta misma manera cualquiera podrá publicar.
Para poder trabajar con la plataforma NodeMCU ESP8266 en el IDE de Arduino, es necesario
instalar el compilador para las plataformas basadas en el microcontrolador ESP8266, el siguiente
video muestra como se hace la configuración del IDE y la programación de prueba en la placa.
Ubidots es una iniciativa colombiana para la elaboración de sistemas basados en el internet
de las cosas.
Ubidots logró convertir su emprendimiento de servicios de monitoreo remoto en una startups que
recibió el apoyo de Mass Challenge - una de las mayores aceleradoras de empresas emergentes del
mundo-, logró levantar un millón de dólares de inversión entre Medellín y Silicon Valley y lanzó
un producto que hoy se usa en más de 160 empresas en todo el mundo. Ubidots ha logrado
posicionarse al punto de tener una comunidad de más de 40.000 desarrolladores y presencia en países
como Argentina, Brasil, EE. UU., Inglaterra, Israel, Australia.
El circuito de prueba empleado se indica en la siguiente figura, es importante indicar que las placas
basadas en el ESP8266 trabajan a 3.3 voltios.
El montaje también puede realizarse con la placa WeMos D1 o Mini. El video que esta a continuación indica el procedimiento para conectar la Placa NodeMCU con
El código de prueba se deja a continuación, en el video muestra como se configura TOKEN y la
red WiFi
/****************************************
* Include Libraries
****************************************/
#include "UbidotsESPMQTT.h"
/****************************************
* Define Constants
****************************************/
#define TOKEN " " // Your Ubidots TOKEN
#define WIFINAME " " //Your SSID
#define WIFIPASS " " // Your Wifi Pass
Ubidots client(TOKEN);
/****************************************
* Auxiliar Functions
****************************************/
void callback(char* topic, byte* payload, unsigned int length) {
Serial.print("Mensaje recibido [");
Serial.print(topic);
Serial.print("] ");
for (int i=0;i<length;i++) {
Serial.print((char)payload[i]);
}
Serial.println();
}
/****************************************
* Main Functions
****************************************/
void setup() {
// put your setup code here, to run once:
//client.ubidotsSetBroker("industrial.api.ubidots.com"); // Sets the broker properly for the industrial account
client.setDebug(true); // Pass a true or false bool value to activate debug messages
Serial.begin(115200);
client.wifiConnection(WIFINAME, WIFIPASS);
client.begin(callback);
}
int i=0;
void loop() {
//put your main code here, to run repeatedly:
if(!client.connected()){
client.reconnect();
}
if(i<100){
float value1 = analogRead(A0);//Lectura analogo
client.add("var_pot01", value1);//El cliente agrega una variable
client.ubidotsPublish("prueba");//Colocar el nombre de dipositivo
client.loop();
i++;
delay(2000);
}
}
En esta publicación se describirá como se realiza la instalación de ActiveMQ en el sistema operativo Linux.
La instalación se realizo sobre un distribución basada en Ubuntu específicamente Pop! OS
El siguiente video explica el proceso de instalación y prueba realizado.
La descarga se puede realizar desde la pagina principal del proyecto y desde la pagina de downloads de Apache.
La descarga descarga y descompresión desde el terminal se realiza con las siguientes instrucciones
wget http://www.apache.org/dist//activemq/5.16.1/apache-activemq-5.16.1-bin.tar.gz
tar -zxvf apache-activemq-5.16.1-bin.tar.gz
La URL empleada en el terminal accede a el enlace de downloads de Apache. En caso de dar error en la descarga por no encontrar la versión esta se puede revisar en el enlace de downloads.
Teniendo ya la carpeta con las archivos de ActiveMQ se procede a configurar el permiso de ejecución y según las necesidades el cambio de parámetros en el archivo de configuración env.
El archivo de ejecución de ActiveMQ esta en la carpeta bin dentro de la carpeta que se ha descomprimido.
![]() |
| Ruta de la carpeta bin |
Las instrucciones empleadas en el terminal son las siguientes, tal como se muestra en el video.
cd apache-activemq-5.16.1/bin
ls -l
chmod 755 activemq
ls -l
El archivo de configuración también se encuentra dentro de la carpeta bin, para visualizar y editar se emplearon cat (visualizar) y vi (editar).
cat env
vi env
Es importante tener una versión actualizada de Java instalada, para saber sobre que versión se dispone se emplea la siguiente instrucción.
java -version
Para ver la ayuda de ActiveMQ se ejecuta la siguiente instrucción.
./activemq -help
Los siguientes enlaces contienen información adicional sobre las instrucciones empleadas en el terminal .
La prueba del broker se realiza desde el terminal ademas de poderse emplear el browser para la viusalizacion del estado de los mensajes enviados y recepcionados. La siguiente imagen muestra las instrucciones empleadas desde el terminal para la realizacion de la prueba.
./activemq start
./activemq bstat
./activemq producer
./activemq consumer
./activemq stop
La URL local que se crea al inicial el broker es http://127.0.0.1:8161/admin/ y tiene por defecto como usuario admin y password admin. La siguiente figura muestra la pagina que debe ser visualizada en el broker.