Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)
*** Seminars will be organized during both the winter and summer semesters (October to April). We ask all students who wish to participate in this course to contact the teachers before winter semester starts (middle of September) at the latest. Information about seminars will be send to all who have applied. ***
Become familiar with basic programming technologies, data structures and algorithms. Learn to write clear and easily maintained computer programs. The course will focus on Fortran 90/95 programming language and its latest generations (Fortran 2003/2018). Generally become familiar with the characteristics and possibilities of other computer languages such as C/C++ and Python, for example, and techniques for interoperation of these languages. Become familiar with the concepts of paralelization (MPI and OpenMP).
Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)
*** Výuka bude probíhat formou nepravidelných seminářů v období říjen - duben. Prosíme všechny zájemce o tento předmět, aby se nejpozději do začátku zimního semestru ozvali garantům předmětu. Termíny seminářů budou se zájemci domluveny následně. ***
Seznámit se základními programovacími technologiemi, datovými strukturami a algoritmy. Naučit se vytvářet přehledné a snadno udržovatelné programy. Důraz bude kladen na programovací jazyk Fortran 90/95 i jeho novější varianty (Fortran 2003/2018). Rámcově se seznámit s charakteristikami a možnostmi použití dalších jazyků (C/C++, Python) a jejich vzájemného propojení. Seznámit se s technikami pro paralelizaci programů (MPI, OpenMP).
Aim of the course -
Last update: Grof Zdeněk doc. Ing. Ph.D. (21.06.2022)
The student will be able to
focus on the most important programming technologies
write concise, clear, and easily maintainable computer programs and use the programming handwriting
use modern Fortran programming language
read and understand programs written in C, C++, and Python
design and use complex data structures
analyze and implement algorithms for various purposes
parallelize programs by using the MPI
Last update: Grof Zdeněk doc. Ing. Ph.D. (21.06.2022)
Student bude umět
orientovat se v nejdůležitějších programovacích technologiích
vytvářet přehledné a snadno udržovatelné programy a používat programátorský rukopis
používat jazyk Fortran v jeho moderní formě
číst programy v jazycích C, C++ a Python
používat a navrhovat složitější datové struktury
teorii a implementaci algoritmů pro různé účely
základy paralelizace programů pomocí MPI
Literature -
Last update: Grof Zdeněk doc. Ing. Ph.D. (21.06.2022)
Curcic M: Modern Fortran - Building efficient parallel applications, Manning, 2020.
Metcalf M, Reid J, Cohen M: Modern Fortran explained: icorporating Fortran 2018, Oxford University Press, 2018.
Clerman N S, Spector W: Modern Fortran: style and usage, Cambridge University Press, 2012.
Ray S, Fortran 2018 with parallel programming, CRC Press, 2020.
Horton I: Ivor Horton's Beginning Visual C++ 2013, Willey, 2014.
Chacon S, Straub B, Pro Git, Apres, 2014. [open source, dostupné z https://git-scm.com/book]
Vaněk T.: Přednášky pro předmět PPPT, 2017. [elektronická forma, dostupné na e-learningu]
Další literatura z internetových zdrojů (programovací jazyky: manuály, tutoriály, apod.)
Syllabus -
Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)
1. Introduction, data representation, programming in Fortran I.
2. Programming in Fortran II.
3. Programmer's handwriting, teamwork in software writing, version control systems (git and github).
4. Data structures (array, list, stack, queue). Use of pointers and basic principles of OOP.
5. Recursion, divide and conquer algorithms, sorting algorithms, searching for an exit from a labyrinth.
6. Parallelization with MPI I.
7. Parallelization with MPI II.
8. Python and C++ programming languages and their binding with Fortran programs.
Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)
1. Úvod, reprezentace dat v paměti, programováni ve Fortranu I.
2. Programování ve Fortranu II.
3. Programátorský rukopis, týmová spolupráce při tvorbě programů a správa verzí (git a github)
4. Datové struktury (např. pole/array, seznam/list, hromada/stack, fronta/queue). Používáni pointerů a základní prvky OOP.
5. Rekurze, algoritmy typu "Rozděl a vyřeš", řadící algoritmy, hledání cesty v labyrintu.
6. Paralelizace programů pomocí MPI I.
7. Paralelizace programů pomocí MPI II.
8. Programovací jazyky Python, C++ a jejich propojení s programy ve Fortranu.
Registration requirements -
Last update: Grof Zdeněk doc. Ing. Ph.D. (21.06.2022)
Students with basic programming skills (programming in Fortran, C, Matlab, or Python, for example) and general knowledge of programming technologies and algorithms will have an advantage.
However, the course schedule will allow the students to catch up on their missing knowledge by a self-study or consultations.
Last update: Grof Zdeněk doc. Ing. Ph.D. (21.06.2022)
Základní zkušenosti s programováním (například v jazycích Fortran, C, Matlab, Python) a obecné povědomí o programovacích technologiích a algoritmech budou výhodou, ale ne nezbytnou.
Předpokládáme, že v průběhu kurzu budou mít studenti dostatek času doplnit si připadné mezery samostudiem nebo konzultacemi.
Course completion requirements -
Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)
Development of programming projects that will be handed out during the seminars.
A final discussion on submitted projects.
Last update: Grof Zdeněk doc. Ing. Ph.D. (08.07.2021)