Undergraduate Course: Software Design and Modelling (INFR10064)
Course Outline
School | School of Informatics |
College | College of Science and Engineering |
Credit level (Normal year taken) | SCQF Level 10 (Year 3 Undergraduate) |
Availability | Available to all students |
SCQF Credits | 20 |
ECTS Credits | 10 |
Summary | This course introduces the design and modelling of software systems using object-oriented techniques. We start by exploring the use of modelling in software development. Students learn to document designs in the Unified Modeling Language, UML, with emphasis on class, sequence and state diagrams and the Object Constraint Language, OCL. We use modern model-driven development tools and discuss their strengths and weaknesses. We study criteria that make one design better than another in context and introduce design principles and patterns that capture good practice. |
Course description |
The course begins by placing design and modelling in the context of the various software engineering processes in widespread use today. Via labs, lectures and self-study using readings, videos and formative exercises, it teaches students to produce (initially straightforward) designs and to document them using UML models, both on paper and with an appropriate tool. We discuss the different affordances of these modes and how models may be used (i) purely informally, (ii) as reviewed documentation for designs, and/or (iii) in model-driven development in which models are formal artefacts and code may be generated from them.
The second part of the course focuses on identifying and producing good designs. What principles should a good object-oriented design follow? We learn some common design patterns and their role in development and learning.
Finally we turn to practical model-driven development: how can the cost-benefit ratio of modelling be improved, now and potentially in the future? Students will learn about model transformations, both model-to-model and model-to-text (e.g., code generation) and be introduced to current tools supporting these. We discuss the role of domain specific languages and the integration of model driven development with agile processes. Throughout the course, we identify the deficiencies as well as the benefits of the fast-changing state of the art, aiming to equip students to critically evaluate tools and techniques that become available to them in future.
|
Information for Visiting Students
Pre-requisites | None |
High Demand Course? |
Yes |
Course Delivery Information
|
Academic year 2024/25, Available to all students (SV1)
|
Quota: 100 |
Course Start |
Semester 2 |
Timetable |
Timetable |
Learning and Teaching activities (Further Info) |
Total Hours:
200
(
Programme Level Learning and Teaching Hours 4,
Directed Learning and Independent Learning Hours
196 )
|
Assessment (Further Info) |
Written Exam
50 %,
Coursework
50 %,
Practical Exam
0 %
|
Feedback |
Exercises in the weekly lab will be supported by automated feedback where possible. Labs will provide opportunities to compare answers with other students, raise questions about them, and get help from course staff.
Where appropriate the course will provide online quizzes with immediate feedback.
Students will be encouraged to interact on the Piazza or similar group, where feedback will be available on questions that need it.
Notes and explanatory videos will be provided on formative exercises, as appropriate.
The summatively assessed coursework will be marked by a combination of automated and human feedback, provided as soon as may be and certainly within two weeks. A session will be dedicated to discussion and matters arising.
As is standard in Informatics, individual feedback will not be provided on the written exam. The lecturer will produce brief notes on what was done well or badly, common errors and points to note. |
Exam Information |
Exam Diet |
Paper Name |
Hours & Minutes |
|
Main Exam Diet S2 (April/May) | Software Design and Modelling (INFR10064) | 2:120 | |
Learning Outcomes
On completion of this course, the student will be able to:
- design simple object-oriented systems
- create, read and modify UML diagrams documenting designs, both on paper and in an appropriate tool
- determine whether a UML model and a body of Java code are consistent; if they are inconsistent, identify the inconsistencies precisely and propose remedies
- evaluate and evolve object-oriented software designs, making use of common design patterns if appropriate
- discuss the use of modelling and model-driven development tools in software development, e.g. why and how models of software can have varying degrees of formality, capabilities and limitations of the tools
|
Reading List
Recommended reading:
- Timothy Lethbridge and Robert Langaniere. Object oriented software engineering: practical software
development using UML and Java. McGraw Hill, 2002.
- Perdita Stevens with Rob Pooley. Using UML. Pearson (second edition).
-Martin Fowler and Rebecca Parsons. Domain-specific languages.
Addison-Wesley 2011. |
Additional Information
Course URL |
https://opencourse.inf.ed.ac.uk/sdm |
Graduate Attributes and Skills |
Not entered |
Keywords | Software engineering,Software Design,Software modelling,Model-driven development |
Contacts
Course organiser | Prof Perdita Stevens
Tel: (0131 6)50 5195
Email: perdita.stevens@ed.ac.uk |
Course secretary | Miss Rose Hynd
Tel: (0131 6)50 5194
Email: rhynd@ed.ac.uk |
|
|