Archivo de la etiqueta: how-to

Sensor ultrasónico HC-SR04 en Icaro

Para conectar un sensor ultrasónico HC-SR04 a una placa Icaro vamos a usar el conector P16 a como se muestra en la siguiente imágen.

Opcionalmente podríamos tomar corriente del banco de sensores analógicos.

En Icaro Bloques podemos ir a Archivo -> Ejemplos y escoger la carpeta hc-sr04 y abrir el ejemplo llamado ping.icr

Este firmware lo que hace es mostrar la distancia en centimetros en valores binarios en la barra de leds de la placa.

Icaro Bloques 1.0.8-3 y Pingüino Bootloader Versión 4

Icaro Bloques llega a la versión 1.0.8-3 y trae como principal cambio el uso del bootloader de pingüino  versión 4.

Este bootloader esta escrito en sdcc3 y entre los cambios notables está que es más pequeño y nos deja más espacio para nuestro firmware.

El cambio se ve impulsado por problemas con en Fedora 24 y 25 en la comunicación serial. En algunos casos no se lograba montar adecuadamente el dispositivo ACM, aunque en algunos casos el PIC se colgaba al inicializar. Lo que uno veía era que la luz de estado del PIC se apagaba justo después de encender, haciendo un parpadeo de un lapso apagado largo y un breve destello.

Lo más novedoso es el proceso de ejecución y carga de firmwares. Ahora la placa entra en estado de ejecución del firmware al encender y solo entra en la rutina de carga al apretar el botón reset.

Con el nuevo bootloader el proceso de carga del firmware cambia. Los pasos son a como siguen:

  1. Dar click en el botón de “Compilar” en Icaro Bloques para compilar el firmaware
  2. Dar click en Cargar para enviar el firmaware al PIC
  3. Oprimir el botón de reset en la placa. (El led de estado parpadea de forma continua)
  4. Dar click “Aceptar” en la ventanita lanzador.py que nos muestra la comunicación de la PC y la placa
  5. Dar click en OK en la notificación del resultado de la carga.

La carga es mucho más rápida.

Otras ventajas del nuevo bootloader es que se han trabajado las librerías, y por ejemplo ahora el control de servos es más preciso.

Si bien Icaro Bloques 1.0.8-3 tiene por defecto comunicarse con la versión 4 del bootloader uno puede editar el archivo /home/user/.icaro/config.ini

[general]
turtlear = /usr/share/sugar/activities/TurtleBlocks.activity/turtleblocks.py
dir = firmware
sdcc = sdcc-sdcc

[icaro_config]
bootloader = v4

Solo hay que reemplazar el número 4 por un número 2. Con ese cambio estaremos listos para correr el programa con PICs que tengan aun el bootloader de la versión 2 de pingüino.

Pilas no esta disponible en Icaro Bloques 1.0.8-3 debido a que no se ha trabajado las nuevas librerías para comunicación Bulk. Sin embargo se ha optado por avanzar debido a los grandes problemas de comunicación con el firmaware de tortucaro para comunicación CDC.

Conectar un shield Bluetooth a Ícaro

Arduino tiene dos shields de Bluetooth, el HC-05 y el HC-06. El HC-05 tiene la posibilidad de funcionar como unidad master o slave, mientras que el HC-06 solo puede funcionar como slave. En este caso me enfocaré al uso como slave, donde abrimos un canal de comunicación de la PC hacia la placa para enviar ordenes y recibir respuesta de estado de los sensores.

El HC-05 tiene 6 pines y el HC-06 tiene solo 4. Para este caso solo usaremos 4 pines, en cualquiera de los dispositivos. En el reverso del dispositivo están claramente indicados los pines RXD, TXD, GND y VCC

Por otra parte hay que ver el mapa de pines de la placa icaro para identificar en los puertos de servos cuales corresponden a señal, cuales a VCC ( corriente de +5VDC) y GND (Tierra). Igual pueden verse en la ilustración a continuación

Asignación
TXD – Pin de Señal K5 (pin más cerca del micro)
RXD – Pin de Señal K6
VCC – VCC K5 (pin del centro)
GND – GND K5 (pin más lejos del micro)

