Crear entorno virtual bajo Conda(python)

Introducción

Conda es un gestor de paquetes y de entornos virtuales multiplataforma que nos permite instalar, ejecutar y actualizar los paquetes y sus dependencias, de esta manera podremos configurar y cambiar entre distintos entornos en nuestro ordenador[1].

A grandes rasgos, un entorno virtual o ‘virtual environment’  es una carpeta en la que se encuentran los ejecutables de python y las distintas versiones de las librerías que vayamos a usar. De este modo, podremos estar desarrollando varias aplicaciones con distintas versiones de las librerías, incluso del propio interprete de python, gracias a los entornos virtuales.

Con conda se instalan multitud de librerías y aplicaciones secundarias que son usadas habitualmente en el desarrollo con python[2].

A continuación se explicará el proceso que hay que seguir para poder crear un entorno virtual usando Conda así como una lista con los comandos más usados en la gestión de los entornos virtuales.

Instalación

Lo primero será comprobar si tenemos conda actualizado:

:~$  conda update conda

En caso de tener que actualizar algún paquete, pulsaremos la tecla Y para confirmar la actualización.

Posteriormente comprobaremos cuales son las versiones de python que tenemos instaladas en nuestro sistema.

:~$ conda search ‘^python$’

Una vez que sabemos cual es la versión que queremos, crearemos el entorno virtual:

:~$ conda create -n nombredeentorno python=x.x anaconda

Donde sustituiremos x.x por la versión antes buscada.

Una vez creado, el siguiente paso será activarlo para poder usarlo:

:~$ source activate nombredeentorno

Una vez que terminemos de usar el entorno deveremos descativarlo:

:~$ source deactivate

Otros comandos

A continuación se detallan otros comandos relacionados con el mantenimiento de los entornos virtuales[3].

Listar todos los entornos virtuales creados:

:~$ conda info –envs

Comprobar el entorno virtual activado:

:~$ conda info –envs

Eliminar un entorno virtual:

:~$ condo env remove –name nombredeentorno

Comprobar las versiones de las librerías instaladas:

:~$ conda list -e

Referencias

  1. http://conda.pydata.org/docs/install/quick.html#os-x-miniconda-install
  2. https://docs.continuum.io/anaconda/pkg-docs
  3. http://conda.pydata.org/docs/using/envs.html#managing-environments

 

Crear entorno virtual bajo Conda(python)

Editar ficheros de un servidor remoto desde Atom

Introducción

Ultimamente estoy desarrollando aplicaciones para la raspberry. Al principio editaba los ficheros de forma local con el entorno gráfico de raspbian, sin embargo el editor de python que trae de serie es demasiado simple, sin resaltado de sintaxis ni corrección de errores.

Por ello, decidi usar el editor Atom y el paquete para poder conectarse a un servidor FTP, remote-ftp. Atom, al igual que otros editores de texto como Sublime Text, permite instalar paquetes para añadir funcionalidades extra.

El sistema operativo Raspbian para raspberry pi trae instalado un servidor ssh/sftp por ello, junto con el paquete para Atom nos conectaremos a la raspberry y editaremos los ficheros

Instalación

Nos dirigimos al apartado install dentro de las preferencias de Atom y en el cuadro de búsqueda introducimos “remote-ftp” e instalamos el paquete.

Captura de pantalla 2016-03-25 a las 16.09.19

  1. Lo siguiente será abrir la carpeta que contenga nuestro proyecto existente o crear uno nuevo(File -> Open folder…)
  2. Al ser la primera vez que usamos remote-ftp deberemos crear un fichero de configuración (Packages -> Remote-ftp -> Create SFTP config file) y se nos generará el fichero .ftpconfig dentro de nuestro proyecto.Captura de pantalla 2016-03-25 a las 16.32.18Deberemos rellenar la siguiente información:
    • host: Dirección ip del servidor.
    • port: Puerto del protocolo sftp.
    • user, password: Usuario y contraseña del servidor.
    • remote: Ruta del directorio del proyecto que estamos editando.
    • hosthash: Por defecto es un parámetro vacío, en caso de obtener un error en la conexión con el servidor. deberemos poner  “sha1” o “md5” [1].
  3. Una vez editamos el fichero de configuración nos conectaremos al servidor Package -> Remote-ftp > Connect
    Captura de pantalla 2016-03-25 a las 16.41.33De esta manera se nos abrirá la barra con los ficheros del servidor remoto y  podremos editar los ficheros del servidor en nuestro editor de textos local teniendo así de manera automática un backup en nuestro ordenador.Captura de pantalla 2016-03-25 a las 16.42.50

 

