KEMBAR78
Timing Constraints in Software Engineering | PDF | Real Time Computing | System
0% found this document useful (0 votes)
1K views7 pages

Timing Constraints in Software Engineering

1. The document discusses timing constraints in software engineering and real-time systems. It defines key concepts like events, stimulus events, response events, and different types of timing constraints - delay constraints, deadline constraints, and duration constraints. 2. Timing constraints are classified into performance constraints, imposed on system response, and behavioral constraints, imposed on environmental stimuli. Delay constraints define a minimum time between two events. Deadline constraints define a maximum time between two events. Duration constraints define the length of a durational event. 3. Different timing constraints can be modeled using finite state machines and extended finite state machines to understand the timing behavior of real-time systems.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
1K views7 pages

Timing Constraints in Software Engineering

1. The document discusses timing constraints in software engineering and real-time systems. It defines key concepts like events, stimulus events, response events, and different types of timing constraints - delay constraints, deadline constraints, and duration constraints. 2. Timing constraints are classified into performance constraints, imposed on system response, and behavioral constraints, imposed on environmental stimuli. Delay constraints define a minimum time between two events. Deadline constraints define a maximum time between two events. Duration constraints define the length of a durational event. 3. Different timing constraints can be modeled using finite state machines and extended finite state machines to understand the timing behavior of real-time systems.
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 7

Module Lesson

7 35
Software Engineering Modelling Timing
Issues Constraints
Version 2 EE IIT, Kharagpur 1 Version 2 EE IIT, Kharagpur 2
Specific Instructional Objectives An event may either be instantaneous or may have certain duration. For example, a
button press event is described by the duration for which the button was kept pressed.
At the end of this lesson, the student would be able to: Some authors argue that durational events are really not a basic type of event, but can be
expressed using other events. In fact, it is possible to consider a duration event as a combination
x Explain what an event is of two events: a start event and an end event. For example, the button press event can be
x Classify the types of events described by a combination of ‘start button press’ and ‘end button press’ events. However, it is
often convenient to retain the notion of a durational event. In this text, we consider durational
x Classify the different types of timing constraints events as a special class of events. Using the preliminary notions about events discussed in this
x Explain what a delay constraint is subsection, we classify various types of timing constraints in subsection 1.7.1.

x Explain what a deadline constraint is


1.2. Classification of Timing Constraints
x Explain what a duration constraint is
A classification of the different types of timing constraints is important. Not only would it
x Identify the different types of delay, deadline, and duration constraints associated
give us an insight into the different types of timing constraints that can exist in a system,
with a system
but it can also help us to quickly identify the different timing constraints that can exist
x Explain how timing constraints can be modelled from a casual examination of a problem. That is, in addition to better understanding of the
behavior of a system, it can also let us work out the specification of a real-time system
x Explain a Finite State Machine (FSM)
accurately.
x Explain an Extended Finite State Machine (EFSM) Different timing constraints associated with a real-time system can broadly be classified into
performance and behavioral constraints.
x Explain how different timing constraints can be modelled using EFSM
Performance constraints are the constraints that are imposed on the response of the system.
Behavioral constraints are the constraints that are imposed on the stimuli generated by the
1. Timing Constraints – An Introduction environment.
Behavioral constraints ensure that the environment of a system is well behaved, whereas
The correctness of real-time tasks depend both on the logical correctness of the result, as well performance constraints ensure that the computer system performs satisfactorily.
as, on the satisfaction of the corresponding timing constraints. The timing constraints as we shall Each of performance and behavioral constraints can further be classified into the following
see in this section, in fact, apply to certain events in a system. These events may be generated by three types:
the tasks themselves or the environment of the system. An example of such an event is the event x Delay Constraint
of activation of a motor. Remember that the results may be generated at different times and it x Deadline Constraint
may not be in the form of a single one-time result. We must first properly characterize the events x Duration Constraint
in a system, to understand the timing behavior of real-time systems. These three classes of constraints are explained in the subsequent sections.

1.1. Events in a System 1.2.1. Delay Constraints


