Praxis der Multikern-Programmierung: Werkzeuge, Modelle, Sprachen

  • Typ: Vorlesung (V)
  • Semester: WS 15/16
  • Zeit: 19.10.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten


    22.10.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    26.10.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    29.10.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    02.11.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    05.11.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    09.11.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    12.11.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    16.11.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    19.11.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    23.11.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    26.11.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    30.11.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    03.12.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    07.12.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    10.12.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    14.12.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    17.12.2015
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    21.12.2015
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    07.01.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    11.01.2016
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    14.01.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    18.01.2016
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    21.01.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    25.01.2016
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    28.01.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    01.02.2016
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    04.02.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    08.02.2016
    14:00 - 15:30 wöchentlich
    50.34 Raum -118 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten

    11.02.2016
    15:45 - 17:15 wöchentlich
    50.34 Raum 131 50.34 INFORMATIK, Kollegiengebäude am Fasanengarten


  • Dozent: Martin Tillmann
    Prof.Dr. Walter Tichy
    Philip Pfaffe
  • SWS: 4
  • LVNr.: 24293
VoraussetzungenEmpfehlungen:

Grundlegende Kenntnisse in C/C++ oder Java, Betriebssysteme, Rechnerstrukturen und Softwaretechnik werden vorausgesetzt.

BeschreibungMultikern-Prozessoren mit mehreren Rechenkernen auf einem Chip werden zum üblichen Standard. Diese Vorlesung fokussiert auf die Vermittlung praktischer Fähigkeiten der Softwareentwicklung für parallele Systeme. Ausgewählte Prinzipien aus den Bereichen Programmiermodelle und -Sprachen, Entwurfsmuster sowie Fehlerfindung werden exemplarisch und ausführlich diskutiert. Das vermittelte Wissen wird anhand von praktischen Übungen und Fallstudien intensiv vertieft.
LehrinhaltMultikern-Prozessoren mit mehreren Rechenkernen auf einem Chip werden zum üblichen Standard. Diese Vorlesung fokussiert auf die Vermittlung praktischer Fähigkeiten der Softwareentwicklung für parallele Systeme. Ausgewählte Prinzipien aus den Bereichen Programmiermodelle und -Sprachen, Entwurfsmuster sowie Fehlerfindung werden exemplarisch und ausführlich diskutiert. Das vermittelte Wissen wird anhand von praktischen Übungen und Fallstudien intensiv vertieft.
Anmerkung

Die Veranstaltung wird derzeit nur im Wintersemester angeboten.

KurzbeschreibungBitte beachten Sie für weitere Informationen die Ilias-Seite.
ArbeitsbelastungVorlesung mit 4SWS und praktischem Programmierprojekt, 6 LP.

6 LP entspricht ca. 180 Arbeitsstunden, davon

ca. 60 Std. Präsenz

ca. 10 Std. Bearbeitung Übungsaufgaben

ca. 5 Std. Präsentationsvorbereitung

ca. 10 Std. Schriftliche Ausarbeitung

ca. 95 Std. Bearbeitung Programmierprojekt

ZielDie Teilnehmer beherrschen theoretische Grundlagen der Parallelprogrammierung, sie kennen die Konzepte von Sperren, Barrieren und gemeinsamem Speicher und können diese Konzepte zum Entwurf

paralleler Algorithmen anwenden. Sie beherrschen die Bedienung von unterstützenden Werkzeugen wie Profilern und Debuggern und können damit die Implementierungen paralleler Programme bewerten.

Insbesondere kennen die Teilnehmer die Konzepte diverser paralleler Programmierumgebungen wie z.B. Java, pthreads, OpenMP und OpenCL und sind in der Lage, mittels dieser komplexe parallele Programme zu entwerfen und zu implementieren. Weiterhin können sie alternative Programmierparadigmen wie beispielsweise nicht-blockierende Synchronisation, nachrichtenbasierte Koordination (z.B. Google Go) und heterogene Programmierung (OpenACC) erläutern.

Die Studierenden sind in der Lage, parallele Programme zu analysieren und dabei Optimierungspotenzial und Programmierfehler aufzudecken und zu verbessern. Sie können parallele Algorithmen bewerten und vergleichen sowie neue entwickeln.

Studierende sind in der Lage, sequentieller Software auf Parallelisierungspotenzial hin zu untersuchen und sie mit unterschiedlichen Technologien in ein paralleles Programm zu überführen. Dazu können sie die Stärken und Schwächen unterschiedlicher paralleler Hard- und Software-Plattformen bewerten und Aussagen über ihre Eignung für das gegebene Problem treffen.

Weiterhin haben die Teilnehmer demonstriert, dass sie fähig sind, sich in große, reale Projekte einzuarbeiten. Sie sind geübt in Teamarbeit, strukturierter Formulierung, Präsentation und schriftlicher

Ausarbeitung ihrer Ergebnisse.

PrüfungDie Erfolgskontrolle erfolgt in Form einer Erfolgskontrolle anderer Art nach § 4 Abs. 2 Nr. 3 SPO und besteht aus mehreren Teilaufgaben. Die Leistungsbewertung erfolgt anhand von Übungsblättern, Ergebnissen aus einem Programmierprojekt, einer Abschlusspräsentation und einem Abschlussbericht.