# Optimal Control System Synthesis Based on Multi-controllers Architecture

Victor ABABII, Ion BALMUS, Gheorghi CEBAN, Radu MELNIC Technical University of Moldova str. Stefan cel Mare nr. 168, MD-2004 Chisinau ababii@mail.utm.md, balmus@mail.utm.md, ceban@mail.utm.md, rmelnic@mail.utm.md

Abstract — This paper offers a solution to the problem of optimal control system synthesis based on uniform multicontroller architecture. For this purpose the equations that describe the control system are decomposed into a set of homogeneous equations with the same complexity and the search for the minimum value of the functional optimization is done as a sequential iterative search using a set of onedimensional equations. In order to ensure maximum efficiency, computational power of the optimal solutions management, is uniformly distributed on a set of computing architecture controllers. AVR ATmega16 microcontrollers and industrial network standard  $I^2C$  series were used to study the behavior of the control system. In the design process there where developed: math models, the structure of the control system, data protocol, the behavioral algorithm and the circuit of the control system based on four microcontrollers. The functionality of the system and convergence of the results were verified with environment design Proteus 7.6.

Index Terms — control system, optimal control, multicontroller architecture,  $I^2C$  bus.

### I. INTRODUCTION

Currently, the sphere of the multiprocessor systems is continuously expanding, covering new domains in various fields of science, business and production. One of such areas is solving optimal control problems of technological or manufacturing processes in real time. The classical problem of optimal control is the system of equations (1), where it is necessary to find the minimum value of the functional Q (2) when maintaining restrictions x(t) (3) and controlling u(t) (4) [1, 2]:

$$\frac{dx}{dt} = f(x, u) \tag{1}$$

$$Q(x, f(x), u, g(u); t) \rightarrow \min$$
 (2)

$$\boldsymbol{x} \in \mathbf{X}$$
, where  $\boldsymbol{x} = \left(\boldsymbol{x}_i, \boldsymbol{i} = \overline{1, N}\right)^T$  (3)

$$\boldsymbol{u} \in \mathbf{U}$$
, where  $\boldsymbol{u} = \left(\boldsymbol{u}_i, i = \overline{1, N}\right)^T$  (4)

The solution of the functional (2) reduces to successive iteration method for solving system of equations (5).

$$\boldsymbol{Q}_{i}\left(\boldsymbol{x},\frac{\partial\boldsymbol{x}_{i}}{\partial t},\boldsymbol{u},\boldsymbol{g}\left(\boldsymbol{u}\right),\boldsymbol{t}\right) < 0, \Rightarrow \boldsymbol{Q} \rightarrow \min, \forall \boldsymbol{i} = \overline{1,N}$$
(5)

The solution of the system of equations (5) is to find the minimum value of the functional (2) through a gradient method in N-dimensional space.

The purpose of this paper is to adapt the solution of optimal control for distributed multi-controllers computing architecture while minimizing the amount of information transmitted between the controllers.

## II. SYNTHESIS PROBLEM STATEMENT OF THE CONTROL SYSTEM

In order to ensure a uniform distribution of computing power the system of equations (1) on optimal condition (2) is decomposed into *N* homogeneous equations of the form:

$$\frac{dx_i}{dt} = f\left(x^*(t), u^*(t)\right), \forall i = \overline{1, N}, \qquad (6)$$

Where:  $\mathbf{x}^*(t) = (\mathbf{x}_i^*(t), \mathbf{i} = \overline{1, N})$  - state of the process and  $\mathbf{u}^*(t) = (\mathbf{u}_i^*(t), \mathbf{i} = \overline{1, N})$  - control signals at the time t.

Starting from the expression (5) and (6), in order to maximize the effectiveness of multi-computing architecture you have to perform the condition of uniform distribution of computer power as follows:

$$\begin{cases}
\frac{dx_i}{dt} = f\left(x^*(t), u^*(t)\right), \\
Q_i\left(x^*, \frac{\partial x_i}{dt}, u^*, g(u^*), t\right) < 0,
\end{cases} \quad (7)$$

#### III. CONTROL SYSTEM SYNTHESIS

To solve the problem (6) considering (5), a MIMD class (Multiple Instruction Multiple Data) [3] multi-controller computing system (MCS) is proposed (Figure 1). MCS is a homogeneous distributed computing architecture based on the industrial network  $I^2C$  [4] and set of processing elements  $PE_i$ ,  $i = \overline{1, N}$ . A controlled process is represented by many technological or manufacturing operations  $TO_i$ ,  $i = \overline{1, N}$ , where  $DI_i$ ,  $i = \overline{1, N}$  - a state signal of the process operation and  $DO_i$ ,  $i = \overline{1, N}$  - the control signal of the process operation.

The functionality of a multi-computing system is based on parallel calculation of the following operations: data input about the process state  $DI_i$ ,  $i = \overline{1, N}$ , data exchange between the computational elements  $PE_i$ ,  $i = \overline{1, N}$ , optimization and calculation of control signals according to expressions (7) and the impact on controlled process signals  $DO_i$ ,  $i = \overline{1, N}$ .



Figure 1. The structure of a computing system.

#### IV. COMMUNICATION PROTOCOL

