5.3 Tipos de Datos en Prolog

Documentos relacionados
5.3 Tipos de Datos en Prolog

5.3 Tipos de Datos en Prolog

Capítulo V: Programación Lógica

Tema 2. La Sintaxis. 1. El vocabulario de un programa PROLOG

1. El vocabulario de un programa PROLOG. 1. El vocabulario de un programa PROLOG. Sintaxis: Conjunto de caracteres válidos v

6. Operadores en PROLOG

Tema 2: Listas, aritmética y operadores

Aritmética y operadores (2011/2012)

Tema 6: Representación lógica del conocimiento

UNIVERSIDAD AUTÓNOMA DE GUERRERO UNIDAD ACADÉMICA DE MATEMÁTICAS. Apuntes de. PROGRAMACIÓN EN PROLOG Segunda Edición

TUTORIAL PROLOG. Lenguajes de programación Universidad Nacional de Colombia Santiago Carvajal Castañeda Mario Andrés Moreno Norato

Programación declarativa ( )

Programación en PROLOG(1)

Programación declarativa ( )

Inteligencia Artificial 2º cuatrimestre de 2009

CAPÍTULO IV: 4.1 Introducción a la. Programación Funcional

Tema II: Introducción al Lenguaje Funcional

Predicados Extra-lógicos

Predicados Extra-lógicos

Componentes Básicos. InCo. InCo Componentes Básicos 1 / 28

Principios de Computadoras II

Tipos algebraicos y abstractos. Algoritmos y Estructuras de Datos I. Tipos algebraicos

Predicados Extra-lógicos. Predicados Extra-lógicos. Contenido. Prolog = Programación lógica. Programa (cláusulas de Horn)

Listas en Prolog. Capítulo. Listas como sujetos

Informática General 2016 Cátedra: Valeria Drelichman, Pedro Paleo, Leonardo Nadel, Norma Morales

Tema 1: Revisión de Prolog

Prolog. Sintaxis Informal. Sintaxis Informal. Hechos: ejemplos. Inteligencia Artificial 2º cuatrimestre de Hechos. Hechos. Reglas.

Métodos de Inteligencia Artificial

Programación Declarativa Haskell Informática Sistemas Curso Pepe Gallardo Universidad de Málaga. Tema 8. Listas

Programación Declarativa. Ingeniería Informática Cuarto curso. Primer cuatrimestre. Escuela Politécnica Superior de Córdoba Universidad de Córdoba

Laboratorio de Lenguajes de Programación Introducción al lenguaje ML

PROgramación LOGica PROLOG. Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional

Tema 2.- Expresiones y funciones

Programación Declarativa. Ingeniería Informática Cuarto curso. Primer cuatrimestre. Escuela Politécnica Superior de Córdoba Universidad de Córdoba

Semántica: principales usos. Semántica: principales enfoques. Semántica Operacional. Sintaxis abstracta de un lenguaje (sujeto) Semántica Operacional

Programación n en Prolog

Unidad II: Análisis semántico

Informática General 2018 Cátedra: Valeria Drelichman, Pedro Paleo, Leonardo Nadel, Norma Morales

El lenguaje de programación Prolog

Capítulo V: Programación Lógica. 5.1 Breve Introducción al Cálculo de Predicados

Capítulo V: Programación Lógica

El lenguaje C. 1. Identificadores, constantes y variables

Procesadores de lenguajes Ingeniería Informática Especialidad de Computación Tercer curso, segundo cuatrimestre

Tema 3. Tipos de datos simples

Generación de Código Intermedio

Prof. María Alejandra Quintero. Informática Año

4.7 Operaciones sobre Objetos en Scheme

UNIDAD 2 Descripción de un programa

4.7 Operaciones sobre Objetos en Scheme. Equivalencias y predicados de tipos, listas, números, caracteres, strings y vectores

Curso de Programación Avanzada en C

Algoritmos y programas. Algoritmos y Estructuras de Datos I

Dra. Jessica Andrea Carballido

