Multicore and Quantum Programming – MQP
Course Coordinator: Ilias Savvas, ECTS: 7.5, Semester: A (C)
Syllabus
The course will cover the following topics: introduction to parallel programming, design of parallel algorithms, directed acyclic graphs (DAGs) and Gantt charts, analysis-design-implementation of parallel programs, parallel programming at the CPU level using OpenMP, multi-core programming on graphics cards using CUDA and OpenACC, hybrid programming using all of the aforementioned techniques/tools simultaneously, introduction to quantum programming with qiskit, quantum gates, construction and execution of quantum circuits, implementation of basic quantum algorithms (Deutsch – Josza, Bernstein–Vazirani, Grover), machine learning algorithms on quantum computers.
Recommended Bibliography
- Berman, and J. L. Paul. Algorithms: Sequential, Parallel, and Distributed, Thomson, 2005
- Michael J. Quinn. Parallel Programming in C with MPI and OpenMP, McGraw Hill Higher Education, 2003
- Ananth Grama, Anshul Gupta, George Karypis, and Vipin Kumar. Introduction to Parallel Computing, Pearson/Addison Wesley, 2003
- Jason Sanders, and Edward Kandrot. “CUDA by Example: An Introduction to General-Purpose GPU Programming”, Addison-Wesley
- John Cheng, and Max Grossman. “Professional CUDA C Programming”, John Viky and Sons, Inc.
- Chang, Weng-Long, Vasilakos, Athanasios V. “Fundamentals of Quantum Programming in IBM’s Quantum Computers”, Springer, 2021
- Eleanor Rieffel and Wolfgang Polak. “Quantum Computing – A Gentle Introduction”, The MIT Press, 2011
- Michael A. Nielsen and Isaac L. Chuang. “Quantum Computation and Quantum Information”, Cambridge University Press, 2010
- Qiskit documentation, URL: https://qiskit.org/documentation/