SlideShare una empresa de Scribd logo
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
• Para salir escriba (exit)

• Pruebe un comando de ejemplo como la multiplicación :
                      (* 5 6 20) => 600

• La anterior instrucción hará una multiplicación de los tres
  números devolviendo 600 como resultado.

• Tenemos 2 tipos de datos: Atómicos y Listas




               INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
b,4, color-casa ,etc.
Al evaluar un tipo de dato atómico, nos devuelve el valor que se le
ha asignado. Los números son un caso especial, siempre devuelven
el mismo valor.
                              20 = > 20

Si ponemos “edad-hermano” sin definirla con un valor, devuelve:
              edad-hermano => Error (variable not defined)
Se asigna un valor con el comando:
                      (setq edad-hermano 19)=> 19
                           edad-hermano => 19

Existen palabras reservadas como nil , T, etc.
No se distinguen mayúscula y minúsculas: las variables ola y Ola son
la misma.

              INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
(b), ( * 9 8) , (casa ( silla mesa e) j ), (), nil

• nil es a la vez un valor atómico y una lista : ()

• La evaluación de una lista siempre invoca una función.
  (nombre-de-la-función argumento1…argumento n)
                (* 50 10) => 5
                (e 45,46,47) => Error (function not defined)
                (+ edad-hermano 8) => 27

• Cuando evaluamos una lista, primero evaluamos los
  argumentos para después aplicar la función



               INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
• Lisp incluye operadores como +, - , * , /
• Además, incluye varias operaciones importantes.
   Cons construye una lista de datos con una cola.
              (cons 10 (cons 12 nil)) => (10 12)

   Hay que tener en cuenta que el valor de la cola que significa
    'nada' es nulo.
   Si probamos con átomos que no están reservados.
     (cons Jose nil) => Error: variable a is not defined.

      ¿Por qué sale ese error?




            INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
Tenemos que decirle al intérprete que no evalúe al átomo Jose. Para ello se
 pone adelante ‘
                        (cons ‘Jose nil) => (JOSE)

De forma abreviada se puede aplicar a una lista completa :
    (cons ‘Jose ‘(Pepe Marta Carlos ))=> (JOSE PEPE MARTA CARLOS)

 Veremos diferencias entre list y append.
            (list ‘Jose ‘Marta ‘Carlos) => (JOSE MARTA CARLOS)
          (list ‘Jose ‘(Marta Carlos)) => (JOSE (MARTA CARLOS))
(append ‘(Jose Marta) ‘(Carlos Carmen))=> (JOSE MARTA CARLOS CARMEN)

La diferencia es que append, usa a listas como argumentos para formar
 otra lista.

               INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
Si queremos listar, pero uno de los elementos a listar es resultado de una
 operación, se pondrá entre paréntesis. Por ejemplo:

(list ‘Jose ‘24 (* edad-hermano 3) ‘ Marta ‘24) => (JOSE 24 75 MARTA 24)



Una coma dentro de un par de paréntesis antepuesto por una apóstrofe,
le dice a Lisp que, tiene evaluar lo que le sigue a la coma. Por ejemplo:

   ‘(Jose 24 ,(* edad-hermano 3) Marta 24)=> (JOSE 24 75 MARIA 24)




                INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
Una vez que tenemos una lista construida, ¿Cómo accedemos a los miembros de
  la lista?
• first : Primero de una lista.
                            (first ‘(Jose Marta Carlos)) => JOSE
            (first ‘((Jose Marta Carlos) Carmen) )=> (JOSE MARTA CARLOS)
• rest : Toda la lista menos el primer elemento
                    (rest ‘(Jose Marta Carlos)) => (MARTA CARLOS)
                  (rest ‘((Jose Marta Carlos) Carmen) )=> (CARMEN)
