17-617: Programming Quantum Computers

Mondays and Wednesdays (5:00pm to 6:20pm @ 3SC 265) Recitation: Fridays (Zoom Only) Daniel Justice Joshmin Ray

Location

Class room is at 3SC 265. The class is in person but will also be streamed via Zoom. I encourage you to come to class and use Zoom as a fallback option.

Course Goals

Students will gain familiarity with current universal gate quantum computing tools and technology. Students will also become comfortable with several QC algorithms and their implementation on state of the art quantum computer simulators and hardware.

Grading

90% Homeworks/Quizzes, 10% Participation.

Quizzes

Each week a quiz will be given. The worst one will not be counted.

Prerequisites

Python, Jupyter Notebooks, Linear Algebra

Students will not need an understanding of quantum mechanics.

Note: The syllabus is subject to occasional change. This is especially the case in the latter half of the semester once your professors have become comfortable with the group’s overall skill level. Adequate notice will be given.

Basic course structure

Due to this being a mini, we will do our best to skirt into a new topic each and every day.

Schedule

Day 1 (08/26): Introduction
Day 2 (08/28): Qubits
Holiday (09/02): Labor Day
Day 3 (09/04): Multiple Qubits
Day 4 (09/09): Quantum Teleportation
Day 5 (09/11): BB84
Day 6 (09/16): Quantum Arithmetic and Logic
Day 7 (09/18): Universal Gates
Day 8 (09/23): Amplitude Amplification
Day 9 (09/25): Quantum Search
Day 10 (09/30): QFT: Quantum Fourier Transform
Day 11 (10/02): Shor’s Factoring Algorithm
Day 12 (10/07): Guest Lecture
Day 13 (09/25): Quantum Phase Estimation