Hasso-Plattner-InstitutSDG am HPI
Hasso-Plattner-InstitutDSG am HPI
Login
 

Softwarearchitektur (Wintersemester 2022/2023)

Dozent: Prof. Dr. Robert Hirschfeld (Software-Architekturen) , Patrick Rein (Software-Architekturen) , Eva Krebs (Software-Architekturen) , Marcel Taeumel (Software-Architekturen) , Dr. Jens Lincke (Software-Architekturen) , Stefan Ramson (Software-Architekturen) , Toni Mattis (Software-Architekturen)
Tutoren: Joana Bergsiek Rieke Freund Tom Braun Leonard Geier

Allgemeine Information

  • Semesterwochenstunden: 4
  • ECTS: 6
  • Benotet: Ja
  • Einschreibefrist: 01.10.2022 - 31.10.2022
  • Prüfungszeitpunkt §9 (4) BAMA-O: 09.02.2023
  • Lehrform: Vorlesung
  • Belegungsart: Pflichtmodul
  • Lehrsprache: Deutsch

Studiengänge, Modulgruppen & Module

IT-Systems Engineering BA

Beschreibung

Software-Entwicklung ist ein kreativer Prozess, in dem Ideen und Entscheidungen zwischen Entwicklern klar kommuniziert und über die Zeit dokumentiert werden müssen. In der Verwendung von Programmiersprachen und darüber hinaus haben sich Idiome, Entwurfsmuster, Frameworks und Architekturstile als hilfreich erwiesen.

Im Rahmen dieser Veranstaltung werden maßgebliche Vertreter dieser Kategorien für die objektorientierte Softwareentwicklung besprochen sowie zugehörige und weitergehende Konzepte und Ansätze vorgestellt.

Stichworte: Software-Architektur, Software-Design, objektorientierte Programmierung, Idiome, Entwurfsmuster, Architekturstile, Refactoring, Frameworks

Lehrinhalte

  • Modularity
  • Objects
  • Idioms
  • Design Patterns
  • Pattern Languages
  • Architectural Styles
  • Architecture Description Languages (ADLs)

Die Vorlesung wird in Präsenz im Hörsaal 2 stattfinden. Als Fallback wird es wenn möglich einen Stream per Zoom geben, gegebenenfalls in einer eingeschränkten Form gegenüber dem Präsenzformat.

Persönliche Kommunikation wird über Slack stattfinden. Alle für die Veranstaltung essenziellen Informationen werden außerdem per Moodle (siehe unten) kommuniziert. Die Kommunikationsmittel für die Projektarbeit kann individuell mit den Tutoren abgestimmt werden. Um einen Missbrauch der Kommunikationskanäle vorzubeugen bitten wir darum Ihren tatsächlichen Namen zu verwenden.

 

Wichtige Links

Voraussetzungen

Vertiefte Programmierkenntnisse in mindestens einer Programmiersprache.

Erfolgreiche Teilnahme an Programmiertechnik I und Programmiertechnik II.

Literatur

  • Erich Gamma, Richard Helm, Ralph E. Johnson, John Vlissides: Design Patterns - Elements of Reusable Object-Oriented Software. Addison-Wesley 1997
  • Martin Fowler: Refactoring - Improving the Design of Existing Code. Addison-Wesley 1999
  • Joshua Kerievsky: Refactoring to Patterns. Addison-Wesley 2004
  • Frank Buschmann, Regine Meunier, Hans Rohnert, Peter Sommerlad: Pattern-Oriented Software Architecture - A System of Patterns. John Wiley and Sons 1996
  • Mary Shaw and David Garlan. Software Architecture: Perspectives on an Emerging Discipline. Prentice-Hall, 1996.

Weitere Literatur wird jeweils gesondert bekannt gegeben.

Lern- und Lehrformen

Vorlesung mit Übungen/Seminaren

Leistungserfassung

Die Leistung wird zum einen durch die Erstellung und Präsentation einer Software-Anwendung, zum anderen durch eine schriftliche Prüfung von 90 Minuten Dauer erbracht. Beide Teile sind mit 50 % gewichtet; sie werden mit insgesamt 6 benoteten Leistungspunkten angerechnet. Zur erfolgreichen Teilnahme an der Lehrveranstaltung müssen beide Teile mit jeweils mindestens 4,0 benotet worden sein.

Im Rahmen einer Projektarbeit sollen Teilnehmer in kleinen Gruppen eine Anwendung entwerfen, implementieren und dokumentieren. Die Themen hierfür werden gestellt. Die Arbeit wird in einem Vortrag von 30 Minuten Dauer präsentiert, an den sich eine Diskussion anschließt. Beim Vortrag besteht für alle Mitglieder der vortragenden Gruppe Anwesenheitspflicht. Der Vortrag soll technische Aspekte der durchgeführten Arbeit als Demonstration beinhalten und mindestens die folgenden Aspekte des Projekts dokumentieren:

  • Architektur und Funktionsweise des Gesamtsystems,
  • Entwurfsentscheidungen,
  • Konsequenzen der getroffenen Entwurfsentscheidungen, und
  • zusammenfassende Bewertung des Projekts.

In Quellcode und Präsentation ist auf die korrekte Angabe aller verwendeten Quellen zu achten. Eine Eigenleistung muss erkennbar sein. Die Entdeckung von Plagiaten führt zu jedem Zeitpunkt zum sofortigen Nichtbestehen der jeweiligen Leistung.

Bis spätestens eine Woche vor dem jeweiligen Vortragstermin bespricht jede Gruppe eine Vorversion ihrer Vortragsunterlagen mit einem der Betreuer. Die Vortragsunterlagen sind spätestens 24 Stunden vor dem Vortrag über das elektronische Abgabesystem einzureichen. Sie bestehen aus

  • den Dokumentquellen der im Vortrag verwendeten Folien,
  • einer PDF-Version derselben,
  • dem vollständigen in der Demonstration verwendeten Quelltexte einschließlich der benötigten Ressourcen,
  • einer Installationsbeschreibung,
  • einem Demo-Script, und
  • einem Demo-Videoclip (screen cast).

Zudem bereitet jede Gruppe eine Diskussion der Architektur einer anderen, zugewiesenen Gruppe vor. Die Diskussion wird in einem fünfminütigen Vortrag im Anschluss an den Vortrag der zugewiesenen Gruppe vorgestellt.

Die erstellte Anwendung ist in ihrer endgültigen Version bis 23:59 Uhr am untenr Termine angegebenen Tag über das elektronische Abgabesystem einzureichen. Wird das Einreichen verlangter Dokumente bis zum jeweils angegebenen Datum und Zeitpunkt versäumt, so gelten diese als nicht eingereicht, was zur Abwertung der Gesamtleistung führt.

Alle im Rahmen der Veranstaltung erstellten Quelltexte und verwendeten Ressourcen sollen unter der MIT-Lizenz und, falls notwendig, mit einer den verwendeten Systemen kompatiblen Lizenz bereitgestellt werden.

Termine

Erster Termin:

  • 18. Oktober 2022 Onboarding, Einführung, Projektvorstellung

Vorlesungen und Übungen/Seminare

Gruppenbildung:

  • bis 23. Oktober 2022

Themenwahl:

  • bis 30. Oktober 2022

Klausur:

  • 9. Februar 2023

Projektabgabe

  • Die erwartete Bearbeitungszeit geht bis zum 10. Februar 2023. Um Teilnehmenden eine freiere Zeiteinteilung für letzte Feinschliffe zu ermöglichen, kann bis zum 17. Februar 2023 abgegeben werden.

Zurück