• car y cdr se pueden combinar
                  (caar '((Jose Marta ​) Carmen Miguel)) => JOSE
                (cdar '((Jose Marta ​) Carmen Miguel)) => (MARTA)
 Se tiene que trabajar desde la derecha hacia la izquierda.


                  INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
• Por ejemplo, si escribimos:
   (setq listaPrueba ‘(Ana Carla Patricia)) => (ANA CARLA PATRICIA)
    (cons ‘Marcos listaPrueba) => (MARCOS ANA CARLA PATRICIA)
                 listaPrueba => (ANA CARLA PATRICIA)

• No tiene efectos secundarios, la lista no cambió. Necesitamos setq
  para cambiar el valor de un átomo.

• setf es una versión de setq que tiene una función como primer
  argumento.
            (setf (cadr listaPrueba) ‘Antonio) => ANTONIO
               listaPrueba => (ANA ANTONIO PATRICIA)



                INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
• A continuación veremos 2 tipos de igualdad
                    (eq ‘Marta ‘Carlos) => nil
                     (eq ‘(jose) ‘(Jose)) => nil
                       (eq ‘Jose ‘JoSe) => T

                    (equal ‘Carlos ‘Carlos) => T
                  (equal ‘(Marta) ‘(Marta)) => T
       (equal ‘(alumno profesor) ‘(alumno profesor)) => T

• (equal x, y) es T cuando (eq x y) es verdadero y cuando las cosas
  se escriben iguales son verdaderas .



              INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
• ¿Se puede el tratar a una lista como un conjunto, es decir, sin preservar
  el orden?
   (union ‘(Marta Carla) ‘(Marta Luis Juan)) => (JUAN LUIS MARTA CARLA)
  (union ‘((Marta) (Carmen)) ‘((Marta))) => ((MARTA) (MARTA) (CARMEN))
 (union ‘((Marta) (Carmen)) ‘((Marta)) :test ‘equal) => ((MARTA) (CARMEN))

• La condición de prueba para determinar si los 2 elementos en el
  conjunto son los mismos es la función equal.
       (adjoin ‘Marta ‘(Marta Carla Juan)) => (MARTA CARLA JUAN)
   (set-difference ‘(Juan Marta Carla ) ‘(Marta Pedro Carla)) => (JUAN)

• adjoin y set-difference también pueden usar :test ‘equal. Incluso puede
  proporcionar su propia función.


                  INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
(length ‘(Richard Cecilia Alonso)) => 3
               (atom ‘1) => T
(atom ‘(Richard Cecilia Alonso)) => NIL
        (listp ‘inteligencia) => NIL
    (listp ‘(IA Modelos Redes)) => T




INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
(<= Alonso (and Bruno Carmen))
                                        (not (not Daniel))
                                  (or Pablo (not Pedro) Marcos)



    (list ‘<= ‘Alonso (list ‘and ‘Bruno ‘Carmen)) => (<= ALONSO (AND BRUNO CARMEN))
                         (list ‘not (list ‘not ‘Daniel)) => (NOT (NOT DANIEL))
        (list ‘or ‘Pablo (list ‘not ‘Pedro) ‘Marcos) => (OR PABLO (NOT PEDRO) MARCOS)


Tener en cuenta que los operadores KIF =>, <=, <=>, and, or, not serán
siempre el primer elemento de la lista.



                    INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
(defun <nombre> <documentación-de-cadena> (<argumentos>)
                              <cuerpo>)
              (defun cubo (dato1) (* dato1 dato1 dato1))
                            cubo 6 => 216

Tenga en cuenta que no tenemos que citar a ninguno de los argumentos de
defun. Se atiende de forma automática.

La evaluación de una función para un conjunto de argumentos como
resultado en la última expresión valuada en el función de seguimiento.



                 INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
(if <expresión> <entonces - expresión> <de lo contrario - expresión>)

Por ejemplo:
                                    setq dat1 5 => 5
                                    setq dat2 6 => 6
               (if (> dat1 dat2) (- dat1 dat2) (* dat1 dat2)) => 30
                            (if (> 3 4) (+ 3 4) (- 3 4)) => -1
                         (if (eq 3 3) (+ 20 1) (/ 10 2)) => 21




                   INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
La evaluación de cond evalúa las pruebas hasta que una
de ellas se evalúe como verdadera. A continuación, se evalúa cada uno de
las formas adecuadas; la última evaluación es el valor de toda la función
cond.

Por ejemplo:
                 setq listaN ‘(25 12 100 20) => (25 12 100 20)
                            listaN => (25 12 100 20)
                                 car listaN => 25
                                atom listaN => NIL
                                 listp listaN => T
    ( cond ( (atom listaN) NIL) ((listp listaN) (car listaN)) (T NIL) ) => 25



                  INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6
INTELIGENCIA ARTIFICIAL   -   CICLO 2012-I   -   GRUPO 6

Más contenido relacionado

PDF
T2 tutorial de lisp completo-grupo6
PDF
T3 ejercicios de recursividad-grupo6
PDF
Algoritmos de Planning - Práctico Nro. 1
PDF
Funciones basicas
PDF
Homogenias f
PPTX
Funciones ex log
PDF
Dominioycodominio
T2 tutorial de lisp completo-grupo6
T3 ejercicios de recursividad-grupo6
Algoritmos de Planning - Práctico Nro. 1
Funciones basicas
Homogenias f
Funciones ex log
Dominioycodominio

Destacado (8)

PDF
Ag rg no ms 695143
PPTX
Clips parte1
ODP
Imagenes para ambiente de aprendizaje
PPSX
Presentación ingre mic (1)
PPTX
Updated goals ivivva
PPTX
Instituto San Jose
PPTX
Salita Digital
PDF
Agosto 2012 cantabria agenda
Ag rg no ms 695143
Clips parte1
Imagenes para ambiente de aprendizaje
Presentación ingre mic (1)
Updated goals ivivva
Instituto San Jose
Salita Digital
Agosto 2012 cantabria agenda
Publicidad

Similar a T1 primer tutorial de lisp-grupo6 (20)

DOCX
Ada 4 casanova leslie
DOCX
Ada 4_casanova leslie
PDF
Apunte del Lenguaje LISP
DOCX
PPTX
Propiedades de numerosentero
DOCX
DOCX
PDF
CLASE 01 - numeros enteros.pdf
PPTX
2do. año Leyes de signos, Potenciación, Función lineal.pptx
DOCX
ADAS 4 - Funciones de la hoja de cálculo
PPTX
Propiedad y operaciones con numeros enteros
PPT
Tipos basicos
PPT
Algoritmos
DOCX
Ada 4 - funciones de la hoja de cálculo
DOCX
Ada 4 funciones de la hoja de cálculo
PDF
Manual_Mysql Query Browser
DOC
Determinantes
PDF
Un1. Números enteros (Matemáticas 2º PCPI MV)
PDF
2 eso matematicas - ud01
Ada 4 casanova leslie
Ada 4_casanova leslie
Apunte del Lenguaje LISP
Propiedades de numerosentero
CLASE 01 - numeros enteros.pdf
2do. año Leyes de signos, Potenciación, Función lineal.pptx
ADAS 4 - Funciones de la hoja de cálculo
Propiedad y operaciones con numeros enteros
Tipos basicos
Algoritmos
Ada 4 - funciones de la hoja de cálculo
Ada 4 funciones de la hoja de cálculo
Manual_Mysql Query Browser
Determinantes
Un1. Números enteros (Matemáticas 2º PCPI MV)
2 eso matematicas - ud01
Publicidad

Más de Hiper S.A. (8)

PDF
Silabo inteligencia artificia2012_1
PDF
S7 fundamentos de sistemas expertos-grupo6
PDF
S5 métodos de búsquedas informados-grupo6
PDF
S6 métodos de búsqueda para juegos hombre máquina-grupo6
PDF
S4 métodos de búsqueda a ciegas-grupo6
PDF
S3 métodos de búsqueda en un espacio de estado-grupo6
PDF
S2 fundamentos de la inteligencia artificial-grupo6
PDF
S1 clasificación de problemas algorítmicos-grupo6
Silabo inteligencia artificia2012_1
S7 fundamentos de sistemas expertos-grupo6
S5 métodos de búsquedas informados-grupo6
S6 métodos de búsqueda para juegos hombre máquina-grupo6
S4 métodos de búsqueda a ciegas-grupo6
S3 métodos de búsqueda en un espacio de estado-grupo6
S2 fundamentos de la inteligencia artificial-grupo6
S1 clasificación de problemas algorítmicos-grupo6

Último (20)

PDF
Tomo 1 de biologia gratis ultra plusenmas
PDF
Teologia-Sistematica-Por-Lewis-Sperry-Chafer_060044.pdf
PPTX
Welcome to the 8th Physical Science Class 2025-2026
PDF
COMPLETO__PROYECTO_VIVAN LOS NIÑOS Y SUS DERECHOS_EDUCADORASSOS.pdf
PDF
Metodologías Activas con herramientas IAG
PDF
Fundamentos_Educacion_a_Distancia_ABC.pdf
PDF
Crear o Morir - Andres Oppenheimer Ccesa007.pdf
PDF
Gasista de unidades unifuncionales - pagina 23 en adelante.pdf
DOCX
PLAN DE CASTELLANO 2021 actualizado a la normativa
PDF
CONFERENCIA-Deep Research en el aula universitaria-UPeU-EduTech360.pdf
PDF
TOMO II - LITERATURA.pd plusenmas ultras
PDF
La Evaluacion Formativa en Nuevos Escenarios de Aprendizaje UGEL03 Ccesa007.pdf
PDF
IDH_Guatemala_2.pdfnjjjkeioooe ,l dkdldp ekooe
PPTX
Presentación de la Cetoacidosis diabetica.pptx
PDF
Habitos de Ricos - Juan Diego Gomez Ccesa007.pdf
PDF
Cronograma de clases de Práctica Profesional 2 2025 UDE.pdf
PPTX
Doctrina 1 Soteriologuia y sus diferente
DOCX
Informe_practica pre Final.docxddadssasdddddddddddddddddddddddddddddddddddddddd
PDF
2.0 Introduccion a processing, y como obtenerlo
PDF
Escuela de Negocios - Robert kiyosaki Ccesa007.pdf
Tomo 1 de biologia gratis ultra plusenmas
Teologia-Sistematica-Por-Lewis-Sperry-Chafer_060044.pdf
Welcome to the 8th Physical Science Class 2025-2026
COMPLETO__PROYECTO_VIVAN LOS NIÑOS Y SUS DERECHOS_EDUCADORASSOS.pdf
Metodologías Activas con herramientas IAG
Fundamentos_Educacion_a_Distancia_ABC.pdf
Crear o Morir - Andres Oppenheimer Ccesa007.pdf
Gasista de unidades unifuncionales - pagina 23 en adelante.pdf
PLAN DE CASTELLANO 2021 actualizado a la normativa
CONFERENCIA-Deep Research en el aula universitaria-UPeU-EduTech360.pdf
TOMO II - LITERATURA.pd plusenmas ultras
La Evaluacion Formativa en Nuevos Escenarios de Aprendizaje UGEL03 Ccesa007.pdf
IDH_Guatemala_2.pdfnjjjkeioooe ,l dkdldp ekooe
Presentación de la Cetoacidosis diabetica.pptx
Habitos de Ricos - Juan Diego Gomez Ccesa007.pdf
Cronograma de clases de Práctica Profesional 2 2025 UDE.pdf
Doctrina 1 Soteriologuia y sus diferente
Informe_practica pre Final.docxddadssasdddddddddddddddddddddddddddddddddddddddd
2.0 Introduccion a processing, y como obtenerlo
Escuela de Negocios - Robert kiyosaki Ccesa007.pdf

T1 primer tutorial de lisp-grupo6

  • 1. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 2. • Para salir escriba (exit) • Pruebe un comando de ejemplo como la multiplicación : (* 5 6 20) => 600 • La anterior instrucción hará una multiplicación de los tres números devolviendo 600 como resultado. • Tenemos 2 tipos de datos: Atómicos y Listas INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 3. b,4, color-casa ,etc. Al evaluar un tipo de dato atómico, nos devuelve el valor que se le ha asignado. Los números son un caso especial, siempre devuelven el mismo valor. 20 = > 20 Si ponemos “edad-hermano” sin definirla con un valor, devuelve: edad-hermano => Error (variable not defined) Se asigna un valor con el comando: (setq edad-hermano 19)=> 19 edad-hermano => 19 Existen palabras reservadas como nil , T, etc. No se distinguen mayúscula y minúsculas: las variables ola y Ola son la misma. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 4. (b), ( * 9 8) , (casa ( silla mesa e) j ), (), nil • nil es a la vez un valor atómico y una lista : () • La evaluación de una lista siempre invoca una función. (nombre-de-la-función argumento1…argumento n) (* 50 10) => 5 (e 45,46,47) => Error (function not defined) (+ edad-hermano 8) => 27 • Cuando evaluamos una lista, primero evaluamos los argumentos para después aplicar la función INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 5. • Lisp incluye operadores como +, - , * , / • Además, incluye varias operaciones importantes.  Cons construye una lista de datos con una cola. (cons 10 (cons 12 nil)) => (10 12)  Hay que tener en cuenta que el valor de la cola que significa 'nada' es nulo.  Si probamos con átomos que no están reservados. (cons Jose nil) => Error: variable a is not defined. ¿Por qué sale ese error? INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 6. Tenemos que decirle al intérprete que no evalúe al átomo Jose. Para ello se pone adelante ‘ (cons ‘Jose nil) => (JOSE) De forma abreviada se puede aplicar a una lista completa : (cons ‘Jose ‘(Pepe Marta Carlos ))=> (JOSE PEPE MARTA CARLOS) Veremos diferencias entre list y append. (list ‘Jose ‘Marta ‘Carlos) => (JOSE MARTA CARLOS) (list ‘Jose ‘(Marta Carlos)) => (JOSE (MARTA CARLOS)) (append ‘(Jose Marta) ‘(Carlos Carmen))=> (JOSE MARTA CARLOS CARMEN) La diferencia es que append, usa a listas como argumentos para formar otra lista. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 7. Si queremos listar, pero uno de los elementos a listar es resultado de una operación, se pondrá entre paréntesis. Por ejemplo: (list ‘Jose ‘24 (* edad-hermano 3) ‘ Marta ‘24) => (JOSE 24 75 MARTA 24) Una coma dentro de un par de paréntesis antepuesto por una apóstrofe, le dice a Lisp que, tiene evaluar lo que le sigue a la coma. Por ejemplo: ‘(Jose 24 ,(* edad-hermano 3) Marta 24)=> (JOSE 24 75 MARIA 24) INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 8. Una vez que tenemos una lista construida, ¿Cómo accedemos a los miembros de la lista? • first : Primero de una lista. (first ‘(Jose Marta Carlos)) => JOSE (first ‘((Jose Marta Carlos) Carmen) )=> (JOSE MARTA CARLOS) • rest : Toda la lista menos el primer elemento (rest ‘(Jose Marta Carlos)) => (MARTA CARLOS) (rest ‘((Jose Marta Carlos) Carmen) )=> (CARMEN) • car y cdr se pueden combinar (caar '((Jose Marta ​) Carmen Miguel)) => JOSE (cdar '((Jose Marta ​) Carmen Miguel)) => (MARTA) Se tiene que trabajar desde la derecha hacia la izquierda. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 9. • Por ejemplo, si escribimos: (setq listaPrueba ‘(Ana Carla Patricia)) => (ANA CARLA PATRICIA) (cons ‘Marcos listaPrueba) => (MARCOS ANA CARLA PATRICIA) listaPrueba => (ANA CARLA PATRICIA) • No tiene efectos secundarios, la lista no cambió. Necesitamos setq para cambiar el valor de un átomo. • setf es una versión de setq que tiene una función como primer argumento. (setf (cadr listaPrueba) ‘Antonio) => ANTONIO listaPrueba => (ANA ANTONIO PATRICIA) INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 10. • A continuación veremos 2 tipos de igualdad (eq ‘Marta ‘Carlos) => nil (eq ‘(jose) ‘(Jose)) => nil (eq ‘Jose ‘JoSe) => T (equal ‘Carlos ‘Carlos) => T (equal ‘(Marta) ‘(Marta)) => T (equal ‘(alumno profesor) ‘(alumno profesor)) => T • (equal x, y) es T cuando (eq x y) es verdadero y cuando las cosas se escriben iguales son verdaderas . INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 11. • ¿Se puede el tratar a una lista como un conjunto, es decir, sin preservar el orden? (union ‘(Marta Carla) ‘(Marta Luis Juan)) => (JUAN LUIS MARTA CARLA) (union ‘((Marta) (Carmen)) ‘((Marta))) => ((MARTA) (MARTA) (CARMEN)) (union ‘((Marta) (Carmen)) ‘((Marta)) :test ‘equal) => ((MARTA) (CARMEN)) • La condición de prueba para determinar si los 2 elementos en el conjunto son los mismos es la función equal. (adjoin ‘Marta ‘(Marta Carla Juan)) => (MARTA CARLA JUAN) (set-difference ‘(Juan Marta Carla ) ‘(Marta Pedro Carla)) => (JUAN) • adjoin y set-difference también pueden usar :test ‘equal. Incluso puede proporcionar su propia función. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 12. (length ‘(Richard Cecilia Alonso)) => 3 (atom ‘1) => T (atom ‘(Richard Cecilia Alonso)) => NIL (listp ‘inteligencia) => NIL (listp ‘(IA Modelos Redes)) => T INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 13. (<= Alonso (and Bruno Carmen)) (not (not Daniel)) (or Pablo (not Pedro) Marcos) (list ‘<= ‘Alonso (list ‘and ‘Bruno ‘Carmen)) => (<= ALONSO (AND BRUNO CARMEN)) (list ‘not (list ‘not ‘Daniel)) => (NOT (NOT DANIEL)) (list ‘or ‘Pablo (list ‘not ‘Pedro) ‘Marcos) => (OR PABLO (NOT PEDRO) MARCOS) Tener en cuenta que los operadores KIF =>, <=, <=>, and, or, not serán siempre el primer elemento de la lista. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 14. (defun <nombre> <documentación-de-cadena> (<argumentos>) <cuerpo>) (defun cubo (dato1) (* dato1 dato1 dato1)) cubo 6 => 216 Tenga en cuenta que no tenemos que citar a ninguno de los argumentos de defun. Se atiende de forma automática. La evaluación de una función para un conjunto de argumentos como resultado en la última expresión valuada en el función de seguimiento. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 15. (if <expresión> <entonces - expresión> <de lo contrario - expresión>) Por ejemplo: setq dat1 5 => 5 setq dat2 6 => 6 (if (> dat1 dat2) (- dat1 dat2) (* dat1 dat2)) => 30 (if (> 3 4) (+ 3 4) (- 3 4)) => -1 (if (eq 3 3) (+ 20 1) (/ 10 2)) => 21 INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 16. La evaluación de cond evalúa las pruebas hasta que una de ellas se evalúe como verdadera. A continuación, se evalúa cada uno de las formas adecuadas; la última evaluación es el valor de toda la función cond. Por ejemplo: setq listaN ‘(25 12 100 20) => (25 12 100 20) listaN => (25 12 100 20) car listaN => 25 atom listaN => NIL listp listaN => T ( cond ( (atom listaN) NIL) ((listp listaN) (car listaN)) (T NIL) ) => 25 INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 17. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 18. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 19. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 20. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 21. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6
  • 22. INTELIGENCIA ARTIFICIAL - CICLO 2012-I - GRUPO 6