Luego de haber conectado el shield de Bluetooth a la placa procedemos a cargar el firmware de Bluetooth a la placa de Ícaro. Para ello conectamos la placa con un cable USB a la computadora, cargamos Ícaro bloques y buscamos el botón de icaroblue.

Este firmware se compila automáticamente y nos invita a resetear la placa Ícaro. Procedemos a oprimir el botón reset de la placa Ícaro esperamos por el mensaje de que la carga se realizó con éxito.

Podemos continuar usando el cable USB como fuente de energía, conectado a la PC o a un transformador. O bien pasamos a alimentar la placa desde una fuente externa, haciendo el cambio del jumper K1.

Para iniciar la comunicación debemos usar el administrador de dispositivos Bluetooth y hacer el emparejamiento con el dispositivo. Luego necesitamos hacer un clic derecho sobre dicho dispositivo para conectarlo como un puerto serial.

Una vez conectado como puerto serial podemos verificar la conexión usando un programa de comunicación serial como cutecom. Los parámetros de conexión que debemos configurar son:
Device: /dev/ttyrfcomm0
Baud rate: 9600bps

Le damos clic al botón Open device y debería establecerse la conexión.

Procedemos a escribir la letra “b” en la barra de input y damos enter.

Deberíamos ver en la pantalla una respuesta Icaro USB2.0 que es la respuesta al comando de estado.

Esto es suficiente para ver que esta funcionando. Mi siguiente reto es documentar los comandos seriales que pueden usarse con la placa ya sea por el cable USB o vía Bluetooth.

Conectar una pantalla LCD a Ícaro

Tengo esta pantalla de 16 caracteres por 2 lineas que deseaba conectar a la placa Ícaro. Esta pantalla es de las más comunes, pero ahora están tomando popularidad pantallas que incluyen un modulo I2C de comunicación. Esta pantalla no incluye dicho módulo. Espero hacer notas sobre trabajo con dispositivos I2C e Ícaro en el futuro.

Para conectar la pantalla LCD 2×16 vamos a ocupar 12 lineas de conexión. Pero lo más importante, antes de iniciar, es conocer nuestro Port B o P5 de la placa Ícaro.

El Port B es la salida del micro-controlador hacia el UNL2803. Si sostenemos placa con la barra de led hacia la derecha de forma que el micro controlador este arriba del integrado UNL2803, entonces en el Port B tendrás los pines de izquierda a derecha. El primer pin de la izquierda sera P0 y el ultimo hacia la derecha será P7.

Para conectar hay que seguir la siguiente asignación.

Pantalla – Placa Ícaro
VSS – Ground
VDD – +5VDC
V0 – Ground
RS – P4 Port B
RW – Ground
E – P5 Port B
D0
D1
D2
D3
D4 – P0 Port B
D5 – P1 Port B
D6 – P2 Port B
D7 – P3 Port B
A – +5VDC
K – Ground

Las lineas de +5VDC y Ground las conecte a los pines de VCC y Ground de los sensores analógicos. Igual podría conectarse a los pines respectivos en los puertos de servos.

Opcionalmente en la linea A se puede conectar una resistencia para variar el brillo o contraste de la pantalla, dado que A y K son los que alimentan la luz de la pantalla.

Para probar que todo esta bien solo hace falta abrir un script del menú Archivo, seleccionar Ejemplos, ahí navegar a la carpeta LCD y cargar el archivo llamado hola mundo. Como siempre, compilar el script y luego cargar al micro-controlador.

Al ver el script podemos identificar que se envían 0 y 0 antes de enviar los caracteres “hola”. El primer cero corresponde a la Columna y el siguiente corresponde a la Fila. Esto la posiciona en la primera columna de la primera fila. Como vemos “mundo” recibe de previo 0 y 1, es decir primera columna, segunda fila.

La pausa al final es importante, es lo que mantiene los caracteres en pantalla antes de reiniciar el bucle infinito del script. Sin la pausa, o con un valor muy pequeño, no podríamos ver el mensaje. Por otro lado las pausas son importante antes de borrar la pantalla o asignarle un nuevo valor. Sin pausa, el nuevo valor se mostrara en pantalla antes de que podamos haberlo leído.

