Architecture Diagrams —
A Graphical Language for
Architecture Style
Specification

EPFL IC IIF RiSD Technical Report
EPFL-REPORT-215210
http://infoscience.epfl.ch/record/215210

Anastasia Mavridou, Eduard Baranov, Simon Bliudze,
Joseph Sifakis

February 15, 2016

Abstract: Architecture styles characterise not a single architecture but a family of architectures sharing common characteristics. We have recently proposed configuration logics for the description of architecture styles. In this technical report, we define a graphical notation for architecture style specification to enhance readability and easiness of expression. Our notation adapts and extends notation from UML class diagrams to the specification of generic coordination mechanisms based on the concept of connector. We study simple architecture diagrams and a more expressive extension, interval architecture diagrams. For each type of diagrams, we present its semantics, a set of necessary and sufficient consistency conditions and a method that allows to characterise compositionally the specified architectures. We provide several examples illustrating the application of the results to the characterisation of architecture styles. We also present a polynomial algorithm for checking that a given architecture conforms to the architecture style specified by a diagram.
@TechReport{MBBS16-ModellingArchs-TR,
  author = {Anastasia Mavridou, Eduard Baranov, Simon Bliudze, Joseph Sifakis},
  title = {Architecture Diagrams - A Graphical Language for Architecture Style Specification},
  institution = {EPFL IC IIF RiSD},
  month = jan,
  year = 2016,
  number = {EPFL-REPORT-215210},
  note = {Available at: \texttt{http://infoscience.epfl.ch/record/215210}}
}
Contents

1 Introduction 2

2 Simple Architecture Diagrams 4
   2.1 Syntax and Semantics ......................................................... 4
   2.2 Consistency Conditions ...................................................... 6
   2.3 Synthesis of Configurations ............................................... 7
      2.3.1 Regular Configurations of a Generic Port ....................... 7
      2.3.2 Configurations of a Connector Motif .............................. 9
   2.4 Architecture Style Specification Examples .......................... 11

3 Interval Architecture Diagrams 11
   3.1 Syntax and Semantics ...................................................... 12
   3.2 Consistency Conditions .................................................... 13
   3.3 Synthesis of Configurations .............................................. 15
   3.4 Architecture Style Specification Examples .......................... 16

4 Checking Conformance of Diagrams 18

5 Related Work 22

6 Conclusion and Future Work 23
1 Introduction

Architectures depict generic coordination principles between types of components. They can be considered as generic operators that take as argument a set of components to be coordinated and return a composite component that satisfies by construction a given characteristic property \[1\].

Several languages have been proposed for architecture description such as architecture description languages, e.g. \[13\], coordination languages, e.g. \[5\] and configuration languages \[17\]. These works rely on the distinction between behaviour of individual components and their coordination in the overall system organization. Informally, architectures are characterised by the structure of the interactions between a set of typed components. The structure is usually specified as a relation, e.g. connectors between component ports.

Architecture styles characterise not a single architecture but a family of architectures sharing common characteristics, such as the type of the involved components and the topology induced by their coordination structure. Simple examples of architecture styles are Pipeline, Ring, Master/Slave, Pipe and Filter. For instance, Master/Slave architectures integrate two types of components masters and slaves such that each slave can interact only with one master. Figure 1 depicts four Master/Slave architectures involving two master components \(M_1, M_2\) and two slave components \(S_1, S_2\). Their communication ports are respectively \(p_1, p_2\) and \(q_1, q_2\). A Master/Slave architecture for two masters and two slaves can be represented as one among the following configurations, i.e. sets of connectors: \(\{p_1q_1, p_2q_2\}\); \(\{p_1q_2, p_2q_1\}\); \(\{p_1q_1, p_1q_2\}\); \(\{p_2q_1, p_2q_2\}\). A term \(p_iq_j\) represents a connector between ports \(p_i\) and \(q_j\). The four architectures are depicted in Figure 1. The Master/Slave architecture style denotes all the Master/Slave architectures for arbitrary numbers of masters and slaves.

![Figure 1: Master/Slave architectures.](image)

We have recently proposed configuration logics \[20\] for the description of architecture styles. These are powerset extensions of interaction logics \[2, 3, 4\] used to describe architectures. In addition to the operators of the extended logic, they have logical operators on sets of architectures. We have studied higher-order configuration logics and shown that they are a very powerful and expressive tool for architecture style specification. Nonetheless, their richness in operators and concepts may make their use cumbersome and tedious for practitioners.

We explore a different avenue to architecture style specification based on architecture diagrams. The key idea is to define a notation similar to that of UML class diagrams \[22\] to graphically specify styles with advantages of readability and easiness of expression. As for class diagrams, architecture diagrams describe the structure of a system by showing the system’s component types and their attributes for coordination, as well as relationships among component types. Our notation adapts notation from class diagrams to the specification of generic coordination mechanisms based on the concept of connector.

An architecture diagram consists of a set of component types and a set of connector motifs.
Component types are characterised by sets of *generic ports*. Each component type is associated with a *cardinality* parameter, i.e. number of instances. Figure 2 shows an architecture diagram consisting of three component types $T_1, T_2$ and $T_3$ with $n_1$, $n_2$ and $n_3$ instances and generic ports $p$, $q$ and $r$ respectively. Instantiated components have *port instances* $p_i$, $q_j$, $r_k$ for $i, j, k$ belonging to the intervals $[1,n_1]$, $[1,n_2]$, $[1,n_3]$, respectively.

Connector motifs are non-empty sets of generic ports that must interact. Each generic port $p$ in the connector motif has two constraints represented as a pair $m : d$. Multiplicity $m$ is the number of port instances $p_i$ that are involved in the connectors. Degree $d$ specifies the number of connectors in which each port instance is involved. A connector motif defines a set of configurations, where a configuration is a set of connectors. The architecture diagram of Figure 2 has a single connector motif involving generic ports $p$, $q$ and $r$.

Figure 3: Architecture obtained from diagram of Figure 2

Figure 3 shows the unique architecture obtained from the diagram of Figure 2 by taking $n_1 = 3$, $m_p = 1$, $a_p = 1$; $n_2 = 2$, $m_q = 2$, $d_q = 3$; $n_3 = 1$, $m_r = 1$, $d_r = 3$. This is the result of composition of constraints for generic ports $p$, $q$ and $r$ as depicted in Figure 4. For port $p$, we have three instances and as both the multiplicity and the degree are equal to 1, each port $p_i$ has a single connector lead. For port $q$, we have two instances and as the multiplicity is 2, we have connectors involving $q_1$ and $q_2$ and their total number is equal to 3 to meet the degree constraint. Finally, for port $r$, we have a single instance $r_1$ that has three connector leads to satisfy the degree constraint.

The semantics of an architecture diagram consisting of a set of connector motifs $\{\Gamma_i\}_{i \in [1..k]}$ is defined as follows. The meaning of each connector motif $\Gamma_i$ as a set of configurations $\{\gamma_{i,j}\}_{j \in J_i}$. The architecture diagram specifies all the architectures characterised by configurations of connec-
tors of the form: $\gamma_{1,j_1} \cup \cdots \cup \gamma_{n,j_n}$, where the indices $j_i \in J_i$. In other words, the configuration of an architecture conforming to the diagram is obtained by taking the union of all sub-configurations corresponding to each connector motif.

We study a method that allows to characterise compositionally the set of configurations specified by a given connector motif. It involves a two-step process. The first step consists in characterising configuration sets meeting the coordination constraints for each generic port $p$ of the connector motif. The second step is applicable if the configuration sets for all the ports involved in the connector motif meet a set of consistency conditions. The configuration of the connector motif is obtained by fusing one by one connectors from the involved ports so that the multiplicities and the degrees of the ports are preserved.

We study two types of architecture diagrams: simple architecture diagrams and interval architecture diagrams. In the former the cardinality, multiplicity and degree constraints are positive integers, while in the latter they can be also intervals. We show that interval architecture diagrams are strictly more expressive than simple architecture diagrams. For each type of diagrams we present 1) its syntax and semantics; 2) a set of consistency conditions; 3) a method that allows to characterise compositionally all the configurations of a connector motif; 4) multiple examples of architecture style specification. Finally, we present a polynomial algorithm for checking that a given diagram conforms to the architecture style specified by a diagram.

