Concurrent programming
Field of study: Computer Science
Programme code: W4-S2IN19.2020

Module name: | Concurrent programming |
---|---|
Module code: | W4-IN-S2-20-2-PW |
Programme code: | W4-S2IN19.2020 |
Semester: | winter semester 2021/2022 |
Language of instruction: | Polish |
Form of verification: | course work |
ECTS credits: | 2 |
Description: | The aim of the course is to introduce students to the subject of design and implementation of correct and efficient concurrent algorithms. The practical aspects of the presented issues are emphasized, and examples made using modern programming languages and tools are presented. |
Prerequisites: | (no information given) |
Key reading: | Ben-Ari, Mordechai, and Môtî Ben-Arî. Principles of concurrent and distributed programming. Pearson Education, 2006.
Herlihy, Maurice, and Nir Shavit. The art of multiprocessor programming. Morgan Kaufmann, 2011.
Czech, Zbigniew J. Introduction to parallel computing. Cambridge University Press, 2016.
Goetz, Brian, et al. Java concurrency in practice. Pearson Education, 2006. |
Learning outcome of the module | Codes of the learning outcomes of the programme to which the learning outcome of the module is related [level of competence: scale 1-5] |
---|---|
Has extended knowledge of the ways in which parallel and concurrent computing are performed on modern computers. [M_001] |
K_W02 [1/5] |
Has knowledge about the safety properties of concurrent programs and is able to verify that the given concurrent algorithm is correct. [M_002] |
K_W02 [1/5] |
Is able to identify and solve typical problems of concurrent computations. [M_003] |
K_W02 [1/5] |
Is able to assess the effectiveness of a parallel algorithm. [M_004] |
K_W02 [1/5] |
Type | Description | Codes of the learning outcomes of the module to which assessment is related |
---|---|---|
Final test. [W_001] | Students are tested on the knowledge gained during lectures and laboratory classes. The test consists of a number of closed and (optionally) open questions. |
M_001 |
Test. [W_002] | At least one test assessing the knowledge gained by students during laboratory classes. |
M_001 |
Programming assignment. [W_003] | An optional programming assignment (project) that checks the programming skills acquired during the course. |
M_001 |
Form of teaching | Student's own work | Assessment of the learning outcomes | |||
---|---|---|---|---|---|
Type | Description (including teaching methods) | Number of hours | Description | Number of hours | |
lecture [Z_001] | Presentation of the course material in spoken and written forms, supplemented with multimedia content. Emphasizing issues that are more difficult to understand and have deeper theoretical foundations. Engaging listeners by asking questions about the content presented. |
15 | Reading recommended books and articles. Analysis and repetition of lecture content. Preparation for the final test. |
15 |
Final test. [W_001] |
laboratory classes [Z_002] | Preparation of students to apply the knowledge in programming practice through the presentation of sample programs and programming tools. Discussion of the methodology by pointing out the key steps required to obtain correct and efficient solutions to typical concurrent programming problems. |
15 | Working on assignments. Studying the recommended literature. |
15 |
Test. [W_002] |
Attachments |
---|
Module description (PDF) |
Syllabuses (USOSweb) | ||
---|---|---|
Semester | Module | Language of instruction |
(no information given) |