An event may be generated either by the system or its environment. Based on this A delay constraint captures the minimum time (delay) that must elapse between the
consideration, events can be classified into the following two types: occurrence of two arbitrary events e1 and e2. After e1 occurs, if e2 occurs earlier than the
Stimulus Events: Stimulus events are generated by the environment and act on the minimum delay, then a delay violation is said to occur. A delay constraint on the event e2 can be
system. These events can be produced asynchronously (i.e. aperiodically). For example, a expressed more formally as follows:
user pressing a button on a telephone set generates a stimulus event to act on the telephone t(e2 ) í t(e1 ) • d
system. Stimulus events can also be generated periodically. As an instance, consider the periodic where t(e2 ) and t(e1 ) are the time stamps on the events e2 and e1 respectively and d is the
sensing of the temperature of the reactor in a nuclear plant. minimum delay specified from e2. A delay constraint on the events e2 with respect to the event
e1 is shown pictorially in Fig. 35.1. In Fig. 35.1s, ¨ denotes the actual separation in time
Response Events: Response events are usually produced by the system in response to between the occurrence of the two events e1 and e2 and d is the required minimum separation
some stimulus events. Response events act on the environment. For example, consider a between the two events (delay). It is easy to see that e2 must occur after at least d time units have
chemical plant where as soon as the temperature exceeds 100ƕ C, the system responds by elapsed since the occurrence of e1; otherwise we shall have a delay violation.
switching off the heater. Here, the event of temperature exceeding 100ƕ C is the stimulus and
switching off of the heater is the response. Response events can either be periodic or aperiodic.

Version 2 EE IIT, Kharagpur 3 Version 2 EE IIT, Kharagpur 4


ǻ >= d

d
t=0 t(e1) t(e2)
Public
Switched
Fig. 35.1 Delay Constraint between two events e1 and e2 Telephone
Network
1.2.2. Deadline Constraints

Telephone
A deadline constraint captures the permissible maximum separation between any two system
arbitrary events e1 and e2. In other words, the second event (i.e. e2) must follow the first event
(i.e. e1) within the permissible maximum separation time. Consider that t(e1 ) and t(e2 ) are the
time stamps on the occurrence of the events e1 and e2 respectively and d is the deadline as
shown in Fig. 35.2. In Fig. 35.2, ¨ denotes the actual separation between the time of occurrence
of the two events e1 and e2, and d is the deadline. A deadline constraint implies that e2 must Call
occur within d time units of e1’s occurrence. We can alternatively state that t(e1) and t(e2) must Call Receiver
satisfy the constraint: Initiator
Environment
t(e2 ) í t(e1 ) ” d

ǻ <= d Fig. 35.3 Schematic Representation of a Telephone System

t=0 t(e1) t(e2)


d 1.3. Examples of Different Types of Timing Constraints
We illustrate the different classes of timing constraints by using the examples from a
Fig. 35.2 Deadline Constraint between two events e1 and e2
telephone system discussed in. A schematic diagram of a telephone system is given in Fig. 35.3.
Note that I have intentionally drawn an old styled telephone, because its operation is easier to
The deadline and delay constraints can further be classified into two types each based on
understand! Here, the telephone handset and the Public Switched Telephone Network (PSTN)
whether the constraint is imposed on the stimulus or on the response event. This has been
are considered as constituting the computer system and the users as forming the environment. In
explained with some examples in section 1.3.
the following, we give a few simple example operations of the telephone system to illustrate the
different types of timing constraints.
1.2.3. Duration Constraints
Deadline constraints: In the following, we discuss four different types of deadline constraints
A duration constraint on an event specifies the time period over which the event acts. A that may be identified in a real-time system depending on whether the two events involved
duration constraint can either be minimum type or maximum type. The minimum type duration in a deadline constraint are stimulus type or response type.
constraint requires that once the event starts, the event must not end before a certain minimum Stimulus–Stimulus (SS): In this case, the deadline is defined between two stimuli. This is a
duration; whereas a maximum type duration constraint requires that once the event starts, the behavioral constraint, since the constraint is imposed on the second event which is a stimulus.
event must end before a certain maximum duration elapses. An example of an SS type of deadline constraint is the following:
Once a user completes dialling a digit, he must dial the next digit within the next 5 seconds;
otherwise an idle tone is produced.
In this example, the dialing two consecutive digits represent the two stimuli to the telephone
system.
Stimulus–Response (SR): In this case, the deadline is defined on the response event, measured
from the occurrence of the corresponding stimulus event. This is a performance constraint,
since the constraint is imposed on a response event. An example of an SR type of deadline
constraint is the following:

Version 2 EE IIT, Kharagpur 5 Version 2 EE IIT, Kharagpur 6


