Optimization is a common form of decision making, and is ubiquitous in our society. Its applications range from solving Sudoku puzzles to arranging seating in a wedding banquet. The same technology can schedule planes and their crews, coordinate the production of steel, and organize the transportation of iron ore from the mines to the ports. Good decisions in manpower and material resources management also allow corporations to improve profit by millions of dollars. Similar problems also underpin much of our daily lives and are part of determining daily delivery routes for packages, making school timetables, and delivering power to our homes. Despite their fundamental importance, all of these problems are a nightmare to solve using traditional undergraduate computer science methods.



Advanced Modeling for Discrete Optimization


Instructors: Prof. Jimmy Ho Man Lee
Top Instructor
Access provided by Jala
19,426 already enrolled
(139 reviews)
Skills you'll gain
Details to know

Add to your LinkedIn profile
See how employees at top companies are mastering in-demand skills

There are 5 modules in this course
Similar to computer programs, models can have bugs. In this module, you will see the symptoms (unsatisfiability, too many solutions, too few solutions) of different bugs, and learn methods to discover what is going wrong with your model and how to fix it. Equipped with these tools, you will be able to develop and debug complex models.
What's included
22 videos5 readings1 programming assignment
In this module, you will learn how to encapsulate a complex constraint definition in a predicate definition to enable its reuse. This will enable the construction of far more complex models with improved readability in a modular manner. You will also encounter for the first time a problem with multiple objectives and learn how to compress them into one single objective. In addition to this, you will learn how to model the banquet seating problem, which will assist you in many occasions in life.
What's included
6 videos1 reading1 programming assignment
Learn how to tackle complex project scheduling problems of various forms, progressively from ones with only basic precedence requirements to ones with unary resources and even cumulative resources. You will see how to model some of the complex constraints that arise in these applications.
What's included
7 videos1 reading1 programming assignment
In this module, you will learn the important application of packing, from the packing of squares to rectilinear shapes with and without rotation. Again, you will see how to model some of the complex constraints that arise in these applications.
What's included
3 videos
This final module looks at the various forms of symmetries that can appear in discrete optimization problems. You will learn various methods and special constraints to break such symmetries so as to increase solving efficiency. You will also learn the notion of dominance, which is a generalization of symmetries, and also dominance breaking techniques.
What's included
6 videos2 readings1 programming assignment
Instructors


Offered by
Why people choose Coursera for their career




Learner reviews
139 reviews
- 5 stars93.52% 
- 4 stars6.47% 
- 3 stars0% 
- 2 stars0% 
- 1 star0% 
Showing 3 of 139
Reviewed on Jan 31, 2021
Excellent course overall with difficult assignments.Learned heaps thanks
Reviewed on Feb 20, 2018
Great course! Good presentation and lectures, challenging assignments. Learned a lot
Reviewed on Aug 27, 2020
Great course! Engaging content and not-so-easy assignments to make you understand the subject better. Thanks Prof. Stuckey and Prof. Lee for making this course available on Coursera!
Explore more from Computer Science
 - The Chinese University of Hong Kong 
 - The Chinese University of Hong Kong 
 - University of Minnesota 
 - University of Minnesota 