Ahora lo que resta en experimentar y aprender.

Usar funciones en Icaro Bloques

Usar funciones al programar nos permite reutilizar código. En particular al tratar con bloques, nos evita atiborrar la pantalla, pero también nos evita errores de conexión entre bloques al repetir varias veces lo mismo.

Lo primero es crear una rutina que será nuestra función. Un ejemplo sencillo, hacer parpadear un led. Esta rutina la salvamos como un archivo de icaro.

Luego la salvamos como una función con el mismo nombre.

En el ejemplo siguiente mostramos como hacer la llamda de la función. Usamos un bloque de carga_func para llamar a la funcion y luego un bloque de acción con la función.

Para que esto funcione debemos salvar la rutina como un archivo de icaro y luego darle compilar. Todos los archivos deben estar en la misma carpeta, de esta manera Ícaro Bloques encuentra el código a usar de los archivos.

Si nos vamos a la pestaña de código fuente y damos click en el boton recargar, podremos ver el código con la declaración de la función y el llamado a la misma en lenguaje C.

 

Sensores Analógicos y Digitales con la placa Icaro

Los sensores digitales son los más simples. Un interruptor es un sensor digtal. Simple: Apagado o encendido. Un interruptor de paro o un botón de pulso es lo mismo.

Tomamos un interruptor y conectamos sus extremos a la bornera sn_d1 justo al lado del boton de reset en la placa NP-06.
interuptor de paro
Hacemos unos bloques simples a como se muestra a continuacion:
sensor-digital
El resultado será que cuando se cierra el circuito, es decir el interruptor esta encendido el led primero se encenderá. Cuando el interruptor se apague, el led hara lo mismo.

Los sensores analógicos son un poco más complicados. Su respuesta es un valor que varia segund determinadas condiciones. Para ilustrar esto usaremos un potenciometro. La forma más simple de potenciometros son los controles de volumen. Es bien fácil comprar uno o rescatar uno de un aparato que ya no sirve.
potenciometro
Vamos a encontrar clasicamente tres patitas. La primera es tierra (GND) , la segunda es la salida del sensor (sens_analog) y la tercera es voltaje (VCC). Realmente es una resistencia variable. Si invertimos el orden, no será un problema. Siempre tendremos un voltaje que varia en el centro en relación al voltaje existente entre la alimentación y tierra.

Lo que hay que hacer es conectar los cables en los puertos que se encuentran al lado del led rojo en la placa NP-06. Los tres primeros pines, los mas cerca al extremo de la barra de leds corresponden al primer sensor analógico. En la placa NP-06 estan claramente identificados.
sensor analogico
Ahora hacemos unos bloques a como se muestran a continuación.
sensor_analogico
El resultado es que al mover el valor del control de volumen, la barra de led incrementara o reducirá el valor binario representado por los leds.

Conexión serial a la placa Icaro

La placa Icaro nos ofrece una gran cantidad de beneficios como una placa autónoma. Pero también podemos sacar provecho de su conexión serial. Tortucaro es la herramienta que nos permite esto.

Para ello debemos ubicar el icono de tortucaro en la ventana de icaro y hacer click en él. Luego hacemos click en compilar. Finalmente hacemos click en Cargar. Oprimimos el botón de reset en la placa y nos debe decir que la carga fue exitosa. En la versión de desarrollo, todo esto es más breve, varios pasos redundante se eliminan, pero la lógica es la misma.
botones_icaro
Si este es el primer intento usando tortucaro, podemos querer hacer algunas pruebas. El primer paso es confirmar que existe la conexión con la placa. Desde la terminal usamos el comando ls /dev/ttyA* nosotros esperamos que la respuesta incluya que dentro de los dispositivos existe /dev/ttyACM0

Posiblemente el programa de comunicación serial más simple de usar es cutecom. Lo mas seguro es que no lo tengan instalado, asi que pueden usar la interfaz gráfica o un comando como
su -c «yum install cutecom»

