1. To support our site, MoocLab may be compensated by some course providers through affiliate links.
  2. We're here to help you stay connected and progress together. Read about MoocLab's response to COVID-19 ►

    Dismiss Notice

Coursera Approximation Algorithms Part I

École normale supérieure via Coursera

  • Overview
  1. Coursera
    Platform:
    Coursera
    Provider:
    École normale supérieure
    Length:
    5 weeks
    Language:
    English
    Credentials:
    Paid Certificate Available
    Overview
    How efficiently can you pack objects into a minimum number of boxes? How well can you cluster nodes so as to cheaply separate a network into components around a few centers? These are examples of NP-hard combinatorial optimization problems. It is most likely impossible to solve such problems efficiently, so our aim is to give an approximate solution that can be computed in polynomial time and that at the same time has provable guarantees on its cost relative to the optimum.

    This course assumes knowledge of a standard undergraduate Algorithms course, and particularly emphasizes algorithms that can be designed using linear programming, a favorite and amazingly successful technique in this area. By taking this course, you will be exposed to a range of problems at the foundations of theoretical computer science, and to powerful design and analysis techniques. Upon completion, you will be able to recognize, when faced with a new combinatorial optimization problem, whether it is close to one of a few known basic problems, and will be able to design linear programming relaxations and use randomized rounding to attempt to solve your own problem. The course content and in particular the homework is of a theoretical nature without any programming assignments.

    This is the first of a two-part course on Approximation Algorithms.

    Syllabus
    Vertex cover and Linear Programming
    We introduce the course topic by a typical example of a basic problem, called Vertex Cover, for which we will design and analyze a state-of-the-art approximation algorithm using two basic techniques, called Linear Programming Relaxation and Rounding. It is a simple, elementary application of powerful techniques.

    Knapsack and Rounding
    This module shows the power of rounding by using it to design a near-optimal solution to another basic problem: the Knapsack problem.

    Bin Packing, Linear Programming and Rounding
    This module shows the sophistication of rounding by using a clever variant for another basic problem: bin packing. (This is a more advanced module.)

    Set Cover and Randomized Rounding
    This module introduces a simple and powerful variant of rounding, based on probability: randomized rounding. Its power is applied to another basic problem, the Set Cover problem.

    Multiway Cut and Randomized Rounding
    This module deepens the understanding of randomized rounding by developing a sophisticated variant and applying it to another basic problem, the Multiway Cut problem. (This is a more advanced module.)

    Taught by
    Claire Mathieu

Share This Page



  1. This site uses cookies to help personalise content, tailor your experience and to keep you logged in if you register.
    By continuing to use this site, you are consenting to our use of cookies.
    Dismiss Notice