El lenguaje Prolog. Prolog es un lenguaje Declarativo, a diferencia de otros lenguajes que son orientados a objetos o procedurales

Inteligencia Artificial II Prolog I

Representación de la información

GLOSARIO 1. Qué es bit y byte? Bit: Es la unidad mínima de información. Puede ser 0 o 1. Byte: Es el conjunto de 8 bits. Ejemplo:

Mathematica como lenguaje de programación

DISEÑO ESTRUCTURADO USANDO HERRAMIENTAS DE

AMBIENTES DE COMPILACION

Informática General Cátedra: Valeria Drelichman Pedro Paleo Leonardo Nadel Norma Morales

INTRODUCCIÓN BÁSICA. Ingeniería Informática AL PROLOG. Departamento de Informática

INTRODUCCIÓN BÁSICA. Ingeniería Informática AL PROLOG. Departamento de Informática

Tema 1. Introducción al PROLOG. 1. Qué es el PROLOG? 2. Los elementos de PROLOG 3. Un programa de ejemplo 4. Ejercicios propuestos

INTELIGENCIA ARTIFICIAL II

2º Certamen ILI-253 Lenguajes de Programación Juan Pablo Menichetti Jorge Mujica 10 de Junio del 2004

Tema 3.- Predicados y sentencias condicionales

Lenguajes y Compiladores Aspectos Formales (Parte 1) Compiladores

Lenguajes de Inteligencia Artificial Segundo curso. Primer cuatrimestre

Metodología de Programación I Tutorial Prolog 1/3

1. El vocabulario de un programa PROLOG

Programación lógica con listas

Tema 2. Tipos predefinidos

LENGUAJES DE PROGRAMACIÓN

Tema 5: Otros predicados predefinidos

Programación lógica con árboles. Introducción. Contenido. Introducción. 1. Programación con árboles 2. Otras estructuras arbóreas

Es toda la información que utiliza el computador. Según sea la información que guardemos en los datos, se clasifican en los siguientes tipos:

Factorización de polinomios. Profa. Anneliesse Sánchez y Profa. Caroline Rodriguez Departamento de Matemáticas Universidad de Puerto Rico

Lenguajes de Programación Programación funcional

Práctica II. Prolog II: Meta Intérprete Vanilla

1.- Para cada uno de los siguientes problemas escribir el diagrama de flujo y el pseudocódigo de un programa que lo resuelva:

Introducción a la programación

LEX. Las definiciones y subrutinas son opcionales. El segundo %% es opcional pero el primer %% indica el comienzo de las reglas.

Introducción al Modelado de Sistemas Capítulo 4

Entorno y herraminetas

Lógica Proposicional. Guía Lógica Proposicional. Tema I: Proposiciones

Procesadores de lenguajes Ingeniería Informática Especialidad de Computación Tercer curso, segundo cuatrimestre

Unidad III: Introducción a la Programación

Listas. Listas. Listas. Listas y Corte en Prolog. Temas Avanzados en Ingeniería Informática I (Lógica) David Camacho Fernández.

SISTEMAS INFORMÁTICOS PROGRAMACION I - Contenidos Analíticos Ing. Alejandro Guzmán M. TEMA 2. Diseño de Algoritmos

Todo programa en 'C' consta de una o más funciones, una de las cuales se llama main.

Programación con Listas

1.1 Define un operador ( ) que devuelva True si y solo si tan solo uno de sus argumentos es True. Por ejemplo:? (3 > 2) (2 > 5)

INDUCCIÓN. Inducción - 2

INDUCCIÓN Instituto de Computación Lógica Inducción - 1

Transcripción:

5.3 Tipos de Datos en Prolog

Objetos de Datos en Prolog Objetos de datos simples Objetos estructurados Calce de operaciones fundamentales sobre objetos

Tipos de Objetos de Datos Objetos de datos Objetos simples Objetos estructurados Constantes Variables Atomos Números

