Download Programación Lógica

Document related concepts

Literal (lógica matemática) wikipedia , lookup

Resolución (lógica) wikipedia , lookup

Cláusula de Horn wikipedia , lookup

Forma normal conjuntiva wikipedia , lookup

Cláusula (lógica) wikipedia , lookup

Transcript
Programación Lógica!
rafael ramirez
rafael.ramirez@upf.edu
55.316 (Tanger)
Lógica proposicional!
 Una literal (proposicional) es una variable proposicional o la
negacion de una variable proposicional:
p, q , ¬r, …
  Una cláusula (proposicional) es una disyuncion de literales
p ∨ q ∨ ¬r
es una cláusula
¬(r ∨ q)
no es una cláusula
Una cláusula de Horn (proposicional) es una clausula (prop.)
con a lo mas una literal positiva
(1) q
(2) ¬p1 ∨ … ∨ ¬pn ∨ q
(3) ¬p1 ∨ … ∨ ¬pn
 Clausulas de Horn de (1) y (2) con una literal positiva se llaman
clausulas de programa. Las (1) se llaman clausulas unitarias
2
Lógica proposicional
 Una cláusula de Horn (proposicional) es una clausula (prop.)
con a lo mas una literal positiva
(1) q
(2) ¬p1 ∨ … ∨ ¬pn ∨ q
(3) ¬p1 ∨ … ∨ ¬pn
 Las clausulas de Horn de tipo (2) pueden reescribirse (usando
la ley de De Morgan) como
¬(p1 ∧ … ∧ pn) ∨ q
Que a su vez se puede reescribir como
(p1 ∧ … ∧ pn) → q
  Un programa logico (proposicional) es un conjunto de de
clausulas de programa
Nota que (3) se puede reescribir como ¬(p1 ∧ … ∧ pn)
3
Resolución!
La regla de resolución: si tenemos 2 cláusulas C1, C2 y una variable
proposicional p
 C1 ∨ p, C2 ∨ ¬p |⎯res C1 ∨ C2
En general C1 y C2 pueden ser clausulas generales pero en
programación logica estamos interesados en clausulas de Horn.
 Supon que tenemos un programa lógico P. Estamos interesados en
    Q es consecuencia logica del programa?
Si las clausulas del programa son tomadas como hipotesis,
podemos concluir Q usando la regla de resolucion?
P |⎯res Q ?
4
Resolucion!
  P |⎯res Q ?
Lo que se hace es introducir ¬Q como una hipotesis adicional y usar
resolucion. Si llegamos a la clausula vacia □ entonces la respuesta a
P |⎯res Q ?
 es si.
Esto se basa en el teorema:
si P, Q |⎯res □ entonces P ∧ ¬Q es insatisfacible
5
Resolución!
6
Diferentes formas, la misma cosa!
(a) ¬p ∨ ¬q ∨ r
p
q
(b) p ∧ q → r
p
q
(c) r ← p ∧ q
p
q
(d) r : - p, q.
p.
q.
(a)=(b)=(c)=(d)
Si preguntamos si r es consecuencia logica de las tres
clausulas (de Horn)
(a)
(b) y (c)
1. ¬p ∨ ¬q ∨ r
2. p
3. q
4. ¬ r
5. ¬p ∨ ¬q
6. ¬q
7. □
hip
hip
hip
hip extra
Res 1,4
Res 2,5
Res 3,6
(d)
r
|
p∧q
|
q
|
□
C1
C2
C3
r
|
p, q
|
q
|
□
C1
C2
C3
7
Resolución!
s :- p, q, r.
r :- t, w.
q.
p :- v, r.
t.
v.
w :- v.
Es s consecuencia logica del programa?
8
Resolución!
s :- p, q, r.
r :- t, w.
q.
p :- v, r.
t.
v.
w :- v.
9
Resolución
10
Resolución
11
Resolución SLD
12
Resolución SLD
13
Negación!
Si P es un programa logico y q es una pregunta y no podemos
probar P |⎯res q entonces deducimos P |⎯res ¬q
14
Lógica de Predicados!
 Una cláusula de Horn es
(1) ∀x1,…∀xn (Q)
(2) ∀x1,…∀xn (¬R1∨…∨¬Rk ∨ Q)
(3) ∀x1,…∀xn (¬R1∨…∨¬Rk)
O reescribiendo:
(1) Q
(2) (R1 ∧ … ∧ Rn) → Q
(3) ¬(R1 ∧ … ∧ Rn)
Ri y Q son (atomos) de la forma p(…)
15
Resolución
16
Resolución
Ejercicio: dado el siguiente programa:
Es m(a) consucuencia logica del programa?
Construye el arbol de resolucion SLD.
17
Resolución
 Solucion: si es consecuencia logica
Este arbol se llama arbol de resolucion SLD
18
Resolución
student_of(X,T):-follows(X,C),teaches(T,C).
follows(paul,computer_science).
follows(paul,expert_systems).
follows(maria,ai_techniques).
teaches(adrian,expert_systems).
teaches(peter,ai_techniques).
teaches(peter,computer_science).
?-student_of(S,peter)
19
Resolución
student_of(X,T):-follows(X,C),teaches(T,C).
follows(paul,computer_science).
follows(paul,expert_systems).
follows(maria,ai_techniques).
teaches(adrian,expert_systems).
teaches(peter,ai_techniques).
teaches(peter,computer_science).
?-student_of(S,peter)
:-follows(S,C),teaches(peter,C)
:-teaches(peter,computer_science)
:-teaches(peter,computer_science)
:-teaches(peter,ai_techniques)
:-teaches(peter,expert_systems)
[]
[]
20
Resolución
brother_of(X,Y):-brother_of(Y,X).
brother_of(paul,peter).
?-brother_of(peter,B)
21
Resolución
brother_of(X,Y):-brother_of(Y,X).
brother_of(paul,peter).
?-brother_of(peter,B)
:-brother_of(B,peter)
:-brother_of(peter,B)
[]
:-brother_of(B,peter)
•
•
•
[]
22
En Resumen!
 Que es:
   Que técnicas/métodos hay para
   La logica proposicional
La logica de predicados
La logica proposicional
La logica de predicados
Que herramientas informáticas hay para
  La logica proposicional
La logica de predicados
23
En Resumen (que es?)!
 Que es la logica proposicional?
     p, q, r, …
¬, ∧, ∨, →
Ej. (p ∧ ¬q) → r
Cada fórmula evalua a T (verdadero) o F (falso)
Que es la logica de predicados?
   Variables: x, y, z; constantes: a, b, c; funciónes: f, g,
predicados: p, q, r; conectivos: prop. + ∀, ∃
Ej. ∀x (H(x) → M(x))
Cada fórmula evalua a T (verdadero) o F (falso)
24
En Resumen (métodos y
herramientas)!
Tablas de
verdad
Tableaux
Manipul.
semánticos algebraica
Deduccion Resolucion Prolog
natural
(SLD)
LProp
si
si
si
si
si
si
LPred
no
aplica
si
si
si
si
si
(no en clase)
25