Ministerio de Cultura y Educación Universidad Nacional de San Luis Facultad de Ciencias Físico Matemáticas y Naturales Departamento: Informatica Área: Area IV: Pr. y Met. de Des. del Soft. |
I - Oferta Académica | |||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
II - Equipo Docente | ||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
III - Características del Curso | |||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
|
IV - Fundamentación |
---|
En este curso se inicia a los alumnos en dos paradigmas: prog. Orientada a Objetos y prog. Declarativa Funcional y se refuerzan y completan los conocimientos y aptitudes que adquirieron en Programación I en el paradigma de la programación estructurada. El contenido mencionado prepara al alumno para poder comparar las características de los distintos modelos formales subyacentes en el desarrollo de programas en los tres paradigmas. Las aptitudes desarrolladas a través de la práctica en esta materia, servirán de base tanto para el desarrollo de aplicaciones reales en los distintos paradigmas como para el análisis comparativo formal lenguajes.
También se explora el tema de verificación de programas continuando con el estilo de demostración semántico funcional de Dijkstra, basado el la lógica axiomática de Hoare (introducido en materia anterior), usando alguna herramienta de software existente para realizar aserciones sobre programas simples, reforzando las bases para su posterior tratamiento formal tanto en el ámbito de la ingeniería del software como en el de teoría de la computación. |
V - Objetivos / Resultados de Aprendizaje |
---|
- Iniciar el estudio del paradigma de la programación funcional
- Ejercitar desarrollos de programas basados en el paradigma de la prog. funcional - Iniciar el estudio y aplicación del paradigma de la prog. orientada a objetos - Ejercitar desarrollos de programas basados en el paradigma de la prog. orientada a objetos -Continuar el estudio y aplicación de técnicas de verificación de software, en particular del estilo de demostración semántico functional de Dijkstra, basado en la lógica axiomática de Hoare, usando alguna herramienta para verificar software previamente desarrollado. |
VI - Contenidos |
---|
1.Programación Funcional
Conceptos Generales del paradigma: Características de los lenguajes funcionales. Estilo de programación libre de puntos (pointfree) vs atada a puntos (poitwise). Evaluación perezosa vs Evaluación impaciente. Transparencia referencial. Concepto de función, definición y aplicación. Coincidencia de patrones (Pattern matching). Funciones recursivas. Funciones de orden superior, definición y aplicación. Currificación y aplicación parcial de funciones. Composición de funciones. Manejo de listas. Listas por comprensión. Lenguaje a utilizar: Haskell. Conceptos particulares del paradigma en el lenguaje Haskell: Entorno de trabajo, definición de programas, uso del intérprete. Módulos. Notación de listas por comprensión. Operadores infijos y prefijos. Reglas de precedencia. Funciones predefinidas para manejo de listas y tuplas. Definición y uso de Funciones de orden superior. Expresiones Lambda. Definición y manipulación de funciones y tipos polimorficos. Análisis de funciones recursivas. Recursión primitiva y estructural. Recursión de cola vs recursión controlada, uso de acumuladores. Análisis y uso de las funciones de folding predefinidas para listas: foldl, foldl1, foldr, foldr1. 2. Programación Orientada a Objetos Conceptos Generales del paradigma: Descripción del paradigma de orientación a Objetos. Conceptos: clases, objetos, servicios/métodos, estado/atributos, mensajes, super, self, encapsulamiento. Herencia. Control de herencia. Tipos de herencia. Sobrecarga y Polimorfismo. Lenguaje a utilizar: Java Conceptos particulares del paradigma en el lenguaje Java: Características generales del lenguaje. Tipos de datos básicos. Estructuras de control. Clases, objetos, variables y métodos. Declaración , creación y destrucción de Objetos. Control de acceso. Herencia. Polimorfismo. Compatibilidad de objetos. Conversión de tipos (Down/Up Casting). Enlace estático vs dinámico de métodos. Definición e implementación de Interfaces. Gestión de excepciones en java. Programación de Interfaces de Usuario Textuales (IUT/) y Gráficas (IGU). 3.Verificación de Programas Herramienta a utilizar: Key-Hoare Tool Descripción y características generales de técnicas de verificación basadas en: casos de prueba, model-checking y en la utilización de métodos formales. Métodos formales: Lógica axiomática de Hoare y estilo semántico functional de Dijkstra. Transformadores de programas. Precondición más débil (weakest precondition WP). Determinismo y disyuntividad. Iteraciones. Aserciones, Invariantes. |
VII - Plan de Trabajos Prácticos |
---|
Prácticos de aula:
1. Desarrollo de ejercicios en Lenguaje Haskell 2. Desarrollo de ejercicios en Lenguaje Java 3. Análisis y ejecución de ejercicios de demostración de algoritmos, usando la herramienta Key-Hoare Tool. Prácticos de máquina: Desarrollo y entrega de laboratorios de Haskell y Java. Ejecución de ejercicios de demostración de algoritmos, usando la herramienta Key-Hoare Tool. |
VIII - Regimen de Aprobación |
---|
CONDICIONES PARA DICTADO REGULAR
- Para regularizar la asignatura: el alumno debe aprobar dos exámenes parciales o sus correspondientes recuperaciones, y presentar y aprobar en forma y tiempo los prácticos de máquina solicitados por la cátedra. Para aprobar la materia deberán rendir un examen final. Se tomarán dos recuperaciones para cada parcial, acorde a la Ord.32/14 CS. - Para promocionar la asignatura: el alumno debe cumplir con las condiciones de regularización y aprobar los exámenes parciales o sus correspondientes recuperaciones, presentar y aprobar en tiempo y forma los prácticos de máquina solicitados por la cátedra y la evaluación integradora con una nota superior o igual a 7. Se debe asistir al 80% de las clases teóricas y de las clases prácticas. Se tomarán dos recuperaciones para cada parcial, acorde a la Ord.32/14 CS. |
IX - Bibliografía Básica |
---|
[1] Guía de estudio del Lenguaje Haskell. Material provisto por la Cátedra.
[2] Learn You a Haskell for Great Good!.A Beginner's Guide by Miran Lipovaca. No Starch press. April 2011, 400 pp. ISBN-13: 978-1-59327283-8, ISBN-10: 978-1-59327283-8. Adaptación al español gratuita on-line en http://aprendehaskell.es/). [3] Real World Haskell, Bryan O'Sullivan, Don Stewart, and John Goerzen. Paperback: 700 pages, O'Reilly, November 2008, English, ISBN-10: 0596514980, ISBN-13: 978-0596514983. Disponible on line gratuito en http://book.realworldhaskell.org/ [4] Thinking in Java (4th Edition),Bruce Eckel, Prentice Hall; 4 edition (February 20, 2006), ISBN-10: 0131872486, ISBN-13: 978-0131872486. [5] Aprender a programar Java desde cero. Autor: Mario Rodríguez Rancel. 200 páginas; Editorial: aprenderaprogramar.com, 2012. ISBN: 978-84-939427-0-0. [6] A Discipline of Programming, Edsger W. Dijkstra, Prentice Hall, Inc. (October 28, 1976), ISBN-10: 013215871X, ISBN-13: 978-0132158718 [7] A Hoare-Style Calculus with Explicit State Updates,Reiner Hahnle and Richard Bubel, "Course on Program Verification". Department of Computer Science, Chalmers University of Technology. Disponible en: https://www.researchgate.net/publication/241142337_A_Hoare-Style_Calculus_with_Explicit_State_Updates |
X - Bibliografia Complementaria |
---|
[1] Haskell: The Craft of Functional Programming (2nd Edition), Simon Thompson, Addison-Wesley, ISBN 0201882957, 2011.
[2] Introduction to programming in Java. Hume, J.N. Patterson; Stephenson, Christine; Holt Software Assoc Inc. 2000. ISBN: 0921598394. [3] Predicate Calculus and Program Semantics (Monographs in Computer Science), Edsger W. Dijkstra, Carel S. Scholten Springer; 1 edition (December 18, 1989), ISBN-10: 0387969578, ISBN-13: 978-0387969572 [4] Logic in Computer Science modelling and reasoning about systems, Michael Huth and Mark Ryan; 427 pages (2nd edition). Cambridge University Press (link) in paperback only: ISBN 0 521 54310X |
XI - Resumen de Objetivos |
---|
1. Estudio y aplicación del paradigma de la prog. orientada a objetos.
Lenguaje Java 2. Estudio y aplicación del paradigma de la programación funcional. Lenguaje Haskell 3. Análisis de la aplicación de técnicas de verificación de software, en el estilo de demostración semántico funcional de Dijkstra, basado en la lógica axiomática de Hoare. |
XII - Resumen del Programa |
---|
1. El paradigma de la Programación Orientada a Objetos:
Objetos. Mensajes. Clases. Herencia. Sobrecarga y Polimorfismo. Excepciones 2. El paradigma de la Programación Funcional: Definición y manipulación de funciones simples y de orden superior. Definición y manipulación de tipos de datos polimorficos y recursivos. Recursión primitiva y estructural. Recursión de cola vs Recursión controlada. 3. Verificación de Programas: Precondición más débil (weakest precondition WP). Determinismo y disyuntividad. Iteraciones. Aserciones, Invariantes. |
XIII - Imprevistos |
---|
Toda modificación será acordada y comunicada con el estudiantado e informada a Secretaría Académica. Aclaración: de acuerdo al art. 2 de la Resolución CD 009/22, el Calendario Académico de la Universidad Nacional de San Luis establece que el Primer Cuatrimestre sea de 14 semanas. A los efectos de que se impartan todos los contenidos y se respete el crédito horario establecido en el Plan de Estudios de la carrera para esta asignatura, se establece que se de cómo máximo 10 horas por semana distribuidas en teorías, prácticos de aula y laboratorio y consultas, hasta completar las horas correspondientes del Crédito Horario Total de la asignatura (135 hs.), es decir, se ha adaptado el crédito horario semanal para cubrir en 14 semanas el crédito total del curso.
|
XIV - Otros |
---|
|