The report is structured as follows. Section 2 presents simple architecture diagrams. Section 3 presents interval architecture diagrams. Section 4 presents a polynomial algorithm for checking conformance of diagrams. Section 5 discusses related work. Section 6 concludes the report by summarising the results and discussing possible directions for future work.

## 2 Simple Architecture Diagrams

### 2.1 Syntax and Semantics

We focus on the specification of generic coordination mechanisms based on the concept of connector. Therefore, the nature and the operational semantics of components are irrelevant. A component is defined by its set of ports, which are used for interaction with other components. Thus, a component type is a set of generic ports.

A simple architecture diagram $(T, N, C)$ consists of
- a set of component types $T = \{T_1, \ldots, T_k\}$;
- a set of type cardinalities $N = \{n_1, \ldots, n_k\} \subset \mathbb{N}$, where $\mathbb{N}$ is the set of natural numbers;
A set of connector motifs \( \mathcal{C} = \{ \Gamma_1, \ldots, \Gamma_i \} \) of the form \( \Gamma = (a, \{ m_p : d_p \}_{p \in a}) \) where \( \emptyset \neq a \subset \bigcup_{i=1}^{k} T_i \) is a generic connector and \( m_p, d_p \in \mathbb{N} \) (with \( m_p > 0 \)), are the multiplicity and degree associated to \( p \in a \).

Figure 5 shows the graphical representation of an architecture diagram with a single connector motif. It defines different architecture styles, for different values of the multiplicity, degree and cardinality parameters.

![Figure 5: A simple architecture diagram.](image)

An architecture is a pair \( \langle \mathcal{B}, \gamma \rangle \), where \( \mathcal{B} \) is a set of components and \( \gamma \) is a configuration, i.e. a set of connectors among the ports of components in \( \mathcal{B} \). We define a connector as a set of ports that must interact. For a component \( B \in \mathcal{B} \) and a component type \( T \), we say that \( B \) is of type \( T \) if the ports of \( B \) are in a bijective correspondence with the generic ports in \( T \). Let \( B_1, \ldots, B_n \) be all the components of type \( T \) in \( \mathcal{B} \). For a generic port \( p \in T \), we denote the corresponding port instances by \( p_1, \ldots, p_n \).

**Semantics.** An architecture \( \langle \mathcal{B}, \gamma \rangle \) conforms to a diagram \( \langle \mathcal{T}, \mathcal{N}, \mathcal{C} \rangle \) if, for each \( i \in [1, k] \), the number of components of type \( T_i \) in \( \mathcal{B} \) is equal to \( n_i \) and \( \gamma \) can be partitioned into disjoint sets \( \gamma_1, \ldots, \gamma_i \), such that, for each connector motif \( \Gamma_i = (a, \{ m_p : d_p \}_{p \in a}) \in \mathcal{C} \) and each \( p \in a \),

1. there are exactly \( m_p \) instances of \( p \) in each connector in \( \gamma_i \);
2. each instance of \( p \) is involved in exactly \( d_p \) connectors in \( \gamma_i \).

The meaning of a simple architecture diagram is a set of all architectures that conform to it.

We assume that, for any two connector motifs \( \Gamma_i = (a, \{ m_p^i : d_p^i \}_{p \in a}) \) (for \( i = 1, 2 \)) with the same set of generic ports \( a \), there exists \( p \in a \), such that \( m_p^1 \neq m_p^2 \). Two connector motifs with the same set of generic ports and multiplicities \( \Gamma_i = (a, \{ m_p^i : d_p^i \}_{p \in a}) \) (for \( i = 1, 2 \)) can be replaced by a single connector motif \( \Gamma = (a, \{ m_p : d_p \}_{p \in a}) \), which imposes a weaker constraint. To be more specific, by this assumption, we lose the ability to guarantee that a set of connectors \( \gamma \) corresponding to a connector motif \( \langle a, \{ m_p : d_p \}_{p \in a} \rangle \) not only satisfies the multiplicity and degree constraints but also can be split into several disjoint subsets \( \gamma_1, \ldots, \gamma_n \) such that for each \( \gamma_i \) for \( i \in [1, n] \) for each \( p \in a \) and for any \( p_j, p_k \in p \), \( |\{a \in \gamma | p_j \in a\}| = |\{a \in \gamma | p_k \in a\}| \) i.e. the degree of all port instances of a generic port are equal.

We consider that the aforementioned assumption does not have significant impact on the expressiveness of the formalism. On the contrary, it greatly simplifies semantics and analysis. In particular, it ensures that for any configuration \( \gamma \) there exists at most one partition into disjoint sets \( \gamma_1, \ldots, \gamma_i \), which correspond to different connector motifs. In other words, a connector cannot correspond to two different connector motifs. This greatly simplifies sub-algorithm 2 (VerifyMultiplicity) in Subsection 4. Furthermore, it also simplifies the consistency conditions presented in Subsection 2.2. Notice that this assumption allows connector motifs with the same set of generic ports but different multiplicities.

Multiplicity constrains the number of instances of the generic port belonging to a connector involved in a motif, whereas degree constrains the number of connectors attached to any instance of the generic port. Consider the two diagrams shown in Figures 6(a) and 6(b). They have the
same set of component types and cardinalities. Nevertheless, their multiplicities and degrees differ, resulting in different architectures. Architectures conforming to the two diagrams are also shown in Figures 6(a) and 6(b).

In Figure 6(a), the multiplicity of the generic port $p$ is 1 and the multiplicity of the generic port $q$ is 3, thus, any connector must involve one instance of $p$ and three instances of $q$. Since there are only three instances of $q$, any connector must include all of them. The degrees of both generic ports are 1, so each port is involved in exactly one connector. Thus, the diagram defines a single architecture with one connector among the four ports.

In Figure 6(b) the multiplicity of both generic ports $p$ and $q$ are 1. Thus, any connector must involve one instance of $p$ and one instance of $q$. Since the degree of $q$ is 1 and there are three instances of $q$ we need three connectors, each involving a distinct instance of $q$. Thus, the architecture diagram defines a single architecture with three binary connectors.

### 2.2 Consistency Conditions

Notice that there exist diagrams that do not define any architecture such as the diagram shown in Figure 7. Since the multiplicity is 1 for both generic ports $p$ and $q$, a configuration in a corresponding architecture must include only binary connectors involving one instance of $p$ and one instance of $q$. Additionally, since the degree of both $p$ and $q$ is 1, each port instance must be involved in exactly one connector. However, the cardinalities impose that there be three connectors attached to the instances of $p$, but only two connectors attached to the instances of $q$. Both requirements cannot be satisfied simultaneously and therefore, no architecture can conform to this diagram.

Consider a connector motif $\Gamma = (a, \{m_p : d_p\}_{p \in a})$ in a diagram $(\mathcal{T}, \mathcal{N}, \mathcal{C})$ and a generic port $p \in a$, such that $p \in T$, for some $T \in \mathcal{T}$. Let $n_p \in \mathcal{N}$ be the cardinality associated to $T$. We denote $s_p = n_p d_p / m_p$ the matching factor of $p$.

A regular configuration of $p$ is a multiset of connectors, such that 1) each connector involves $m_p$ instances of $p$ and no other ports and 2) each instance of the port $p$ is involved in exactly $d_p$ connectors. Notice the difference between a configuration and a regular configuration of $p$: the

