Dynamic & Functional Modelling
Dynamic & Functional Modelling
Dynamic & Functional Modelling
Contents
DYNAMIC MODELING .............................................................................................................................. 1
SCENARIO.................................................................................................................................................... 2
EVENT TRACE DIAGRAM ........................................................................................................................ 2
STATE MACHINE ....................................................................................................................................... 4
STATE DIAGRAM ....................................................................................................................................... 4
When to use state diagrams ? ..................................................................................................................... 5
How to draw state diagrams ? .................................................................................................................... 5
STATE DIAGRAM FOR MAKING A PHONE CALL ........................................................................... 8
STATE DIAGRAM FOR ATM TRANSACTION ....................................................................................... 9
FUNCTIONAL MODELLING ................................................................................................................... 10
DATA FLOW DIAGRAMS (DFD) ............................................................................................................ 10
CONTEXT DIAGRAM / LEVEL 0 DFD ................................................................................................... 12
DRAWING DFDs ........................................................................................................................................ 12
GUIDELINES FOR DRAWING DFD ........................................................................................................ 13
COMMONLY MADE MISTAKES IN DFDS............................................................................................ 14
DFD OF COMPILER .................................................................................................................................. 15
DYNAMIC MODELING
Dynamic model describes those aspects of the system that changes with the time.
It is used to specify and implement control aspects of the system. It depicts states, transitions, events
and actions.
The dynamic model includes event trace diagrams describing scenarios.
An event is an external stimulus from one object to another, which occurs at a particular point in time.
An event is a one-way transmission of information from one object to another.
A scenario is a sequence of events that occurs during one particular execution of a system. Each basic
execution of the system should be represented as a scenario.
The dynamic model is represented graphically by state diagrams.
A state corresponds to the interval between two events received by an object and describes the "value"
of the object for that time period.
A state is an abstraction of an object's attribute values and links, where sets of values are grouped
together into a state according to properties that affect the general behaviour of the object.
Each state diagram shows the state and event sequences permitted in a system for one object class.
PREPARED BY: PRAMOD MATHEW JACOB 1
DYNAMIC & FUNCTIONAL MODELLING
SCENARIO
A scenario is a sequence of events that occurs during one particular execution of a system.
Each basic execution of the system should be represented as a scenario.
The scope of scenario may vary. It may include all events in the system or it may include only those
events generated by certain objects. A scenario can be written as a list of text statements.
Example: A scenario to use ATM for withdrawing money. Each event transmits information from one
object to another. For example, the event “the ATM asks the user to insert a card” transmits a signal from
the ATM to the User. The next event is “the user inserts a cash card”. The next event is “the ATM accepts
the card and reads its serial no.” and so on.
2. The ATM accepts the card and reads its serial number.
4. The ATM verifies the serial number and password with the
consortium
The consortium checks it with bank ABC and notifies the
ATM of acceptance
Example: In this diagram, four objects – User, ATM, Consortium and Bank - are involved, which are shown
with four vertical lines. User generates an event “insert card” which is shown as horizontal arrow from user
to ATM. That means source of the event is User object and destination of the event is ATM. In response to
this event, the ATM generates the “request password” event to the User. Spacing between these two arrows
is insignificant but the event “insert card” occurs before the event “request password” and so on.
STATE MACHINE
A state machine is a behaviour which specifies the sequence of states an object visits during its
lifetime in response to events, together with its responses to those events.
State: A state is a condition during the life of an object during which it satisfies some condition,
performs some activity, or waits for some external event.
A state corresponds to the interval between two events received by an object and describes the "value"
of the object for that time period.
A state is an abstraction of an object's attribute values and links, where sets of values are grouped
together into a state according to properties that affect the general behaviour of the object.
A sub-state is a state that is nested in another state. A state that has sub-states is called a composite
state. A state that has no sub-states is called a simple state. Sub-states may be nested to any level.
Event: An event is the specification of a significant occurrence. For a state machine, an event is the
occurrence of a stimulus that can trigger a state transition.
In other words, an event is something that happens at a point in time. An event does not have duration.
An individual stimulus from one object to another is an event. Press a key on the key board, train
departs from station are examples of events.
Transition: A transition is a relationship between two states indicating that an object in the first state
will, when a specified set of events and conditions are satisfied, perform certain actions and enter the
second state. Transition can be self-transition. It is a transition whose source and target states are the
same.
Action: An action is an executable, atomic (with reference to the state machine) computation. Actions
may include operations, the creation or destruction of other objects, or the sending of signals to other
objects (events).
An action is an instantaneous operation. An action represents an operation whose duration is
insignificant compared to the resolution of the state diagram. For instance, disconnect phone line
might be an action in response to an on-hook event for the phone line. An action is associated with an
event.
Activity: Activity is an operation that takes time to complete. An activity is associated with a state.
Activity includes continuous operations such as displaying a picture on a television screen as well as
sequential operations that terminate by themselves after an interval of time such as closing a valve or
performing a computation.
A state may control a continuous activity such as ringing a telephone bell that persists until an event
terminates it causing the transition of the state. Activity starts on entry to the state and stops on exit.
A state may also control a sequential activity such as a robot moving a part that progresses until it
completes or until it is interrupted by an event that terminates prematurely.
STATE DIAGRAM
State diagrams are used to describe the behaviour of a system. State diagrams describe all of the
possible states of an object as events occur.
Each diagram usually represents objects of a single class and tracks the different states of its objects
through the system.
It relates events and states. A change of state caused by an event is called a transition. Transition is
drawn as an arrow from the receiving state to the target state.
A state diagram is graph whose nodes are states and whose directed arcs are transitions labelled by
event names. State diagram specifies the state sequence caused by an event sequence.
PREPARED BY: PRAMOD MATHEW JACOB 4
DYNAMIC & FUNCTIONAL MODELLING
State diagrams have very few elements. The basic elements are rounded boxes representing the state
of the object and arrows indicting the transition to the next state. The activity section of the state
symbol depicts what activities the object will be doing while it is in that state as shown in figure
below.
Initial and Final States: All state diagrams being with an initial state of the object as shown below.
This is the state of the object when it is created. After the initial state the object begins changing
states. Conditions based on the activities can determine what the next state the object transitions to.
The initial state is denoted by a filled black circle and may be labeled with a name. The final state is
denoted by a circle with a dot inside and may also be labeled with a name as shown in figure below
Transitions: Transitions from one state to the next are denoted by lines with arrowheads. A transition
may have a trigger, a guard and an effect, as shown in figure below.
"Trigger" is the cause of the transition, which could be a signal, an event, a change in some condition,
or the passage of time. "Guard" is a condition which must be true in order for the trigger to cause the
transition. "Effect" is an action which will be invoked directly on the object that owns the state
machine as a result of the transition.
State Actions: In the transition example above, an effect was associated with the transition. If the
target state had many transitions arriving at it, and each transition had the same effect associated with
it, it would be better to associate the effect with the target state rather than the transition. This can be
done by defining an entry action for the state. The diagram in Figure 3.7 below shows a state with an
entry action and an exit action. It is also possible to define actions that occur on events, or actions that
always occur. It is possible to define any number of actions of each type.
Self-Transitions: A state can have a transition that returns to itself, as shown in the Figure below. This
is the most useful when an effect is associated with the transition.
Compound States: A sub-state is a state that is nested in another state. A state that has sub-states is
called a composite state. A state that has no sub-states is called a simple state. Sub-states may be
nested to any level. The notation in the above version indicates that the details of the Check PIN
submachine are shown in a separate diagram.
FUNCTIONAL MODELLING
The functional model describes computations and specifies those aspects of the system concerned with
transformations of values - functions, mappings, constraints, and functional dependencies. The
functional model captures what the system does, without regard to how or when it is done.
The functional model is represented graphically with multiple data flow diagrams, which show the
flow of values from external inputs, through operations and internal data stores, to external outputs.
Data flow diagrams show the dependencies between values and the computation of output values from
input values and functions. Functions are invoked as actions in the dynamic model and are shown as
operations on objects in the object model.
DATA FLOW DIAGRAMS (DFD)
The DFD is a simple graphical formalism that can be used to represent a system in terms of the input
data to the system, various processing carried out on that data, and the output generated by the system.
DFD is used to represent the data transformations. That is it shows how input data is transformed into
suitable output data.
DFD is also termed as Bubble chart though a process is represented using bubble.
Advantages of DFD are:
i. DFDs are simple to understand and use
ii. It uses a very few primitive symbols to represent the functions performed by a system
and the data flow among these functions
There are two different notations used in DFDs.
i. Gane and Sarson notation
ii. DeMarco and Yourdon notation
You may use either of these two conventions, just don’t mix them.
1.1
id
1.1
DeMarco & Yourdon
tenant receive work outstanding work orders work request
symbols request
Entities:
Those physical entities external to the software system such as people, departments, other companies,
other systems or even a logical entity like bank account.
Entities are called sources if they are external to the system and provide data to the system, and sinks
if they are external to the system and receive information from the system
Processes:
A function / process is represented using a circle.
A process must have at least one input and at least one output
A process should be numbered.
The name of the process should be specified in the bubble.
Data stores:
Data store represents a logical file or a data base or any media which stores data. It can be online or
“hard copy” .
Data stores are labelled with a noun (e.g. the label “customer” indicates that information about
customers is kept in that data store)
Data is stored whenever there are more than one process that needs it and these processes don’t always
run one after the other (if the data is ever needed in the future it must be stored)
Data flows:
It must originate from and/or lead to a process (this means that entities and data stores cannot
communicate with anything except processes –remember that it takes a process to make the data flow)
It can go from process to process, but that does imply that no data is stored at that point
It can have one arrowhead indicating the direction in which the data is flowing
It can have 2 arrowheads when a process is altering (updating) existing records in a data store
Elementary data cannot be decomposed into its meaningful constituents. For example, roll no, pin
code, and quantity. Aggregate data can be decomposed into its meaningful constituents. For example,
name can be decomposed into first name, middle name and last name. Sometimes an aggregate value
is split into its constituents, each of which goes to a different process. A fork in the path as shown
below is used to do this. Reverse can also be done. That is elementary data coming from different
sources can be aggregated. This is done by reversing the arrows in the diagram below.
Street
Address city
State
In De Marco and Yourdon notation an additional symbol is mentioned for representing hardcopy
output.
A data dictionary lists all data items that appear in a DFD model. The data items listed include all data
flows and lists all data items that appear in a DFD model.
Synchronous and Asynchronous operations:
If two processes are directly connected by a dataflow arrow, then they are synchronous. This
means that they operate at the same speed.
If two processes are connected through a data store, then the speed of operation is independent.
They are asynchronous.
Number DB
DRAWING DFDs
Except for the context DFD, each DFD represents the breakdown of one process.
For example, in the hierarchy on the next page, the level 1 DFD that represents the breakdown of
process 1.2 will contain processes 1.2.1, 1.2.2 and 1.2.3. But it will not contain 1.2, nor any other
process.
Context level diagrams show all external entities. They do not show any data stores. The context
diagram always has only one process labelled 0.
When you draw a level 0 diagram, follow these rules:
include all entities in the context diagram
show any data store that are shared by the processes in the level 0 diagram
When you draw a level 1 or 2 etc. diagram, follow these rules:
o include all entities and data stores that are directly connected by data flow to the one process
you are breaking down
o show all other data stores that are shared by the processes in this breakdown (these data
stores are “internal” to this diagram and will not appear in higher level diagrams, but will
appear in lower level diagrams)
That last statement is often confusing. Here is another explanation using the hierarchy on If a data
store is used only by processes 3.2.1 and 3.2.3, then it will appear only in the level 2 diagram that
includes processes 3.2.1, 3.2.2 and 3.2.3. It will not appear in the diagram that shows processes 3.1
and 3.2 because it is internal to process 3.2.
A DFD that contains processes that are not further broken down is called a primitive DFD.
Naming conventions:
o Processes: strong verbs
o Data flows: nouns
o data stores: nouns
o external entities: nouns
No more than 7 - 9 processes in each DFD.
Dataflow must begin, end, or both begin & end with a process.
Dataflow must not be split.
A process is not an analogy of a decision in a systems or programming flowchart. Hence, a dataflow
should not be a control signal. Control signals are modelled separately as control flows.
Loops are not allowed.
A dataflow cannot be an input signal. If such a signal is necessary, then it must be a part of the
description of the process, and such process must be so labelled. Input signals as well as their effect
on the behaviour of the system are incorporated in the behavioural model (say, state transition graphs)
of the information system.
Decisions and iterative controls are part of process description rather than dataflow.
If an external entity appears more than once on the same DFD, then a diagonal line is added to the
north-west corner of the rectangle (representing such entity).
Updates to data store are represented in the textbook as double-ended arrows. This is not, however, a
universal convention. I would rather you did not use this convention since it can be confusing. Writing
to a data store implies that you have read such data store (you cannot write without reading). Therefore,
data store updates should be denoted by a single-ended arrow from the updating process to the updated
data store.
Data flows that carry a whole record between a data store and a process is not labelled in the textbook
since there is no ambiguity. This is also not a universal convention. I would rather you labelled such
data flows explicitly.
Conservation Principles:
Data stores & Data flows: Data stores cannot create (or destroy) any data. What comes out of a data
store therefore must first have got into a data store through a process.
Processes: Processes cannot create data out of thin air. Processes can only manipulate data they have
received from data flows. Data outflows from processes therefore must be derivable from the data
inflows into such processes.
Levelling Conventions:
Numbering: The system under study in the context diagram is given number `0'. The processes
in the top level DFD are labelled consecutively by natural numbers beginning with 1. (Also
you can number the processes in LEVEL 1 as 0.1, 0.2, 0.3, 0.4…..0.n). When a process is
exploded in a lower level DFD, the processes in such lower level DFD are consecutively
numbered following the label of such parent process ending with a period or full-stop (for
example 1.2, 1.2.3, etc. or you can use 0.1.1, 0.1.2…etc).
Remember: Don’t mix up the numbering conventions. If you label the level 1 processes as 0.1,
0.2, 0.3…0.n then you have to number the level 2 processes as 0.1.1, 0.1.2, 0.1.3 etc.
Else if you label the level 1 processes as 1,2,3…n, then you have to number the level 2
processes as 1.1, 1.2, 1.3 etc.
Balancing: The set of DFDs pertaining to a system must be balanced in the sense that
corresponding to each dataflow beginning or ending at a process there should be an identical
dataflow in the exploded DFD.
Data stores: Data stores may be local to a specific level in the set of DFDs. A data store is used
only if it is referenced by more than one process.
External entities: Lower level DFDs cannot introduce new external entities. The context
diagram must therefore show all external entities with which the system under study interacts.
In order not to clutter higher level DFDs, detailed interactions of processes with external
entities are often shown in lower level DFDs but not in the higher level ones.
A second class of DFD mistakes arise when the outputs from one processing step do not match its inputs. It
is not hard to list situations in which this might occur:
A processing step may have input flows but no output flows. This situation is sometimes called a
black hole .
A processing step may have output flows but now input flows. This situation is sometimes called a
miracle.
A processing step may have outputs that are greater than the sum of its inputs - e.g., its inputs could
not produce the output shown. This situation is sometimes referred to as a grey hole.
DFD OF COMPILER