Zaawansowane programowanie Field of study: Computer Science
Programme code: 08-N1INI12.2014

Module name: Zaawansowane programowanie
Module code: 08- IO1N-13-ZP
Programme code: 08-N1INI12.2014
Semester:
  • winter semester 2017/2018
  • summer semester 2016/2017
  • winter semester 2016/2017
Language of instruction: Polish
Form of verification: course work
ECTS credits: 4
Description:
Celem zajęć jest przygotowanie studentów do projektowania i implementacji poprawnych algorytmów współbieżnych. W trakcie zajęć studenci uzyskują wiedzę na temat problemów związanych z projektowaniem programów współbieżnych i zaawansowanych mechanizmów ich rozwiązywania. Dodatkowo studenci zdobędą niezbędną wiedzę dotyczącą podstaw projektowania efektywnych algorytmów równoległych.
Prerequisites:
Dobra znajomość podstaw programowania w językach Java, C i C++ (poziom podstawowy). Znajomość obsługi zintegrowanych środowisk programistycznych i podstawowych narzędzi programistycznych wspomagających tworzenie i testowanie oprogramowania.
Key reading:
(no information given)
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]
Potrafi pracować w zespole dwuosobowym i dokonuje właściwego podziału pracy [ZP-K_9]
K_1_A_I_K01 [1/5] K_1_A_I_K03 [1/5] K_1_A_I_K06 [1/5]
Potrafi wskazać i rozwiązać z zastosowaniem różnych mechanizmów synchronizacji typowe problemy w algorytmach współbieżnych, takie jak problem ucztujących filozofów, producenta i konsumenta, czytelników i pisarzy. [ZP-U_4]
K_1_A_I_U15 [1/5] K_1_A_I_U16 [1/5] K_1_A_I_W06 [2/5]
Potrafi zastosować mechanizmy takie jak zmienne i instrukcje atomowe, semafory, monitory i współbieżne struktury danych w implementacji programów współbieżnych. [ZP-U_5]
K_1_A_I_U15 [2/5] K_1_A_I_W06 [2/5] K_1_A_I_U17 [1/5]
Potrafi ocenić efektywność algorytmów równoległych za pomocą podstawowych miar, takich jak przyspieszenie, koszt i efektywność. Potrafi ocenić możliwe do uzyskania przyspieszenie na podstawie prawa Amdahla oraz Gustavsona. [ZP-U_6]
K_1_A_I_W09 [2/5] K_1_A_I_W10 [1/5]
Potrafi zaimplementować program równoległy dla modelu z pamięcią wspólną. [ZP-U_7]
K_1_A_I_U14 [1/5] K_1_A_I_U15 [1/5] K_1_A_I_W06 [2/5]
Potrafi skonstruować program rozproszony z zastosowaniem mechanizmu zdalnego wykonywania procedur i zna mechanizmy uzgadniania w algorytmach rozproszonych. [ZP-U_8]
K_1_A_I_W13 [1/5] K_1_A_I_U13 [1/5]
Ma szczegółową wiedzę na temat sposobów wykonywania programów i procesów współbieżnych i zna pojęcia takie jak proces, wątek, wykonanie w przeplocie, wykonanie równoległe. [ZP-W_1]
K_1_A_I_W04 [1/5] K_1_A_I_W07 [1/5] K_1_A_I_W12 [2/5] K_1_A_I_W06 [2/5]
Ma wiedzę na temat własności bezpieczeństwa i żywotności programów współbieżnych i potrafi zweryfikować, czy zadany algorytm współbieżny jest poprawny. [ZP-W_2]
K_1_A_I_W06 [3/5] K_1_A_I_W10 [2/5]
Ma wiedzę na temat problemu wzajemnego wykluczania i metod jego rozwiązania, i potrafi podać algorytmy jego rozwiązania (algorytmy Petersona, Dekkera i piekarniany). [ZP-W_3]
K_1_A_I_U15 [1/5] K_1_A_I_W06 [2/5]
Type Description Codes of the learning outcomes of the module to which assessment is related
Prace kontrolne [ZP_w_1]
Co najmniej jedno kolokwium sprawdzające wiedzę z tematyki poruszanej na wykładzie oraz realizowanej w ramach laboratoriów.
ZP-U_4 ZP-U_5 ZP-U_6 ZP-U_7 ZP-U_8 ZP-W_1 ZP-W_2 ZP-W_3
Projekt programistyczny [ZP_w_2]
Ocena zrealizowanego projektu aplikacji współbieżnej, w której zastosowano podstawowe mechanizmy kontroli jednoczesnego wykonania obliczeń przez odrębne wątki. Ocena uwzględnia poprawność, złożoność i efektywność wykonanego oprogramowania
ZP-K_9 ZP-U_5 ZP-U_6 ZP-U_7
Zaliczenie wykładu [ZP_w_3]
Test złożony z pytań wielokrotnego wyboru oraz zadań otwartych dotyczących tematów poruszanych na wykładach oraz laboratoriach.
ZP-U_4 ZP-U_5 ZP-U_6 ZP-U_7 ZP-U_8 ZP-W_1 ZP-W_2 ZP-W_3
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 [ZP_fs_1]
Podanie treści kształcenia w formie werbalnej z wykorzystaniem wizualizacji treści. Omówienie ważnych kwestii teoretycznych i praktycznych dotyczących programowania współbieżnego.
20
Zapoznanie się z tematyką prezentowaną podczas wykładów oraz przygotowanie się do laboratoriów związanych z wykładami.
15 Prace kontrolne [ZP_w_1] Zaliczenie wykładu [ZP_w_3]
laboratory classes [ZP_fs_2]
Przygotowanie studentów do tworzenia aplikacji współbieżnych we współczesnych językach programowania. Prezentacja i omówienie narzędzi wspierających realizację oprogramowania współbieżnego.
20
Rozwiązywanie zadań z poszczególnych tematów wraz z analizą rozwiązań już istniejących. Zrealizowanie projektu programistycznego z zastosowaniem prezentowanych na wykładach metod.
45 Projekt programistyczny [ZP_w_2]
Attachments
Module description (PDF)
Information concerning module syllabuses might be changed during studies.
Syllabuses (USOSweb)
Semester Module Language of instruction
(no information given)