Figure 6: Two examples of simple architecture diagrams.
former defines a set of connectors, while the latter defines a multiset of sub-connectors involving only instances of the generic port $p$. Considering the diagram in Figure 2 and the architecture in Figure 3, the only regular configuration of $r$ is the multiset $\{r_1, r_1, r_1\}$. The three copies of the singleton sub-connector $r_1$ are then fused with sub-connectors $p_1 q_1 q_2$ ($i = 1, 2, 3$), resulting in a configuration with three distinct connectors.

Lemma 2.1. Each regular configuration of a port $p$ has exactly $s_p$ connectors.

Proof. 1) we have $s$ connectors and each connector is a set of $m_p$ port instances. Thus the sum of connectors sizes is $s \cdot m_p$; 2) Connectors consist of ports and each port instance is involved in $d_p$ connectors. The total number of ports in connectors is $n_p \cdot d_p$, where $n_p$ is the number of port instances. Thus $s \cdot m_p = n_p \cdot d_p$ or $s = n_p \cdot d_p / m_p$.

Notice that, for the diagram of Figure 7, we have $s_p = 3$, while $s_q = 2$. To form connectors, each sub-connector from a regular configuration of $p$ has to be fused with exactly one sub-connector from a regular configuration of $q$, and vice-versa. Since, by the above lemma, the sizes of such regular configurations are different, there is no architecture conforming to this diagram.

Proposition 2.2 provides the necessary and sufficient conditions for a simple architecture diagram to be consistent, i.e. to have at least one conforming architecture. The multiplicity of a generic port must be less than or equal to the number of component instances that contain this port. The matching factors of all ports participating in the same connector motif must be equal integers. Finally, there must be enough distinct sub-connectors to build a configuration. Notice that because of the assumption that we made in Subsection 2.1, this condition can be applied independently to each connector motif. Since, by the semantics of diagrams, connector motifs correspond to disjoint sets of connectors, these conditions are applied separately to each connector motif.

Proposition 2.2. A simple architecture diagram has a conforming architecture iff, for each connector motif $\Gamma = (a, \{m_p : d_p\}_{p \in a})$ and each $p \in a$, we have

1. $m_p \leq n_p$,
2. $\forall q \in a, s_p = s_q \in \mathbb{N}$,
3. $s_p \leq \prod_{q \in a} \left( \binom{n_q}{m_q} \right)$.

Proof. This proposition is a special case of Proposition 3.5.

2.3 Synthesis of Configurations

The synthesis procedure for each connector motif consists of the following two steps: 1) we find regular configurations for each generic port satisfying the connector motif constraints; 2) we fuse these regular configurations generating global configurations specified by the connector motif.

2.3.1 Regular Configurations of a Generic Port

We start with an example illustrating the steps of the synthesis procedure for a port $p$. 
Table 1: Vector representation of regular configurations.

<table>
<thead>
<tr>
<th>$d_p$</th>
<th>Vector representation</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>[100001], [010010], [001100]</td>
</tr>
<tr>
<td>2</td>
<td>[110011], [101101], [011110], [000002], [020020], [002200]</td>
</tr>
<tr>
<td>3</td>
<td>[111111], [210012], [201102], [120021], [021120], [012210], [102201], [300003], [030030], [003300]</td>
</tr>
</tbody>
</table>

**Example 2.3.** Consider a port $p$ with $n_p = 4$ and $m_p = 2$. There are 6 connectors of multiplicity 2: $p_1p_2, p_1p_3, p_1p_4, p_2p_3, p_2p_4, p_3p_4$. They correspond to the set of edges of a complete graph with vertices $p_1, p_2, p_3, p_4$. The regular configurations of $p$ for $d_p = 1, 2, 3$, where each edge appears at most once (i.e. sets of connectors) are shown in Figure 8.

Figure 8: Regular configurations of $p$ with $n_p = 4$, $m_p = 2$.

We provide below an equational characterisation of all the regular configurations (multisets) of a given generic port $p$ with given $n_p, m_p,$ and $d_p$. For the $n_p$ port instances, $p_1, \ldots, p_n$ we have a set $\{a_i\}_{i \in [1,w]}$ of different connectors, where $w = \binom{n_p}{m_p}$, to which we associate a column vector of non-negative integer variables $X = [x_1, \ldots, x_w]^T$.

Consider the Example 2.3 and variables $x_1, \ldots, x_6$ representing the number of occurrences in a regular configuration of the connectors $p_1p_2, p_1p_3, p_1p_4, p_2p_3, p_2p_4, p_3p_4$, respectively. All the regular configurations (i.e. multisets of connectors), for $d_p = 1, 2, 3$, represented as vectors of the form $[x_1, \ldots, x_6]$ are listed in Table 1. Notice that vectors for $d_p > 1$ can be obtained as linear combinations of the vectors describing configuration sets for $d_p = 1$.

Then, for the port $p$ we define an $n_p \times w$ incidence matrix $G = [g_{i,j}]_{n_p \times w}$ with $g_{i,j} = 1$ if $p_i \in a_j$ and $g_{i,j} = 0$ otherwise. The following equation holds: $GX = D$, where $D = [d_p, \ldots, d_p]$ ($d_p$ repeated $n_p$ times). Any non-negative integer solution of this equation defines a regular
configuration of \( p \). For Example 2.3 the equations are:

\[
\begin{align*}
    x_1 + x_2 + x_3 &= d, \\
    x_1 + x_4 + x_5 &= d, \\
    x_2 + x_4 + x_6 &= d, \\
    x_3 + x_5 + x_6 &= d,
\end{align*}
\]

\[\begin{array}{l}
    x_1 + x_2 + x_3 = d, \\
    x_3 = x_4, \\
    x_2 = x_5, \\
    x_1 = x_6.
\end{array}\]  

(1)

Notice that the vectors of Table 1 are solutions of (1).

### 2.3.2 Configurations of a Connector Motif

Let \( \Gamma = (a, \{ m_p : d_p \}_{p \in a}) \) be a connector motif such that all generic ports of \( a = \{ p^1, \ldots, p^n \} \) have the same integer matching factor \( s \). For each \( p^j \in a \), let \( \gamma^j = \{ a^j_i \}_{i \in [1,n]} \) be a regular configuration of \( p^j \). For arbitrary permutations \( \pi_j \) of \( [1,n] \), a set \( \{ a^j_1 \cup \bigcup_{j=2}^n a^j_{\pi_j(i)} \}_{i \in [1,s]} \) is a configuration specified by the connector motif.

In order to provide an equational characterisation of the connector motif, we consider, for each \( \gamma \), the system of linear equations \( G^j X^j = D^j \) characterising the configurations of \( p^j \) (cf. Section 2.3.1). Denote \( w^j \) the dimension of the vector \( X^j \).

In order to characterise the configurations of connectors conforming to \( \Gamma \), we consider, for each configuration, the \( v \)-dimensional matrix \( E = [e_{i_1, \ldots, i_v}]_{w^1 \times \ldots \times w^v} \) of 0-1 variables, such that \( e_{i_1, \ldots, i_v} = 1 \) if the connector \( a^j_{i_1} \cup \cdots \cup a^j_{i_v} \) belongs to the configuration and 0 otherwise. By definition, the sum of all elements in \( E \) is equal to \( s \). Moreover, the following equations hold:

\[
\begin{align*}
    x^1_i &= \sum_{i_2, i_3, \ldots, i_v} e_{i,i_2,\ldots,i_v}, & \text{for } i & \in [1, w^1], \\
    x^2_i &= \sum_{i_1, i_3, \ldots, i_v} e_{i,i_1,\ldots,i_v}, & \text{for } i & \in [1, w^2], \\
    & \vdots & & \\
    x^v_i &= \sum_{i_1, i_2, \ldots, i_{v-1}} e_{i_1,\ldots,i_{v-1},i}, & \text{for } i & \in [1, w^v].
\end{align*}
\]

(2)