Al iniciar cutecom enviará un aviso que no logro conectar con el puerto /dev/ttyS0, lo cual es lógico porque seguramente no tienen nada conectado a un puerto serial o incluso no tiene puerto seriales en la computadora. Asi que en la parte superior debemos configurar dispositivo o device a /dev/ttyACM0 y luego hacer click en el botón abrir dispositivo o open device. Si no hay malas noticias, son buenas noticias.
cutecom
El programa tiene tres áreas de texto, de arriba hacia abajo, respuesta del dispositivo, historico de comandos enviados al dispositivo y entrada o input. Nos colocamos en input y escribimos «b» y damos enter. En la ventana de respuesta dirá «icaro USB 02»

Si tenemos un servo podemos usar comando como m1! (mover servo del puerto uno al valor ascii 33) o bien puede escribir m1Ñ (mover servo del puerto uno al valor ascii 126) Puede buscar una guia de valores ascii

Ahora que ya saben como es el asunto de la comunicación serial y han comprobado que funciona, pueden hacer algunas cosas más intersantes. Por ejemplo les comparto un pequeño programa de python escrito por Valentin Basel

#!/usr/bin/env python
# -*- coding: utf-8 -*-
#
# servo.py
#
# Copyright 2014 valentin basel
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
# MA 02110-1301, USA.
#
#

import apicaro
import time
icaro=apicaro.puerto()

icaro.iniciar()
for a in range(3):
icaro.activar_servo(1,1)
time.sleep(1)
icaro.activar_servo(1,255)
time.sleep(1)

Icaro y la version devel

Cuando estamos probando las ultimas cosas de un programa puede ser que tengamos deseo de ir al paso del desarrollo de ese programa. La versión en desarrollo o devel es un espacio para experimentar, encontrar que cosas no están funcionando y hacer sugerencias. Icaro tiene esta versión y quiero compartir como echarla a andar. No estoy siendo muy explicito, porque si están buscando la versión de desarrollo, supongo que ya tienen alguna experiencia en Fedora

Lo primero a saber, es que el repositorio nos va a presentar la versión estable. Nosotros tenemos que navegar en busca de la versión de desarrollo.

La pueden encontrar aqui: https://github.com/valentinbasel/icaro/tree/devel

Eso les dará acceso a hacer una descarga de un archivo zip. Deben descomprimirlo manteniendo la estructura interna de directorios. Usualmente yo descomprimo en la misma carpeta de Descargas y obtengo una carpeta llamada icaro-devel. Luego muevo esta carpeta hacia mi directorio Home. Lo hago así porque un error de descomprimir cosas en Home, puede ser algo tedioso de limpiar, mientras que si ocurre en Descargas no será la gran cosa.

Voy a usar la palabra USUARIO que ustedes deberan cambiar por el nombre de su propio usuario. Hasta el momento tenemos /home/USUARIO/icaro-devel/ y posiblemente han usado los beneficios de las herramientas gráficas.

Si no han instalado la version estable, ustedes deben hacer algunas configuraciones, las cuales las realicé desde la terminal

su -c «group add microchip»
su -c «usermod -a -G microchip USUARIO»
su -c «usermod -a -G dialout USUARIO»

Lo siguiente es poner algunos archivos en su sitio, lo mismo esto lo hago desde la terminal

mkdir ~/.icaro
cp -r ~/icaro-devel/hardware/icaro/micro/firmware ~/.icaro/
cp -r ~/icaro-devel/hardware/icaro/micro/conf ~/.icaro/
su -c «mkdir /usr/share/icaro»
su -c «cp -r ~/icarodevel/hardware /usr/share/icaro/»

Para correr la version de desarrollo la ejecutan desde la terminal ubicandose en el directorio de desarrollo:

cd ~/icaro-devel
python lanzador.py

Correr el programa desde la terminal nos permite ver los comentarios que va generando y en caso de error nos puede dar idea de que se trata ese error.

HPLIP configurar impresoras HP en fedora 21

Tengo una impresora o printer multifuncional HP LaserJet 1536 dnf MFP conectada en red a mi nueva instalación de Fedora 21 Work Station.

