Tema 2 Sistemas Basados en Reglas - Grupo de Inteligencia Artificial

Transcripción

Tema 2 Sistemas Basados en Reglas - Grupo de Inteligencia Artificial
II. Razonamiento con conocimiento preciso
Tema 2
Sistemas Basados en Reglas
Sistemas Basados en el Conocimiento
Grado en Ingeniería Informática
–1–
Razonamiento con conocimiento preciso
Tema 2. Sistemas Basados en Reglas
• 
• 
• 
Descripción
CLIPS
Ejemplos
Tema 3. Repaso de Lógica
Tema 4. Web Semántica y Web de Datos
–2–
Referencias
• 
• 
• 
• 
Inteligencia Artificial — Métodos y Técnicas.
D. Borrajo, N. Juristo, V. Martínez-Orga, J. Pazos.
Editorial Centro de estudios Ramón Areces. 1997
Sistemas expertos representación e inferencia problemas resueltos.
A. Fernández. Dykinson (URJC). 2010
Problemas resueltos de inteligencia artificial aplicada: búsqueda y
representación.
Fernández, S.; González, J.; Mira, J. Addison-Wesley Iberoamericana. 1998.
Ingeniería del Conocimiento. Aspectos Metodológicos.
A. Alonso, B. Guijarro, A. Lozano, J. T. Palma, M. J. Tabeada.
Pearson Prentice Hall. 2004
CLIPS:
•  Sistemas expertos: principios y programación (3ª ed.).
J. Giarratano, G. Riley, G. Editorial. Thompson Ed. 2001.
•  CLIPS Reference Manual (CLIPS 6.1). http://clipsrules.sourceforge.net/
•  JESS in Action: Rule-based systems in Java. Friedman-Hill, E. Manning. 2003.
–3–
Sistemas Basados en Reglas
DEFINICIÓN
conjunto de sentencias en un LRC
mecanismo de inferencia automática
<BH,BR,MI>
BASE DE HECHOS
MOTOR DE INFERENCIA
(Memoria de trabajo)
Representa conocimientos sobre el
problema:datos, hechos establecidos
y metas a alcanzar
Razona con el conocimiento del
problema y sobre su solución
Determina cómo se aplican las reglas
BASE DE REGLAS
Representa conocimientos sobre la solución
del problema en forma de producciones
–4–
Base de Hechos
•  Hechos:
– 
– 
– 
– 
estructuras de datos: aserciones sobre objetos/situaciones etc.
representamos hechos como listas de símbolos
pueden concebirse como relaciones entre entidades
ejemplo: (ladra perro), (on A B)
•  Base de hechos (BH):
–  representa el modelo del mundo (o el problema en curso de solución)
–  cambia con el proceso de inferencia
–  Estado inicial: situación inicial
–  Estado final: situación final
–  Estado intermedio: situación actual o en curso de resolución
–  ejemplo BH:
(bloque A)
(bloque B)
(on A B)
(on B T)
(clear A)
–5–
Base de Hechos
Partes de la BH:
•  permanente: hechos invariantes
–  describen características que siempre se dan en el problema
–  Ejemplo: (bloque A) (bloque B) (clear T)
•  temporal: hechos variantes
–  cambian durante el proceso de la solución del problema
–  Ejemplo: (on A B) (on B T) (clear A)
Modificación de la BH:
•  añadir hechos a la BH
•  borrar hechos de la BH
–6–
Base de Reglas
Regla:
•  Representa una parte del conocimiento sobre la solución del problema
•  Sintaxis: SI <Premisas> ENTONCES <Acciones>
“Antecedente, LHS”
•  Ejemplo Regla R1:
“Consecuente, RHS”
SI (hombre Socrates)
ENTONCES añadir(mortal Socrates)
•  Semántica:
–  Si todas las premisas se encuentran en la BH, se pueden ejecutar todas las acciones
sobre la BH
–  Ej.: Si (hombre Socrates) se encuentra en la BH, se puede añadir (mortal Socrates) a
la BH
Base de Reglas (BR):
•  conjunto de reglas: agrupa el conocimiento sobre la solución del problema
•  La BH describe el problema, la BR da información para resolverlo
–7–
Base de Reglas
Reglas con variables:
•  premisas y acciones pueden contener constantes (p.e. A,
ladra, on) o variables (p.e. ?x)
•  Ejemplos:
–  Regla R2: SI (hombre ?x) ENTONCES añadir(mortal ?x)
–  Regla R3: SI (padre ?x ?y) (padre ?y ?z)
ENTONCES añadir(ancestro ?x ?z)
Semántica:
•  Una variable puede ligarse con cualquier constante de un hecho en la
misma posición
•  Una variable ha de ligarse al mismo valor en toda la regla
Nótese:
•  sólo las reglas pueden contener variables, no los hechos
•  cualquier variable del consecuente ha de ligarse anteriormente en el
antecedente
–8–
Motor de inferencia
•  Mecanismo automático que permite contestar consultas a partir de una BC
basada en reglas
•  Dos posibles estrategias de inferencia para BC basadas en reglas
–  Encadenamiento hacia delante (inglés: forward chaining)
Soluciones
intermedias
BH inicial
Consulta
(BH final)
BR
–  Encadenamiento hacia atrás (inglés: backward chaining)
Objetivo
(Consulta)
Subobjetivos
BR
BH inicial
–9–
Soluciones
Motor de Inferencia
Mecanismo de encadenamiento hacia delante:
•  a partir de la BH1 se procura deducir una BHn en la que se cumple la consulta
•  “disparando” sucesivamente las reglas Ri de la BR
•  cada disparo de una regla caracteriza un ciclo de razonamiento CCk
BH1
R1
R2
...
Rm
CC1
BH2
Ri
...
Rj
CC2
CC n-1
– 10 –
BHn-1
BHn
Rk
Ciclo de Inferencia
Paso 1:
Detección de reglas aplicables
(determinación del conjunto conflicto)
Paso 2:
Selección de una regla aplicable
(resolución del conjunto conflicto)
Paso 3:
Aplicación de una regla y
actualización de la BH
(disparo de la regla)
– 11 –
Ciclo de Inferencia: Detección de reglas aplicables
Equiparación:
• 
Selección del conjunto de reglas candidatas para dispararse, las que son
compatibles con la BH (instancias de reglas aplicables o activadas)
BH
(enfermedad Pepe pulmón) (enfermedad ?persona corazón)
(enfermedad Juan corazón)
(enfermedad María corazón)
(enfermedad Juan corazón), ?persona=Juan
(edad Pepe 18)
(enfermedad María corazón), ?persona=María
Conjunto conflicto:
• 
todas las (instancias de) reglas que son aplicables en el presente ciclo
• 
puede haber varias instancias de la misma regla en el conjunto conflicto
– 12 –
Ciclo de Inferencia: Selección de una regla aplicable
Estrategias de selección:
•  Establecer un orden de preferencia en la aplicación de las reglas
•  Preferencia basada en las reglas
– 
– 
– 
– 
prioridad explícita: asignar valores de prioridad a cada regla
prioridad implícita: orden de de las reglas en la BR (Prolog)
refracción: historia de una regla (la más/menos disparada)
especificidad: preferir la reglas con más/menos condiciones
•  Preferencia basada en las instancias de reglas
–  la más antigua en el conjunto conflicto (estrategia de amplitud)
–  la más nueva en el conjunto conflicto (estrategia de profundidad)
•  Preferencia basada en objetos
–  selección de reglas que se aplican a los objetos más recientes
–  prioridad explícita: asignación de prioridades a los patrones más comunes
de la BH
•  Combinaciones de las diferentes preferencias
– 13 –
Ciclo de Inferencia: Aplicación y actualización de la BH
“Disparo” de la instancia de regla seleccionada:
•  Se ejecutan todas las acciones del consecuente de la (instancia de)
regla
•  se modifica la BH actual dando lugar a una BH nueva al añadir y
borrar elementos de la primera
•  La BH nueva se tomará como punto de partida en el siguiente ciclo de
funcionamiento (por tanto es posible que algunas reglas han de
eliminarse del antiguo del conjunto conflicto!)
Parada del mecanismo de inferencia:
•  cuando no hay más reglas aplicables en el conjunto conflicto
•  cuando el consecuente de una regla ejecuta un comando de parada
(regla de terminación, puede codificar la consulta)
– 14 –
Ejemplo de inferencia hacia adelante en BC de reglas
CONSULTA: ¿(perro Tucky)?
BASE DE HECHOS BH1
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
BASE DE REGLAS
Regla R1:
SI (animal ?A)
(esqueleto ?A si)
ENT añadir (vertebrado ?A)
Motor de inferencia
Regla R2:
SI
(animal ?A)
(esqueleto ?A no)
ENT añadir (invertebrado ?A)
Ciclo1
R1,?A=Tucky
R1,?A=Piolín
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
(vertebrado Tucky)
Regla R3:
SI
(vertebrado ?A)
(ladra ?A)
ENT añadir (perro ?A)
– 15 –
Ejemplo de inferencia hacia adelante en BC de reglas
BASE DE HECHOS BH2
CONSULTA: ¿(perro Tucky)?
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
(vertebrado Tucky)
BASE DE REGLAS
Regla R1:
SI (animal ?A)
(esqueleto ?A si)
ENT añadir (vertebrado ?A)
Motor de inferencia
Ciclo2
Regla R2:
SI
(animal ?A)
(esqueleto ?A no)
ENT añadir (invertebrado ?A)
R1,?A=Tucky
R1,?A=Piolín
R3, ?A=Tucky
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
(vertebrado Tucky)
(vertebrado Piolín)
Regla R3:
SI
(vertebrado ?A)
(ladra ?A)
ENT añadir (perro ?A)
– 16 –
Ejemplo de inferencia hacia adelante en BC de reglas
BASE DE HECHOS BH3
CONSULTA: ¿(perro Tucky)?
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
(vertebrado Tucky)
(vertebrado Piolín)
BASE DE REGLAS
Regla R1:
SI (animal ?A)
(esqueleto ?A si)
ENT añadir (vertebrado ?A)
Motor de inferencia
Ciclo3
Regla R2:
SI
(animal ?A)
(esqueleto ?A no)
ENT añadir (invertebrado ?A)
R1,?A=Tucky
R1,?A=Piolín
R3, ?A=Tucky
(animal Tucky)
(animal Piolín)
(esqueleto Piolín si)
(esqueleto Tucky si)
(ladra Tucky)
(vertebrado Tucky)
(vertebrado Piolín)
(perro Tucky)
Regla R3:
SI
(vertebrado ?A)
(ladra ?A)
ENT añadir (perro ?A)
– 17 –
BASE DE HECHOS BH4
Ciclo de Inferencia: Aspectos de Implementación
Problema:
•  Ineficiencia del mecanismo de inferencia debido a la fase 1
(determinación del conjunto conflicto)
•  en cada ciclo se equiparan todas las reglas con todos los elementos de
la MT para construir el nuevo conjunto conflicto
Solución: Algoritmo de Redundancia Temporal (RETE)
•  se construye el conjunto conflicto de forma incremental
Cambios en la MT
Red RETE
Cambios en el CC
•  La red RETE se genera al principio de la ejecución del sistema de
producción mediante un compilador.
– 18 –
RETE (Redundancia Temporal)
•  Red de nodos (RETE)
•  En cada ciclo de funcionamiento, las acciones modifican
Memoria de Trabajo (inclusión o borrado)
•  En cada ciclo, no es necesario equiparar todas las reglas
con todos los elementos de la MT
•  La red RETE se genera al principio mediante un
compilador
– 19 –
RETE: Ejemplo
•  Compartir partes comunes
•  Ej.:
¿es 1º una a?
–  R7: SI (a b ?x) (c ?x d e ?y) ENT ...
–  R8: SI (a b ?x) (c ?x d f ?y) ENT ...
¿es 1º una c?
¿es 3º una d?
¿es 2º una b?
¿es 4º una e?
¿es 4º una f?
Nodo de unión si
3º izda = 2º dcha
Nodo de unión si
3º izda = 2º dcha
Informar de
cambios en R7
Informar de
cambios en R8
– 20 –
Diseño de BCs: Errores frecuentes
Una regla NO es una estructura “if-then-else”
SI condicion1
condicion2
...
ENTONCES
acciones1
EN CASO CONTRARIO
acciones2
¿QUÉ HACER?
•  Identificar las condiciones que no se cumplen para la
ejecución de las acciones2
•  Crear dos reglas, una para cada bloque de acciones
– 21 –
Diseño de BCs: Errores frecuentes
No pueden aparecer OR en el consecuente de la regla
SI condicion1
condicion2
...
ENTONCES
acciones1 OR acciones2
¿QUÉ HACER?
•  Crear dos reglas, una para cada bloque de acciones
–  para conservar la precedencia, p.e. establecer prioridades entre las reglas
Ri: SI condicion1
condicion2...
ENTONCES acciones1
Rj: SI condicion1
condicion2...
ENTONCES acciones2
– 22 –
Diseño de BCs: Errores frecuentes
En el consecuente de la regla NO hay elementos de decisión
SI condicion1 , condicion2 ...
ENTONCES
acciones1
SI condicion4 ...
ENTONCES
acciones2
¿QUÉ HACER?
•  Introducir señalizadores que provoquen la ejecución prioritaria de
reglas con tales elementos
•  No olvidar borrar los señalizadores
Ri: SI condicion1 , condicion2 ...
ENTONCES acciones1
añadir S
– 23 –
Rj: SI S, condicion4 ...
ENTONCES acciones2
borrar S
Diseño de BCs: Errores frecuentes
Desde una regla nunca se puede lanzar otra regla
Ri: SI condicion1
condicion2
...
ENTONCES
Rj
¿QUÉ HACER?
•  Introducir señalizadores que provoquen la ejecución de Rj
•  No olvidar borrar los señalizadores al ejecutar la regla Rj
– 24 –
Diseño de BCs: Errores frecuentes
BR
Regla R1:
SI (envio ?e ?origen ?destino)
(dia-entrega ?e hoy)
(coste ?e ?coste)
ENTONCES
añadir(coste ?e ?coste+10)
BH (envio E1 Madrid Barcelona)
Motor de inferencia
Ciclo1
?e=E1
?origen=Madrid
?destino=Barcelona
?coste=7
(dia-entrega E1 hoy)
(coste E1 7)
BH (envio E1 Madrid Barcelona)
ERROR: El coste del envío es único
SOLUCIÓN: Modificar la regla
– 25 –
(dia-entrega E1 hoy)
(coste E1 7)
(coste E1 17)
Diseño de BCs: Errores frecuentes
BR
Regla R1:
SI (envio ?e ?origen ?destino)
(dia-entrega ?e hoy)
(coste ?e ?coste)
ENTONCES
borrar (coste ?e ?coste)
añadir (coste ?e ?coste+10)
BH (envio E1 Madrid Barcelona)
Motor de inferencia
Ciclo1
?e=E1
?origen=Madrid
?destino=Barcelona
?coste=7
(dia-entrega E1 hoy)
(coste E1 7)
BH
PROBLEMA: Bucle infinito
SOLUCIÓN:
•  Introducir señalizadores,
•  Utilizar nuevo hecho (coste-final)
– 26 –
(envio E1 Madrid Barcelona)
(dia-entrega E1 hoy)
(coste E1 7)
(coste E1 17)
Características de la Representación del Conocimiento
•  Ventajas
–  Representación próxima a la forma de proceder de los expertos
–  Sintaxis simple y homogénea
–  Permite seguimiento del proceso de deducción
•  Inconvenientes
–  Conocimiento procedimental y heurístico
•  Dificultad para verificar la consistencia de la BC
– 27 –
Sistemas Basados en Reglas
Tema 2. Sistemas Basados en Reglas
• 
• 
• 
Descripción
CLIPS
Ejemplos
...
– 28 –
Qué es CLIPS
•  CLIPS (C Language Integrated Production System):
–  herramienta para desarrollar sistemas inteligentes basadas en reglas
–  desarrollada en C/ANSI por Software Technology Branch, NASA/Lyndon B.
Johnson Space Center desde 1986
–  implementación eficiente del encadenamiento hacia delante
•  Facilidades adicionales
– 
– 
– 
– 
diferentes estrategias de resolución de conflictos
adición dinámica de reglas
sistema de mantenimiento de verdad
lenguaje orientado a objetos: COOL (Clips Object-Oriented Language)
•  Extensiones:
– 
– 
– 
– 
fácilmente embebible en aplicaciones en C, FORTRAN, Java, ...
disponible en diversas plataformas (MS-DOS/Windows, Unix)
extensiones para Lógica Borrosa (FuzzyCLIPS)
JESS: versión en Java que usa el sistema de objetos correspondiente
– 29 –
Sistemas Basados en Reglas
Tema 2. Sistemas Basados en Reglas
1.  Descripción
2.  CLIPS
1.  Base de Hechos
2.  Base de Reglas
3.  Motor de Inferencia
3.  Ejemplos
…
– 30 –
CLIPS: Base de Hechos
Terminología
•  La BH en CLIPS se llama memoria de trabajo (MT)
•  puede contener diferentes tipos de hechos
Hechos ordenados (“ordered facts”)
•  Patrones con uno o varios campos
–  la posición de la información en el hecho es relevante
–  información tipada: símbolos, integers, real, string, etc.
–  sintaxis acostumbrada
•  Ejemplos:
(hola)
(alumnos Pepe Juan Luis)
(nombre "Juan")
(edad 14)
(pi 3.1415)
– 31 –
CLIPS: Base de Hechos
Patrones no-ordenados (deftemplate)
•  Permiten definir la información en forma de clases de elementos y
atributos de esas clases.
•  Permiten abstraer la estructura de un hecho asignando un nombre a
cada campo
–  campos slot: pueden tener exactamente un valor
–  campos multislot: pueden tener varios valores (de varios tipos)
•  Se permite una cadena de caracteres como comentario (opcional)
•  Ejemplo: (deftemplate clase
"Informacion sobre clases"
(slot grupo)
(slot aula)
(slot hora)
(multislot alumnos)
(multislot profesor))
– 32 –
CLIPS: Base de Hechos
Hechos no-ordenados (“unordered facts”, “deftemplate facts”)
• 
• 
• 
• 
• 
hechos que “instancian” los patrones deftemplate
el primer nombre del hecho no-ordenado referencia su deftemplate
el orden de los campos no tiene importancia
se pueden omitir slots del patrón deftemplate
Ejemplo:
(cliente
(cliente
(clase
(nombre Juan Pérez)
(id 33435))
(id 33435)
(nombre Juan Pérez))
(aula "III-002")
(profesor Alberto Fernández)
(alumnos))
– 33 –
CLIPS: Base de Hechos
Hechos iniciales:
•  los hechos iniciales, se definen con la estructura deffacts
–  ejemplo1:
(deffacts hechos-600
“información del 600”
(modelo 600)
(puertas 2) )
–  ejemplo2:
(deffacts OtrosHechos
(cliente (nombre Juan Pérez) (id 33435))
(cliente (nombre Rosa Gómez) (id 33436)) )
•  por defecto existe el hecho inicial (initial-fact)
•  los hechos iniciales se añadirán a la MT al hacer reset
– 34 –
CLIPS: Base de Hechos
Indices de hechos (etiquetas temporales, time-tags)
•  CLIPS genera para cada hecho un índice relativo al tiempo de su creación:
–  Al primer hecho creado le corresponde la etiqueta temporal 0 :
f-0 (initial-fact)
–  Ejemplo: Si (ladra perro) es el segundo hecho añadido a la MT, su
etiqueta temporal el f-1
–  Nunca disminuye y nunca se reasigna. Para cada nuevo hecho que se cree o
modifique se incrementa en uno
•  Sirven para
–  Identificar de forma única y simplificada cada hecho
–  Saber el tiempo que lleva un hecho en la memoria de trabajo
– 35 –
CLIPS: Base de Hechos
Ordenes básicas de manejo de la MT
(facts)
Lista los hechos de la MT
(assert <hecho>) Añade (si no existe) un hecho a la MT
(retract <indice-hecho>) Elimina un hecho de la MT
(modify <indice-hecho> <slot>*)
Modifica un hecho (no ordenado) de la MT
•  (duplicate <indice-hecho> <slot>*)
Como modify pero sin borrar el antiguo
•  (clear)
Elimina todos los hechos y construcciones de la MT
•  (reset)
Elimina todos los hechos de la MT, elimina las activaciones
de la agenda y restaura las condiciones iniciales:
• 
• 
• 
• 
Añade initial-fact
–  Añade el conocimiento inicial definido con deffacts
–  Añade las variables globales con su valor inicial
–  Fija como módulo principal el módulo MAIN
– 
– 36 –
CLIPS: Base de Hechos
Ejemplo:
CLIPS> (reset)
CLIPS> (retract 1)
CLIPS> (facts)
CLIPS> (assert (hola))
f-0 (initial fact)
<Fact-2>
For a total of 1 fact.
CLIPS> (facts)
CLIPS> (assert (hola))
f-0 (initial-fact)
<Fact-1>
f-2 hola
CLIPS> (facts)
For a total of 2 facts.
f-0 (initial-fact)
CLIPS> (clear)
f-1 hola
CLIPS> (facts)
For a total of 2 facts.
CLIPS>
– 37 –
Sistemas Basados en Reglas
Tema 2. Sistemas Basados en Reglas
1.  Descripción
2.  CLIPS
1.  Base de Hechos
2.  Base de Reglas
3.  Motor de Inferencia
3.  Ejemplos
…
– 38 –
CLIPS: Base de Reglas
Sintaxis
Ejemplo
(defrule marca-del-600
(defrule <nombre_regla>
"Marca del modelo 600"
[<documentacion opcional>]
(modelo 600)
[<caracteristicas op.>]
=>
(premisa 1)
(assert (marca-es SEAT))
(premisa 2)
)
...
(premisa N)
Semántica
=>
•  Si “se cumplen” todas las premisas
(accion 1)
•  Se ejecutan todas las acciones
(accion 2)
...
(accion M)
)
– 39 –
CLIPS: Base de Reglas
Elementos de las premisas
•  Patrones
–  existencia / ausencia de hechos en la BH
–  pueden instanciar variables a partir de hechos
•  Restricciones
–  restricciones como premisas (tipo test)
–  restricciones de variables (conectivas)
– 40 –
CLIPS: Base de Reglas
•  Patrones: Constantes
–  equiparación con hechos concretos en la MT
–  Ejemplos:
(defrule encontrar-dato
(dato 1 azul rojo)
=>)
(defrule encontrar-Roberto
(persona (nombre Roberto) (edad 20))
=>)
– 41 –
CLIPS: Base de Reglas
Equiparación de patrones constantes
•  Caso a: Hechos ordenados
BR
(defrule R1
(A B)
=> (assert (C D))
MT
f-1
f-2
(A B)
(C D)
1 equiparación
Conjunto Conflicto={R1(f-1)}
La ejecución de la regla introduce en la MT a (CD)
•  Caso b: hechos no ordenados
BR
(defrule R1
(clase1 (nombre1 A))
=> (assert (C D))
MT
f-1(clase1
(nombre1 A))
f-2(C D)
1 equiparación
Conjunto Conflicto={R1(f-1)}
La ejecución de la regla introduce en la MT a (CD)
– 42 –
CLIPS: Base de Reglas
•  Patrones: Comodines
–  patrones genéricos que equiparan con diferentes hechos
–  se usan cuando no importa el valor de un campo
•  ? :
Equipara con un campo
•  $? : Equipara con cero a n campos
•  Ejemplos:
(defrule encontrar-dato
(dato ? azul rojo $?)=>)
(defrule encontrar-dato
(dato $? amarillo $?)=>)
– 43 –
CLIPS: Base de Reglas
•  Equiparación con comodines
–  cada par hecho-comodín puede dar lugar a una instanciación
–  Ejemplo:
BR
(defrule R1
(A $? B)
=>...
MT
f-1
f-2
f-3
3 equiparaciones de la misma regla
Eq1: $?=
Eq2: $?=3
Eq3: $?= C E B
(A B)
(A 3 B)
(A C E B B)
Conjunto Conflicto:
{R1(f-1),R1(f-2),R1(f-3)}
–  Un comodín repetido puede tener valores diferentes
– 44 –
CLIPS: Base de Reglas
•  Patrones: Variables
–  patrones genéricos que equiparan con diferentes hechos
–  almacenan valores de campos para usarlos posteriormente
•  ?x : variable de valor único
•  $?x : variable multivalor (cero, uno o más valores)
•  Ejemplos:
(defrule encontrar-dato
(dato ?x ?y ?z)=>)
(defrule encontrar-dato
(dato ?x $?y ?z)=>)
– 45 –
CLIPS: Base de Reglas
•  Equiparación con variables
–  Una variable que aparece dos o más veces en la regla debe
equipararse en todas las ocurrencias con el mismo valor
BR
(defrule R1
(animal ?x)
(piel pelo ?x)
=>
(assert (especie mamifero ?x))
MT
f-1
f-2
f-3
f-4
f-5
(animal Tucky)
(piel pelo Dolly)
(piel pelo Tucky)
(animal Dolly)
(animal Dumbo)
Eq1: ?x=Tucky : (animal Tucky) (piel pelo Tucky)
Eq2: ?x=Dolly : (animal Dolly) (piel pelo Dolly)
Dumbo no equipara por no tener (piel pelo Dumbo) en la MT
Conjunto Conflicto = { R1(f-1,f-3), R1(f-4,f-2) }
– 46 –
CLIPS: Base de Reglas
Patrones: Ausencia de patrones
•  Sintaxis: (not (<patron>))
•  la premisa se cumple, si no hay ningún hecho en la MT
que equipara con <patron>
•  Ejemplo:
(defrule volar
(pajaro ?x)
(not (avestruz ?x))
=>
(assert (vuela ?x))
)
•  Hipótesis del mundo cerrado:
–  todo lo que no se encuentra en la MT es “falso”
– 47 –
CLIPS: Base de Reglas
•  Equiparación basada en la ausencia de patrones
–  Ejemplo:
(defrule R1
(A ?x)
(not (B ?x))
=> )
MT: (A C) (B D) (A B) (A A) (B A)
Eq1: ?x=C
Eq2: ?x=B
?x=A no equipara porque en la MT está (B A)
– 48 –
CLIPS: Base de Reglas
Patrones: Direcciones de hechos (referencia a la MT):
•  se pueden almacenar referencias a los hechos de la MT en variables
•  dichas referencias pueden ser usadas en las acciones de consecuente
•  Ejemplo
(defrule matrimonio
?ref-soltero <- (soltero ?nombre)
=>
(retract ?ref-soltero)
(assert (casado ?nombre))
)
– 49 –
Premisas de las Reglas CLIPS: Restricciones
Restricciones de premisa:
•  premisa del tipo (test (<expresión booleana>))
•  forma más general para comprobar el cumplimiento de una condición
•  Expresiones booleanas se construyen en notación prefija sobre:
–  Funciones de comparación
•  Numérica: =, <>, <, >, >=, <=
•  Cualquier tipo: eq, neq
–  Funciones lógicas: or, not, and
–  Funciones de predicado: stringp, numberp, symbolp...
•  Ejemplo: (defrule mes-valido
(entrada ?mes)
(test (and (>= ?mes 1)
(<= ?mes 12) ) )
=>)
– 50 –
Premisas de las Reglas CLIPS: Restricciones
Restricciones conectivas (connective constraints) :
•  limitan la posibilidad de equiparación de variables
•  restricciones conectivas con constantes:
–  Sintaxis: ?x&˜<valor>
–  Semántica:?x equipara con cualquier valor menos <valor>
–  ejemplos
(defrule no-rojo-ni-verde
(color ?x&~rojo&~verde)
=>)
(defrule no-rojo-ni-verde-test
(color ?x)
(test (neq ?x rojo verde))
=>)
(defrule datos-distintos
(dato ?x ?y&~?x)
=>)
(defrule datos-distintos-test
(dato ?x ?y)
(test (neq ?x ?y))
=>)
– 51 –
Premisas de las Reglas CLIPS: Restricciones
Restricciones conectivas de resultado (return value constraints)
•  Sintaxis: ?x&=(<expresion>)
•  Semántica:
–  ?x equipara sólo con el valor que resulta de evaluar <expresion>
–  <expresion> puede ser de cualquier tipo (i.e. se aplica eq)
•  Ejemplos:
(defrule mas-una
(dato ?x ?y&=(+ ?x 1))
=>)
(defrule mas-una-test
(dato ?x ?y)
(test (= ?y (+ ?x 1)))
=>)
(defrule segundo-elemento
(lista $?l)
(valor ?x&=(nth$ 2 $?l))
=>)
(defrule segundo-elemento-test
(lista $?l)
(valor ?x)
(test (eq ?x (nth$ 2 $?l)))
=>)
– 52 –
Premisas de las Reglas CLIPS: Restricciones
Restricciones conectivas de predicado (predicate constraints)
•  Sintaxis: ?x&:(<expr.booleana>)
•  Semántica:
–  ?x equipara con cualquier valor si sólo si <expr.booleana> es true
–  <expr.booleana> también suele contener variables
•  Ejemplos:
(defrule valor-numerico
(valor ?x&:(numberp ?x))
=>)
(defrule valor-numerico-test
(valor ?x)
(test (numberp ?x))
=>)
(defrule dos-o-mas
(lista $?y&:(> (length$ ?y) 2))
=>)
(defrule dos-o-mas-test
(lista $?y)
(test (> (length$ ?y) 2))
=>)
– 53 –
Acciones de las Reglas CLIPS
• 
• 
• 
• 
• 
Modificar MT: assert, retract, modify, duplicate
Entrada/Salida: printout, read, readline, open, close
Parada del proceso de inferencia: halt
Asignar valores a variables (en el consecuente): bind
Ejemplo:
(defrule coste-del-envio
(envio ?paquete ?origen ?destino)
(dia-entrega ?paquete hoy)
?coste-inicial<-(coste ?paquete ?precio)
=>
(retract ?coste-inicial)
(bind ?suplemento (read))
(bind ?nuevo-precio (+ ?precio ?suplemento))
(assert (coste-final ?paquete ?nuevo-precio))
(printout t "Coste final es " ?nuevo-precio crlf)
(halt)
)
– 54 –
Funciones predefinidas en CLIPS
Funciones de predicado
Funciones campos multislot Funciones matemáticas
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
• 
numberp
floatp
integerp
lexmep
stringp
symbolp
evenp
oddp
multifieldp
eq
neq
=, <>, >, >=, <, <=
or, not, and
create$
nth$
member$
subsetp
delete$
explode$
implode$
subseq$
replace$
insert$
first$
rest$
– 55 –
• 
• 
• 
• 
• 
+, -, *, /, div
max, min
abs
float
integer
Se pueden definir más funciones al
estilo LISP con deffunction
(ver manual)
(deffunction aplicar (?op ?e1 ?e2)
(switch ?op
(case + then (+ ?e1 ?e2))
(case - then (- ?e1 ?e2))
(case * then (* ?e1 ?e2))
(case / then (/ ?e1 ?e2))
(default error)
)
)
Sistemas Basados en Reglas
Tema 2. Sistemas Basados en Reglas
1.  Descripción
2.  CLIPS
1.  Base de Hechos
2.  Base de Reglas
3.  Motor de Inferencia
3.  Ejemplos
…
– 56 –
CLIPS: Motor de inferencia
•  Algoritmo de selección de reglas aplicables en CLIPS
1. elegir la regla aplicable con máxima prioridad
2. elegir regla según estrategia de resolución de conflictos
3. elegir de forma arbitraria
•  Definir prioridades en CLIPS
–  asignar un valor de prioridad (entero positivo o negativo) a cada regla
–  se definen como propiedades de reglas
–  por defecto su valor es 0
(defrule marca-del-600
"Marca del modelo 600"
(declare (salience 10))
(modelo 600)=> (assert (marca-es SEAT)))
–  recomendación: minimizar el uso de prioridades de reglas
– 57 –
Motor de inferencia: Estrategias de resolución del CC
Estrategias de resolución de conflictos (I):
•  Depth Strategy (estrategia por defecto)
–  Una activación más reciente se sitúa por encima de las activaciones con
igual o mayor antigüedad
•  Breadth Strategy
–  Una activación más reciente se sitúa por debajo de las activaciones con
igual o mayor antigüedad
•  Complexity Strategy
–  Las nuevas activaciones se sitúan por encima de las activaciones con
igual o menor especificidad
•  Simplicity Strategy
–  Las nuevas activaciones se sitúan por encima de las activaciones con
igual o mayor especificidad
– 58 –
Motor de inferencia: Estrategias de resolución del CC
•  Especificidad en CLIPS
–  número de comparaciones que deben realizarse en el antecedente de la
regla
–  Se suma uno a la especificidad por cada:
•  Comparación con una constante
•  Comparación con una variable previamente asignada (ligada a un valor)
•  Llamada a función que forme parte de una premisa de test o de una
utilización del valor de retorno de una función (:,=), exceptuando
–  Llamadas a funciones booleanas (and, or, not)
–  Llamadas a funciones anidadas
–  Ejemplo:
Especificidad=5
(defrule ejemplo
(item ?x ?y ?x)
(test (and (numberp ?x) (> ?x (+10 ?y)) (< ?x 100))) =>)
– 59 –
CLIPS: Motor de inferencia
Estrategias de resolución de conflictos (II):
•  LEX Strategy
–  Se ordenan los time-tag en orden decreciente y se comparan uno
a uno, hasta encontrar uno mayor que otro
–  En caso de que no haya el mismo número de time-tag se añaden
ceros al final
–  Si igual entonces se elige la más específica
–  Ejemplo:
•  Conjunto Conflicto= {R1(f-4), R2(f-2,f-4)}
•  Para R1: 4, 0 / para R2: 4, 2 / por tanto LEX elige R2
•  MEA Strategy
–  parecido a LEX, pero mirando sólo el primer patrón que equipara en la
regla (si es el mismo se usa LEX)
–  Ejemplo: R1
•  Random Strategy
–  A cada activación se le asigna un número aleatorio para determinar su
orden en la agenda.
– 60 –
Sistemas Basados en Reglas
Tema 2. Sistemas Basados en Reglas
• 
• 
• 
Descripción
CLIPS
Ejemplos
…
– 61 –
Diseño de BCs
Proceso:
•  Definir el modelo:
–  conceptualizar el mundo: ¿qué es importante?
–  p.e.: bloques, mesas, posición vertical relativa de los bloques
•  Definir la ontología:
–  Escoger vocabulario
–  p.e.: block1, clear, on, encima...
•  Definir conocimiento del dominio:
–  Codificar el conocimiento general sobre el dominio
–  p.e.: (defrule R (on ?x ?y) => (assert (encima ?x ?y)))
•  Definir conocimiento del caso:
–  Codificar una descripción del caso específico (p.e.: estado actual)
–  p.e.: (deffacts ((On A B) (On B T)))
•  Hacer consultas
– 62 –
Ejemplo: El mundo de los circuitos
•  Construir una BC que permita contestar preguntas acerca del
comportamiento del siguiente circuito
1
2
xor1
xor2
3
1
and2
or1
and1
Circuito C
– 63 –
2
El mundo de los circuitos
•  Definir el modelo:
–  características relevantes
•  circuitos, puertas binarias, tipos de puertas binarias (and, or, xor), terminales de
puertas/circuitos, conexiones entre terminales, señales, señales en las terminales, ...
–  características irrelevantes
•  rutas de las líneas, posición de las puertas, tamaño de las puertas etc.
•  Definir la ontología:
–  Puertas: patrón no ordenado puerta
•  Identificación puerta: slot id-puerta
•  Tipo de puertas: slot tipo
•  Terminales: slots id-entrada-1, id-entrada-2, id-salida
–  Circuito: patrón circuito
•  Identificación circuito: slot id-circuito
•  Terminales: multislots id-entradas, id-salidas
–  Conexiones entre terminales: patrón ordenado conexión/4
–  Señales: valores booleanos TRUE y FALSE
–  Señales en las terminales: patrón no ordenado estado-terminal
– 64 –
Declaración parcial de la Ontología
•  Declaración de la estructura de patrones no-ordenados:
(deftemplate puerta
"Puertas logicas binarias"
(slot id-puerta)
(slot tipo (allowed-symbols
(slot id-entrada-1 (default
(slot id-entrada-2 (default
(slot id-salida-1 (default
AND OR XOR))
e1))
e2))
s1)) )
(deftemplate circuito
"Circuito con multiples entradas y salidas"
(slot
id-circuito)
(multislot id-entradas)
(multislot id-salidas ) )
(deftemplate estado-terminal
"Senyal en terminales de una puerta o circuito"
(slot id-elemento)
(slot id-terminal)
(slot senyal (allowed-symbols TRUE FALSE)) )
– 65 –
Conocimiento del dominio
•  Regla para modelar el comportamiento de una puerta AND:
(defrule logica-AND
(puerta
(id-puerta ?p)
(tipo AND)
(id-entrada-1 ?e1)
(id-entrada-2 ?e2)
(id-salida-1 ?s1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e1)
(senyal ?senyal-e1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e2)
(senyal ?senyal-e2) )
=>
(assert (estado-terminal
(id-elemento ?p)
(id-terminal ?s1)
(senyal (and ?senyal-e1 ?senyal-e2)) ) ) )
– 66 –
Conocimiento del dominio
•  Regla para modelar el comportamiento de una puerta OR:
(defrule logica-OR
(puerta
(id-puerta ?p)
(tipo OR)
(id-entrada-1 ?e1)
(id-entrada-2 ?e2)
(id-salida-1 ?s1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e1)
(senyal ?senyal-e1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e2)
(senyal ?senyal-e2) )
=>
(assert (estado-terminal
(id-elemento ?p)
(id-terminal ?s1)
(senyal (or ?senyal-e1 ?senyal-e2)) ) ) )
– 67 –
Conocimiento del dominio
•  Regla para modelar el comportamiento de una puerta XOR:
(defrule logica-XOR
(puerta
(id-puerta ?p)
(tipo XOR)
(id-entrada-1 ?e1)
(id-entrada-2 ?e2)
(id-salida-1 ?s1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e1)
(senyal ?senyal-e1) )
(estado-terminal
(id-elemento ?p)
(id-terminal ?e2)
(senyal ?senyal-e2) )
=>
(assert (estado-terminal
(id-elemento ?p)
(id-terminal ?s1)
(senyal (not (eq ?senyal-e1 ?senyal-e2))) ) ) )
– 68 –
Conocimiento del dominio
•  Regla para propagar señales por conexiones:
(defrule logica-conexion
"Si dos terminales estan conectados, entonces
tienen la misma senyal"
(estado-terminal
(id-elemento ?elemento-A)
(id-terminal ?terminal-A)
(senyal ?senyal))
(conexion ?elemento-A ?terminal-A
?elemento-B ?terminal-B)
=>
(assert (estado-terminal
(id-elemento ?elemento-B)
(id-terminal ?terminal-B)
(senyal ?senyal))))
– 69 –
Conocimiento del caso
•  Hechos iniciales para definir los elementos de un circuito concreto:
(deffacts lista-de-elementos
(circuito (id-circuito C)
(id-entradas e1 e2 e3)
(id-salidas s1 s2)
)
(puerta
(id-puerta X1)
(tipo XOR))
(puerta
(id-puerta X2)
(tipo XOR))
(puerta
(id-puerta A1)
(tipo AND))
(puerta
(id-puerta A2)
(tipo AND))
(puerta
(id-puerta O1)
(tipo OR )) )
– 70 –
Conocimiento del caso
•  Hechos iniciales para definir las conexiones concretas entre elementos:
(deffacts lista-de-conexiones
(conexion C e1 X1 e1)
(conexion C e1 A1 e1)
(conexion C e2 X1 e2)
(conexion C e2 A1 e2)
(conexion C e3 A2 e1)
(conexion C e3 X2 e2)
(conexion X1 s1 X2 e1)
(conexion X1 s1 A2 e2)
(conexion A1 s1 O1 e2)
(conexion A2 s1 O1 e1)
(conexion X2 s1 C s1)
(conexion O1 s1 C s2) )
•  Regla para completar conexiones:
(defrule conexion
"La conexion es conmutativa"
(conexion ?p1 ?t1 ?p2 ?t2)
=>
(assert (conexion ?p2 ?t2 ?p1 ?t1)) )
– 71 –
Conocimiento del caso
•  Regla para leer las señales iniciales en las entradas:
(defrule leer-entradas
(circuito (id-circuito ?c)
(id-entradas $? ?t $?))
=>
(printout t "Circuito: " ?c
" Entrada: " ?t
" Senyal: " )
(bind ?senyal (read))
(assert (estado-terminal
(id-elemento ?c)
(id-terminal ?t)
(senyal ?senyal)) ) )
– 72 –
Conocimiento del caso
•  Regla para escribir las señales deducidas en las salidas:
(defrule imprimir-salidas
(estado-terminal
(id-elemento ?c)
(id-terminal ?t)
(senyal ?senyal))
(circuito (id-circuito ?c)
(id-salidas $? ?t $?))
=>
(printout t "Circuito: " ?c
"
Salida: " ?t
"
Senyal: " ?senyal crlf) )
– 73 –
Realizar Consultas
•  Preguntar por las salidas que producen ciertas entradas:
–  Consulta a la BC
CLIPS> (reset)
CLIPS> (run)
Circuito: C Entrada: e1
Circuito: C Entrada: e2
Circuito: C Entrada: e3
Senyal: TRUE
Senyal: TRUE
Senyal: FALSE
–  Respuesta:
Circuito: C
Circuito: C
Senyal: FALSE
Senyal: TRUE
Salida: 11
Entrada: e2
– 74 –
Ejercicio
Suponga que se ha cargado la anterior Base de Conocimiento en CLIPS, y
que se ha configurado para que aplique la estrategia breadth (amplitud).
Suponga también que todos los hechos sobre conexiones se encuentran ya
en la MT, y que se han leído ya los señales en los terminales de entradas,
dando lugar a estos hechos
(estado-terminal
(estado-terminal
(estado-terminal
(estado-terminal
(estado-terminal
(estado-terminal
(id-elemento
(id-elemento
(id-elemento
(id-elemento
(id-elemento
(id-elemento
A2)
X2)
X1)
A1)
X1)
A1)
(id-terminal
(id-terminal
(id-terminal
(id-terminal
(id-terminal
(id-terminal
e1)
e2)
e2)
e2)
e1)
e1)
(senyal
(senyal
(senyal
(senyal
(senyal
(senyal
TRUE)
TRUE)
FALSE)
FALSE)
TRUE)
TRUE)
Simule algunos ciclos de razonamiento de CLIPS. ¿Qué se escribiría en
en pantalla? ¿Cuál es la funcionalidad del circuito C?
– 75 –
Modelar acciones
Para modelar la función expandir:
•  un estado se caracteriza por un hecho en la memoria de trabajo
•  reglas modelan acciones:
–  el antecedente representa las precondiciones
–  el consecuente modela el resultado de la acción
•  al disparar todas las reglas activadas por un estado, se obtienen los estados
sucesores
Implementación 1 (destructiva):
•  la regla borra el estado que la activaba, y sólo deja el estado actual en la
memoria
•  Problema:
–  no queda traza de los estados visitados
–  al no mantener los estados hermanos en la MT, no se puede dar marcha atrás
– 76 –
Modelar acciones
Implementación 2:
•  se mantienen todos los estados en la memoria (“árbol de búsqueda”)
•  las reglas aplicables en cada momento se encuentran en la agenda
(conjunto conflicto)
•  completo con estrategia “breadth” (amplitud)
Ejemplo:
•  dos jarras, con una capacidad de 3 litros (llamada Tres), y 4 litros (llamada Cuatro).
•  inicialmente Tres y Cuatro están vacías, y se intenta que haya 2l de agua en Cuatro
•  cualquiera de ellas puede llenarse con el agua de un grifo G.
•  el contenido tanto de Tres como de Cuatro puede vaciarse en una pila P.
•  es posible echar todo el agua de una jarra a la otra., pero no se dispone de
dispositivos de medición adicionales.
– 77 –
Modelar acciones
•  Llenar jarras del grifo
(defrule llenar-cuatro-del-grifo
?nodo <- (situacion
(litros-en-cuatro ?cuatro)
(litros-en-tres ?tres) )
(test (< ?cuatro 4))
=>
(assert (situacion (padre ?nodo)
(litros-en-cuatro 4)
(litros-en-tres ?tres))) )
(defrule llenar-tres-del-grifo
?nodo <- (situacion
(litros-en-tres ?tres) )
(test (< ?tres 3))
=>
(duplicate ?nodo (padre ?nodo)
(litros-en-tres 3)) )
– 78 –
Modelar acciones
•  Vaciar jarras en la pila
(defrule vaciar-cuatro-en-pila
?nodo <- (situacion
(litros-en-cuatro ?cuatro) )
(test (> ?cuatro 0))
=>
(duplicate ?nodo (padre ?nodo)
(litros-en-cuatro 0)) )
(defrule vaciar-tres-en-pila
?nodo <- (situacion
(litros-en-tres ?tres) )
(test (> ?tres 0))
=>
(duplicate ?nodo (padre ?nodo)
(litros-en-tres 0)) )
– 79 –
Modelar acciones
•  Llenar una jarra de la otra
(defrule llenar-cuatro-desde-tres
?nodo <- (situacion
(litros-en-cuatro ?cuatro)
(litros-en-tres ?tres) )
(test (> (+ ?cuatro ?tres) 4))
(test (< ?cuatro 4))
=>
(assert (situacion (padre ?nodo)
(litros-en-cuatro 4)
(litros-en-tres (- ?tres (- 4 ?cuatro))))) )
– 80 –
Modelar acciones
•  Llenar una jarra de la otra
(defrule llenar-tres-desde-cuatro
?nodo <- (situacion
(litros-en-cuatro ?cuatro)
(litros-en-tres ?tres) )
(test (> (+ ?cuatro ?tres) 3))
(test (< ?tres 3))
=>
(bind ?nuevo-cuatro (- ?cuatro (- 3 ?tres)))
(assert (situacion (padre ?nodo)
(litros-en-cuatro ?nuevo-cuatro)
(litros-en-tres 3))) )
– 81 –
Modelar acciones
•  Vaciar una jarra en la otra:
(defrule vaciar-tres-en-cuatro
?nodo <- (situacion
(litros-en-cuatro ?cuatro)
(litros-en-tres ?tres) )
(test (<= (+ ?cuatro ?tres) 4))
(test (> ?tres 0))
=> (assert (situacion (padre ?nodo)
(litros-en-cuatro (+ ?tres ?cuatro))
(litros-en-tres 0)) ) )
(defrule vaciar-cuatro-en-tres
?nodo <- (situacion
(litros-en-cuatro ?cuatro)
(litros-en-tres ?tres) )
(test (<= (+ ?cuatro ?tres) 3))
(test (> ?cuatro 0))
=> (assert (situacion (padre ?nodo)
(litros-en-cuatro 0)
(litros-en-tres (+ ?tres ?cuatro)) ) ) )
– 82 –
Ejercicio
Representación de acciones con reglas:
Aunque el número de estados para el problema de las
jarras el relativamente pequeño, existen muchos ciclos,
por lo que se genera un árbol de búsqueda bastante
grande
–  ¿Cómo se podrían modificar las reglas para evitar ciclos
simples?
–  ¿Cómo se podrían modificar las reglas para evitar todos
los ciclos?
– 83 –
Modelar cambio
¿Cómo representar acciones en el mundo de los bloques ?
C
A B
B
C A
C A B
A
B
C
Problema:
•  estados parcialmente caracterizados
–  sólo algunas propiedades del estado son relevantes
–  no se puede definir de antemano un deftemplate para estados
•  Solución:
–  hechos ordenados: asignar un nombre a cada estado, y añadirlo como
argumento a cada propiedad
–  p.e.: (on C A S0), (on A T S0), (on B T S0), (clear C S0),
(clear B S0),(clear T S0)
– 84 –
Modelar cambio: Axiomas de efecto
Reglas de efecto:
•  describir qué propiedades son relevantes para una acción
–  el antecedente describe las precondiciones para que se pueda realizar la
acción
–  el consecuente describe las nuevas propiedades (las que no se cumplen en
el estado actual S1, pero sí en el estado resultante S2)
(defrule efecto-move
(clear ?x ?s1)
(clear ?z&~?x ?s1)
(on ?x ?y&~?z ?s1)
=>
(bind ?s2 (gensym*))
(assert (on ?x ?z ?s2))
(assert (clear ?y ?s2))
(assert (clear T ?s2))
(assert (move ?s1 ?s2 ?x ?y ?z)) )
– 85 –
Modelar cambio: Axiomas de marco
Reglas de marco:
•  Problema:
–  las acciones sólo cambian algunas propiedades
–  la mayoría de las propiedades no es afectada por una acción
–  de momento no se puede deducir que después de poner C de A
sobre T en el estado s0, se cumple (on A T S1)
•  Solución:
–  describir qué propiedades no cambian con una acción
•  Reglas de marco:
–  reglas que indican qué propiedades no cambian
–  aquí: una reglas de marco para cada par propiedad/acción
– 86 –
Modelar cambio: Axiomas de marco
•  Regla de marco para clear:
(defrule marco-move-1
(move ?s1 ?s2 ?x ?y ?z)
(clear ?u&~?z ?s1)
=>
(assert (clear ?u ?s2)) )
•  Regla de marco para on:
(defrule marco-move-2
(move ?s1 ?s2 ?u ?v ?z)
(on ?x&~?u ?y ?s1)
=>
(assert (on ?x ?y ?s2)) )
– 87 –
Ejemplo de ejecución (Breadth): ciclo 0
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
C
A
B
•  Agenda:
0 efecto-move: f-4,f-5,f-3
– 88 –
“move(C,A,T)”
Ejemplo de ejecución: ciclo 1
Se ejecuta la regla efecto: “cambios producidos por move(C,A,T) ”
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
f-6
f-7
f-8
f-9
(on C T gen1)
(clear A gen1)
(clear T gen1)
(move S0 gen1 C A T)
•  Agenda:
0 marco-move-1: f-9,f-4
0 marco-move-2: f-9,f-1
0 marco-move-2: f-9,f-2
– 89 –
“clear(C) persiste en gen1”
“on(B,T) persiste en gen1”
“on(A,B) persiste en gen1”
Ejemplo de ejecución: ciclo 2
Se ejecuta la regla marco: “clear(C) persiste después de move(C,A,T) ”
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
f-6 (on C T gen1)
f-7 (clear A gen1)
f-8 (clear T gen1)
f-9 (move S0 gen1 C A T)
f-10 (clear C gen1)
•  Agenda:
0 marco-move-2: f-9,f-1
0 marco-move-2: f-9,f-2
0 efecto-move: f-10,f-7,f-6
– 90 –
“on(B,T) persiste en gen1”
“on(A,B) persiste en gen1”
“move(C,T,A) en gen1”
Ejemplo de ejecución: ciclo 3
Se ejecuta la regla efecto: “on(B,T) persiste después de move(C,A,T) ”
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
f-6 (on C T gen1)
f-7 (clear A gen1)
f-8 (clear T gen1)
f-9 (move S0 gen1 C A T)
f-10 (clear C gen1)
f-11 (on B T gen1)
•  Agenda:
0 marco-move-2: f-9,f-2
0 efecto-move: f-10,f-7,f-6
– 91 –
“on(A,B) persiste en gen1”
“move(C,T,A) en gen1”
Ejemplo de ejecución: ciclo 4
Se ejecuta la regla efecto: “on(A,B) persiste después de move(C,A,T)”
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
f-6 (on C T gen1)
f-7 (clear A gen1)
f-8 (clear T gen1)
f-9 (move S0 gen1 C A T)
f-10 (clear C gen1)
f-11 (on B T gen1)
f-12 (on A B gen1)
•  Agenda:
0 efecto-move: f-10,f-7,f-6
0 efecto-move: f-7,f-10,f-12
0 efecto-move: f-7,f-8,f-12
...
– 92 –
“move(C,T,A) en gen1”
“move(A,B,C) en gen1”
“move(A,B,T) en gen1”
Ejemplo de ejecución: ciclo 5
Se ejecuta la regla efecto: “cambios producidos por move(C,T,A)”
•  Memoria de Trabajo
f-0
f-1
f-2
f-3
f-4
f-5
(initial-fact)
(on B T S0)
(on A B S0)
(on C A S0)
(clear C S0)
(clear T S0)
f-6 (on C T gen1)
f-13 (on C A gen2)
f-7 (clear A gen1)
f-14 (clear T gen2)
f-8 (clear T gen1)
f-15 (move gen1 gen2
f-9 (move S0 gen1 C A T)
C T A)
f-10 (clear C gen1)
f-11 (on B T gen1)
f-12 (on A B gen1)
•  Agenda:
0
0
0
0
0
0
efecto-move: f-7,f-10,f-12
efecto-move: f-7,f-8,f-12
marco-move-1: f-15,f-8
marco-move-1: f-15,f-10
marco-move-2: f-15,f-11
marco-move-2: f-15,f-12
– 93 –
“move(A,B,C) en gen1”
“move(A,B,T) en gen1”
“clear(T) persiste en gen1”
“clear(C) persiste en gen1”
“on(B,T) persiste en gen1”
“on(A,B) persiste en gen1”
...