Computability, Complexity & Algorithms - Georgia Tech

Course

Online

Free

Description

  • Type

    Course

  • Methodology

    Online

  • Start date

    Different dates available

Learn tools and techniques that will help you recognize when problems you encounter are intractable and when there an efficient solution.

Facilities

Location

Start date

Online

Start date

Different dates availableEnrolment now open

Questions & Answers

Add your question

Our advisors and other users will be able to reply to you

Who would you like to address this question to?

Fill in your details to get a reply

We will only publish your name and question

Reviews

Subjects

  • Algorithms
  • Duality
  • Maximum Flow
  • Turing Machines
  • Computability

Course programme

Approx. 0

Built by Join thousands of students Course Summary

This class is offered as CS6505 at Georgia Tech where it is a part of the Online Masters Degree (OMS). Taking this course here will not earn credit towards the OMS degree.

In this course, we will ask the big questions, “What is a computer? What are the limits of computation? Are there problems that no computer will ever solve? Are there problems that can’t be solved quickly? What kinds of problems can we solve efficiently and how do we go about developing these algorithms?” Understanding the power and limitations of algorithms helps us develop the tools to make real-world computers smarter, faster and safer.

Why Take This Course?

You will learn a wealth of tools and techniques that will help you recognize when problems you encounter in the real-world are intractable and when there an efficient solution. This can save you countless hours that otherwise would have been spent on a fruitless endeavor or in re-inventing the wheel.

Prerequisites and Requirements

Students are expected to have a solid grasp of the basics of discrete mathematics. Discrete Mathematics and Its Applications by Ken Rosen provides an excellent background for this course.

If you answer “no” to any of the following questions, it may be beneficial to acquire background knowledge concurrently or prior to taking the course.

  1. Can you show that the sum of the first n numbers is n(n+1)/2? Can you give the proof as an induction on n?
  2. Can you give an O(n log n) algorithm for sorting n numbers?
  3. Can you describe the difference between breadth-first and depth-first search?
  4. Given an nxn matrix A and an n-dimensional vector b, can you give a polynomial-time algorithm to find a vector x such that Ax=b?

See the Technology Requirements for using Udacity.

Syllabus Lesson 1: Computability
  • Languages & Countability
  • Turing Machines
  • The Church-Turing Thesis
  • Universality
  • Undecidability
Lesson 2: Complexity
  • P and NP
  • NP-Completeness
  • NP-Complete Problems
  • The Golden Ticket
Lesson 3: Algorithms
  • Dynamic Programming
  • Fast Fourier Transform
  • Maximum Flow
  • Maximum Bipartite Matching
  • Linear Programming
  • Duality
  • Randomized Algorithms
  • Approximation Algorithms

Computability, Complexity & Algorithms - Georgia Tech

Free