Esto siempre es un dilema, puesto que añadir impresora desde el panel de administración de impresoras no siempre me deja los resultados deseados. Por ejemplo no tengo acceso al scaner de la impresora multifuncional. Por otra parte desinstalar hplip de fedora e instalarlo desde el sitio del fabricante es una opción válida pero bastante lenta. Inicia por borrar la cache de yum, luego instala paquete por paquete, lo que incluye los paquetes de compilación gcc entre otros. Además incluye la herramienta de scaner xsane, muy poderosa pero mucha gente prefiere la herramienta simple scan. Luego pasa a compilar y finalmente uno debe ejecutar hp-setup.

Para evitarse tanto complicación, la forma fácil de instalar una impresora multifuncional HP en fedora es irse a la terminal y ejecutar de una vez como administrador (root o superusuario) el comando :

hp-setup

Bueno no es tan fácil, eso les va a dar un error porque hay un paquete que no esta instalado. Si leen con atención les va a decir cual es el problema. Pero nadie lee la salida del sistema para encontrar la solución. La computadora no te odia, solo no sabe que hacer y te dice que no te entiende. Muchas veces al decir que no entiende te das cuenta que te falto. Asi que de nuevo como administrador:

yum install hplip-gui

Luego de instalar ese paquete y sus dependencias, entonces si estamos listos para la mágia. Intentamos de nuevo como administrador

hp-septup

Eso les llevara a un panel de configuración que es bien sencillo de seguir. Como resultado tendrán su impresora HP multifuncional instalada en Fedora 21 en el panel de impresoras y además el scaner funcionando. Yo desactive la opción de fax, pero tendrían esa opción también si lo desean.

En fin, normalmente las impresoras o printers se configuran automaticamente en Fedora, pero algunos modelos necesitan un pequeño paso adicional.

UPDATE he tenido problemas en Fedora 22 con el instalador gráfico. Una opción alternativa es usar como administrador el comando:

hp-setup -i

Esto hace la secuencia de instalación en la terminal.

Enviar SMS desde la linea de comando

Como enviar mensajes de texto desde la terminal con el modem 3g ZTE MF636 en Fedora Linux? Como activar un plan prepago de tu modem3g desde la linea de comando?

Yo necesito enviar un mensaje para activar mi plan prepago de movistar (Nicaaragua), luego esperar la respuesta sobre las opciones de tiempo de conexión, contestar con un número de opción y esperar por la confirmación. Poner el SIM card en un telefono para hacer esto y luego ponerlo en el modem es tedioso. Peor aun sería cargar Windows con la suite de la compañía de celular para enviar el mensaje y luego regresar a linux. Cosa que a final no puedo hacer porque no tengo Windows en mi laptop.

Para mi lo ideal era usar una herramienta con interfase gráfica como gnome-phone-manager. En verdad me funcionó para enviar mensajes, luego hubo un conflicto de versión de GTK y ahora no logro que se conecte a un puerto serial, siempre busca un puerto bluetooth. En realidad gnome-phone-manager es una interfase gráfica para gnokii que es el verdadero programa que administra la comunicación con el modem 3g.

Así que lo primero es instalar gnokii y lo podemos hacer desde la terminal.

su -c «yum install gnokii»

Yo uso la sintaxis de fedora. Para usar sudo en fedora deben configurarlo. Y si usan otra distro deben ver el comando de instalación específico para su distro. Igual podemos buscar el paquete para su instalación desde la administración de software.

Lo siguiente es configurar gnokii. Para ellos creamos un archivo llamado .gnokiirc y lo ponemos en nuestra carpeta de usuario.

/home/mi_nombre/.gnokiirc

Donde mi_nombre es el nombre del usuario. El contenido del archivo es simple:

[global]
port=/dev/ttyUSB2
model=AT
connection=serial

Nuestro usuario no tiene permisos de acceso al puerto serial que hemos utilizado. Así que debemos incluir a nuestro usuario en el grupo de dialout.

Desde la linea de comando podemos usar el siguiente comando:

su -c «usermod -a -G dialout mi_nombre»