Once the receiver of the hand set is lifted, the dial tone must be produced by the A classification of the different types of timing constraints that we discussed in this
system within 2 seconds, otherwise a beeping sound is produced until the handset is section is shown in Fig. 35.4. Note that a performance constraint can either be delay,
replaced. In this example, the lifting of the receiver hand set represents a stimulus to the deadline, or durational type. The delay or deadline constraints on performance can either be
telephone system and production of the dial tone is the response. RR or RS type. Similarly, the behavioral constraints can either be delay, deadline, or durational
type. The delay or deadline constraints on behavior of environment can either be RS or SS type.
Response–Stimulus (RS): Here the deadline is on the production of response counted
from the corresponding stimulus. This is a behavioral constraint, since the constraint is
imposed on the stimulus event. An example of an RS type of deadline constraint is the following: 2. Modelling Timing Constraints
Once the dial tone appears, the first digit must be dialed within 30 seconds, otherwise
In this section, we describe how the timing constraints identified in Sec. 1.2 can be modelled.
the system enters an idle state and an idle tone is produced.
Modelling time constraints is very important since once a model of the time constraints in a
Response–Response (RR): An RR type of deadline constraint is defined on two response system is constructed, it can serve as a formal specification of the system. Further, if all the
events. In this case, once the first response event occurs, the second response event must occur timing constraints in a system are modelled accurately, then it may even be used to automatically
before a certain deadline. This is a performance constraint, since the timing constraint has been generate code from it. Besides serving as a specification, modelling time constraints can help to
defined on a response event. An example of an RR type of deadline constraint is the following: verify and understand a real-time system.
Once the ring tone is given to the callee, the corresponding ring back tone must be
given to the caller within two seconds, otherwise the call is terminated. 2.1. The Finite State Machine (FSM)
Here ring back tone and the corresponding ring tone are the two response events.
The modelling approach we discuss here is based on Finite State Machines (FSMs). An
Delay Constraints: We can identify only one type of delay constraint (SS type) in the FSM is a powerful tool which has long been used to model traditional systems. In an FSM, a
telephone system example that we are considering. However, in other problems it may be state is defined in terms of the values assumed by some attributes. For example, the states of an
possible to identify different types of delay constraints. An SS type of a delay constraint is a elevator may be denoted in terms of its directions of motion. Here direction is the attribute,
behavioral constraint. An example of an SS type of delay constraint is the following: based on which the states up, down, and stationery are defined.
Once a digit is dialled, the next digit should be dialled after at least 1 second. In an FSM model, at any point of time a system can be in any one of a (possibly infinite)
Otherwise, a beeping sound is produced until the call initiator replaces the handset. number of states. A state is represented by a circle. The system changes state due to events that
change the values of, or relations among the state variables. A state change is also called a state
Here the delay constraint is defined on the event of dialling of the next digit (stimulus) after a transition. A transition causing event may either be an interface event that are transmitted
digit is dialled (also a stimulus). between the environment and the computer system or it could also be an internal event that is
Duration Constraint: A duration constraint on an event specifies the time interval over generated and consumed solely within the system. A transition from one state to another is
which the event acts. An example of a duration constraint is the following: represented by drawing a directed arc from the source to the destination (see Fig.35.5). The event
causing a transition is annotated on the arc. We keep our discussions of FSM to the bare
If you press the button of the handset for less than 15 seconds, it connects to the local minimum since we assume that the reader is familiar with basic FSM modelling of traditional
operator. If you press the button for any duration lasting between 15 to 30 seconds, it systems.
connects to the international operator. If you keep the button pressed for more than
30 seconds, then on releasing it would produce the dial tone.
2.2. Extended Finite State Machine (EFSM)
Timing Constraints
We use an Extended Finite State Machine to model time constraints. EFSM extends the
traditional FSM by incorporating the action of setting a timer and the expiry event of a timer.
Performance Constraints Behaviorial Constraints The notations we use for construction of EFSMs are simple and straightforward. Therefore
rather than introducing them formally, we have illustrated them through an example in Fig. 35.5.
The example shown in Fig. 35.5 describes that if an event e1 occurs when the current state of the
Delay Deadline Duration Delay Deadline Duration system is s1, then an action will be taken by setting a timer to expire in the next 20 milliseconds
and the system transits to state s2.

RR SR SR RR RS SS SS RS

Fig. 35.4 Classification of Timing Constraints

Version 2 EE IIT, Kharagpur 7 Version 2 EE IIT, Kharagpur 8


