Industrial Automation
Industrial Automation
Industrial Automation
I ST / DEEC / API
http://users.isr.ist.utl.pt/~jag/courses/api1112/api1112.html
Slides 2010/2011 Prof. Paulo J orge Oliveira
Rev. 2011/2012 Prof. J osGaspar
Supervised Control of
Supervised Control of
Discrete Event Systems
Discrete Event Systems
MEEC 2011-2012
I ndustrial
I ndustrial
Automation
Automation
(Automa
(Automa
o de Processos I ndustriais)
o de Processos I ndustriais)
Page2
I ST / DEEC / API
...
Chap. 8 - SEDsand I ndustrial Automation [2 weeks]
Chap. 9 Supervised Control of SEDs[1 week]
* SCADA
* Methodologies for the Synthesis of Supervision Controllers
* Failure detection
Some jokes available in http://members.iinet.net.au/~ianw/cartoon.html
The End.
I ndustrial Automation
Syllabus:
Syllabus:
Page3
I ST / DEEC / API
History: The SCADA Web, http://members.iinet.net.au/~ianw/
Monitoring and Control of Discrete Event Systems
StphaneLafortune,
http://www.ece.northwestern.edu/~ahaddad/ifac96/introductory_workshops.htm
Tutorial: http://vita.bu.edu/cgc/MIDEDS/
http://www.daimi.au.dk/PetriNets/
Analysers,
and http://www.nd.edu/~isis/techreports/isis-2002-003.pdf (Users Manual)
Simulators: http://www.nd.edu/~isis/techreports/spnbox/ (Software)
Bibliography: * SCADA books http://www.sss-mag.com/scada.html
* Moody J . e AntsaklisP., Supervisory Control of Discrete Event
Systems using Petri Nets, Kluwer Academic Publishers, 1998.
* Cassandras, Christos G., "Discrete Event Systems - Modelingand
Performance Analysis," AksenAssociates, 1993.
* YamalidouK., Moody J ., Lemmon M. and AntsaklisP.
Feedback Control of Petri Nets Based on Place I nvariants
http://www.nd.edu/~lemmon/isis-94-002.pdf
Chap. 9 SupervisedControl of DES
Some
Some
pointers
pointers
on
on
Supervised
Supervised
Control
Control
of
of
DES
DES
Page4
I ST / DEEC / API
Supervision of DES: SCADA
Supervisory
Control
And
Data
Acquisition
Chap. 9 Supervised Control of DES
Page5
I ST / DEEC / API
Supervision of DES
SCADA topics
Remote monitoringof the state of automation systems
Loggingcapacity (resorting to specialized Databases)
Able to access to historical information (plots along time, with
selectable periodicity)
Advanced tools to design Human-Machine interfaces
Failure Detectionand Isolation capacity (thresholdand/or logical
functions) on supervised quantities
Access control
Chap. 9 Supervised Control of DES
Page6
I ST / DEEC / API
Examples of SCADA
Chap. 9 Supervised Control of DES
Supervision of DES
Page7
I ST / DEEC / API
Examples of software packages including
SCADA solutions
Chap. 9 Supervised Control of DES
Supervision of DES
Page8
I ST / DEEC / API
Hardware Support Architecture of SCADA
Field Bus
...
RTU
1
RTU
n
S
1
S
1
MTU A
1
A
1
...
...
Legend:
MTU - Main Terminal Unit
RTU - Remote Term. Unit
S Sensor
A - Actuator
Chap. 9 Supervised Control of DES
Supervision of DES
Page9
I ST / DEEC / API
And
Now
Something
Completely
Different
Chap. 9 Supervised Control of DES
Supervision of DES
Page10
I ST / DEEC / API
Objectives of the Supervised Control
Supervise and bound the work of the supervised DES
Reinforce that some properties are verified
Assure that some states are not reached
Performance criteria are verified
Prevent deadlocks in DES
Constrain on the use of resources (e.g. mutual exclusion)
Chap. 9 Supervised Control of DES
Supervision of DES
Page11
I ST / DEEC / API
Some history on Supervised Control
Methods for finite automata [Ramadgeet al.], 1989
some are based on brute-force search (!)
or may require simulation (!)
Formal verification of softwarein Computer Science
(since the 60s) and on hardware(90, ...)
Supervisory Control Method of Petri Nets, method based on
monitors[Giuaet al.], 1992.
Supervisory Control of Petri Nets based on Place Invariants
[Moody, Antsakliset al.], 1994 (shares some similitude with the
previous one, but deduced independently!...).
Chap. 9 Supervised Control of DES
Supervision of DES
Page12
I ST / DEEC / API
Advantages of the Supervisory Control of Petri Nets
Mathematical representation is clear (and easy)
Resorts only to linear algebra (matrices)
More compact then automata
Straightforward the representation of infinity state spaces
Intuitive graphical representation available
The representation of the controller as a Petri Net leads to
simplified Analysis and Synthesis tasks
Chap. 9 Supervised Control of DES
Supervision of DES
Page13
I ST / DEEC / API
Place I nvariants
Place invariants are sets of places whose token count remains always constant.
Place invariants can be computed from integer solutions of x
T
D = 0. Non-zero
entries of x correspond to the places that belong to the particular invariant.
Chap. 9 Supervised Control of DES
Supervision of DES
Supervisor Synthesis using Place I nvariants [I SI S docs]:
What type of relations can be represented in the method of PlaceInvariants?
Sets of linear constraints in the state space
Representation of convex regions(there are extensions for non-convex regions)
Constraints to guarantee livenessand to avoid deadlocks(that can be expressed, in
general, as linear constraints)
Constraints on the events and timings (that can be expressed, in general, as linear
constraints)
Page14
I ST / DEEC / API
Methods of Analysis/Synthesis
Chap. 9 Supervised Control of DES
Method of the Matrix Equations (just to remind)
The dynamics of the Petri net state can be written in
compact form as:
where:
(k+1)- marking to be reached
(k) - initial marking
q(k) - firing vector (transitions)
D - incidence matrix. Accounts the balance of
tokens, giving the transitions fired.
( ) ( ) ( ) k Dq k k + = + 1
Page15
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Analysis/Synthesis
How to build the I ncidence Matrix? (just to remind)
For a Petri net with nplaces and mtransitions
n
N
0
e
m
N q
0
e
m n
D D D
+
Z e =
The enabling firing rule is
Can also be written in compact form as the inequality
interpreted element by element.
. q D
>
, 0 > + Dq
Page16
I ST / DEEC / API
Some notation for the method
The supervised system is modelled as a Petri net with
nplaces and mtransitions, and incidence matrix
.
m n
P
D
Z e
The supervisor is modelled as a Petri net with
places and m transitions, and incidence matrix
C
n
.
m n
C
C
D
Z e
The resulting total system has an incidence matrix
.
) ( m n n
C
D
+
Z e
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page17
I ST / DEEC / API
Theorem: (T1)
Synthesis of Controllers based on Place I nvariants
Given the set of linear state constraints that the supervised
system must follow, written as
. , ,
0
C C
n n n
n
P P
Z b and Z L N b L e e e s
If then the controller with incidence matrix
and the initial marking, respectively
and
enforce the constraints to be verified for all markings obtained
from the initial marking.
,
P C
LD D = ,
0 0
P C
L b =
, 0
0
>
P
L b
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page18
I ST / DEEC / API
Theorem- proof outline :
The constraint can be written as
using the slack variables They represent the marking
of the n
C
places of the controller.
To have a place invariant, the relation must be
verified and in particular, given the previous constraint:
resulting
b L
P
s , b L
C P
= +
.
C
0 = D x
T
| | , 0 =
(
=
C
P
T
D
D
I L D x
.
P C
LD D =
,
0 0
b L
C P
= +
From follows that
.
0 0
P C
L b =
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page19
I ST / DEEC / API
.
. p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
Example of controller synthesis: Mutual Exclusion
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
P
D
1
4 2
s +
Linear constraint:
.
0
1
0
1
0
(
(
(
(
=
P
b L
P
s
| | . 1 1 0 1 0
4
3
2
1
s
(
(
(
(
= =
P C
LD D
| | . 0 1
0
1
0
1
1 0 1 0 1
0
> =
(
(
(
(
=
P
L b
1) Test
2) Compute
. 1
0 0
= =
P C
L b
OK.
OK.
and
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis: Mutual Exclusion
Page21
I ST / DEEC / API
3) Resulting in
(
(
(
(
(
(
=
0
1
0
1
0
.
.
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
p
C
(
(
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
D
1 1 1 1
1
OK.
UAU!!!.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis: Mutual Exclusion
Page22
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Synthesis
Result using the function
LINENF.mof the
toolbox SPNBOX:
Example of controller synthesis: Mutual Exclusion
Page23
I ST / DEEC / API
Definition:
Maximal permissivityoccurs when all the linear constraints
are verified andall legal markings can be reached.
Lemmas:
i) The controllersobtained with T1 have maximal permissivity.
ii) Given the linear constraints used, the place invariants
obtained with the controller synthesized with T1 are the same
as the invariants associated with the initial system.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page24
I ST / DEEC / API
Readers / Writers
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
s t
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
P
D
n n s +
4 2
Linear constraints
for nbooks:
.
0
0
0
(
(
(
(
=
t
s
P
b L
P
s
| | . 0 1 0
4
3
2
1
n n s
(
(
(
(
0 0 0
, , N n N t N s e e e
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
That can be written as:
Incidence
Matrix
and initial
marking
Page25
I ST / DEEC / API
| | | |, 1 1
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
0 1 0 n n n LD D
P C
=
(
(
(
(
= =
| | . 0
0
0
0 1 0
0
> =
(
(
(
(
= n
t
s
n n L b
P
1) Test
2) Compute
.
0 0
n L b
P C
= =
OK.
OK.
and
Chap. 9 Supervised Control of DES
Methods of Synthesis
Readers / Writers
Example of controller synthesis
Page26
I ST / DEEC / API
3) Resulting in
(
(
(
(
(
(
=
0
0
0
t
s
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
p
C
s t
n
n
n
(
(
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
D
n n 1 1
n
OK.
UAU!!!.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Readers / Writers
Example of controller synthesis
Page27
I ST / DEEC / API
Advantages of the Method of the Place I nvariants [I SI S docs]:
Other characteristics that can impact on the solutions?
Existence and uniqueness
Optimality of the solutions (e.g. maximal permissivity)
Existence of transition non-controllable and/or not observable
(remind definitions for time-driven systems)
In general the solutions can be found solving:
Linear Programming Problems, with Linear Constraints
Chap. 9 Supervised Control of DES
Supervision of DES
Page28
I ST / DEEC / API
Let p2=#machines working, t2=product produced
p3=#consumers, t3=request to consume (e.g. transport product)
Q: How to write consume only when produced? What is the linear constraint?
Not possible to write it as a linear constraint on places L
p
b .
Is it impossible to solve this problem with the proposed method ?
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
P
D .
0
0
0
(
(
(
(
=
t
s
P
Incidence
matrix
Initial
marking
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
s t
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis: s Producers / t Consumers
Page29
I ST / DEEC / API
Let the generalized linear constraint be
, , , ,
, , ,
,
0 0 0
C C C C
n m n m n n n
m
P
m
P
n
P
P P P
Z b e Z C Z F Z L
N q N v N
b Cv Fq L
e e e e
e e e
s + +
where
* is the marking vector for system P;
* is the firing vector since t
0
;
* is the number of transitions (firing) that can occur,
also designated as Parikh vector.
P
P
q
P
v
Generalized linear constraint
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page30
I ST / DEEC / API
Theorem: Synthesis of Controllers based on Place I nvariants,
for Generalized Linear Contraints
Given the generalized linear constraint
if then the controller with incidence matrix
and initial marking, respectively
guarantees that constraints are verified for the states resulting from the
initial marking.
( )
( ) ( ) ( ), , 0 min , 0 max , 0 max
, , 0 max
C LD C LD F D
F C LD D
P P C
P C
+ + =
+ =
+
,
0
0 0
P P C
Cv L b =
, 0
0
>
P
L b
, b Cv Fq L
P P P
s + +
Function LI NENF of SPNBOX
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page31
I ST / DEEC / API
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
s t
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
P
D
2 3
v v s
Linear constraint:
.
0
0
0
(
(
(
(
=
t
s
P
0 , 0 = =
s
F L
b Cv
P
| | . 0 0 1 1 0
4
3
2
1
s
(
(
(
(
v
v
v
v
That can be written as:
Incidence
matrix
Initial
marking
0 0 0
, , N n N t N s e e e
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Producer / Consumer
Page32
I ST / DEEC / API
. 0 0 0
0
> =
P
L b
1) Test
2) Compute
. 0 0 0
0 0
= = =
P C
L b
OK.
OK.
and
( )
( ) ( )
] 0 0 1 0 [ ] 0 0 1 0 [ ] 0 0 0 0 [
] 0 1 1 0 [ , 0 min ] 0 1 0 0 [ , 0 max
] 0 1 0 0 [ 0 ], 0 1 1 0 [ , 0 max
= =
=
= =
+
C
C
D
D
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Producer / Consumer
( )
( ) ( ) ( ), , 0 min , 0 max , 0 max
, , 0 max
C LD C LD F D
F C LD D
P P C
P C
+ + =
+ =
+
,
0
0 0
P P C
Cv L b =
Page33
I ST / DEEC / API
(
(
(
(
(
(
=
0
0
0
t
s
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
p
C
s t
(
(
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
D
0 1 1 0
0
OK.
UAU!!!.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Producer / Consumer
3) Resulting in
Page34
I ST / DEEC / API
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t
s t
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
P
D
s
s
+ s
s
n v v
v v
n v v
v v
3 2
2 3
3 2
2 3
0
TWO linear constraints:
.
0
0
0
(
(
(
(
=
t
s
P
= =
s
0 , 0 . . F L e i
b Cv
P
(
s
(
(
(
(
n
v
v
v
v
0
0 1 1 0
0 1 1 0
4
3
2
1
The two linear constraints
can be written as:
Incidence
matrix
Initial
marking
0 0 0
, , N n N t N s e e e
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Bounded
Producer /
Consumer
Page35
I ST / DEEC / API
.
0 1 0 0
0 0 1 0
0 1 0 0
0 0 1 0
0 0 0 0
0 0 0 0
0 1 1 0
0 1 1 0
, 0 min
0 1 1 0
0 1 1 0
, 0 max 0 , 0 max
,
0 0 1 0
0 1 0 0
0 ,
0 1 1 0
0 1 1 0
, 0 max
(
=
(
=
|
|
.
|
\
|
(
|
|
.
|
\
|
|
|
.
|
\
|
(
=
(
=
|
|
.
|
\
|
(
=
+
C
C
D
D
. 0
0
0
>
(
= =
n
b L b
P
1) Test
2) Compute
.
0
0 0
(
= =
n
L b
P C
OK.
OK.
and
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Bounded Producer / Consumer
Page36
I ST / DEEC / API
3) Resulting in
(
(
(
(
(
(
(
(
=
0
0
0
t
s
(
(
(
(
(
(
(
(
=
1 1 0 0
1 1 0 0
0 0 1 1
0 0 1 1
D
0 1 1 0
0 1 1 0
n
0
OK.
UAU!!!.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example of controller synthesis
Bounded Producer / Consumer
p
1
p
p p
2
3
4
4
t
3
t
1
t
2
t p
C
s t
1
p
C
2
n
Page37
I ST / DEEC / API
Definition of Uncontrollable Transition:
A transition is uncontrollable if its firing cannot be inhibitedby an external
action (e.g. a supervisory controller).
Definition of Unobservable Transition:
A transition is unobservable if its firing cannot be detected or measured
(therefore the study of any supervisory controller can not depend from that
firing).
Proposition:
For a Petri net based controller, both input and output arcs to the plant transitions are
used to trigger state changes in the controller. A controller can not have arcs that
connect to an unobservable transition, thus all unobservable transitions are also
implicitly uncontrollable.
Chap. 9 Supervised Control of DES
Methods of Synthesis:
adding Uncontrollable and Unobservable transitions
Page38
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Synthesis:
adding Uncontrollable and Unobservable transitions
Assuming that t1 is controllable and t2 is uncontrollable:
- case (a) t2 cannot be directly inhibited; it will eventually fire
- case (b) t2 can be indirectly preventedfrom firing by inhibiting t1.
Assuming that t2 is unobservable and t3 is observable, i.e. we cannot detect
when t2 fires. The state of a supervisor is not changed by firing t2. However
we can indirectly detect that t2 has fired, by detecting the firing of t3.
Page39
I ST / DEEC / API
Definition: A marking
P
is admissibleif
i) L
P
b and ii) e R(C,
Po
) verifies L b
Definition: A Linear Constraint (L, b) is admissibleif
i) L
Po
b and
ii) e R(C,
Po
) such that L b
is an admissible marking.
Chap. 9 Supervised Control of DES
Methods of Synthesis
Note: ii) indicates that the firing of uncontrollable transitions can never lead from a
state that satisfies the constraint to a new state that does not satisfy the constraint.
Page40
I ST / DEEC / API
Proposition: Admissibility of a constraint
A linear constraint is admissible iff
The initial markings satisfy the constraint.
There exists a controller with maximal permissivitythat forces the
constraint and does not inhibit any uncontrollable transition.
Corollary: given a system with uncontrollable transitions,
implies admissibility. 0 s
uc
T
D l
Corollary: given a system with unobservable transitions,
implies admissibility. 0 =
uo
T
D l
Methods of Synthesis
Chap. 9 Supervised Control of DES
Two sufficient (not necessary) conditions:
Page41
I ST / DEEC / API
Lemma: Structure of Constraint transformation
Let
be a matrix with positive elements in the diagonal,
If there exists
such that
then it is also verified that
Function MRO_ADM of SPNBOX
, 0
1 1
> e
P
n n
R that such Z R
C
C C
n n
Z R
e
2
( ) , 1 1
2
'
2 1
'
+ =
+ =
b R b
L R R L
' '
b L
P
s
. b L
P
s
Chap. 9 Supervised Control of DES
Methods of Synthesis
Page42
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example: design controller with t1 unobservable
Objectives:
1
+
3
1 and
2
+
3
1 which can be written in matrix
form as
Example extracted from Supervised Control of Concurrent Systems: A Petri Net
Structural Approach, M. Iordacheand P. Antsaklis, Birkhauser 2006.
Page43
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example: design controller with t1 unobservable
Solution obtained with the function MRO_ADM.mof the SPNBOX toolbox:
Note: verify that L
a
b
a
impliesL b
Page44
I ST / DEEC / API
Chap. 9 Supervised Control of DES
Methods of Synthesis
Example: design controller with t1 unobservable
Finally the supervised controller is simply obtained from L
a
and b
a
:
(
=
(
(
(
=
=
(
=
(
(
(
=
=
1
1
0
1
1
1 2 0
1 0 2
1
1
1 1 0
1 1 0
1 1 2
1 0 1
0 1 1
1 2 0
1 0 2
0 0 p a a c
p a c
L b
D L D
Page45
I ST / DEEC / API
This course is ending. What is next?
Page46
I ST / DEEC / API
Top 10 Challenges in Logic Control for Manufacturing Systems
byDawn TilburyfromUniversityof Michigan
10. Distributed Control (General management of distributed control applications,
Open/distributed control -- ethernet-based control)
9. Theory (No well-developed and accepted theory of discrete event control,
in contrast to continuous control)
8. Languages (None of the programming languages do what we need but nobody
wants a new programming language)
7. Control logic synthesis (automatically)
6. Standards (Machine-control standards -- every machine is different, Validated standards,
Standardizing different types of control logic programming language)
5. Verification (Standards for validation, Simulation and verification of controllers)
4. Software (Software re-usability -- cut and paste, Sophisticated software for logic control,
User-unfriendly software)
3. Theory/Practice Gap (Bridging the gap between industry and academia,
Gap between commercial software and academic research)
2. Education (Educating students for various PLCs, Education and keeping current with
evolution of new control technologies, Education of engineers in logic control,
Lack of curriculum in discrete-event systems)
And the number one challenge in logic control for manufacturingsystems is...
1. Diagnostics (Integrating diagnostic tools in logic control, Standardized methodologies for design,
development, and implementation of diagnostics)
Page47
I ST / DEEC / API
Chap. 9 Supervised Control of DES
The End.