zum Inhalt springen

Lecture: Softwaretechnik / Software Engineering

Overview

The development of good and successful software requires more than just programming knowledge. Software engineering deals with the systematic use of principles, methods, and tools for the division of labor, engineering development, and application of extensive software systems.

Professional software developers, architects, and managers need to be able to answer the following questions:

  • When is a software product good enough to ship?
  • Have we developed what the customer or user really needs?
  • What do we do if tomorrow we have 10 times more users for our software system and 100 times the day after tomorrow?
  • How can we import changes into our software as quickly and safely as possible?
  • Why is it that we are not as good at software development as others?

Successful software projects require more than just technical expertise. Finding out what the customer wants, working together in a team, managing complexity, reducing risks, adhering to time and budget constraints and determining under various restrictions when a product is good enough to be delivered are at least as important topics. They often have a significant human component. The lecture deals with these topics and covers the basics of modern software engineering to a large extent.

We will examine the following topics:

  • Process consideration in software development
    (How can problems be avoided at an early stage? When and how much is to be designed? When and how much is to be tested? When and how are the customers to be involved? Agile methods ...)
  • Requirements elicitation, documentation, and evaluation
    (How do you find out what the customer really wants? Who is interested? How can we measure success objectively? How can we reliably document expectations? ...)
  • Software Design und Software Architektur
    (How can we design a system so that it is scalable for millions of users? How can we build security into a system?)
  • Quality assurance measures including measurement, inspection, static and dynamic analysis
    (Which quality assurance strategy is best suited for a particular system? What can we automate and when should we keep people up to date? How many tests and what type of tests should we run? What properties are important to ensure beyond functional correctness? Can we evaluate usability, scalability, reliability, performance? How can we statically guarantee the absence of certain security problems? ...)
  • Empirical methods in software engineering
    (How can we measure quality characteristics such as performance, security, and reliability? How can we measure how users interact with the system? How can we know whether the difference matters? ...)
  • Time and team management / network plan
    (How do you estimate the duration and costs of a project? How do you monitor progress and risks in order to identify problems at an early stage? How do you coordinate developers in a team? How can you form and develop teams? How do you choose do you motivate team members? How do you deal with team dynamics such as social loafing? ....)
  • Economics of software development
    (business models, outsourcing, open source, ...)

This course has a strong technical focus and includes homework with and without programming. The students gain experience with team management and modern software engineering tools. The course optimally prepares students for management positions in software development projects.

 

Organization

The lecture takes place on Mondays and Wednesdays from 4:00 pm to 5:30 pm in HS2 in the Physik building (321 Hörsaal II (265/159 Sitzpl.), Zülpicher Str., 77(321), Erdgeschoß).

There are a total of 6 exercise groups to accompany the lecture. The exercise groups start on October 17th.
Group 1: Mondays, 12:00 - 13:30 (in English), Gebäude 106 (Seminargebäude), Seminarraum S15
Group 2: Mondays, 14:00 - 15:30 (in German), Gebäude 106 (Seminargebäude), Seminarraum S15 
Group 3: Tuesday, 16:00 - 17:30 (in English), Gebäude 106 (Seminargebäude), Seminarraum S16
Group 4: Wednesday, 10:00 - 11:30 (in German), Gebäude 106 (Seminargebäude), Seminarraum S15
Group 5: Wednesday, 12:00 - 13:30 (in German), Gebäude 106 (Seminargebäude), Seminarraum S24
Group 6: Thursdays, 14:00 - 15:30 (in German), Gebäude 106 (Seminargebäude), Seminarraum S15

Schedule

Date topic     Submission (always on Monday at 12:00)
Mon, Oct 10, 2022 Introduction, organization No submission
Exercise

Class: No exercise class

Task: HW1- Technical setup 1 

-
Wed, Oct 12, 2022 The ingredients of good SE -
Mon, Oct 17, 2022

Requirements I

No submission
Exercise

Class: Assessment of HW1- Technical setup 1 

Task: HW2 requirements

-
Wed, Oct 19, 2022 Requirements II -
Mon, Oct 24, 2022 Modeling I HW2 requirements
Exercise

Class: Assessment of HW2 requirements

Task: HW3 behavioral modeling

-
Wed, Oct 26, 2022 Modeling II -
Mon, Oct 31, 2022 Architecture HW3-Behavioral Modeling
Exercise

Class: Assessment of HW3-Behavioral Modeling

Task: HW4-Architecture Modeling