For instance, for a fixed \( i \in [1, w^1] \), all \( e_{i,i_2,\ldots,i_v} \) describe all connectors that contain \( a^j_i \). The regular configuration \( \gamma^1 \) is characterised by \( X^1 \), enforcing that \( a^j_i \) belongs to \( x^1_i \) connectors. The system of linear equations (2), combined with the systems of linear equations \( G^j X^j = D^j \), for \( j \in [1,v] \), fully characterise the configurations of \( \Gamma \). They can be used to synthesise architectures from architecture diagrams.

**Example 2.4.** Consider a diagram \( \{(T_1, T_2), \{n_1, n_2\}, \{\Gamma\}\} \), where \( T_1 = \{p\} \), \( T_2 = \{q\} \), \( n_1 = n_2 = 4 \) and \( \Gamma = \text{pq} \{ \{m_p : d_p, m_q : d_q\} \} \) with \( m_p = 2 \), \( m_q = 3 \). The corresponding equations \( G_pX = D_p \), \( G_qY = D_q \) can be rewritten as

\[
\begin{align*}
    x_1 + x_2 + x_3 &= d_p, \\
    x_3 &= x_4, \\
    x_2 &= x_5, \\
    x_1 &= x_6,
\end{align*}
\]

\[
\begin{align*}
    3y_1 &= d_q, \\
    y_1 &= y_2 = y_3 = y_4.
\end{align*}
\]

(3)

Together with the constraints \( x_i = \Sigma_i e_{i,j} \) and \( y_j = \Sigma_j e_{i,j} \) for the matrix of variables \( E = [e_{i,j}]_{6 \times 4} \), equations (3) completely characterise all the configurations conforming to \( \Gamma \).

The same methodology can be used to synthesise configurations with additional constraints. To impose that some specific connectors must be included, whereas other specific connectors must be excluded from the configurations, the corresponding variables in the matrix \( E \) are given fixed values: 1 (resp. 0) if the connector must be included (resp. excluded) from the configurations. The rest of the synthesis procedure remains the same.
Example 2.5. Figure 9 shows the architecture diagram from Example 2.4 with $d_p = 2$ and $d_q = 3$. We want to synthesise the configurations of this diagram with the following additional constraints: connectors $p_1p_2q_1q_3$ and $p_1p_3q_2q_4$ must be included, whereas connector $p_2p_4q_1q_2q_4$ must be excluded from the synthesised configurations.

First, we compute the vectors $X$ and $Y$ that represent the regular configurations of generic ports $p$ and $q$, respectively. Variables $x_1, \ldots, x_6$ represent the number of occurrences in a configuration of the connectors $p_1p_2$, $p_1p_3$, $p_1p_4$, $p_2p_3$, $p_2p_4$, $p_3p_4$, respectively. Variables $y_1, \ldots, y_4$ represent the number of occurrences in a configuration of the connectors $q_1q_2q_3$, $q_1q_2q_4$, $q_1q_3q_4$, $q_2q_3q_4$, respectively.

Vector $X$ can take one of the following values for $d_p = 2$: $[110011]$, $[101101]$, $[011110]$, $[200002]$, $[020020]$ or $[002200]$ (Example 2.3). Regular configurations of $q$ are characterised by the equations $3y_1 = d$ and $y_1 = y_2 = y_3 = y_4$ (Example 2.4). For $d = 3$ there is a single solution $Y = [1111]$.

We now consider the matrix $E$, where we fix $e_{1,2} = e_{2,4} = 1$ and $e_{5,2} = 0$ to impose the additional synthesis constraints:

$$E = \begin{pmatrix} x_1 & e_{1,2} & e_{1,3} & e_{1,4} \\ x_2 & e_{2,1} & e_{2,2} & e_{2,3} & 1 \\ x_3 & e_{3,1} & e_{3,2} & e_{3,3} & e_{3,4} \\ x_4 & e_{4,1} & e_{4,2} & e_{4,3} & e_{4,4} \\ x_5 & e_{5,1} & 0 & e_{5,3} & e_{5,4} \\ x_6 & e_{6,1} & e_{6,2} & e_{6,3} & e_{6,4} \end{pmatrix}$$

Since, for all $i \in [1, 6]$, we have $x_i = \Sigma_j e_{i,j}$, we observe that $x_1, x_2 \geq 1$. The only valuation of $X$ that satisfies this constraint is $[110011]$; as mentioned above, the only possible valuation of $Y$ is $[1111]$.

The sum of rows 3 and 4 of $E$ is 0, so all their elements must be 0s. The sum of rows 1 and 2 as well as the sum of columns 1 and 4 is 1. Since there exists already an element with value 1, all other elements in these rows and columns must be 0s. This gives us the following multidimensional matrix:

$$E = \begin{pmatrix} y_1 & y_2 & y_3 & y_4 \\ x_1 & 1 & 0 & 0 & 0 \\ x_2 & 0 & 0 & 0 & 1 \\ x_3 & 0 & 0 & 0 & 0 \\ x_4 & 0 & 0 & 0 & 0 \\ x_5 & 0 & 0 & e_{5,3} & 0 \\ x_6 & 0 & e_{6,2} & e_{6,3} & 0 \end{pmatrix}$$

The sums of the rest rows and columns give us the correct values of the other three elements.
The complete solution is the following:

\[
E = \begin{pmatrix}
 y_1 & y_2 & y_3 & y_4 \\
x_1 & 1 & 0 & 0 & 0 \\
x_2 & 0 & 0 & 0 & 1 \\
x_3 & 0 & 0 & 0 & 0 \\
x_4 & 0 & 0 & 0 & 0 \\
x_5 & 0 & 0 & 1 & 0 \\
x_6 & 0 & 1 & 0 & 0
\end{pmatrix},
\]

which corresponds to the configuration \( \{ p_1p_2q_1q_2q_3, p_1p_3q_2q_3q_4, p_2p_4q_1q_3q_4, p_3p_4q_1q_2q_4 \} \).

### 2.4 Architecture Style Specification Examples

**Example 2.6.** The Star architecture style consists of a single center component of type \( T_1 = \{ p \} \) and \( n_2 \) components of type \( T_2 = \{ q \} \). The central component is connected to every other component by a binary connector and there are no other connectors. The diagram in Figure 10 graphically describes the Star architecture style.

![Figure 10: Star architecture style.](image)

**Example 2.7.** We now consider the multi-star extension of the Star architecture style, with \( n \) center components of type \( T_1 \), each connected to \( d \) components of type \( T_2 \) by binary connectors. As in Example 2.6, there are no other connectors. The diagram of Figure 11 graphically describes this architecture style.

### 3 Interval Architecture Diagrams

To further enhance the expressiveness of diagrams we introduce interval architecture diagrams where the cardinalities, multiplicities and degrees parameters can be intervals. With simple architecture diagrams we cannot express properties such as “component instances of type \( T \) are optional”. For instance, let us consider the example of Figure 1 that shows four Master/Slave architectures involving two masters and two slaves. In this example, one of the masters might be optional, i.e. it might not interact with any slaves. As illustrated in Figure 4 in the first and second architectures each master interacts with one slave, however, in the third and fourth architectures a single master interacts with both slaves while the other master does not interact with any slaves. In other words, the degree of the generic port \( m \) varies from 0 to 2 and cannot be represented by an integer.
3.1 Syntax and Semantics

An interval architecture diagram \((\mathcal{T}, \mathcal{N}, \mathcal{C})\) consists of:

