Download presentation
Presentation is loading. Please wait.
1
1 Specification of IT Systems – Introduction
2
2 Book and web pages zIn the course we use the following litterature: yDesign Methods for Reactive Systems – Yourdon, Statemate, and the UML yR.J. Wieringa yMorgan Kaufmann, 2003 zCourse web page yhttp://www.daimi.au.dk/~krell/SoITS/
3
3 Lectures and exercises zTime and place yTuesdays 9-13 yShannon-157 zFirst a lecture (us), then exercises (you)
4
4 Mandatory exercises and exam zMandatory exercises ySpecification of a reactive system of your own choice yHand-ins each week yDone in groups with 3-4 participants (must be formed today) zExam yOral, 20 minutes, no preparation, 13-grade, curriculum is all that we read
5
5 Lectures zLectures yJens Bæk Jørgensen (jbj@daimi.au.dk) yKristian Bisgaard Lassen (krell@daimi.au.dk)
6
6 Purpose and Contents zPurpose: yThe purpose of this course is to strengthen the students knowledge of conceptual modeling and system specification. zContents: yThe student will learn skills to build data models, data flow models and behavioral models. The course describe how these techniques is combined. The course emphasizes not just to describe the IT system from a technical point of view, but also to describe the environment where the given system is to be used. The course walks through techniques is method independent, but different concrete methods and notations is uses such as UML. yThe course focuses on making specification of systems and to a lesser extend how these specifications is realized in an implementation.
7
7 Part I: Reactive system design – contents zChapter 1: Reactive systems zChapter 2: The environment zChapter 3: Stimulus-response behaviour zChapter 4: Software specifications
8
8 Reactive systems – first characterisation zTwo main classes of systems yTransformational systems yReactive systems zReactive systems respond to stimuli in order to bring about desirable effects in their environments zReactive systems may yManipulate complex data yEngage in complex behavior yCommunicate with (many) other systems
9
9 Reactive systems – training information system example zPurpose yCoordinate monthly training courses for new employees of large company zCharacteristics yInteractive yNonterminating yState-dependent response yEnvironment-oriented response yParallel processing
10
10 Reactive systems – elevator controller example zPurpose yControl the movement of two elevator cages in a 10 floor building; update location and direction indicators zCharacteristics yInteractive yNonterminating yState-dependent response yEnvironment-oriented response yParallel processing yReal-time
11
11 Reactive systems – definition (Wieringa) zA reactive system is a system that, when switched on, is able to create desired effects in its environment by enabling, enforcing or preventing events in the environment. zCharacteristics yInteractive yNonterminating yInterrupt-driven yState-dependent response yEnvironment-oriented response yParallel processing yReal-time zExamples yInformation systems, workflow systems, groupware, EDI systems, web market places, production control software, embedded software
12
12 Transformational systems – definition (Wieringa) zContrast reactive systems with transformational systems, that compute output from an input and then terminate zCharacteristics y Terminating y Sometimes interactive y Not interrupt-driven y Output not state-dependent y Output defined in terms of input y Sequential y Usually not real-time z Examples y Compiler, assembler, loader, expert system, optimization algorithm, search algorithm, linear programming algorithm, etc.
13
13 The environment – training information system example
14
14 The environment – message exchange zEnvironment and system exchange messages zEach message has yA subject (people, devices, conceptual entities, lexical entities,...) yA function, which x informs the environment, x directs the environment, or x manipulates lexical items yA connection, which is xa path from sender to receiver that may delay, distort, or loose the message
15
15 The environment – subject domain zSubject domain of a reactive system yConsists of entities ySet of all subjects of all its input and output messages yThe part of the world talked about by the messages that cross the system interface zCategories of entities yPhysical entities yConceptual entities yLexical items
16
16 The environment – example of subject domain (with physical, conceptual, and lexical entities)
17
17 The environment – example of system directly connected to subject domain
18
18 The environment - connection domain zEvents of interest usually do not occur exactly at the interface of the system zActions caused by the system usually do not occur exactly at the interface of the system zIf a connection between system and environment is represented explicitly we call it a connection domain. zSource of delay, loss and distortion of messages to and from the system
19
19 The environment – example of connection domain (and subject domain)
20
20 Stimulus-response behaviour – training information system example Assumptions -Registration desk reliable -Employee is indeed a joiner
21
21 Stimulus-response behaviour – heating controller example Assumptions?
22
22 Stimulus-response behaviour – in general Event types -Named external event -Condition change event -Temporal event
23
23 Stimulus-response behaviour zA reactive system receives messages from sources in its environment and it sends messages to destination in its environment zAt the sources, events occur zAt the destinations, actions occur zAt the system interface, stimuli occur zAt the system interface, response occur zTo interpret a stimuli properly we need to make assumptions about the environment
24
24 Stimulus-response behaviour – assumptions zAssumptions are statements about the environment yMust be true for the (stimulus, response) pair to be desirable yBeyond control of SuD zExamples of categories of assumptions yLaws of nature yProperties of devices yProperties of people (users, operators, …)
25
25 Stimulus-response behaviour – event recognition and response computation - Observer makes event recognition - Actor makes response computation
26
26 Stimulus-response behaviour – example of assumptions about observers zEvents of interest: beginning of plate arrives, end of plate arrives zAvailable stimuli: on, off zNecessary assumptions: yThe photo-electric cell is functioning properly. yThe cell is stimulated only by the arrival of the beginning or end of a metal plate zEvent recognition?
27
27 Stimulus-response behaviour – Observability of events Subject domain?
28
28 Software specifications – basic concepts and terminology zDesign decision yAny creative decision about a system zSpecification yDescription of design decisions zA reactive system specification must describe ythe place of the SuD in the system hierarchy yfunctions, behaviour and communication of the SuD yits composition zThe specification must be used to make a system engineering argument
29
29 Software specifications – system engineering argument for training information system zEmergent property (E): Department must be able to handle newcomers efficiently zSpecification (S): The training information system allows registration of unexpected participants zAssumption (A): The department has extra staff
30
30 Software specifications – system engineering argument for heating controller zEmergent property (E): Pasteurization unit heats batch according to recipe zSpecification (S): The heating controller controls heater according to batch recipe zAssumption (A): The thermometer is functioning correctly
31
31 Software specifications – system engineering argument in general zIf SuD satisfies specification S and environment satisfies assumptions A (constraints) then composite system has emergent properties E (requirements) zEmergent properties arise by interaction of component systems
32
32 Software specifications – properties at every level zFunctional properties yService: Interaction that delivers desired effect yBehaviour: Ordering of interactions over time yCommunication: Symbol flow between different entities zQuality properties/attributes: Efficiency, usability, reliability, …
33
33 Software specification – operational semantics zSpecification of a set of reproducible operations to find out whether a property is present zImportant class of operational specifications has the form: s ^ C => r ys is a stimulus that occur yC is the current system state yr is a produced response
34
34 Summary zReactive systems yCommunicate with environment, create desired effects, … zThe environment yMessage exchange between subject domain and SuD, possibly via a connection domain yMessage functions are informative, manipulative, or directive zStimulus-response behaviour yEvent -> stimulus -> response -> action yAssumptions necessary zSoftware specifications yUsed in system engineering argument yFunctional properties concern services, behaviour, and communication
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.