Los problemas de optimización discreta aparecen en una gran cantidad de dominios que van desde ingeniería, logística, bioinformática, razonamiento probabilístico, asignación de recursos, programación, etc.
En este curso aprenderemos a identificar, modelar y resolver este tipo de problemas. Usaremos el famoso enfoque declarativo en el que el usuario modela el problema con un lenguaje genérico y luego usa una biblioteca genérica de técnicas de resolución.
Para este curso usaremos el lenguaje de modelado MiniZinc y presentaremos tres paradigmas de resolución que se pueden usar con él: satisfacibilidad booleana, programación de restricciones y programación lineal entera. De cada uno cubriremos su poder expresivo y las principales intuiciones detrás de sus técnicas de resolución.
La orientación del curso es esencialmente práctica. Aprenderemos principalmente a través de ejemplos, aunque también se incluirán algunas ideas teóricas.
Profesorado
Responsable
Francisco Javier Larrosa Bondia (
)
Horas semanales
Teoría
1
Problemas
1
Laboratorio
1
Aprendizaje dirigido
0
Aprendizaje autónomo
5.65
Objetivos
Capacidad para modelar problemas de optimización discreta y resolverlos con las herramientas más apropiadas
Competencias relacionadas:
CEA1,
CEA13,
CG1,
CT6,
Subcompetences:
Traducir un problema de optimización real a una especificación bien definida con un lenguaje formal
Satisfactibilidad Booleana para resolver problemas de optimización discreta
Programación con restricciones
Programación Lineal Entera
Búsqueda Local
Traducir un problema de optimización real a una especificación bien definida con un lenguaje formal
Satisfactibilidad Booleana para resolver problemas de optimización discreta
Programación con restricciones
Programación Lineal Entera
Búsqueda Local
Contenidos
Modelado de problemas combinatorios
Utilizaremos el lenguaje de modelado MiniZinc para modelar una amplia variedad de problemas. Abarcaremos temas como el modelado de problemas lineales, conjuntos, funciones y el manejo de simetrías, subexpresiones comunes, etc.
Resolucion con programacion con restricciones
Cubriremos temas como Look-ahead, heurísticas, consistencia local y restricciones globales.
Resolución con técnicas de Lógica Proposicional (SAT)
Cubriremos temas como la forma normal conjuntiva (CNF), resolución, propagación de clausulas unitarias y aprendizaje de cláusulas.
Resolución con programación lineal entera
Revisaremos el SIMPLEX y el Branch and Bound
Para la parte de modelado se utilizará el sistema de "flipped classroom" donde los estudiantes tendrán que ver videos y realizar pequeños proyectos. Las horas lectivas se utilizarán para resolver dudas y consolidar conocimientos.
Por la parte de técnicas de resolución se utilizará la metodología clásica de clase magistral y alguna clase de problemas.
Método de evaluación
A lo largo del curso se irán realizando pequeños proyectos con un peso conjunto del 20% de la nota final. También se hará un quizz al inicio del curso, un examen parcial y un examen final con un peso total del 80% de la nota
MiniZinc is a high-level constraint modelling language that allows you to easily express and solve discrete optimisation problems. https://www.minizinc.org/