-
Wed, Nov 02, 2022 Design -
Mon, Nov 07, 2022 Implementation HW4-Architecture Modeling
Exercise

Class: Assessment of HW4-Architecture Modeling

Task: HW5-Design 1

-
Wed, Nov 09, 2022 Design Patterns I -
Mon, Nov 14, 2022 Design Patterns II HW5-Design 1
Exercise

Class: Assessment of HW5-Design 1

Task: HW6-Design 2

-
Wed, Nov 16, 2022 QA + Testing -
Mon, Nov 21, 2022 QA + Testing II HW6-Design 2
Exercise

Class: Assessment of HW6-Design 2

Task: HW7-Implementation and Design Patterns

-
Wed, Nov 23, 2022 QA + Testing III -
Mon, Nov 28, 2022 Deployment and Operations HW7-Implementation and Design Patterns
Exercise

Class: Assessment of HW7-Implementation and Design Patterns

Task: HW8-Debugging and Testing  1

-
Wed, Nov 20, 2022 Collaboration in SE -
Mon, Dec 05, 2022 Process I HW8 Debugging and Testing 1
Exercise

Class: Assessment of HW8-Debugging and Testing 1

Task: HW9 Debugging and Testing 2

-
Wed, Dec 07, 2022 Process II -
Mon, Dec 12, 2022 Management I HW9 Debugging and Testing 2
Exercise

Class: Assessment of HW9-Debugging and Testing 2

Task: HW10 deployment 

-
Wed, Dec 14, 2022 Management II -
Mon, Dec 19, 2022 Open source HW10 deployment 
Exercise

Class: Assessment of HW10 Deployment 

Task: HW11-Git flow 

-
Wed, Dec 21, 2022 Evolution and Maintenance -
Mon, Jan 09, 2022 SE for Web Applications HW11-Git flow 
Exercise

Class: Assessment of HW11-Git flow 

Task: HW12-SE for Web Applications 1

-
Wed, Jan 11, 2023 Intro to HTML, CSS, and JavaScript  -
Mon, Jan 16, 2023 SE for Web Applications II  HW12-SE for Web Applications 1
Exercise

Class: Assessment of HW12-SE for Web Applications 1

Task: HW13-SE for Web Applications 2

-
Wed, Jan 18, 2023 Guest Lecture  -
Mon, Jan 23, 2023 SE for Machine Learning HW13-SE for Web Applications 2
Exercise Class: Assessment of HW13-SE for Web Applications 2 -
Wed, Jan 25, 2023 SE Ethics -
Mon, Jan 30, 2023 Q&A session No submission
Exercise no exercise classes -
Thu, Feb 06, 2023 First exam date (09:30 - 11:30, Physik I + II) -
Wed, Mar 22, 2023 Second exam date (09:30 - 11:30, Physik I + II) -

Rules and Agreements

The lecture has an ILIAS course for the slides, submission of homework, and supplementary documents;  We'll be using Slack for announcements, communication, and group work. See ILIAS for the link to register.

Waiting list: The lecture is not limited in size.

Prerequisites: No formal prerequisites but we recommend that you have completed the programming course and Info I (data structures and algorithms).

Textbook: We do not have a single textbook, but rather compile lectures from various sources.
For optional supplementary reading, consider Ian Sommerville, Software Engineering and Ian Sommerville, Engineering Software Products: An Introduction to Modern Software Engineering.

Homework:  Every Wednesday evening, we publish a homework sheet. Homework sheets must be submitted by the following Monday 12:00. By submitting a homework sheet, you indicate that you are also able to present it in the exercise classes.

Grading: The grading is based on the results of the exam. You have to submit at least 6/12 homework sheets to take the exam. You need >50% points in the exam to pass. If you have submitted at least 11/12 homework sheets, you get a 5% bonus on your exam points.

Delayed submissions:  Delays are not tolerated and are considered as "not submitted". Exceptions to this rule are only made in exceptional cases, almost always in connection with a family or medical emergency. 

Time management: This is a course with 9 ECTS points. We, therefore, expect that you will spend up to 12 hours per week on the course. Typically 6 hours per week are spent on lectures and exercise groups and 6 hours on homework sheets. 

Academic honesty and collaboration: You are allowed and actually encouraged to prepare the homework sheets in groups. However, everyone has to submit their own solution that shows that you have actually worked on the sheet yourself and not just copied it from someone else. This implies not taking credit for other's work and not covering for team members that have not contributed.