• A
  • A
  • A
  • ABC
  • ABC
  • ABC
  • А
  • А
  • А
  • А
  • А
Regular version of the site
Master 2019/2020

Discrete Optimization

Type: Elective course (Mathematical Methods of Modelling and Computer Technologies)
Area of studies: Applied Mathematics and Informatics
When: 1 year, 3 module
Mode of studies: distance learning
Instructors: Evgeny Vybornyi
Master’s programme: Mathematical Methods of Modelling and Computer Technologies
Language: English
ECTS credits: 3
Contact hours: 2

Course Syllabus

Abstract

Tired of solving Sudokus by hand? This course teaches how to solve complex search problems with discrete optimization concepts and algorithms, including constraint programming, local search, and mixed-integer programming. Optimization technology is ubiquitous in our society. It schedules planes and their crews, coordinates the production of steel, and organizes the transportation of iron ore from the mines to the ports. Optimization clears the day-ahead and real-time markets to deliver electricity to millions of people. It organizes kidney exchanges and cancer treatments and helps scientists understand the fundamental fabric of life, control complex chemical reactions, and design drugs that may benefit billions of individuals. This class is an introduction to discrete optimization and exposes students to some of the most fundamental concepts and algorithms in the field. It covers constraint programming, local search, and mixed-integer programming from their foundations to their applications for complex practical problems in areas such as scheduling, vehicle routing, supply-chain optimization, and resource allocation.
Learning Objectives

Learning Objectives

  • The objective of this course is to form a foundation of discrete optimization.
Expected Learning Outcomes

Expected Learning Outcomes

  • On completion of the course, the student should know the fundamental concepts and algorithms in discrete optimization .
Course Contents

Course Contents

  • Introduction
    These lectures and readings give you an introduction to this course: its philosophy, organization, and load. They also tell you how the assignments are a significant part of the class. This topic covers the common input/output organization ofthe assignments, how they are graded, and how to succeed in this class.
  • Knapsack
    These lectures introduce optimization problems and some optimization techniques through the knapsack problem, one of the most well-known problem in the field. It discusses how to formalize and model optimization problems using knapsack as an example. It then reviews how to apply dynamic programming and branch and bound to the knapsack problem, providing intuition behind these two fundamental optimization techniques. The concept of relaxation and search are also discussed
  • Constraint Programming
    Constraint programming is an optimization technique that emerged from the field of artificial intelligence. It is characterized by two key ideas: to express the optimization problem at a high level to reveal its structure and to use constraints to reduce the search space by removing, from the variable domains, values that cannot appear in solutions. These topic cover constraint programming in detail, describing the language of constraint programming, its underlying computational paradigm and how it can be applied in practice
  • Local Search
    Local search is probably the oldest and most intuitive optimization technique. It consists in starting from a solution andimproving it by performing (typically) local perturbations (often called moves). Local search has evolved substantially in the last decades with a lot of attention being devoted on which moves to explore. These lectures explore the theory and practice of local search, from the concept of neighborhood and connectivity to meta-heuristics such as tabu search and simulated annealing
  • Linear Programming
    Linear programming has been, and remains, a workhorse of optimization. It consists in optimizing a linear objective subject to linear constraints, admits efficient algorithmic solutions, and is often an important building block for other optimization techniques. These lectures review fundamental concepts in linear programming, including the infamous simplex algorithm, simplex tableau, and duality
  • Mixed Integer Programming
    Mixed Integer Programming generalizes linear programming by allowing integer variables, which dramatically changes the complexity of the problems but also broadens the potential applications significantly. These lectures review how to model problems in mixed-integer programming and how to solve mixed-integer programs using branch and bound. Advanced techniques such as cutting planes and polyhedral cuts are also covered
  • Advanced Topics: Part I
    These lectures cover some more advanced concepts in optimization. They introduce constraint-programming techniques for scheduling and routing
  • Advanced Topics: Part II
    These lectures continue to cover some more advanced concepts in optimization. They introduce large neighborhood search, which often combines constraint programming and 3local search, and column generation which decomposes an optimization model into a master and pricing problem, using more complex variables.
Assessment Elements

Assessment Elements

  • non-blocking Exam
  • non-blocking Assessment obtained on the platform https://www.coursera.org/learn/discrete-optimization
Interim Assessment

Interim Assessment

  • Interim assessment (3 module)
    0.5 * Assessment obtained on the platform https://www.coursera.org/learn/discrete-optimization + 0.5 * Exam
Bibliography

Bibliography

Recommended Core Bibliography

  • Дискретная оптимизация. Модели, методы, алгоритмы решения прикладных задач: Учебное пособие / Струченков В.И. - М.:СОЛОН-Пр., 2016. - 192 с.: ISBN 978-5-91359-181-4

Recommended Additional Bibliography

  • Kochetov Y, Pardalos P., Nurminski E., Beresnev V., Khachay M. Discrete Optimization and Operations Research \\ Springer \\https://www.springer.com/gp/book/9783319449135