Validation of Mixed Signal-Alpha Real-Time Systems through Affine Calculus on Clock Synchronisation Constraints by Smarandache, Irina et al.
Validation of Mixed Signal-Alpha Real-Time Systems
through Affine Calculus on Clock Synchronisation
Constraints
Irina Smarandache, Thierry Gautier, Paul Le Guernic
To cite this version:
Irina Smarandache, Thierry Gautier, Paul Le Guernic. Validation of Mixed Signal-Alpha Real-
Time Systems through Affine Calculus on Clock Synchronisation Constraints. World Congress
on Formal Methods in the Development of Computing Systems (FM’99), Sep 1999, Toulouse,
France. Springer, pp.1364-1383, 1999, LNCS vol. 1709. <10.1007/3-540-48118-4 22>. <hal-
00548887>
HAL Id: hal-00548887
https://hal.archives-ouvertes.fr/hal-00548887
Submitted on 20 Dec 2010
HAL is a multi-disciplinary open access
archive for the deposit and dissemination of sci-
entific research documents, whether they are pub-
lished or not. The documents may come from
teaching and research institutions in France or
abroad, or from public or private research centers.
L’archive ouverte pluridisciplinaire HAL, est
destine´e au de´poˆt et a` la diffusion de documents
scientifiques de niveau recherche, publie´s ou non,
e´manant des e´tablissements d’enseignement et de
recherche franc¸ais ou e´trangers, des laboratoires
publics ou prive´s.

Validation of Mixed Signal-Alpha Real-Time
Systems through Ane Calculus on Clock
Synchronisation Constraints
Irina M. Smarandache
1
, Thierry Gautier
2
, and Paul Le Guernic
2
1
The University of Reading, Department of Computer Science
Whiteknights, PO Box 225, Reading RG6 6AY, United Kingdom
Tel.: (44) 118 931 8611 (7626), Fax: (44) 118 975 1994
I.M.Smarandache@reading.ac.uk
2
IRISA-INRIA, Campus de Beaulieu, 35042 Rennes Cedex, France
Thierry.Gautier@irisa.fr, Paul.LeGuernic@irisa.fr
Abstract. In this paper we present the ane clock calculus as an exten-
sion of the formal verication techniques provided by the Signal lan-
guage. A Signal program describes a system of clock synchronisation
constraints the consistency of which is veried by compilation (clock cal-
culus). Well-adapted in control-based system design, the clock calculus
has to be extended in order to enable the validation of Signal-Alpha ap-
plications which usually contain important numerical calculations. The
new ane clock calculus is based on the properties of ane relations in-
duced between clocks by the renement of Signal-Alpha specications
in a codesign context. Ane relations enable the derivation of a new set
of synchronisability rules which represent conditions against which syn-
chronisation constraints on clocks can be assessed. Properties of ane
relations and synchronisability rules are derived in the semantical model
of traces of Signal. A prototype implementing a subset of the synchro-
nisability rules has been integrated in the Signal compiler and used for
the validation of a video image coding application specied using Signal
and Alpha.
1 Introduction
Real-time systems, and more generally reactive systems [4], are in continuous
interaction with their environment. Therefore, they must respond in time to
external stimuli. Moreover, real-time systems must be safe, thus one would wish
to prove their correctness. Time constraints and safety are two important aspects
to be considered in the design of a real-time application.
Real-time systems may be constrained by very tight real-time deadlines.
Moreover, a hardware implementation of parts of these systems is sometimes
required, to meet specic constraints for instance. An example is an application
consisting of numerical calculations performed iteratively on large structures of
regular multidimensional data. In this case, a hardware/software implementation
may be envisaged, in which the numerical calculations are conveyed to hardware
for eciency reasons, while the control relating these parts is implemented in
software.
In general, designing a mixed hardware/software real-time system requires a
rigorous methodology that comprises methods and tools addressing, among oth-
ers, system specication and validation, optimal code generation and hardware
synthesis. These aspects are dealt with in codesign [7] [9] which denotes the spec-
ication, validation and implementation of an application which consists both
of a hardware part, in the form of a set of specialised integrated circuits, and a
software part implemented on general programmable processors. The idea is to
explore various possible implementations of hardware/software systems in order
to improve their performance and to ensure the respect of cost constraints.
1.1 Real-Time System Codesign
System codesign is a complex process which can be decomposed into three main
activities [7]: 1. The cospecication of an application at various levels of abstrac-
tion; 2. The validation of a specication by formal verication or simulation, also
known as cosimulation; 3. The hardware/software partitioning of an application,
the evaluation of a partitioning from the point of view of the time constraints
and cost, the generation of executable code, the synthesis of hardware, and the
production of the interface between hardware and software, i.e cosynthesis. A
lot of work has been done, the purpose of which was to dene a well-structured
methodology for codesign [7] [11] [19]. An important point was generally the
description of both hardware and software using the same language, like for in-
stanceVhdl enhanced with mechanisms for callingC functions [14], or high-level
languages like C, C++ or Fortran extended with facilities for the description
of hardware systems [10]. These approaches enable the programming of both the
hardware and software parts of a system in a unique framework and their vali-
dation by simulation. However, they cannot guarantee system correctness. This
aspect can be much improved by using formal languages for system specication,
renement of specications towards lower levels of abstraction (implementation)
and validation of the various specications by formal verication.
Dening a complete methodology of codesign requires addressing other rel-
evant problems, most of them concerning cosynthesis. Among these problems
there are the automatic partitioning into hardware and software, the synthesis
of hardware and the generation of optimal code for software implementation.
The work presented in this paper is part of a more general eort for building
a hybrid framework in which the Signal [12] [13] and Alpha [20] languages can
be used for real-time system codesign.
1.2 Cospecication and Cosimulation of Signal-Alpha Systems
Signal is a synchronous [4] language developed for the specication, validation
and implementation of real-time systems. Signal variables represent nite or
innite sequences of values (data) which can be ltered or merged before being
submitted to classical boolean or mathematical operations. A clock is implicitly
associated with each Signal variable: it represents a set of temporal indices
which denote the logical instants where the variable is present and has a value.
The semantics of a Signal program can be described by a system of constraints
(relations) on clocks and values, which is constructed and veried for consistency
during compilation. The verication of the clock constraints is called clock cal-
culus. The Signal environment is enhanced with tools for C [5] and Vhdl [3]
code generation and formal verication of dynamic properties [2].
In its present form, Signal is well-adapted for the design of control-based
real-time systems. Firstly, this is due to its limitations concerning the treatment
of computations on multidimensional data such as matrices. Only simple algo-
rithms can be expressed in Signal and no signicant optimisation is performed
at the level of the generation of executable C or Vhdl code concerning vectors.
In contrast with Signal, the Alpha language has been developed primarily for
the specication and implementation of algorithms on multidimensional data.
Such algorithms can be described in Alpha using ane recurrence equations
over convex polyhedral domains [20] and be further transformed for optimal
hardware or software implementation on parallel or sequential architectures [21].
Given their complementary properties, the Signal and Alpha languages
can be used jointly for the design of real-time systems containing important
numerical calculations on multidimensional data and control: numerical compu-
tations are expressed in Alpha and the control is conveyed to Signal. When the
real-time requirements of the system are very tight, a mixed hardware/software
implementation may be envisaged. In [9] we propose a hybrid framework for the
combined use of Signal and Alpha in real-time system codesign. In order for
this framework to be operational, it is necessary to interface Signal and Alpha
programs both at the functional and architectural level. The former corresponds
to a high-level mathematical representation of an algorithm in Alpha, while the
latter contains a set of new temporal indices corresponding to the execution of
the algorithm on a parallel or sequential architecture.
In Signal-Alpha systems, the renement of an Alpha program from a
functional level to an architectural level oriented toward a particular implemen-
tation also induces a renement of the temporal indices in Signal. The new
time indices are obtained through ane transformations on the instants of time
of the initial Signal specication. Consider clocks c and c
1
in Signal which
are identical at the functional level (they are also denoted as synchronous). Af-
ter renement, their relative position is such that clock c
1
can be obtained by
an ane transformation applied to clock c: the instants of time of c and c
1
,
denoted respectively T and T
1
, can be described by a pair of ane functions
T = fnt+ '
1
j t 2 T g, T
1
= fdt+ '
2
j t 2 T g, on the same set of instants T .
With ' = '
2
  '
1
, we will say that clock c
1
is obtained by an (n; '; d)-ane
transformation applied to clock c, where n; d 2 IIN

the set of strictly positive
integers and ' 2
6
Z the set of integers. Clocks c and c
1
are also said to be in an
(n; '; d)-ane relation.
Clocks obtained by ane transformation may be re-synchronised at the ar-
chitectural level. As an example, consider clocks c, c
1
and c
2
which are identical
in the Signal functional specication. At the architectural level, clocks c
1
and
c
2
have been transformed such that c, c
1
and c, c
2
are respectively in ane
relations of parameters (n
1
; '
1
; d
1
) and (n
2
; '
2
; d
2
). Whether clocks c
1
and c
2
can be re-synchronised depends on the properties of the ane relations which
are induced from the values of (n
1
; '
1
; d
1
) and (n
2
; '
2
; d
2
). Moreover, the rela-
tions between c, c
1
and respectively, c, c
2
may be expressions on (n; '; d)-ane
relations constructed using operations like composition, union, etc. In this case,
the re-synchronisation of clocks c
1
and c
2
depends on the properties of these
operations.
The Signal clock calculus performs the verication of clock synchronisation
constraints using a set of synchronisability rules, i.e. conditions against which
these constraints can be assessed. The current clock calculus depends on boolean
equation resolution methods [5] [1] which have been successfully used for the val-
idation of numerous control-based real-time applications. However, in order to
validate mixed Signal-Alpha systems as presented above, it is necessary to ex-
tend the current clock calculus with a set of synchronisability rules deduced from
the properties of (n; '; d)-ane relations. The new set of rules denes the ane
clock calculus, which constitutes the main topic of this paper. We explore the
space of (n; '; d)-ane relations and study to which extent it is closed under the
main operations that can be performed on ane relations. Following this study,
we dene a set of synchronisability rules which, although incomplete, enables
the validation of the principles underlying the cospecication and cosimulation
using Signal and Alpha. The semantical model of traces of Signal [12] [16]
constitutes the support for the study of the properties of ane relations and for
the denition of the new synchronisability rules.
1.3 Organisation of the Paper
In Section 2 we present the integration of Signal and Alpha for system code-
sign. Section 3 is the central core of this paper and is dedicated to the denition
and implementation of the ane clock calculus. The main concepts useful for
this purpose are progressively introduced: these are the model of traces of the
Signal language, the properties of ane relations on clocks, the set of synchro-
nisability rules induced by the latter, and nally the necessary elements for the
integration of the ane clock calculus in the compiler. The ane clock calculus
has been applied to the cospecication and cosimulation of a video image coding
application; this is briey illustrated in Section 4. In the same section we discuss
in which way the Signal and Alpha environments may further contribute to
the development of a complete codesign methodology based on both languages.
Finally, in Section 5 we present conclusions and perspectives of our work.
2 Signal and Alpha in Real-Time System Codesign
Figure 1 summarizes the main elements of the environments around Signal and
Alpha that make both languages well-adapted for real-time system codesign.
Signal and Alpha programs represent mathematical notations for the proper-
ties of the processes they dene. The system of constraints on clocks and values
associated with a Signal program is transformed by compilation into a synchro-
nised data ow graph (Sdfg). This data structure constitutes the support for
executable code generation (C or Vhdl) or verication of dynamic properties
using the formal tool Sigali [2].
The Alpha compiler includes a powerful type checking mechanism based on
the structure of an Alpha variable as a function over convex polyhedra. The
syntax tree obtained after compilation can be directly translated into C code for
functional simulation, or it can be transformed into a subset ofAlpha calledAl-
pha0 which exhibits the details of a parallel or sequential implementation. The
syntax tree in Alpha0 form can be further translated in C or Vhdl executable
code or directly mapped on a netlist [21].
The interface between Signal and Alpha is based on the fact that both
languages can be translated in C and executed for functional simulation. Fur-
thermore, Signal oers the possibility to call external processes: such a process
can be the specication of an algorithm in a language other than Signal. A
particular type of an external process is a function, the execution of which is
considered instantaneous from the point of view of Signal. A Signal function
can be a predened or a user-dened C function.
Fig. 1. Signal and Alpha in system codesign.
2.1 Functional Cospecication and Cosimulation
Being a synchronous language, Signal is based on the following hypotheses [4]:
1. All actions (communications and calculations) in a system have zero logical
duration (the elapsed time is represented by the precedence of successive values
on a same data ow); 2. Two or more actions can take place at the same logical
instant, such actions being termed \simultaneous". From the point of view of
the logical temporal properties of a system, only succession and simultaneity
of instants are of interest. Although their exact time values are not considered,
note however that they will be considered for a given implementation. The pro-
cess associated with a Signal program represents thus a succession of logical
instants, with each instant being associated one or more actions considered of
zero logical duration and involving process variables present at that instant.
Consider for example a coding system for sequences of video images at 34
Mbits/s [8]. A system of this type consists of a set of numerical treatments
applied iteratively on images of the same dimension. Images are divided into
luminance and chrominance blocks and treatments are applied to each block.
Numerical treatments consist mainly of algorithms for inter and intra image
coding which require operations like a discrete cosine transformation (Dct). In
order to illustrate the interfacing between Signal and Alpha, we have isolated
from the coding application a simple Signal program and have illustrated the
associated process in Fig. 2. It consists of aDct operation applied in sequence to
dierent values A
i
of the matrix of pixels A present at each logical instant of time
t
i
. The matrixA corresponds to a block of luminance or chrominance of an image.
The Dct can be expressed in Signal as B := Dct(A), where Dct is actually an
external process. The Dct is a time consuming algorithm, particularly for large
matrices or when applied to images containing a large number of blocks. In order
to improve the overall performance of the coding application, one would wish
to execute each instance B
i
:= Dct(A
i
) on a parallel integrated architecture as
derived by the Alpha environment.
The Dct can be easily described in Alpha. The Signal-Alpha cospecica-
tion and cosimulation of the new system is made possible at the functional level
as follows (see Fig. 2): 1. The Alpha system is translated in executable C code;
2. The C function ALPHA C obtained at step 1 represents the external process
implementing the Dct in Signal. The function ALPHA C is considered instan-
taneous in Signal; the clocks of the matrices A and B, denoted respectively by
c and c
1
, are therefore synchronous. The overall system is thus represented as
a Signal specication executing instantaneously the functional description of
the Alpha specication. The system can be validated in the Signal environ-
ment by formal verication (compilation, model checking with Sigali) and/or
simulation.
2.2 Implementation-oriented Cospecication and Cosimulation
A mixed Signal-Alpha specication at the functional level may be rened in
order to take into consideration the details of a particular implementation. The
Alpha program of Section 2.1 describing a Dct may be submitted to a sequence
of transformations for a parallel or sequential implementation. These transfor-
mations guarantee the equivalence of the nal specication, noted ALPHA' in
Fig. 3, with the initial ALPHA system of Fig. 2. The system ALPHA' contains
Fig. 2. Signal-Alpha interface at functional level.
the time indices corresponding to a particular scheduling of the Dct operation.
In Fig. 3 these time indices are represented as the diagonal sets of micro-instants
t
j
i
associated with each macro-instant t
i
.
The Signal specication has to be rened accordingly in order to enable the
validation of the overall system. Therefore, the micro-instants of time of ALPHA'
are taken into consideration in the new process SIGNAL' and described as the
sets of instants St
i
0
, St
i
1
, etc. (see Fig. 3). The C function ALPHA' C has
been derived from ALPHA' and transformed in order to describe the sequence
of operations performed at each micro-instant of time.
Fig. 3. Signal-Alpha interface at architectural level.
The regularity of Alpha values manifests itself in Signal in several ways.
First, the sets of micro-instants St
i
0
, St
i
1
, etc. have the same cardinality. Also,
successive values for B are provided at specic micro-instants between any two
successive macro-instants t
i
and t
i+1
in a regular manner. This situation is il-
lustrated in Fig. 4 where the clocks of matrices A and B, denoted respectively
by c and c
1
, are dened by the following instants of time: c = f0; 9; 18; :::g and
c
1
= f6; 15; :::g (after providing the values B
i
at the instants of time dened by
c
1
, the architecture implementing the operation B
i
:= Dct(A
i
) may execute fur-
ther computations like initialisations for the next operation B
i+1
:= Dct(A
i+1
)).
Fig. 4. Illustration of an ane relation.
In Fig. 4, clock c
0
is dened by the set of instants f0; 1; 2; 3; 4; 5; :::g. It can
be noticed that clocks c and c
1
are placed in a regular manner on the sup-
port clock c
0
: their relative position is such that c
1
has been obtained through
an (9; 6; 9)-ane transformation applied to c. By denition, clock c
1
is the re-
sult of an (n; '; d)-ane transformation applied to clock c if it can be obtained
from c through steps 1 and 2 as follows: 1. Constructing a new clock c
0
as the
union of c with the set of instants obtained by introducing n   1 ctive in-
stants between any two successive instants of c (and  ' ctive instants before
the rst instant of c when ' is negative). 2. Dening the clock c
1
as the set
of instants fdt+ ' j t 2 c
0
g, with c
0
= ft j t 2 IINg (in other words, counting ev-
ery d instant, starting with the '
th
instant of c
0
, or with the rst instant of
c
0
when ' is negative). Clocks c and c
1
are then said to be in an (n; '; d)-
ane relation. The above denition can be expressed in an equivalent form
as follows: clocks c and c
1
are in (n; '; d)-ane relation if there exists a clock
c
0
such that c and c
1
can be respectively expressed using the ane functions
t:(nt+ '
1
) and t:(dt+ '
2
), with '
2
  '
1
= ', with respect to the time in-
dices of c
0
: c
0
= ft j t 2 IINg, c = fnt+ '
1
j t 2 c
0
g, c
1
= fdt+ '
2
j t 2 c
0
g.
Properties on ane relations can be exploited in order to verify that
clocks are synchronisable, that is, their sets of instants can be identied (re-
synchronised). Consider (Fig. 2) a Signal program which executes two succes-
sive Dct operations at each macro-instant t
i
, one on a luminance block of an
image, noted B := Dct(A), and the second one on the next block of red chromi-
nance of the same image, described by D := Dct(C).
Each Dct function is expressed in Alpha at the functional level and further
rened according to a particular implementation. The Signal specication is
rened accordingly and we obtain the timing diagrams of Fig. 5: the clocks of A
and C are synchronous and equal to c, the clocks of B and D are respectively
c
1
and c
2
, and the clocks c
0
and c
00
describe the instants of the excution of the
Dct functions on a potential architecture derived in the Alpha environment.
In the functional Signal-Alpha specication, clocks c, c
1
and c
2
were syn-
chronous (see Section 2.1 for details). After renement of the time indices in
the Signal-Alpha specication, the clocks c
1
and c
2
should be re-synchronised
in order to preserve the temporal properties of the whole application. Whether
the re-synchronisation of c
1
and c
2
is possible given their relative position as
illustrated in Fig. 5, or after further adjustments of their time indices, can be
decided based on the properties of the ane relations existing between c, c
1
Fig. 5. Synchronisable clocks in the context of codesign with Signal and Alpha.
and c, c
2
respectively. Clocks c, c
1
and c, c
2
are respectively in (9; 6; 9) and
(7; 3; 7)-ane relation in the process SIGNAL'. The relation existing between
the triplets (9; 6; 9) and (7; 3; 7) guarantees the equivalence of the corresponding
ane relations. This will be detailed in Section 3. Informally, the equivalence of
the above ane relations expresses the fact that the relative positions of clocks
c and c
1
, respectively c and c
2
, are identical. Based on this observation, clocks
c
1
and c
2
can be identied without contradicting the temporal behaviour of the
other clocks in the Signal program. The instants of time of clocks c
0
and c
00
situated between two successive instants of c and c
1
(or c
2
) are independent and
can be positioned with respect to each other in various manners; in Fig. 5 we
have illustrated one possibility. Therefore, c
1
and c
2
can be re-synchronised; we
say that c
1
and c
2
are synchronisable.
The aim of the ane clock calculus discussed in Section 3 is to dene neces-
sary and sucient conditions for clock synchronisability based on the properties
of ane relations on clocks. These conditions are expressed as a set of synchro-
nisability rules and are derived in the semantical model of traces of Signal.
Section 3 begins with an introdution to these concepts.
3 Ane Calculus on Clocks in Signal
Figure 6 introduces the reader to the semantics of traces [12] [16] of Signal.
The most important concepts in Signal are: 1. the signal, which denotes a
variable of the language and represents a nite or innite sequence of values;
2. the clock, a variable associated with each signal which represents the set of
logical instants where the values of the signal are present. Signal operators
manipulate signals by imposing implicit or explicit constraints on their values
and clocks. Constraints on clocks are usually expressed as identities between
clock expressions constructed using the operators of intersection (^), union (_)
or dierence (n). Clocks can be also subsets of other clocks dened as samplings
by boolean conditions. When no condition is explicitly or implicitly stated on a
pair of clocks, they are independent.
Fig. 6. Illustration of Signal semantics of traces.
A Signal program describes a real-time system, which is in continuous inter-
action with its environment. Input values are transformed corresponding to the
actions of a given specication and the results are provided to the environment.
This situation is illustrated in Fig. 6 in the case of a program manipulating in-
puts x and y and providing output z depending on the values of x and y. In case
z is the addition of x and y, signals x, y and z are implicitly constrained by the
+ operator in Signal to have the same clocks c
x
= c
y
= c
z
.
The congurations F and F
0
illustrated in Fig. 6 correspond to two dierent
executions of the Signal program, involving sequences x
i
, y
i
and z
i
and respec-
tively x
0
i
, y
0
i
and z
0
i
. The set of all possible congurations, called traces, which
can be exhibited during the execution of a Signal program, denes completely
the process P associated with the program. Consider A a subset of the set B of
signals manipulated by a program. A trace may contain instants with no action
involving signals from A. However, each instant of this type contains actions
which involve other signals from the set BnA. Given a subset A of signals, a ow
on A is a trace with at least one action involving signals from A for each logical
instant. In the particular case of Fig. 6, if we consider the subset of signals to
be fx; y; zg, the traces illustrated are actually ows.
More generally, the process P associated with a Signal program is a set of
ows on the variables of the program. Each ow F in P is constrained by a system
of equations on the clocks and values of signals manipulated by P . Equations
on values can be further expressed in the abstract form of a data dependency
graph (an example of a data dependency graph is illustrated in Fig. 6 for the +
operator). Besides the clock calculus, the compiler veries data consistency by
checking the absence of cycles in the data dependency graph. In the next section
however, we will concentrate mainly on the clock calculus.
3.1 Clock calculus & Synchronisability
The clock calculus is equivalent to the resolution of a system of clock equations.
For example:
c = c
1
c
0
= (c
1
^ c
2
) _ c
1
c = c
0
(1)
can be a system derived from a Signal program which manipulates clocks c, c
0
,
c
1
and c
2
. In this simple system, c
1
and (c
1
^ c
2
) _ c
1
have clearly to be proved
equivalent, which is an immediate consequence of the axioms of the boolean
lattice. The space of clocks associated with a Signal program is a boolean lattice
[6] the properties of which are extensively used for the proof of equivalences. The
resolution of the system is performed by triangularisation of the system [5] [1].
Given a boolean signal Cd, its clock, denoted
^
Cd, can be partitioned into the
clock [Cd] where the signal Cd is present and true and the clock [:Cd] where Cd
is present and false (the clocks [Cd] and [:Cd] represent samplings by boolean
conditions). The relations between clocks
^
Cd, [Cd] and [:Cd] are expressed by
the partition equations below:
[Cd] _ [:Cd] =
^
Cd
[Cd] ^ [:Cd] = ;
(2)
The axioms of the boolean lattice together with the partition equations induce
on the space of clocks a lattice of an order  \coarser" than the order  of
the boolean lattice [5]. Clocks can be boolean formulas constructed either with
samplings by boolean conditions [Cd], [:Cd] or with free variables of the boolean
lattice. The properties of the lattice of order  are actually used during the
triangularisation of any system of clock equations.
The axioms of the lattice  represent a system of synchronisability rules in
the sense described below. Clocks c and c
0
are synchronisable in the process P ,
which is denoted by c
P
 c
0
, if there exists a ow F in P in which c and c
0
are
synchronous:
c
P
 c
0
, 9F 2 P; c
F
= c
0
(3)
(we note c
F
= c
0
the fact that c and c
0
are synchronous in F ).
Whenever the property expressed by equation 3 is valid for each ow F in P ,
the clocks c and c
0
are said to be synchronous in P , which is denoted by c
P
= c
0
.
This denition can be expressed as follows:
c
P
= c
0
, 8F 2 P; c
F
= c
0
(4)
Unless explicitly constrained through the Signal program, clocks c and c
0
are
completely independent in the associated P process. Therefore, their relative
position can be such that in some ows F in P they are identical, while in some
other ows F
0
in P their instants interleave in an arbitrary manner: obviously,
if c and c
0
are independent in P , they are synchronisable. When the relative
position of clocks c and c
0
is implicitly or explicitly constrained by the Signal
operators, ows F in P are subsequently constrained and the synchronisability
of c and c
0
depends on these constraints.
In order to better understand the use of the synchronisability rules, consider
for example a process P derived from a Signal program Prg in which clocks c
and c
0
are dened by the rst two equations of the system (1):
c = c
1
c
0
= (c
1
^ c
2
) _ c
1
(5)
Program Prg may be transformed into Prg
0
in which an additional constraint
has been expressed on clocks c and c
0
: c = c
0
(in the Signal-Alpha context, Prg
could be part of a transformed Signal-Alpha specication, as seen above, and
Prg
0
the same specication, in which clocks are resynchronised). Consider the
process P
0
corresponding to the program Prg
0
. The system of clock equations
associated with Prg
0
is (1). Given the set of ows F
0
 P such that c
F
= c
0
,
8F 2 F
0
, it results P
0
= F
0
. Therefore, verifying the consistency of (1), which is
equivalent to testing that clocks c and c
0
are equivalent in P
0
, is further equivalent
to testing the synchronisability of c and c
0
in P . The rule (c
1
^ c
2
)_ c
1
= c
1
from
the boolean lattice is indeed a synchronism rule: (c
1
^ c
2
) _ c
1
P
= c
1
for every
process P . The same axiom holds for the process P associated with Prg . And
thus (c
1
^ c
2
) _ c
1
P
 c
1
, since synchronism implies synchronisability. Therefore
in the example, F
0
is not empty and it can be concluded that P
0
is consistent
from the point of view of the constraints expressed on its clocks.
The rules of the lattice  represent synchronisability rules: each identity
f
1
= f
2
, with f
1
, f
2
boolean formulas on clocks, is equivalent to f
1
P
= f
2
which
implies f
1
P
 f
2
for every process P . These rules can be further extended using
the properties of the ane relations between clocks. Figure 5 illustrates this idea:
if P is the process associated with the program SIGNAL', the conguration in
which clocks c
1
and c
2
coincide represent a ow F 2 P such that c
1
F
= c
2
. Thus, c
1
and c
2
are synchronisable in P . The reason here is that the (9; 6; 9) and (7; 3; 7)-
ane relations existing respectively between c, c
1
and c, c
2
are equivalent. In the
next section, we dene the ane relation associated with a ow and a process
and further explicitate the concept of equivalence of ane relations.
3.2 Ane Relations in Signal
Given n; d 2 IIN

and ' 2
6
Z xed, clocks c and c
1
are in (n; '; d)-ane relation in
the ow F|which is denoted c R
F
(n;';d)
c
1
or (c; c
1
) 2 R
F
(n;';d)
|if the relative
position of c and c
1
in F can be induced by an (n; '; d)-ane transformation as
dened in Section 2.2.
Clocks c and c
1
are in (n; '; d)-ane relation in process P , denoted
c R
P
(n;';d)
c
1
or (c; c
1
) 2 R
P
(n;';d)
, if they are in (n; '; d)-ane relation in each
ow F of P , i.e. c R
F
(n;';d)
c
1
, 8F 2 P . Flows and processes are dened over the
set of variables they manipulate. For a given set A, a ow F on A is a member of
the set of ows F
A
that can be constructed with the variables of A. In a similar
manner, a process P on A belongs to the set of processes on A, i.e. P 2 P
A
.
Because of the nite nature of the sets of variables associated with ows and
processes, ane relations can be dened as nite sets as follows:
8F 2 F
A
; R
F
(n;';d)
= f(c; c
1
) 2 AA j c R
F
(n;';d)
c
1
g (6)
8P 2 F
A
; R
P
(n;';d)
= f(c; c
1
) 2 AA j c R
P
(n;';d)
c
1
g (7)
Consider the process P 2 P
fc;c
1
;c
2
g
dened as follows:
P = fF 2 F
fc;c
1
;c
2
g
j c R
F
(n
1
;'
1
;d
1
)
c
1
; c R
F
(n
2
;'
2
;d
2
)
c
2
g (8)
(induced by a Signal program that manipulates only the clocks c, c
1
and c
2
).
From the denition of an ane relation associated with a process it results
c R
P
(n
1
;'
1
;d
1
)
c
1
and c R
P
(n
2
;'
2
;d
2
)
c
2
. Clocks c
1
and c
2
are synchronisable in P
if there exists F 2 P satisfying c
1
F
= c
2
. Consider F
s
2 P satisfying c
1
F
s
= c
2
.
Obviously c R
F
s
(n
1
;'
1
;d
1
)
c
1
and c R
F
s
(n
2
;'
2
;d
2
)
c
2
. Being identical in F
s
, clocks c
1
and c
2
can be replaced with each other and therefore c R
F
s
(n
1
;'
1
;d
1
)
c
1
implies
c R
F
s
(n
1
;'
1
;d
1
)
c
2
and c R
F
s
(n
2
;'
2
;d
2
)
c
2
implies c R
F
s
(n
2
;'
2
;d
2
)
c
1
. It results therefore
that R
F
s
(n
1
;'
1
;d
1
)
= R
F
s
(n
2
;'
2
;d
2
)
= f(c; c
1
); (c; c
2
)g. In conclusion, a necessary con-
dition for clocks c
1
and c
2
to be synchronisable in P is that R
F
s
(n
1
;'
1
;d
1
)
and
R
F
s
(n
2
;'
2
;d
2
)
be equivalent. In the case of the process P dened by (8), it can be
proved that this condition is also sucient.
The equivalence of ane relations depends on the closure properties of the
space of ane relations with respect to the main operations that can be applied
to it. These are either union, intersection or dierence induced by the homonym
operations on clocks, or general operations on relations like inverse and com-
position [15]. In the next section we propose a study of these properties in the
semantical model of traces of Signal.
3.3 Properties on Ane Relations & Synchronisability Rules
The semantics of traces. Consider a nite set of signals A. The set of all
possible ows dened on A is denoted F
A
. Subsets of ows from F
A
can be
grouped in processes which are members of the set P
A
of all processes that can
be dened on A. A Signal program on A denes a process P 2 P
A
; each ow
F 2 P satises some constraints imposed by the Signal operators on the clocks
and values of the signals from A.
Signal disposes of four basic operators (kernel) which are sucient for the
construction of any program regardless of its complexity. Kernel operators are
combined through composition and restriction in order to build programs. The
composition and restriction of programs induce naturally the corresponding op-
erations on processes and ows. Intuitively, the restriction of a ow F to a set
of variables A
0
 A is the ow 
A
0
(F ) which contains only those instants of F
with actions involving signals from A
0
.
Concerning processes, the main operations are dened as follows. Given a set
of variables A
0
 A, the restriction of P 2 P
A
to A
0
(the projection of P on A
0
)
contains the ows F 2 P manipulating exclusively variables of A
0
:

A
0
(P ) = fF
0
2 F
A
0
j F
0
= 
A
0
(F );8F 2 Pg (9)
The composition of processes P
1
2 P
A
1
and P
2
2 P
A
2
, with A
1
, A
2
arbitrary
sets of variables, is dened by:
P
1
j P
2
= fF 2 F
A
1
[ A
2
j 
A
1
(F ) 2 P
1
; 
A
2
(F ) 2 P
2
g (10)
The following lemma describes the necessary and sucient conditions|
stated as 
A
2
(P )  Q|for a property valid in the process Q to be also also
in P :
Lemma 1. 8P 2 P
A
1
, 8Q 2 P
A
2
, A
2
 A
1
,

A
2
(P )  Q, P j Q = P
(11)
In other words, given the hypothesis described by the left hand side of (11), Q
expresses a property valid also in P .
Properties on ane relations. Operations specic to relations in general,
like inverse ()
 1
and composition , can be applied to ane relations [15]. As an
example, consider a process P 2 P
fc;c
1
;c
2
;c
3
g
with clocks c, c
1
, c
2
and c
3
satisfying
c R
P
(n
1
;'
1
;d
1
)
c
1
, c
1
R
P
(n
2
;'
2
;d
2
)
c
2
and c R
P
(n
3
;'
3
;d
3
)
c
3
. Obviously, it results that
c R
P
(n
1
;'
1
;d
1
)
 R
P
(n
2
;'
2
;d
2
)
c
2
and the synchronisability of c
2
and c
3
depends on
properties of the composition. When the space of ane relations is closed under
composition, the test of the synchronisability of c
2
and c
3
reduces itself to the
verication of the equivalence of ane relations.
Ane relations can be further combined through union [
r
, intersection \
r
and dierence n
r
induced by the homonym operations on clocks (_, ^, n). A sim-
ilar argument as before conducts to the necessity of studying closure properties
of these operators with respect to the space of ane relations.
Here is a brief presentation of the main steps and results obtained in the
study of ane relations.
Equivalence of Ane Relations. An equivalence relation, noted, can be dened
between triplets (n; '; d) as follows: (n; '; d)  (n
0
; '
0
; d
0
) i either nd
0
= n
0
d and
n'
0
= n
0
', for G j ' (i.e., G is a divisor of ') and G
0
j '
0
, or nd
0
= n
0
d and
h
dt+'
n
i
=
h
d
0
t+'
0
n
0
i
;8t 2 IIN; dt+'  0, for G 6 j ' and G
0
6 j '
0
, with G = gcd(n; d)
the greatest common divisor of n and d, G
0
= gcd(n
0
; d
0
) and [x] the integer
part of x 2 IIN. The equivalence of ane relations depends exclusively on the
values of the associated triplets (n; '; d) [17]:
Proposition 1.
R
F
(n;';d)
= R
F
(n
0
;'
0
;d
0
)
; 8 F 2 F
A
, (n; '; d)  (n
0
; '
0
; d
0
) (12)
Canonical Form. In order to reduce the complexity of the test of the equivalence
, we have then dened a canonical form (n
CF
; '
CF
; d
CF
) for a triplet (n; '; d)
[18] as follows:
Proposition 2.
a) G j ' ) (n
CF
; '
CF
; d
CF
) = (
n
G
;
'
G
;
d
G
)
b) G 6 j ') (n
CF
; '
CF
; d
CF
) = (2
n
G
; (2

'
G

+ 1); 2
d
G
)
(13)
Consequently, the canonical form of R
F
(n;';d)
is R
F
(n
CF
;'
CF
;d
CF
)
and the ver-
ication of the identity of two ane relations is thus reduced to the verication
that two triplets of integers are identical:
Proposition 3.
R
F
(n;';d)
= R
F
(n
0
;'
0
;d
0
)
, (n
CF
; '
CF
; d
CF
) = (n
0
CF
; '
0
CF
; d
0
CF
) (14)
Operations on ane relations. If any expression on ane relations could be
rewritten as an ane relation, the verication of clock synchronisability would
consist only in a test of equivalence on ane relations as above. But it has been
observed that this was not the case in general. The closure property is true
for the inverse of an ane relation. Also, the ane relation R
F
(1;0;1)
is neutral
with respect to composition. However, the closure property is lost when dealing
with composition. The composition of two general ane relations R
F
(n;';d)
and
R
F
(n
0
;'
0
;d
0
)
does not generally produce an ane relation. Nevertheless, it has
been possible to identify in the space of the ane relations R
F
(n;';d)
a subspace
consisting of relations of the form R
F
(1;';d)
, with '  0, in which the closure
property is true. Following this observation, we have distinguished two cases, as
detailed in the sequel.
Properties of ane relations R
F
(1;';d)
, with '  0. It has been demonstrated [16]
that the space of ane relations R
F
(1;';d)
, although closed under composition 
and intersection \
r
, is not closed under union [
r
and dierence n
r
. It is there-
fore necessary to dene necessary and sucient conditions for the equivalence
of arbitrary expressions constructed with ane relations of the form R
F
(1;';d)
using composition, union, intersection and dierence. Given the complexity of
the space of expressions on ane relations R
F
(1;';d)
and the necessity of ecient
algorithms for testing their equivalence, the question of the existence of a canon-
ical form appears. Our attempt to provide a canonical form using exclusively the
[
r
operator|based on the observation that any expression in this space can be
rewritten as a union of ane relationsR
F
(1;';d)
|has failed because of the innite
number of possibilities in which a relation R
F
(1;';d)
can be rewritten as a union of
ane relations of the same type. However, in [16] we propose a relative normal
form which reduces partially the complexity of the equivalence calculus.
Properties of general ane relations R
F
(n;';d)
. Deciding that two arbitrary ex-
pressions on general ane relations are equivalent is a dicult problem. An
initial step may be to isolate subsets of triplets (n; '; d) and (n
0
; '
0
; d
0
) which
respect the condition that the result of the operation R
F
(n;';d)
op
r
R
F
(n
0
;'
0
;d
0
)
,
with op
r
2 f;[
r
;\
r
; n
r
g, is an ane relation. In [16] we propose a subset
of such triplets f(n; '; d); (n
0
; '
0
; d
0
)g, for which the above property is true, for
the composition. Computing this subset f(n; '; d); (n
0
; '
0
; d
0
)g is an NP-complete
problem. Future work may consider the applicability of heuristic search methods
for this computation. Another open problem is the study of the properties of the
union [
r
, intersection \
r
and dierence n
r
of general ane relations.
Synchronisability rules. The main results concerning the particular ane
relations R
F
(1;';d)
, with '  0, and the general ones R
F
(n;';d)
have respectively
permitted the induction of a set of synchronism rules and a set of synchronisabil-
ity rules. These rules actually represent a set of conditions which are necessary
and sucient for the synchronism and respectively the synchronisability of two
clocks.
An example of synchronism rule is given below. Consider the process P 2
P
fc;c
1
;c
2
;c
3
g
dened by:
P = fF 2 F
fc;c
1
;c
2
;c
3
g
j c R
F
(1;'
1
;d
1
)
c
1
; c
1
R
F
(1;'
2
;d
2
)
c
2
; c R
F
(1;'
3
;d
3
)
c
3
g (15)
Obviously c R
P
(1;'
1
;d
1
)
c
1
, c
1
R
P
(1;'
2
;d
2
)
c
2
and c R
P
(1;'
3
;d
3
)
c
3
. The calculus
on ane relations R
F
(1;';d)
induces R
F
(1;'
1
;d
1
)
 R
F
(1;'
2
;d
2
)
= R
F
(1;'
1
+d
1
'
2
;d
1
d
2
)
which is valid also for processes: R
P
(1;'
1
;d
1
)
 R
P
(1;'
2
;d
2
)
= R
P
(1;'
1
+d
1
'
2
;d
1
d
2
)
.
Therefore c R
P
(1;'
1
+d
1
'
2
;d
1
d
2
)
c
2
, and c
2
and c
3
are synchronisable if and only
if R
P
(1;'
1
+d
1
'
2
;d
1
d
2
)
= R
P
(1;'
3
;d
3
)
. With Propositions 2 and 3, R
P
(1;'
1
+d
1
'
2
;d
1
d
2
)
and R
P
(1;'
3
;d
3
)
are equivalent if and only if (1; '
1
+ d
1
'
2
; d
1
d
2
) and (1; '
3
; d
3
)
are identical, that is, '
1
+ d
1
'
2
= '
3
and d
1
d
2
= d
3
. This result is expressed in
the following synchronism rule:
Proposition 4. 8P 2 P
fc;c
1
;c
2
;c
3
g
with c, c
1
, c
2
and c
3
satisfying
c R
P
(1;'
1
;d
1
)
c
1
, c
1
R
P
(1;'
2
;d
2
)
c
2
and c R
P
(1;'
3
;d
3
)
c
3
, the following equivalences are
veried:
c
2
P
 c
3
,

'
1
+ d
1
'
2
= '
3
d
1
d
2
= d
3

, c
2
P
= c
3
(16)
In Fig. 7 the particular case '
1
= 6, d
1
= 2, '
2
= 1, d
2
= 2, and '
3
= 8,
d
3
= 4 is illustrated. It can be observed that clock c
1
is an ane sampling of
phase '
1
and period d
1
on clock c. Clock c
2
is dened similarly by an ane
sampling of parameters '
2
and d
2
on c
1
. The same clock c
2
can be obtained by
an ane sampling of '
3
and d
3
on c; the clock c
3
constructed in this manner is
synchronous, and therefore synchronisable, with c
2
.
Following a sequence of steps similar as for Proposition 4, we have derived
a system of synchronism rules which is minimal; it enables the verication of
the synchronisability of two arbitrary clocks related by an expression on ane
relations R
F
(1;';d)
, with '  0. The results concerning the equivalence of general
ane relations R
F
(n;';d)
, summarized by Propositions 1, 2 and 3, and the partial
result on composition of general ane relations, have allowed the derivation of
a set of synchronisability rules which are sucient for the validation of Signal
programs for which the single operation performed on ane relations is composi-
tion. Further work should be dedicated to the study of the union [
r
, intersection
\
r
and dierence n
r
of general ane relations.
Fig. 7. Illustration of Proposition 4.
3.4 Implementation of the Ane Clock Calculus
A prototype implementing the synchronisability rules introduced in Section 3.3
has been integrated with the existing clock calculus and used for the validation
of the Signal-Alpha interface on the video image coding application intro-
duced in Section 2. In Section 3.1 we have explained that the existing (boolean)
clock calculus relies on the properties of the lattice  existing on the space of
clocks, and that it is equivalent to a system of synchronisability rules. The im-
plementation of the ane clock calculus is briey described now. By choosing
an appropriate implementation of a general ane relation R
P
(n;';d)
as detailed
in [16], the considered clock expressions contain formulas constructed only with
ane clocks, that is, ane samplings of specied phase and period on a given
basis clock. Thus, the order 
aff
dened by

aff
= f(c
1
; c
2
)j 9'
i
 0; d
i
> 1;R
P
t
= EXP(: : : ;R
P
(1;'
i
;d
i
)
; : : :); c
1
R
P
t
c
2
g
(17)
with EXP a general expression on ane relations, induces on the space of ane
clocks a lattice structure. The system of equations on ane clocks associated
with a Signal program is solved by triangularisation. When the equivalence of
two clock expressions has to be demonstrated, synchronisability rules such that
deduced in Section 3.3 are applied. Finally, for the integration of the ane and
boolean clock calculus, each synchronisability rule which has been deduced in a
process Q 2 P
A
2
, is used in a larger context P 2 P
A
1
, with A
2
 A
1
, satisfying

A
2
(P )  Q. Following Lemma 1, the synchronisability rule is also valid in P .
4 Application
The ane clock calculus has been used for the validation of the video image
coding application described in Section 2. This application contains an important
control part, which has been programmed in Signal, and operations like the
Dct, which have been expressed in Alpha. The application has been specied
and simulated at both functional and architectural levels as described in Section
2. In the coding system described in [8], each image is decomposed into a xed
number of macro-blocks, each macro-block consisting of one block of luminance
and two blocks of chrominance (red and blue). At the architectural level, we
have rened the Alpha specications of the Dcts corresponding to the blocks
of luminance and red chrominance of a macro-block. These temporal renements
have been expressed in Signal by means of two general ane relations between
clocks c, c
1
and c, c
2
as illustrated in Fig. 5. The synchronisability of c
1
and c
2
has been veried by compilation and the entire Signal-Alpha system has been
simulated in C.
Most of the operations involved in image coding applications are critical from
the point of view of execution time or resources. Therefore, a codesign approach
can be considered. The ane clock calculus represents an important element
in dening a complete codesign methodology based on the Signal and Alpha
languages. Besides the cospecication and cosimulation of an application, using
Signal and Alpha in a codesign framework is interesting since it oers solu-
tions to other codesign problems such as the automatic synthesis of specialised
circuits for regular algorithms, or the generation of optimal code for the soft-
ware implementation of both calculations and control. Concerning the latter,
one might consider the hardware/software partitioning of an application corre-
sponding to the partitioning into Signal and Alpha subsystems. Therefore,
Alpha processes would be implemented in hardware by automatic synthesis,
while Signal processes would be translated into C code for general purpose
architectures. However, the proposed partitioning is not unique and automatic
hardware/software partitioning remains an open problem, as it is the implemen-
tation of the hardware/software interface.
5 Conclusion
The joint use of the Signal andAlpha languages in hardware/software codesign
has introduced the problem of the validation of mixed Signal-Alpha specica-
tions both at the functional and architectural levels. The renement of Signal-
Alpha specications towards the architectural level and their subsequent val-
idation necessitates the extension of the formal clock calculus implemented in
the Signal compiler. This paper presents the new ane clock calculus based
on the properties of ane relations induced between clocks by the renement of
Signal-Alpha specications. The properties of ane relations are studied in
the semantical model of traces of the Signal language, but can be extended to
any general model with similar characteristics. Based on this study, a new set
of synchronisability rules is dened and integrated with the set already imple-
mented by the existing formal clock calculus.
The ane clock calculus is relevant for the denition and implementation
of a codesign methodology using the Signal and Alpha languages. Techniques
for real-time system validation (formal verication, simulation) available in the
Signal and Alpha environments can be used for cospecication and cosimu-
lation. Both environments also have tools for automatic generation of optimal
implementations which can be used in a complementary manner for hardware
synthesis and/or implementation on general architectures. Further work should
be devoted to the complete integration of the Signal and Alpha languages
thus making possible the use of the most adapted formalism and environment
for a given application.
References
1. Amagbegnon T., Besnard L., Le Guernic P.: Arborescent Canonical Form of
Boolean Expressions. INRIA Research Report 2290, IRISA/INRIA - Rennes,
France, 1994
2. Amagbegnon T., Le Guernic P., Marchand H., Rutten E.: The Signal
dataow methodology applied to a production cell. IRISA Research Report 917,
IRISA/INRIA - Rennes, France, 1995
3. Belhadj M.: \Using Vhdl for Link to Synthesis Tools". Proceedings of the North
Atlantic Test Workshop, June 1994, Nmes, France
4. Benveniste A., Berry G.: \Real-Time systems design and programming", Proceed-
ings of the IEEE, September 1991, 79, (9)
5. Besnard L.: Compilation de Signal : horloges, dpendances, environnement, PhD
Thesis, University of Rennes 1, France, September 1992
6. Birkho G.: Lattice Theory, AMS colloquium publications, 1973
7. De Micheli G.: \Computer-Aided Hardware-Software Codesign", IEEE Micro,
August 1994, 14, (4)
8. ETSI (European Telecommunication Standards Institute) Specication of Compo-
nent TV codecs 32-45 Mbit/s. December 1990
9. Gautier T., Le Guernic P., Quinton P., Rajopadhye S., Risset T., Smarandache I.:
\Projet CAIRN: conception d'architectures partir de Signal et Alpha" CODE-
SIGN Conception conjointe logiciel-matriel, Eyrolles, Collection Technique et Sci-
entique des Tlcommunications, 1998
10. Gupta R.K., Coelho C.N., De Micheli G.: \Program Implementation Schemes for
Hardware-Software Systems" Computer, January 1994, pp. 48-55
11. Kalavade A., Lee E.A.: \A Hardware-Software Codesign Methodology for Dsp
Applications" IEEE Design & Test of Computers, September 1993, 10, (3), pp.
16-28
12. Le Guernic P., Gautier T.: \Data-Flow to von Neumann: the Signal Approach",
Advanced Topics in Data-Flow Computing, (Gaudiot J.-L. and Bic L., 1991), pp.
413-438
13. Le Guernic P., Gautier T., Le Borgne M., Le Maire C.: \Programming Real-time
Applications with Signal", Proceedings of the IEEE, September 1991, 79, (9), pp.
1321-1336
14. Salinas M.H., Johnson B.W., Aylor J.H.: \Implementation-Independent Model of
an Instruction Set Architecture in Vhdl" IEEE Design & Test of Computers,
September 1993, 10, (3), pp. 42-54
15. Sanderson J.G.: A Relational Theory of Computing, Springer Verlag 1980, 80,
Goss G. and Hartmanis J.
16. Smarandache I.: Transformations anes d'horloges : application au codesign de
systemes temps-reel en utilisant les langages Signal et Alpha, PhD Thesis, Uni-
versity of Rennes 1, France, October 1998
17. Smarandache I., Le Guernic P.: \Ane Transformations in Signal and
Their Applications in the Specication and Validation of Real-Time Systems"
Transformation-Based Reactive Systems Development, Proceedings of the 4th In-
ternational AMAST Workshop on Real-Time Systems and Concurrent and Dis-
tributed Software, Palma, Spain, LNCS 1231, Springer Verlag, 1997
18. Smarandache I., Le Guernic P.: A Canonical Form for Ane Relations in Signal.
INRIA Research Report 3097, IRISA/INRIA - Rennes, France, 1997
19. Thomas D.E., Adams J.K., Schmit H.: \A Model and Methodology for Hardware-
Software Codesign" IEEE Design & Test of Computers, September 1993, 10, (3),
pp. 6-15
20. Wilde D.: The Alpha Language. IRISA Research Report 827, IRISA/INRIA -
Rennes, France, 1994
21. Wilde D., Sie O.: Regular array synthesis using Alpha. IRISA Research Report
829, IRISA/INRIA - Rennes, France, 1994