Reconocimiento de Tipos Se reconoce el tipo de un dato por su forma sintáctica; no se requiere de declaración de tipos Ejemplo: Variables se definen comienzan con primera en mayúsculas (e.g. X) Atomos comienzan con una letra en minúscula (e.g. pedro)

Formación de Variables y Átomos Strings de los siguientes caracteres: Letras mayúsculas A..Z Letras minúsculas a..z Dígitos 0..9 Caracteres especiales: + - * / < > = :. & _ ~

Atomos 1) Strings de letras, dígitos y underscore (_), comenzando con minúscula pedro nil x_25 algo_especial 2) Strings de caracteres especiales <----> ===>... 3) Strings con citación simple Juan San Francisco

Números Números enteros 13213 0-323 Reales 3.14-0.0234 100.2 Dado que Prolog es principalmente un lenguaje de computación simbólica, los números no son su fuerte (el entero es lo que más se usa)

Variables Strings de letras, dígitos y underscore, comenzando con mayúscula o underscore. X Resultado _X1 _12 Si una variable aparece una solo vez en una cláusula, se puede usar variables anónima _?- padre(juan, _). yes tiene_hijo(x) % no se imprime variable :- padre(x, _). Ámbito de variable es una cláusula

Objetos Estructurados Son objetos que tienen varias componentes Estructuras son tratadas como un único objeto Se construyen usando un functor: fecha(22, mayo, 2000) Componentes pueden ser constantes, variables o estructuras. Fecha(Dia, mayo, 2000)

Ejemplo con Figuras Geométrica 6 4 2 P2 = (2,3) S P1 = (1,1) (4,2) (6,4) T (7,1) 2 4 6 8 P1 = punto(1, 1) P2 = punto(2,3) S = seg(p1, P2) T = triangulo (punto(4,2), punto(6,4), punto(7,1))

Representación de Árbol de Estructuras T = triangulo punto punto punto 4 2 6 4 7 1

5.4 Calce de Términos en Prolog

Concepto de Calce La operación más importante sobre términos es el calce, que corresponde a la unificación en el cálculo de predicados. Dos términos calzan si: ❶Son idénticos ❷Las variables en ambos términos pueden ser instanciados, sustituyendo variables, tal que los términos se hacen idénticos.

Ejemplo de Calce Calzar: fecha(d, M, 2000) y fecha(d1, mayo, A1), entonces: D se instancia a D1 M se instancia a mayo A1 se instancia a 2000 Que como salida de Prolog se escribe: D = D1 M= mayo A1 = 2000

Ejemplo de Calce Calzar: fecha(d, M, 2000) y fecha(d1, julio, 1956), entonces: No es posible encontrar un calce (se dice que el proceso de calce ha fracasado). En caso contrario, se dice que el proceso ha sido exitoso.

Ejemplo de Calce en Prolog?- fecha(d, M, 2000) = fecha(d1, mayo, A1). D = H86 M = mayo D1 = H86 A1 = 2000?- fecha(d, M, 2000) = fecha(d1, julio, 1956). no

Grado de Ajuste del Calce?- fecha(d, M, 2000) = fecha(d1, mayo, A1). Podría haber sido calzado como: D = 1 D1 = 1 M = mayo A1 = 2000 Pero esta forma es más restrictiva (menos general) que la anterior. Prolog calza el resultado a su forma más general!

Reglas de Calce Dos términos S y T calzan, si: Si S y T son constantes, entonces S y T calzan si ambos son el mismo objeto. Si S es una variable y T cualquier cosa, entonces calzan y S se instancia como T. Viceversa, si T es variable, entonces T se instancia como S. Si S y T son estructuras, entonces calzan sólo si: ❶ S y T tienen el mismo functor, y ❷ Todas sus correspondientes componentes calzan. Instanciaciones resultantes es determinado por proceso de calce de componentes.

Ejemplo de Calce de Estructuras?- triangulo(punto(1, 1), A, punto(2, 3)) = triangulo(x, punto(4, Y), punto(2, Z)). A = punto(4,h193) X = punto(1,1) Y = H193 Z = 3 triangulo triangulo punto A punto X punto punto 1 1 2 3 4 Y 2 Z