- a set of component types \(\mathcal{T} = \{T_1, \ldots, T_k\}\);
- a set of type cardinalities \(\mathcal{N} = \{[n^i_1, n^i_2], \ldots, [n^i_k, n^i_k]\}\), where \(n^i_1, n^i_k \in \mathbb{N}\) for all \(i \in [1, k]\);
- A set of connector motifs \(\mathcal{C} = \{\Gamma_1, \ldots, \Gamma_l\}\) of the form \(\Gamma = (a, \{ty[m_p^{l_1}, m_p^{l_2}] : ty[d_p^{l_1}, d_p^{l_2}]\}_{p \in a})\)
  where \(\emptyset \neq a \subset \bigcup_{i=1}^k T_k\) is a generic connector (set of generic ports) and \(ty[m_p^{l_1}, m_p^{l_2}], ty[d_p^{l_1}, d_p^{l_2}]\),
  with \([m_p^{l_1}, m_p^{l_2}], [d_p^{l_1}, d_p^{l_2}] \subset \mathbb{N}\) non-empty multiplicity and degree intervals (with \(m_p^{l_2} > 0\) associated to \(p \in a\). The interval type \(ty\) can be either \(mc\) (multiple choice) or \(sc\) (single choice).

**Semantics.** An architecture \((\mathcal{B}, \gamma)\) conforms to an interval architecture diagram \((\mathcal{T}, \mathcal{N}, \mathcal{C})\) if, for each \(i \in [1, k]\), the number of components of type \(T_i\) in \(\mathcal{B}\) lies in \([n^i_1, n^i_k]\) and \(\gamma\) can be partitioned into disjoint sets \(\gamma_1, \ldots, \gamma_l\), such that for each connector motif \(\Gamma_i = (a, \{ty[m_p^{l_1}, m_p^{l_2}] : ty[d_p^{l_1}, d_p^{l_2}]\}) \in \mathcal{C}\) and each \(p \in a\):

1. there are \(m_p \in [m_p^{l_1}, m_p^{l_2}]\) instances of \(p\) in each connector in \(\gamma_i\); in case of a single choice
   interval the number of instances of \(p\) is equal in all connectors in \(\gamma_i\);

2. each instance of \(p\) is involved in \(d_p \in [d_p^{l_1}, d_p^{l_2}]\) connectors in \(\gamma_i\); in case of a single choice
   interval, the number of connectors involving an instance of \(p\) is the same for all instances of \(p\).

The meaning of an interval architecture diagram is a set of all architectures that conform to it.

In other words, each generic port \(p\) has an associated pair of intervals defining its multiplicity and degree. The interval attributes specify whether these constraints are uniformly applied or not. We write \(sc[x, y]\) (single choice) to mean that the same multiplicity or degree is applied to each port instance of \(p\). We write \(mc[x, y]\) (multiple choice) to mean that different multiplicities or degrees can be applied to different port instances of \(p\), provided they lie in the interval.

We assume that, for any two connector motifs \(\Gamma_i = (a, \{ty[m_p^{l_1}, m_p^{l_2}] : ty[d_p^{l_1}, d_p^{l_2}]\})\) (for \(i = 1, 2\)) with the same set of generic ports \(a\), there exists \(p \in a\) such that \([m_p^{l_1}, m_p^{l_2}] \cap [m_p^{l_1}, m_p^{l_2}] = \emptyset\).

![Diagram](image-url)
Similarly to simple architecture diagrams, without significant impact on the expressiveness of the formalism, this assumption greatly simplifies semantics and analysis. In particular, it ensures that for any configuration $\gamma$ there exists at most one partition into disjoint sets $\gamma_1, \ldots, \gamma_l$, which correspond to different connector motifs, which simplifies sub-algorithm 2 (VerifyMultiplicity) in Section 4. Furthermore, it simplifies the consistency conditions in Proposition 3.5 that can now be applied independently to each connector motif.

Example 3.1. The diagram in Figure 12 defines the set of architectures shown in Figure 1. Notice that the degree of the generic port $p$ is the multiple choice interval $[0, 2]$, since one master component may be connected to two slaves, while the other master may have no connections.

Proposition 3.2. Interval architecture diagrams are strictly more expressive than simple architecture diagrams.

Proof. Any parameter $x$ of a simple architecture diagram can be represented as $sc[x, x]$ in interval architecture diagrams. Thus, any simple architecture diagram can be represented as an interval architecture diagram. The diagram of Example 3.1 cannot be expressed with simple architecture diagrams, proving that interval architecture diagrams are strictly more expressive.

3.2 Consistency Conditions

Similarly to simple architecture diagrams, there are interval diagrams that do not define any architectures. Proposition 3.5 provides the necessary and sufficient conditions for the consistency of interval architecture diagrams. A connector cannot contain more port instances than there exist in the system. Thus, the lower bound of multiplicity should not exceed the number of instances of the associated component type. For all generic ports of a connector motif, there should exist a common matching factor that does not exceed the maximum number of different connectors between these ports. These conditions are a generalisation of Proposition 2.2. Lemmas 3.3 and 3.4 are auxiliary for proving Proposition 3.5.

Lemma 3.3. Consider a set of generic ports $P$ and a set of $s$ connectors over these ports. Assume that connector $k \in [1,s]$ contains $m_{k,p}$ port instances of $p \in P$ and a port instance $p_j \in p$ is an element of exactly $d_{p,j}$ connectors. The following equality holds $\forall p \in P$, $\sum_{k=1}^{s} m_{k,p} = \sum_{p_j \in p} d_{p,j}$.

Proof. Consider a generic port $p \in P$. Consider a bipartite graph $G = (U, V, E)$ defined by two disjoint sets of vertices: set of vertices $U$ where each vertex corresponds to one port instance, and a set of vertices $V$ where each vertex corresponds to one connector. The graph $G$ has an edge between vertices $u \in U$ and $v \in V$ if the port associated to $u$ is an element of the connector associated to $v$. A vertex $v_k \in V$ associated with connector $k$ is adjacent to exactly $m_{k,p}$ vertices associated with ports $p$ of the connector $k$. Therefore, the number of edges between $U$ and $V$ is equal to $\sum_{k=1}^{s} m_{k,p}$. Furthermore, the degree of a vertex $u_j \in U$ is equal to $d_{p,j}$ because $p_j$ is an element of $d_{p,j}$ connectors. Therefore, the number of edges between $U$ and $V$ must also be equal to $\sum_{p_j \in p} d_{p,j}$. Combining this with our previous observation, we obtain that $\sum_{k=1}^{s} m_{k,p} = \sum_{p_j \in p} d_{p,j}$. The same reasoning can be applied to any generic port $p \in P$ giving the same equality.
Lemma 3.4. Let $P$ be a set of generic ports with two associated parameters: $n_p$ representing a number of port instances $p \in P$ and $[d^l_p, d^u_p]$ for $d^l_p \in \mathbb{N}, d^u_p \in \mathbb{N}, d^l_p \leq d^u_p$ representing the desired degree interval. Consider a set of $s$ distinct connectors $A$ over $P$, such that for a port $p \in P$, a connector $a \in A$ contains $m_{a,p}$ instances of $p$, where $m_{a,p} \leq n_p$, and $n \cdot d^l_p \leq \sum_{a \in A} m_{a,p} \leq n \cdot d^u_p$. Then it is possible to construct a set of $s$ distinct connectors $A'$ such that a connector $a$ contains $m_{a,p}$ instances of $p$ with the degree of an instance $p_j$ being equal to $d^l_{p,j} \in [d^l_p, d^u_p]$.

Proof. Let $d_{p,i}$ be a degree of the port $p_i$ in $A$, i.e. $d_{p,i} = |\{a \in A| p_i \in a\}|$. Let us define a function $f : 2^A \to \mathbb{N}$ such that $f(A) = \sum_{p \in P} \sum_{i \in e_{p}} \min(d_{p,i} \in [d^l_p, d^u_p]) \cdot |d_{p,i} - d_p|$. Function $f(A)$ achieves its minimal value $f(A) = 0$ if and only if the degree $d_{p,i} \in [d^l_p, d^u_p]$ for all ports. That is, if $f(A) = 0$, we construct $A'$ by the assignment $A' = A$.

Suppose now that we have $A$ for which $f(A) \neq 0$. Since $f(A) \neq 0$, this means that there is at least one port $p_i$ such that $d_{p,i} < d^l_p$ or $d_{p,i} > d^u_p$. Without loss of generality we can assume the first case (the other case is symmetric). From Lemma 3.3 we know that $\sum_{k=1}^x m_{k,p} = \sum_{p \in P} d_{p,j}$. Thus, for at least one port $p_j \in p$ holds $d_{p,j} > d^l_p$.

Now, observe that for the two ports $p_i$ and $p_j$, $d_{p,j} > d_{p,i}$. This means that we can redefine at least one connector by replacing port $p_i$ with port $p_j$ without having duplicated connectors (otherwise, by the pigeonhole principle port $p_j$ would already be an element of two identical connectors). Consider a new set of $s$ connectors $A_{new}$ obtained by applying the port replacement procedure. Its value function is at most $f(A_{new}) \leq f(A) - 1 < f(A)$. Since initial value $f(A)$ is bounded, the consecutive application of the port replacement procedure eventually leads to set $A_{new}$ for which $f(A_{new}) = 0$. Therefore, it is possible to construct set $A'$.

To simplify the presentation of Proposition 3.5 we use the following notion of choice function. Let $I_T$ and $I$ be the sets of, respectively, typed intervals and intervals, as in the definition of interval diagrams above. A function $g : I_T \to I$ is a choice function if it satisfies the following constraints:

$$g(ty[x, y]) = \begin{cases} [x, y], & \text{if } ty = mc, \\ [z, z], & \text{for some } z \in [x, y], \text{if } ty = sc. \end{cases}$$

Proposition 3.5. An interval architecture diagram $(T, N, C)$ is consistent if, for each $T \in T$, there exists a cardinality $n_T \in [n_T^l, n_T^u]$ and, for each connector motif $(a, \{M_p : D_p\}_{p \in a}) \in C$ and each $p \in a$, there exist choice functions $g^m_p, g^d_p$, such that, for $[m^l_p, m^u_p] = g^m_p(M_p)$ and $[d^l_p, d^u_p] = g^d_p(D_p)$ hold:

1. $m^l_p \leq n_p$, for all $p \in a$, (where $n_p = n_T$ for $p \in T$),
2. $(S \cap U \cap \mathbb{N}) \neq \emptyset$, where

(a) $S = \bigcap_{p \in a} s_p$ with $s_p = \begin{cases} \left[\frac{n_p \cdot d^l_p}{m^u_p}, \frac{n_p \cdot d^u_p}{m^l_p}\right], & \text{if } m^l_p > 0, \\ \left[\frac{n_p \cdot d^l_p}{m^u_p}, \infty\right), & \text{if } m^l_p = 0, \end{cases}$

(b) $U = \left[1, \prod_{p \in a} \sum_{m \in [m^l_p, m^u_p]} \binom{n_p}{m}\right]$.

Proof. Necessity $\rightarrow$: Consider an architecture conforming to the diagram. Consider values $n_T \in [n_T^l, n_T^u]$ for each $T \in T$ equal to the number of components of the corresponding type in the architecture. Consider a connector motif $\Gamma = (a, \{M_p : D_p\}_{p \in a}) \in C$ and consider functions $g^m_p, g^d_p$ for each generic port $p \in a$ consistent with the architecture, i.e. if the multiplicity (degree) of $p$
in the sub-configuration corresponding to the connector motif $\Gamma$ in the architecture is equal to $v$ and the multiplicity (degree) interval has type $sc$ then the corresponding $g_p^m$ ($g_p^d$) returns $[v, v]$.

Condition 1 is trivially obtained - $n_p < m_p^l$ cannot occur as the multiplicity of ports cannot be greater than the number of component instances. In order to show condition 2 we apply Lemma 3.3 $\forall p, a \sum_{k=1} n_{k,p} = \sum_{p_i \in p} d_{p,j}$, where $s$ is the number of connectors in the architecture corresponding to $\Gamma$. The lower bound on the left hand side is $s \cdot m_p^l$, while the upper bound on the right hand side is $n_p \cdot d_p^u$: these two bounds give us $s \leq n_p \cdot d_p^u / m_p^l$ (if $m_p^l = 0$, $s \to \infty$). By inspecting the upper bound of the left hand side and the lower bound of the right hand side, we obtain $s \geq n_p \cdot d_p^u / m_p^l$. Thus, $s \in S$. For the set $U$, notice that $\prod_{p \in a} \sum_{m \in \{m_p^l, m_p^u\}} \binom{n_p}{m}$ is equal to the number of different ways one could connect ports in $a$, so that port $p \in a$ has $n_p$ instances and connector $k$ contains $n_{k,p} \in \{m_p^l, m_p^u\}$ ports $p_i \in p$. Therefore, $s \in U$, otherwise, by the pigeonhole principle there would exist duplicated connectors. Thus, $s \in S$ and $s \in U$ and $s \in N$ so their intersection is not empty. This reasoning can be applied to any connector motif, proving the necessity of the consistency conditions.

Sufficiency $\Rightarrow$: We prove this part by construction. Consider values $n_T$ and functions $g$ for which all conditions are satisfied. Consider a set of behaviours, such that each type $T \in T$ has $n_T$ instances. In order to construct an architecture we need only a set of connectors. We construct sets for each connector motif independently, taking their union in the final step. Consider a connector motif $\Gamma = (a, \{M_p : D_p\}_{p \in a}) \in C$. Suppose that there are no degree constraints. As in the first part of the proof, we know that condition 2 implies that the number of connectors is bounded by $\prod_{p \in a} \sum_{m \in \{m_p^l, m_p^u\}} \binom{n_p}{m}$, where $m^l_p \leq n_p$, which is satisfied by condition 1. Since $\prod_{p \in a} \sum_{m \in \{m_p^l, m_p^u\}} \binom{n_p}{m}$ is the number of different ways one could connect ports in $a$, so that generic port $p \in a$ has $n_p$ instances and connector $k$ contains $n_{k,p} \in \{m_p^l, m_p^u\}$ port instances of generic port $p$, it follows that it is always possible to select $s$ distinct connectors (distinct by the set of port instances they contain), where a port instance $p_i \in p$ is allowed to have a degree $d_{p,i} \notin \{d_p^l, d_p^u\}$. Now, consider one such set $A$ of $s$ connectors. Since condition 2 is satisfied, we know that $n_p \cdot d_p^l \leq \sum_{k \in A} n_{k,p} \leq n_p \cdot d_p^u$ for all $p \in a$, so we can apply the result of Lemma 3.4 More precisely, we can iterate over ports in $a$ (in arbitrary order), and balance the degrees of port instances $p_i \in p$, achieving the degree $d_{p,i} \in \{d_p^l, d_p^u\}$. Since by Lemma 3.4 each iteration preserves the distinctness of connections, once the entire iterative procedure finishes, we obtain a set of $s$ distinct connectors for which each port instance has the degree that takes values in $\{d_p^l, d_p^u\}$, and this holds for all $p \in a$. Considering such sets for each connector motif and taking their union, we obtain an architecture that conforms to the diagram.

3.3 Synthesis of Configurations

The equational characterisation in Section 2.3 can be generalised, using systems of inequalities with some additional variables, to interval architecture diagrams. Below, we show how to characterise the configurations induced by $n$ instances of a generic port $p$ with the associated degree interval $ty[d_p^l, d_p^u]$.

For a given multiplicity $m$, let $X = [x_1, \ldots, x_w]^T$ be the column vector of integer variables, corresponding to the set $\{a_i\}_{i \in [1,w]}$ (with $w = \binom{n}{m}$) of connectors of multiplicity $m$, involving port instances $p_1, \ldots, p_n$. Let $G$ be the incidence matrix $G = [g_{i,j}]_{n \times w}$ with $g_{i,j} = 1$ if $p_i \in a_j$ and $g_{i,j} = 0$ otherwise. The configurations induced by the $n$ instances of $p$ are characterised by the equation $GX = D$, where $D = [d_1, \ldots, d_n]^T$ and the additional (in)equalities:

$$
d_1 = \cdots = d_n = d \quad \text{and} \quad d_p^l \leq d \leq d_p^u, \quad \text{for } ty = sc,
$$

$$
d_p^l \leq d_1 \leq d_p^u, \ldots, d_p^l \leq d_n \leq d_p^u, \quad \text{for } ty = mc.
$$

(4)
**Example 3.6.** As in Example 2.3, consider a generic port \( p \) and \( n_p = 4, m_p = 2 \). For the degree interval \( sc[1,3] \), the corresponding constraints are \( 1 \leq d \leq 3, x_1 + x_2 + x_3 = d, x_4 = x_3, x_5 = x_2, x_6 = x_1 \).

For the degree interval \( mc[1,3] \) the corresponding constraints are \( 1 \leq d_i \leq 3, \) for \( i \in [1,4] \), \( x_1 + x_2 + x_3 = d_1, x_1 + x_4 + x_5 = d_2, x_2 + x_4 + x_6 = d_3, x_3 + x_5 + x_6 = d_4 \). By solving this system we get:

\[
\begin{align*}
0 &\leq x_i \text{ for } i \in [1..6], \\
x_6 &\leq 3, \\
x_5 &\leq 3 - x_6, \\
x_4 &\leq 3 - x_6, \\
x_4 &\leq 3 - x_5, \\
1 - x_5 - x_6 &\leq x_3 \leq 3 - x_5 - x_6, \\
1 - x_4 - x_6 &\leq x_2 \leq 3 - x_4 - x_6, \\
x_2 &\leq 3 - x_3, \\
1 - x_4 - x_5 &\leq x_1 \leq 3 - x_4 - x_5, \\
1 - x_2 - x_3 &\leq x_1 \leq 3 - x_2 - x_3.
\end{align*}
\]

Suppose that the multiplicity of \( p \) in the motif is given by an interval \( ty[m_p^l, m_p^u] \). Contrary to the degree, multiplicity does not appear explicitly as a variable in the constraints. Instead, it influences the number and nature of elements in both the matrix \( G \) and vector \( X \).

Therefore, for single choice (i.e. \( ty = sc \)), the configurations induced by \( n \) instances of \( p \) are characterised by the disjunction of the instantiations of the system of equalities combining \( G_mX_m = D \) with \( n \) for \( m \in [m_p^l, m_p^u] \).

For multiple choice (i.e. \( ty = mc \)), all the configurations are characterised by the system combining \( n \) with

\[
\sum_{m \in [m_p^l, m_p^u]} (G_mX_m) = D.
\]

Notice that the above modifications to accommodate for interval-defined multiplicity are orthogonal to those in \( n \), accommodating for interval-defined degree. Similarly to the single-choice case for multiplicity, for interval-defined cardinality, the configurations are characterised by taking the disjunction of the characterisations for all values \( n \in [n^l, n^u] \).

Based on the above characterisation for the configurations of one generic port, global configurations can be characterised by systems of linear constraints in the same manner as for simple architecture diagrams.

### 3.4 Architecture Style Specification Examples

**Example 3.7.** The diagram of Figure 13 describes a particular Master/Slave architecture style. We require that each slave interact with at most one master and that each master be connected to the same number of slaves.
Multiplicities of both generic ports $p$ and $q$ are equal to 1, allowing only binary connectors between a master and a slave. The single choice degree of generic port $p$ ensures that all port instances are connected to the same number of connectors which is a number in $[1,n_2]$. The multiple choice degree of generic port $q$ ensures that all port instances are connected to at most one master. A conforming architecture for $n_1 = 2$ and $n_2 = 5$ is shown in Figure 14.

![Diagram](image.png)

**Figure 14:** A Master/Slave architecture.

**Example 3.8.** The diagram in the top of Figure 15 describes the Repository architecture style involving a single instance of a component of type $R$ and an arbitrary number $n_2$ of data-accessor components of type $A$. We require that any data-accessor component must be connected to the repository. In the bottom of Figure 15 we show conforming architectures for $n_2 = 3$.

![Diagram](image.png)

**Figure 15:** Repository architecture style.

**Example 3.9.** The Pipes and Filters architecture style involves two types of components, $P$ and $F$, each having two ports $in$ and $out$. Each input (resp. output) of a filter is connected to an output (resp. input) of a single pipe. The output of any pipe can be connected to at most one filter. Figure 16 graphically describes the Pipes and Filters architecture style. A conforming architecture for $n_1 = 3$ and $n_2 = 4$ is shown in Figure 17.

![Diagram](image.png)

**Example 3.10.** The Peer-to-Peer architecture style involves one component type $P$ with generic ports $req$ (request) and $pro$ (provide). Figure 18 graphically describes the Peer-to-Peer architecture style. Peers request and provide services by using binary connectors between their $req$ and $pro$ ports. A conforming architecture for $n_1 = 4$ is also shown in Figure 18.

**Example 3.11.** The Map-Reduce architecture style allows processing large datasets, such as those found in search engines and social networking sites. Figure 19 graphically describes the
Map-Reduce architecture style. A conforming architecture for $n_1 = 3$ and $n_2 = 2$ is shown in Figure 20.

A large dataset is split into smaller datasets and stored in the global filesystem (GFS). The Master is responsible for coordinating and distributing the smaller datasets from the GFS to each of the map worker components (MW). The port in of each MW is connected to the Mcontrol and read ports of the Master and the GFS, respectively. Each MW processes the datasets and writes the result to its dedicated local filesystem (LFS) through a binary connector between their out and write ports. The connector is binary since no MW is allowed to read the output of another MW. Each reduce worker (RW) reads the results from multiple LFS as instructed by the Master component. To this end, the in port of each RW is connected to the Rcontrol and read ports of the Master and some LFS, respectively. Then, each RW combines the results to produce a final result written back to the GFS through a binary connector between their out and write ports. No RW is allowed to read the output of another RW.

4 Checking Conformance of Diagrams

Algorithm 1 can be used to check whether an architecture $<B, \gamma>$ conforms to an interval architecture diagram $(T, N, C)$. This algorithm has polynomial complexity.

Algorithm 1 checks the validity of the following three statements: 1) the number of components of each type of the model satisfies the cardinality constraints of the diagram; 2) there exists a partition of $\gamma$ into $\gamma_1, \ldots, \gamma_l$ such that each $\gamma_i$ corresponds to a different connector-motif $\Gamma_i \in C$ of the diagram and satisfies its multiplicity constraints; 3) for each connector motif $\Gamma_i$,
Figure 19: Map-Reduce architecture style.

