DVA Praktikum für Informatiker

Sommersemester 2024

Hubert Högl, <Hubert.Hoegl@tha.de>, https://tha.de/~hhoegl

URL: https://tha.de/~hhoegl/home/DVAINF_Praktikum

Moodle-Kurs SoSe2024: https://moodle.hs-augsburg.de/course/view.php?id=8018

Gitlab (nur mit VPN): https://gitlab.informatik.hs-augsburg.de/dva/berichte-2024

Kurzanleitung zur Vorbereitung (fasst den folgenden Text auf dieser Seite zusammen): https://hhoegl.informatik.hs-augsburg.de/dva/inf/DVAINF-TLDR.txt

Kurzübersicht Themen der vergangenen Jahre: https://hhoegl.informatik.hs-augsburg.de/dva/inf/Themen/index.html

Etherpad für die Planung der Themen: https://yopad.eu/p/dvainf24

Mitschnitt der Einführungsveranstaltung vom 26.3.20, 9:50-11:20, https://cloud.hs-augsburg.de/s/RdL8dim6FxgcGLB


Aktuelle Tipps

Sommer 2024

  • Benachrichtigungen von Moodle oder Gitlab werden an Ihre E-mail Adresse geschickt. Bitte lesen Sie deshalb regelmässig Ihre E-mails, mindestens ein mal am Tag!

Sommer 2023

  • Allen die etwas mit Containern zu tun haben sei das freie Buch „Podman in Action“ empfohlen:

    https://developers.redhat.com/e-books/podman-action

    Podman ist eine Neuimplementierung von Docker die komplett Open-Source ist und einige Vorteile zu Docker bietet. Man kann alles was man in Docker auf der Kommandozeile gewohnt ist auch genauso in Podman eingeben.


Die Betreuung erfolgt durch

  • Hubert Högl (HH)

  • Volodymyr Brovkov (VB)

Ziele

Das DVA Praktikum für Informatiker hat zum Ziel, dass Sie mit möglichst vielen Gebieten der Informatik in praktischen Kontakt kommen. Aus einer Themenliste (siehe Abschnitt Versuche) werden Sie ein Semester lang alle ein bis zwei Wochen einen neuen Versuch bearbeiten. Die technische Schwierigkeit steht dabei wegen der kurzen Bearbeitungszeit nicht im Vordergrund. Die Versuche werden eher leichte bis mittlere Anforderungen stellen.

Die Veranstaltung zählt mit 5 Creditpoints, das heisst der Arbeitswaufwand liegt bei 150 Stunden je Teammitglied (45 Std. Präsenz, 105 Std. Selbststudium).

Termine

Die Termine und Einteilungen finden Sie im Moodle Kurs.

Ablauf

http://hhoegl.informatik.hs-augsburg.de/dva/workflow/workflow1.png

Diese Menschen und Dienste sind beim DVA Praktikum beteiligt.

Die Studentinnen und Studenten werden in Teams eingeteilt, jedes Team hat in etwa vier bis sechs Mitglieder. Jedes Team sucht sich einen Versuch aus und bearbeitet ihn in der vorgegebenen Bearbeitungszeit (in der Regel zwei Wochen, gelegentlich auch nur eine Woche). Am Ende der Bearbeitungszeit wird der Versuch präsentiert Legen Sie Wert auf eine gute Versuchsvorführung, das macht die Präsentation lebhaft. In der Regel werden zur Vorführung und zum Bericht von ihren Betreuern Verbesserungsvorschläge gemacht, die innerhalb der darauffolgenden Woche umgesetzt werden müssen.

Jedes Team schreibt im Semester einen einzigen Bericht, der für jeden Versuch ein Kapitel enthält. Am Ende der Bearbeitungszeit eines Versuches muss der Bericht aktualisiert sein. Der Bericht wird mit Sphinx geschrieben und in einem Gitlab Repository fortlaufend aktualisiert. Der Bericht existiert nur in elektronischer Form. Auch die pro Versuch angefertigten Quelltexte und sonstigen notwendigen Dateien werden in gitlab abgespeichert.

In der Bearbeitungszeit des Versuchs arbeiten alle Team-Mitglieder zusammen. Typische Tätigkeiten sind Recherche, Aufteilung der Arbeit, Programmierung, Fehlersuche, Bericht, Präsentation und Vorführung erstellen. Sie können entweder ausserhalb der Hochschule oder in den Laboren der Hochschule (G2.09, G2.16) arbeiten. Dazu sind die Labore täglich geöffnet von ca. 8:00 bis 17 Uhr. Anmerkung: Seit Corona arbeiten wir nur noch Online zusammen.

Bei einer zweiwöchigen Bearbeitungszeit kann der Zwischentermin für eine „Lagebesprechung“ im Labor oder per Zoom genutzt werden.

