Skip to content

Skablop/Syllabus

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

66 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

IIC2233 - Programación Avanzada

Tabla de contenidos

Calendario

Todas las actividades (AC) son evaluadas. La ausencia a clases implica un 1.0 en las evaluaciones de ese día.

Agosto

Día Evento Contenido Información adicional
Jueves 04 AC00 Primer día de clases
Lunes 08 Ayudantía 1 Cómo pasar el curso
Jueves 11 AC01 OOP + properties
Lunes 15 - Feriado 🎉
Jueves 18 AC02 Herencia - Polimorfismo - Abstract

Septiembre

Día Evento Contenido Información adicional

Octubre

Día Evento Contenido Información adicional

Noviembre

Día Evento Contenido Información adicional

Diciembre

Día Evento Contenido Información adicional
Viernes 2 9:00 AM Final Exam Por anunciar Salas: Por anunciar

Notas

Extracto del programa del curso

Equipo

Profesores

Nombre Sección Github Email
Cristian Ruz 1 @cruz [email protected]
Christian Pieringer 2 @cpieringer [email protected]
Ivania Donoso 3 @indonoso [email protected]

Ayudantes Jefes

Nombre Área Github Email
Bastián Mavrakis Coordinación @bamavrakis [email protected]
Antonio Ossa Docencia @aaossa [email protected]
Matías Jünemann Tareas @mjjunemann [email protected]
Florencia Barrios Tareas @flobarrios [email protected]

Ayudantes Mentores

Nombre Área Github Email
Florencia Valladares Docencia @fvr1 [email protected]
María José Hidalgo Docencia @cotehidalgov [email protected]
Benjamín Kramm Docencia @btkramm [email protected]
Freddie Venegas Docencia @fgvenegas [email protected]
Rodolfo Palma Tareas @rpalmaotero [email protected]
Felipe Pezoa Tareas @mainscientist [email protected]

Ayudantes TPD

Nombre Área Github Email
Anders Skog Docencia @andersskog [email protected]
Joaquín Tagle Docencia @jtagle2 [email protected]
Felipe Haase Docencia @felipehv [email protected]
Juan Cortés Docencia @jicortes2 [email protected]
Nicolás Falconi Docencia @nigfasa [email protected]
Matías Andrade Docencia @mandrade2 [email protected]
Hernán Valdivieso Tareas @Hernan4444 [email protected]
Isidora Palma Tareas @isipalma [email protected]
Matias Eynaudi Tareas @Mieynaudi [email protected]
Manuel Silva Tareas @ManuelSIlvaCav [email protected]
Javier Montoya Tareas @jgmontoya [email protected]
Cristian Cortés Tareas @criscv94 [email protected]
Fernando Pieressa Tareas @FernandoPieressa [email protected]
Andrés Mardones Tareas @agmardones [email protected]
Stephanie Chau Tareas @stephichau [email protected]

Descripción del curso

Este curso enseña técnicas para diseñar, implementar, ejecutar y evaluar herramientas de software que resuelven problemas algorítmicos a partir de especificaciones detalladas. En particular, el curso enseña construcciones avanzadas de programación orientada a objetos, estructuras de datos fundamentales, diseño básico de algoritmos y técnicas de análisis.

Objetivos

  1. Descomponer problemas complejos para diseñar y estructurar sus soluciones.
  2. Crear diseños orientados a objetos y comunicar estos diseños a través de documentación externa y comentarios en el código.
  3. Aplicar conceptos de orientación a objetos (herencia, polimorfismo, interfaces) y estructuras de datos fundamentales (listas ligadas, stacks, colas, árboles binarios y tablas de hash), para diseñar y escribir aplicaciones en el lenguaje de programación Python, pudiendo extender este conocimiento a distintos lenguajes.
  4. Fomentar el uso de:
    • herramientas de programación estándares para el desarrollo de software como entornos de desarrollo, debuggers y sistemas de control de versiones;
    • técnicas de programación como bibliotecas de programación orientada a objetos y pruebas unitarias;
    • y entornos de desarrollo de software para editar, compilar, y depurar programas.
  5. Generar software desde cero, con código de alto nivel, de fácil re­utilización, actualización y mantenimiento. Incluyendo el uso interfaces gráficas totalmente funcionales.

Contenidos

  • Programación Orientada a Objetos:
    • Objetos
    • Herencia
    • Herencia múltiple
    • Polimorfismo
    • Clases Abstractas
    • Properties.
  • Estructuras de Datos:
    • Árboles
    • Diccionarios
    • Colas
    • Stacks
    • Sets
  • Funciones de Python y Programación Funcional:
    • Algunas funciones especiales de Python
    • Comprensión de listas
    • Iterables e iteradores
    • Generadores
    • Funciones lambda
    • Map
    • Reduce
    • Filter
    • Decoradores
  • Meta Clases:
    • Comprender la lógica detrás de la construcción y creación de clases
  • Manejo de Excepciones:
    • Tipos de excepciones
    • Control de excepciones
  • Testing:
    • Tests unitarios en Unittest
  • Simulación:
    • Introducción a la simulación con eventos discretos
  • Threading:
    • Creación y sincronización de threads
    • Concurrencia
  • Interfaces Gráficas:
    • Introducción a las interfaces gráficas usando PyQt4
  • I/O:
    • Manejo de Strings
    • Bytes
    • Serialización binaria
    • Serialización en formato JSON
  • Networking:
    • ​Sockets, cliente, servidor
  • Webservices:
    • REST API
    • Regex

Evaluación

  1. Las evaluaciones serán efectuadas por medio de actividades prácticas en clases, controles (de materia y/o lecturas adicionales), tareas y un examen final. Se calculará la nota del curso NC como:

    NC = 0.2 * FE + 0.4 * T + 0.25 * AC + 0.15 * C

    Donde FE es la nota del examen final, T es el promedio de las tareas, AC es el promedio de las actividades en clases sin incluir la peor de ellas, y C es el promedio de los controles.

  2. Adicionalmente, para aprobar el curso el alumno debe cumplir con:

    • FE debe ser mayor o igual a 3.500
    • AC debe ser mayor o igual a 3.700
    • T debe ser mayor o igual a 3.950
  3. Si el alumno cumple con todas las condiciones mencionadas, la nota final del curso (NF) corresponde a NC. En caso contrario, NF es la nota mínimo entre los items no cumplidos.

  4. La inasistencia a alguna de las actividades en clases se evalúa con nota 1.0, pero para el cálculo final de este ítem se eliminará la nota más baja

  5. Solo se aproximará la nota final NF. Todo el resto de las notas serán usadas con tres decimales.

  6. Durante el semestre NO se borrará ninguna otra evaluación, lo que incluye T, AC, FE, C.

  7. El Examen final es obligatorio, no hay eximición. La inasistencia al Examen es reprobatoria.

Wiki

Toda la información que subiremos se encontrará en la Wiki del repositorio.

Foro

La página de Issues se utilizará como foro para preguntas.

Semestres Anteriores

Puedes ver los syllabus de los semestres anteriores en:

About

Repositorio principal del curso

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 99.7%
  • Other 0.3%