De nuevo donde mi_nombre es el nombre del usuario. El comando anterior debe ser igual para todas las distribuciones de linux. Otra alternativa es instalar el paquete system-config-users que es una interfase gráfica para administrar los usuarios con más detalles, como por ejemplo hacer un check en el grupo que queremos que nuestro usuario pertenezca. Esto lo encontramos como la aplicación de «usuarios y grupos». Desde los ajustes de sistema en Gnome Shell solo veremos unas opciones limitadas para administrar usuarios.

Ahora podemos conectar el modem y esperar que este listo. Esto a simple vista se puede verificar con la luz azul que parpadea en el modem ZTE MF636.

La otra alternativa es usar el comando dmesg en la terminal que nos brinda al final aproximadamente las siguientes lineas

[ 824.501063] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB2
[ 824.507774] usbcore: registered new interface driver option
[ 824.507783] option: v0.7.2:USB Driver for GSM modems
[ 829.753101] scsi 5:0:0:0: Direct-Access ZTE MMC Storage 2.31 PQ: 0 ANSI: 2
[ 829.758421] sd 5:0:0:0: Attached scsi generic sg1 type 0
[ 829.766896] sd 5:0:0:0: [sdb] Attached SCSI removable disk

A este punto podemos probar que todo esta bien con el siguiente comando:

gnokii – -identify

la respuesta deberia ser a como sigue:

GNOKII Version 0.6.31
IMEI : 352847029322631
Manufacturer : ZTE INCORPORATED
No flags section in the config file.
Model : MF636
Product name : MF636
Revision : BD_LATMOVP673M2V1.0

Yo debo enviar la palabra ACTIVAME al número 2266, el comando es a como sigue:

echo «activame» | gnokii – -sendsms 2266

La parte dificil es que el modem ZTE MF636 no es compatible con la opción de espera para capturar el mensaje. Asi que debemos consultar el contenido de memoria del modem con el siguiente comando:

gnokii – -showsmsfolderstatus

Lo que nos brinda el siguiente reporte

GNOKII Version 0.6.31
No. Name Id #Msg
========================================================
0 Internal memory ME 0
1 Combined ME and SIM phonebook MT 0
2 SIM card SM 7
3 SMS Status Reports SR 0

Podemos ver que los mensajes se almacenan en la SIM card y que esa memoria es SM. En este caso hay 7 mensajes, en linux eso significa mesnajes del 0 al 6. Si quiero ver los mensajes el comando será:

gnokii – -getsms SM 0 6

puedo consultar solo un mensaje, le doy la posición de dicho mensaje sin especificar inicio y fin, por ejemplo el último mensaje será:

gnokii – -getsms SM 6

lo que me da como resultado algo asi:

6. Inbox Message (Unread)
Date/time: 13/09/2013 21:50:23 -0600
Sender: 2266 Msg Center: +5026099948
Text:
Envia 1 para contratar 2hr de navegacion por CS15, 2 para contratar 12hrs por CS50, 3 para 30min por CS10, 4 para 24hrs por CS90 o 5 para 3 Dias por CS150

Ahora podría repetir los pasos y enviar la respuesta, por ejemplo opción número 1 con el siguiente comando:

echo «1» | gnokii – -sendsms 2266

Y solo me queda esperar la confirmación, que puedo consultar a como he mostrado anteriormente.

Algunas cosas adicionales con el manejo de los mensajes podría ser guardar los mensajes a un archivo de texto

gnokii – -getsms SM 0 6 -f archivo.txt

Donde archivo.txt es el nombre de archivo de su elección.

Tambien pueden borrar los mensajes almacenados en el SIM card. Supongamos que queremos respaldar a nuestra maquina los mensajes y luego borrarlos:

gnokii – -getsms SM 0 6 -f archivo.txt -d

Algo a tener en cuenta es que cuando se conectan a la internet por el modem3g, ya no podrán hacer uso de las opciones de envío y recepción de mensajes.

Espero que esto sea de utilidad para algunas personas con planes de prepago en modem 3g. Sin embargo yo solo tengo el modem que describo. Así que no puedo asegurar como funcionará con otros modem3g, sin embargo esto les podrá servir de guía.

Quiero agradecer a Spot quien me ayudo a encontrar muchos de los detalles de gnokii en particular la siguiente referencia: http://wiki.gnokii.org/index.php/SMS_options (la página esta en inglés)