Referencias

  1. https://github.com/mgrenier/remote-ftp/issues/321
Editar ficheros de un servidor remoto desde Atom

Cómo usar el buspirate V4 como conversor Serial

Hay muchos tipos de convertidores USB serial, para poder comunicarnos con varios dispositivos. Sin embargo, yo uso el buspirate. Que es una placa muliusos, entre las que incluye conversor USB a serial (mode UART). Vamos a ver dos ejemplos para comunicarnos con un arduino que está mandado información por un puerto serie usando la librería SoftwareSerial y para comunicarnos con el puerto serie de una raspberryPi.

Yo estoy usando el Buspirate V4 con la versión V6.2 beta1

Buspirate-Arduino

Las conexiones que hay que realizar son las siguientes:

Buspirate Arduino
Tx(MOSI) Rx
RX(MISO) TX
GND GND

Una vez que ya están hechas las conexiones, abrimos una comunicación serie del ordenador al BusPirate, en mi caso uso Mac, y usaré la aplicación Screen.

$>screen /dev/tty.usbmodem00000001 115200
$Hiz>m # Para entrar en la configuracion
$Hiz>3 # Establece el modo UART
$Hiz>4 # para una velocidad de 4,800 bps (SoftwareSerial)
$Hiz>1 # para 8 bits, sin paridad
$Hiz>1 # para 1 bit de parada
$Hiz>1 # Espera de 1
$Hiz>2 # para normal, 3.3v de salida
$Hiz>(1) # para activar Transparent bridge mode
$Hiz>y # Para empezar el modo puente

De este modo empezaremos a ver por pantalla lo que nos manda el arduino. Esto lo podemos usar para crear u puerto serie virtual de depuración de arduino.

Buspirate-Raspberry pi

Buspirate RaspberryPi
Tx(MOSI) Rx(pin 8)
RX(MISO) TX (pin 10)
GND GND(pin 6)

Una vez que ya están hechas las conexiones, abrimos una comunicación serie del ordenador al BusPirate, en mi caso uso Mac, y usaré la aplicación Screen.

$>screen /dev/tty.usbmodem00000001 115200
$Hiz>m # Para entrar en la configuracion
$Hiz>3 # Establece el modo UART
$Hiz>9 # para una velocidad de 115,200 bps
$Hiz>1 # para 8 bits, sin paridad
$Hiz>1 # para 1 bit de parada
$Hiz>1 # Espera de 1
$Hiz>2 # para normal, 3.3v de salida
$Hiz>(1) # para activar Transparent bridge mode
$Hiz>y # Para empezar el modo puente

Una vez que está en espera, Pulsamos en cualquier tecla y ya nos habilita el login en la raspberry

Cómo usar el buspirate V4 como conversor Serial

Renacujo sigue lineas y seguidor de luz

Siguiendo con los ejemplos de programación de renacuajo he añadido un ejemplo muuuy sencillo. Hasta ahora, si el renacuajo llegaba al final de la linea, buscaba otra con los sensores IR, sin embargo ahora he añadido que, al llegar al final de la linea se le pueda guiar con la luz que va recibiendo con las fotoresistencias.

Aquí añado un vídeo de ejemplo:

Y el código muy sencillo:

#include <Servo.h>

//Creamos los objetos del tipo servo
Servo Servo1;
Servo Servo2;

int ir_derecho;
int ir_izquierdo;
int ldr_derecho;
int ldr_izquierdo;
int NEGRO =0;
int BLANCO= 1;
int umbral = 30;

void setup()
{

Servo1.attach(6);
Servo2.attach(9);

pinMode(2, INPUT);
pinMode(3, INPUT);

}