Die Versuche werden je Team als bestanden oder nicht bestanden gewertet. Die Betreuer führen je Versuch und Team einen „Zustandsautomaten“, der wie folgt funktioniert:

dvafsm.png

Der Zustandsautomat der Bewertung.

Jedes Team muss bei allen Versuchen den Zustand „bestanden“ erreichen.

Gitlab

Am Anfang der Veranstaltung werden die benötigte Anzahl Repositories von den Betreuern angelegt. Der Owner der Repositories ist ihr Betreuer. Als Maintainer wird ein Studierender pro Team ausgewählt, der dann selbständig die weiteren Teammitglieder einteilen kann.

In jedem Gitlab Repository liegt an oberster Stelle eine Datei README.md. Der Inhalt wird im Markdown Format geschrieben. Gitlab zeigt den Inhalt dieser Datei schön formatiert an. Die Datei dient als erste Beschreibung, wenn jemand das Repository auswählt. Deshalb sollte in etwa der folgende Inhalt enthalten sein:

# DVA Praktikum für Informatiker

Hochschule Augsburg \
Fakultät für Informatik \
Sommersemester 2021 \
Prof. Dr. Hubert Högl

**Team: 1**

<!-- Nr   Name       MatrNr  Studiengang+Sem,   E-mail -->
1. Hans Maier, #123456, INF6, <Hans.Maier@hs-augsburg.de>
2. Anna Huber, #126987, INF6, <Anna.Huber@hs-augsburg.de>
3. Franz Xaver, #349816, INF8, <Franz.Xaver@hs-augsburg.de>
4. Isolde Weber, #432190, INF8, <Isolde.Weber@hs-augsburg.de>

Der Bericht im HTML Format liegt hier: http://www.hs-augsburg.de/~maier/dva.

Statt der \-Zeichen kann man zum Zeilenumbruch auch zwei oder mehr Leerzeichen am Zeilenende verwenden.

Die Anzeige in gitlab sieht damit so aus:

README.png

