Procesado de Lenguaje Natural

Anuncio
Procesado de Lenguaje Natural
Fernando Muñoz del Nuevo
Ingeniería de telecomunicaciones
Universidad Carlos III
Av. De la Universidad, 30
28911 Leganés (Madrid)
100047355@alumnos.uc3m.es
RESUMEN
El siguiente artículo expone el estado actual del procesado del
lenguaje natural y los mecanismos a través de los cuales la
inteligencia artificial es capaz de interactuar con un humano y
no dar sensación de ser una máquina.
Términos Generales
Algoritmos, Lenguaje, Etiquetas,
Sintáctico, Diagrama de Flujo.
Análisis
Morfológico,
Palabras Clave
AIML, PLN, Árboles de Decisión, XML.
1. INTRODUCCIÓN
El ser humano desde que tiene conciencia siempre ha tenido
necesidad de compañía, por ello no es extraño que siempre
haya intentado dotar de vida a lo que le rodea. En éste caso, se
está llegando al punto de crear robots con forma humana, que
se comporten como los humanos y por último que sean capaces
de mantener conversaciones coherentes.
Como se puede observar en la figura 1 los robots han llegado a
un nivel de parecido con el ser humano muy importante.
El procesado del lenguaje natural por el contrario está más lejos
del parecido que se muestra en la imagen. Aún nos
encontramos con las dificultades propias del lenguaje, de la
comprensión del mismo y de las múltiples interpretaciones que
puede tener en función de los diferentes significados de las
palabras dependiendo del contexto en que se encuentren.
La historia del procesado del lenguaje natural (PLN) comienza
cuando a finales de los años cuarenta se comenzó a proponer
sistemas de traducción automática. Dichos sistemas entre los
cuarenta y cincuenta fracasaron debido a la falta de capacidad
de procesamiento en comparación con la complejidad del
lenguaje, posteriormente en los años setenta y ochenta se logra
un nivel aceptable de traducción automática pasando los
objetivos del PLN a los campos de interfaces en lenguaje
natural y procesamiento de textos.
2. OBJETIVOS Y DIFICULTADES
Las interfaces en lenguaje natural pretenden poder dar órdenes
a ordenadores y robots mediante el propio lenguaje ya sea
hablado o escrito de tal modo que personas que por su
casuística no pueden dar órdenes mediante interfaces gráficas lo
puedan hacer a través de la voz o un teclado. Esto tiene mucha
importancia para las personas con discapacidades físicas que no
les permiten ver o actuar con las manos sobre un terminal.
El procesamiento de textos es importante porque la mayor
cantidad de información de la humanidad se encuentra en textos
con la consiguiente importancia de acceder a lo que se desea en
el menor tiempo posible, por ello, un procesado de textos bueno
nos permitirá tener toda la información de cualquier cosa que
deseemos si esta existe.
La traducción automática es uno de los problemas más antiguos
con una gran importancia puesto que de un buen o mal
traductor dependen muchas cosas en determinados ámbitos.
Las dificultades con las que se debe lidiar en el PLN son
importantes y por ello aún no tenemos un PLN perfecto que nos
permita abordar todos los casos anteriormente expuestos.
La dificultad principal es que el lenguaje natural es localmente
ambiguo, y ésta ambigüedad es la que impide un PLN eficaz.
Un ejemplo es la palabra inglesa hit la cual tiene diferentes
significados a partir del contexto:
Figura 1: Andy, robot humanoide femenina.
He hit the nail with the hammer Golpear
The car swerved and hit the tree Chocar
The soldier fired and hit the target Acertar
Por lo tanto el único modo de conocer el significado de la
palabra es a partir del contexto, el cual hay que acotar,
identificar el significado de las demás palabras y reconocer el
significado de la palabra objetivo.
Por otro lado, si lo que se está pretendiendo es buscar
información acerca de algo en concreto, por ejemplo un paro
cardíaco habrá que buscar información no sólo de paros
cardíacos sino también acerca de fallos del corazón,
enfermedades del corazón y demás búsquedas relacionadas para
encontrar la mayor cantidad de información posible.
Además de la ambigüedad léxica existe la ambigüedad
referencial y la ambigüedad estructural. La primera tiene lugar
cuando se utilizan pronombres o sintagmas nominales concisos
para hacer referencia a objetos o eventos descritos previamente.
En estos casos, el sistema de PLN debe determinar la entidad
lingüística previa a que hacen referencia estas anáforas. La
segunda es aún más frecuente; el caso más claro de este tipo de
ambigüedad es el de la ambigüedad en el nivel de dependencia
de los sintagmas preposicionales.
Además a veces se cae en constantes repeticiones y poca
variedad de respuestas que hace aburrida y poco atractiva la
experiencia, por lo tanto el sistema debe tener una gran base de
datos de posibles combinaciones de respuestas y en un
siguiente paso de complejidad, sería muy importante que
pudiera aprender expresiones del usuario para ser mucho más
cercano.
En busca de la generación correcta del lenguaje, los lingüistas
desarrollaron las gramáticas que describen las estructuras
correctas de cada lenguaje (lo que aún complica más el asunto
teniendo en cuenta la gran cantidad de lenguajes y dialectos
existentes en el mundo. Dichas estructuras se representan en
árboles como el que se muestra a continuación:
Todas estas dificultades son las que debe resolver un sistema de
PLN que pretenda dar una sensación de realidad al usuario.
3. COMPONENTES DE UN PLN
Un PLN se compone de la realización de las siguientes tareas:
•
•
•
•
•
•
Análisis Morfológico: Análisis de las palabras para extraer
raíces, rasgos flexivos, unidades léxicas compuestas y
otros fenómenos.
Análisis sintáctico: El análisis de la estructura sintáctica de
la frase mediante una gramática de la lengua en cuestión.
Análisis semántico: La extracción del significado de la
frase, y la resolución de ambigüedades léxicas y
estructurales.
Análisis pragmático: El análisis del texto más allá de los
límites de la frase, por ejemplo, para determinar los
antecedentes referenciales de los pronombres.
Planificación de la frase: Estructurar cada frase del texto
con el fin de expresar el significado adecuado.
Generación de la frase: La generación de la cadena lineal
de palabras a partir de la estructura general de la frase, con
sus correspondientes flexiones, concordancias y restantes
fenómenos sintácticos y morfológicos.
Todas estas tareas deben realizarse paralelamente para obtener
un resultado adecuado porque si esto se realizara mediante un
flujo continuado concatenando dichas operaciones el resultado
no sería adecuado.
Figura 2: Ejemplo de árbol de gramática inglesa para
la oración “The little boy ran quickly”.
A partir de ésta forma de representación introducimos el
sistema de etiquetado para expresar mediante un lenguaje la
gramática y así un ordenador sea capaz de expresarse. Esto nos
lleva al lenguaje AIML.
4. ARTIFICIAL INTELLIGENCE
MARKUP LANGUAGE (AIML)
AIML se desarrolló desde 1995 hasta 2000 por parte de Dr.
Richard Wallace y la comunidad de código abierto Alicebot. Es
un lenguaje basado en XML que es sencillo de aprender y
permite crear en poco tiempo una entidad parlante.
Las partes más importantes del lenguaje son:
•
•
•
•
<aiml>: Es un tag que indica el comienzo de un trozo de
código AIML.
<category>: Identifica una unidad de conocimiento.
<pattern>: Identifica un patrón concreto de una
determinada oración.
<template>: Contiene la respuesta a una determinada
entrada del usuario.
Un ejemplo de una arquitectura de un PLN es el siguiente:
Un ejemplo de un código en AIML es el siguiente:
El usuario le expresa al ordenador sus deseos.
La computadora analiza las oraciones proporcionadas.
Se realiza el análisis pragmático del texto y proporciona una
respuesta final.
<category>
<pattern>WHAT ARE YOU</pattern>
<template>
<think><set name="topic">Me</set></think>
I am the latest result in artificial intelligence,
which can reproduce the capabilities of the human brain
with
greater
speed
and
accuracy.
</template>
</category>
El siguiente paso que se debe analizar para comprender la
dificultad a la que nos exponemos es la de la generación del
lenguaje, ya sean textos o voces.
No podemos pensar que simplemente por fuerza bruta se puede
resolver el problema, hay que tener en cuenta el uso de
pronombres, sinónimos, palabras adecuadas en determinados
contextos y una jerga concreta para dar una experiencia
adecuada al usuario.
Éste es un ejemplo del tipo de respuesta que daría el robot en
caso de detectar un patrón que le pregunte por qué es.
La completa definición del lenguaje se encuentra en la
referencia bibliográfica [7].
4.
Uno de los problemas más comunes en la identificación
del lenguaje son los errores de escritura o las
contracciones, un ejemplo de ello es en el inglés “your”
que en la mayoría de los casos se traduciría por “you’re” o
“you are” por lo tanto no todas las ocurrencias se traducen
por lo mismo. Para ello debe buscarse algo de contexto, el
cuál se codifica así.
En cualquier caso, un pequeño resumen de los modos de
actuación en AIML son los siguientes:
1.
Reducción Simbólica
Consiste en reducir expresiones complejas a expresiones
más simples que coincidan en significado, por ejemplo, la
reducción de ¿Sabes quién es Zapatero? a ¿Quién es
Zapatero? Se trata de dos oraciones con el mismo
significado pero con formaciones distintas por lo tanto se
produce a identificar oraciones largas en patrones más
cortos de tal modo que sea más sencillo su tratamiento
posterior.
<category>
<pattern>YOUR A *</pattern>
<template>I think you mean "you’re" or "you are" not
"your."
<srai>YOU ARE A <star/></srai>
</template>
</category>
<category>
<pattern>DO YOU KNOW WHO * IS</pattern>
<template><srai>WHO IS <star/></srai></template>
</category>
En éste caso el programa corregiría la ambigüedad para
adaptarse a lo correcto.
5.
2.
Palabras Clave
Divide y Vencerás
Frecuentemente debemos activar un trozo de código
cuando aparece determinada palabra que corresponde a
unas determinadas acciones muy particulares. El siguiente
ejemplo se incluyó por primera vez en ELIZA
Una oración que se componga de dos sub-oraciones como
por ejemplo cualquiera que se componga de una
afirmación y un posterior comentario a dicha información
se puede dividir en dos de tal modo que se analicen por
separado y así conseguir una mejor experiencia.
<category>
<pattern>MOTHER</pattern>
<template> Tell me more about your family. </template>
</category>
<category>
<pattern>YES *</pattern>
<template><srai>YES</srai> <sr/></template>
</category>
3.
Deletreado y Correción Gramática.
<category>
<pattern>_ MOTHER</pattern>
<template><srai>MOTHER</srai></template>
</category>
Sinónimos
AIML no permite más de un patrón por categoría, por lo
tanto para integrar sinónimos (una de las aplicaciones más
usadas del lenguaje) se hace del siguiente modo:
<category>
<pattern>HELLO</pattern>
<template>Hi
</category>
<category>
<pattern>MOTHER _</pattern>
<template><srai>MOTHER</srai></template>
</category>
there!</template>
<category>
<pattern>_ MOTHER *</pattern>
<template><srai>MOTHER</srai></template>
</category>
<category>
<pattern>HI</pattern>
<template><srai>HELLO</srai></template>
</category>
<category>
<pattern>HI
THERE</pattern>
<template><srai>HELLO</srai></template>
</category>
<category>
<pattern>HOWDY</pattern>
<template><srai>HELLO</srai></template>
</category>
<category>
<pattern>HOLA</pattern>
<template><srai>HELLO</srai></template>
</category>
En el primer caso detectamos la categoría y aplicamos la
regla general, en la segunda categoría tenemos la palabra
como sufijo y aplicamos la regla de distinta forma.
6.
Condicionales
Existe la posibilidad de utilizar condicionales para en
función de la proveniencia de la frase responder con reglas
distintas.
<category>
<pattern>WHO IS HE</pattern>
<template><srai>WHOISHE<getname="he"/></srai></te
mplate>
</category>
<category>
<pattern>WHOISHE *</pattern>
<template>He is <get name="he"/>.</template>
</category>
<category>
<pattern>KNOCK KNOCK</pattern>
<template>Who is there?</template>
</category>
<category>
<pattern>WHOISHE UNKNOWN</pattern>
<template>I don’t know who he is.</template>
</category>
7.
<category>
<pattern>*</pattern>
<that>WHO IS THERE</that>
<template><person/> who?</template>
</category>
Targeting
El targeting es el proceso mediante el cual el bot aprende
en relación con las conversaciones que tiene con el usuario
y el creador del bot. La mejor manera de exponer el
proceso es el siguiente ejemplo:
<category>
<pattern>*</pattern>
<that>* WHO</that>
<template>Ha
ha
very
name="name"/>.</template>
</category>
User: Where do I find the webpage with Australopithecus?
Alice: Where do you want to find it?
funny,
<get
User: Bad Answer Alice, time to Learn a new Line
Produce el siguiente diálogo:
Alice: How would you answer "Where do I find the
webpage with Australopithecus?"
C: Knock knock.
R: Who’s there?
C: Banana.
R: Banana who?
C: Knock knock.
R: Who’s there?
C: Banana.
R: Banana who?
C: Knock knock.
R: Who’s there?
C: Orange.
R: Orange who?
C: Orange you glad I didn’t say banana.
R: Ha ha very funny, Nancy.
User: I would say:
"http://www.ancientskulls.net/australopithecus.html"
Alice: Thanks, human. Try asking me again.
User: Where do I find the webpage with Australopithecus?
Alice: http://www.ancientskulls.net/australopithecus.html
De éste modo se muestra cómo enseñar al bot a responder
de acuerdo a las preguntas realizadas por el usuario.
Este escenario por supuesto tiene muchas interrogantes
como qué ocurriría si se dejara éste proceso de aprendizaje
abierto a los usuarios y el peligro de que Hackers crearan
respuestas con contenidos inadecuados y demás ataques.
8.
La palabra clave “that” en AIML se refiere a la última
referencia del robot, en caso de tener una respuesta de
múltiples oraciones, “that” se refiere a la última frase.
Un ejemplo es el siguiente:
R: Today is yesterday.
C: That makes no sense.
R: The answer is 3.1412926 approximately.
C: That is cool.
<category>
<pattern>YES</pattern>
<that>DO YOU LIKE MOVIES</that>
<template>What is your favorite movie?</template>
</category>
Esta categoría se active cuando el cliente dice YES. El
robot intenta saber a qué está diciendo YES, si la pregunta
es ¿Te gustan las películas? La categoría coincidirá y la
respuesta ¿Cuál es tu película favorita? será la que
continúe la conversación por parte del bot.
Una aplicación interesante de éstas categorías es que
permite al robot responder a determinadas bromas:
9.
Estructura “Topic”
La estructura “Topic” nos permite adoptar diferentes
preguntas y respuestas en función de un tema concreto de
tal manera que cuando se converse acerca de una
determinada cuestión, la respuesta pueda ser distinta:
topic name="CARS">
<category>
<pattern>*</pattern>
<template>
<random>
<li>What’s your favorite car?</li>
<li>What kind of car do you drive?</li>
<li>Do you get a lot of parking tickets?</li>
<li>My favorite car is one with a driver.</li>
</random>
</template>
En éste caso el bot respondería aleatoriamente entre alguna
de las cuestiones anteriores en cuanto detecte el tema
coches.
A partir de todos los patrones anteriores y aplicando las
técnicas anteriormente expuestas podemos desarrollar un bot
que de cierta sensación de inteligencia respondiendo
adecuadamente a un gran número de cuestiones.
Un ejemplo de diagrama de flujo atendiendo a los anteriores conceptos es el siguiente:
Figura 3: Diagrama de flujo del sistema de respuesta del bot utilizando AIML
5. EL CEREBRO DE ALICE
Si hacemos una representación neuronal de los árboles de
decisión que puede tener el ALICE tenemos diferentes
imágenes en función de los programas que tengan cargados que
nos muestra el desarrollo de su “cerebro”.
Figura 4: Cerebro de ALICE de 24000 categorías con
factor de podado de primera categoría de 2000 y de
segunda categoría de 2. [9]
Figura 6: Cerebro de ALICE mostrado en espiral.
Las zonas con mayor cantidad de hojas representan
las relaciones con las palabras Quién, Dónde, Qué,
Cuándo… [9]
6. ESTADO ACTUAL DE DESARROLLO
DE BOTS
En la actualidad se está desarrollando una gran cantidad de bots
entre los cuales se encuentran los siguientes con sus respectivas
direcciones para informarse.
Proyecto: Pandorabots
URL: http://www.pandorabots.com
Director: Dr. Doubly Aimless
Información Adicional: Free web based bot hosting
Figura 5: ¼ del cerebro de ALICE correspondiente a
Srai.aiml. Cerca de 2000 patrones. [9]
Proyecto: Oddcast, Inc.
URL: http://www.oddcast.com
Director: Adi Sideman, CEO
Información Adicional: Vhost animated avitars with AIMC
Proyecto: Media Semantics / HostABot.com
URL: http://www.mediasemantics.com
Director: Doug Copeland
Información Adicional: Flash characters and AIML engine
URL: http://www.monigarr.com
Director: Monica Peters
Información Adicional: develops chatbots to learn and teach
any language
Proyecto: AIML Scripting Resourcee
URL: http://www.aiml.info
Director: Anne Kootstra
Información Adicional: Articles, links and downloads
Proyecto: Shadowbots
URL: http://www.shadowbots.com/
Director: Karen Gibbs
Información Adicional: Eggdrop TCL scripts to publish ALICE
bots on TalkCity (formerly Dawnhosting.com/bots)
Proyecto: Aitools
URL: http://www.aitools.org
Director: Noel Bush
Información Adicional: Program D downloads and info
Proyecto: Artificial Intelligence Nexus
URL: http://www.knytetrypper.com/ain.html
Director: Richard Gray
Información Adicional: Link site for Alicebots
Proyecto: J-Alice
URL: http://j-alice.sourceforge.net/
Director: Jonathan Roewen
Información Adicional: Program J: AIML in C++ with IRC
client
Proyecto: AIMLPad
URL: http://www.aimlpad.com
Director: Gary Dubuque
Información Adicional: Program N: AIML in C++ with
extensions for MSAgent and more
Proyecto: PASCALice and AIML Tools
URL: http://www.sweb.cz/alicebot/
Director: Kim Sullivan
Información Adicional: Program P: AIML in Pascal and
Shadowchecker
Proyecto: Program E
URL: http://sourceforge.net/projects/programe/
Director: Sean Elias, Anne Kootstra, Paul Rydell
Información Adicional: AIML in PHP
Proyecto: Virtualitas
URL: http://www.virtualitas.net/perl/aiml/
Director: Ernest Lergon
Información Adicional: Program V: AIML in Perl in Apache
environment
Proyecto: Pyaiml
URL: http://pyaiml.sourceforge.net/
Director: Cort Stratton
Información Adicional: Program Y: AIML in Python
Proyecto: AimlBot
URL: http://www.windowpane.com/alice/
Director: Conan Callen
Información Adicional: allows VB developers to create new
front ends and applications
Proyecto: CyN
URL: http://www.daxtron.com/123start.htm?Cyn
Director: Kino Coursey
Información Adicional: merger of AIML with the OpenCyc
inference engine
Proyecto: Onkwehonwehneha A.I.
Proyecto: Searchers: Ask?
URL: http://www.searchers.com/ask/
Director: Kym Kinlin
Información Adicional: Intelligent NLP Search Engine based
on AIML and
Haptek
Proyecto: VirtualFem
URL: http://www.virtualfem.com/
Director: Mike, Developer
Información Adicional: This site contains adult-oriented
material
Proyecto: Charliebot
URL: https://sourceforge.net/projects/charliebot/
Director: Josip Almasi
Información Adicional: based on ALICE, ANNA v7.0, and
Program D
Proyecto: Robot-Hosting
URL: http://www.robot-hosting.com
Director: Tom Davies, Marketing Director
Información Adicional: V-bots use AIML, Haptek chacters, and
other systems
Proyecto: Intellibuddy
URL: http://www.intellibuddy.com/
Director: Rami Mayron, Chief Executive Officer
Información Adicional: uses Oddcast Vhosts
Proyecto: TrillAlice
URL: http://www.estmatic.net/category/trillalice/
Director: Esteban Aparicio, Project Director
Información Adicional: AIML plugin for Trillian IM
Proyecto: The Bot Factory
URL: http://www.thebotfactory.com/
Director: Tom Delanoy
Información Adicional: Flash interfacce with lip synch
Proyecto: ChatterBean
URL: http://chatterbean.bitoflife.cjb.net/
Director: Helio Perroni Filho
Información Adicional: Java AIML interpreter
Proyecto: libaiml
URL: http://omicron.at4x.net/
Director: Omicron
Información Adicional: C++ AIML interpreter
Entre los chatbots de aficionados y grupos universitarios de
desarrollo se realiza un torneo, éste torneo tiene como premio el
“Loebner Prize” que sería de 100000 $ para el ganador si éste
es totalmente indistinguible de un humano en una conversación
larga. A ésa máquina se podrá decir que “piensa”, aunque de
momento ninguno ha ganado dicha medalla, el premio de
bronce se da a la mejor de las máquinas presentadas. Los
últimos ganadores son los siguientes:
2000 Richard Wallace (ALICE)
2001 Richard Wallace (ALICE)
2002 Kevin Copple
2003 Juergen Pirner
2004 Richard Wallace (ALICE)
2005 Rollo Carpenter
2006 Rollo Carpenter
2007 Robert Medeksza
2008 Fred Roberts and Artificial Solutions
2009 David Levy
de necesidades humanas a través de robots con una
comprensión del lenguaje cercana a la que un humano tiene.
Aunque todavía falta mucho para lograr el robot que piensa, si
podemos decir que el aprendizaje del lenguaje verbal es cada
vez mayor y su perfeccionamiento nos abrirá un nuevo nivel en
lo que a IA se refiere.
De momento, el robot más desarrollado del mundo es Albert
Hubo.
7. APLICACIONES Y CONCLUSIONES
Las aplicaciones en las que puede ser útil además del mero
disfrute de tener una máquina que sea capaz de responder
coherentemente a cualquier pregunta son las siguientes:
7.1 Personas discapacitadas.
Los desarrollos de sistemas de reconocimiento de voz y habla
basados en la AIML pueden ser muy útiles para que personas
con algún tipo de discapacidad física puedan relacionarse con
una máquina que les facilite su vida dentro de su casa, o fuera
de la misma. Un ejemplo sería el caso de un invidente en su
casa pudiera preguntar al robot central de la casa si llueve o no,
si hay algún obstáculo en su camino (todo esto combinado con
otro tipo de AI no explicadas en este artículo).
Otro ejemplo sería el caso de una persona de movilidad
reducida que pudiera haber tenido algún incidente lejos del
teléfono, simplemente hablando con el robot podría ponerse
éste en contacto con emergencias para recibir ayuda
convenientemente.
7.2 Coducción de vehículos
Puesto que gestionar un GPS con las manos mientras se
conduce está prohibido y es peligroso, un bot que tuviera un
buen reconocimiento verbal e interpretara adecuadamente las
frases del conductor podría perfectamente orientar al conductor
siendo interpelado por éste de tal modo que encuentre su
destino sin necesidad de desviar la mirada de la carretera.
También puede ser útil para otro tipo de controles como
intermitentes, limpiaparabrisas, la radio, DVD de los asientos
traseros y demás interacciones que distraen de la conducción.
Además, el ordenador podría a través de nuestras órdenes
verbales conectarse a la información del tráfico para corregir la
trayectoria y encontrar el trayecto más adecuado sin necesidad
de soltar las manos del volante.
Además de éstas aplicaciones, en función del desarrollo y
perfeccionamiento del lenguaje que sean capaces de alcanzar
los robots podremos llegar a utilizarlos para reducir la
sensación de soledad en personas con tendencia a la depresión,
robots que reaccionen instantáneamente y de forma adecuada a
las órdenes de sus dueños/jefes y demás aplicaciones que
podrían parecernos de ciencia ficción.
7.3 Conclusiones
A modo de conclusiones se puede decir que la IA en éste
campo está en pleno desarrollo y pretende cubrir una gran parte
Figura 7: Albert Hubo, el robot más avanzado hasta
el momento.
Sus funciones lingüísticas están desarrolladas y se puede ver un
video de presentación en el link a continuación:
http://hubolab.kaist.ac.kr/index.php
8. REFERENCIAS
[1] http://upload.wikimedia.org/wikipedia/commons/1/16/A
ctroid-DER_01.jpg
[2] http://cvc.cervantes.es/obref/congresos/sevilla/tecnologi
as/ponenc_carbonell.html
[3] http://es.wikipedia.org/wiki/Procesamiento_de_lenguaje
s_naturales
[4] http://www.monografias.com/trabajos17/lenguajenatural/lenguaje-natural.shtml
[5] http://es.wikipedia.org/wiki/AIML.html
[6] http://www.alicebot.org/aiml.html
[7] http://alicebot.org/TR/2005/WD-aiml/WD-aiml-1.0.1008.html
[8] http://www.pandorabots.com/pandora/pics/wallaceaimlt
utorial.html
[9] http://www.alicebot.org/documentation/gallery/
[10] http://alicebot.org/TR/2005/WD-aiml/WD-aiml-1.0.1008.html
[11] http://en.wikipedia.org/wiki/Albert_Hubo
Descargar