To exchange data between the computational elements  $PE_i, i = \overline{1, N}$  a special protocol is developed, which is a bitvector  $BV_x$  change in the state of the controlled process and state of the process  $BV_u$ . Figure 2 shows the method of calculating the values of  $BV_x$  and  $BV_u$ .



Figure 2. The method of calculating the bit-vectors.

To determine the values of bit-vectors the sign of the first derivative signal of the state of the process (8) and control is calculated (9) from the following conditions:

$$\begin{cases} If \quad \frac{dx_i}{dt} > 0, \text{ then } BV_{x_i} = 1, \\ If \quad \frac{dx_i}{dt} \le 0, \text{ then } BV_{x_i} = 0. \end{cases} \quad \forall i = \overline{1, N}, \quad (8)$$

$$\begin{cases} If \quad \frac{du_i}{dt} > 0, \text{ then } BV_{u_i} = 1, \\ If \quad \frac{du_i}{dt} \le 0, \text{ then } BV_{u_i} = 0. \end{cases} \quad \forall i = \overline{1, N}. \tag{9}$$

The purpose of bit-vector use is to decrease the amount of sending information between the computational elements  $PE_{i}$ ,  $i = \overline{1, N}$ .

Recovery of standing  $f^*(x)$  and process control  $g^*(u)$  is carried out from the expression (10).

$$\begin{cases} \boldsymbol{f}^{*}(\boldsymbol{x}_{i}) = \int_{0}^{T} (\boldsymbol{B}\boldsymbol{V}_{\boldsymbol{x}_{i}}) d\boldsymbol{t}, \\ 0 & \forall \boldsymbol{i} = \overline{1, N} \\ \boldsymbol{g}^{*}(\boldsymbol{u}_{i}) = \int_{0}^{T} (\boldsymbol{B}\boldsymbol{V}_{\boldsymbol{u}_{i}}) d\boldsymbol{t}. \end{cases}$$
(10)

#### V. CONTROL SYSTEM ALGORITHM

Algorithm for optimal functioning of the control system is shown in Figure 3, where computing elements  $PE_1 \dots PE_N$ are displayed, containing the same sequence of operations and operating in parallel.



Figure 3. The algorithm of computing elements operation.

Specification of a sequence of computational operations to processing elements  $PE_i$ ,  $i = \overline{1, N}$ :

*Start* – beginning of the sequence of operations; *Init System* – initialization processing elements; *System Ready* – determination of availability of computational elements, if the device is ready to work Y then continue to execute sequences of operations of the algorithm, if the device is not ready to work N then blocked and is derived from the multi-controller computing architecture; **Control Computing** – computation of control signals; **Control** – impact of control signals  $DO_i, i = \overline{1, N}$  a controlled process; **State** – input the state  $DI_i, i = \overline{1, N}$  of operation of the controlled process; **Data Comm** – data exchange between computing elements  $BV_x$  and  $BV_u$ ; **State Comm** – exchange of data between computing elements via an  $I^2C$  network; **Stop** – end of the sequence of operations.

#### VI. EXPERIMENTAL MULTI-CONTROLER SYSTEM SYNTHESIS

To test the functionality of the control system is proposed embodiment of the processing elements  $PE_i$ ,  $i = \overline{1, N}$  based on microcontrollers Atmel AVR ATmega16 [5].

4 shows the experimental Figure scheme of architecture, which multiprocessor includes four microcontrollers (U1-U4) ATmega16 connected to the network through a standard  $I^2C$  signals SCL and SDA. Connectors (J1-J4) are intended to enter the state of the controlled process (ADC1), and process control signals (PA3).

The principle of operation of the control system is to solve the system of equations (7) using an iterative method.

As a result of modeling a multi-functional control system (Figure 4) results that prove the correctness of the solution have been obtained for this purpose we used design environment Proteus 7.6 [6]. For more complex control systems (up to 50 MCU) functionality and precision of the results were checked by analytical methods.

#### VII. CONCLUSION

The optimal control problems include increased complexity and the solution of this problem based on singleprocessor (single-controller) computer architectures is inefficient.

This paper offers a solution to the problem of optimal control based on multi-controller architecture with a uniform distribution of computing power and minimizes the amount of information transmitted between the computing elements.

Further research in this area will be used to develop mathematical models for optimal control of the colony of mobile robots in solving collective problems.

#### REFERENCES

- A. A. Agrachev, Yu. L. Sachkov, Lectures on geometric control theory, Trieste, SISSA preprint, 2001.
- [2] A. A. Agrachev, Introduction to Optimal Control Theory, Trieste, SISSA preprint, 2001.
- [3] Henry, John L., and David A. Patterson. "Multiprocessing and Thread level Parallelism". Computer Architecture. ed. 3<sup>rd</sup>. Singapore: Elsevier Pte. Ltd, 2003.
- [4] <u>http://easyelectronics.ru/interface-bus-iic-i2c.html</u> (citation 20.03.2012)
- [5] <u>http://www.atmel.com/products/microcontrollers/</u> (citation 20.03.2012)
- [6] <u>http://www.labcenter.com/index.cfm</u> (citation 28.03.2012)



Figure 4. Experimental multi-controller system.