Security And Safety In Autonomous System Page 1
CPS 573: Security and Safety in Autonomous Systems, Fall 2021
University of Dayton
Homework Assignment 1, Due: 11:55 PM, 09/18/2021
Note: Students should start working on homework as early as possible. Please work by yourself
submit your solution as one file to Isidore.
Problem 1 (30 points): Consider a modified version of the Delay component, called OddDelay,
that has a Boolean input variable in, a Boolean output variable out, and two Boolean state variables
x and y. Both the state variables are initialized to 0, and the reaction description is given by:
if y then out := x else out := 0;
x := in;
y := ¬y.
a. Describe in words the behavior of the component OddDelay. (Hint: what is the output at odd
and even rounds?)
b. List a possible execution of the component if it is supplied with the sequence of inputs 0, 1, 1,
0, 1, 1, 1, 0, 0, 1 for the first tenth rounds.
c. Describe the component OddDelay as an extended-state machine with two modes. The mode
of the state machine should capture the value of the state variable y, while the state variable x
should be updated using assignments in the mode-switches.
d. Is the OddDelay component finite-state? Draw the corresponding Mealy machine.
Recall that Delay is:
Problem 2 (20 points): An Xor (Exclusive-Or) gate has two Boolean inputs 1 and 2, and a
Boolean output . The output is 1 when exactly one of its two inputs are 1 and is 0 otherwise.
Design the combinational component SyncXor to capture this desired functionality by composing
And, Or, and Not gates.
Problem 3 (30 points): In this problem, we will design a synchronous reactive component to set
the cruising speed of a vehicle. This component corresponds to the SetSpeed component in the
cruise-control system CruiseController. The SetSpeed component takes the following inputs:
– event(bool) cruise: This event models the user turning the cruise control on or off.
– nat speed: This input models the speed input from the vehicle (corresponds to the current
speed of the vehicle).
– event inc: This input models the user requesting an increase in the cruising speed.
– event dec: This input models the user requesting a decrease in the cruising speed.
It has one output:
– event(nat) cruiseSpeed: this output, if presents, contains the current cruising speed.
Page 2
The component maintains two state variables:
– an enumerated type variable called mode = {on, off} that keeps track of whether the
controller is turned on or off.
– a current desired (nat) speed s.
There are two constants called minSpeed and maxSpeed that we will use within the component.
The operation of the component is as follows. The component updates the state variable on
according to the following rule: every time the event cruise occurs, the variable mode is set to on.
Then the component outputs the cruising speed using the cruiseSpeed output variable. If the current
speed s is within the legal range minSpeed and maxSpeed, then the cruiseSpeed variable is set to
s; if not, it is set to the closest legal value (i.e. minSpeed or maxSpeed). Also, when mode is on, if
a dec event is received, then the cruising speed is decremented (restricting the lowest speed to
minSpeed), and when the inc event is received, the cruising speed is incremented (restricting the
highest speed to maxSpeed). If the mode variable is set to off, all input events except cruise are
ignored, and there is no output.
a. Show the synchronous reactive component that implements this functionality.
b. Suppose we want to add another input control for the driver, pause, with the following desired
behavior. When the cruise controller is on, if the driver presses pause, then the controller is
temporarily turned off. In the resulting paused state, the output cruiseSpeed should be absent,
and the events inc and dec should be ignored. Pressing pause again in this paused state should
resume the operation of the cruise controller, restoring the desired speed on pausing. Pressing
cruise in the paused state should switch the system off, and when the controller is off, pressing
pause should have no effect. Redesign the component SetSpeed with this additional input event
pause to capture the above specification. Hint: the component SetSpeed now maintains a state
variable mode that can be either on, paused, or off, i.e., mode = {on, paused, off}.
Problem 4 (20 points): We want to design an asynchronous process Split that is the dual of
Merge. The process Split has one input channel and two output channels 1 and 2. The
messages received on the input channel should
be routed to one of the output channels in a
nondeterministic manner so that all possible
splittings of the input stream are feasible
executions. Describe all the components of the
desired process Split.
Asynchronous merge component
Problem 5 (Bonus 20 points): Consider the asynchronous process
Merge[ ↦ ] | Merge[ 1 ↦ ][ 2 ↦ 3]
obtained by connecting two instances of the process Merge. Show the “compiled” version of this
composite process. Explain the input/output behavior of this composite process.
LDR 3302-21.01.01-1A24-S1, Organizational Theory and Behavior Unit III Essay Top of Form Bottom of Form…
Chapter 9 What are teratogens? Give 5 examples. Define each of these stages: Germinal, embryonic,…
You are a Financial Analyst that has been appointed to lead a team in the…
You are familiar with the ANA Code of Ethics and have a growing understanding of…
This week’s discussion will focus on management decision-making and control in two companies, American corporation…
Mary Rowlandson felt that the man who eventually came to own her, Quinnapin, was “the…