# Zasady zaliczenia egzaminu z Programowania współbieżnego 2022 na podstawie referatu
###### tags: `PRW22` `pwit`
## Zasady
Zreferowanie wybranej publikacji z dziedziny programowania współbieżnego jest alternatywnym sposobem zaliczenia egzaminu, do którego zachęcam osoby posiadające
ocenę z ćwiczeń **4.0** lub wyższą.
Należy:
* wybrać jeden z poniższych artykułów lub rozdziałów
* slot czasowy 90. minut, najlepiej w dniach 13, 14, 16 lub 17 lutego (inne dni do indywidualnego ustalenia)
* zgłosić mi swój wybor mailowo (adres: pwit@cs.uni.wroc.pl). Przyjęcie zgłoszenia zostanie potwierdzone odpowiednim wpisem w tym dokumencie. Decyduje kolejność zgłoszeń.
Referaty zostaną przedstawione podczas zdalnego spotkania na teamsowym kanale wykładu. Można, a nawet trzeba, posługiwać się notatkami (np. zredagowanymi w hackmd.io) i własnymi rysunkami (ręcznie, np. w paincie). Należy założyć życzliwość, ale dociekliwość egzaminującego. Spotkania są otwarte, może w nich uczestniczyć każdy
## Tematy do zreferowania
### Rozdziały z TAoMP2e
* 6. Universality of Consensus
* ~~15. Priority queues~~ (ZAREZERWOWANE)
* 16. Scheduling and work distribution
* ~~17. Data parallelism~~ (ZAREZERWOWANE)
* 20. Transactional programming
Oprócz zreferowania wybranego rozdziału należy rozwiązań 2-3 zadania dowolnie wybrane spośród w nim zamieszczonych.
### Artykuły
#### Synchronizacja w Javie
* [David F. Bacon, Ravi B. Konuru, Chet Murthy, Mauricio J. Serrano, Thin locks: featherweight synchronization for Java, in: SIGPLAN Conference on Programming Language Design and Implementation, 1998](https://ei.cs.vt.edu/~cs5314/presentations/Group3PLDI.pdf)
* [Ole Agesen, David Detlefs, Alex Garthwaite, Ross Knippel, Y.S. Ramakrishna, Derek White, An efficient meta-lock for implementing ubiquitous synchronization, ACM SIGPLAN Notices 34 (10)(1999)](https://sci-hub.se/https://dl.acm.org/doi/10.1145/320385.320402)
* [Jeremy Manson, William Pugh, Sarita V. Adve, The Java memory model, in: Proceedings of the 32nd ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages, POPL ’05 ](https://sci-hub.se/https://dl.acm.org/doi/10.1145/1040305.1040336)
#### Pozostałe
* [Maurice Herlihy, Nir Shavit, On the nature of progress, in: Proceedings of the 15th International Conference on Principles of Distributed Systems, OPODIS’11, Springer-Verlag, Berlin, Heidelberg, 2011](https://www.cs.tau.ac.il/~shanir/progress.pdf)
* [Maurice Herlihy, Nir Shavit, Moran Tzafrir, Hopscotch Hashing, in: DISC 2008: Distributed Computing](https://people.csail.mit.edu/shanir/publications/disc2008_submission_98.pdf)
* [James E. Burns, Gary L. Peterson, Constructing multi-reader atomic values from non-atomic values, in: PODC ’87: Proceedings of the Sixth Annual ACM Symposium on Principles of Distributed Computing,](https://sci-hub.se/https://dl.acm.org/doi/abs/10.1145/41840.41859). Alternatywna, względem pokazanej na wykładzie, konstrukcja rejestru MRSW.
* [Clyde P. Kruskal, Larry Rudolph, Marc Snir, Efficient synchronization of multiprocessors with shared memory, ACM Transactions on Programming Languages and Systems 10 (4) 1988](https://courses.cs.washington.edu/courses/csep524/02au/kruskal.pdf) Artykuł ma znaczenie historyczne, wprowadza pojęcie rejestrów RMW i pokazuje ich zastosowanie we wczesnych komputerach wieloprocesorowych.
#### Pozostałe (trudniejsze)
* [Danny Dolev, Nir Shavit, Bounded concurrent time-stamping, SIAM Journal on Computing 26 (2) (1997)](https://groups.csail.mit.edu/tds/papers/Shavit/sicomp97.pdf). Wstępem do artykułu powinna być lektura rozdziału 2.8 TAoMP2e
* [Sibsankar Haldar, Paul Vitányi, Bounded concurrent timestamp systems using vector clocks, Journal of the ACM 49 (1) (2002)](https://homepages.cwi.nl/~paulv/papers/timestampfinal.pdf). Wstępem do artykułu powinna być lektura rozdziału 2.8 TAoMP2e
#### Temat własny
Można też zaproponować temat własny. Zastrzegam sobie prawo do odmowy lub do doprecyzowania zakresu referatu.
* ~~Efektywne haszowanie współbieżne: wokół pracy "Algorithmic Improvements for Fast Concurrent Cuckoo Hashing"~~ (ZAREZERWOWANE)
## Przydział referatów
| Imię i nazwisko | Temat | Data |
|-----------------|-------| -----|
| Marcin Wróbel |TAoMP2e 15. Priority queues | czwartek, 16 lutego, g. 12.30|
| Mikołaj Depta | Efektywne haszowanie współbieżne: wokół pracy "Algorithmic Improvements for Fast Concurrent Cuckoo Hashing"| piątek, 17 lutego g. 12.30 |
| Wiktor Bukowski | TAoMP2e 17. Data parallelism | czwartek, 16 lutego, g. 18.00