Ejemplo de Calce con Estructuras?- vertical(seg(punto(1,1), punto(1,2))). yes?- vertical(seg(punto(1,1), punto(2,y))). no?- horizontal(seg(punto(1,1), punto(2,y))). Y = 1?- vertical(seg(punto(2,3), Y)). Y = punto(2,h561)?- vertical(s), horizontal(s). S = seg(punto(h576,h577),punto(h576,h577))

Significado Declarativo versus Procedural La cláusula: P :- Q, R. Se interpreta declarativamente como: p es verdadero si Q y R lo son. De Q y R se deriva P. En cambio una interpretación procedural sería: Para resolver P, primero se debe resolver Q y luego R. Para satisfacer a P, primero se debe satisfacer Q y luego R.

Significado Declarativo Una meta G es verdadera (se satisface o se deriva lógicamente de un programa), ssi: ❶ Existe en el programa una cláusula C, tal que ❷ existe una cláusula I, instancia de C, tal que: La cabeza de I es idéntica a G, y todas las metas en el cuerpo de I son verdaderas.

Disjunción en Cláusulas La cláusula: P :- Q; R. Se puede interpretar como: P :- Q. P :- R. La cláusula: P :- Q, R; S, T, U. Se puede interpretar como: P :- Q, R. P :- S, T, U.

Significado Procedural Especifica cómo responder a una pregunta Para obtener la respuesta es necesario satisfacer una lista de metas. Las metas pueden ser satisfechas si a través de la instanciación de sus variables se permite que del programa se deriven las metas.

Visión Procedural programa Lista de metas Ejecución Indicador de éxito/fracaso Instanciación de Variables Sólo si hay indicación de éxito Sólo si hay indicación de éxito

5.5 Listas y Operadores

Listas en Prolog Una lista en Prolog se puede escribir como: [perro, gato, ratón, loro] Sin embargo esto es sólo un sabor sintáctico, pues Prolog lo traduce una forma de estructura. Si existe la estructura.(cabeza, Cola), entonces:.(perro,.(gato,.(ratón,.(loro, [])))) equivale a la lista anterior (que es más legible)

Representación de Listas Una lista define un árbol binario, similar a las listas propias de Scheme. Prolog permite una notación similar a los pares: L = [a Cola], donde a es la cabeza (cualquier tipo) y Cola es el resto de la lista (debe ser una lista). La lista vacía se expresa como []. Ejemplo:?- L2 = [ a [b []]]. L2 = [a,b]

Algunos Posibles Operadores sobre Listas Membresía del objeto X en la lista L: member(x, L) Concatenación de listas L1 y L2 en L3 conc(l1, L2, L3) Agregar un elemento X en una lista L add(x, L, L1) Borrar un elemento X en una lista L del(x, L, L1)

Definición de Operadores (1/2) %definicion de membresia de X en una lista L: member(x, L). % ============================================ member(x, [X Cola]). member(x, [Cabeza Cola]) :- member(x, Cola). % concatenacion de listas L1 y L2 en lista L3: conc(l1, L2, L3). % ============================================== % concat. con lista vacia es la misma lista conc([], L, L). % caso de que primera lista no esté vacía conc([x L1], L2, [X L3]) :- conc(l1, L2, L3).

Definición de Operadores (2/2) % agregar un elemento en la cabeza % ========================== add(x, L, [X L]). % en realidad basta el operador % borrar un elemento de una lista % ====================== % elemento está en la cabeza del(x, [X Cola], Cola). % elemento no está en la cabeza del(x, [Y Cola1], [Y Cola2]) :- del(x, Cola1, Cola2).

Ejemplos de Operadores con Listas?- member(x, [a, b]). X = a ; X = b ; no?- conc([a], [b], L). L = [a,b] ; no?- add(a, X, Y). X = H918 Y = [a H918] ; no?- del(b, [a, b, c, b, d], L). L = [a,c,b,d] ; L = [a,b,c,d] ; no

