Direkt zum InhaltDirekt zur SucheDirekt zur Navigation
▼ Zielgruppen ▼

Humboldt-Universität zu Berlin - Mathematisch-Naturwissenschaftliche Fakultät - Software Engineering

Debugging und automatisierte Fehlerbereinigung

 


 

Wann und Wo

Seminar: Dienstag, 9-11 Uhr, RUD 26, 1'307

Wer

Dozent: Dipl.Inf. Simon Heiden / Prof. Lars Grunske

Beschreibung und Aufbau der Lehrveranstaltung

Fehlererkennung und -beseitigung ist im Allgemeinen ein sehr zeitaufwändiges und kostspieliges Unterfangen. Im Allgmeneinen gilt: Je komplexer die Softwaresysteme sind, desto größer ist der materielle und personelle Aufwand für das Auffinden und die Korrektur von Fehlern. Viele Wissenschaftler beschäftigen sich daher mit der Suche nach Techniken und Methoden, um Entwickler bei Fehlererkennung, -lokalisierung und -korrektur zu unterstüzen.

Ziel dieses Seminars ist es, den Stand der Wissenschaft und Technik zum Debugging und zur Fehlerbereinigung systematisch zu untersuchen. Dabei werden besonders automatisierte Techniken zum Auffinden, Diagnostizieren und Eliminieren von Fehlern vorgestellt und im Verlauf des Seminars von den Teilnehmern untersucht. Beispiele für diese Techniken sind die Diagnose von Fehlerursachen mit Hilfe von Unit-Tests (u.a. SBFL Techniken) und das automatisierte Reparieren mit genetischen Algorithmen.

Die teilnehmenden Studenten werden im Verlauf des Seminars eine wissenschaftliche Arbeit zu einem ausgewählten Thema verfassen und diese dann in einem etwa 20-Minütigen Vortrag vorstellen. Neben persönlichen Treffen mit dem jeweiligen Betreuer ist ein Treffen in der Gruppe daher nur beim ersten Termin und bei den Vorträgen am Ende des Semesters nötig.

 

Ablaufplanung

Erstes Treffen  
Struktur und Literaturliste  
Voreinreichung der Ausarbeitung  
Finale Einreichung der Ausarbeitung  
Einreichung des Peer-Reviews  
Einreichung der überarbeiteten Ausarbeitung  

Präsentationen (Ende des Semesters)

Präsentations-Themen Termin

 

 

 

 

 

 

 

 

 

 

 

Themenliste (Beispiele vom letzten Jahr; wird noch aktualisiert!)

Die aktuelle, vollständige Liste der Themen wird beim ersten Treffen präsentiert. Jeder Teilnehmer muss zur Themenverteilung anwesend sein.

Bitte schauen Sie sich vor der Anmeldung die Liste der (vorläufigen) Themen an, um sicherzugehen, dass das Seminar für Sie interessant ist!

Gerne können Sie sich vorab mit den Betreuern bzgl. der Themen in Verbindung setzen oder eigene Themen vorschlagen, falls diese in das Seminar passen.

Hinweis: Die in den Themenbeschreibungen angegebene Literatur dient jeweils nur als Startpunkt für eine notwendige, eigene Literaturrecherche.

Nr. Thema Betreuer Bearbeiter
  General Debugging    
1 Interactive Automated Debugging Simon Heiden  
2 Code Transplantation Simon Heiden  
3 Human Studies in Debugging Simon Heiden  
4 Debugging with AI Simon Heiden  
  Fault Recognition    
5 Cross-Project Defect Prediction Minxing Tang  
6 Differential Program Analysis Yannic Noller  
7 Performance Bug Detection Minxing Tang  
8 Symbolic Side-Channel Analysis Yannic Noller  
9 Testing of Multi-Threaded Programs Minxing Tang  
10 Analysis of Neural Networks with Fuzzing Yannic Noller  
  Fault Localization    
11 Contextual Fault Localization with Bug Signatures Simon Heiden  
12 Dynamic Program Slicing for Fault Localization Simon Heiden  
13 Information Retrieval Fault Localization Simon Heiden  
  Automated Repair    
14 Effective Search-Based Automated Program Repair Simon Heiden  
15 Repair of Deployed Software Simon Heiden  
16 Automated Program Synthesis Minxing Tang  

 

Seminar-Hinweise

Material, Ankündigungen, ...
  • ... gibt es über den Moodle-Kurs (Link folgt).
Einreichung der Paper
  • Einreichung aller Arbeiten auf der für das Seminar angelegten Seite auf EasyChair:
    Submission-Seite (Link folgt).
  • Erste Einreichung ist die Struktur und Literaturliste. Bei allen weiteren Abgaben werden die vorherigen Abgaben überschrieben, bzw. aktualisiert (Update).
Format der Ausarbeitung
  • Ausarbeitungen müssen in Englisch verfasst sein und sollten eine Länge von 15 Seiten nicht überschreiten. Es ist das LaTeX-Template für das Seminar zu nutzen. (Wird über Moodle zur Verfügung gestellt.)
Review-Prozess (Nach finaler Einreichung)
  • Jeder Teilnehmer verfasst ein Gutachten zu zwei weiteren Ausarbeitungen anderer Seminar-Teilnehmer.
  • Das Gutachten muss den Seminar-Begutachtungs-Hinweisen (werden über Moodle zur Verfügung gestellt) folgen.
Überarbeitete Ausarbeitung
  • Die Teilnehmer müssen ihre Ausarbeitung basierend auf den Hinweisen der Betreuer sowie der Gutachten überarbeiten.
  • Das Antwortschreiben auf die Gutachten muss den entsprechenden Hinweisen (werden über Moodle zur Verfügung gestellt) folgen und zusammen mit der überarbeiteten Version der Ausarbeitung eingereicht werden.
Präsentation
  • Die Präsentationsdauer ist 20-25 Minuten gefolgt von 5-10 Minuten für Fragen und Diskussion.
  • Die Teilnehmer werden dazu ermutigt, ihre Präsentation auf Englisch zu halten.