Mit dem Werkzeug grip (https://github.com/joeyespo/grip) kann man bereits auf dem Entwicklungsrechner prüfen, wie die README.md Datei formatiert wird.

Den aktuellen Gitlab Link finden Sie am Anfang dieses Textes.

Sie können Ihr Repository dann entweder mit ssh oder https klonen:

  • git clone ssh://git@gitlab.informatik.hs-augsburg.de:2222/dva/berichte-20xx/01.git

  • git clone https://gitlab.informatik.hs-augsburg.de/dva/berichte-20xx/01.git

Das Verzeichnis heisst nach dem Klonen einfach 1. Falls Sie einen sprechenderen Namen möchten, müssen Sie diesen als weiteres Argument dahinter angeben, also z.B. so:

  • git clone ssh://git@gitlab.informatik..../01.git DVA23_Projektteam_01

Damit das Klonen über ssh klappt, müssen Sie in Gitlab ihren öffentlichen ssh Schlüssel hinterlegen. Wie das geht habe ich kurz unter dem Link https://tha.de/~hhoegl/home/GitSpicker#git-im-www-gitlab erläutert.

Der Bericht

Es gibt einen Demo-Bericht, den Sie hier finden:

http://hhoegl.informatik.hs-augsburg.de/dva/sphinxbericht/index.html

Der „Quelltext“ des Demo-Berichtes liegt auf dem Gitlab Server an folgender Stelle:

https://gitlab.informatik.hs-augsburg.de/hhoegl/sphinxbericht

Der Bericht wird mit „make html“ nach HTML übersetzt. Die generierte HTML Ausgabe des Berichts soll in Ihrem RZ WWW-Verzeichnis gespeichert werden. Auf dem Rechner login.rz.hs-augsburg.de findet man dieses Verzeichnis in /www/<user>, wobei <user> Ihr Login-Name ist. Dieses Verzeichnis finden Sie im WWW Browser dann unter http://www.hs-augsburg.de/~user.

WICHTIG Sie müssen am Anfang der Veranstaltung den Demo-Bericht mit git holen und ihn für Ihre Gruppe anpassen. Alle Teile im Bericht, die nur zur Demonstration geschrieben wurden, müssen Sie entfernen!

Der Bericht kann bei Bedarf über Sphinx auch als PDF Datei ausgegeben werden („make latex“). Diese Option ist ganz praktisch, wenn man einen Überblick bekommen möchte, wie viele Seiten man schon geschrieben hat. Ausserdem sieht man, ob die Grösse der Bilder im PDF Format stimmt. Wir brauchen die Berichte nicht auf Papier (ganz nach dem „paperless“ Motto).

Der Bericht enthält für jeden durchgeführten Versuch ein Kapitel. Jedes Versuchskapitel sollte in etwa folgende Gliederung aufweisen:

Datum, Thema

  1. Einleitung

    Motivation, Aufgabenstellung

  2. Grundlagen

  3. Versuchsdurchführung

    Vorbereitung, Durchführung, Ergebnisse, Probleme

  4. Zusammenfassung

    Fazit, Tipps für spätere Teams

  5. Literaturangaben

Ganz wichtig: Bei jedem Versuch muss nachvollziehbar sein, wer im Team welche Arbeit gemacht hat und welcher Zeitaufwand dafür in etwa nötig war! Der Bericht muss darüber Auskunft geben.

Hier ist ein Beispiel für einen Bericht aus dem Wintersemester 21/22 (Technische Informatik):

https://www.hs-augsburg.de/homes/sebkl/dva-bericht/

Die Vorbereitungsaufgabe

Die Vorbereitungsaufgabe dient dazu, dass sich alle Teams an den Ablauf gewöhnen. Sie werden im wesentlichen

  • sich mit Sphinx anfreunden (http://www.sphinx-doc.org/en/master/contents.html)

  • sich mit Gitlab anfreunden (https://about.gitlab.com)

  • den Demobericht auf Ihr Team personalisieren und in Ihr Gitlab Repository aufnehmen

  • die HTML Ausgabe des Berichtes auf Ihr Web-Verzeichnis im RZ ablegen (das müssen Sie natürlich nach jeder Veränderung des Berichts wiederholen)

Moodle

Wie verwenden den Moodle-Kurs für diese Veranstaltung nur zum Eintragen der TeilnehmerInnen, zur Teambildung, und zur Benachrichtigung. Die Abgabe der Berichte wird in gitlab erfolgen.

Die Versuche

Diese Veranstaltung hat schon eine lange Tradition an der Hochschule (30 Jahre und mehr). In dieser Zeit haben sich natürlich die Themen stark gewandelt. Sie können mal kurz hineinschauen in die frühere Veranstaltungsseite um einen Eindruck davon zu bekommen. Hier ist auch eine Zusammenfassung DVAINF_VersucheAlt der alten Versuche.

Seit dem Sommer 2018 übertragen wir die alten Versuchsbeschreibungen, die grösstenteils direkt im HTML-Format geschrieben waren, in das Sphinx Format. Alle übertragenen Versuchsbeschreibungen (und einige neue) finden Sie unter diesem Link: http://hhoegl.informatik.hs-augsburg.de/dva/inf/html/index.html.

Neben diesen Versuchen ist in letzter Zeit auch ein Trend entstanden, dass wir einfach spontan neue interessante Themen, auch auf Vorschlag der Studierenden hin in den Plan aufnehmen. Hier sind in den letzten Semestern unter anderem folgenden Themen vorgekommen:

  • Programmiersprachen Python und Go

  • Embedded Linux

  • Embedded Systems

  • RFID/NFC

  • Open-Source Software

  • Open-Source Software Engineering

  • Linux-Treiber

  • Internet of Things

  • LoRa/TheThingsNetwork

  • Fablab, 3D Druck

  • App-Entwicklung für Smartphones

  • Web Entwicklung mit Dart/Flutter

  • Containerisierung mit Docker

  • und einige mehr…

Wenn Sie selber einen Versuch vorschlagen möchten, dann melden Sie sich unter der oben angegebenen E-mail Adresse!

Seit ein paar Jahren veranstalte ich auch das verwandte Praktikum DVA für Technische Informatiker. Diese Versuche sind auch für Informatiker offen.

Literatur zum Schreiben von Berichten, zur Teamarbeit und zum Programmieren

  1. In der Bibliothek gibt es ein Regal gleich in der Nähe des Empfangs, das ausgewählte Literatur enthält für Studierende die Berichte, Seminararbeiten, Bachelor- und Masterarbeiten schreiben müssen. Schauen Sie sich dort einfach mal um!

  2. Brian W. Fitzpatrick, Ben Collins-Sussman, Team Geek. A Software Developer’s Guide to Working Well with Others, O’Reilly, 2012 https://www.oreilly.com/library/view/team-geek/9781449329839/

    Es gibt eine neuere Auflage mit dem Titel Debugging Teams, O’Reilly 2015. https://www.oreilly.com/library/view/debugging-teams/9781491932049/

  3. Kathrin Passig und Johannes Jander, Weniger schlecht programmieren, O’Reilly 2013.

    https://learning.oreilly.com/library/view/weniger-schlecht-programmieren/9783955615697

  4. Christina Czeschik und Matthias Lindhorst, Weniger schlecht über IT schreiben, O’Reilly 2018.

    https://learning.oreilly.com/library/view/weniger-schlecht-uber/9781492070177