Sublistas Una sublista es una parte de una lista El operador puede ser definido con la siguiente regla: Ejemplo: sublist(s, L) :- conc(l1, L2, L), conc(s, L3, L2).?- sublist([b, X], [a, b, c, d]). X = c

Permutación de una Lista % Permutar la lista L % ============== permutation([], []). permutation(l, [X P]) :- del(x, L, L1), permutation(l1, P).

Ejemplo de Permutación?- permutation([gato, perro, raton], L). L = [gato,perro,raton] ; L = [gato,raton,perro] ; L = [perro,gato,raton] ; L = [perro,raton,gato] ; L = [raton,gato,perro] ; L = [raton,perro,gato] ; no

5.6 Operadores y Aritmética

Notación de Operadores Las operaciones en Prolog se expresan normalmente como functores. Se permite también especificar operadores especiales con su relación de precedencia mediante directivas al traductor Prolog. Este mecanismo permite mejorar la lectura de programas (sabor sintáctico), similar a la sobrecarga de operadores en C++

Ejemplo de Operadores La expresión: +(*(2, a), *(b, c)) podría escribirse como: 2*a + b*c Que resulta más legible!! Ejemplo en Prolog:?- X = +(*(2, 3), *(4, 5)). X = 2 * 3 + 4 * 5?- X is +(*(2, 3), *(4, 5)). X = 26.?- X is 2*3 + 4*5. X = 26 Se ha supuesto que + tiene mayor precedencia que *

Definición de Operadores Se permite definición de operadores prefijos, infijos y postfijos A cada operador se le puede definir el nivel de precedencia mediante un valor (e.g. entre 1-1200 dependiente de la implementación) Nombre del operador debe ser un átomo Ejemplo: Operador binario infijo gusta :- op(600, xfx, gusta).

Tipos de Operadores Operador Infijo (tres tipos) xfx xfy yfx Operador Prefijo (dos tipos) fx fy Operador Postfijo (dos tipos) xf yf Donde la notación se interpreta como. f corresponde al nombre del operador x e y representan los argumentos x representa operando con precedencia estrictamente menor que el operador y representa operando cuya precedencia es menor o igual que el operador

Conjunto de Operadores Predefinidos :- op(1200, xfx, :- ). :- op(1200, fx, [:-,?-] ). :- op(1100, xfy, ; ). :- op(1000, xfy,, ). :- op(700, xfx, [=, is, <, >, =<, >=, ==, =\=, \==, =:=] ). :- op(500, yfx, [+, -] ). :- op(500, fx, [+, -, not] ). :- op(400, yfx, [*, /, div] ). :- op(300, xfx, mod).

Ejemplo: Operadores Matemáticos?- X = 3 + 5. X = 3 + 5. yes?- X is 3 + 5. X = 8. yes?- X is 5/3. X = 1.66666666666667. yes?- X is5-2 -1. X = 2. yes?- 1 + 2 = 2 + 1. no?- 1 + 2 =:= 2 +1. yes

Ejemplo: Máximo Común Divisor mcd(x, X, X). mcd(x, Y, D) :- X<Y, Y1 is Y-X, mcd(x, Y1, D). mcd(x, Y, D) :- Y<X, mcd(y, X, D).

Ejemplo: Máximo Común Divisor?- mcd(100, 10, X). X = 10?- mcd(27, 36, X). X = 9

Ejemplo 1: Largo de una Lista largo([], 0). largo([ _ Cola], N) :- largo(cola, N1), N is N1 + 1. % Y ahora se consulta?- largo([a, b, [c, d], d, e], N). N = 5

Ejemplo 2: Largo de una Lista largo([], 0). largo([ _ Cola], N) :- largo(cola, N1), N = N1 + 1. % Y ahora se consulta?- largo([a, b, [c, d], d, e], N). N = 0 + 1 + 1 + 1 + 1 + 1 ;