The EFSM model for this constraint is shown in Fig. 35.7. In Fig. 35.7, as soon as dial tone
E1 / set timer (20 ms) appears, a timer is set to expire in 30 seconds and the system transits to the “Await First Digit”
state. If the timer expires before the first digit arrives, then the system transits to an idle state
S1 where an idle tone is produced. Otherwise, if the digit appears first, then the system transits to
S2
the “Await Second Digit” state.

Fig. 35.5 Conventions Used in Drawing an EFSM Await


Second
We have already discussed that events can be considered to be of two types: stimulus events Digit
and response events. We had also discussed different types of timing constraints in Section 1.3.
Now we explain how these constraints can be modelled by using EFSMs. First digit

2.2.1. Stimulus-Stimulus (SS)


Let us consider the example of an SS type of deadline constraint we had discussed in Section Timer alarm/idle tone
1.3: Once the first digit has been dialled on the telephone handset, the next digit must be dialled Await
within the next 5 milliseconds. This has been modelled in Fig. 35.6. In Fig.35.6, we can observe Dial tone/ First
set timer Digit
that as soon as the first digit is dialled, the system enters the “Await Second Digit” state and the
(30 s) Idle
timer is set to 20 milliseconds. If the next digit does not appear within 20 milliseconds, then the
timer alarm expires and the system enters the “Await Caller On-hook” state and a beeping sound
is produced. If the second digit occurs before 20 milliseconds, then the system transits to the
“Await Next Digit” state.
Fig. 35.7 Model of an RS Type of Deadline

Await 2.2.3. Stimulus–Response (SR)


Next
Second digit/ Digit
set timer (5 ms) In Sec. 1.3, we had considered the following example of an SR type of deadline constraint:
Once the receiver of the hand set is lifted, the dial tone must be produced by the
system within 20 seconds, otherwise a beeping sound is produced until the handset is
replaced.
The EFSM model for this constraint is shown in Fig. 35.8. As soon as the handset is lifted, a
timer is set to expire after 2 sec and the system transits to “Await Dial Tone” state. If the dial
Timer alarm/beeping tone appears first, then the system transits to “Await First Digit” state. Otherwise, it transits to
First digit/ Await “Await Receiver On-hook” state.
set timer (5 ms) Second
Digit Await
Caller
On-hook

Fig. 35.6 Model of an SS Type of Deadline Constraint

2.2.2. Response-Stimulus (RS)


In Sec. 1.3, we had considered the following example of an RS type of deadline constraint:
Once the dial tone appears, the first digit must be dialed within 30 seconds, otherwise the system
enters an idle state and an idle tone is produced.

Version 2 EE IIT, Kharagpur 9 Version 2 EE IIT, Kharagpur 10


in 2 seconds. If the ring-back tone appears first, the system transits to “Await First Digit” state,
else it enters “Await Receiver On-hook” state, and the call is terminated.
Await
First
Digit 2.2.5. Delay Constraint
Dial tone A delay constraint between two events is one where after an event occurs, a minimum time
must elapse before the other event can occur. We had considered the following example of delay
constraint in Sec. 1.3: After a digit is dialed, the next digit should be dialed no sooner than 10
milliseconds. The EFSM model for it is shown in Fig. 35.10. In Fig. 35.10, if the next digit
appears before the alarm, then the beeping sound is produced and the system transits to “Await
Timer alarm/beeping Caller On-hook” state.
Await
Dial
Hand set lift/ Tone
set timer Await Await
(2 s) Receiver Next
On-hook Digit

Timer alarm
Fig. 35.8 Model of an SR Type of Deadline

Await Next digit/beeping


Await
First Next
Digit First digit/ Event
set timer Await
Ring-back tone (10 ms) Caller
On-hook

Fig. 35.10 Model of an SS Type of Delay Constraint


Await Timer alarm/terminate call
Ring-back 2.2.6. Durational Constraint
Ring-tone/ Tone
set timer Await In case of a durational constraint, an event is required to occur for a specific duration. The
(2 s) Receiver example of a durational constraint we had considered in Sec. 1.3 is the following: If you press
On-hook the button of the handset for less than 15 seconds it connects to the local operator. If you press
the button for any duration lasting between 15 to 30 seconds, it connects to the international
operator. If you keep the button pressed for more than 30 seconds, then on releasing it would
Fig. 35.9 Model of an RR Type of Deadline Constraint produce the dial tone.

