Download Entorno Java para simulación y control de robots móviles 1

Document related concepts
no text concepts found
Transcript
Entorno Java para simulación y control de robots
móviles1
Miguel Ángel Lozano Ortega, Ignacio Iborra Baeza, Domingo Gallardo López
Grupo de Visión, Gráficos e Inteligencia Artificial
Departamento de Ciencia de la Computación e Inteligencia Artificial
Universidad de Alicante
Carretera San Vicente, s/n
03690 – San Vicente del Raspeig, Alicante
e-mail: domingo@dccia.ua.es
Resumen: En este trabajo se describe un entorno Java de simulación y programación
de robots móviles basado en la arquitectura Saphira. El entorno permite la comunicación cliente-servidor de una aplicación cliente realizada en Java tanto con un servidor
Saphira (bien sea un simulador, o un robot real conectado por un puerto serie), como
con un simulador 3D propio realizado en Java. También se describe la forma de programar los robots mediante este entorno, así como un conjunto de librerías de apoyo
que se proporcionan junto con el entorno, y un ejemplo se programa realizado para
ejecutar sobre un robot.
Palabras clave: Robots autónomos, Programación de robots, Simulador de robots
1 Introducción
Para la investigación y el desarrollo de software para robots autónomos es muy importante contar con un entorno de simulación lo más real posible, así como con un software
de alto nivel que permita ocultar las problemáticas de bajo nivel de los dispositivos robóticos. Sin embargo, muchas veces es necesario también poder modificar características de bajo nivel para, por ejemplo, añadir nuevos dispositivos o modificarlos. Es por
1
En la dirección http://www.dccia.ua.es/jmr se encuentra disponible el entorno descrito en este
trabajo, junto con documentación detallada.
Miguel Ángel Lozano, Ignacio Iborra, Domingo Gallardo
ello fundamental contar con un sistema de control y simulación abierto, portable, escalable y reusable.
JMR (Java Mobile Robots) es un entorno Java diseñado para cumplir estas características. Proporciona un completo software de simulación de robots basado en una arquitectura cliente-servidor, que permite estudiar el comportamiento de uno o varios robots sobre un mundo o entorno definido. El sistema dispone de una aplicación cliente,
sobre la que se cargan los robots que se desea probar, y de una aplicación servidor que
se encarga de llevar un control de los robots conectados, actualizar su situación en el
mundo que se haya especificado, y proporcionar al cliente los datos que se soliciten.
Se persiguen con este entorno dos objetivos fundamentales: uno es definir una interfaz de comunicación de Java con la librería Saphira de control de robots [6]. De este
modo, es posible conectar el sistema al simulador de robots de Saphira (Pioneer) y también a los robots reales que se gestionen con dicha librería. Conviene resaltar aquí la
modificabilidad y escalabilidad que permite Java [4], y que hace posible la adaptación
del programa a muchas otras librerías de control de robots. También sería muy sencillo
definir distintos interfaces Web para controlar el robot, facilitando la implementación de
este tipo de sistemas [8,9].
El otro objetivo que se persigue es proporcionar un sistema propio de simulación,
escalable y fácilmente portable, que permita sencillas modificaciones o actualizaciones
del mismo. La estructura de Java permite definir un esqueleto básico sobre el que ir
modificando o ampliando características de forma sencilla, añadiendo nuevas clases que
extiendan o sobreescriban a las anteriores. De esta forma, además de la comunicación
con Saphira, se dispone de un sistema auto-integrado, que permite la prueba de robots y
procesos sobre el mismo sin necesidad de ningún programa adicional, mediante un simulador 3D propio.
Para todo lo anterior, se ha desarrollado un programa cliente-servidor que permite la
gestión de robots, así como algunas librerías auxiliares, algunas de las cuales son utilizadas por dichos programas, y otras facilitan la elaboración de procesos en los robots
por parte del usuario.
2 Descripción del entorno
Como se ha comentado anteriormente, el entorno está basado en una arquitectura cliente-servidor, cuyo funcionamiento, a grandes rasgos, se pasa a explicar a continuación.
2.1 El cliente
En la parte cliente de la aplicación se tiene un programa para manejar los distintos
robots que queramos conectar. El programa está preparado para soportar varios robots
CAEPIA 2001
Entorno Java para simulación y control de robots móviles
simultáneamente (aunque si se está comunicando con Saphira, sólo se permitirá uno,
por las limitaciones de Saphira), y se conseguiría con ello el mismo efecto que lanzando
varias aplicaciones cliente, una por cada robot.
El cliente dispone de controles para elegir a qué servidor conectarse (actualmente, al
simulador Java, al simulador Saphira, o a un robot real a través de Saphira por un puerto
serie dado), indicando la dirección donde se encuentra el servidor. Esto permite comunicar con un servidor situado en una máquina remota, conociendo su dirección IP.
Además, se permite añadir y quitar robots del servidor, y llevar un control de los datos de cada robot (lecturas de sónares, estado actual, parámetros de configuración, imagen de la cámara, etc). En la figura 1 podemos ver el aspecto de la aplicación.
Figura 1. Aspecto de la aplicación cliente
2.2 El servidor
En la parte del servidor, se distingue entre el servidor Java y el servidor Saphira.
El servidor Java implementa un simulador que permite monitorizar la situación del
mundo, mediante distintas cámaras virtuales colocadas en él o la situación particular de
cada robot mediante su propia cámara virtual (ver figura 2).
CAEPIA 2001
Miguel Ángel Lozano, Ignacio Iborra, Domingo Gallardo
Figura 2. Cámaras virtuales del simulador, situadas en el mundo (derecha) y en el robot (izquierda).
Además, cuenta con métodos para obtener los datos de cada robot en cada instante:
detección de colisiones con obstáculos mediante cálculo de intersecciones, toma de lecturas de los sónares, captura de imágenes mediante un dispositivo de tipo cámara, y toma de otros datos de interés, como puedan ser estimaciones de posición mediante otro
tipo de dispositivos, filtrado o procesado de imágenes, etc.
Dentro del servidor Saphira se englobarían tanto la conexión con el simulador Pioneer como la conexión con un robot real a través de un puerto serie utilizando Saphira.
Este tipo de servidor no dispone de ninguna aplicación visual de monitorización, sino
simplemente de un programa que se deja ejecutando y permite la comunicación con Saphira. Para poder comunicar con las funciones de Saphira, se ha empleado JNI (Java
Native Interface), una herramienta de Java que permite ejecutar código escrito en otros
lenguajes de programación.
Se ha minimizado en la medida de lo posible la parte de tratamiento del robot que
hace Saphira, dejando únicamente el reflector de estado, del que tomar los datos del
robot, y utilizando algunas funciones para tomar datos y establecer velocidades. Lo que
se pretende es dejar que se gestionen todas las estructuras desde Java, y utilizar la API
de Saphira para obtener los datos y enviar los comandos básicos de movimiento (velocidad lineal y rotacional) al robot.
Para la comunicación de ambas aplicaciones (cliente y servidor), se ha empleado la
tecnología RMI (Remote Method Invocation), una tecnología Java que permite ejecutar
remotamente comandos de otra máquina, y permitir así la comunicación en sistemas
distribuidos.
Por una parte, se tendrá el servidor que se haya elegido (Java o Saphira), ejecutando
en una máquina. Dicho servidor estará escuchando por un puerto determinado, a la espera de solicitudes de conexión de distintos clientes.
CAEPIA 2001
Entorno Java para simulación y control de robots móviles
Por otra parte, se tendrá cada uno de los clientes que se quieran lanzar, que podrán
estar en la misma máquina que el servidor o en máquinas distintas. En el cliente, se indicará la dirección en la que se encuentra el servidor, y todos los robots que se generen
se conectarán con dicha dirección.
Se establecerá así una conexión por cada robot que se añada en la aplicación cliente,
que será gestionada de forma independiente. Una vez establecida la conexión, el cliente
podrá solicitar datos del robot al servidor ejecutando comandos remotos en el mismo
(toma de lecturas de sónares, toma del estado actual, establecimiento de la velocidad del
robot, etc).
3 Programación del robot
Existen múltiples propuestas de arquitecturas de control y programación de robots móviles [1,2,7,10]. En el diseño de JMR hemos seguido la propuesta de Saphira, enriqueciéndola con las posibilidades de manejo de concurrencia que proporciona Java.
En la librería robots se proporcionan distintos métodos de control del robot. Los
clientes podrán controlar el robot mediante el control directo, utilizando comandos de
bajo nivel, mediante conductas, mediante actividades, o mediante combinación de cualquiera de los métodos anteriores.
3.1 Procesos
Los procesos son fragmentos de código que pueden ser ejecutados en el entorno con el
fin de controlar el robot. Como características generales, es posible especificar su prioridad, su timeout, pudiendo ser iniciados concurrentemente con quien les llama o bloqueando al llamador. Pueden encontrarse en uno de los siguientes estados: inicial,
ejecutando, suspendido, detenido o finalizado. Se definen dos subclases de procesos:
actividades y conductas.
3.2 Conductas
Todas las conductas definidas se ejecutan concurrentemente de forma síncrona, accediendo a las variables que definen el estado del robot y modificando el comportamiento
del mismo según el estado leído.
Cuando tengamos varias conductas activas, cada una de ellas podrá estar fijando un
movimiento distinto para el robot. En este caso, el movimiento que se establecerá en el
robot se calculará combinando los resultados de todas las conductas. Para obtener este
movimiento, se facilita la creación de un sistema difuso, aunque se da libertad para utilizar cualquier otro método.
CAEPIA 2001
Miguel Ángel Lozano, Ignacio Iborra, Domingo Gallardo
3.3 Actividades
Las actividades son procesos concurrentes y asíncronos. A diferencia de las conductas,
no se activan todas de forma síncrona, sino que, de forma procedural, se pueden enviar
comandos de movimiento al robot, leer datos de su estado, o invocar otras actividades o
conductas.
3.4 Coordinación de conductas y actividades
Se dispone de un manejador de robots, que se encarga de invocar y coordinar actividades y conductas. La forma en la que se combinan los resultados de las distintas conductas puede ser modificada por el cliente, definiendo subclases de la clase principal que
especializan su comportamiento, creando así distintos manejadores de robots.
Este manejador de robots mantiene el estado del robot, de manera que cualquier proceso podrá obtenerlo de él sin tener que realizar una conexión con el robot.
3.5 Librería de robots
Esta librería incluye las interfaces que tendrán los robots, y los dispositivos asociados a
ellos, clases que encapsulan el estado y datos del robot, y clases para la creación de distintos procesos y manejador de robots. Además incluye clases de apoyo para visión.
3.6 Visión
Se tiene un módulo dedicado a tratar el problema del procesado de imágenes en el robot. Se definen en él estructuras de datos que permitan al servidor enviar al cliente información sobre la imagen que está viendo en cada momento el robot, y se han definido
las estructuras de determinados métodos que se emplearán para procesar y obtener imágenes.
Además, se ha definido un puente que comunica las imágenes que puedan captarse y
procesarse con la herramienta Javavis desarrollada también en el Departamento de
Ciencia de la Computación e Inteligencia Artificial de la Universidad de Alicante [3],
de modo que se pueden emplear los diversos filtros y funciones que se han desarrollado
para dicha librería, y aplicarlos para procesar imágenes en el servidor y enviarlas al
cliente.
3.7 Dispositivos
Puede ser útil (e incluso necesario) tener la posibilidad de definir dispositivos sobre el
robot, elementos que actúen en el servidor, procesando determinados datos, y proporcionando mecanismos para que el cliente pueda adquirir dichos datos procesados. Un
CAEPIA 2001
Entorno Java para simulación y control de robots móviles
ejemplo puede ser la cámara que pueda tener el robot. Conviene disponer de un mecanismo que permita definir la cámara, y poder visualizar así en el cliente las imágenes
que capture el robot.
Pero no sólo se trata de dispositivos físicos, como puedan ser una cámara, una pinza,
o cualquier otro elemento, sino también dispositivos lógicos, como fragmentos de código que preprocesen información en el servidor para ponerla a disposición del cliente
cuando lo requiera. Por ejemplo, aplicar un algoritmo para determinar en qué posición
puede estar el robot, o un procesado de imágenes que también permita especular sobre
dicha posición mediante razonamiento probabilístico.
4 Otras librerías desarrolladas
Se han implementado una serie de librerías que, bien serán utilizadas por las aplicaciones para algunas tareas auxiliares, bien permitirán al usuario definir procesos y programas Java de forma sencilla. A continuación se comentan brevemente.
4.1 Librería para desarrollo de entornos gráficos: robotGUI
La librería robotGUI se desarrolló para facilitar la elaboración de aplicaciones visuales
como el propio cliente. Dispone de una serie de controles específicos que puedan resultar interesantes para el control de robots (formados a base de controles Java Swing
agrupados), tales como paneles de imágenes, listas de parámetros, etc.
Se ha empleado esta misma librería para construir la propia aplicación cliente, de
forma que también puede servir de ejemplo de uso para construir otras aplicaciones similares.
4.2 Librería geométrica: javaGL
La librería javaGL contiene una serie de elementos geométricos que facilitan el tratamiento de objetos del mundo en que se mueve el robot, así como del propio robot. Dispone de objetos tales como líneas, segmentos, círculos, puntos, posiciones, que permiten definir, entre otras cosas, los límites de los muros del mundo, las dimensiones del
robot, la posición del mismo, etc.
Se emplea sobre todo en la parte del simulador Java para obtener aproximaciones 2D
del mundo 3D que se tiene representado, mantener listas de segmentos para obtener intersecciones (y ver con ellas si el robot ha colisionado, o determinar las lecturas de los
sónares, etc), definir posiciones, y otras funcionalidades.
CAEPIA 2001
Miguel Ángel Lozano, Ignacio Iborra, Domingo Gallardo
4.3 Librería de lógica difusa: fuzzy
La librería fuzzy contiene un conjunto de clases que permiten emplear lógica difusa en
el comportamiento del robot, así como en otras tareas que se quieran realizar. Dispone
de elementos para poder definir variables difusas, conjuntos difusos, elaborar reglas
difusas que obtengan una serie de consecuentes a partir de unas entradas determinadas
para sus antecedentes, etc.
4.4 Librería probabilística: prob
La librería prob se ha definido para mantener, además de una librería para control mediante lógica difusa (la librería fuzzy vista en el punto anterior), una librería que permite
control mediante razonamiento probabilístico, basada en la propuesta de Thrun [11].
Además, proporciona ayuda a la hora de realizar determinadas tareas, como generación
de datos aleatorios siguiendo una determinada distribución de probabilidades, etc.
Uno de los aspectos más interesantes de la librería es la implementación de una versión genérica del algoritmo CONDENSATION (CONditional DENSity propagATION)
[5], un algoritmo que permite realizar un seguimiento en el tiempo de una función de
densidad genérica, posiblemente multimodal, mediante la disposición de un conjunto de
muestras en el espacio objeto de estudio, y la evaluación de la probabilidad de cada
muestra. Con este algoritmo genérico, se podrán estimar distintas variables que describen el estado del robot, como por ejemplo localizar un robot en un pasillo, evaluar la
posición del robot en función de la imagen que capta, etc.
5 Programa de ejemplo
El siguiente código fuente presenta un ejemplo de una actividad, FollowRoute, en la
que se planifica un recorrido del robot. En ella se define un constructor, en el que se
inicializa el vector de puntos de control que determina el recorrido y se sobrescribe el
método execute() con el comportamiento de la actividad. En este comportamiento
se activa la conducta AvoidCollision y se va llamando a la conducta GoToPos
conforme vamos recorriendo el vector de puntos de control.
Tabla I. Ejemplo de un programa de control.
package user.processes;
public class FollowRoute extends Activity
{
Vector points;
CAEPIA 2001
Entorno Java para simulación y control de robots móviles
public FollowRoute(String pFile)
{
super("FollowRoute", -1, false, false);
setBlock(false);
points = new Vector();
points.addElement(new Point2D(1000.0, 1000.0));
points.addElement(new Point2D(2000.0, 1000.0));
points.addElement(new Point2D(3000.0, 4000.0));
}
public void execute() throws InterruptedException
{
Point2D p;
AvoidCollision ac = new AvoidCollision(200,800,200,800);
GoToPos go;
execute(ac);
for(int i=0;i<points.size();i++)
{
p = (Point2D)points.elementAt(i);
go = new GoToPos((int)p.getX(), (int)p.getY(), 100);
execute(go);
}
ac.setState(RobotProcess.iSTOPPED);
}
}
6 Conclusiones y trabajos futuros
Se ha presentando un entorno de simulación y control de robots móviles basado en la
arquitectura Saphira y desarrollado en Java. El entorno proporciona un sistema abierto
con el que poder definir aplicaciones cliente-servidor de control de robots. Tanto el servidor como el simulador pueden ser ampliados y modificados fácilmente atendiendo a
las necesidades del sistema robótico a implementar. Por ejemplo, si se incorpora un
nuevo dispositivo al robot, es muy sencillo añadir en el servidor el controlador Java para el nuevo dispositivo, así como definir la interfaz de acceso desde el cliente.
Se ha presentado también la arquitectura de clases que permite definir clientes que
manejan el robot utilizando procesos, conductas y actividades, así como un conjunto de
librerías de apoyo que se proporcionan junto con el entorno.
Como trabajo futuro estamos preparando la coordinación de JMR como un proyecto
de código abierto en el que, al estilo Linux, la comunidad robótica y de visión artificial
pueda incorporar al entorno nuevas funcionalidades.
CAEPIA 2001
Miguel Ángel Lozano, Ignacio Iborra, Domingo Gallardo
Bibliografía
[1]
R. C. Arkin. Integrating behavioral, perceptual and world knowledge in reactive
navigation. Robotics and Autonomous Systems, Vol. 6. 1990.
[2]
M. Beetz. Structured reactive controllers-a computational model of everyday
activity. En Proc. of the Third International Conf. on Autonomous Agents, 1999.
[3]
M. Cazorla. Javavis – Librería de procesamiento de imágenes en Java.
http://www.dccia.ua.es/~miguel/JavaVis/start.htm
[4]
Bruce Eckel. Thinking In Java. Prentice Hall, 1998.
[5]
M. Isard y A. Blake. CONDENSATION -- conditional density propagation for
visual tracking. International Journal on Computer Vision, Vol. 29, No. 1, pp. 528. 1998
[6]
K. Konolige y K. Myers K. The Saphira Architecture for Autonomous Mobile
Robots. En D. Kortenkamp, P. Bonasso y R. Murphi (Eds.), Artificial Intelligence and Mobile Robots, pp. 211-242. AAAI Press/MIT Press. 1998.
[7]
D. McDermott. A reactive plan language. Research Report YALEU/DCS/RR864, Yale University, 1991.
[8]
D. Schulz, W. Burgard, A.B. Cremers, D. Fox, y S. Thrun. Web interfaces for
mobile robots in public places. IEEE Magazine on Robotics and Automation,
Vol. 7, No. 1, pp. 48-57, Marzo 2000.
[9]
R. Siegwart and K. Goldberg (eds). Robots on the Web. IEEE Magazine on Robotics and Automation (special issue), Vol. 7, No. 1, March 2000.
[10]
R. Simmons, J. Fernandez, R. Goodwin, S. Koenig, J. O'Sullivan. Xavier: An
Autonomous Mobile Robot on the Web. IEEE Robotics and Automation Magazine, Vol. 7, No. 2, pp. 33-39, Junio 2000.
[11]
S. Thrun. A Framework for Programming Embedded Systems: Initial Design
And Results. Informe Técnico Carnegie Mellon University, Octubre 1998.
CAEPIA 2001