Figure 20: A Map-Reduce architecture.
and its corresponding $\gamma_i$, the number of times each port instance participates in $\gamma_i$ satisfies the degree requirements. The aforementioned statements correspond to sub-algorithms 2, 3 and 4 respectively.

We use two auxiliary functions. Function $\text{generic}(p)$ takes a port instance and returns a corresponding generic port. Function $\text{typeof}(B)$ returns the component type of component $B$. Operation $\text{map}[\text{key}]++$ increases the value associated with the key by one if the key is already in the map, otherwise it adds a new key to the map with value 1.

---

**Algorithm 1: VerifyArchitecture**

**Data:** Architecture $(B, \gamma)$, diagram $(\mathcal{T}, \mathcal{N}, \mathcal{C})$

**Result:** Returns $true$ if the architecture satisfies the diagram $(\mathcal{T}, \mathcal{N}, \mathcal{C})$. Otherwise, it returns $false$.

```plaintext
begin
  if not VerifyCardinality($B$, $(\mathcal{T}, \mathcal{N}, \mathcal{C})$) then
    return $false$;
  /* Splits connectors between connector motifs according to multiplicities constraints. */
  $S_\gamma \leftarrow$ VerifyMultiplicity($\gamma$, $\mathcal{C}$);
  if $S_\gamma = \emptyset$ then
    return $false$;
  /* Verifies degree constraints for all generic ports of all connector motifs. */
  for $\Gamma \in \mathcal{C}$ do
    if VerifyDegree($S_\gamma[\Gamma], \Gamma$) $\neq true$ then
      return $false$;
  return $true$;
```