2.2.4. Response–Response (RR)


In Sec. 1.3, we had considered the following example of an RR type of constraint: Once the
ring tone is given to the callee, the corresponding ring back tone must be given to the caller
within two seconds, otherwise the call is terminated.
The EFSM model for this constraint is shown in Fig. 35.9. In Fig. 35.9, as soon as the ring
tone is produced, the system transits to “Await Ring-back Tone” state, and a timer is set to expire

Version 2 EE IIT, Kharagpur 11 Version 2 EE IIT, Kharagpur 12


preset timer expires or the user presses the stop switch. After the agitation stops, the
machine waits for the user to press the startDrying switch. After the user presses the
Local startDrying switch, the machine starts the hot air blower and continues blowing hot air into
Operator the drying chamber until either the user presses the Stop switch or the preset timer expires.
Button 4. What is the difference between a performance constraint and a behavioral constraint? Give
release practical examples of each type of constraint.
Button 5. Represent the timing constraints in a collision avoidance task in an air surveillance system
press as an extended finite state machine (EFSM) diagram. The collision avoidance task
Await Inter- consists of the following activities.
Set Event 1 national x The first subtask named radar signal processor processes the radar signal on a signal
alarm Button Operator processor to generate the track record in terms of the target’s location and velocity
(15sec) release within 100 mSec of receipt of the signal.
x The track record is transmitted to the data processor within 1 mSec after the track
Timer
alarm/ record is determined.
Set Await Dial x A subtask on the data processor correlates the received track record with the track
alarm Event 2 Tone records of other targets that come close to detect potential collision that might occur
(15sec) Button
release/ within the next 500 mSec.
dial tone x If a collision is anticipated, then the corrective action is determined within 10 mSec
Timer by another subtask running on the data processor.
alarm Await x The corrective action is transmitted to the track correction task within 25 mSec.
Button 6. Consider the following (partial) specification of a real-time system:
Release The velocity of a space-craft must be sampled by a computer on-board the spacecraft at
least once every second (the sampling event is denoted by S). After sampling the velocity,
the current position is computed (denoted by event C) within 100 msec, parallelly, the
Fig. 35.11 A Model of a Durational Constraint expected position of the space-craft is retrieved from the database within 200 msec
(denoted by event R). Using these data, the deviation from the normal course of the space-
craft must be determined within 100 msec (denoted by event D) and corrective velocity
The EFSM model for this example is shown in Fig. 35.11. Note that we have introduced two adjustments must be carried out before a new velocity value is sampled in (the velocity
intermediate states “Await Event 1” and “Await Event 2” to model a durational constraint. adjustment event is denoted by A). Calculated positions must be transmitted to the earth
station at least once every minute (position transmission event is denoted by the event T).
3. Exercises Identify the different timing constraints in the system. Classify these into either
performance or behavioral constraints. Construct an EFSM to model the system.
1. Mark the following as True or False. Justify your answer. 7. Construct the EFSM model of a telephone system whose (partial) behavior is described
a. A deadline constraint between two stimuli can be considered to be a behavioural below:
constraint on the environment of the system. After lifting the receiver handset, the dial tone should appear within 20 seconds. If a dial
2. Identify and represent the timing constraints in the following air-defense system by means tone can not be given within 20 seconds, then an idle tone is produced. After the dial tone
of an extended state machine diagram. Classify each constraint into either performance or appears, the first digit should to be dialled within 10 seconds and the subsequent five digits
behavioral constraint. within 5 seconds of each other. If the dialling of any of the digits is delayed, then an idle
Every incoming missile must be detected within 0.2 seconds of its entering the radar tone is produced. The idle tone continues until the receiver handset is replaced.
coverage area. The intercept missile should be engaged within 5 seconds of detection of 8. What are the different types of timing constraints that can occur in a system? Give
the target missile. The intercept missile should be fired after 0.1 Seconds of its engagement examples of each.
but no later than 1 second.
3. Represent a wash-machine having the following specification by means of an extended
state machine diagram.
The wash-machine waits for the start switch to be pressed. After the user presses the start
switch, the machine fills the wash tub with either hot or cold water depending upon the
setting of the HotWash switch. The water filling continues until the high level is sensed.
The machine starts the agitation motor and continues agitating the wash tub until either the

Version 2 EE IIT, Kharagpur 13 Version 2 EE IIT, Kharagpur 14

You might also like