void loop()
{
//Vemos como están los IR
ir_derecho = digitalRead(2);
ir_izquierdo = digitalRead(3);
// Seguimos la linea
if ( (ir_derecho == NEGRO) && (ir_izquierdo == NEGRO) ) {
Servo1.write(0);
delay(20);
Servo2.write(180);
delay(20);

}
//Giramos a la izquierda
else if ( (ir_derecho == BLANCO) && (ir_izquierdo == NEGRO) ){
Servo1.write(90);
delay(20);
Servo2.write(180);
delay(20);
}
//Giramos a la derecha
else if ( (ir_derecho == NEGRO) && (ir_izquierdo == BLANCO) ) {
Servo1.write(0);
delay(20);
Servo2.write(90);
delay((20));

}
//Seguimos la luz si los dos sensores no detectan negro
else {
//Leemos el estado de los sensores de luz
ldr_derecho = analogRead(A2);
ldr_izquierdo = analogRead(A3);
//Si hay mas luz en el lado derecho giramos a la derecha
if (ldr_derecho >= ldr_izquierdo + umbral){
Serial.println(“Derecha”);
Servo1.write(0);
delay(20);
Servo2.write(90);
delay((20));
}
//Si hay mas luz en el lado izquierdo giramos a la iquierda
else if (ldr_izquierdo >= ldr_derecho + umbral){
Serial.println(“Izquierda”);
Servo1.write(90);
delay(20);
Servo2.write(180);
delay(20);
}
//Vamos hacia adelante.
else{
Serial.println(“Adelante”);
Servo1.write(0);
delay(20);
Servo2.write(180);
delay(20);
}
}

}

 

 

Renacujo sigue lineas y seguidor de luz

Libreria para renacuajoBot

Aprovechando la librería de arduino que empezaron a escribir Juan Gonzalez y David Estevez, he añadido nuevas funcionalidades para trabajar de manera cómoda con el renacuajobot.

He añadido nuevos métodos para añadir un servo, indicándole el pin en el que está conectado, y la posición en la que está del robot.

He hecho lo mismo para añadir los sensores, en este caso solo están operativos los del sigue lineas.

Por último, he agregado una función que automáticamente sigue las linea sobre la que esté posicionado el robot. Lo siguiente que haré será que el propio robot busque las lineas a seguir dentro de un rango

El nuevo código lo podeis encontrar en mi github.

Libreria para renacuajoBot

Sigue lineas renacuajoBot

Como dije anteriormente, los sensores de IR del kit de robótica de Bq, no tienen un diodo a la salida del pin de signal que impida el paso de corriente del pin al circuito. Por ello, al cometer un error en el montaje, lo conecté a una salida PWM del arduino que en ese momento estaba encendida, con lo que me cargue el sensor y no era capaz de detectar el cambio de color.

Ahora que he podido sustituirlo ya he terminado la primera versión del renacuajo para que siga lineas. La programación es muy sencilla, y lo explica José Luis V en su post.

Lo siguiente que quiero hacer es implementar la programación de los sensores y del propio regulador para seguir las lineas en la librería del miniskybot y su programación sea tan sencilla como ejecutar una función. Cuando los exámenes me den tregua empezaré a programarlo.

Sigue lineas renacuajoBot

RenacuajoBot

El primer robot que han diseñado desde BQ para usar el kit de robótica, ha sido renacuajoBot. Este fin de semana he aprovechado para imprimirme una versión e ir haciendo pruebas.

2014-01-05 23.42.18La primera cosa que he probado han sido los servos conectado a la placa y probar su correcto funcionamiento. Las pruebas han sido estar cambiando la dirección del servo de una manera un tanto brusca, de esta manera, y debido a los picos de corriente, la placa se resetea y no funciona correctamente. Quizás si se alimentarán los servos de forma independiente a la de la placa el correcto sería el correcto. Por este motivo, y si están los servos conectados, la placa falla a la hora de subir el programa, es necesario subir el programa sin tener los servos conectados.

Captura de pantalla 2014-01-06 a la(s) 22.41.18

He estado modificando la librería de Obijuan y David Estevez que programaran para el miniskybot. De esta manera le he añadido la opción de añadir los servos de  rotación continua que se incluyen en el kit.

He tenido un problema al hacer las conexiones y he conectado uno de los sensores IR a una salida de la placa, y creo que se ha estropeado, los sensores no tienen ningún diodo para evitar que en el pin de signal le introduzcamos una tensión. Por eso, y como solo tengo un sensor IR, he programado el robot para evitar que se caiga de la mesa. A ver si consigo arreglarlo o cambiarlo por otro y lo programo para seguir lineas.

He colgado en mi github la librería con la actualización para los servos. Es una primera versión muuy primeriza, iré actualizando en cuanto pueda con el resto de sensores y actuadores que vienen incluidos en el kit.

RenacuajoBot