6. Operadores en PROLOG
|
|
|
- Roberto Cabrera Gutiérrez
- hace 9 años
- Vistas:
Transcripción
1 6. Operadores en PROLOG 1. Definición de operadores propios 2. Operadores predefinidos Igualdad Entrada y Salida básicos Manejo de ficheros Evaluación de expresiones aritméticas Comparación de números Introducción de nuevas cláusulas
2 6. Operadores en PROLOG 2. Operadores predefinidos (cont.) Cumplimiento y fracaso de objetivos Clasificación de términos Manejo de cláusulas como términos Construcción y acceso a componentes de estructuras Control de la re-evaluación Metavariables
3 1. Declaración de operadores (I) Utilización de un predicado predefinido:?- op(precedencia, Tipo, Nombre).?- op(500, yfx, por). yes?- X= a por b. X= a por b Precedencia Є [1, 1200] y depende de implementaciones. Tipo: Aridad Notación o posición Infijo: xfy, yfx, xfx, yfy (f representa operador; x e y operandos) Prefijo: fx, fy. Sufijo: xf, yf
4 Declaración de operadores (II) Asociatividad: y indica que el argumento puede contener operadores de igual o menor precedencia. x obliga a que sea estrictamente menor. Ejemplo: + declarado como yfx. a+b+c : a+(b+c) ó (a+b)+c La primera opción queda eliminada porque el segundo argumento no puede contener un operador de precedencia igual. Esto se conoce como asociatividad por la izquierda (yfx), por la derecha (xfy) o indistintamente (xfx); según esto, no tendría sentido (yfy).
5 2. Operadores predefinidos Ya hemos visto: Pueden tener efectos laterales al satisfacerse, además de instanciar variables. Ejemplo: corte Pueden forzar a que los argumentos sean de un cierto tipo. Ejemplo: < necesita dos argumentos numéricos Definiremos los predicados que deberían formar el núcleo del intérprete PROLOG, aunque habrá que revisarlos para cada versión
6 2.1. Igualdad X = Y. Unificación: intenta hacer X e Y iguales mediante unificación. X \= Y. Su opuesto: no unifican X == Y. Identidad Más restrictivo que X = Y. Se satisface si X = Y, pero no necesariamente a la inversa.?- X = Y.?- X == X.?- X = Y, X == Y.?- append([a B], C) == append(x, Y).?- append([a B], C) == append([a B], C). X \== Y. Su opuesto.
7 2.2. Entrada y Salida básicos Lectura read(x), get0(x), get(x) Escritura write(x), display(x) put(x) Formato: nl tab(x) skip(+code) skip(a).
8 2.3. Manejo de ficheros Lectura: see(x), seeing(x), seen Escritura: tell(x), telling(x), told
9 2.4. Evaluación de expresiones aritméticas X is Y. Fuerza la evaluación de Y para unificar con X. Los siguientes sólo se evalúan si están a la derecha de is: X + Y. X Y. X * Y. X / Y. X mod Y.
10 2.5. Comparación de números X = Y. X \= Y. X < Y. X > Y. X >= Y. X =< Y.
11 2.6. Introducción de nuevas cláusulas consult(x). Añade nuevas clausulas. Si ya están definidos predicados, añade clausulas al final.?- consult(fichero).?- consult(fichero1), consult(fichero2). reconsult(x). Las clausulas leidas substituyen a las actuales.?- reconsult(fichero3), reconsult(fichero4). Notación de lista: fichero para consult. -fichero para reconsult.?- [fichero1, - fichero3.pl, fichero2.pl, - fichero4.pl ]
12 2.7. Cumplimiento y fracaso de objetivos true siempre se cumple fail siempre fracasa Utilidades:...,!, fail. si la ejecución llega hasta este punto, debemos dejar de intentar satisfacer el objetivo: fail lo hace fracasar y el corte anula la re-satisfacción.,!, genera(x), muestra(x), fail. queremos recorrer todas las soluciones de un objetivo y, por ejemplo, mostrarlas.
13 2.8. Clasificación de términos Permiten seleccionar ciertos tipos de términos para ser utilizados en las clausulas: var(x) se satisface si en ese momento X es una variable no instanciada permite saber si una variable ya tiene o no un valor, pero sin fijárselo como efecto lateral?- var(x). yes?- var(23). no?- X = Y, Y = 23, var(x).? nonvar(x) comportamiento opuesto al anterior
14 Clasificación de términos (II) atom(x) se cumple si X identifica en ese momento un átomo?- atom(23). no?- atom(libros). yes?- atom( esto es una cadena ).? integer(x) se satisface si X representa en ese momento a un entero atomic(x) se cumple si en ese momento X es un entero o un átomo atomic(x):- atom(x). atomic(x):- integer(x).
15 2.9. Manejo de cláusulas como términos PROLOG permite al programador examinar y modificar otros programas PROLOG: construir estructuras que representen cláusulas añadir clausulas retirar clausulas Para PROLOG una cláusula es una estructura le_gusta_a(juan, X) :- le_gusta_a(x, vino). Una clausula es una estructura cuyo functor principal es :- y cuyos argumentos son cabeza y cuerpo de la clausula. :- (le_gusta_a(juan, X), le_gusta_a(x, vino)) Si la cola tiene varios términos, deben considerarse unidos por el functor,. abuelo(x, Z):- padres(x, Y), padres(y,z). :- (abuelo(x, Z),, (padres(x,y) padres(y,z)))
16 Manejo de cláusulas como términos (II) listing(a). Se muestran por el canal de salida activo todas las cláusulas asociadas al átomo al que esté instanciado A. El formato depende del intérprete. Útil para descubrir errores. Ejemplo:?- [recorrer_fichero].?- listing(mostrar_fichero). mostrar_fichero :- write('nombre de fichero: '), read(a), see(a), muestra_contenido, seen.
17 Manejo de cláusulas como términos (III) clause(x, Y). Si se satisface hace coincidir X e Y con la cabeza y el cuerpo de una cláusula existente. Si no, falla. Si no hay cláusulas asociadas, fracasa. X debe tener información para identificar el predicado principal. Se instancia a la primera cláusula y si se re-satisface, irán instanciándose a las siguientes cláusulas. Para los hechos instancia el cuerpo a true. Ejemplo: añadir_sin_duplicar(x, L, L):- member(x, L),!. añadir_sin_duplicar(x, L, [X L]).?- clause(añadir_sin_duplicar(x, U, V), Y). U=V Y = member(x,l),! ; V = [X U] Y = true.
18 Manejo de cláusulas como términos (IV) asserta(x), assertz(x). Añade una nueva clausula a la BC: asserta() lo hace al principio de la misma y assertaz() al final. X debe estar suficientemente instanciada ser una cláusula válida. Una vez satisfecho, no se deshace aunque haya reevaluación. La única forma de eliminar entonces la cláusula es con: retract(x). X debe estar suficientemente instanciada para identificar una cláusula válida. Si se satisface, elimina la primera cláusula. Si se reevalúa, eliminará las siguientes.
19 2.10. Construcción y acceso de componentes de estructuras Se pueden escribir programas con cláusulas que hagan referencia a estructuras arbitrarias functor(t, F, N). T es una estructura con functor F y aridad N Si T está instanciada, fracasará si T no es un átomo o una estructura. Si no fracasa, nos dará el functor F y su aridad N Si T no está instanciada, deben estarlo F y N. T devolverá las estructuras que verifiquen F y N. Ejemplos:?- functor(a+b, F, N). F = +, N = 2?- functor([a, b, c], F, N). F =., N = 2?- functor([a, b, c],., 3). No
20 Construcción y acceso de componentes de estructuras (II) arg(n, T, A). N debe indicar una posición en los argumentos de T Ambos deben estar instanciados A será el argumento N-ésimo de T X =.. L Llamado históricamente univ L es la lista que consiste en el functor de X seguido de los argumentos de X Permite: a) obtener todos los argumentos de una estructura b) construir una estructura a partir de una lista Ejemplo:?- algo(a, b, c) =.. L. L = [algo, a, b, c]
21 Construcción y acceso de componentes de estructuras (III) Ejemplo:?- X =.. [f, a, b, c]. X = f(a, b, c). name(a, L) Permite manejar átomos arbitrarios Relaciona un átomo, A, con la lista de caracteres ASCII que lo compone, L Ejemplos:?- name(prueba, X). X = [112, 114, 117, 101, 98, 97]?- name(prueba, prueba ). yes?- name(x, [112, 114, 117, 101, 98, 97]). X = prueba
22 2.11. Control de la reevaluación Predicado predefinido corte ó! Detiene la búsqueda de nuevas soluciones repeat Permite buscar soluciones alternativas. Sería equivalente a tener definido: repeat. repeat :- repeat. Se usa en combinación con corte y fail echo :- repeat, read(x), echo(x),!. echo(x):- X=end_of_file,!. echo(x):- write(x), nl, fail.
23 2.12. Metavariables call(x) el objetivo call(x) se cumple si se satisface X como objetivo?- padre(x).?- call(padre(x)).?-meta=..[padre,x], call(meta). not(x) \+ padre(x). not(padre(x)). X, Y conjunción de objetivos X ; Y disyunción de objetivos
5. Entrada y Salida en PROLOG
5. Entrada y Salida en PROLOG 1. Escritura de términos 2. Lectura de términos 3. Escritura y lectura de caracteres 4. Escritura en fichero 5. Lectura de fichero 1. Escritura de términos (I) Predicado predefinido
5.3 Tipos de Datos en Prolog
5.3 Tipos de Datos en Prolog Objetos de Datos en Prolog Objetos de datos simples Objetos estructurados Calce de operaciones fundamentales sobre objetos 1 Tipos de Objetos de Datos Objetos de datos Objetos
5.3 Tipos de Datos en Prolog
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
5.3 Tipos de Datos en Prolog
5.3 Tipos de Datos en Prolog Recocimiento de Tipos Se recoce el tipo de un dato por su forma sintáctica; se requiere de declaración de tipos Ejemplo: Variables se definen comienzan con primera en mayúsculas
4. Predicados predefinidos
4. Predicados predefinidos CONTENIDO 4.1. El esquema condicional en PROLOG. 4.2. La notación operador. 4.3. Predicados predefinidos. 4.3.1. Clasificación de términos. 4.3.2. Control de otros predicados.
Programación n Declarativa: Lógica y Restricciones
Programación n Declarativa: Lógica y Restricciones El lenguaje de programación ISO Prolog (Parte I) Mari Carmen Suárez de Figueroa Baonza [email protected] Contenidos Predicados para Tipos Aritmética
Tema 12.- Entrada y Salida
UNIVERSDAD DE CÓRDOBA ESCUELA POLITÉCNICA SUPERIOR DEPARTAMENTO DE INFORMÁTICA Y ANÁLISIS NUMÉRICO LENGUAJES DE INTELIGENCIA ARTIFICIAL INGENIGERÍA TÉCNICA EN INFORMÁTICA DE GESTIÓN INGENIERÍA TÉCNICA
Predicados Básicos de Prolog TAII(I) - Curso
Predicados Básicos de Prolog TAII(I) - Curso 2005-2006 Existe un conjunto de predicados predefinidos en Prolog que podrás utilizar en tus programas para realizar operaciones de entrada/salida, trabajar
Tema 2. La Sintaxis. 1. El vocabulario de un programa PROLOG
Tema 2. La Sintaxis 1. El vocabulario de un programa PROLOG 2. TérminosT 2.1. Constantes 2.2. Variables 2.3. Estructuras 3. Operadores 4. Igualdad y Desigualdad 5. Aritmética tica en los programas PROLOG
Programación Exploratoria - Predicados Predefinidos en Prolog -
Universidad Nacional del Centro de la Provincia de Buenos Aires Facultad de Ciencias Exactas Programación Exploratoria - Predicados Predefinidos en Prolog - Tipos de Predicados Construcción de Predicados
Metaprogramación. Ingeniería Informática. Departamento de Lenguajes y Ciencias de la Computación Universidad de Málaga
Ingeniería Informática Departamento de Lenguajes y Ciencias de la Computación Universidad de Málaga Contenido 1. Clasificación de términos 2. Inspección de estructuras 2 Clasificación de términos Clasificación
Predicados Extra-lógicos. Predicados Extra-lógicos. Contenido. Prolog = Programación lógica. Programa (cláusulas de Horn)
Contenido Ingeniería Informática Ingeniería Técnica en Informática de Sistemas 1. Predicados extra-lógicos 2. Predicados aritméticos 3. Entrada/salida de términos 4. Unificación y no unificación 5. Comparación
INTRODUCCIÓN BÁSICA. Ingeniería Informática AL PROLOG. Departamento de Informática
INTRODUCCIÓN BÁSICA AL PROLOG Ingeniería Informática Departamento de Informática PRÓLOGO Esta introducción al Prolog está pensada para las prácticas de la asignatura de Matemática Discreta de la Universitat
TUTORIAL PROLOG. Lenguajes de programación Universidad Nacional de Colombia Santiago Carvajal Castañeda Mario Andrés Moreno Norato
TUTORIAL PROLOG Lenguajes de programación Universidad Nacional de Colombia Santiago Carvajal Castañeda Mario Andrés Moreno Norato Prolog es un lenguaje de programación lógica de propósito general que se
Introducción a PROLOG
Inteligencia Artificial II Curso 2003 2004 Introducción a PROLOG Carmen Graciani Díaz José L. Ruiz Reina Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla IA-II 2003
el proceso de backtracking.
1 El proceso de Backtracking 1.1 Backtracking En esta práctica se examina en detalle cómo Prolog busca todas las soluciones a un objetivo. Prolog responde a una pregunta hecha por el programador. Esta
Programación en PROLOG(1)
Programación en PROLOG(1) Inteligencia Artificial 2º cuatrimestre de 2008 Departamento de Ciencias e Ingeniería de la Computación Universidad Nacional del Sur Prolog Es el representante más conocido del
Tema 2: Listas, aritmética y operadores
Programación Declarativa Curso 200 2002 Tema 2: Listas, aritmética y operadores José A. Alonso Jiménez Miguel A. Gutiérrez Naranjo Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad
Tema 1. Introducción al PROLOG. 1. Qué es el PROLOG? 2. Los elementos de PROLOG 3. Un programa de ejemplo 4. Ejercicios propuestos
Tema 1. Introducción al PROLOG 1. Qué es el PROLOG? 2. Los elementos de PROLOG 3. Un programa de ejemplo 4. Ejercicios propuestos 1. Qué es el PROLOG? 1.1. Un poco de historia PROgramming in LOGic Desarrollado
Escuela Normal Superior N 40 Mariano Moreno. Cuadernillo Propedéutico 2017 Nivel Superior
Escuela Normal Superior N 40 Mariano Moreno Cuadernillo Propedéutico 2017 Nivel Superior INDICE Página Datos 1 Tipos de Datos 2 Variables 3 Constantes 4 Operadores y Expresiones 5 Algoritmos - Algoritmos
PHP: Lenguaje de programación
Francisco J. Martín Mateos Carmen Graciani Diaz Dpto. Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla Tipos de datos Enteros Con base decimal: 45, -43 Con base octal: 043, -054
Tema III Predicados Extralógicos de PROLOG
Tema III Predicados Extralógicos de PROLOG Programación Declarativa 1 Predicados Extralógicos Se incorporan al lenguaje como predicados predefinidos con usos limitados para acceder a funciones del sistema
Listas. Listas. Listas. Listas y Corte en Prolog. Temas Avanzados en Ingeniería Informática I (Lógica) David Camacho Fernández.
Temas Avanzados en Ingeniería Informática I (Lógica) Listas y Corte en Prolog Listas Una lista es una secuencia de elementos. Estos elementos pueden ser términos (constantes, variables, estructuras) o
Tema 6: Representación lógica del conocimiento
Inteligencia Artificial Curso 999 2000 Tema 6: Representación lógica del conocimiento José A. Alonso Jiménez Miguel A. Gutiérrez Naranjo Francisco J. Martín Mateos Dpto. de Ciencias de la Computación e
El lenguaje C. 1. Identificadores, constantes y variables
Principios de Programación El lenguaje C 1. Identificadores, constantes y variables 1.1. Conceptos de memoria Los nombres de variable como x, y, suma corresponden a localizaciones o posiciones en la memoria
Prolog. Sintaxis Informal. Sintaxis Informal. Hechos: ejemplos. Inteligencia Artificial 2º cuatrimestre de Hechos. Hechos. Reglas.
Prolog Programación en PROLOG(1) Inteligencia Artificial 2º cuatrimestre de 2009 Departamento de Ciencias e Ingeniería de la Computación Universidad Nacional del Sur Es el representante más cocido del
Programación declarativa ( )
Programación declarativa (2004 05) Tema 2: Listas, operadores y aritmética José A. Alonso Jiménez Dpto. Ciencias de la Computación e Inteligencia Artificial Universidad de Sevilla PD (2004 05) Tema 2 p.
Estructuras de Datos y Listas en PROLOG. 1. Estructuras y árboles 2. Listas 3. Operaciones con Listas 4. Ejercicios 5. Prácticas
Estructuras de Datos y Listas en PROLOG 1. Estructuras y árboles 2. Listas 3. Operaciones con Listas 4. Ejercicios 5. Prácticas 1. Estructuras y árboles Una estructura de datos en PROLOG se puede visualizar
Programación lógica Curso Tema 2: Prolog. José A. Alonso Jiménez.
Programación lógica Curso 2002 03 Tema 2: Prolog José A. Alonso Jiménez [email protected] http://www.cs.us.es/ jalonso Dpto. de Ciencias de la Computación e Inteligencia Artificial Universidad
Práctica II. Prolog II: Meta Intérprete Vanilla
Práctica II Prolog II: Meta Intérprete Vanilla Contenido 1. Meta intérpretes. 2. Meta intérprete vanilla para cláusulas definidas. 3. Extensión vanilla predicados predefinidos. 4. Extensión vanilla pruebas.
Introducción a Haskell. El lenguaje Haskell
Capítulo 2. Introducción a Haskell 9 Introducción a Haskell Un ejemplo de fichero Haskell El lenguaje Haskell Haskell es un lenguaje funcional puro, no estricto y fuertemente tipificado. Puro = transparencia
Trabajo Práctico N o 1 - Programación Lógica Fecha de entrega: 19/05/2005 hasta las 21hs
Trabajo Práctico N o 1 - Programación Lógica Fecha de entrega: 19/05/2005 hasta las 21hs Razonando con lenguajes naturales El objetivo de este trabajo práctico consiste en analizar sintácticamente un pequeño
Trabajo Práctico 2 Programación Lógica
Trabajo Práctico 2 Programación Lógica Paradigmas de Lenguajes de Programación 1 o cuat. 2011 Fecha de entrega: 9 de Junio Este trabajo consiste en implementar en Prolog un programa que resuelva tableros
INTRODUCCIÓN A PROLOG
INTRODUCCIÓN A PROLOG Lenguaje declarativo (opuesto a procedimentales) basado en reglas de la lógica PROLOG = Programming in Logic Originado en Europa a principios de los 70 s por Alain Colmerauer (Universidad
UNIVERSIDAD AUTÓNOMA DE GUERRERO UNIDAD ACADÉMICA DE MATEMÁTICAS. Apuntes de. PROGRAMACIÓN EN PROLOG Segunda Edición
UNIVERSIDAD AUTÓNOMA DE GUERRERO Apuntes de PROGRAMACIÓN EN PROLOG Segunda Edición Serie: Material de Apoyo a la Licenciatura en Matemáticas Área Computación. Edgar Altamirano Carmona Chilpancingo, Gro.,
Inteligencia en Redes de Comunicaciones. Prolog. Julio Villena Román.
Inteligencia en Redes de Comunicaciones Prolog Julio Villena Román [email protected] Prolog La lógica proporciona: un lenguaje base para la representación del conocimiento modelos para el razonamiento
LENGUAJES DE PROGRAMACIÓN
LENGUAJES DE PROGRAMACIÓN Paradigma Lógico Caso de Estudio : Prolog Lenguajes de Programación 2018 Depto. de Ciencias e Ingeniería de la Computación Universidad Nacional del Sur, Bahía Blanca 1 2 1 1/2
Metodología de Programación I Tutorial de Prolog (3/3)
Metodología de Programación I Tutorial de Prolog (3/3) Dr. Alejandro Guerra-Hernández Departamento de Inteligencia Artificial Facultad de Física e Inteligencia Artificial [email protected] http://www.uv.mx/aguerra
PROgramación LOGica PROLOG. Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional
PROgramación LOGica PROLOG Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional Dónde bajar? Strawberry PROLOG: www.dobrev.com PROLOG -> PROgramming in LOGig Paradigma -> El lenguaje
Principios de Computadoras II
Departamento de Ingeniería Electrónica y Computadoras Operadores y Expresiones [email protected] Primer programa en Java 2 Comentarios en Java Comentario tradicional (multi-línea) Comentario de línea Comentario
Expresiones Lógicas y Operadores sobre Bits
Expresiones Lógicas y Operadores sobre Bits Andrés Arcia Departamento de Computación Escuela de Ingeniería de Sistemas Facultad de Ingeniería Universidad de Los Andes Programación Digital I 1 Expresión
$0 Representa al parámetro cero o nombre del programa $1 Representa al parámetro uno $2 Representa al parámetro dos
PROGRAMACIÓN DE SHELL SCRIPTS EN LINUX El shell es un intérprete de órdenes, pero el shell no es solamente eso; los intérpretes de órdenes de Linux son auténticos lenguajes de programación. Como tales,
PROgramación LOGica PROLOG
PROgramación LOGica PROLOG Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional Dónde bajar? Strawberry PROLOG: www.dobrev.com PROLOG -> PROgramming in LOGig Paradigma -> El lenguaje
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Unificación en Prolog Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Satisfacer objetivos
23/09/2009. Introducción Hello word La familia Buendía Recursión Listas
Prolog Contenido Introducción Hello word La familia Buendía Recursión Listas Qué es Prolog? Lenguaje de programación Declarativo Programación lógica Está compuesto de: Hechos Reglas Declarativo vs Imperativo
Tema 4. Operadores y Expresiones
Tema 4 Operadores y Expresiones Contenidos 1. Conceptos Básicos. 2. Operadores Aritméticos. 3. Operadores de Relación, de Igualdad y Lógicos. 4. Operadores de Incremento y Decremento. 5. Operadores y Expresiones
Tema 3.- Predicados y sentencias condicionales
UNIVERSIDAD DE CÓRDOBA ESCUELA POLITÉCNICA SUPERIOR DE CÓRDOBA DEPARTAMENTO DE INFORMÁTICA Y ANÁLISIS NUMÉRICO PROGRAMACIÓN DECLARATIVA INGENIERÍA INFORMÁTICA ESPECIALIDAD DE COMPUTACIÓN CUARTO CURSO PRIMER
Listas en Prolog. Capítulo. Listas como sujetos
Capítulo 5 Listas en Prolog Este capítulo introduce el concepto de lista, un tipo de dato de gran influencia dentro de la inteligencia artificial. Se comienza con una introducción a listas en Prolog y
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Aritmética Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Introducción a la Aritmética
Unidad II: Análisis semántico
Unidad II: Análisis semántico Se compone de un conjunto de rutinas independientes, llamadas por los analizadores morfológico y sintáctico. El análisis semántico utiliza como entrada el árbol sintáctico
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:
Cuestionario Modulo 1.1 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: 1001 0110. 2. qué es Dato? Definición: Es toda
Inteligencia Artificial II Prolog I
Inteligencia Artificial II Prolog I Dr. Alejandro Guerra-Hernández Universidad Veracruzana Centro de Investigación en Inteligencia Artificial mailto:[email protected] http://www.uv.mx/personal/aguerra Maestría
Operador de corte (cut): Motivaciones. Cut (!): Definición formal. Cut (!): Implicancias de la Definición. Aplicaciones. Cut (!): Ejemplo. b,!
Operador de corte (cut): Motivaciones Programación en PROLOG(2) Inteligencia Artificial 2º cuatrimestre de 2009 Departamento de Ciencias e Ingeniería de la Computación Universidad Nacional del Sur Prolog
Programación n en Prolog
Programación n Declarativa: Lógica y Restricciones Conceptos Básicos B de la Programación n en Prolog Mari Carmen Suárez de Figueroa Baonza [email protected] Contenidos Unificación Estructuras de datos
Guía 2: Listas, recursión e inducción
Introducción a los Algoritmos - 2do cuatrimestre 2014 Guía 2: Listas, recursión e inducción Docentes: Walter Alini, Luciana Benotti En esta guía comenzaremos a trabajar con listas Para familiarizarnos
Operadores y Expresiones
Operadores y Expresiones Los programas Java constan de datos, sentencias de programas y expresiones. Una expresión es normalmente, una ecuación matemática, tal como 3 * x + 5 * z. En esta expresión, los
Índice del capítulo. Capítulo 4. Expresiones. Las expresiones. Indice de la sección. Lenguajes de Programación. Introducción. 2.
Índice del capítulo Capítulo 4. Expresiones Lenguajes de Programación Capítulo 4. Expresiones 1. Carlos Ureña Almagro 2. Dpt. Lenguajes y Sistemas Informáticos ETSI Informática y de Telecomunicación Universidad
Tema 2. Tipos predefinidos
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 2. Tipos predefinidos 2.1 Tipos simples predefinidos El tipo Bool El tipo Int El tipo Integer
SISTEMAS INFORMÁTICOS PROGRAMACION I - Contenidos Analíticos Ing. Alejandro Guzmán M. TEMA 2. Diseño de Algoritmos
TEMA 2 Diseño de Algoritmos 7 2. DISEÑO DE ALGORITMOS 2.1. Concepto de Algoritmo En matemáticas, ciencias de la computación y disciplinas relacionadas, un algoritmo (del griego y latín, dixit algorithmus
PROgramación LOGica PROLOG. Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional
PROgramación LOGica PROLOG Dr. Oldemar Rodríguez Rojas Escuela de Informática Universidad de Nacional Dónde bajar? Strawberry PROLOG: www.dobrev.com PROLOG -> PROgramming in LOGig Paradigma -> El lenguaje
Tema 3. Patrones y Definiciones de Funciones
Programación Declarativa Haskell Informática Sistemas Curso 2003-2004 Pepe Gallardo Universidad de Málaga Tema 3. Patrones y Definiciones de Funciones 3.1 Comparación de Patrones Patrones constantes Patrones
Componentes Básicos. InCo. InCo Componentes Básicos 1 / 28
Componentes Básicos InCo InCo Componentes Básicos 1 / 28 Modelo de Computación Vemos al computador como un procesador de datos. +------------+ Entrada ===> Computador ===> Salida +------------+ InCo Componentes
Tema 2.- Expresiones y funciones
UNIVERSIDAD DE CÓRDOBA ESCUELA POLITÉCNICA SUPERIOR DE CÓRDOBA DEPARTAMENTO DE INFORMÁTICA Y ANÁLISIS NUMÉRICO PROGRAMACIÓN DECLARATIVA INGENIERÍA INFORMÁTICA ESPECIALIDAD DE COMPUTACIÓN CUARTO CURSO PRIMER
Algoritmos. Medios de expresión de un algoritmo. Diagrama de flujo
Algoritmos En general, no hay una definición formal de algoritmo. Muchos autores los señalan como listas de instrucciones para resolver un problema abstracto, es decir, que un número finito de pasos convierten
Inteligencia en Redes de Comunicaciones - 04a Prolog
En este Tema 4a se van a estudiar los fundamentos de Prolog, el lenguaje de programación lógica más extendido. 1 Prolog es un lenguaje de programación para representar conocimiento y realizar razonamientos
Lenguajes de Programación. Capítulo 4. Expresiones.
Lenguajes de Programación. Capítulo 4. Expresiones. Carlos Ureña Almagro Curso 2011-12 Contents 1 Introducción 2 2 Literales 5 2.1 Literales tipos primitivos......................................... 5
Conceptos Fundamentales. Programación Lógica y Funcional MTI. Eduardo Cruz Romero
Conceptos Fundamentales Programación Lógica y Funcional MTI. Eduardo Cruz Romero www.tics-tlapa.com Estilos de Programación (1/3) Estilo de programación (también llamado estándares de código o convención
Inteligencia Artificial: Prolog
Inteligencia Artificial: Prolog Listas Christopher Expósito-Izquierdo 1, Belén Melián-Batista 2 {cexposit 1, mbmelian 2 }@ull.es Universidad de La Laguna (España) Contenidos Qué es una lista? Operador
INTRODUCCIÓN A LA PROGRAMACIÓN EN FORTRAN. Métodos Numéricos Carlos Zotelo
INTRODUCCIÓN A LA PROGRAMACIÓN EN FORTRAN Métodos Numéricos 2008 - Carlos Zotelo Introducción a Fortran 77 / 90 1. El lenguaje Fortran 77 / 90 2. Tipos de datos básicos 3. Constantes y variables 4. Entrada
Números enteros (cortos, largos y sin signo) Números reales (precisión simple y doble) Carácter y cadenas de caracteres. Lógicos.
Universidad Rafael Urdaneta Escuela de Ingeniería de Computación Números enteros (cortos, largos y sin signo) Números reales (precisión simple y doble) Carácter y cadenas de caracteres. Lógicos. Asignación
Sistemas Inteligentes de Gestión. Tutorial de PROLOG
Sistemas Inteligentes de Gestión Tutorial de PROLOG Juan Carlos Cubero & Fernando Berzal Sistemas Inteligentes de Gestión: PROLOG 1 Índice Programación de sistemas expertos en PROLOG... 3 El lenguaje PROLOG...
JavaScript: Operadores
Las variables por sí solas son de poca utilidad. Hasta ahora, sólo se ha visto cómo crear variables de diferentes tipos y cómo mostrar su valor mediante la función alert(). Para hacer programas realmente
Representación del conocimiento mediante reglas (2011/2012)
Luis Valencia Cabrera (coordinador) [email protected] (http://www.cs.us.es/~lvalencia) Manuel García-Quismondo [email protected] (http://www.cs.us.es/~mgarcia) Ciencias de la Computacion e IA (http://www.cs.us.es/)
