# Zasady zaliczenia egzaminu z Programowania współbieżnego 2023 na podstawie referatu
###### tags: `PRW23` `pwit`
## Zasady
Zreferowanie wybranej publikacji z dziedziny programowania współbieżnego jest alternatywnym sposobem zaliczenia egzaminu, do którego uprawnieni są studenci posiadający
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 7, 8, 12 -- 15 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 (ZAREZERWOWANO)
* 16. Scheduling and work distribution
* 17. Data parallelism
* 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) (RESERVED)
* [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"
* Współbieżna implementacja drzew BST, [link](https://swapnil-pimpale.github.io/lock-free-BST/proposal.html)
## Przydział referatów
| Imię i nazwisko | Temat | Data |
|-----------------|-------| -----|
|Marcel Szelwiga | Współbieżna implementacja drzew BST | 7.02, g 12.15 |
|Javier Rábago Montero| Hopscotch hashing | 8.02, 1.15PM |
|Jakub Mikołajczyk | Priority queues | 7.02 g. 16.15 |