**Algorithm 2: VerifyCardinality**

**Data:** Set of components $B$, diagram $(\mathcal{T}, \mathcal{N}, \mathcal{C})$

**Result:** Returns $true$ if the number of components of each type in $B$ is in the interval $[n_L^T, n_U^T]$ specified in the diagram. Otherwise, it returns $false$.

```plaintext
begin
  /* Creates a map with key: component type, value: number of instances */
  countTypes $\leftarrow \emptyset$;
  for $B_i \in B$ do
    countTypes[typeof($B_i$)]++;
  for $T \in \mathcal{T}$ do
    if countTypes[$T] \notin [n_L^T, n_U^T]$ then
      return $false$;
  return $true$;
```
Algorithm 3: VerifyMultiplicity

**Data:** Configuration $\gamma$, Set of connector motifs $C$

**Result:** Returns a partition $\mathcal{P}_\gamma$ of $\gamma$ such that each part corresponds to one $\Gamma \in C$. Connectors in each part satisfy multiplicity constraint of the corresponding connector motif. If no partition exists, returns $\emptyset$.

begin

/* Creates a map for the partition with key: connector motif and value: sub-configuration.*/
partition $\leftarrow\{\}$;
for $\Gamma \in C$ do
   $\text{partition}[\Gamma] \leftarrow\emptyset$;
/* Creates a map for the single choice intervals with key: generic port of a connector motif and value: chosen value.*/
scValues $\leftarrow\{}$;
for $k \in \gamma$ do
   /* Creates a map with key: generic port and value: number of instances of the generic port in the connector. */
   portsCount $\leftarrow\{}$;
   for $p_i \in k$ do
      $\text{portsCount}[\text{generic}(p_i)]++$;
      $x \leftarrow false$;
   /* Tries to find a connector motif such that connector satisfies its constraints.*/
   for $\Gamma = (a, \{ty[ml,mu] : dp\}_{p \in a}) \in C$ do
      if $a = \text{keys}(\text{portsCount})$ then
         $y \leftarrow true$;
         /* Checks the multiplicity intervals. */
         for $p \in a$ do
            if $\text{portsCount}[p] \notin [ml, mu]$ then
               $y \leftarrow false$;
               break;
            /* Additional check in case of the single choice interval. */
            if $\text{ty}[ml,mu] = \text{sc}[ml,mu]$ then
               if $\text{hasKey}(\text{scValues}, (\Gamma, p))$ && $\text{scValues}((\Gamma, p)) \neq \text{portsCount}[p]$ then
                  $y \leftarrow false$;
                  break;
               else
                  $\text{scValues}((\Gamma, p)) \leftarrow \text{portsCount}[p]$;
            if $y$ then
               $\text{partition}[\Gamma] \leftarrow \text{partition}[\Gamma] \cup k$;
               $x \leftarrow true$;
               break;
         /* A connector does not satisfy constraints of any connector motif. */
         if $x = false$ then
            return $\emptyset$;
      return partition;
end
Algorithm 4: VerifyDegree

**Data:** Configuration $\gamma_i$, Connector motif $\Gamma = (a, \{m_p : ty[d_p^l, d_p^u] \}_{p \in a})$

**Result:** Returns true if the degree requirements are satisfied. Otherwise returns false.

**begin**

/* Creates a map with key: port and value: number of connectors it appears in.*/

$$\text{degrees} \leftarrow \{\}$$

for $k \in \gamma_i$ do

for $p_i \in k$ do

$$\text{degrees}[p_i] + +;$$

/* Creates a map for the single choice intervals with key: generic port and value: chosen value.*/

$$\text{scValues} \leftarrow \{\}$$

for $p_i \in \text{keys(degrees)}$ do

$p \leftarrow \text{generic}(p_i)$

if $\text{degrees}[p_i] \not\in \text{[d_p^l, d_p^u]}$ then

$$\text{return false;}$$

/* Additional check in case of the single choice interval.*/

if $\text{ty}[d_p^l, d_p^u] = \text{sc}[d_p^l, d_p^u]$ then

if $\text{hasKey(scValues, p)} && \text{scValues}[p] \neq \text{degrees}[p_i]$ then

$$\text{return false;}$$

else

$$\text{scValues}[p] \leftarrow \text{degrees}[p_i];$$

$$\text{return true;}$$

**end**

5 Related Work

UML class diagrams \[22\] have been extensively used to model software systems. Architecture diagrams naturally extend the basic concepts of UML class diagrams taken from the specification/design perspective \[8, 18\]. In this perspective, a UML diagram is interpreted as a description of software abstractions or components with interfaces, but without commitment to a particular implementation.

Architecture diagrams consist of: 1) component types which are similar to UML classes; 2) connector motifs which are similar to UML associations. UML associations define a set of UML links, which are similar to our connectors. UML links, however, cannot specify interactions that involve two or more instances of the same component type \[22\]. For instance, UML diagrams can express the example in Figure 6(b) but not in Figure 6(a) or the Repository style (Figure 15).

In UML, the term multiplicity is used in two different contexts: 1) to define the number of instances of a UML class; 2) to define the number of UML links connected to a UML class. The former is similar to our cardinality constraint, the latter is similar to our degree constraint. In our approach, in addition to degree constraints we have constraints on the multiplicity of the connectors within a class of components. This generalization is a direct consequence of the fact that connectors can relate several instances of the same component type. Figure 21 shows how two UML diagrams taken from the UML specification \[22\] are equivalently represented with
architecture diagrams.

Another difference is that UML multiplicities only allow multiple choice intervals \([2,2]\). We are also using single choice intervals which are essential for the specification of relevant architecture styles (see diagram of Figure 13).

Patterns [6,12] are commonly used for specifying architecture styles in practical applications. The specification of styles is usually done in a graphical way using general purpose graphical tools. Such specifications are easy to produce but the meaning of the design may not be clear since the graphical conventions lack formal semantics and thus, are not amenable to formal analysis.

Several Architecture Description Languages (ADLs), for instance ACME [9], Darwin [11], SOFA [13], Rapide [19], have been proposed for architecture description. ADLs usually provide graphical notations for the specification of architectures [21]. To the best of our knowledge, their graphical notations either do not support the specification of architecture styles or they support it on a higher abstraction level, where it is not possible to deduce all the details without additional textual specifications.

In [11,16], textual logical constraints in Alloy [14] were used to specify architecture styles. Nevertheless, the connectivity primitives used for instance in [11] are binary predicates and cannot tightly characterise coordination structures involving multiparty interaction. Our approach allows to specify \(n\)-ary connectors. Dealing with connectors of arbitrary arity requires that the underlying semantic model is not anymore a graph, it becomes a hypergraph.

6 Conclusion and Future Work

We study architecture diagrams, a graphical language rooted in well-defined semantics for the description of architecture styles. Architecture diagrams are directly inspired from associations/links of class diagrams in UML. In addition to mathematical rigorosity, they naturally extend the basic concepts of UML specification formalisms.

The report proposes a hierarchy consisting of two classes of architecture diagrams and studies their expressive power from a theoretical but also from a practical point of view. Simple architecture diagrams express uniform degree and multiplicity constraints. They are easy to interpret and use but they have limited expressive power. Interval architecture diagrams are strictly more expressive. They cannot be modelled as the union of simple architecture diagrams, because they allow heterogeneity of multiplicity and degree.

Architecture diagrams provide powerful and flexible means for graphical specification of architectures with \(n\)-ary connectors. Using architecture diagrams instead of purely logic-based specifications confers the advantages of graphical formalisms.
We are currently studying the connection between architecture diagrams and configuration logics for the description of architecture styles. In particular, we are working on general architecture diagrams enriched with logical constraints. Additionally, we are working on implementing the synthesis procedure described in this report with the JaCoP¹ constraint solver. In our future work, we plan to use architecture diagrams to model complex architecture styles.

References


¹http://jacop.osolpro.com/


