

## VYSOKÉ UČENÍ TECHNICKÉ V BRNĚ

BRNO UNIVERSITY OF TECHNOLOGY


FAKULTA ELEKTROTECHNIKY A KOMUNIKAČNÍCH TECHNOLOGIÍ<br>ÚSTAV RADIOELEKTRONIKY

FACULTY OF ELECTRICAL ENGINEERING AND COMMUNICATION DEPARTMENT OF RADIO ELECTRONICS

# EVOLUTIONARY SYNTHESIS OF ANALOG ELECTRONIC CIRCUITS USING EDA ALGORITHMS 

EVOLUČNÍ SYNTÉZA ANALOGOVÝCH ELEKTRONICKÝCH OBVODŮ S VYUŽITÍM ALGORITMŮ EDA

DIZERTAČNÍ PRÁCE DOCTORAL THESIS

AUTOR PRÁCE
Ing. JOSEF SLEZÁK
AUTHOR
VEDOUCí PRÁCE
SUPERVISOR


#### Abstract

ABSTRAKT Disertační práce je zameřena na návrh analogových elektronických obvodů pomocí algoritmů s pravděpodobnostními modely (algoritmy EDA). Prezentované metody jsou na základě požadovaných charakteristik cílových obvodů schopny navrhnout jak parametry použitých komponent tak také jejich topologii zapojení. Tři ruzné metody využití EDA algoritmů jsou navrženy a otestovány na příkladech skutečných problemů z oblasti návrhu analogových elektronických obvodů.

První metoda je určena pro návrh pasivních analogových obvodů a využívá algorithmus UMDA pro návrh jak topologie zapojení tak také hodnot parametrů použitých komponent. Metoda je použita pro návrh admitanční sítě s požadovanou vstupní impedancí pro účely chaotického oscilátoru.

Druhá metoda je také určena pro návrh pasivních analogových obvodů a využívá hybridní přístup - UMDA pro návrh topologie a metodu lokální optimizace pro návrh parametrů komponent.

Třetí metoda umožňuje návrh analogových obvodů obsahujících také tranzistory. Metoda využívá hybridní přístup - EDA algoritmus pro syntézu topologie a metoda lokální optimalizace pro určení parametrů použitých komponent. Informace o topologii je v jednotlivých jedincích populace vyjádřena pomocí grafu a hypergrafů.


## KLÍČOVÁ SLOVA

Automatizovaná syntéza analogových elektronických obvodů, návrh analogových elektronických obvodů, evoluční algoritmus, evoluční elektronika, EDA, UMDA, chaotický oscilátor, fraktální kapacitor, pravděpodobnostní model.


#### Abstract

Dissertation thesis is focused on design of analog electronic circuits using Estimation of Distribution Algorithms (EDA). Based on the desired characteristics of the target circuits the proposed methods are able to design the parameters of the used components and theirs topology of connection as well. Three different methods employing EDA algorithms are proposed and verified on examples of real problems from the area of analog circuits design.

The first method is capable to design passive analog circuits. The method employs UMDA algorithm which is used for determination of the parameters of the used components and synthesis of the topology of their connection as well. The method is verified on the problem of design of admittance network with desired input impedance function which is used as a part of chaotic oscillator circuit.

The second method is also capable to design passive analog circuits. The method employs hybrid approach - UMDA for synthesis of the topology and local optimization method for determination of the parameters of the components.

The third method is capable to design analog circuits which include also active components such as transistors. Hybrid approach is used. The topology is synthesized using EDA algorithm and the parameters are determined using a local optimization method. In the individuals of the population information about the topology is represented using graphs and hypergraphs.


## KEYWORDS

Automated synthesis of analog electronic circuits, design of analog electronic circuits, evolutionary algorithm, evolutionary electronics, EDA, UMDA, chaotic oscillator, fractional capacitor, probabilistic model.

SLEZÁK J. Evolutionary Synthesis of Analog Electronic Circuits Using EDA Algorithms. Brno: Brno University of Technology, The Faculty of Electrical Engineering and Communication, 2014. 123 pages, Doctoral thesis.

## PROHLÁŠENÍ

Prohlašuji, že svou disertační práci na téma Evoluční syntéza analogových elektronických obvodů pomocí algoritmů EDA jsem vypracoval samostatně pod vedením školitele a s použitím odborné literatury a dalších informačních zdrojů, které jsou všechny citovány v práci a uvedeny v seznamu literatury na konci práce. Jako autor uvedené disertační práce dále prohlašuji, že v souvislosti s vytvořením této disertační práce jsem neporušil autorská práva třetích osob, zejména jsem nezasáhl nedovoleným způsobem do cizích autorských práv osobnostních a jsem si plně vědom následků porušení ustanovení 11 a následujících autorského zákona č. $121 / 2000 \mathrm{Sb}$., včetně možných trestněprávních důsledků vyplývajících z ustanovení 152 trestního zákona č. 140/1961 Sb.

V Brně dne $\qquad$
(podpis autora)

## DECLARATION

I declare that I have elaborate my doctoral thesis on Evolutionary Synthesis of Analog Electronic Circuits Using EDA Algorithms independently under supervision and using literature and other information sources, which are all cited in the work and listed in the bibliography at the end of work. I furthermore declare that, concerning the creation of this doctoral thesis, I did not infringe the copyrights of third parties, in particular, I have not infringed any copyright. In particular, I have not unlawfully encroached on anyones personal copyright and I am fully aware of the consequences in the case of breaking Regulation 11 and the following of the Copyright Act No $121 / 2000$ Vol., including the possible consequences of criminal law resulted from Regulation 152 of Criminal Act No 140/1961 Vol.

In Brno on $\qquad$

## PODĚKOVÁNÍ

Děkuji svému školiteli prof. Ing. Tomáši Dostálovi, DrSc. za vedení, odbornou pomoc a podporu při vypracování této práce. Dále děkuji doc. Ing. Jiřímu Petrželovi, Ph.D. a Ing. Romanu Šotnerovi, Ph.D. za cenné připomínky a diskuze a prof. Dr. Ing. Zbyňku Raidovi za vstřícnost během celého doktorského studia. Speciálně děkuji mojí rodině, Alexandře Mateáskové, Pradhanu Balterovi, Radku Šebelovi a Michalu Kuncovi za porozumění a podporu.

## ACKNOWLEDGMENT

I would like to thank my supervisor, prof. Ing. Tomáš Dostál, DrSc., for his methodological, pedagogical and professional support. Thanks to doc. Ing. Jiří Petržela, Ph.D. and Ing. Roman Šotner, Ph.D. for valuable discussions and their comments. Thanks to prof. Dr. Ing. Zbyněk Raida for his helpfulness and support. Special thanks to my whole family for support during my doctoral study and to Alexandra Mateásková, Pradhan Balter, Radek Šebela and Michal Kunc for their help and understanding.

## CONTENTS

1 Introduction ..... 1
2 Evolutionary Electronics ..... 4
2.1 Basic Principle ..... 4
2.2 Intrinsic and Extrinsic Systems ..... 5
2.3 Possible Strategies of Evolutionary Electronics Systems ..... 6
3 State of the Art ..... 8
4 Review of The Encoding Methods ..... 11
4.1 Direct Encoding Method ..... 11
4.2 Parse Tree Representation ..... 13
4.3 Linear Representation ..... 17
4.4 Adjacency Matrix Representation ..... 20
5 Autonomous Circuits, Graphs and Encoding Methods ..... 22
5.1 Autonomous Circuits ..... 22
5.2 Autonomous Circuits and Circuit Design ..... 25
5.3 Graph Representations of Analog Circuits ..... 27
5.3.1 Simple Graph Representation ..... 27
5.3.2 Multigraph Representation ..... 28
5.3.3 3-Uniform Labeled Hypergraph Representation ..... 29
5.4 Evolutionary Analog Circuits Design as a Problem of Searching of a .....
Subgraph ..... 30
5.4.1 Passive Circuits ..... 30
5.4.2 Transistor Circuits ..... 32
5.4.3 Mixed Type Circuits ..... 33
5.5 Encoding of Graph Representations of Analog Circuits ..... 35
5.5.1 Characteristic Vector of Simple Graph ..... 35
5.5.2 Characteristic Vector of Multigraph ..... 36
5.5.3 Encoding of Passive Analog Circuits ..... 36
5.5.4 Characteristic Vector of 3-Uniform Hypergraph ..... 37
5.5.5 Characteristic Vector of 3-Uniform Labeled Hypergraph ..... 38
5.5.6 Encoding of Active Analog Circuits (Transistors) ..... 39
5.6 Analog Circuit Synthesis and Unitation Constraints ..... 39
6 Thesis objectives ..... 40
7 Used Approaches ..... 41
7.1 Estimation of Distribution Algorithms ..... 41
7.1.1 Univariate Marginal Distribution Algorithm (UMDA) ..... 42
7.1.2 Bivariate Marginal Distribution Algorithm (BMDA) ..... 42
7.1.3 Population Based Incremental Learning (PBIL) ..... 42
7.1.4 Compact Genetic Algorithm (cGA) ..... 42
7.1.5 Factorization Distribution Algorithm (FDA) ..... 43
7.1.6 Bayesian Optimization Algorithm (BOA) ..... 43
7.2 UMDA for Problems with Unitation Constraints ..... 43
7.3 Hybrid Genetic Algorithm ..... 45
7.3.1 Lamarckian Hybrid Genetic Algorithm ..... 45
7.3.2 Baldwinian Hybrid Genetic Algorithm ..... 45
8 Evolutionary Synthesis of Analog Circuits using EDA ..... 46
9 Evolutionary Synthesis of Chaotic Dynamics Using Pure UMDA ..... 48
9.1 Definition of the Problem ..... 48
9.1.1 Mathematical Background of Chaotic Dynamics ..... 48
9.1.2 Circuit Realization of the Proposed Chaotic Oscillator ..... 50
9.2 Description of the Method ..... 53
9.2.1 Used Encoding ..... 53
9.2.2 Objective Function ..... 54
9.2.3 Settings of the Algorithm ..... 55
9.2.4 Experiments and Solutions ..... 56
9.2.5 Simulation of the Chaotic Oscillator ..... 61
9.3 Conclusion ..... 63
10 Synthesis of Fractional Capacitor Using Hybrid UMDA Algorithm ..... 64
10.1 Definition of the Problem ..... 64
10.2 Hybrid UMDA Algorithm ..... 66
10.2.1 Main Flowchart of the Method ..... 66
10.2.2 Evaluation of Cost Value and Local Search Method ..... 67
10.2.3 Encoding Method ..... 69
10.2.4 Objective Function ..... 70
10.2.5 Settings of the Proposed Algorithm ..... 71
10.2.6 Experiments and Solutions ..... 72
10.2.7 Comparison of the Best Synthesized Solution and Original Ap- proximation Circuit ..... 75
10.3 Conclusion ..... 77
11 Synthesis of Cube Root Function Using Graph EDA Method ..... 78
11.1 Definition of the Problem ..... 78
11.2 Introduction of Graph Estimation of Distribution Algorithm ..... 79
11.3 Encoding Method ..... 80
11.4 Learning of the Probabilistic Model ..... 85
11.5 Sampling of the Probabilistic Model ..... 86
11.6 Objective Function ..... 87
11.7 Parameters Optimization ..... 88
11.8 Experiments and Solutions ..... 89
11.9 Comparison to Other Methods ..... 92
11.10Conclusion ..... 93
12 Summary and Future Directions ..... 94
13 Implementation notes ..... 96
13.1 MATEDA 2.0 ..... 96
13.2 BNLEARN ..... 96
13.3 DEAL ..... 96
13.4 COPULAEDAS ..... 97
13.5 NGSPICE ..... 97
13.6 HSPICE ..... 97
References ..... 98

## LIST OF FIGURES

2.1 a) Basic idea of evolutionary electronics system b) Principal flow chartof the evolutionary electronics methods.4
2.2 Evaluation of the fitness value in the intrinsic system (a) and in the extrinsic system (b). ..... 6
4.1 a) Encoding variables sequence b) example of an analog circuit c) encoding vector of the circuit ..... 11
4.2 a) Example of parse tree representation b) encoded circuit. ..... 13
4.3 Structure of the embryonic circuit. ..... 14
4.4 Illustration of the functions FLIP and C. ..... 15
4.5 Illustration of the function QT. ..... 15
4.6 Ilustration of the function SERIES. ..... 16
4.7 Illustration of the function PSS. ..... 16
4.8 Structure of the basic embryonic circuit. ..... 17
4.9 Example of sequence of OPCODEs. ..... 18
4.10 Corresponding encoded circuit. ..... 18
4.11 Example of generic floating graph with self-loops $G_{a}$ and its corre- ..... 20
4.12 Example of graph representation of analog circuit topology $G_{a}^{\prime}$ and its corresponding reduced adjacency matrix $M_{a}^{\prime}$. ..... 21
5.1 Autonomous circuit 2AC5. ..... 23
5.2 Autonomous circuit 3AC4. ..... 24
5.3 Autonomous circuit with 2 ports generalized admittances and com- ..... 25
5.4 Replacement of the generalized admittances by real components. ..... 26
5.5 a) Graph $G_{s}$ b) Analog circuit $C_{s}$. ..... 27
5.6 a) Multigraph $G_{m}$ b) analog circuit $C_{m}$. ..... 28
5.7 a) 3-uniform labeled hypergraph $G_{h}$ b) Analog circuit $C_{h}$. ..... 29
5.8 a) Complete graph $G_{c p}$ b) circuit 2AC4 corresponding to $G_{c p}$. ..... 30
5.9 Graph $G_{c p e}$ (obtained by expansion of graph $G_{c p}$ ). ..... 31
5.10 Analog circuit $C_{e}$ corresponding to expanded graph $G_{c p e}$. ..... 31
5.11 a) Example of subgraph $G_{p}$ b) Analog circuit $C_{p}$ corresponding to subgraph $G_{p}$. ..... 32
5.12 a) Complete 3-uniform hypergraph $G_{c t}$ b) circuit 3AC4 corresponding32
5.13 a) Example of subgraph $G_{t}$ on complete 3-uniform hypergraph $G_{c t}$ b)analog circuit $C_{t}$ corresponding to $G_{t}$.33
5.14 a) Example of passive part graph $G_{p a s}$ b) analog circuit $C_{p a s}$ corre-
5.15 a) Example of active part graph $G_{a c t}$ b) analog circuit $C_{a c t}$ corre-sponding to graph $G_{a c t}$.34
5.16 Analog circuit of mixed type $C_{m t}$ consisting of passive part circuit$C_{p a s}$ and active part circuit $C_{a c t}$.34
5.17 a) Example of simple graph for $n_{n}=3$ and its characteristic vector$\left.e_{s 1} \mathrm{~b}\right)$ example of simple graph for $n_{n}=4$ and its characteristic vector$e_{s 2}$.35
5.18 a) Mutigraph $G_{m}$ with 4 vertices b) characteristic vector $e_{m}$ of multi- ..... $\square$
graph $G_{m}$. ..... 36
5.19 Encoding vector $e_{p}$ of graph $G_{p}$ in Fig. 5.11a ..... 37
5.20 Two examples of 3-uniform hypergraphs for $n_{n}=4$ and theirs char- ..... _
acteristic vectors. ..... 38
5.21 Example of 3-uniform labeled hypergraph $G_{h l}$ (a) and its encoding ..... 38
7.1 Pseudo-code of Estimation of Distribution Algorithm. ..... 41
7.2 Pseudo-code of original UMDA. ..... 44
7.3 Pseudo-code of modified UMDA. ..... 44
8.1 Procedure of manual design of analog circuits using autonomous cir- cuits approach. ..... 46
8.2 Pseudo-code of the proposed automated analog circuit synthesis method based on EDA. ..... 46
9.1 a) Numerical integration of the first set of parameters (9.1) b)Numerical integration of the second set of parameters (9.2).50
9.2 Block diagram of the proposed chaotic oscillator. ..... 50
9.3 a) Schematic of PWL resistor b) Input DC characteristic of PWL51
9.4 a) Magnitude of input impedance $Z_{i n 1}$ b) Phase of input impedance $Z_{i n 1}$
c) Magnitude of input impedance $Z_{i n 2}$ d) Phase of input impedance$Z_{i n 2}$52
9.5 Schematic diagram of the used encoding vector $e$. ..... 53
9.6 Configuration of toolbox Mateda 2.0 for realization of UMDA algorithm. ..... 55
9.7 Parameters (9.1), solution 4: schematic of the synthesized circuit (a),magnitude of $Z_{\text {in }}$ (b), deviation of magnitude $Z_{i n}$ and desired function$(9.11)(\mathrm{c})$, phase of $Z_{i n}(\mathrm{~d})$, deviation of phase $Z_{i n}$ and desired function(9.11)(e)57

|  | Parameters (9.1), solution 15: schematic of the synthesized circuit |
| :---: | :---: |
| (a), magnitude of $Z_{\text {in }}$ (b), deviation of magnitude $Z_{i n}$ and desired |  |
| function (9.11)(c), phase of $Z_{\text {in }}(\mathrm{d})$, deviation of phase $Z_{\text {in }}$ and desired |  |
|  | function (9.11)(e) |
|  | Parameters (9.2), solution 5: schematic of the synthesized circuit (a), |
| magnitude of $Z_{\text {in }}(\mathrm{b})$, deviation of magnitude $Z_{\text {in }}$ and desired function |  |
| (9.12)(c), phase of $Z_{\text {in }}$ (d), deviation of phase $Z_{\text {in }}$ and desired function |  |
|  | (9.12)(e) |
| Parameters (9.2), solution 6: schematic of the synthesized circuit (a), |  |
| magnitude of $Z_{\text {in }}(\mathrm{b})$, deviation of magnitude $Z_{\text {in }}$ and desired function |  |
| (9.12) (c), phase of $Z_{\text {in }}(\mathrm{d})$, deviation of phase $Z_{\text {in }}$ and desired function |  |
| (9.12)(e) |  |
| State projection for parameters (9.1) and solution 4: I(L1) vs. Vin |  |
| (a), I(L2) vs. Vin (b) |  |
| State projection for parameters (9.1) and solution 15: I(C3) vs. V(R4) |  |
| (a), I(L1) vs. V(R4) (b). |  |
| State projection for parameters (9.2) and solution 5: I(C1) vs. Vin |  |
| (a), I(L2) vs Vin (b). . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 |  |
| State projection for parameters (9.2) and solution 6: I(C3) vs. Vin |  |
| (a), I(C6) vs. Vin (b). . . . . . . . . . . . . . . . . . . . . . . . . . 62 |  |
| 10.1 Schematic of the original approximation circuit. |  |
| 10.2 a) Comparison of the magnitude characteristics of ideal function |  |
| (10.1) and original approximation circuit b) deviation of the mag- |  |
| nitude c) comparison of the phase characteristics of ideal function |  |
| (10.1) and original approximation circuit d) deviation of the phase. |  |
| 10.3 Principal flowchart of the proposed method. . . . . . . . . . . . . . . 66 |  |
| 10.4 Flow chart of the evaluation cost and local search phase. |  |
| 10.5 Schematic diagram of encoding vector e. . . . . . . . . . . . . . . . . 69 |  |
| 10.6 Configuring of MATEDA 2.0 toolbox for realization of UMDA algo- |  |
| rithm. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . |  |
| 10.7 Schematics of the approximation circuits synthesized in run 5 (a), run |  |
| 4 (b), run 11 (c), run 20 (d). |  |
| 10.8 a) Comparison of magnitude of $Z_{\text {in }}$ of the best circuit and (10.1) b) |  |
| Deviation of magnitude of $\mathrm{Z}_{\text {in }}$ of the best circuit c) Comparison of |  |
| phase of $\mathrm{Z}_{\text {in }}$ of the best circuit and (10.1) d) Deviation of phase of |  |
| $\mathrm{Z}_{\text {in }}$ of the best circuit. |  |
| 10.9 Zeros and poles diagram of the best synthesized circuit. |  |
| 11.1 Target response of the desired circuit realization of cube root function. |  |
| 11.2 Pseudo-code of the proposed method. |  |

11.3 a) Complete graph $G_{\text {resc }}$ for $n_{n}=4 \mathrm{~b}$ ) Analog circuit corresponding to $G_{\text {resc }}$ c) Subgraph $G_{\text {res }}$ d) Analog circuit corresponding to $G_{\text {res }}$ and its encoding vector $e_{\text {res }}$.
11.4 a) Complete 3-uniform hypergraph $G_{n p n c}$ for $n_{n}=4 \mathrm{~b}$ ) Analog circuit representation of $G_{n p n c}$ c) Example of 3-uniform hypergraph $G_{n p n}$ d) Analog circuit representation of $G_{n p n}$. . . . . . . . . . . . . . . . . . . 82
11.5 Encoding vector $e_{n p n}$ of hypergraph $G_{n p n}$. . . . . . . . . . . . . . . . 84
11.6 a) Graphs $G_{v c c p}$ and $G_{v c c n}$ b) Connection of the voltage sources de-

11.7 Encoding vector $e_{v c c p}$ of graph $G_{v c c p}$ and encoding vector $e_{v c c n}$ of graph $G_{v c c n .}$. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
11.8 Examples of vectors $v_{n p n}$ and $v_{p n p}(\mathrm{a}), v_{r e s}(\mathrm{~b}), v_{v c c p}(\mathrm{c})$ and $v_{v c c n}(\mathrm{~d}) . ~ 86$
11.9 Flow chart of the sampling phase. . . . . . . . . . . . . . . . . . . . . 86
11.10Pseudo code of the optimization phase. . . . . . . . . . . . . . . . . . 88
11.11a) Comparison of the output voltage characteristic $U_{2}=f\left(U_{1}\right)$ of the best solution and desired function (11.1) b) deviation of the output voltage characteristic $U_{2}=f\left(U_{1}\right)$ of the best solution and function (11.1). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 90
11.12Netlist of the best solution. . . . . . . . . . . . . . . . . . . . . . . . 91
11.13Schematic of the best solution. . . . . . . . . . . . . . . . . . . . . . . 92

## LIST OF TABLES

4.1 Values of variable $v_{\text {type }}$ for different types of the components. ..... 12
4.2 Assignment of variable multiplier $v_{\text {mult }}$. ..... 12
4.3 Component-creating functions. ..... 14
4.4 Circuit-modifying functions. ..... 14
4.5 Summary of OPCODEs used in developmental encoding method. ..... 17
5.1 Assignment of the generalized admittances to nodes of 2AC5. ..... 24
5.2 Assignment of the generalized admittances to nodes of 3AC4. ..... 24
5.3 Replacement of the generalized admittances by real components. ..... 26
5.4 Parameters of the edges and corresponding configurations of compo-27
5.5 Labels of the edges and corresponding selection of the component. ..... 28
5.6 Labels of the hyperedges and corresponding "rotations" of the tran-29
5.7 Assignment of the edges to the combinations of the vertices for simple ..... 35
5.8 Assignment of the edges to the combinations of the vertices. ..... 36
5.9 Assignment of the hyperedges to the vertices. ..... 37
9.1 Setting of weights $w_{d m}$ and $w_{d p}$. ..... 54
9.2 Summary of the parameters of the used UMDA algorithm. ..... 55
9.3 Results for the first set of the parameters (9.1). ..... 56
9.4 Results for the second set of the parameters (9.2). ..... 56
10.1 The highest deviations of magnitude and phase of the original ap- ..... 65
10.2 Setting of weights $w_{d m}$ and $w_{d p}$. ..... 70
10.3 Setting of the parameters of the problem. ..... 71
10.4 Results of 20 runs of the proposed algorithm. ..... 72
10.5 The highest deviations of magnitude and phase of the best synthesized ..... 74
10.6 Comparison of deviations of magnitude of $Z_{\text {in }}$ for original approxima-tion circuit and for the best synthesized circuit.76
10.7 Comparison of deviations of phase of $Z_{\text {in }}$ for original approximation76
11.1 Assignment of the edges to the vertices for graphs $G_{\text {resc }}$ and $G_{r e s}$ andassignment of the resistors to the nodes for circuits in Fig. 111.3b andFig. |11.3d]81
11.2 Assignment of the hyperedges to the vertices for hypergraphs $G_{n p n c}$ and $G_{n p n}$ and assignment of the 3 ports generalized admittances ( $Y_{1}$ to $Y_{4}$ ) to the nodes for circuits in Fig. $11.4 \mathrm{~b} \mid$ and Fig. $11.4 \mathrm{~d} \mid$. . . . . . 83
11.3 Assignment of the labels of the hyperedges to the connection nodes
of the transistors. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
11.4 Summary of the parameters of the proposed algorithm. . . . . . . . . 89
11.5 Results of 20 runs of the proposed algorithm. . . . . . . . . . . . . . 90
11.6 Comparison of the results of GhEDA to GP and GA OLG. . . . . . . 92
11.7 Comparison of the number of the components of the best solutions of methods GP, GA OLG and GhEDA. 93

## 1 INTRODUCTION

Although there is a trend of using digital processing in most areas of the modern electronics, analog electronic circuits are still important part of today's electronic integrated chips. There is variety of applications where using of analog circuit processing is advantageous compared to digital solutions or such digital solutions even do not exist.

Probably the most important application of analog circuits is to provide connection between digital circuits and analog signals of "outer world". Analog signals from variety of different sensors (mechanical tension, air pressure, magnetic field) can be transformed to digital signals using analog to digital converters. Similarly digital signals of digital circuits can be transformed to analog signals using digital to analog converters. Important application of analog circuits are frequency filters which are necessary during sampling process to avoid aliasing effect (anti-aliasing filters). Another traditional application of analog circuits are radio frequency (RF) circuits which can operate on frequencies of several GHz. Analog circuits can be used as a part of digital circuits to provide constant reference voltage (voltage reference circuits) with stable conditions independent on the parameters of the environment.

Design of analog circuits is traditionally domain of experienced designers and usually is viewed as a kind of art where important part is designer's intuition involved in the design process. Therefore analog circuit design is expensive and time consuming. As was discussed in [1] although digital parts in mixed-type SoCs integrated chips generally occupy for more than 90 percent of the chip area, the most design cost and effort is spent on design of the analog part which accounts usually only 10 percent of the area of the whole chip. Therefore there is an effort to automatize the design process of analog circuits using automated computer analog circuit design tools.

With increasing performance of modern computing and advances in the areas of artificial intelligence, machine learning and optimization there is possibility to take over considerable amount of the time consuming procedures required to design of analog electronics to modern computer methods called automated analog circuit design or evolutionary electronics.

Another motivation for usage of the evolutionary electronics methods is demand of synthesis of analog circuits for which no methods of classical analog design exist. There is a variety of problems of analog electronics which can be hardly or even by no means solved using classical analog design methods. For example synthesis of computational circuits as discussed in [57.

Process of automated analog circuit synthesis consists of two main tasks which are formation of suitable topology and sizing of the components. Topology can
be selected from a library of possible topologies or it can be generated during the synthesis process. Since selection of the suitable topology from a library has not brought satisfactory results the research in topology formation methods is now focused mainly on the topology generation approach.

Given a variety of desired specifications of the evolved circuit evolutionary electronics systems are able to synthesize different types of electronic circuits. In some cases evolutionary electronics method can produce strange circuit structures with non-standard topologies. Although the resulting circuit meets the desired specifications the way how the evolutionary synthesis reached the target specification in not really what the designer wanted. Such behavior can be unacceptable for example in evolutionary design of operational amplifiers or OTA circuits where the circuit topologies are well-established. Optimization task of such circuits usually consists only in optimization of the parameters of the used transistors (width, height) while topology is fixed. The goal of the optimization is to achieve desired parameters of the circuit as slow rate, bandwidth or dynamic range. The problem of generation of non-standard topologies can be solved using evolutionary electronics synthesis methods which use a library of building blocks (voltage sources, current sources, current mirrors). Such method is able to reach target circuits with topologies similar to classical hand analog circuits design [22], [23].

On the other hand there are some problems of analog circuit synthesis where no well established topologies exist. For example passive analog networks with arbitrary input impedance function [3] [4] [5] [6] or computational circuits [57]. In these cases creative potential of the evolutionary electronics methods can be fully utilized with no restrictions of the target topologies.

Although evolutionary electronics systems and design automation tools for digital electronic circuits are at very good useful level, in the area of analog circuits the tools are still not mature enough for regular usage. One of the reasons of this fact is that complex digital circuits are usually partitionable to lower complexity functional blocks which can be designed and optimized separately. This way the synthesis of a complex digital system can be separated into partial low complexity designs. Since analog circuits usually work as systems where all blocks are connected through feedback connections and strongly interact between each other partitioning of an analog circuits is difficult task. By disconnecting of the feedback connections in the circuit lower complexity blocks usually lose theirs function. This behavior of analog circuits results in requirement of simultaneous optimization of the whole circuits which is computationally very expensive task.

There have been presented variety of different approaches to handle automated analog circuit synthesis problem. Systems based on optimization and machine learning methods such as genetic algorithms, genetic programming, ant colony optimiza-
tion, graph grammar and others have been presented.
Recently Estimation of Distribution Algorithms (EDA) have shown theirs superior performance compared to classical genetic algorithms. Drawbacks of genetic algorithms such as requirement of tight linkage in the encoding, deceptive functions and disruption of the building blocks after the crossover operation can be overcome using EDA [26].

The presented thesis is focused on evolutionary design of low complexity and medium complexity passive and active analog electronic circuits using Estimation of Distribution Algorithms.

## 2 EVOLUTIONARY ELECTRONICS

### 2.1 Basic Principle

Imagine a design space where each point in that space represents the design of an electronic circuit. All possible electronic circuits are there, given the component types available to electronics engineer, and the technological restrictions on how many components there can be and how they can interact. In this metaphor, we loosely visualize the circuits to be arranged in the design space so that similar circuits are close to each other. The design space is vast. There are oscillators and filters, finite-state machines, analogue computers, parallel distributed systems, Von Neumann computers, and so on. These nestle amongst the majority of circuits for which a use will never be found.

The chapter is introduced with metaphor [2] which perfectly depicts the main idea of evolutionary electronics synthesis methods. Electronic circuits are synthesized by means of search algorithms which try to find suitable solution in a given search space (Fig. 2.1 a ). Principal flow chart of the evolutionary electronics synthesis methods is presented in Fig. 2.1b.


Fig. 2.1: a) Basic idea of evolutionary electronics system b) Principal flow chart of the evolutionary electronics methods.

As can be seen in Fig. 2.1b there are three basic phases of the program flow of the evolutionary electronics methods. In the first phase promising candidate solutions are generated. Various methods of local and global optimization, machine learning, artificial intelligence or theirs combinations can be used. In the next phase fitness values of the generated solutions are evaluated. In the last phase meeting of the desired specifications is tested. If any solution meeting the desired specifications has been found the whole evolutionary electronics system is terminated. Otherwise the whole process repeats.

### 2.2 Intrinsic and Extrinsic Systems

Based on the realization of the fitness evaluation phase evolutionary electronics systems can be intrinsic or extrinsic.

Intrinsic evolutionary electronics systems utilize real HW implementation in configurable device as for example FPTA (field transistor array). Generated solutions are directly implemented in the configurable device and its fitness value is calculated based on the measured results of the implemented solution.

Flow chart of evaluation of the fitness value in intrinsic systems is presented in Fig. 2.2 a. Generated solution is transformed to a form suitable for configurable device and the corresponding circuit is implemented. Responses (voltage transfer, frequency response) of the configured device are measured and the fitness value is calculated.

The strong advantage of this solution is that circuit is implemented in real hardware including all parasitic influences. Also the speed of such fitness evaluation approach is very high therefore running time of intrinsic systems is much shorter than extrinsic systems. On the other hand intrinsic systems require specialized HW devices which are expensive compared to the extrinsic systems. Also the configurable devices are usually designed for specific small range of applications.

In the extrinsic systems evaluation of the fitness values is based on the responses obtained by simulation. Flow chart of evaluation of the fitness values in extrinsic systems is presented in Fig. 2.2b. Generated solution is transformed into netlist file suitable for circuit simulators and simulation is performed. Based on the results of the simulation fitness value of the solution is calculated.

The first most obvious advantage of the extrinsic systems compared to the intrinsic ones is that no additional HW is required. The extrinsic evolutionary synthesis systems can be used on any standard computer. Since the responses of the candidate solutions are obtained using circuit simulator the accuracy and reliability of evaluation of the fitness function fully depends on the quality of the used circuit

a)

b)

Fig. 2.2: Evaluation of the fitness value in the intrinsic system (a) and in the extrinsic system (b).
simulator. Usually spice compatible circuit simulators as hspice or ngspice are used. Although credibility of the modern circuit simulators is very high there can be still some differences between responses obtained using circuit simulator and responses obtained using real HW implementation in some cases.

Since the simulation run time of the circuit simulators is much longer than measurement in the intrinsic systems the extrinsic systems require much longer run time of the whole synthesis process.

### 2.3 Possible Strategies of Evolutionary Electronics Systems

Generally the automated analog circuits synthesis problem can be defined as two strongly related tasks. The first one is searching for the suitable topology and the second one is determining of the parameters of the components of the selected topology. Searching for the suitable topology can be defined as combinatorial optimization problem. Searching for the parameters of values can be defined as continuous or discrete continuous optimization problem.

Based on the used algorithm or combination of algorithms these two partial problems can be solved simultaneously or separately. In the case of simultaneous solving the whole problem of analog circuit synthesis is encoded into one encoding vector which includes information about the topology and the parameters of the components as well. Used optimization algorithm has to be able to deal with mixed
combinatorial/continuous types of problems. Mixed-type problems can be solved using simulated annealing as used in [3] (4) 5], messy genetic algorithm as used in [18] and others. Simultaneous solving of the topology and the components values results in lower running time of the whole synthesis process. On the other hand used encoding method has to be carefully designed to comply different demands of the both parts of the problem (topology and parameters). Another difficulty of the simultaneous solving is to selected, design or modify suitable optimization method which is able to handle such mixed type optimization problem.

The second approach is to separate the whole synthesis process into two partial tasks - searching for the topology and determining of the parameters. Although such strategy is usually more computationally expensive than simultaneous solving the advantage of this approach is simpler implementation and high variability of the whole method. There is no need of difficult design of suitable encoding and various methods of combinational optimization for searching of the topology can be used in combination with various methods of continuous optimization for searching of the parameters. Separate solving of the analog circuit synthesis problem was used in methods published for example in [22] or [23].

## 3 STATE OF THE ART

The first papers focused on the subject of the evolutionary electronics synthesis methods and analog circuit design automation were published in late eighties of 20th century. In the section review of the evolutionary electronics methods which are able to synthesize whole analog circuits (the topology and the parameters of the components) is presented.

One of the first attempts to handle the problem of the analog circuits design automation was published by Degrauwe et al. in [7] where system IDAC was described. In the first step the designer specifies the technology, desired building-block parameters, design options and one or more schematics from the program's library. After performing of the synthesis results as frequency responses, SPICE2 input file, input file for layout program ILAC [7] or input file for PPR-G [7] representing the datasheet can be obtained.

In 8 Harjani described tool OASYS which uses design plans to successively select the topologies and translate specifications in a knowledge based synthesis framework.

Another system called OPASYN which is suitable for synthesizing of CMOS transistor structures was presented by Koh et al. in [9]. Similar tool called DARWIN was presented by Kruiskamp et al. in [10. Synthesis of VLSI circuits using parallel genetic algorithm system consisted of twenty distributed SPARC workstations was presented by Davis et al. in [11.

The pioneer of genetic programming (GP) J. Koza employed GP method in automated analog circuit synthesis system where analog electronic circuits are encoded using tree structures [31]. Despite extensive effort of J. Koza et al. evolutionary electronics systems based on genetic programming are computationally very expensive.

Another research line of the earliest works was focused on analog circuits design automation based on genetic algorithms (GA). Grimbleby have published several papers focused on employing of hybrid GA and direct encoding method for synthesis of passive analog circuits [13] [14]. The synthesis was performed in two steps. In the first one the topology was selected and its simulatability was verified using symbolic calculation routine. In the second step the parameters (values of the components) were determined using a numerical optimization method. As was stated in [13] computational cost of this approach was much lower than similar system based on GP.

Another attempt to handle analog circuit synthesis automation problem by means of GA was presented by Lohn and Colombano in [15]. The method uses simultaneous synthesis of the topology and the parameters approach. Compared
to the previous work presented by Grimbleby analog circuits are encoded using developmental encoding. The basic principle of developmental encoding is to encode sequence of circuit-building instructions (OP codes) which construct the topology of the circuit. The motivation for using developmental encoding method was demand to decrease number of dead (nonsimulatable) individuals created after recombination phase of the used GA. On the other hand developmental encoding can restrict possible encodable analog circuit topology in some cases.

More advanced approach of synthesis of passive and also active analog circuits was proposed by Zebulum who employed GA with variable chromosome representation [16]. Besides the main chromosome vector containing the analog circuit structure information the GA utilizes also mask vector which is used to define coding and noncoding segments of the main chromosome. There were proposed three approaches called ILG, OLG and UDIP to manipulate the bits of the mask vector. The method was also used for unconstrained synthesis of the active QR networks 17.

System employing GA with variable length chromosome was used in [18]. The paper also discusses modification of the parameters of the evolved analog circuit by addition of random noise. As was discussed in [18] this approach tries to model impact of the environment and guides the search to the topologies with higher resistivity to variation of the parameters (topologies with lover sensitivity).

Compared to the previous works where only synthesis in the frequency domain was handled. Paper [19] is focused on synthesis of sinusoidal oscillator circuit in time domain.

Mattiussi proposed method called analog genetic encoding (AGE) which is able to synthesize analog circuits and neural networks [20]. The system employs encoding method based on biological chromosomes principles. The proposed method was verified on a number of analog circuit synthesis problems [20].

Das and Vemuri have proposed several methods for automated analog circuit synthesis. The first method called GAPSYS was able to synthesis only passive analog circuits [21. Another two methods separate the analog circuits synthesis task into two partial processes. Synthesis of the topology and sizing of the components. In the method presented in [22] selection of the topology is realized using adaptively generated building blocks. Evolutionary electronics synthesis method using graph grammar based approach was presented in [23].

Analog circuits encoding method based on adjacency matrix representation and special type of crossover were presented by Mesquite et al. in [24]. Compared to the incidence matrix representation the proposed method is able to preserve topologies of both parental circuits and to connect them in meaningful way through subset of nodes [24]. The adjacency matrix encoding method was used for synthesis of
low-sensitivity antenna matching network [25].
Recently Estimation of Distribution Algorithms (EDA) have shown theirs superior performance compared to classical genetic algorithms [26] . Univariate Marginal Distribution Algorithm (UMDA) [27] which is the simplest version of EDA was employed in evolutionary electronics system presented by Zinchenko [28]. The proposed system was verified on the problem of synthesis of low pass filter. Application of UMDA in mixed analog-digital circuits design system was described by Zinchenko in [29]. Another application of UMDA in automated analog circuits synthesis method was presented by Torres in 30].

The goal of the thesis is to design and verify three types of automated analog circuits synthesis methods based on Estimation of Distribution Algorithms. Synthesis capability of every method will be verified on an example of analog circuit synthesis problem.

## 4 REVIEW OF THE ENCODING METHODS

Besides the optimization method choosing or design of the suitable encoding approach is one of the key requirements of the success of the optimization. In the text bellow there will reviewed different types of encoding methods of analog circuits as were presented in literature focused on evolutionary analog circuit synthesis.

### 4.1 Direct Encoding Method

The most simple and straightforward method of the analog circuit encoding is direct encoding method. The principle of the approach will be demonstrated on the example of encoding of passive circuit including RLC components. Encoding vector $e$ is formed of $n$ integer numbers. Every component of the encoded circuit is described by sequence of 5 integer variables defining its type (variable $v_{\text {type }}$ ), connection nodes ( $n_{1}$ and $n_{2}$ ), exponent ( $v_{\text {exp }}$ ) and mantissa ( $v_{\text {man }}$ ). Therefore maximal complexity of the encoded circuit which is encoded by vector $e$ of length $n$ is $n / 5$. The sequence of the five mentioned definition variables is ordered as presented in Fig. 4.1a. An example of an analog circuit structure and its corresponding encoding vector $e$ are presented in Fig. 4.1b and Fig. 4.1. respectively.


Fig. 4.1: a) Encoding variables sequence b) example of an analog circuit c) encoding vector of the circuit

Assignment of the values of variable $v_{\text {type }}$ to the used types of the components is summarized in Tab. 4.1.

| component type | inductor | resistor | capacitor |
| :---: | :---: | :---: | :---: |
| $v_{\text {type }}$ | 0 | 1 | 2 |

Tab. 4.1: Values of variable $v_{\text {type }}$ for different types of the components.
Value of every component is calculated as ( $v_{\text {man }} / 128$ ). $v_{\text {mult }}$, where $v_{\text {man }}$ is value of mantissa encoded in the encoding vector $e$ and $v_{\text {mult }}$ is multiplier which is assigned according to $v_{\text {exp }}$ and $v_{\text {type }}$. Value of mantissa is selected from integer numbers in the range $\langle 1,128\rangle$. All possible values of variable $v_{\text {mult }}$ are summarized in Tab. 4.2.

| $v_{\text {exp }}$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $v_{\text {type }}=0$ (inductor) | $10^{0}$ | $10^{-1}$ | $10^{-2}$ | $10^{-3}$ | $10^{-4}$ | $10^{-5}$ | $10^{-6}$ | $10^{-7}$ |
| $v_{\text {type }}=1$ (resistor) | $10^{0}$ | $10^{1}$ | $10^{2}$ | $10^{3}$ | $10^{4}$ | $10^{5}$ | $10^{6}$ | $10^{7}$ |
| $v_{\text {type }}=2$ (capacitor) | $10^{-5}$ | $10^{-6}$ | $10^{-7}$ | $10^{-8}$ | $10^{-9}$ | $10^{-10}$ | $10^{-11}$ | $10^{-12}$ |

Tab. 4.2: Assignment of variable multiplier $v_{\text {mult }}$.
Although only passive components were used in the presented example the method is able to encode various active types of components such as transistors, current conveyors or operational amplifiers.

Direct encoding method is very simple, straightforward and easy to use. On the other hand there are some drawbacks which have to be taken into account in case of using simple genetic algorithm. As was discussed in [24] using direct encoding method and standard recombination operators such as single point crossover, two points crossover or bit-wise mutation usually results in producing high number of low-fitness individuals what is caused by generating of high number of unsimulatable topologies (unconnected components, unconnected branches). There have been presented a number of methods to overcome this problem. For example J. Grimbleby has presented a special type of mutation where the modification of the topology is performed in nondestructive way [13]. Another method is using of developmental encoding method or adjacency matrix representation what will be described in the next sections.

### 4.2 Parse Tree Representation

Genetic programming (GP) is evolutionary algorithm based approach where each individual of the evolved population is a computer program. In terms of evolutionary electronics synthesis every individual is defined as sequence of circuit constructing and circuit modifying instructions. The major research of GP was made by J. Koza et al. [31] [32] [33] 34].

In GP the sequence of the instructions is represented as a parse tree structure where every node defines an operator function and every terminal node defines an operand.

An example of the parse tree representation and corresponding circuit structure are presented in Fig. 4.2 a and Fig. 4.2 b respectively [12]. As can be seen in Fig. 4.2 two types of circuit-constructing instructions are used in the representation. The first function denoted as "+" represents adding of a component in series. The second function denoted as "//" represents adding of a component in parallel.


Fig. 4.2: a) Example of parse tree representation b) encoded circuit.

On the contrary to direct encoding method, parse tree representation is developmental method which means that the circuit is constructed progressively using sequence of circuit construction instructions. The process of the circuit synthesis begins at basic circuit structure called embryonic circuit. Its structure depends on the particular problem. An example of single-input and single-output embryonic circuit which can be used for example for synthesis of frequency filter is presented in Fig. 4.3.


Fig. 4.3: Structure of the embryonic circuit.

Component-creating and connection-modifying functions were introduced in [31]. List of the component-creating functions and the connection-modifying functions which were described in the mentioned paper are presented in Tab. 4.3 and Tab. 4.4 respectively.

| Name | number of arguments | Function |
| :--- | :---: | :---: |
| C | 2 | insert capacitor |
| L | 3 | insert inductor |
| QT0..GT11 | 3 | insert transistor |

Tab. 4.3: Component-creating functions.

| Name | number of arguments | Function |
| :--- | :---: | :---: |
| FLIP | 1 | reversing of polarity |
| SERIES | 3 | insert component in series |
| PSS | 4 | insert component in parallel |
| VIA0..VIA7 | 2 | connect distant parts of the circuit |
| GND | 2 | connect to the ground node |
| NOP | 1 | empty instruction |
| END | 0 | loose its writing head |

Tab. 4.4: Circuit-modifying functions.

The structure of the circuit is developed using writing heads which are pointing to the nodes of current circuit development positions. An example describing two writing heads is presented in Fig. 4.4. The first writing head Z1 points to the wire between nodes 2 and 3 and realizes connection-modifying function FLIP. As can be seen in Tab. 4.4 the function realizes reversion of the polarity of the circuit between two nodes defined by the writing head. The second writing head Z 0 realizes component-creating function C which places capacitor between nodes 3 and 4.


Fig. 4.4: Illustration of the functions FLIP and C.

BJT transistor placement function QT is presented in Fig. 4.5. Based on the context-sensitive subfunction selected from QT0 to QT11 transistor BJT is inserted to the nodes where the highlighted component is connected. After execution of the QT function there will be five new nodes and three new modifiable wires which are defined by writing heads (Z7, Z8, Z9).


Fig. 4.5: Illustration of the function QT.

Another examples of connection-modifying functions presented in 31 are functions SERIES and PSS. Function SERIES places copy of the highlighted component in series to the original component (R1) (Fig. 4.6). After execution of the function SERIES there will be three writing heads which are pointing to the newly created component (R7), the new modifiable wire (Z6) and the original component (R1).


Fig. 4.6: Ilustration of the function SERIES.

The function PSS places newly created component (R7) in parallel to the original highlighted component (R1) (Fig. 4.7). After execution of PSS function there will be four writing heads which are pointing to the original component (R1), newly created component (R7) and two modifiable wires (Z8 and Z6).


Fig. 4.7: Illustration of the function PSS.

For description of the other component-creating and connection-modifying functions or more detailed description of the parse tree approach please refer to [31] 32] [33] (34].

### 4.3 Linear Representation

Linear representation is another example of developmental encoding method. The approach was introduced by J. Lohn and S. Colombano in [15]. Sequences of instructions (called OPCODEs) are encoded into encoding vectors consisting of integer numbers. Compared to the direct encoding method where the order of the components encoding 5 -tuples is not important in linear representation it strongly affects the whole structure of the resulting circuit.

Every component is encoded using four integer numbers. The first one is OPCODE and the next three numbers define the value of the component. The list of OPCODEs as was presented in [15] is summarized in Tab. 4.5.

| Opcode | Destination Node | CN Register |
| :--- | :---: | ---: |
| x-move-to-new | newly-created node | newly-created node |
| x-cast-to-previous | previous node | unchanged |
| x-cast-to-ground | ground node | unchanged |
| x-cast-to-input | input node | unchanged |
| x-cast-to-output | output node | unchanged |

Tab. 4.5: Summary of OPCODEs used in developmental encoding method.

Similarly to the parse tree representation method, the process of circuit synthesis begins at the basic embryonic circuit which is presented in Fig. 4.8.


Fig. 4.8: Structure of the basic embryonic circuit.

The circuit synthesis starts from node 1 and continues according to the decoded sequence of OPCODEs until the output node (finish node) is reached or another termination criterion as maximal number of the decoded components is met. An example of sequence of OPCODEs and corresponding circuit are presented in Fig. 4.9 and Fig. 4.10 respectively.

| C_MOVE_TO_NEW C 1210837006 | L_CAST_TO_PREV L 7610259 |
| :---: | :---: |
| C_MOVE_TO_NEW C 233547581 | C_CAST_TO_PREV C 7610161281 |
| C_CAST_TO_PREV C 329862769 | L_CAST_TO_INPUT L 172452274 |
| L_CAST_TO_PREV L 326880711 | C_CAST_TO_PREV C 762457158 |
| L_CAST_TO_INPUT L 137668359 | L_CAST_TO_INPUT L 1715284140 |
| R_CAST_TO_PREV R 3210844497 | L_CAST_TO_PREV L 761272684 |
| L_CAST_TO_INPUT L 136794434 | R_MOVE_TO_NEW L 7811316166 |
| L_CAST_TO_INPUT L 1310915194 | C_CAST_TO_GND C 0824495 |
| L_CAST_TO_INPUT L 1310360067 | L_CAST_TO_PREV L 8715793607 |
| L_CAST_TO_PREV L 3253267 | L_CAST_TO_INPUT L 183300694 |
| L_MOVE_TO_NEW L 347713100 | L_MOVE_TO_NEW L 895376858 |
| C_MOVE_TO_NEW C 453568044 | C_CAST_TO_GND C 0925063 |
| C_MOVE_TO_NEW C 568573596 | L_CAST_TO_PREV L 984863538 |
| C_CAST_TO_GND C 0610481 | L_MOVE_TO_NEW L 9104364222 |
| L_CAST_TO_INPUT L 1610897482 | C_CAST_TO_GND C 01012564 |
| L_CAST_TO_INPUT L 162462113 | L_CAST_TO_PREV L 1094489818 |
| R_MOVE_TO_NEW R 6712757499 |  |

Fig. 4.9: Example of sequence of OPCODEs.


Fig. 4.10: Corresponding encoded circuit.

During the synthesis process register CN is used to store the number of the last created node. The principle of the circuit structure synthesis will be demonstrated for the first six instructions presented in Fig. 4.9.

1. C_MOVE_TO_NEW C 1210837006

Capacitor is placed between starting node 1 and newly created node 2. Number 2 is stored in CN register.
2. C_MOVE_TO_NEW C 233547581

Capacitor is placed between node 2 and newly created node 3 . Number 3 is stored in CN register.
3. C_CAST_TO_PREV C 32982769

Capacitor is placed between node in CN (node 3) and previously created node (node 2). CN register unchanged.
4. L_CAST_TO_PREV L 326880711

Inductor is placed between node in CN (node 3) and previously created node (node 2). CN register unchanged.
5. L_CAST_TO_INPUT L 137668359

Inductor is placed between node in CN (node 3) and input (node 1). CN register unchanged.
6. R_CAST_TO_PREV R 3210844497

Resistor is placed between node in CN (node 3) and previously created node (node 2). CN register unchanged.

The motivation of development of linear representation encoding method is demand to overcome problems with high number of unsimulatable circuits produced by crossover of genetic algorithm in which direct encoding method is used. The proposed method is designed to construct closed analog circuit topologies what prevents generating a circuit topologies with dangling terminals or unconnected components. On the other hand using linear representation method can in some cases restrict circuit topologies which can be encoded [15].

### 4.4 Adjacency Matrix Representation

Adjacency Matrix representation was proposed by A. Mesquita in [24]. The approach was developed to overcome some problems of other analog circuits encoding methods and to simplify the evolution process.

Let $G_{a}=\left(V_{a}, E_{a}\right)$ be a directed graph with no parallel edges, $V_{a}$ is set of vertices defined as $V_{a}=\left\{v_{1}, v_{2}, \ldots, v_{n}\right\}$ and $E_{a}$ is set of edges defined as $E_{a}=\left\{e_{1}, e_{2}, \ldots, e_{n}\right\}$. Then the adjacency matrix $M_{a}=\left[m_{i j}\right]$ of graph $G_{a}$ is defined as n x n matrix, where $m_{i j}$ is defined as:

$$
m_{i j}= \begin{cases}1, & \text { if }\left(v_{i}, v_{j}\right) \in E_{a} \\ 0, & \text { otherwise }\end{cases}
$$

In Fig. 4.11 there is an example of generic floating graph with self-loops and its corresponding adjacency matrix [24].


Fig. 4.11: Example of generic floating graph with self-loops $G_{a}$ and its corresponding adjacency matrix $M_{a}$.

In the domain of analog circuits topologies the self-loops can be discarded. Also the ground nodes are redundant in the adjacency matrix. Then modified directed graph $G_{a}^{\prime}=\left(V_{a}^{\prime}, E_{a}^{\prime}\right)$ and reduced adjacency matrix $M_{a}^{\prime}$ are defined. Example of graph representation of an analog circuit $G_{a}^{\prime}$ and corresponding reduced adjacency matrix $M_{a}^{\prime}$ are presented in Fig 4.12. Vertex $v_{0}$ of the modified graph $G_{a}^{\prime}$ represents the ground node of the circuit.


$$
M_{a}^{\prime}=\begin{gather*}
v_{1}  \tag{4.2}\\
v_{2} \\
v_{3}
\end{gather*}\left[\begin{array}{ccc}
v_{1} & v_{2} & v_{3} \\
1 & 1 & 1 \\
1 & 1 & 1 \\
0 & 0 & 1
\end{array}\right]
$$

Fig. 4.12: Example of graph representation of analog circuit topology $G_{a}^{\prime}$ and its corresponding reduced adjacency matrix $M_{a}^{\prime}$.

In the given example adjacencies to the ground node $v_{0}$ are represented by diagonal branches $e_{1}, e_{2}, e_{3}$. Parallel branches $e_{4}$ and $e_{6}$ represent two parallel components in the corresponding analog circuit.

For the purpose of evolutionary electronics system which employs genetic algorithm the adjacency matrix is transformed to sequence its rows. This way binary chromosome representation of the reduced adjacency matrix is formed.

In [24] special type of crossover (cascading of chromosomes) was proposed. It was demonstrated that using incidence matrix representation together with classical GA crossover results in construction of invalid graph topologies. On the contrary to the classical GA crossover the proposed method cascades the parent circuits through a subset of nodes in a meaningful way. This way topologies of both of the parental circuits are preserved.

As was discussed in [24] the proposed encoding method overperforms simple direct encoding method (incidence matrix representation) in terms of generation of low number of unsimulatable individuals after performing of GA crossover. Paper [24] also discusses another issues of the proposed methods such as employing of variable size chromosomes or generating of anomalous circuits.

## 5 AUTONOMOUS CIRCUITS, GRAPHS AND ENCODING METHODS

Autonomous circuits theory employs fully connected admittance networks which can be used for obtaining of new structures of analog circuits such as filters or oscillators [36]. There is direct relation between autonomous circuits and corresponding fully connected graphs. Autonomous circuits are described in section 5.1 .

The main principle of the proposed automated analog circuits synthesis method is to utilize autonomous circuits idea in connection with Estimation of Distribution Algorithm. This way hand design using autonomous circuits theory as was presented in [36] will be replaced by probabilistic modeling of the promising circuit structures. Using powerful computation and probabilistic modeling approach allow to explore extensive solution space of large number of different combinations of suitable topologies of analog circuits.

Choosing of suitable encoding method is one of the key aspects of every evolutionary algorithm system. The most straightforward method of representation of the topology of analog circuit is graph. Detailed study of graph representations of the topologies of analog circuits can be found in [35]. Graph representations of the topologies of analog circuits with regard to using Estimation of Distribution Algorithms are presented in section 5.3 .

Section 5.4 describes analog circuit design problem as problem of searching of subgraph. Design of passive, active and mixed passive/active circuits are discussed in the section.

Section 5.5 is focused on encoding methods of the topology of passive, active and mixed passive/active analog circuits. The proposed methods are designed with regard to usage of Estimation of Distribution Algorithms.

With respect to the encoding methods proposed in section 5.5 the problem of analog circuit synthesis has to be viewed as a problem with unitation constraints. This issue is discussed in section 5.6.

### 5.1 Autonomous Circuits

Autonomous circuits theory was described in [36]. The paper is also focused on employing of the theory for the purpose of obtaining new topologies of passive and active analog circuits.

Autonomous circuit (AC) can be formed of network of only passive components or combination of passive and active components (OTA, operational amplifier, cur-
rent conveyor, current mirror). In the thesis autonomous circuit is defined as presented bellow.

Given number of nodes $n_{n}$, autonomous circuit is defined as fully connected network of $n_{p}$ ports generalized admittances, where $n_{p}$ ports generalized admittances are connected between all possible combinations of the nodes. A $n_{p}$ ports generalized admittance is component of $n_{p}$ ports with no defined type. It can be replaced by any component of $n_{p}$ ports or theirs parallel combination. Autonomous circuit with $n_{n}$ nodes and with $n_{p}$ ports generalized admittances is denoted as $n_{p} \mathrm{AC} n_{n}$.

Number of $n_{p}$ ports generalized admittances of autonomous circuit with complexity $n_{n}$ nodes can calculated according to 5.1.

$$
\begin{equation*}
n_{a d m}=\binom{n_{n}}{n_{p}}=\frac{n_{n}!}{n_{p}!\left(n_{n}-n_{p}\right)!} \tag{5.1}
\end{equation*}
$$

Autonomous circuit for $n_{n}=5$ (nodes 0 to 4 ) consisting of 2 ports generalized admittances $\left(n_{p}=2\right)$ is presented in Fig. 5.1. According to the denotation presented above the autonomous circuit is denoted as 2AC5. The autonomous circuit contains ten 2 ports generalized admittances (see (5.1)).


Fig. 5.1: Autonomous circuit 2AC5.

Assignment of the 2 ports generalized admittances to the nodes of AC is presented in Tab. 5.1. Later this assignment will be used in definition of binary encoding vector of the circuit topology.

| generalized admittance | $Y_{1}$ | $Y_{2}$ | $Y_{3}$ | $Y_{4}$ | $Y_{5}$ | $Y_{6}$ | $Y_{7}$ | $Y_{8}$ | $Y_{9}$ | $Y_{10}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| node 1 | $n_{0}$ | $n_{0}$ | $n_{0}$ | $n_{0}$ | $n_{1}$ | $n_{1}$ | $n_{1}$ | $n_{2}$ | $n_{2}$ | $n_{3}$ |
| node 2 | $n_{1}$ | $n_{2}$ | $n_{3}$ | $n_{4}$ | $n_{2}$ | $n_{3}$ | $n_{4}$ | $n_{3}$ | $n_{4}$ | $n_{4}$ |

Tab. 5.1: Assignment of the generalized admittances to nodes of 2AC5.

Autonomous circuit for $n_{n}=4$ consisting of 3 ports generalized admittances $\left(n_{p}=3\right)$ is presented in Fig. 5.2. The autonomous circuit is denoted as 3AC4 and contains four 3 ports generalized admittances.


Fig. 5.2: Autonomous circuit 3AC4.

Assignment of the 3 ports generalized admittances to the nodes of AC is presented in Tab. 5.2,

| generalized admittance | $Y_{1}$ | $Y_{2}$ | $Y_{3}$ | $Y_{4}$ |
| :---: | :---: | :---: | :---: | :---: |
| node 1 | $n_{1}$ | $n_{1}$ | $n_{1}$ | $n_{2}$ |
| node 2 | $n_{2}$ | $n_{2}$ | $n_{3}$ | $n_{3}$ |
| node 3 | $n_{3}$ | $n_{4}$ | $n_{4}$ | $n_{4}$ |

Tab. 5.2: Assignment of the generalized admittances to nodes of 3AC4.
Autonomous circuit with 3 ports generalized admittances enables using of 3 ports active components. Every single 3 ports generalized admittance of autonomous circuit in Fig. 5.2 can be replaced by defined type of 3 ports transistor (NPN, PNP, NMOS, PMOS, etc.).

### 5.2 Autonomous Circuits and Circuit Design

The autonomous circuits design method can be used for synthesis of different types of analog circuit applications as frequency filters or oscillators. In [37] autonomous circuits method was used for obtaining new biquad filters using two CFOA blocks. Study of general three ports current conveyors (GCC) utilizing autonomous circuits theory was presented in [38]. Filters and oscillators design based on autonomous circuits representation of generalized multi-port current conveyors was presented in [39.

In the text bellow design of passive analog circuits based on application of autonomous circuits as was presented in [36] will be discussed. Since the desired analog circuit is of passive type 2 ports generalized admittances ( $n_{p}=2$ ) are used.

Complexity of the used autonomous circuit $\left(n_{n}\right)$ is user defined parameter and its selection is based on the target application of the designed circuit. For example if the target application of the designed circuit is frequency filter, the complexity of the autonomous circuit can be determined based on the order of the filter. Also previous experience of the designer is helpful during this phase. For the demonstration purpose autonomous circuit with complexity $n_{n}=5$ is chosen. Its schematics is presented in Fig. 5.3.


Fig. 5.3: Autonomous circuit with 2 ports generalized admittances and complexity $n_{n}=5$.

Design of passive analog circuit using autonomous circuits consists of few steps as will be described bellow.

STEP1: 2 ports generalized admittances are manually replaced by real passive components, theirs parallel combination, or open circuit. The replacement is performed randomly or based on some initial requirements (all capacitors grounded). Also
previous experience of the designer or intuition is incorporated in the process. An example of such replacement is presented in Fig 5.4. The replacement of the components is summarized in Tab 5.3.


Fig. 5.4: Replacement of the generalized admittances by real components.

| General admittance | $Y_{1}$ | $Y_{2}$ | $Y_{3}$ | $Y_{4}$ | $Y_{5}$ | $Y_{6}$ | $Y_{7}$ | $Y_{8}$ | $Y_{9}$ | $Y_{10}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | ---: |
| node 1 | $n_{0}$ | $n_{0}$ | $n_{0}$ | $n_{0}$ | $n_{1}$ | $n_{1}$ | $n_{1}$ | $n_{2}$ | $n_{2}$ | $n_{3}$ |
| node 2 | $n_{1}$ | $n_{2}$ | $n_{3}$ | $n_{4}$ | $n_{2}$ | $n_{3}$ | $n_{4}$ | $n_{3}$ | $n_{4}$ | $n_{4}$ |
| replacement | open | $L_{2}$ | open | $R_{4}$ | $R_{5} \\| C_{5}$ | open | $R_{7}$ | $R_{8}$ | $L_{9}$ | $C_{10}$ |

Tab. 5.3: Replacement of the generalized admittances by real components.

STEP2: After obtaining of a new structure of analog circuit (Fig. 5.4) characteristic equation in symbolic form is obtained. For different input and output connection nodes various impedance and transfer functions can be obtained. Selection of input and output nodes is determined by desired function of the designed analog circuit.

STEP3: For selected configuration of input and output nodes and resulting impedance or transfer function values of the components are calculated.

### 5.3 Graph Representations of Analog Circuits

### 5.3.1 Simple Graph Representation

Let's define simple parametrized undirected graph $G_{s}=\left(V_{s}, E_{s}, Q_{s}\right)$, where $V_{s}=$ $\left\{v_{0}, v_{1}, \ldots, v_{4}\right\}$ is set of vertices, $E_{s}=\left\{e_{1}, e_{2}, \ldots, e_{5}\right\}$ is set of parametrized edges and $Q_{s}=\left\{q_{1}, q_{2}, \ldots, q_{5}\right\}$ is set of parameters of edges $E_{s}$. An example of graph $G_{s}$ is presented in Fig. 5.5 a . Numbers in the brackets behind the names of the edges denote parameters of the edges. Analog circuit $C_{s}$ corresponding to graph $G_{s}$ is presented in Fig. 5.5b. Branches of circuit $C_{s}$ correspond to parametrized edges of set $E_{s}$. Set of nodes $N_{s}=\left\{n_{0}, n_{1}, \ldots, n_{4}\right\}$ of circuit $C_{s}$ corresponds to set of vertices $V_{s}$.

(a

(b

Fig. 5.5: a) Graph $G_{s}$ b) Analog circuit $C_{s}$.
Since simple graph does not allow to use multiple edges (representation of parallel connection of the components), the configuration of the used components is represented as parameters of the edges of the simple graph. All possible parameters of the edges representing the combination of the passive components are summarized in Tab. 5.4

| edge parameter | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| configuration of components | $L$ | $R$ | $C$ | $L \\| R$ | $L \\| C$ | $R \\| C$ | $L\\|R\\| C$ |

Tab. 5.4: Parameters of the edges and corresponding configurations of components.

Parameters in set $Q_{s}$ define configuration of the components for the corresponding edges. For example edge $e_{3}$ is connected between vertices $v_{4}$ and $v_{0}$ and its parameter is $q_{3}=4$. Therefore according to Tab. 5.4 corresponding configuration of the components connected between nodes $n_{4}$ and $n_{0}$ is parallel combination of inductor and resistor ( $L_{3} \| R_{2}$ ).

### 5.3.2 Multigraph Representation

Let's define undirected labeled multigraph $G_{m}=\left(V_{m}, E_{m}, Q_{m}\right)$, where $V_{m}=\left\{v_{0}\right.$, $\left.v_{1}, \ldots, v_{4}\right\}$ is set of vertices, $E_{m}=\left\{e_{1}, e_{2}, \ldots, e_{7}\right\}$ is set of labeled edges and $Q_{m}=\left\{q_{1}, q_{2}, \ldots, q_{7}\right\}$ is set of labels of edges $E_{m}$. Self loops are not allowed. Three multiple edges between two vertices are allowed at the most. An example of graph $G_{m}$ is presented in Fig. 5.6a. Numbers in the brackets behind the names of the edges denote the labels of the edges. Analog circuit $C_{m}$ corresponding to graph $G_{m}$ is presented in Fig. 5.6b. Branches of circuit $C_{m}$ correspond to labeled edges $E_{m}$. Set of nodes $N_{m}=\left\{n_{0}, n_{1}, \ldots, n_{4}\right\}$ of circuit $C_{m}$ corresponds to set of vertices $V_{m}$. Labels $Q_{m}$ of edges $E_{m}$ define selection of the passive components for the corresponding edges. For example edge $e_{6}$ is connected between vertices $v_{3}$ and $v_{0}$ and its label is $q_{6}=1$. Therefore according to Tab. 5.5 corresponding passive component connected between nodes $n_{3}$ and $n_{0}$ is inductor $\left(L_{2}\right)$.


Fig. 5.6: a) Multigraph $G_{m} \mathrm{~b}$ ) analog circuit $C_{m}$.

Compared to simple graph representation every component of analog circuit $C_{m}$ is represented by single edge of multigraph $G_{m}$. All possible values of the labels of the edges representing selection of the passive components are summarized in Tab. 5.5

| edge label | 1 | 2 | 3 |
| :---: | :---: | :---: | :---: |
| selected component | L | R | C |

Tab. 5.5: Labels of the edges and corresponding selection of the component.

### 5.3.3 3-Uniform Labeled Hypergraph Representation

Compared to simple graph and multigraph representations described above, labeled hypergraphs allow to encode components with more than 2 ports. An example of 3uniform labeled hypergraph which allows to encode 3 ports components (transistors) is presented in the section.

Let's define 3 -uniform labeled hypergraph $G_{h}=\left(V_{h}, E_{h}, Q_{h}\right)$, where $V_{h}=\left\{v_{1}\right.$, $\left.v_{2}, \ldots, v_{6}\right\}$ is set of vertices, $E_{h}=\left\{e_{1}, e_{2}\right\}$ is set of labeled hyperedges and $Q_{h}=$ $\left\{q_{1}, q_{2}\right\}$ is set of labels of hyperedges of set $E_{h}$. An example of hypergraph $G_{h}$ is presented in Fig. 5.7a. Numbers in the brackets behind the names of the hyperedges denote the labels of the hyperedges. Analog circuit $C_{h}$ corresponding to graph $G_{h}$ is presented in Fig. 5.7b. Labeled hyperedges of set $E_{h}$ correspond to the transistors of analog circuit $C_{h}$ where the labels of the hyperedges define "rotations" of the transistors (Tab. 5.6). Set of vertices $V_{h}$ correspond to set of nodes $N_{h}=\left\{n_{1}, n_{2}\right.$, $\left.\ldots, n_{6}\right\}$ of analog circuit $C_{h}$. For example hyperedge $e_{1}$ is connected to vertices $v_{1}$, $v_{2}$ and $v_{3}$. Label of hyperedge $e_{1}$ is set to 3 what corresponds to transistor (Q1) connected as $n_{1}-\mathrm{C}, n_{2}-\mathrm{B}$ and $n_{3}-\mathrm{E}$ (Tab. 5.6). Similarly hyperedge $e_{2}$ represents transistor $Q 2$.


Fig. 5.7: a) 3-uniform labeled hypergraph $G_{h}$ b) Analog circuit $C_{h}$.

Summary of the labels of the hyperedges and corresponding "rotations" of the transistors is presented in Tab. 5.6.

| hyperedge label | 1 | 2 | 3 | 4 | 5 | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| node 1 | B | B | C | C | E | E |
| node 2 | C | E | B | E | B | C |
| node 3 | E | C | E | B | C | B |

Tab. 5.6: Labels of the hyperedges and corresponding "rotations" of the transistors.

### 5.4 Evolutionary Analog Circuits Design as a Problem of Searching of a Subgraph

### 5.4.1 Passive Circuits

Let's define complete graph $G_{c p}=\left(V_{c p}, E_{c p}\right)$, where $V_{c p}=\left\{v_{0}, v_{1}, \ldots, v_{3}\right\}$ is set of vertices and $E_{c p}=\left\{e_{1}, e_{2}, \ldots, e_{6}\right\}$ is set of edges. Analog circuit corresponding to complete graph $G_{c p}$ is AC with 2 ports generalized admittances and $n_{n}=4$ denoted as 2AC4. Edges of set $E_{c p}$ correspond to generalized admittances of autonomous circuit 2AC4. Vertices of set $V_{c p}$ correspond to set of nodes $N_{p}=\left(n_{1}, n_{2}, \ldots, n_{4}\right)$ of circuit 2AC4. Complete graph $G_{c p}$ and autonomous circuit 2AC4 are presented in Fig. 5.8.

a)

b)

Fig. 5.8: a) Complete graph $G_{c p}$ b) circuit 2AC4 corresponding to $G_{c p}$.

Now let's define passive analog circuit topology synthesis problem as problem of searching of a subgraph.

As was described in section 5.1 every 2 ports generalized admittance $Y_{x}$ can be replaced by resistor, capacitor, inductor or theirs parallel combination. Therefore maximal combination of the components which can be used as a replacement of 2 ports generalized admittance $Y_{x}$ is parallel combination of resistor, capacitor and inductor.

Every edge $e_{x}$ of complete graph $G_{c p}$ is replaced by triplet of edges $e_{x}(1), e_{x}(2), e_{x}(3)$ what corresponds to parallel connection of passive components inductor, resistor and capacitor (section 5.3.2). This way graph $G_{c p}$ is expanded to graph $G_{c p e}$ (Fig. 5.9).

Now analog circuit $C_{e}$ corresponding to expanded graph $G_{c p e}$ will be obtained. Every generalized admittance of autonomous circuit 2 AC 4 will be replaced by parallel combination of resistor, capacitor and inductor. This way autonomous circuit 2 AC 4 is expanded to circuit $C_{e}$. Analog circuit $C_{e}$ corresponding to expanded graph $G_{\text {cpe }}$ is presented in Fig. 5.10. Note that circuit $C_{e}$ is maximal circuit which can be
obtained for 4 nodes and passive components RLC. Every possible passive analog circuit with complexity 4 nodes or less consisting of RLC components can be derived from circuit $C_{e}$ by replacing its components with open circuits or short circuits.


Fig. 5.9: Graph $G_{c p e}$ (obtained by expansion of graph $G_{c p}$ ).


Fig. 5.10: Analog circuit $C_{e}$ corresponding to expanded graph $G_{\text {cpe }}$.

Now the problem of the synthesis of a passive analog circuit topology can be defined as searching for a subgraph $G_{p}$ on graph $G_{\text {cpe }}$ what corresponds to selection of a subcircuit $C_{p}$ of circuit $C_{e}$. Example of subgraph $G_{p}$ and corresponding analog circuit $C_{p}$ are presented in Fig. 5.11.

c)

d)

Fig. 5.11: a) Example of subgraph $G_{p}$ b) Analog circuit $C_{p}$ corresponding to subgraph $G_{p}$.

### 5.4.2 Transistor Circuits

Let's define complete 3-uniform hypergraph $G_{c t}=\left(V_{c t}, E_{c t}\right)$, where $V_{c t}=\left\{v_{1}, v_{2}\right.$, $\left.v_{3}, v_{4}\right\}$ is set of vertices and $E_{c t}=\left\{e_{1}, e_{2}, e_{3}, e_{4}\right\}$ is set of hyperedges. Analog circuit corresponding to complete hypergraph $G_{c t}$ is AC with 3 ports generalized admittances and $n_{n}=4$ denoted as 3 AC 4 . Every single hyperedge of hypergraph $G_{c t}$ corresponds to a single generalized admittance of circuit 3AC4. Hypergraph $G_{c t}$ and circuit 3 AC 4 are presented in Fig. 5.12.


Fig. 5.12: a) Complete 3-uniform hypergraph $G_{c t}$ b) circuit 3AC4 corresponding to $G_{c t}$.

There are six possible combinations of connection of 3 ports generalized admittance $Y_{x}$ (admittances $Y_{1}$ to $Y_{4}$ in Fig. 5.12b) to three nodes. These connections are denoted as "rotations" (Tab. 5.6).

The problem of synthesis of the topology of connection of analog circuit consisting of transistors can be defined as searching for a subhypergraph $G_{t}$ on complete hypergraph $G_{c t}$ and definition of the labels of the hyperedges of subhypergraph $G_{t}$ which define "rotations" of the transistors.

Example of labeled subhypergraph $G_{t}$ is presented in Fig. 5.13a. Numbers in the brackets behind the names of the hyperedges define the labels of the hyperedges (Tab. 5.6). Circuit $C_{t}$ corresponding to $G_{t}$ is presented in Fig. 5.13b.

a)

b)

Fig. 5.13: a) Example of subgraph $G_{t}$ on complete 3-uniform hypergraph $G_{c t}$ b) analog circuit $C_{t}$ corresponding to $G_{t}$.

### 5.4.3 Mixed Type Circuits

Representation of circuits of mixed type $C_{m t}$ (circuit including transistors and passive components) is separated into two subcircuits $C_{p a s}$ and $C_{a c t}$. Subcircuit $C_{p a s}$ is formed of passive part of circuit $C_{m t}$ (passive components) and subcircuit $C_{a c t}$ is formed of active part of circuit $C_{m t}$ (transistors). The passive part is defined by graph $G_{p a s}$ and it is represented as was described in section 5.4.1. The active part of the mixed circuit is defined by hypergraph $G_{\text {act }}$ and it is represented as was described in section 5.4.2. An example of graph $G_{p a s}$ and corresponding analog circuit $C_{p a s}$ are presented in Fig. 5.14. An example of hypergraph $G_{a c t}$ and corresponding analog circuit $C_{\text {act }}$ are presented in Fig. 5.15.

After combination of both parts represented by graph $G_{p a s}$ and hypergraph $G_{a c t}$ mixed type circuit in Fig. 5.16 is obtained.


Fig. 5.14: a) Example of passive part graph $G_{p a s} \mathrm{~b}$ ) analog circuit $C_{\text {pas }}$ corresponding to graph $G_{p a s}$.

c)

d)

Fig. 5.15: a) Example of active part graph $G_{\text {act }}$ b) analog circuit $C_{\text {act }}$ corresponding to graph $G_{\text {act }}$.


Fig. 5.16: Analog circuit of mixed type $C_{m t}$ consisting of passive part circuit $C_{p a s}$ and active part circuit $C_{a c t}$.

### 5.5 Encoding of Graph Representations of Analog Circuits

### 5.5.1 Characteristic Vector of Simple Graph

Every simple graph $G_{s}$ with $n_{n}$ vertices can be encoded by binary vector $e_{s}$ of length $n_{s c}$, where $n_{s c}$ is number of edges of complete graph $G_{s c}$ of order $n_{n}$ vertices. Size $n_{s c}$ of $G_{s c}$ can be computed as $n_{s}=n_{n}\left(n_{n}-1\right) / 2$. Vector $e_{s}$ is called characteristic vector of graph $G_{s}$. Every single bit of $e_{s}$ represents including or not including of the corresponding edge in graph $G_{s}$. If characteristic vector $e_{s}(i)=1$ for $i \in\left\{1,2, \ldots n_{s}\right\}$ then vector $e_{s}$ encodes complete graph $G_{s c}$. Examples of simple graphs and theirs characteristic vectors for $n_{n}=3\left(G_{s 1}\right)$ and $n_{n}=4\left(G_{s 2}\right)$ are presented in Fig. 5.17a and Fig. 5.17b respectively. Assignment of the edges to the combinations of the vertices is presented in Tab. 5.7.

a)


$$
\begin{gathered}
e_{1} \\
e_{2}
\end{gathered} e_{3} e_{4} e_{5} e_{6} .
$$

b)

Fig. 5.17: a) Example of simple graph for $n_{n}=3$ and its characteristic vector $e_{s 1} \mathrm{~b}$ ) example of simple graph for $n_{n}=4$ and its characteristic vector $e_{s 2}$.

| graph $G_{s 1}$ |  |  |  |
| :---: | :---: | :---: | :---: |
| vertice 1 | $v_{0}$ | $v_{0}$ | $v_{1}$ |
| vertice 2 | $v_{1}$ | $v_{2}$ | $v_{2}$ |
| edge | $e_{1}$ | $e_{2}$ | $e_{3}$ |


| graph $G_{s 2}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| vertice 1 | $v_{0}$ | $v_{0}$ | $v_{0}$ | $v_{1}$ | $v_{1}$ | $v_{2}$ |
| vertice 2 | $v_{1}$ | $v_{2}$ | $v_{3}$ | $v_{2}$ | $v_{3}$ | $v_{3}$ |
| edge | $e_{1}$ | $e_{2}$ | $e_{3}$ | $e_{4}$ | $e_{5}$ | $e_{6}$ |

Tab. 5.7: Assignment of the edges to the combinations of the vertices for simple graphs $G_{s 1}$ and $G_{s 2}$.

### 5.5.2 Characteristic Vector of Multigraph

Since multigraphs allow using multiple edges between two vertices the definition of the characteristic vector which was presented in the previous section has to be modified. Let's define multigraph $G_{m}$ with $n_{n}$ vertices in which $n_{m}$ multiple edges are allowed at the most. Selfloops are not allowed. Then multigraph $G_{m}$ can be encoded using binary characteristic vector $e_{m}$ of length $n_{m} n_{e c}$, where $n_{e c}$ is number of edges of complete graph $G_{c}$ of order $n_{n}$.

An example of multigraph $G_{m}$ with 4 vertices $\left(n_{n}=4\right)$ and three multiple edges at the most $\left(n_{m}=3\right)$ is presented in Fig. 5.18 a. Its characteristic vector $e_{m}$ is presented in Fig. 5.18b. As can be seen in Fig. 5.18b characteristic vector $e_{m}$ consists of six triplets of bits, where every single triplet corresponds to one combination of the vertices. Assignment of the edges to the combinations of the vertices is presented in Tab. 5.8.

a)

$$
\begin{array}{lllllllllllllllllll}
1 & 2 & & 1 & 2 & 3 & 1 & 2 & 3 & 1 & 2 & 3 & 1 & 2 & 3 & 1 & 2 & 3 \\
1
\end{array} \quad\left[\begin{array}{llllllllllllllll}
1 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 0 & 1 & 0
\end{array}\right]
$$

b)

Fig. 5.18: a) Mutigraph $G_{m}$ with 4 vertices b) characteristic vector $e_{m}$ of multigraph $G_{m}$.

| vertice 1 | $v_{1}$ | $v_{1}$ | $v_{1}$ | $v_{2}$ | $v_{2}$ | $v_{3}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| vertice 2 | $v_{2}$ | $v_{3}$ | $v_{4}$ | $v_{3}$ | $v_{4}$ | $v_{4}$ |
| edge | $e_{1 x}$ | $e_{2 x}$ | $e_{3 x}$ | $e_{4 x}$ | $e_{5 x}$ | $e_{6 x}$ |

Tab. 5.8: Assignment of the edges to the combinations of the vertices.

### 5.5.3 Encoding of Passive Analog Circuits

Topology of passive analog circuit is represented by graph $G_{p}$ which is subgraph of complete expanded graph $G_{\text {cpe }}$ (section 5.4.1). Examples of $G_{c p e}$ and $G_{p}$ are given in Fig. 5.9 and Fig. 5.11a respectively.

As was stated in section 5.4.1 graph $G_{p}$ is always subgraph of complete expanded graph $G_{\text {cpe }}$. Circuit corresponding to graph $G_{\text {cpe }}$ is the maximal circuit which can
be obtained (for given $n_{n}$ nodes). Therefore $G_{\text {cpe }}$ is the maximal graph which the encoding method has to be able to encode.

Encoding vector of graph $G_{p}$ can be defined as binary vector $e_{p}$ of length $n_{\text {edgcpe }}$, where $n_{\text {edgcpe }}$ is number of edges of expanded complete graph $G_{\text {cpe }}$ and can be calculated according to (5.2)

$$
\begin{equation*}
n_{\text {edgcpe }}=\frac{n_{m} n_{n}\left(n_{n}-1\right)}{2} \tag{5.2}
\end{equation*}
$$

, where $n_{m}$ is maximal number of multiple edges of multigraph $G_{p}$ what corresponds to maximal number of components of different type which can be connected in parallel. Typically for passive analog circuits there are three types of components (resistor, capacitor, inductor). Therefore $n_{m}=3$. (section 5.4.1).

Every single bit of vector $e_{p}$ denotes including or not including of the corresponding edge of expanded complete graph $G_{\text {cpe }}$ in its subgraph $G_{p}$. Encoding vector $e_{p}$ of graph $G_{p}$ presented in Fig. 5.11a is presented in Fig. 5.19.

$$
\left.\begin{array}{l}
\frac{e_{1}}{\text { L R C L R C L R C L R C L R C L R C }} \frac{e_{2}}{} \\
e_{p}=\left[\begin{array}{llllllllllllllll}
0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0
\end{array}\right] \\
e_{3}
\end{array}\right]
$$

Fig. 5.19: Encoding vector $e_{p}$ of graph $G_{p}$ in Fig. 5.11a

### 5.5.4 Characteristic Vector of 3-Uniform Hypergraph

Every 3-uniform hypergraph $G_{h}$ of order $n_{n}$ can be encoded by binary vector $e_{h}$ of length $n_{e}$, where $n_{e}$ is size of complete 3 -uniform hypergraph $G_{h c}$ of order $n_{n}$. Size $n_{e}$ of complete 3-uniform hypergraph $G_{h c}$ can be calculated as $n_{e}=n_{n}\left(n_{n}-1\right)\left(n_{n}-2\right) / 3$.

Every single bit of $e_{h}$ represents including or not including of the corresponding hyperedge of hypergraph $G_{h}$. If characteristic vector $e_{h}(i)=1$ for $i \in\left\{1,2, \ldots n_{e}\right\}$ then vector $e_{h}$ encodes complete 3-uniform hypergraph $G_{h c}$.

Two examples of 3 -uniform hypergraphs for $n_{n}=4$ and theirs characteristic vectors are presented in Fig. 5.20. Assignment of the hyperedges to the combinations of the vertices is presented in Tab. 5.9.

| hyperedge | $e_{1}$ | $e_{2}$ | $e_{3}$ | $e_{4}$ |
| :---: | :---: | :---: | :---: | :---: |
| vertices | $v_{1}, v_{2}, v_{3}$ | $v_{1}, v_{2}, v_{4}$ | $v_{1}, v_{3}, v_{4}$ | $v_{2}, v_{3}, v_{4}$ |

Tab. 5.9: Assignment of the hyperedges to the vertices.


$e_{1} \quad e_{2} \quad e_{3} \quad e_{4}$

$$
e_{h 2}=\left[\begin{array}{llll}
1 & 1 & 1 & 1
\end{array}\right]
$$

Fig. 5.20: Two examples of 3 -uniform hypergraphs for $n_{n}=4$ and theirs characteristic vectors.

### 5.5.5 Characteristic Vector of 3-Uniform Labeled Hypergraph

As was described in the previous section connection of three ports components can be defined using 3 -uniform hypergraphs. Assuming three ports transistor there are six possible combinations of connection of the transistor to three nodes. These combinations are called "rotations" of the transistor in this thesis and are represented as labels of hyperedges. Label of every hyperedge can be set to numbers 1 to 6 .

To include information about "rotation" characteristic vector of 3-uniform hypergraph which was defined in the previous section has to be modified. Labeled 3 -uniform hypergraph $G_{h l}$ of order $n_{n}$ can be encoded by binary vector $e_{h l}$ of length $n_{h l}$, where $n_{h l}=n_{n}\left(n_{n}-1\right)\left(n_{n}-2\right)$. Example of labeled 3-uniform hypergraph and its encoding vector $e_{h l}$ are presented in Fig. 5.21a and Fig. 5.21b respectively.


Fig. 5.21: Example of 3-uniform labeled hypergraph $G_{h l}$ (a) and its encoding vector $e_{h l}$ (b).

### 5.5.6 Encoding of Active Analog Circuits (Transistors)

Encoding method of active analog circuits containing transistors is described in section 11.3 on example of synthesis of analog circuit realization of cube root function.

### 5.6 Analog Circuit Synthesis and Unitation Constraints

Binary representation of the topology of passive analog circuits using graphs was described in section 5.5.3. Binary representation of the topology of transistor circuits using labeled hypergraphs was described in section 5.5.6. In both cases number of the components of the resulting encoded circuits is determined by number of "ones" of the corresponding encoding vectors ( $e_{p}$ for passive circuits and $e_{t}$ for transistor circuits).

Generally desired specifications of analog circuits are easier to reach using analog circuit of higher complexity. Because of this fact evolutionary analog circuits synthesis methods tend to evolve analog circuits with complexity as large as possible. Without restriction of number of the components of the evolved circuit complexity of the evolved circuit becomes higher that necessary.

Therefore number of the components of the evolved circuit has to be restricted to user define value. Since in the proposed encoding methods number of the components of the encoded circuit is determined by number of "ones" of the binary encoding vectors the restriction of components leads to problem with unitation constraints [48].

Definition 1. Let's define vector $x=\left(x_{1}, x_{2}, \ldots, x_{n}\right) \in \Omega$. Then unitation value of $x$ is defined as

$$
\begin{equation*}
u(x):=\sum_{i=1}^{n} x_{i} \tag{5.3}
\end{equation*}
$$

Value of unitation function $u(x)$ depends only on the number of ones in an input vector $x$. Unitation values of two vectors with the same numbers of ones are equal.

Problem with unitation constraints is defined as solution $e_{s}$ in which unitation value $u\left(e_{s}\right)$ (number of ones in solution $e_{s}$ ) is restricted to defined number [48].

## 6 THESIS OBJECTIVES

The goal of the thesis is to design and verify three types of automated analog circuits synthesis methods based on Estimation of Distribution Algorithms as listed bellow. Synthesis capability of every method will be verified on an example of analog circuit synthesis problem. The goals of the thesis are:

- Design and verify automated passive analog circuits synthesis method based on pure UMDA. The topology and the parameters (values of the components) are determined using UMDA algorithm. The method should be able to overcome two drawbacks of the method presented in [28] which are inability of encoding of parallel connection of the components and problems with circuits of larger complexity.
- Design and verify hybrid automated passive analog circuits synthesis method based on UMDA [27] and local search method. The topology of the desired circuit is synthesized using UMDA. The parameters of the desired circuit are determined using a local search method.
- Design hybrid automated active analog circuits synthesis method based on employing of univariate probabilistic model. As in the previous case, the topology of the desired analog circuit is synthesized using Estimation of Distribution Algorithm and the parameters of the desired circuit are determined using local search algorithm. Compared to the previous case the method should be able to synthesize active analog circuits which includes active components such as transistors.


## 7 USED APPROACHES

Approaches, methods and principles used in the proposed evolutionary analog electronics synthesis methods will be introduced in the section.

### 7.1 Estimation of Distribution Algorithms

Estimation of Distribution Algorithms (EDA) also referred to as Population ModelBuilding Genetic Algorithms (PMBGA) are evolutionary optimization techniques employing probabilistic models to generate new solutions. Pseudo-code of EDA is presented in Fig. 7.1.
step1: Set $\mathrm{k}=1$. Initialize population $P(k)$.
step2: Select population of promising individuals $P_{s}(k)$.
step3: Create probabilistic model $M(k)$ of population of selected individuals $P_{s}(k)$.
step4: Using probabilistic model $M(k)$ generate population of new solutions $P_{g}(k)$.
step5: Set $k=k+1$. Create new population $P(k)$. If termination criteria not met go to step2.

Fig. 7.1: Pseudo-code of Estimation of Distribution Algorithm.

The main idea behind EDA is to replace recombination phase of genetic algorithms (GA) by probabilistic modeling of the promising areas of the solution space. The motivation for developing EDA was demand to overcome some drawback of genetic algorithms as requirement of tight linkage, problems with deceptive functions or disruption of the building blocks after performing crossover operation. As can be seen in Fig. 7.1 the pseudo-code of EDA is similar to pseudo-code of classic GA. The only difference is probabilistic modeling used in step3 and step4.

In step1 population $P(1)$ is initialized. Initialization is performed randomly or with defined seed.

In step2 good individuals (based on fitness values) are selected and selected population $P_{s}(k)$ is formed.

In step3 probabilistic model $M(k)$ of individuals of selected population $P_{s}(k)$ is created. There are many types of probabilistic models which can be employed. Some of them will be briefly introduced in the next sections.

In step4 created probabilistic model $M(k)$ is used to generate population of new solutions $P_{g}(k)$. This phase of EDA algorithms is usually called sampling.

In step5 new population $P_{k+1}$ which is created of population of new solutions $P_{g}(k)$ or combination of $P_{g}(k)$ and $P(k)$ is created. Described process continues until one of the termination criteria such as desired fitness function, maximal number of objective function evaluations or maximal running time is met.

There have been proposed many different types of EDA algorithms which vary in the used probabilistic models or theirs principles. Some of them will be briefly introduced bellow.

### 7.1.1 Univariate Marginal Distribution Algorithm (UMDA)

Univariate Marginal Distribution Algorithm [27] is the simplest variant of EDA algorithm. The basic principle of the building of the probabilistic model is to count the marginal frequencies of occurrence of the components (the univariate marginal probability) in a population of the candidate solutions. The probabilistic model is constructed under assumption that the components of the solution are independent of each other. The computed marginal frequencies of the components are used for generation of new solutions during sampling phase of the algorithm.

### 7.1.2 Bivariate Marginal Distribution Algorithm (BMDA)

Bivariate Marginal Distribution Algorithm is a extension of UMDA algorithm [40]. While UMDA uses simple univariate marginal distributions, algorithm BMDA uses pair gene dependencies. Algorithm BMDA is special case of Factorial Distribution Algorithm however there is not used any problem specific knowledge in the initial stage. Dependencies between the variables of the solution vector are discovered during the run of the algorithm.

### 7.1.3 Population Based Incremental Learning (PBIL)

The main objective of the algorithm is to reduce memory required by the classical genetic algorithm [41. Characteristics of the population of the candidate solutions are represented by real-valued prototype probabilistic vector $p_{l}(x)$. During the sampling phase probabilistic vector $p_{l}(x)$ is used for generation of new candidate solutions.

New probability vector is created based on the probability vector of the previous generation in addition to the recently sampled solutions.

### 7.1.4 Compact Genetic Algorithm (cGA)

Similarly to PBIL algorithm cGA uses real-valued probability vector which represents probability of occurrence of each component in candidate solution [42].

### 7.1.5 Factorization Distribution Algorithm (FDA)

The algorithm uses the same probabilistic model during the whole optimization process of the algorithm [43]. The algorithm requires factorization and decomposition of the problem to be given by an expert what is usually not available. This differs from the classic EDA algorithm where the probabilistic model of the candidate solutions is usually created in every generation.

### 7.1.6 Bayesian Optimization Algorithm (BOA)

In the algorithm the model of the promising solutions is realized using Bayesian network [44]. The process of learning of the Bayesian network consist of searching for the suitable structure using a search algorithm and scoring every candidate using scoring metric. As the scoring metric Bayesian Dirichlet equivalence (BDe) method is used. The complexity of the search space is reduced allowing only $k$ incoming edges to every node of the Bayesian network.

There have been published several extensions of BOA algorithm.
Mixed Bayesian Optimization Algorithm (MBOA) extends algorithm BOA to using mixed type variables (binary and continuous) [45]. MBOA is based on binary decision trees and idea of CART model (Classification and Regression Tree).

MBOA is further modified by combination with variance adaptation as implemented in Evolutionary Strategies. Experiments have shown that the modified algorithm called Adaptive Mixed Bayesian Optimization Algorithm (AMBOA) [46] is more efficient than the original MBOA algorithm.

Another extension of BOA is Hierarchical Bayesian Optimization Algorithm $\left(\mathrm{hBOA}^{T M}\right)$ [47 which combines Bayesian optimization algorithm, local structures in Bayesian networks and a powerful niching technique. Experiments have shown that ability of hBOA of solving hierarchical traps and other difficult problems is very strong.

### 7.2 UMDA for Problems with Unitation Constraints

As was described in section 5.6 the problem of analog circuit synthesis has to be viewed as problem with unitation constraints [48] [49. Therefore modified version of UMDA algorithm which is able to handle problems with unitation constraints has to be used. Modification of Factorized Distribution Algorithm (FDA) [43] algorithm which enables to solve problems with unitation constraints was described in [48]. Application of UMDA algorithm for problems with unitation constraints was presented in 49. The proposed modification of UMDA algorithm which enables
to solve problems with unitation constraints was inspired by [48]. Pseudo-code of original UMDA algorithm [27] is presented in Fig. 7.2.

```
step0: Set \(k=1\). Generate \(n_{i} \gg 0\) points randomly.
step1: Select \(n_{s} \leq n_{i}\) points according to a selection schedule. Compute
the marginal frequencies \(r_{k ; i}\left(x_{i}\right)\) of the selected set.
step2: Generate \(n_{i}\) new points according to the distribution \(q_{k+1}(x)=\)
\(\prod_{i=1}^{n} r_{k ; i}\left(x_{i}\right)\). Set \(k=k+1\).
step3: If not terminated, go to step1.
```

Fig. 7.2: Pseudo-code of original UMDA.

As was described in paper [48] only generation phase (sampling) of FDA algorithm was modified to handle unitation constraints problems. Presented approach was adopted also in the proposed modification of UMDA algorithm. UMDA algorithm was implemented using toolbox MATEDA 2.0 [59]. Pseudo-code of modified UMDA algorithm is presented in Fig. 7.3.
step0: Set $k=1$. Generate $n_{i} \gg 0$ points randomly.
step1: Select $n_{s} \leq n_{i}$ points according to a selection schedule. Compute the marginal frequencies $r_{k ; i}\left(x_{i}\right)$ of the selected set.
step2: Generate $n_{i}$ new points according to the distribution $q_{k+1}(x)=$ $\prod_{i=1}^{n} r_{k ; i}\left(x_{i}\right)$. Set $k=k+1$.
step3: With regard to unitation constraints repair generated points.
step4: If not terminated, go to step1.
Fig. 7.3: Pseudo-code of modified UMDA.

One additional phase was added to the original UMDA. In step3 generated samples are repaired to satisfy desired unitation constraints.

The repairing function is applied to every individual of the population of generated samples in step2. Only $n_{c}$ " ones" with the highest marginal frequencies $r_{k ; i}$ of every generated sample are accepted. The rest of "ones" of the samples are set to zero. If the number of "ones" of the sample is equal or lower than $n_{c}$ then the sample is accepted without any modification and no repairing is performed. This way number of "ones" (what corresponds to the number of the components of the encoded analog circuit) of every generated sample is always $n_{c}$ or less.

Note that the repairing function is applied only for the part of the encoding vector which encodes the topology of the solution.

### 7.3 Hybrid Genetic Algorithm

Hybrid genetic algorithm [50] is formed of classical genetic algorithm and one or more another search methods. The motivation for using of this approach is demand for enhancing search capabilities, improving accuracy of the solutions, improving efficiency (faster convergence speed, lower population size) or to guarantee feasible solutions [50].

Two methods of incorporation of a local search method into genetic algorithm - Lamarckian and Baldwinian hybrid genetic algorithm will be briefly presented in the section. Local search methods use local knowledge to help genetic algorithm to locate the promising individuals in the population and prefer them during the selection process.

### 7.3.1 Lamarckian Hybrid Genetic Algorithm

In every generation of Lamarckian genetic algorithm local search algorithm tries to improve accuracy of defined percentage of individuals of the population. The individuals and their fitness values are modified to match the result found by local search method. Since Local search method tries to improve selected individuals of the population it can be called refinement genetic operator.

### 7.3.2 Baldwinian Hybrid Genetic Algorithm

As in the case of Lamarckian Hybrid Genetic Algorithm, local search algorithm tries to improve accuracy of defined portion of individual of the population. However compared to Lamarckian approach genotypes of the selected individuals are not modified. Only fitness values of the individuals are modified according to the results obtained by the local search method. Improvement of the fitness value after execution of the local search method reflects potential of the individual to improve its quality. This way chances of selection of individuals with potential to improve theirs fitness values during selection phase of the genetic algorithm are increased.

## 8 EVOLUTIONARY SYNTHESIS OF ANALOG CIRCUITS USING EDA

Analog circuit design method using autonomous circuits theory was briefly described in section 5.2. Design flow of the method is presented in Fig. 8.1. Let's assume that complexity of the initial autonomous circuit was selected based on the target application of the desired circuit.
step1: Generalized admittances of the autonomous circuit are replaced by real components, their parallel combination or open circuit.
step2: Characteristic equations of derived topologies are analyzed.
step3: Using characteristic equations of the promising topologies values of the components are calculated.

Fig. 8.1: Procedure of manual design of analog circuits using autonomous circuits approach.

All of the presented steps of the design were performed manually taking into account some designer's intuition or previous experience. The principle of the automated analog circuit synthesis method proposed in the thesis is to automatize described process of the replacement of the generalized admittances of the autonomous circuit using Estimation of Distribution Algorithms. Thus the intuition and the previous experience of the designer will be replaced by probabilistic modeling of the promising areas of the design search space and generating of high probable solutions. Pseudo-code of the proposed automated synthesis method which is inspired by manual design presented in Fig. 8.1 is presented in Fig. 8.2. Let's assume that complexity of the autonomous circuit is already chosen.
step0: Set $k=1$. Randomly initialize population of solutions $P(1)$.
step1: Select set of promising individuals $P_{s}(k)$ of population $P(k)$.
step2: Build probabilistic model $M(k)$ of selected individuals $P_{s}(k)$.
step3: Using probabilistic model $M(k)$ generate population of new so-
lutions $P_{g}(k)$.
step4: Set $k=k+1$. Based on $P(k-1)$ and $P_{g}(k-1)$ create new population $P(k)$. If termination criteria are not met go to step1.

Fig. 8.2: Pseudo-code of the proposed automated analog circuit synthesis method based on EDA.

In the next sections three different types of automated analog circuit synthesis methods based on Estimation of Distribution Algorithms will be presented.

The first proposed method is based on UMDA [27] algorithm which is used to synthesize the topology and the parameters of the desired admittance network. The method can be viewed as improved version of method presented in [28]. As was described in section 5.6 the problem of analog circuit synthesis has to be solved as problem with unitation constrains [48]. Therefore modified version of UMDA as described in section 7.2 was used. The method is verified on problem of synthesis of admittance network with desired input impedance. Afterwards the synthesized network is employed in a chaotic oscillator circuit which is simulated.

In the second proposed method hybrid approach based on UMDA and a local search algorithm is used. The topology of the desired analog circuit is synthesized using UMDA and the parameters of the desired circuit are determined using the local search algorithm. As in the previous method modified version of UMDA (section 7.2) was used. For verification of the proposed method problem of synthesis of fractional capacitor circuit is adopted.

Compared to the first two presented methods which were focused on synthesis of passive analog circuits the third proposed method is able to synthesize active analog circuits as well. The method is based on utilization of univariate marginal probability model where individuals of the population are represented as graphs and hypergraphs. Hybridization with local search algorithm is employed and used for solving of the parameters of the components. For verification of the synthesis capability of the proposed method problem of analog circuit realization of cube root function was adopted.

## 9 EVOLUTIONARY SYNTHESIS OF CHAOTIC DYNAMICS USING PURE UMDA

The paper is focused on the synthesis of the topology and the parameters of analog impedance network with arbitrary input impedance function using the univariate marginal distribution algorithm. As a test problem design of chaotic oscillator circuit is adopted. Impedance network with desired input impedance function is synthesized and employed in the chaotic oscillator circuit. Afterwards functionality of the oscillator is verified using PSpice simulation.

### 9.1 Definition of the Problem

### 9.1.1 Mathematical Background of Chaotic Dynamics

Suppose the general class of three-segment piecewise-linear vector fields which can be described by the following set of the differential equations 51:

$$
\begin{equation*}
\dot{x}=y \quad \dot{y}=\dot{z} \quad \dot{z}=q_{1} z-q_{2} y+q_{3} x+h(.) \tag{9.1}
\end{equation*}
$$

where argument of the nonlinear feedback function is:

$$
\begin{equation*}
h(.)=\left[\left(p_{1}-q_{1}\right) z-\left(p_{2}-q_{2}\right) y+\left(p_{3}-q_{3}\right) x\right] \tag{9.2}
\end{equation*}
$$

and function itself:

$$
\begin{equation*}
h(x)=0.5(|x+1|-|x-1|) \tag{9.3}
\end{equation*}
$$

Generally argument of the $h($.$) is a linear combination of all state variables.$ Having this mathematical model of some real physical system we have also some clues about geometry of the vector field. First of all the state space is separated by two parallel boundary planes into three linear segments. The equation for each plane can be considered as an argument of $h($.$) . The dynamical motion in each segment$ is uniquely determined by eigenvalues, i.e. roots of the characteristic polynomials. For inner segment we get:

$$
\begin{equation*}
\lambda^{3}-p_{1} \lambda^{2}+p_{2} \lambda-p_{3}=0 \tag{9.4}
\end{equation*}
$$

and analogically for both outer segments:

$$
\begin{equation*}
\lambda^{3}-q_{1} \lambda^{2}+q_{2} \lambda-q_{3}=0 \tag{9.5}
\end{equation*}
$$

It is evident that the system behavior can be also uniquely specified by the socalled equivalent eigenvalues, $\mathrm{p}_{i}$ and $\mathrm{q}_{i}$ which are always real numbers. Typically chaotic solution is characterized by both stable and unstable manifolds for the individual fixed points. Recently it turns out that this is not a strict requirement for the existence of chaotic solution. For example the configuration:

$$
\begin{array}{ccc}
p_{1}=0.363 & p_{2}=1.063 & p_{3}=0.277  \tag{9.6}\\
q_{1}=-10.286 & q_{2}=-1.2 & q_{3}=-2.719
\end{array}
$$

as well as values:

$$
\begin{array}{cll}
p_{1}=0.8 & p_{2}=100.21 & p_{3}=20.018 \\
q_{1}=-2.4 & q_{2}=-0.71 & q_{3}=-3.27 \tag{9.7}
\end{array}
$$

lead to the following geometry of the vector field:

$$
\begin{equation*}
D_{o}: \Re^{3} \in E_{u}^{2} \oplus E_{u}^{1} \quad D_{ \pm 1}: \Re^{3} \in E_{u}^{2} \oplus E_{s}^{1} \tag{9.8}
\end{equation*}
$$

where $D_{0}$ denotes inner segment and symbol $D_{ \pm 1}$ marks outer segments. Speaking in numerical terms the set (9.6) leads to the eigenvalues:

$$
\begin{array}{ll}
D_{o}: & \lambda_{1,2}=0.048 \pm 1.017 j  \tag{9.9}\\
D_{ \pm 1}: & \lambda_{3}=0.267 \\
1,0.07 \pm 0.506 j & \lambda_{3}=-10.426
\end{array}
$$

Analogically for the set (9.7) results into the eigenvalues:

$$
\begin{array}{lll}
D_{o}: & \lambda_{1,2}=0.3 \pm 10 j & \lambda_{3}=0.2 \\
D_{ \pm 1}: & \lambda_{1,2}=0.3 \pm 1 j & \lambda_{3}=-3 \tag{9.10}
\end{array}
$$

It seems that dynamical system described by (9.1) and (9.2) with an fully unstable equilibria at origin is something special because the state space trajectory entering inner segment is repealed towards outer segments along every direction. Since by definition the trajectory can not cross an eigenspace system has two symmetrical chaotic attractors separated by an unstable eigenplane. From the viewpoint of circuit theory this property also suggest not only one but rather several grounded and/or floating one-ports. Negative resistors, capacitors and inductors are unwanted since it makes the final circuits much more complicated. The number of the negative elements can be minimalized as will be clarified later.

As the reference state space trajectory the numerical integration of the mathematical model together with a given set of the parameters can be considered. For this purpose Mathcad and build-in fourth-order Runge-Kutta method has been used. The typical chaotic attractor for (9.6) is shown in Fig. 9.1a and similarly for 9.7 it is demonstrated in Fig. 9.1b.


Fig. 9.1: a) Numerical integration of the first set of parameters (9.1) b) Numerical integration of the second set of parameters 9.2.

### 9.1.2 Circuit Realization of the Proposed Chaotic Oscillator

The proposed realization of the chaotic oscillator consists of parallel connection of two parts, PWL resistor and admittance network $\mathrm{Y}(\mathrm{s})$. The block diagram is presented in Fig. 9.2.


Fig. 9.2: Block diagram of the proposed chaotic oscillator.

The three-segment PWL resistor is realized by diode limiter and imitance converters. Further details can be found in [52]. Since in our case the experimental verification is restricted to PSpice circuit simulations the idealized approach can be adopted. One possible implementation of the function 9.3 is provided in Fig. 9.3a. The breakpoints are defined by the voltage controlled switches, where on and off states are represented by $1 \mu \Omega$ and $1 \mathrm{~T} \Omega$ resistor on the switch output port. Input DC characteristic of the PWL resistor is presented in Fig. 9.3b.


Fig. 9.3: a) Schematic of PWL resistor b) Input DC characteristic of PWL resistor.

The second part, admittance network $\mathrm{Y}(\mathrm{s})$, will be synthesized using pure UMDA algorithm as will be described in the next section. Desired impedance function of the admittance network is (9.11) for the first set of the parameters and (9.12) for the second set of the parameters.

$$
\begin{gather*}
Z_{i n 1}=\frac{10.649 s^{2}-2.263 s+2.996}{s^{3}+10.286 s^{2}-1.2 s+2.719}  \tag{9.11}\\
Z_{i n 2}=\frac{3.2 s^{2}-100.92 s+23.288}{s^{3}+2.4 s^{2}-0.71 s+3.27} \tag{9.12}
\end{gather*}
$$

Magnitude and phase characteristics for the first impedance function (9.11) are presented in Fig. 9.4 a and Fig. 9.4b respectively. Magnitude and phase characteristics for the second impedance function 9.12 ) are presented in Fig. 9.4c and Fig. 9.4d respectively.


Fig. 9.4: a) Magnitude of input impedance $Z_{i n 1}$ b) Phase of input impedance $Z_{i n 1}$ c) Magnitude of input impedance $Z_{i n 2}$ d) Phase of input impedance $Z_{i n 2}$

### 9.2 Description of the Method

### 9.2.1 Used Encoding

As was described in section 5.6 the problem of synthesis of the topology of analog circuit employing encoding method presented in section 5.5.3 has to be solved as problem with unitation constraints [48]. Topology and values of the components of the desired admittance network are synthesized using modified UMDA algorithm as was described in section 7.2 . Note that the repairing function (section 7.2) is applied only for the part of encoding vector $e$ which includes information about the topology of the solution (bits $b 1$ to $b 135$ ).

As an encoding method characteristic vector approach as described in section 5.5 .3 is used. Number of the nodes of the used AC (5.1) was chosen to $n_{n}=10$. Therefore according to (5.2) the topology is encoded using binary vector of length 135 bits.

Values of the components are represented in mantissa-exponent form where every single mantissa $v_{\text {man }}$ is encoded using 7 bits and every single exponent $v_{\text {exp }}$ is encoded using 3 bits. Since maximal number of the components $n_{c}$ is set to 15 , encoding vector $e$ encodes parameters for 15 components. Bits $b 136$ to $b 180$ encode exponents. Bits $b 181$ to $b 285$ encode mantissas. Gray coding for the exponents and mantissas was used. See Fig. 9.5 for schematic diagram of the whole used encoding vector $e$.

$$
e=\left[\frac{\text { topology }}{[b 1 b 2 b 3 \ldots b 135}\right]\left[\frac{\text { exponents }}{b 136 b 137 b 138 \ldots b 180}\right]\left[\frac{\text { mantissas }}{b 181 b 182 b 183 \ldots b 285]}\right.
$$

Fig. 9.5: Schematic diagram of the used encoding vector $e$.

Note that only topological part (bits $b 1$ to $b 135$ ) of the encoding vector $e$ is viewed as problem with unitation constraints (modified UMDA approached used). The rest of the encoding vector $e$ (bits $b 136$ to $b 285$ ) is solved as in classical UMDA algorithm.

### 9.2.2 Objective Function

Cost value cost is according to (9.15) computed as weighted summation of magnitude differences (9.13) and phase differences (9.14). Difference of magnitude $\Delta_{m}$ is calculated as weighted absolute value of differences between desired magnitude function $f_{m d}$ and magnitude of current solution $f_{m c}$ over 61 frequency points in range $1 \mathrm{e}-3 \mathrm{rad} / \mathrm{s}$ to $10 \mathrm{rad} / \mathrm{s}$. Similarly difference of phase $\Delta_{p}$ is calculated as weighted absolute value of differences between desired phase function $f_{p d}$ and phase of current solution $f_{p c}$.

$$
\begin{array}{r}
\Delta_{m}=\frac{1}{m} \sum_{i=1}^{m} w_{d m}\left|f_{m d}(i)-f_{m c}(i)\right| \\
\Delta_{p}=\frac{1}{m} \sum_{i=1}^{m} w_{d p}\left|f_{p d}(i)-f_{p c}(i)\right| \\
\operatorname{cost}=\Delta_{m} w_{c m}+\Delta_{p} w_{c p} \tag{9.15}
\end{array}
$$

For the first set of parameters (9.1) weights $w_{c m}$ and $w_{c p}$ are set to 1 and 0.35 respectively. For the second set of parameters (9.2) weights $w_{c m}$ and $w_{c p}$ are set to 1 and 0.1 respectively. Setting of weights $w_{d m}, w_{d p}$ for both sets of parameters is summarized in Tab. 9.1

| Parameters |  | Parameters 9.1 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| angular frequency (rad/s): | $w_{d m}$ | $w_{d p}$ | angular frequency (rad/s): | $w_{d m}$ | $w_{d p}$ |
| 1e-3 to 0.0293 | 1 | 1 | $1 \mathrm{e}-3$ to 0.0293 | 1 | 1 |
| 0.0341 to 0.1359 | 2 | 2 | 0.0341 to 0.1359 | 2 | 2 |
| 0.1585 to 10 | 1 | 1 | 0.1585 to 10 | 1 | 1 |

Tab. 9.1: Setting of weights $w_{d m}$ and $w_{d p}$.

Frequency responses of the current solution $f_{m c}$ and $f_{p c}$ are obtained using nodal analysis method implemented in Matlab.

### 9.2.3 Settings of the Algorithm

The algorithm is configured to use only passive RLC components. Values of the resistors can be also negative. Maximal circuit complexity of the desired solution is restricted to use AC of 10 nodes and 15 components $\left(n_{c}=15\right)$ at the most. Input is fixed to node 1. Initial population is selected randomly with uniform probability distribution. Population size is set to 200 individuals. There were performed 500 generations in every single run of the algorithm what corresponds to 1 e 5 objective function evaluations per a run. Summary of all parameters of the presented synthesized problem is presented in Tab. 9.2. Algorithm UMDA is realized using Matlab toolbox Mateda 2.0 (section 13.1).

| maximal number of nodes | 10 |
| :---: | :---: |
| maximal number of components | 15 |
| used types of components | R,L,C |
| negative resistors | allowed |
| problem complexity | $285 \mathrm{bits}(6.2 \mathrm{e} 85)$ |
| angular frequency range | $1 \mathrm{e}-3 \mathrm{rad} / \mathrm{s}$ to $10 \mathrm{rad} / \mathrm{s}$ |
| number of points | $61(15 \mathrm{points} /$ decade $)$ |
| population size | 200 |
| generations per run | 500 |
| objective function evaluations per run | 1 e 5 |

Tab. 9.2: Summary of the parameters of the used UMDA algorithm.

Configuration of the initialization file of toolbox Mateda 2.0 for realization of UMDA algorithm is presented in Fig. 9.6.

```
PopSize = 200; n = 285; cache = [0,0,0,0,0];
Card = 2*ones(1,n); MaxGen = 500;
Cliques = CreateMarkovModel(n, 0);
edaparams{1} = {'learning_method','LearnFDA',{Cliques}};
edaparams{2} = {'sampling_method','SampleFDAmodif',{PopSize}};
edaparams{3} = {'stop_cond_method','maxgen_maxval',stop_cond_params};
[AllStat,Cache]=RunEDA(PopSize, n, F, Card, cache, edaparams);
```

Fig. 9.6: Configuration of toolbox Mateda 2.0 for realization of UMDA algorithm.

### 9.2.4 Experiments and Solutions

There were performed 20 runs of the presented algorithm for each set of the parameters (9.1) (9.2). Average run time of the algorithm was 4 minutes and 27 seconds. The results for the first set of the parameters (9.1) are presented in Tab. 9.3. The results for the second set of the parameters 9.2 are presented in Tab. 9.4.

| id of run | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| cost value | 1.23 | 1.58 | 1.78 | 0.17 | 1.55 | 0.60 | 0.93 | 1.06 | 1.36 | 1.21 |
| id of run | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
| cost value | 1.36 | 1.20 | 1.23 | 1.72 | 0.2 | 0.31 | 1.15 | 1.35 | 0.82 | 1.37 |

Tab. 9.3: Results for the first set of the parameters 9.1.

| id of run | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| cost value | 2.85 | 4.69 | 10.3 | 6.95 | 0.16 | 0.62 | 4.52 | 6.49 | 1.93 | 4.61 |
| id of run | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
| cost value | 5.37 | 2.69 | 7.57 | 2.34 | 9.97 | 4.34 | 5.31 | 3.23 | 3.02 | 6.25 |

Tab. 9.4: Results for the second set of the parameters 9.2 .

As you can see in Tab. 9.3 the best results for the first set of the parameters were achieved in runs 4 and 15. Schematic of solution 4 and its magnitude and phase characteristics are presented in Fig. 9.7. Schematic of solution 15 and its magnitude and phase characteristics are presented in Fig. 9.8.

For the second set of the parameters the best results were achieved in runs 5 and 6. Schematic of solution 5 and its magnitude and phase characteristics are presented in Fig. 9.9. Schematic of solution 6 and its magnitude and phase characteristics are presented in Fig. 9.10.


Fig. 9.7: Parameters 9.1), solution 4: schematic of the synthesized circuit (a), magnitude of $Z_{\text {in }}$ (b), deviation of magnitude $Z_{\text {in }}$ and desired function 9.11) (c), phase of $Z_{\text {in }}(\mathrm{d})$, deviation of phase $Z_{\text {in }}$ and desired function 9.11)(e)


Fig. 9.8: Parameters (9.1), solution 15: schematic of the synthesized circuit (a), magnitude of $Z_{i n}(\mathrm{~b})$, deviation of magnitude $Z_{i n}$ and desired function 9.11) (c), phase of $Z_{\text {in }}(\mathrm{d})$, deviation of phase $Z_{\text {in }}$ and desired function (9.11)(e)


Fig. 9.9: Parameters (9.2), solution 5: schematic of the synthesized circuit (a), magnitude of $Z_{\text {in }}$ (b), deviation of magnitude $Z_{\text {in }}$ and desired function 9.12 (c), phase of $Z_{i n}(\mathrm{~d})$, deviation of phase $Z_{i n}$ and desired function (e)


Fig. 9.10: Parameters 9.2), solution 6: schematic of the synthesized circuit (a), magnitude of $Z_{\text {in }}$ (b), deviation of magnitude $Z_{i n}$ and desired function 9.12 (c), phase of $Z_{\text {in }}(\mathrm{d})$, deviation of phase $Z_{i n}$ and desired function 9.12 (e)

### 9.2.5 Simulation of the Chaotic Oscillator

For verification of the synthesized admittance networks the resulting structures are employed in the proposed chaotic oscillator circuit. Examples of the state projections of the output signals of the oscillator for parameters (9.1) and solutions 4 and 15 are presented in Fig. 9.11 and Fig. 9.12 respectively. Examples of the state projections of the output signals of the oscillator for parameters 9.2 and solutions 5 and 6 are presented in Fig. 9.13 and Fig. 9.14 respectively.


Fig. 9.11: State projection for parameters 9.1) and solution 4: I(L1) vs. Vin (a), I(L2) vs. Vin (b)


Fig. 9.12: State projection for parameters 9.1) and solution 15: I(C3) vs. V(R4) (a), I(L1) vs. V(R4) (b).


Fig. 9.13: State projection for parameters (9.2) and solution 5: I(C1) vs. Vin (a), I(L2) vs Vin (b).


Fig. 9.14: State projection for parameters (9.2) and solution 6: I(C3) vs. Vin (a), (C6) vs. Vin (b).

### 9.3 Conclusion

Method of evolutionary synthesis of passive analog network with desired input impedance function using UMDA algorithm was presented. Both parts of the analog circuit synthesis problem (synthesis of the topology and determination of the parameters) were solved using UMDA. To enable UMDA to deal with the problem of determination of the parameters which is continuous problem in nature discretization of the parameters was used. Algorithm UMDA was modified to enable solving problems with unitation constraints.

Compared to method presented in [28] the proposed method enables encoding of parallel connection of the components and synthesis of circuits with higher complexity.

Four analog networks for two sets of the parameters were synthesized. Comparison of magnitude and phase characteristics of the synthesized circuits and desired function show very good accuracy of the synthesized solutions. The synthesized circuits were verified in the chaotic oscillator and resulting state projections were presented. Correct function of the chaotic oscillator confirms good accuracy of the synthesized analog networks.

The problem of synthesis of analog network for purpose of the chaotic oscillator was solved also in 3 where simulated annealing method (SA) was used. SA was capable to produce solutions with similar accuracy using comparable number of objective function evaluations. However there are two drawbacks of using SA. Since SA is not population based evolutionary algorithm there is no possibility of parallel evaluation of the objective function. The second problem is that SA is single objective optimization method. Although this issue can be partially solved using weighted summation of the fitness values of the particular objectives fully multiobjective approaches as pareto approach can not by applied here.

Compared to SA the proposed method is population based evolutionary algorithm. Therefore parallel evaluation of objective function is possible. Also fully multiobjective approach such as pareto ranking can be applied.

## 10 SYNTHESIS OF FRACTIONAL CAPACITOR USING HYBRID UMDA ALGORITHM

### 10.1 Definition of the Problem

Authors of [53] describe approximation of fractional capacitors $(1 / s)^{1 / \mathrm{n}}$ by a regular newton process and they present its RLC network representations which are obtained using classical method of analog circuit synthesis. Another informations concerning the fractional order systems can be found in [54] [55] 56]. The problem of the synthesis of the circuit approximation of (10.1) was adopted from the mentioned paper and will be used for demonstration of the synthesis capability of the proposed method. In [53] function (10.1) was approximated using $5^{\text {th }}$ order function (10.2).

$$
\begin{gather*}
Z_{\text {in }}=s^{-0.6}  \tag{10.1}\\
Z_{\text {in }}=\frac{8.58 s^{4}+255 s^{3}+405 s^{2}+35.9 s+0.169}{1 s^{5}+94.2 s^{4}+472 s^{3}+134.8 s^{2}+2.627 s+9.8 \times 10^{-3}} \tag{10.2}
\end{gather*}
$$

In Fig. 10.1 there is circuit realization of function (10.1) as presented in [53]. For the rest of the chapter, the circuit will be called original approximation circuit.


Fig. 10.1: Schematic of the original approximation circuit.

Comparison of magnitude of $Z_{\text {in }}$ for original approximation circuit and for (10.1) is presented in Fig. 10.2a. The broken line represents function (10.1) and the solid line represents original approximation circuit. Since the deviation is not clear from the picture absolute value of difference of both curves presented in Fig. 10.2a is presented in Fig. 10.2b Comparison of phase of $Z_{i n}$ for original approximation circuit and for 10.1 ) is presented in Fig. 10.2c. The absolute value of difference of both curves plotted in Fig. 10.2 d is presented in Fig. 10.2d.


Fig. 10.2: a) Comparison of the magnitude characteristics of ideal function 10.1 and original approximation circuit b) deviation of the magnitude c) comparison of the phase characteristics of ideal function (10.1) and original approximation circuit d) deviation of the phase.

The highest deviations of magnitude and phase of the original approximation circuit are presented in Tab. 10.1.

| Magnitude |  |  |  |  | Phase |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\mathrm{rad} / \mathrm{s}]$ |  |  |  | 0.01 | 100 | 0.3311 |  |  |
| $\Delta_{m}[\mathrm{~dB}]$ | 0.71 | 0.46 | 0.61 |  |  |  |  |  |  |

Tab. 10.1: The highest deviations of magnitude and phase of the original approximation circuit.

The following sections will be focused on synthesis of the presented fractional capacitor circuit problem using hybrid UMDA algorithm.

### 10.2 Hybrid UMDA Algorithm

### 10.2.1 Main Flowchart of the Method

The proposed method is based on combination of UMDA and a local search algorithm. Its principal flow chart is presented in Fig. 10.3 .


Fig. 10.3: Principal flowchart of the proposed method.

Population $P$ is formed of binary vectors of length 135 bits which are initialized randomly with seeding of 10 bits $\left(n_{c}=10\right)$. Parameters storage $e_{p s}$ is formed of vector of length 135 consisting of real numbers in the range $<0,1>$. Parameters storage $e_{p s}$ is dynamically optimized during the whole synthesis process and it is adapted to the selected topologies in the selection phase of the algorithm. The vector includes a component value for every single admittance of the used AC. During initialization phase $e_{p s}$ is set randomly with uniform distribution.

In the next step good individuals are selected using truncation selection method. Selected population $P_{s}$ is formed of good individuals of the previous population $P$.

Probabilistic model $M$ of selected population $P_{s}$ is built. For more informations on building probabilistic model in UMDA algorithm please refer to [27].

Probabilistic model $M$ built in the previous step is used for generation of new samples of solutions $P_{g}$. New samples are generated using Stochastic Universal Sampling method (SUS) and are repaired using the method described in section 7.2 ,

Generated samples are evaluated using the topological information stored in $P_{g}$ and the parameters stored in $e_{p s}$. If the condition of execution of the local search
algorithm is fulfilled, the local search algorithm tries to optimize the parameters of the current solution. If accuracy of the current solution is improved then parameters storage $e_{p s}$ is updated according to the results of the local search algorithm. Detailed description of the cost evaluation phase and the local search algorithm is presented in section 10.2.2.

In the next step new population $P$ is formed of the best individuals of $P_{g}$ and selected population $P_{s}$. Described process is repeated until one of the termination criteria of the algorithm is met.

### 10.2.2 Evaluation of Cost Value and Local Search Method

Evaluation of the cost values and using of the local search algorithm will be discussed in the section. Principal flow chart of this phase is presented in Fig. 10.4.


Fig. 10.4: Flow chart of the evaluation cost and local search phase.

The following procedure which is described bellow is performed for every single individual $P_{g}(i)$ of population of generated samples $P_{g}$.

Based on the topology information stored in the binary vector of individual $P_{g}(i)$ appropriate set of parameters $P_{1}$ is loaded from parameters storage $e_{p s}$ and cost value $c_{1}$ of individual $P_{g}(i)$ is evaluated.

If the condition of execution of the local search algorithm (LSA) is fulfilled (rand $<P_{L S A}$ ) LSA tries to improve accuracy of individual $P_{g}(i)$. The probability of execution of LSA is set to $P_{L S A}=0.02$. Initial point of the search of LSA is set to parameters set $P_{1}$. Number of maximal function evaluations of LSA is set to MaxFunEvals $=100$. The results of LSA are cost value of optimized solution $c_{2}$ and set of optimized parameters $P_{2}$.

If LSA was successful in improving of the accuracy of individual $P_{g}(i)$ and its cost value was improved $\left(c_{2}<c_{1}\right)$ then value cost of individual $P_{g}(i)$ is set to $c_{2}$ (cost $:=c_{2}$ ) and appropriate parameters of parameters storage $e_{p s}$ are updated according to parameters set $P_{2}$.

If condition for execution of LSA was not fulfilled (rand $>P_{L S A}$ ) or LSA was not able to improve cost value of individual $G(i)\left(c_{2} \geq c_{1}\right)$ resulting value cost of individual $P_{g}(i)$ is set to $c_{1}\left(\right.$ cost $\left.:=c_{1}\right)$.

After performing of the described process cost value cost of individual $P_{g}(i)$ and updated parameters storage $e_{p s}$ are obtained. During the run of the algorithm the parameters stored in $e_{p s}$ are adapted to the topological information of good individuals selected in the selection phase of the algorithm (Fig. 10.3). This way information about the topology stored in $P_{g}$ and information about the parameters stored in $e_{p s}$ are mutually optimized and the whole synthesis process is directed towards the promising areas of the solution space.

### 10.2.3 Encoding Method

As a encoding method characteristic vector approach as described in section 5.5.3 is used. Number of the nodes of used AC (section 5.1) was chosen $n_{n}=10$. Therefore according to (5.2) the topology is encoded using binary vector of length 135 bits.

Schematic of the used encoding vector $e$ is presented in Fig. 10.5. The topological information is encoded using set of binary variables $S_{t}=\{\mathrm{b} 1, \mathrm{~b} 2, \mathrm{~b} 3, \ldots, \mathrm{~b} 135\}$ and the parameters (values of the components) are encoded using set of real numbers $S_{p}$ $=\{\mathrm{dbl} 11, \mathrm{dbl} 2, \mathrm{db} 3, \ldots, \mathrm{dbl} 10\}$.

$$
e=\left[\frac{\text { topology }}{\mathrm{b} 1 \mathrm{~b} 2 \mathrm{~b} 3 \ldots \mathrm{~b} 135}\right][\mathrm{dbl1dbl22dbl3} \mathrm{\ldots dbl10}]
$$

Fig. 10.5: Schematic diagram of encoding vector $e$.
Based on the admittances selected in the topological part of the information (set $S_{t}$ ) corresponding parameters values are loaded from parameters storage $e_{p s}$ and copied to the parameters part of encoding vector $e$ (set $S_{p}$ ). For example let's assume that set $S_{t}$ is chosen $S_{t}=\{\mathrm{b} 1, \mathrm{~b} 3, \mathrm{~b} 15, \mathrm{~b} 18, \mathrm{~b} 28, \mathrm{~b} 52, \mathrm{~b} 78, \mathrm{~b} 92, \mathrm{~b} 107, \mathrm{~b} 115\}$ then the corresponding set of the parameters loaded from parameters storage $e_{p s}$ is $S_{l}$ $=\{\mathrm{p} 1, \mathrm{p} 3, \mathrm{p} 15, \mathrm{p} 18, \mathrm{p} 28, \mathrm{p} 52, \mathrm{p} 78, \mathrm{p} 92, \mathrm{p} 107, \mathrm{p} 115\}$. Afterwards the assignment of set $S_{l}$ to set $S_{p}$ is p1 $\rightarrow \mathrm{dbl1}, \mathrm{p} 3 \rightarrow \mathrm{dbl2}, \mathrm{p15} \mathrm{\rightarrow dbl3,p18} \mathrm{\rightarrow dbl4,p28} \mathrm{\rightarrow dbl5,p52} \mathrm{\rightarrow dbl6} \mathrm{}$, $\mathrm{p} 78 \rightarrow \mathrm{dbl} 7, \mathrm{p} 92 \rightarrow \mathrm{dbl} 8, \mathrm{p} 107 \rightarrow \mathrm{dbl} 9, \mathrm{p} 115 \rightarrow \mathrm{dbl} 10$.

Based on the parameters in set $S_{p}$ the values of the components are calculated using formula 10.3)

$$
\begin{equation*}
v=\frac{2 \times 10^{6}}{1+e^{(-1.4(10 r-14))}} \tag{10.3}
\end{equation*}
$$

where $r$ are values of the parameters loaded from parameters set $S_{p}$. Formula (10.3) was formed to map the values of the parameters stored in set $S_{p}$ to suitable range of the component's values. Since the parameters in set $S_{p}$ are set in the range $<0,1\rangle$ corresponding component values for the lowest $r=0$ and for the highest $r=1$ are $v_{\min }=0.0061$ and $v_{\max }=7.3685 \times 10^{3}$ respectively. Note that formula 10.3 is used for all three types of components RLC. Since the used angular frequency range is from $0.01 \mathrm{rad} / \mathrm{s}$ to $100 \mathrm{rad} / \mathrm{s}$, the values of the components are set to non-realistic values.

### 10.2.4 Objective Function

Cost value cost is according to (10.6) computed as weighted summation of the magnitude and phase differences. Difference of magnitude $\Delta_{m}$ is according to (10.4) calculated as weighted absolute value of differences of desired magnitude function $f_{m d}$ and magnitude of current solution $f_{m c}$ over $m=101$ frequency points in range $0.01 \mathrm{rad} / \mathrm{s}$ to $100 \mathrm{rad} / \mathrm{s}$. Similarly difference of phase $\Delta_{p}$ is according to 10.5 calculated as weighted absolute value of differences of desired phase function $f_{p d}$ and phase of current solution $f_{p c}$.

$$
\begin{array}{r}
\Delta_{m}=\frac{1}{m} \sum_{i=1}^{m} w_{d m}(i)\left|f_{m d}(i)-f_{m c}(i)\right| \\
\Delta_{p}=\frac{1}{m} \sum_{i=1}^{m} w_{d p}(i)\left|f_{p d}(i)-f_{p c}(i)\right| \\
\operatorname{cost}=\Delta_{m} w_{c m}+\Delta_{p} w_{c p} \tag{10.6}
\end{array}
$$

Weights $w_{c m}$ and $w_{c p}$ were set to 1 and 2 respectively. Setting of weights $w_{d m}$, $w_{d p}$ is presented in Tab. 10.2.

| angular frequency range: | $w_{d m}$ | $w_{d p}$ |
| :---: | :---: | :---: |
| $0.01 \mathrm{rad} / \mathrm{s}$ to $0.0398 \mathrm{rad} / \mathrm{s}$ | 1.3 | 1.3 |
| $0.0437 \mathrm{rad} / \mathrm{s}$ to $20.8930 \mathrm{rad} / \mathrm{s}$ | 1 | 1 |
| $22.9087 \mathrm{rad} / \mathrm{s}$ to $100 \mathrm{rad} / \mathrm{s}$ | 1.3 | 1.3 |

Tab. 10.2: Setting of weights $w_{d m}$ and $w_{d p}$.

Frequency responses of current solution $f_{m c}$ and $f_{p c}$ are obtained using nodal analysis method implemented in Matlab.

### 10.2.5 Settings of the Proposed Algorithm

The goal of the synthesis is to design a circuit which approximates function 10.1. The only informations supplied to the system are desired magnitude and phase characteristics 10.1) and maximal number of the used components $n_{c}$.

To allow direct comparison of accuracy of the original approximation circuit presented in [53] and approximation circuits obtained using the proposed method maximal number of the components in the synthesized circuit was set $n_{c}=10$.

The synthesis method is configured to use only passive components resistors, capacitors and inductors. Negative values of the resistors are not allowed. Number of objective function evaluations (evals) required by the proposed algorithm consists of number of evaluations required for calculation of the cost values of all individuals of the population (PopEvals) and number of evaluations required by the used local search algorithm (LSevals). Population size was set PopSize $=200$ and number of generation was set MaxGen $=200$. Therefore PopEvals $=40 e 3$. The local search method requires MaxFunEvals $=100$ evaluations in each its run and it is executed with probability $P_{L S A}=0.02$ (2\% Lamarckian approach - see section 7.3). The condition of its execution is tested during each objective function evaluation. Therefore LSevals $=80 e 3$ and total number of objective function evaluations required by the proposed algorithm is 120 e 3 (PopEvals + LSevals). Local search algorithm was realized using Matlab function fmincon.

Parameters of the synthesized problem and settings of the proposed algorithm are summarized in Tab. 10.3.

| maximal number of nodes $\left(n_{n}\right)$ | $10(0$ to 9$)$ |
| :---: | :---: |
| maximal number of components $\left(n_{c}\right)$ | 10 |
| used types of components | R,L,C |
| negative resistors | not allowed |
| angular frequency range | $0.01 \mathrm{rad} / \mathrm{s}$ to $100 \mathrm{rad} / \mathrm{s}$ |
| number of points $(\mathrm{m})$ | $101(25$ points/decade $)$ |
| population size $($ PopSize $)$ | 200 |
| number of generations $($ MaxGen $)$ | 200 |
| probability of local search $\left(P_{L S A}\right)$ | 0.02 |
| $w_{c m}$ | 1 |
| $w_{c p}$ | 2 |

Tab. 10.3: Setting of the parameters of the problem.

Algorithm UMDA is realized using Matlab toolbox MATEDA 2.0 (section 13.1). Settings of the algorithm are presented in Fig. 10.6

```
PopSize = 200; n = 135; cache = [0,0,0,0,0];
Card = 2*ones(1,n); MaxGen = 200; MaxVal = -1e-2;
stop_cond_params = {MaxGen,MaxVal};
Cliques = CreateMarkovModel(n, 0);
edaparams{1} = {'seeding_pop_method','seedingFract',25};
edaparams{2} = {'learning_method','LearnFDA',{Cliques}};
edaparams{3} = {'sampling_method','SampleFDAmodif',{PopSize}};
edaparams{4} = {'stop_cond_method','maxgen_maxval',stop_cond_params};
[AllStat,Cache]=RunEDAfractal(PopSize, n, F, Card, cache, edaparams);
```

Fig. 10.6: Configuring of MATEDA 2.0 toolbox for realization of UMDA algorithm.

The whole program flow of UMDA algorithm is realized using functions of MATEDA 2.0 toolbox. The only exception is sampling phase of the algorithm which is modified to enable dealing with problems with unitation constraints (section 5.6). For more information on the modified sampling method please see section 7.2,

### 10.2.6 Experiments and Solutions

There were executed 20 instances of the proposed algorithm. Average running time of a single execution was 11 min . Cost values of the solutions are presented in Tab. 10.4 .

| id of run | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| cost value | 3.805 | 2.442 | 3.805 | 2.431 | 2.428 | 2.437 | 2.443 | 3.653 | 2.433 | 2.436 |
| id of run | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 |
| cost value | 2.432 | 3.662 | 5.197 | 5.663 | 5.353 | 6.071 | 3.805 | 5.691 | 6.072 | 2.429 |

Tab. 10.4: Results of 20 runs of the proposed algorithm.
As can be seen in Tab. 10.4 the best solution was achieved in run 5 with cost value 2.428. Its schematic diagram is presented in Fig. 10.7a. Schematic diagrams of another three good solutions (run 4, run 11, run 20) are presented in Fig. 10.7b, Fig. 10.7 d and Fig. 10.7 d respectively.


Fig. 10.7: Schematics of the approximation circuits synthesized in run 5 (a), run 4 (b), run 11 (c), run 20 (d).

Comparison of magnitude and phase characteristics of $Z_{i n}$ of the best found approximation circuit and desired function (10.1) are presented in Fig. 10.8a and Fig. 10.8 c respectively. Absolute value of deviation of magnitude and phase of the best synthesized circuit are presented in Fig. 10.8b, and Fig. 10.8d respectively.


Fig. 10.8: a) Comparison of magnitude of $Z_{i n}$ of the best circuit and 10.1 b) Deviation of magnitude of $Z_{\text {in }}$ of the best circuit c) Comparison of phase of $Z_{i n}$ of the best circuit and $(10.1)$ d) Deviation of phase of $Z_{i n}$ of the best circuit.

Three highest deviations of magnitude and phase characteristics of $Z_{i n}$ of the best synthesized circuit are summarized in Tab. 10.5.

| Magnitude |  |  |  |
| :---: | :---: | :---: | :---: |
| $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 3.02 |
| $\Delta_{m}[\mathrm{~d} B]$ | 0.9 | 0.78 | 0.30 |


| Phase |  |  |  |
| :---: | :---: | :---: | :---: |
| $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 17.38 |
| $\Delta_{p}[\mathrm{\circ}]$ | 2.78 | 3.97 | 1.64 |

Tab. 10.5: The highest deviations of magnitude and phase of the best synthesized approximation circuit.

As can be seen in Fig. 10.8a and Fig. 10.8c the maximal deviations of magnitude and phase responses are located at the boundaries of the used frequency range. At these frequencies unoptimized areas of the frequency response ( 0 to $10^{-2} \mathrm{rad} / \mathrm{s}$ and $10^{2}$ to $\infty \mathrm{rad} / \mathrm{s}$ ) affect the circuit's behavior in the area where the optimization was performed. Zeros and poles diagram of the synthesized circuit is presented in Fig. 10.9 .


Fig. 10.9: Zeros and poles diagram of the best synthesized circuit.

Although the probability of using of all three component types (resistors, capacitors, inductors) was equal during the synthesis process, all synthesized circuits presented in Fig. 10.7a to Fig. 10.7d do not include any inductors. As the proposed algorithm was constrained to use only 10 components at the most, it seems that using only capacitors and resistors allows the method to reach lower cost values than in solutions where inductors are included.

### 10.2.7 Comparison of the Best Synthesized Solution and Original Approximation Circuit

In the section the best synthesized approximation circuit obtained using the proposed algorithm will be compared to original approximation circuit designed in 53] by classical method of analog circuits design.

Since the proposed evolutionary synthesis method was configured to use the same circuit complexity ( 10 components at the most) as original approximation circuit, accuracy of both circuits can be directly compared.

Except deviations at boundaries of the used frequency range (as was commented above) for the original approximation circuit the highest deviation of magnitude is $\Delta_{m}=0.61 \mathrm{db}$ at angular frequency $0.33 \mathrm{rad} / \mathrm{s}$. For the solution of the proposed
method the highest deviation of the magnitude is $\Delta_{m}=0.27 \mathrm{~dB}$ at angular frequency $0.30 \mathrm{rad} / \mathrm{s}$. Thus in terms of deviation of magnitude the accuracy of the synthesized circuit is more than twice better than the original approximation circuit. Comparison of the deviations of magnitude of $Z_{\text {in }}$ for both circuits is presented in Tab. 10.6

| original | $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 0.33 |
| :---: | :---: | :---: | :---: | :---: |
| circuit | $\Delta_{m}[\mathrm{~dB}]$ | 0.71 | 0.46 | 0.61 |
| synthesized <br> circuit | $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 0.30 |
|  | $\Delta_{m}[d B]$ | 0.93 | 0.92 | 0.27 |

Tab. 10.6: Comparison of deviations of magnitude of $Z_{i n}$ for original approximation circuit and for the best synthesized circuit.

The highest phase deviation inside the used frequency range is for original circuit $\Delta_{p}=5.2^{\circ}$ at angular frequency $0.14 \mathrm{rad} / \mathrm{s}$ and for the synthesized circuit it is $\Delta_{p}=1.5^{\circ}$ at angular frequency $0.58 \mathrm{rad} / \mathrm{s}$. Thus phase accuracy of the synthesized circuit is more than three times better than the original approximation circuit. Comparison of maximal deviations of phase of $Z_{i n}$ is presented in Tab 10.7.

| original <br> circuit | $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 0.14 |
| :---: | :---: | :---: | :---: | :---: |
|  | $\Delta_{p}[\circ]$ | 26.3 | 7.98 | 5.2 |
| synthesized <br> circuit | $\omega[\mathrm{rad} / \mathrm{s}]$ | 0.01 | 100 | 0.58 |
|  | $\Delta_{p}[\circ]$ | 3.0 | 4.2 | 1.5 |

Tab. 10.7: Comparison of deviations of phase of $Z_{i n}$ for original approximation circuit and for the best synthesized circuit.

### 10.3 Conclusion

Automated analog circuits synthesis method based on hybrid approach employing UMDA and a local search algorithm was presented. Used hybrid approach enables to employ specialized methods for both sub problems of different nature (synthesis of the topology and determination of the parameters). Synthesis of the topology which is combinational optimization problem was solved using UMDA. Synthesis of the parameters which is continuous optimization problem was solved using a local search algorithm. The principle of the method is based on mutual interaction of synthesis of the topology (UMDA) and determination of the parameters (local search algorithm) of the desired solution. Note that modified version of UMDA which allows to solve problems with unitation constrains was used.

The proposed method was verified on the problem of synthesis of fractional capacitor circuit introduced in [53]. Presented experiments have shown that the proposed algorithm is capable to synthesize solutions whose accuracy overperform solutions obtained using classical method of analog circuit design given in [53]. Accuracy of magnitude of the best obtained solution was more than twice better then the original approximation circuit. Accuracy of phase of the best obtained solution was more than three times better then the original approximation circuit.

In [4] the problem of fractional capacitor analog circuit realization was solved using simulated annealing method (SA). Accuracy of the circuits synthesized using SA was comparable to the solutions produced using the proposed EDA method. However SA required much higher number of objective function evaluations. While the proposed EDA method required 120e3 objective function evaluations for synthesis of the same problem SA required 440e3 objective function evaluations.

## 11 SYNTHESIS OF CUBE ROOT FUNCTION USING GRAPH EDA METHOD

### 11.1 Definition of the Problem

The problem of synthesis of circuit realization of cube root function was proposed by John Koza as a benchmark problem for evolutionary analog electronics synthesis systems in his paper discussing synthesis of analog circuits using genetic programming [57. The problem was also adopted in [17] where unconstrained optimization genetic algorithm with oscillating length representation was used. The target voltage response of the desired circuit is (11.1).

$$
\begin{equation*}
U_{2}=\sqrt[3]{U_{1}} \tag{11.1}
\end{equation*}
$$

In other words the goal of the synthesis is to design analog circuit in which output voltage $U_{2}$ is cube root of its input voltage $U_{1}$. Graphical representation of (11.1) is presented in Fig. 11.1.


Fig. 11.1: Target response of the desired circuit realization of cube root function.

To enable direct comparison of the results obtained using the proposed method and the results of other authors the objective function in the proposed method is defined exactly the same way as was presented in original paper [57].

### 11.2 Introduction of Graph Estimation of Distribution Algorithm

Synthesis capability of the proposed GhEDA method will be demonstrated on problem of circuit realization of cube root function. The cube root function circuit realization consists of bipolar transistors NPN and PNP, resistors and positive and negative voltage sources. The goal of the synthesis is to design topology of connection of the transistors NPN and PNP, topology of connection of the resistors, the parameters of the resistors (the values of the resistors) and define nodes of connection of the positive and negative voltage sources. Pseudo-code of the proposed method is presented in Fig. 11.2 .
step0: Initialize population $P$ of $n_{i}$ individuals.
step1: According to selection method select population $P_{s}$.
step2: Build probabilistic model $M$ of selected population $P_{s}$.
step3: Using probabilistic model $M$ generate set of new samples $P_{g}$ consisting of $n_{g}$ individuals.
step4: Using objective function evaluate cost values of set of samples $P_{g}$.
step5: Based on $P$ and $P_{g}$ create new population $P_{n}$ and replace old population $\left(P:=P_{n}\right)$.
step6: According to the topologies of $n_{\text {opt }}$ randomly selected individuals of $P$ optimize values of parameters storage $e_{p s}$. Go to step1.

Fig. 11.2: Pseudo-code of the proposed method.

Initial population $P$ consisting of $n_{i}$ individuals is set randomly respecting maximal number of components of every type $n_{\text {npn }}, n_{p n p}, n_{\text {res }}, n_{v c c p}, n_{v c c n}$. Parameters storage $e_{p s}$ is initialized randomly with uniform distribution. Detailed description of the encoding method and parameters storage $e_{p s}$ is presented in section 11.3 .

After evaluation of the cost values of population $P$, selected population $P_{s}$ is formed. Tournament selection method with tournament size 2 is used.

In the learning phase probabilistic model $M$ of selected population $P_{s}$ is created. Marginal frequencies of the components included in selected population $P_{s}$ are calculated. Every single component connected to specific set of connection nodes is represented by corresponding edge of the graph (resistors and positive and negative voltage sources) or hyperedge of the hypergraph (transistors NPN and PNP). Therefore the marginal frequencies of the components correspond to the marginal frequencies of the edges of the graphs and the hyperedges of the hypergraphs encoded in
the individuals of selected population $P_{s}$. Detailed description of the learning phase is presented in section 11.4 .

In the next phase probabilistic model $M$ is used to generate population of new samples of solutions $P_{g}$ which consists of $n_{g}$ individuals. Detailed description of the sampling phase is described in section 11.5 .

New individuals are simulated and theirs cost values are calculated using objective function described in section 11.6 .

In the replacement phase new population $P_{n}$ is formed of best $n_{i}-n_{g}$ individuals of current population $P$ and whole population of new samples $P_{g}$. Afterwards current population $P$ is replaced by new population $P_{n}\left(P:=P_{n}\right)$.

In the optimization phase the local search algorithm tries to improve (decrease) cost values of $n_{\text {opt }}$ randomly selected individuals of population $P$. Detailed description of the optimization phase is presented in section 11.7 .

### 11.3 Encoding Method

Graphs are the most straightforward method of representation of the topology of analog circuits. The desired circuit realization of cube root function consists of resistors, bipolar transistors NPN and PNP and positive and negative voltage sources. As will be described bellow topology of connection of the resistors and connection of the positive and the negative voltage sources are represented by corresponding graphs. Topology of connection of the transistors NPN and PNP are represented by 3 -uniform hypergraphs.

Maximal complexity of the desired analog circuit is defined by maximal number of nodes $n_{n}$ and maximal number of transistors NPN, transistors PNP and resistors denoted as $n_{n p n}, n_{p n p}, n_{\text {res }}$. Maximal number of nodes connected to the positive and negative voltage sources are denoted as $n_{v c c p}$ and $n_{v c c n}$ respectively. Every individual of population $P$ consist of informations about topology of connection of the transistors NPN and PNP, topology of connection of the resistors and connection of the positive and negative voltage sources. Parameters of the resistors are stored in parameters storage $e_{p s}$ which is described in section 11.7 .

The topology of connection of the resistors is represented by simple undirected graph $G_{r e s}$. Since maximal complexity of the synthesized circuit is restricted to $n_{n}$ nodes graph $G_{r e s}$ is always subgraph of complete graph $G_{r e s c}$ which includes $n_{n}$ vertices and $n_{\text {edgres }}=n_{n}\left(n_{n}-1\right) / 2$ edges. Complete graph $G_{\text {resc }}$ for $n_{n}=4$ and corresponding topology of connection of the resistors are presented in Fig. 11.3a and Fig. 11.3b respectively. Example of graph $G_{r e s}$ and corresponding topology of connection of the resistors are presented in Fig. 11.3d and Fig. 11.3d,

Graph $G_{r e s}$ is defined by its characteristic vector. Maximal number of edges of graph $G_{r e s}$ is given by number of edges $n_{\text {edgres }}$ of corresponding complete graph $G_{\text {resc }}$. Characteristic vector of graph $G_{\text {res }}$ can be defined as binary vector $e_{\text {res }}$ of length $n_{\text {edgres }}$ bits. Every single bit of $e_{\text {res }}$ corresponds to including or not including corresponding edge of complete graph $G_{\text {resc }}$ in its subgraph $G_{r e s}$. Characteristic vector $e_{\text {res }}$ of graph $G_{\text {res }}$ in Fig. 11.3d is presented in Fig. 11.3d.

(a)

(c)

(b)

(d)

Fig. 11.3: a) Complete graph $G_{\text {resc }}$ for $\left.n_{n}=4 \mathrm{~b}\right)$ Analog circuit corresponding to $G_{r e s c}$ c) Subgraph $G_{r e s}$ d) Analog circuit corresponding to $G_{r e s}$ and its encoding vector $e_{\text {res }}$.

Assignment of the edges to the vertices for graphs $G_{\text {res }}$ and $G_{\text {resc }}$ and assignment of the resistors to the nodes for the corresponding circuits (Fig. 11.3b and Fig. 11.3d) are presented in Tab. 11.1.

| edge (resistor) | $e_{1}\left(R_{1}\right)$ | $e_{2}\left(R_{2}\right)$ | $e_{3}\left(R_{3}\right)$ | $e_{4}\left(R_{4}\right)$ | $e_{5}\left(R_{5}\right)$ | $e_{6}\left(R_{6}\right)$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| vertex 1 (node 1) | $v_{0}\left(n_{0}\right)$ | $v_{0}\left(n_{0}\right)$ | $v_{0}\left(n_{0}\right)$ | $v_{1}\left(n_{1}\right)$ | $v_{1}\left(n_{1}\right)$ | $v_{2}\left(n_{2}\right)$ |
| vertex 2 (node 2) | $v_{1}\left(n_{1}\right)$ | $v_{2}\left(n_{2}\right)$ | $v_{3}\left(n_{3}\right)$ | $v_{2}\left(n_{2}\right)$ | $v_{3}\left(n_{3}\right)$ | $v_{3}\left(n_{3}\right)$ |

Tab. 11.1: Assignment of the edges to the vertices for graphs $G_{r e s c}$ and $G_{r e s}$ and assignment of the resistors to the nodes for circuits in Fig. 11.3b and Fig. 11.3d.

Topology of connection of the transistors NPN is represented by labeled 3uniform hypergraph $G_{n p n}$ and is restricted to $n_{n}$ nodes. Similarly to the repre-
sentation of the topology of the resistors there can be defined complete 3 -uniform hypergraph $G_{n p n c}$ which includes $n_{n}$ vertices and $n_{\text {edgnpn }}=n_{n}\left(n_{n}-1\right)\left(n_{n}-2\right) / 6$ hyperedges. Hypergraph $G_{n p n}$ is always subhypergraph of complete hypergraph $G_{n p n c}$.

Compared to the representation of the topology of connection of the resistors, representation of the topology of connection of the transistors requires another additional parameter "rotation" of the transistors. While connection nodes of every single encoded transistor are defined by the connection vertices of the corresponding hyperedge of hypergraph $G_{n p n}$, "rotation" of the transistor is defined by the label of the corresponding hyperedge. Given 3 ports transistor there are six possible combinations ("rotations") of the assignment of the nodes to the ports of the transistor. Complete 3-uniform hypergraph $G_{n p n c}$ for $n_{n}=4$ is presented in Fig. 11.4a. Larger white circles represent vertices of the hypergraph. Smaller black circles represent hyperedges. Corresponding analog circuit is presented in Fig. 11.4b,


Fig. 11.4: a) Complete 3-uniform hypergraph $G_{n p n c}$ for $n_{n}=4 \mathrm{~b}$ ) Analog circuit representation of $G_{n p n c}$ c) Example of 3-uniform hypergraph $G_{n p n}$ d) Analog circuit representation of $G_{n p n}$.

Assignment of the hyperedges to the vertices for hypergraphs $G_{n p n c}$ and $G_{n p n}$ and assignment of the 3 ports generalized admittances $\left(Y_{1}\right.$ to $\left.Y_{4}\right)$ to the nodes for corresponding circuits (Fig. 11.4b and Fig. 11.4d) are presented in Tab. 11.2 .

| hyperedge (generalized 3-ports admittance) | $e_{1}\left(Y_{1}\right)$ | $e_{2}\left(Y_{2}\right)$ | $e_{3}\left(Y_{3}\right)$ | $e_{4}\left(Y_{4}\right)$ |
| :---: | :---: | :---: | :---: | :---: |
| vertex 1 (node 1) | $v_{1}\left(n_{1}\right)$ | $v_{1}\left(n_{1}\right)$ | $v_{2}\left(n_{2}\right)$ | $v_{1}\left(n_{1}\right)$ |
| vertex 2 (node 2) | $v_{2}\left(n_{2}\right)$ | $v_{2}\left(n_{2}\right)$ | $v_{3}\left(n_{3}\right)$ | $v_{3}\left(n_{3}\right)$ |
| vertex 3 (node 3) | $v_{3}\left(n_{3}\right)$ | $v_{4}\left(n_{4}\right)$ | $v_{4}\left(n_{4}\right)$ | $v_{4}\left(n_{4}\right)$ |

Tab. 11.2: Assignment of the hyperedges to the vertices for hypergraphs $G_{n p n c}$ and $G_{n p n}$ and assignment of the 3 ports generalized admittances $\left(Y_{1}\right.$ to $\left.Y_{4}\right)$ to the nodes for circuits in Fig. 11.4b and Fig. 11.4d.

Since "rotation" labels are not specified in complete 3-uniform hypergraph $G_{n p n c}$, generalized three-ports admittances $Y_{1}$ to $Y_{4}$ are used in Fig. 11.4b, An example of labeled 3-uniform hypergraph $G_{n p n}$ is presented in Fig. 11.4c. The numbers in the brackets behind the names of the hyperedges define the labels of the hyperedges. For hyperedges $e_{1}$ and $e_{3}$ of hypergraph $G_{n p n}$ the labels "rotation" are set to 1 and 3 respectively. Assignment of the labels of the hyperedges to "rotations" of the transistors is defined in Tab. 11.3,

| label of hyperedge ("rotation") | 1 | 2 | 3 | 4 | 5 | 6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| node 1 | B | B | C | C | E | E |
| node 2 | C | E | B | E | B | C |
| node 3 | E | C | E | B | C | B |

Tab. 11.3: Assignment of the labels of the hyperedges to the connection nodes of the transistors.

Since every possible configuration of hypergraph $G_{n p n}$ is subhypergraph of complete 3-uniform hypergraph $G_{n p n c}$, characteristic vector of hypergraph $G_{n p n}$ can be defined as binary vector $e_{n p n}$ of length $n_{\text {edgnpn }}$ bits. Every single bit of $e_{n p n}$ corresponds to including or not including corresponding hyperedge of complete hypergraph $G_{n p n c}$ in its subhypergraph $G_{n p n}$. Encoding vector $e_{n p n}$ is further extended to include information about "rotation" of the encoded transistors. There are six possible combinations of connection of the ports of a transistor to three nodes. Therefore the final encoding vector $e_{n p n}$ is defined as binary vector of length $6 n_{\text {edgnpn }}$. Encoding vector $e_{n p n}$ of hypergraph $G_{n p n}$ presented in Fig. 11.4 dis presented in Fig. 11.5

$$
\begin{aligned}
& \frac{}{c} Y_{2} \\
& \begin{array}{c}
\text { rotation: } 1
\end{array} 2 \begin{array}{lllllllllllllllllllllll} 
& 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5 & 6 \\
e_{n p n}=[ & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0
\end{array} 0
\end{aligned}
$$

Fig. 11.5: Encoding vector $e_{n p n}$ of hypergraph $G_{n p n}$.

Topology of connection of the PNP transistors is represented by labeled 3uniform hypergraph $G_{p n p}$ and encoded by vector $e_{p n p}$ exactly the same way as was described above for the topology of connection of the NPN transistors.

The last type of information which has to be encoded is connection of the positive and the negative voltage sources what is represented by graphs $G_{v c c p}$ and $G_{v c c}$ respectively.

As can be seen in example in Fig. 11.6a graph $G_{v c c p}$ includes vertex $V_{v c c p}$ which represents positive voltage source. Edges between vertices $V_{v c c p}$ and $v_{1}$ and $v_{3}$ represent connection of positive voltage source $V_{c c p}$ to nodes $n_{1}$ and $n_{3}$.

Similarly in graph $G_{v c c n}$ vertex $V_{v c c n}$ is connected to vertices $v_{2}$ and $v_{4}$ what corresponds to connection negative voltage source $V_{c c n}$ to nodes $n_{2}$ and $n_{4}$ (Fig. 11.6a). Schematic representation of connection of the positive and the negative voltage sources corresponding to graphs in Fig. 11.6a is presented in Fig. 11.6b.


Fig. 11.6: a) Graphs $G_{v c c p}$ and $G_{v c c n}$ b) Connection of the voltage sources defined by graphs $G_{v c c p}$ and $G_{v c c n}$.

Encoding vectors $e_{v c c p}$ and $e_{v c c n}$ of graphs $G_{v c c p}$ and $G_{v c c n}$ are represented by binary vectors of length $n_{n}$, where every single bit represents including or not including of an edge between voltage source ( $V_{v c c p}$ or $V_{v c c n}$ ) and corresponding vertex ( $v_{1}$ to $v_{5}$ in the example). Encoding vectors $e_{v c c p}$ and $e_{v c c n}$ are presented in Fig. 11.7 .

Parameters of the resistors (values of the resistors) are stored in parameters storage $e_{p s}$ which is vector of real numbers of length $n_{\text {edgres }}$. Vector $e_{p s}$ includes a value

```
evccp}=[\begin{array}{llllll}{\mp@subsup{v}{1}{}}&{\mp@subsup{v}{2}{}}&{\mp@subsup{v}{3}{}}&{\mp@subsup{v}{4}{}}&{\mp@subsup{v}{5}{}}&{\mp@subsup{v}{6}{}}\\{1}&{0}&{1}&{0}&{0}&{0}\end{array}]\quad e vcccn = [\begin{array}{llllll}{\mp@subsup{v}{1}{}}&{\mp@subsup{v}{2}{}}&{\mp@subsup{v}{3}{}}&{\mp@subsup{v}{4}{}}&{\mp@subsup{v}{5}{}}&{\mp@subsup{v}{6}{}}\\{0}&{1}&{0}&{1}&{0}&{0}\end{array}
```

Fig. 11.7: Encoding vector $e_{v c c p}$ of graph $G_{v c c p}$ and encoding vector $e_{v c c n}$ of graph $G_{v c c n}$.
for every possible resistor connected to nodes $n_{1}$ and $n_{2}$, where $n_{1} \in\left\{0,1, \ldots, n_{n}-1\right\}$ and $n_{2} \in\left\{0,1, \ldots, n_{n}-1\right\}$.

During every single evaluation of the objective function the cost value is obtained based on two types of information. The first one informs about the topology and is stored in encoding vector of individual ( $\left.e_{r e s}, e_{n p n}, e_{p n p}, e_{v c c p}, e_{v c c n}\right)$ in population $P$. The second one informs about the parameters of the encoded resistors and is stored in parameters storage $e_{p s}$.

The only way how to modify the values of parameters storage $e_{p s}$ is execution of the local search algorithm (LSA) in optimization phase (step6 in Fig. 11.2). The synthesis process consists of mutual interaction between selection of the promising topologies (step1 in Fig. 11.2) and optimization of the values of parameters storage $e_{p s}$. In the optimization phase LSA tries to optimize the values of $e_{p s}$ to adapt them to the promising topologies selected in the selection phase. This way the values stored in parameters storage $e_{p s}$ are evolved during the whole synthesis process.

### 11.4 Learning of the Probabilistic Model

For every single component type (transistors NPN, transistors PNP, resistors, positive voltage sources, negative voltage sources) marginal frequencies of the edges contained in current selected population $P_{s}$ are calculated and saved in vectors $v_{n p n}$, $v_{p n p}, v_{r e s}, v_{v c c p}, v_{v c c n}$ which are encoded the same way as encoding vectors $e_{n p n}, e_{p n p}$, $e_{\text {res }}, e_{v c c p}, e_{v c c n}$. Values of vectors $v_{n p n}, v_{p n p}, v_{r e s}, v_{v c c p}, v_{v c c n}$ represent numbers of appearing of the corresponding edges in current selected population $P_{s}$. Examples of vectors $v_{n p n}, v_{p n p}, v_{r e s}, v_{v c c p}, v_{v c c n}$ are presented in Fig. 11.8a to Fig. 11.8d. For example $v_{n p n}(3)=4$ (number 4 in the third position of vector $v_{n p n}$ ) denotes that current selected population $P_{s}$ includes four individuals with $e_{n p n}(3)=1$. This corresponds to the fact that transistor NPN with C connected to $n_{1}$, B connected to $n_{2}$ and E connected to $n_{3}$ (see Tab. 11.3) was used four times in the current selected population $P_{s}$. Similarly $v_{r e s}(2)=9$ denotes that the resistor connected to nodes 0 and 2 (see Tab. 11.1) was used nine times in $P_{s}$ and it becomes the most frequently used resistor in the individuals of current selected population $P_{s}$. In other words there is high probability that this resistor will appear in topology of good individual.
$\qquad$

$$
\begin{aligned}
& \text { rotation: } 1 \begin{array}{llllllllllllllllllllll}
2 & 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5 & 6 & 1 & 2 & 3 & 4 & 5
\end{array} \\
& v_{n p n}=\left[\begin{array}{lllllllllllllllllllllll}
0 & 0 & 4 & 0 & 0 & 0 & 3 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 2 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0
\end{array}\right] \\
& v_{p n p}=\left[\begin{array}{llllllllllllllllllllll}
0 & 2 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 4 & 0 & 0 & 0 & 0 & 0 & 0 & 0
\end{array}\right)
\end{aligned}
$$

(a)

$$
\left.v_{\text {res }}=\left[\begin{array}{cccccc}
R_{1} & R_{2} & R_{3} & R_{4} & R_{5} & R_{6} \\
2 & 9 & 5 & 4 & 7 & 3
\end{array}\right] \quad v_{v c c p}=\begin{array}{ccccccc}
n_{1} & n_{2} & n_{3} & n_{4} & n_{5} & n_{6}
\end{array} \begin{array}{rllllll}
4 & 1 & 2 & 7 & 2 & 1
\end{array}\right] \quad v_{v c c n}=\left[\begin{array}{lllllll}
3 & 6 & 2 & 5 & 2 & 1
\end{array}\right]
$$

Fig. 11.8: Examples of vectors $v_{n p n}$ and $v_{p n p}(\mathrm{a}), v_{r e s}(\mathrm{~b}), v_{v c c p}(\mathrm{c})$ and $v_{v c c n}(\mathrm{~d})$.
After calculation of the marginal frequencies of the edges for all types of components, values of vectors $v_{n p n}, v_{p n p}, v_{r e s}, v_{v c c p}, v_{v c c n}$ are sorted from the highest to the lowest and this way vectors $s_{n p n}, s_{p n p}, s_{r e s}, s_{v c c p}, s_{v c c n}$ are obtained. Vectors of sorted marginal frequencies $s_{n p n}, s_{p n p}, s_{r e s}, s_{v c c p}, s_{v c c n}$ are used for determination of the most probable components during the phase of generation of new individuals (sampling phase). Sorted information about the marginal frequencies of the used components in current population $P_{s}$ stored in five vectors $s_{n p n}, s_{p n p}, s_{r e s}, s_{v c c p}, s_{v c c n}$ is denoted as probabilistic model $M$.

### 11.5 Sampling of the Probabilistic Model

Created probabilistic model $M$ is used to generate new solutions of the promising topologies of the given solution space. To increase diversity of the created samples some portion of the edges of the generated samples is created randomly. Presented sampling method was inspired by sampling principle of Estimation of Distribution Algorithm based on graphs kernels presented in [58]. Pseudo-code of the used sampling method is presented in Fig. 11.9.
step1: Randomly select individual $I$ of population $P_{s}$.
step2: Randomly with probability $P_{\text {rem }}$ remove edges of graphs $G_{\text {res }}$, $G_{v c c p}, G_{v c c n}$ and hyperedges of hypergraphs $G_{n p n}, G_{p n p}$ of individual $I$. step3: Add edges to graphs $G_{r e s}, G_{v c c p}, G_{v c c n}$ and hyperedges to hypergraphs $G_{n p n}, G_{p n p}$ of selected individual $I$.

Fig. 11.9: Flow chart of the sampling phase.

In step1 individual $I$ of current selected population $P_{s}$ is chosen randomly and is used as a basis for new generated sample.

In step2 edges of graphs $G_{r e s}, G_{v c c p}, G_{v c c n}$ and hyperedges of hypergraphs $G_{n p n}$, $G_{p n p}$ of individual $I$ are removed randomly with probability $P_{\text {rem }}$ which is typically set to 0.2 . In other words approximately 100. $P_{\text {rem }}$ percent of the edges of graphs $G_{r e s}, G_{v c c p}, G_{v c c n}$ and the hyperedges of hypergraphs $G_{n p n}, G_{p n p}$ of individual $I$ are removed.

In step3 new edges are added to graphs $G_{r e s}, G_{v c c p}, G_{v c c n}$ and new hyperedges are added to hypergraphs $G_{n p n}, G_{p n p}$. There are two ways how to perform this step. In the first one the process of the addition of the edges and the hyperedges is guided using information about the promising areas of the solution space stored in probabilistic model $M$. The edges and the hyperedges with high values of the marginal frequencies in vectors $s_{n p n}, s_{p n p}, s_{r e s}, s_{v c c p}, s_{v c c n}$ are more favorable than those with lower values. This way modification of the topologies of graphs $G_{r e s}, G_{v c c p}, G_{v c c n}$ and hypergraphs $G_{n p n}, G_{p n p}$ is guided to include edges which are frequently used in good individuals of the population. The second way is random addition of the edges and the hyperedges what helps to maintain diversity of the generated samples. Probability of using of probabilistic model $M$ to guide the process of addition of the edges and the hyperedges is defined as $P_{\text {add }}$ and is typically set to 0.8 .

### 11.6 Objective Function

Information about the topology stored in the individuals of population $P_{g}$ and information about the parameters stored in parameters storage $e_{p s}$ are transformed into netlist representation suitable for external spice compatible circuit simulator.

After obtaining of voltage frequency characteristic, cost value is calculated using objective function (11.2). To enable direct comparison of the results obtained using the proposed method to the results of other authors the objective function is defined exactly the same way as was presented in original paper [57].

$$
\begin{equation*}
\operatorname{cost}=\sum_{i=1}^{m} w_{v}(i)\left|f_{v d}(i)-f_{v c}(i)\right| \tag{11.2}
\end{equation*}
$$

According to (11.2) cost value cost is defined as weighted summation of absolute values of differences between voltage response of desired solution $f_{v d}$ and voltage response of current solution $f_{v c}$ over $m=21$ equidistant voltage values in range 250 mV to 250 mV . There is penalization of the cost value by 10 if the output voltage response is not within $1 \%$ deviation of the target voltage characteristic. In such case weight $w_{v}$ is set to 10 , otherwise $w_{v}=1$. Voltage response of the current solution is obtained using circuit simulator ngspice (section 13.5).

### 11.7 Parameters Optimization

In the last phase of the proposed method the parameters of the resistors stored in parameters storage $e_{p s}$ are optimized according to the topologies of $n_{\text {opt }}$ randomly selected individuals of newly created population $P$. In every generation of the proposed method the parameters optimization routine is executed with probability $P_{L S A}$. Pseudo-code of the parameters optimization phase is presented in Fig. 11.10.
step1: Randomly choose individual $I$ of population $P$.
step2: Based on topology of individual $I$ load parameters $p_{1}$ from parameters storage $e_{p s}$.
step3: Using topology information stored in $I$ and parameters $p_{1}$ evaluate cost value of individual $I$.
step4: Execute local search algorithm. Optimized parameters $p_{2}$ and cost value of optimized solution $c_{2}$ are obtained.
step5: If $c_{2}<c_{1}$ then replace parameters $p_{1}$ in $e_{p s}$ with parameters $p_{2}$.

Fig. 11.10: Pseudo code of the optimization phase.

Individual $I$ of current population $P$ is selected randomly (step1). Based on the topology encoded in individual $I$ corresponding parameters $p_{1}$ of parameters storage $e_{p s}$ are loaded and cost value $c_{1}$ of individual $I$ is evaluated (step2, step3).

In step4 the local search algorithm (LSA) tries to improve accuracy of individual I. Parameters $p_{1}$ loaded in step2 are used as a starting point for LSA. After finishing LSA new optimized parameters $p_{2}$ and cost value of the optimized individual $c_{2}$ are obtained.

If LSA was successful in improving of cost value of individual $I\left(c_{2}<c_{1}\right)$ then parameters $p_{1}$ in parameters storage $e_{p s}$ are replaced by optimized parameters $p_{2}$. If LSA was not successful in improving accuracy of individual $I$ then parameters optimization process is terminated with no modification of parameters storage $e_{p s}$ (step5).

As LSA Matlab function fmincon was used. The function was configured to use Interior-Point algorithm and maximal number of function evaluations MaxFunEvals was set to 800 .

According to [17] values of the resistors are chosen from E12 series in five decades. Thus resistance of every resistor can be set to one of 60 possible values. The lowest and the highest possible values of resistors were $10 \Omega$ and $820 \mathrm{k} \Omega$ respectively.

### 11.8 Experiments and Solutions

The proposed algorithm was implemented in 64-bit version of Matlab 8.0 (R2012b). Experiments were performed on 64-bit dual core PC with processor AMD Athlon II X2 245, 8GB RAM and operational system Centos 6.5. Parameters of the algorithm used in the experiments are summarized in Tab. 11.4.

Number of total function evaluations $n_{\text {evals }}$ consists of number of function evaluations required by evaluation of cost values of $P_{g}$ (step4 in Fig. 11.2) and number of function evaluations required by parameters optimization phase (step6 in Fig. 11.2) and can be computed as $n_{\text {evals }}=n_{\text {gen }} d+n_{\text {gen }} P_{L S A} n_{\text {opt }}$ MaxFunEvals.

| maximal number of nodes $\left(n_{n}\right)$ | 17 |
| :---: | :---: |
| used types of components | R, NPN, PNP, Vccp, Vccn |
| maximal number of resistors $\left(n_{\text {res }}\right)$ | 12 |
| maximal number of transistors NPN $\left(n_{\text {npn }}\right)$ | 14 |
| maximal number of transistors PNP $\left(n_{\text {pnp }}\right)$ | 14 |
| maximal number of nodes connected to Vccp $\left(n_{\text {vccp }}\right)$ | 6 |
| maximal number of nodes connected to Vccn $\left(n_{v c c n}\right)$ | 6 |
| negative resistors | not allowed |
| size of $P\left(n_{i}\right)$ | 400 |
| size of $P_{g}\left(n_{g}\right)$ | 200 |
| generations per run $\left(n_{\text {gen }}\right)$ | 3000 |
| number of objective function evaluations $\left(n_{\text {evals }}\right)$ | 1.5 e 6 |
| probability of parameters optimization $\left(P_{L S A}\right)$ | 0.15 |
| number of optimized individuals $\left(n_{\text {opt }}\right)$ | 4 |
| number of function evaluations of LSA | 500 |

Tab. 11.4: Summary of the parameters of the proposed algorithm.

The proposed algorithm was executed in four parallel threads. Five runs per single thread. Therefore 20 runs of the proposed algorithm in total. Average run time of a single run was 14 hours. Average time of a single evaluation of the objective function was 0.0336 second. Results of the runs are presented in Tab. 11.5 .

| Tread 1 |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| id of run | 1 | 2 | 3 | 4 | 5 |  |
| cost value | 6.88 | 5.42 | 20.6 | 44.2 | 4.05 |  |


| Tread 2 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| id of run | 1 | 2 | 3 | 4 | 5 |
| cost value | 47.1 | 21.7 | 35.4 | 6.53 | 4.99 |

Tread 3

| Tread 3 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| id of run | 1 | 2 | 3 | 4 | 5 |
| cost value | 6.15 | 7.65 | 1.44 | 5.67 | 1.91 |


| Tread 4 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| id of run | 1 | 2 | 3 | 4 | 5 |
| cost value | 3.92 | 8.90 | 85.5 | 26.3 | 8.78 |

Tab. 11.5: Results of 20 runs of the proposed algorithm.

The best solution was found in run 3 of thread 3. Comparison of the output characteristics of the best solution and desired function (11.1) is presented in Fig. 11.11a. Since both curves in Fig. 11.11 are almost merged together, deviation of $U_{2}$ is presented in Fig. 11.11b,


Fig. 11.11: a) Comparison of the output voltage characteristic $U_{2}=f\left(U_{1}\right)$ of the best solution and desired function (11.1) b) deviation of the output voltage characteristic $U_{2}=f\left(U_{1}\right)$ of the best solution and function 11.1).

Netlist of the best solution obtained in the proposed experiments is presented in Fig. 11.12. Bipolar transistors NPN and PNP are denoted as bjtnpn and bjtpnp respectively. Default models were used for both types of the transistors. To reduce convergence problems caused by unconnected components and dangling terminals all nodes of the encoded analog circuit are connected to GND (node 0) through resistance $1 \mathrm{G} \Omega$ (resistors $\operatorname{Rg} 1$ to $\operatorname{Rg} 16$ ). Resistors $R_{i n}$ and $R_{L}$ are input and output resistances respectively and are set to $1 k \Omega$. Schematic corresponding to the netlist of the best evolved solution in Fig. 11.12 is presented in Fig. 11.13. Since transistors q1 and q11 have no function in the synthesized circuit (netlist in Fig. 11.12) these transistors were not used in the resulting schematic (Fig. 11.13). Voltage $V_{I N}$ and voltage on resistor $R_{L}$ are input and output voltages respectively (Fig. 11.13).

```
R1 1 15 4.7e+05
R2 2 6 5.6e+02
R3 4 6 1.5e+04
R4 6 11 6.8e+02
R5 8 11 2.7e+04
R6 10 16 4.7e+03
q1 0 5 4 bjtnpn
q2 3 11 1 bjtnpn
q3 2 14 12 bjtnpn
q4 15 3 7 bjtnpn
q5 4 14 9 bjtnpn
q6 6 14 12 bjtnpn
q7 8 0 2 bjtpnp
q8 7 4 0 bjtpnp
q9 11 0 8 bjtpnp
q10 11 8 0 bjtpnp
q11 13 9 0 bjtpnp
q12 9 16 0 bjtpnp
q13 6 1 14 bjtpnp
q14 4 10 9 bjtpnp
q15 16 6 8 bjtpnp
q16 14 15 8 bjtpnp
Rn1 12 nvccn 1e-3 .dc vin -0.25 0.25 0.025
Rp1 10 nvccp 1e-3 .save v(2)
Rg1 1 0 1e9 .end
Rg2 2 0 1e9
```

Fig. 11.12: Netlist of the best solution.


Fig. 11.13: Schematic of the best solution.

### 11.9 Comparison to Other Methods

As was stated above the problem of circuit realization of cube root function which was introduced by Koza et al. in [57] was adopted also by Sapargaliyev et al. in [17]. In [57] Koza et al. employed genetic programming (GP) approach. In [17] unconstrained genetic algorithm with oscillating length representation (GA OLG) was used. Comparison of the best solutions of both mentioned authors and the best solution of the proposed method GhEDA is presented in Tab. 11.6.

| method | best cost | objective function evaluations |
| :---: | :---: | :---: |
| GP (Koza et al. [57]) | 1.68 | 37 e 6 |
| GA OLG (Sapargaliyev et al. in [17]) | 2.27 | 4 e 6 |
| GhEDA | 1.44 | 1.5 e 6 |

Tab. 11.6: Comparison of the results of GhEDA to GP and GA OLG.

As can be seen in Tab. 11.6 proposed method GhEDA overperforms other two methods in terms of accuracy of the best solution and number of required objective function evaluations as well. Comparison of the number of the components of the best synthesized circuits of methods GP, GA OLG and GhEDA is presented in Tab. 11.7.

| method | GP | GA OLG | GhEDA |
| :---: | :---: | :---: | :---: |
| number of transistors | 36 | 24 | 14 |
| number of resistors | 12 | 12 | 7 |
| number of diodes | 2 | 2 | 0 |

Tab. 11.7: Comparison of the number of the components of the best solutions of methods GP, GA OLG and GhEDA.

As can be seen from Tab. 11.7 the complexity of the synthesized circuit was highest for GP. Method GA OLG was able to reach circuit of lower complexity compared to GP. The best result was achieved using GhEDA method which was able to synthesize circuit twice smaller than circuit produced using GP.

### 11.10 Conclusion

There was presented graph based hybrid estimation of distribution algorithm (GhEDA). Its synthesis capability was demonstrated on problem of circuit realization of cube root function. Results of the proposed method were compared to results of Koza et al. (GP) [57] and Sapargaliyev et al. (GA OLG) [17] who adopted the same problem of cube root function circuit realization. Experiments have shown that in terms of accuracy of the solution and number of required objective function evaluations the proposed method overperforms both other methods.

The proposed method employs simple univariate probabilistic model based on the assumption that there are no dependencies between the variables of the solution vector. Although the presented experiments have shown that the used probabilistic model was suitable for the proposed method univariate probabilistic model can be replaced by more advanced multivariate probabilistic model which is capable to capture higher order dependencies between the variables of the solution vector. This might be interesting and promising area of another research. Since some multivariate models can incorporate some portion of previous knowledge (prior) another interesting area of the future research might be usage of different priors based on the target application of the synthesized circuit.

Since the proposed method is population based evolutionary algorithm, multiobjective approach as pareto ranking can be incorporated into the method. Also parallel computation of the cost values of the individuals of the population can be applied.

## 12 SUMMARY AND FUTURE DIRECTIONS

In many areas of evolutionary computation Estimation of Distribution Algorithms (EDA) deliver great performance and overperform classical genetic algorithms. Also in the area of automated analog circuit synthesis methods EDA algorithms produce very good results.

Three different methods of automated analog circuit synthesis based on EDA algorithms were proposed, described and verified. As was stated in section 2.3 the two tasks of analog circuit synthesis problem - synthesis of the topology and determination of the parameters can be solved separately or simultaneously. While synthesis of the topology is combinational optimization problem determination of the parameters is continuous optimization problem in nature.

Simultaneous solving of the problem brings a demand of careful design of the encoding method which allows to combine different requirements of both parts of the problem (synthesis of the topology and determination of the parameters).

The first proposed method employs simultaneous solving of the problem. To enable UMDA to solve this problem continuous part of the problem (parameters of the components) is discretized.

Another possibility of solving automated analog circuit synthesis problem is employing of probabilistic models of mixed type as Bayesian networks for variables of mixed discrete/continuous type. Probabilistic model for variables of mixed type was used in algorithm MBOA [45] however experimentation with using MBOA for problems of analog circuit synthesis has not brought satisfactory results. However there are some another possibilities of solving problems of mixed discrete/continuous type (mixtures of distributions, clustering, heterogeneous factorized models (some factors are continuous and some are discrete)). This is one of the areas of possible future research.

The second approach to the automated analog circuit synthesis - separate solving of the topology and the parameters was used in the last two proposed methods. In the first step the candidate topology is chosen using EDA method. In the second step the parameters (the values of the components) of the selected topology were determined using local optimization algorithm. Strong advantage of the separate solving is that this approach allows to use completely different and independent methods for the topology selection and for the parameters determination. From the viewpoint of easy implementation and variability the separate solving approach is advantageous compared to the simultaneous solving.

Another interesting area of the research is utilization of multivariate probabilistic models which are capable to capture higher order dependencies between variables of the solution vectors.

Some of the probabilistic models enable to incorporate some portion of previous knowledge about the problem (priors). Experiments in the area of utilization of different prior informations based on the type of the target application of the analog circuit can be another interesting area of another future research.

## 13 IMPLEMENTATION NOTES

There have been used several tools and toolboxes which enable proper analysis of the proposed evolutionary electronic methods or estimation of distribution algorithms generally.

All experiments presented in the thesis were performed on 64-bit dual core PC with processor AMD Athlon II X2 245, 8GB RAM. The first two problems (Evolutionary Synthesis of Chaotic Dynamics Using Pure UMDA and Synthesis of Fractional Capacitor Using Hybrid UMDA Algorithm) were implemented in 64-bit version of Matlab 7.8.0 (R2009a) and operational system Ubuntu 12.04. The third problem (Synthesis of Cube Root Function Using Graph EDA Method) was implemented in 64-bit version of Matlab 8.0 (R2012b) and operational system Centos 6.5.

### 13.1 MATEDA 2.0

There are three main parts of MATEDA 2.0 toolbox [59. The first one is focused on realization of various types of Estimation of Distribution Algorithms as for example UMDA, FDA, EBNA and MOA. Single-objective and also multi-objective problems can be solved. The second part allows analysis and visualization of particular features of the learned probabilistic models. Last part allows to use the probabilistic models as fitness modeling tools. MATEDA 2.0 toolbox is based on Bayes Net Toolbox for Matlab (BNT package) and Structure Learning Package for Bayes Net Toolbox (BNT SLP package).

### 13.2 BNLEARN

BNLEARN [60] is R package which allows to learn graphical structure of Bayesian networks, estimate theirs parameters and compute inference. The package implements several constraint-based structure learning algorithms, score-based structure learning algorithms, hybrid structure learning algorithms, local discovery algorithms and Bayesian network classifiers.

### 13.3 DEAL

DEAL [61] is R package which allows to learn Bayesian networks with variables of discrete, continuous or mixed discrete/continuous types. Compared to package

BNLEARN, the package DEAL is able to learn networks with variables of mixed types.

### 13.4 COPULAEDAS

This R package allows to implement various types of estimation of distribution algorithms based on copulas and vines. Using the package behavior of the algorithms can be studied and new algorithms can be implemented 62].

### 13.5 NGSPICE

NGSPICE is open source mixed-level/mixed-signal circuit simulator based on Spice3f5, Cider1b1 and Xspice packages. The package is very useful especially in connection with operational system Linux. The features of the simulator are comparable to commercial circuit simulator hspice. For purposes of research or experiments Ngspice can be used as very good open source alternative to commercial hspice. Simulated circuit is represented in the form of NETLIST.

### 13.6 HSPICE

HSPICE is commercial spice based circuit simulator which can be considered as industry's standard for accurate circuit simulation. As for any other spice based circuit simulator, simulated circuit is represented in the form of NETLIST.

## REFERENCES

[1] DOBOLI, A., VEMURI, R. Exploration based High Level Synthesis of Linear Analog Systems Operating at Low/Medium Frequencies. IEEE Transactions on CAD, 2003, Vol. 22, No. 11, pp. 1556-1568.
[2] THOMPSON, A., LAYZELL, P. Analysis of unconventional evolved electronics. Communications of the ACM, 1999, Vol. 42, No. 4, pp. 71-79.
[3] SLEZÁK, J., PETRŽELA, J., ŠOTNER, R. On the derivation of Piecewise-Linear Chaotic Oscillators using Simulated Annealing Method and Hspice. Przeglad Elektrotechniczny, 2011, vol. 87, no. 1, pp. 262-265, ISSN 0033-2097.
[4] SLEZÁK, J., PETRŽELA, J., ŠOTNER, R. Evolutionary Synthesis of Fractional Capacitor Using Simulated Annealing Method. Radioengineering, 2012, vol. 21, no. 4, pp. 1252-1259, ISSN 0033-2097.
[5] SLEZÁK, J. Evolutionary Synthesis of Analog Electronics Using Simulated Annealing. In Proceedings of Student Conference EEICT 2012, Brno, 2012, pp. 25-30.
[6] SLEZÁK, J. Evolutionary Synthesis of Chaotic Dynamics Using Univariate Marginal Distribution Algorithm. In Proceedings of Student Conference EEICT 2013, Brno, 2013, pp. 19-23.
[7] DEGRAUWE, M. G. R., NYS, O., DIJKSTRA, E., RIJMENANTS, J., BITZ, S., GOFFART, B. L. A. G., VITTOZ, E. A., CSERVENY, S., MEIXENBERGER, C., VAN DER STAPPEN, G., OGUEY, H. J. IDAC: an interactive design tool for analog CMOS circuits.IEEE Journal of Solid-State Circuits, 1987, vol. 22, no. 6, pp. 1106-1116.
[8] HARJANI, R. OASYS: a framework for analog circuit synthesis. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, 1989, vol. 8, no. 12, pp. 12471266. ISSN 0278-0070.
[9] KOH, H. Y., SEQUIN, C. H., GRAY, P. R. OPASYN: a compiler for CMOS operational amplifiers. IEEE Transactions on Computer-Aided Design of Integrated Circuits and Systems, 1990, vol. 9, no. 2, pp. 113-125.
[10] KRUISKAMP, W., LEENAERTS, D. DARWIN: CMOS opamp Synthesis by Means of a Genetic Algorithm. 32nd Conference on Design Automation DAC'95, CA: San Francisco, 1995, pp. 433-438, ISBN 0-89791-725-1.
[11] DAVIS, M., LIU, L., ELIAS, J. G. VLSI circuit synthesis using a parallel genetic algorithm. Proceedings of the First IEEE Conference on Evolutionary Computation,FL: Orlando, 1994, pp. 104-109, ISBN 0-7803-1899-4.
[12] CHANG, S. J., HOU, H. S., SU, Y. K. Automated passive filter synthesis using a novel tree representation and genetic programming. IEEE Transactions on Evolutionary Computation, 2006, vol. 10, no. 1, pp. 93-100.
[13] GRIMBLEBY, J. B. Automatic analogue network synthesis using genetic algorithms. In Proceeding of First International Conference on Genetic Algorithms in Engineering Systems: Innovations and Applications (GALESIA), Sheffield, 1995, pp. 5358.
[14] GRIMBLEBY, J.B. Hybrid Genetic Algorithms for Analogue Network Synthesis, Proceedings of the 1999 Congress on Evolutionary Computation CEC 99, DC: Washington, 1999, ISBN 0-7803-5536-9.
[15] LOHN, J. D., COLOMBANO, S. P. A circuit representation technique for automated circuit design. IEEE Transactions on Evolutionary Computation, 1999, vol. 3, no. 3, pp. 205-219.
[16] ZEBULUM, R. S., PACHECO, M. A., VELLASCO, M. M. Evolutionary Electronics: Automatic Design of Electronic Circuits and Systems by Genetic Algorithms, Florida: CRC Press, 2001, ISBN 0-8493-0865-8.
[17] SAPARGALIYEV, Y., KALGANOVA, T. Unconstrained Evolution of Analogue Computational QR Circuit with Oscillating Length Representation. In proceeding of: Evolvable Systems: From Biology to Hardware ICES 2008, Czech Republic: Prague, 2008, pp. 1-10.
[18] ANDO, S., IBA, H. Analog circuit design with a variable length chromosome. Proceedings of Congress on the Evolutionary Computation, CA: La Jolla, 2000, vol. 2, pp. 994-1001.
[19] AGGARWAL, V. Evolving sinusoidal oscillators using genetic algorithms. Proceedings of NASA/DoD Conference on Evolvable Hardware, 2003, pp. 67-76.
[20] MATTIUSSI, C., FLOREANO, D. Analog Genetic Encoding for the Evolution of Circuits and Networks, IEEE Transactions on Evolutionary Computation, 2007, Vol. 11, No. 5, pp. 596-607.
[21] DAS, A., VEMURI, R. GAPSYS: A GA-Based tool for automated passive analog circuit synthesis. in Proc. of IEEE International Symposium on Circuits and Systems (ISCAS), 2007, pp. 2702-2705.
[22] DAS, A., VEMURI, R. Topology synthesis of analog circuits based on adaptively generated building blocks. in Proc. of IEEE/ACM Design Automation Conference (DAC),CA: Anaheim, 2008, pp. 44-49, ISBN 978-1-60558-115-6.
[23] DAS, A., VEMURI, R. A Graph Grammar Based Approach to Automated Multi-Objective Analog Circuit Design. In Proc. of Design, Automation, and Test in Europe (DATE), France: Nice, 2009, pp. 700-705, ISBN 978-1-4244-3781-8 .
[24] MESQUITE, A., SALAZAR, F. A., CANAZIO, P. P. Chromosome representation through adjacency matrix in evolutionary circuits synthesis. Proceedings of NASA/DoD Conference on Evolvable Hardware, 2002, pp. 102-109.
[25] DE SÁ, L. B., Pedro, F. V., MESQUITA, A. Evolutionary Synthesis of Low-Sensitivity Antenna Matching Networks using Adjacency Matrix Representation. Proceedings of the Eleventh conference on Evolutionary Computation,Trondheim, 2009, pp. 1201-1208, ISBN 978-1-4244-2958-5.
[26] LARRAÑAGA, P., LOZANO, J. Estimation of Distribution Algorithms: A New Tool for Evolutionary Computation, Kluwer Academic Publishers, 2002.
[27] MÜHLENBEIN, H., PAAß, G. From Recombination of Genes to the Estimation of Distributions I. Binary Parameters, In Lecture Notes in Computer Science 1411: Parallel Problem Solving from Nature - PPSN IV, pp. 178-187.
[28] ZINCHENKO, L., MÜHLENBEIN, H., KUREICHIK, V., MAHNING, T. Application of the univariate marginal distribution algorithm to analog circuit design. Proceedings of NASA/DoD Conference on Evolvable Hardware, 2002, pp. 93-101.
[29] ZINCHENKO, L., RADECKER, M., BISOGNO, F. Multi-Objective Univariate Marginal Distribution Optimisation of Mixed Analogue-Digital Signal Circuits. in Proceedings of Genetic and Evolutionary Computation Conference (GECCO 2007), England: London, 2007, pp. 2242-2249, ISBN 978-1-59593-697-4.
[30] TORRES, A., PONCE, E. E., TORRES, M. D., DIAZ, E., PADILLA, F. Comparison of Two Evolvable Systems in the Automated Analog Circuit Synthesis. Eighth Mexican International Conference on Artificial Intelligence (MICAI 2009), Guanajuato, 2009, pp. 3-8, ISBN 978-0-7695-3933-1.
[31] KOZA, J. R., BENETT III, F. H., ANDRE, D., KEANE, M. A. Automated WYSIWYG Design of both the topology and component values of electrical circuits using genetic programming. In Proceedings of the First Annual Conference on Genetic Programming, 1996, pp. 123-131.
[32] KOZA, J. R. Genetic Programming: On the Programming of Computers by Means of Natural Selection, Cambridge: MIT Press, 1994.
[33] KOZA, J. R., ANDRE, D., BENNETT III, F. H., KEANE, M. Genetic Programming 3: Darwinian Invention and Problem Solving, San Francisco: Morgan Kaufman, 1999.
[34] KOZA, J. R., KEANE, M. A., STREETER, M. J., MYDLOWEC, W., YU, J., LANZA, G. Genetic Programming IV: Routine Human-Competitive Machine Intelligence, Kluwer Academic Publishers, 2003.
[35] STARZYK, J. A. Topological Analysis and Diagnosis of Analog Circuits, Gliwice, Wydawnictwo Politechniki Ślaskiej, 2007.
[36] KOTON, J., VRBA, K. Method for Designing Frequency Filters using Universal Current Conveyors. International Transactions on Computer Science and Engineering, 2005, Vol. 13, No. 1, pp. 144-154.
[37] VOCHYÁN, J. Synthesis of New Biquad Filters Using Two CFOAs, Radioengineering, 2006, vol. 15, no. 4, pp. 76-79, ISSN 1210-2512.
[38] BIOLEK, D., VRBA, K., ČAJKA, J., DOSTÁL, T. General three-port current conveyor: a useful tool for network design, Journal of ELECTRICAL ENGINEERING, 2000, vol. 51, no 1-2, pp. 36-39.
[39] DOSTÁL, T., VRBA, K., ČAJKA, J. On Multi-port Current Conveyors, In Proceedings of the 4 th WSEAS international conference on Applications of electrical engineering (AEE'05), Wisconsin: Stevens Point, 2005, pp. 261-264, ISBN:960-8457-13-0.
[40] PELIKAN, M., MÜHLENBEIN, H. The bivariate marginal distribution algorithm. In Advances in Soft Computing Engineering Design and Manufacturing, London:Springer-Verlag, 1999, pp. 521535.
[41] BALUJA, S. Population-Based Incremental Learning: A method for integrating genetic search based function optimization and competitive learning. Technical report, 1994, Carnegie Mellon Report.
[42] HARIK, G. R., LOBO, F. G., GOLDBERG, D. E. The compact Genetic Algorithm. IEEE Transactions on Evolutionary Computation, 1999, pp. 287297.
[43] MÜHLENBEIN, H., MAHNIG, T., OCHOA, A. Schemata, distributions and graphical models in evolutionary optimization. Journal of Heuristics, 1999, pp. 215247.
[44] PELIKAN, M., GOLDBERG, D. E., CANTÚ-PAZ, E. BOA: The Bayesian optimization algorithm, Morgan Kaufmann, 1999, pp. 525532.
[45] OČENÁŠEK, J., SCHWARZ, J. Estimation Distribution Algorithm for mixed continuousdiscrete optimization problems. In Proceedings of the 2nd Euro-International Symposium on Computational Intelligence, 2002, pp. 227-232, ISBN 1-58603-256-9.
[46] OČENÁŠEK, J., KERN, S., HANSEN, N., MÜLLER, S., KOUMOUTSAKOS, P. A Mixed Bayesian Optimization Algorithm with Variance Adaptation. Lecture Notes in Computer Science, 2004, pp. 352-361, ISBN 3-540-23092-0.
[47] CHICKERING, D. M., HECKERMA, D., MEEK, C. A Bayesian approach to learning Bayesian networks with local structure. Technical Report MSR-TR-97-07, 1997, Redmond: Microsoft Research.
[48] SANTANA, R., OCHOA, A., SOTO, M. R. Factorized Distribution Algorithms for functions with unitation constraints. In Proceedings of the Third Symposium on Adaptive Systems (ISAS-2001), 2001, pp. 158-165.
[49] LOZADA-CHANG, L., SANTANA, R. Univariate marginal distribution algorithm dynamics for a class of parametric functions with unitation constraints, Information Sciences, 2011, vol. 181, no. 11, pp. 2340-2355.
[50] EL-MIHOUB, T. A., HOPGOOD, A. A., NOLLE, L., BATTERSBY, A. Hybrid Genetic Algorithms: A Review. Engineering Letters, 2006, vol. 13, no. 2, pp. 124-137, ISSN: 1816093X.
[51] POSPÍŠIL, J., KOLKA, Z., HORSKÁ, J., BRZOBOHATÝ, J. Simplest ODE Equivalents of Chua s Equations. International Journal of Bifurcation and Chaos, 2000, vol. 10, no. 1, ISSN 0218-1274.
[52] TOH, M. Synthesis of electronic circuits for simulating nonlinear dynamics. International Journal of Bifurcation and Chaos, 2001, vol. 11, no. 3, pp. 605653.
[53] CARLSON, G. E., HALIJAK, C. A. Approximation of Fractional Capacitors $(1 / \mathrm{s}) 1 / \mathrm{n}$ by a Regular Newton Process. IEEE Trans. On Circuit Theory, 1964, Vol. 11, No. 2, pp. 210-213, ISSN 0018-9324.
[54] HARTLEY, T., LORENZO, C., QAMMER, H. K. Chaos in a Fractional Order Chua's System. IEEE Trans. on CAS-I: Fund. Theory and Applications, 1995, Vol. 42, No. 8, pp. 485-490, ISSN 1057-7122.
[55] STEIGLITZ, K. An RC Impedance Approximantion to s ${ }^{1 / 2}$. IEEE Trans. On Circuit Theory, 1964, Vol. 11, No. 1, ISSN 0018-9324.
[56] ORTIGUEIRA, M. D. An Introduction to the Fractional Continuous Time Linear Systems, IEEE Circuits and Systems Magazine, 2008, Vol. 8, No. 3, pp. 19-26, ISSN 1531-636X.
[57] KOZA, J. R., BENNETT, F. H., FORREST, H., LOHN, J., DUNLAP, F., ANDRE, D., KEANE, M. A. Automated synthesis of computational circuits using genetic programming. In: IEEE conference on evolutionary computation,IN: Indianapolis, 1997, pp. 447452, ISBN 0-7803-3949-5.
[58] HANDA, H. Use of graph kernels in Estimation of Distribution Algorithms. In: IEEE congress on evolutionary computation (CEC), QLD: Brisbane, 2012, pp. 1-6, ISBN 978-1-4673-1510-4.
[59] SANTANA, R., ECHEGOYEN, C., MENDIBURU, A., BIELZA, C., LOZANO, J. A., LARRAÑAGA, P., ARMAÑANZAS, R., SHAKYA, S. MATEDA: A suite of EDA programs in Matlab. Technical Report EHU-KZAA-IK-2/09,2009, University of the Basque Country.
[60] SCUTARI, M. Learning Bayesian Networks with the bnlearn R Package. Journal of Statistical Software, 2010, vol. 35, no. 3, pp. 1-22, 2010.
[61] BTTCHER, S. G., DETHLEFSEN, C. DEAL: A Package for Learning Bayesian Networks, Journal of Statistical Software, 2003, vol. 8, no. 20, pp. 200-208.
[62] GONZÁLES-FERNÁNDEZ, Y., SOTO, M. Copulaedas: Estimation of Distribution Algorithms Based on Copula Theory, R package version 1.0.1 (2011), http://CRAN.Rproject.org/package=copulaedas.

## ABBREVIATIONS

| AC | Autonomous Circuit |
| :--- | :--- |
| AGE | Analog Genetic Coding |
| AMBOA | Adaptive Mixed Bayesian Optimization Algorithm |
| BDe | Bayesian Dirichlet Equivalence |
| BJT | Bipolar Junction Transistor |
| BMDA | Bivariate Marginal Distribution Algorithm |
| BOA | Bayesian Optimization Algorithm |
| CART | Classification and Regression Tree |
| CFDA | Constraint Factorization Distribution Algorithm |
| CFOA | Current Feedback Operational Amplifier |
| cGA | Compact Genetic Algorithm |
| EBNA | Estimation of Bayesian Network Algorithm |
| EDA | Estimation of Distribution Algorithm |
| FDA | Factorization Distribution Algorithm |
| FPTA | Field Programmable Transistor Array |
| GA | Genetic Algorithm |
| GCC | General Three Port Current Conveyor |
| GhEDA | Graph Hybrid Estimation of Distribution Algorithm |
| GP | Genetic Programming |
| hBOA | Hierarchical Bayesian Optimization Algorithm |
| HW | Hardware |
| ILG | Increasing Length Genotype |
| LSA | Local Search Algorithm |
| MBOA | Mixed Bayesian Optimization Algorithm |
| MOA | Markovian Optimization Algorithm |
| OLG | Oscillation Length Genotype |
| OTA | Operational Transconductance Amplifier |
| PBIL | Population Based Incremental Learning Scale Integration |
| PLS | Probabilistic Logic Sampling |
| PMBGA | Population Model-Building Genetic Algorithms |
| PWL | Piece-Wise Linear |
| RF | Radio Frequency |
| RLC | Resistors, Inductors and Capacitors |
| SA | Simulated Annealing |
| SoC | A System On Chip |
| SUS | Utochastic Universal Sampling |
| UDIP | UMDA |


| $\Delta_{m}$ | difference of magnitude |
| :---: | :---: |
| $\Delta_{p}$ | difference of phase |
| $b 1, b 2, \ldots b x$ | bits of encoding vector |
| $C_{\text {act }}$ | analog circuit consisting of transistors |
| $C_{e}$ | analog circuit corresponding to graph $G_{\text {cpe }}$ |
| $C_{h}$ | analog circuit corresponding to hypergraph $G_{h}$ |
| $C_{m}$ | analog circuit corresponding to multigraph $G_{m}$ |
| $C_{m t}$ | analog circuit of mixed type (passive components and transistors) |
| $C_{p}$ | analog circuit corresponding to graph $G_{p}$ |
| $C_{\text {pas }}$ | analog circuit consisting of passive components |
| $C_{s}$ | analog circuit corresponding to graph $G_{s}$ |
| $C_{t}$ | analog circuit corresponding to hypergraph $G_{t}$ |
| cost | cost value |
| $c_{1}$ | cost value of the solution before execution of LSA |
| $c_{2}$ | cost value of the solution after execution of LSA |
| $d b l 1, \ldots, d b l x$ | parameters of encoding vector |
| $E_{a}$ | set of edges of graph $G_{a}$ |
| $E_{a}^{\prime}$ | set of edges of graph $G_{a}^{\prime}$ |
| $E_{c p}$ | set of edges of graph $G_{c p}$ |
| $E_{c t}$ | set of hyperedges of hypergraph $G_{c t}$ |
| $E_{h}$ | set of labeled edges of hypergraph $G_{h}$ |
| $E_{m}$ | set of parametrized edges of multigraph $G_{m}$ |
| $E_{s}$ | set of parametrized edges of graph $G_{s}$ |
| $e$ | encoding vector |
| $e_{0}, e_{2}, \ldots e_{x}$ | edge of graph or hyperedge of hypergraph |
| $e_{h}, e_{h 1}, e_{h 2}$ | characteristic vector of 3-uniform hypergraph |
| $e_{h l}$ | characteristic vector of labeled 3-uniform hypergraph |
| $e_{m}$ | characteristic vector of multigraph |
| $e_{n p n}$ | encoding vector representing topology of NPN transistors |
| $e_{p}$ | encoding vector of topology of passive circuit |
| $e_{p n p}$ | encoding vector representing topology of PNP transistors |
| $e_{p s}$ | parameters storage vector |
| $e_{\text {res }}$ | encoding vector representing topology of resistors |
| $e_{s}, e_{s 1}, e_{s 2}$ | characteristic vector of simple graph |
| $e_{t}$ | encoding vector of topology of circuit consisting of transistors |
| $e_{v c c p}$ | encoding vector of connection of positive voltage sources |
| $e_{v c c}$ | encoding vector of connection of negative voltage sources |
| $f_{m c}$ | magnitude function of the current solution |
| $f_{m d}$ | desired magnitude function |
| $f_{p c}$ | phase function of the current solution |
| $f_{p d}$ | desired phase function |


| $f_{v c}$ | voltage function of the current solution |
| :---: | :---: |
| $f_{v d}$ | desired voltage function |
| $G_{a}$ | generic floating graph with self-loops |
| $G_{a}^{\prime}$ | graph corresponding to adjacency matrix representation |
| $G_{a c t}$ | graph representation of active part of a mixed type circuit |
| $G_{c}$ | complete graph corresponding to multigraph $G_{m}$ |
| $G_{c p}$ | complete graph of representation of passive circuit |
| $G_{\text {cpe }}$ | complete expanded graph (topology of passive circuit) |
| $G_{c t}$ | complete 3-uniform hypergraph (topology of transistors) |
| $G_{h}$ | 3 -uniform hypergraph |
| $G_{h c}$ | complete 3-uniform hypergraph |
| $G_{h l}$ | 3 -uniform labeled hypergraph |
| $G_{m}$ | multigraph |
| $G_{n p n}$ | 3-uniform hypergraph representing topology of NPN transistors |
| $G_{n p n c}$ | complete hypergraph of representation of topology of NPN transistors |
| $G_{p}$ | graph representing topology of passive circuit |
| $G_{p a s}$ | graph representation of passive part of a mixed type circuit |
| $G_{p n p}$ | 3 -uniform hypergraph representing topology of PNP transistors |
| $G_{\text {res }}$ | graph representing topology of resistors |
| $G_{\text {resc }}$ | complete graph of representation of topology of resistors |
| $G_{s}, G_{s 1}, G_{s 2}$ | simple graph |
| $G_{s c}$ | complete graph corresponding to simple graph $G_{s}$ |
| $G_{t}$ | 3 -uniform hypergraph (topology of connection of transistors) |
| $G_{v c c n}$ | graph representing connection of $V_{c c n}$ |
| $G_{v c c p}$ | graph representing connection of $V_{c c p}$ |
| $I, I(i)$ | individual of population |
| $k$ | counter of generations |
| LSevals | number of objective function evaluations for LSA (one generation) |
| M, M(k) | probabilistic model |
| $M_{a}$ | adjacency matrix corresponding to graph $G_{a}$ |
| $M_{a}^{\prime}$ | adjacency matrix corresponding to graph $G_{a}^{\prime}$ |
| MaxFunEvals | number of objective function evaluations of LSA (one run) |
| MaxGen | maximal number of generations per run |
| $m$ | number of points of frequency response |
| $m_{i j}$ | component of adjacency matrix $M_{a}$ |
| $N_{h}$ | set of the nodes of analog circuit $C_{h}$ |
| $N_{m}$ | set of the nodes of analog circuit $C_{m}$ |
| $N_{p}$ | set of nodes of passive analog circuit |
| $N_{s}$ | set of nodes of analog circuit $C_{s}$ |
|  | length of encoding vector |


| $n_{0}, n_{2}, \ldots n_{x}$ | node of analog electronic circuit |
| :---: | :---: |
| $n_{\text {adm }}$ | number of generalized admittances of AC |
| $n_{c}$ | maximal number of the components of the desired circuit |
| $n_{e}$ | number of edges or hyperedges |
| $n_{\text {edgcpe }}$ | number of edges of expanded complete graph $G_{\text {cpe }}$ |
| $n_{\text {edgnpn }}$ | number of hyperedges of hypergraph $G_{n p n}$ |
| $n_{\text {edgres }}$ | number of edges of complete graph $G_{\text {resc }}$ |
| $n_{\text {evals }}$ | number of objective function evaluations |
| $n_{\text {gen }}$ | number of generations |
| $n_{h l}$ | length of vector $e_{h l}$ |
| $n_{i}$ | size of population |
| $n_{m}$ | number of multiple edges of multigraph |
| $n_{n}$ | number of nodes of an analog circuit |
| $n_{\text {npn }}$ | maximal number of NPN transistors of the desired circuit |
| $n_{\text {opt }}$ | number of optimized individuals |
| $n_{p}$ | number of ports of generalized admittance |
| $n_{p n p}$ | maximal number of PNP transistors of the desired circuit |
| $n_{\text {res }}$ | maximal number of resistors of the desired circuit |
| $n_{s c}$ | size (number of edges) of graph $G_{s c}$ |
| $n_{v c c n}$ | maximal number of nodes connected to $V_{c c n}$ |
| $n_{v c c p}$ | maximal number of nodes connected to $V_{\text {ccp }}$ |
| $P, P(k)$ | population of individuals |
| $P_{1}$ | set of parameters before execution of LSA |
| $P_{2}$ | set of parameters after execution of LSA |
| $P_{\text {add }}$ | probability of adding edges using probabilistic model $M$ |
| $P_{g}, P_{g}(k)$ | population of generated individuals (samples) |
| $P_{L S A}$ | probability of execution of LSA |
| $P_{n}, P_{n} k$ | new population |
| $P_{\text {rem }}$ | probability of removing edges and hyperedges |
| $P_{s}, P_{s}(k)$ | selected population of individuals |
| PopEvals | number of objective function evaluations (for evaluation of $P$ ) |
| PopSize | size of population |
| $p 1, p 2, \ldots p 135$ | parameters loaded from $e_{p s}$ |
| $p_{l}(x)$ | probabilistic vector |
| $Q_{h}$ | set of labels of hyperedges $E_{h}$ |
| $Q_{m}$ | set of labels of edges $E_{m}$ |
| $Q_{s}$ | set of parameters of edges $E_{s}$ |
| $q_{1}, \ldots, q_{x}$ | parameter of parametrized edge or hyperedge |
| $r$ | parameter loaded from $e_{p s}$ |
| $r_{l ; i}\left(x_{i}\right)$ | marginal frequency |
| $S_{l}$ | set of parameters loaded from $e_{p s}$ |
| $S_{p}$ | set of variables of e consisting information about parameters |
| $S_{t}$ | set of variables of e consisting information about topology |


| $s_{n p n}$ | sorted information of vector $v_{n p n}$ |
| :---: | :---: |
| $s_{p n p}$ | sorted information of vector $v_{p n p}$ |
| $s_{\text {res }}$ | sorted information of vector $v_{\text {res }}$ |
| $s_{v c c n}$ | sorted information of vector $v_{v c c}$ |
| $s_{v c c p}$ | sorted information of vector $v_{v c c}$ |
| $U_{2}$ | output voltage |
| $u(x)$ | unitation value |
| $V_{a}$ | set of vertices of graph $G_{a}$ |
| $V_{a}^{\prime}$ | set of vertices of graph $G_{a}^{\prime}$ |
| $V_{c c n}$ | negative voltage source |
| $V_{\text {ccp }}$ | positive voltage source |
| $V_{c p}$ | set of vertices of graph $G_{c p}$ |
| $V_{c t}$ | set of vertices of hypergraph $G_{c t}$ |
| $V_{h}$ | set of vertices of hypergraph $G_{h}$ |
| $V_{m}$ | set of vertices of multigraph $G_{m}$ |
| $V_{s}$ | set of vertices of graph $G_{s}$ |
| $v_{0}, v_{2}, \ldots v_{x}$ | vertex of graph or hypergraph |
| $v_{\text {exp }}$ | value of exponent |
| $v_{i n}, U_{1}$ | input voltage |
| $v_{\text {man }}$ | value of mantissa |
| $v_{\text {mult }}$ | value of multiplier |
| $v_{n p n}$ | vector of marginal frequencies of NPN transistors |
| $v_{p n p}$ | vector of marginal frequencies of PNP transistors |
| $v_{\text {res }}$ | vector of marginal frequencies of resistors |
| $v_{\text {type }}$ | type of the component |
| $v_{v c c}$ | vector of marginal frequencies of nodes connected to $V_{c c n}$ |
| $v_{v<c}$ | vector of marginal frequencies of nodes connected to $V_{c c p}$ |
| val | value of a component |
| val ${ }_{\text {max }}$ | maximal value of a component |
| val $_{\text {min }}$ | minimal value of a component |
| $w_{c m}$ | weight of difference of magnitude |
| $w_{c p}$ | weight of difference of phase |
| $w_{d m}(i)$ | weight values for differences of magnitude |
| $w_{d p}(i)$ | weight values for differences of phase |
| $w_{v}$ | weight of cube root objective function |
| $Y_{1}, Y_{2}, \ldots Y_{x}$ | generalized admittance |
| $Y(s)$ | admittance network |
| $Z_{i n}, Z_{i n 1}, Z_{i n 2}$ | input impedance function |

## CURRICULUM VITAE

## Personal Data:

Name:
Josef Slezák
Date of Birth:
June 17, 1982
Address:
Havlíčkova 1280, 76502 Otrokovice
E-mail:
xsleza08@stud.feec.vutbr.cz

## Education:

- 2007-2014: Brno University of Technology, Brno, Czech Republic.

Ph.D. Candidate, Electrical Engineering.
Thesis: "Evolutionary Synthesis of Analog Electronic Circuits Using EDA Algorithms".

Supervisor: prof. Ing. Tomás DOSTÁL, DrSc. .

- 2001-2007: Brno University of Technology, Brno, Czech Republic.

Master degree, Electrical Engineering.
Thesis: "Demonstration of Programmable Logic Devices".
Supervisor: Doc. Ing. Jaromír KOLOUCH, CSc.

## Selected Publications

SLEZÁK, J., PETRŽELA, J. Evolutionary Synthesis of Cube Root Computational Circuit Using Graph Hybrid Estimation of Distribution Algorithm. Accepted in Radioengineering.

SLEZÁK, J., PETRŽELA, J., ŠOTNER, R. Evolutionary Synthesis of Fractional Capacitor Using Simulated Annealing Method. Radioengineering, 2012, vol. 21, no. 4, pp. 1252-1259, ISSN 0033-2097.

SLEZÁK, J., PETRŽELA, J., ŠOTNER, R. On the derivation of Piecewise-Linear Chaotic Oscillators using Simulated Annealing Method and Hspice. Przeglad Elektrotechniczny, 2011, vol. 87, no. 1, pp. 262-265, ISSN 0033-2097.

SLEZÁK, J., ŠOTNER, R. Circuit synthesis using admittance network modification in MATLAB. In Proceedings of Conference on Mixed Design of Integrated Circuits and Systems (MIXDES'09), Poland: Lodz, 2009, pp. 613-617, ISBN 978-1-4244-4798-5.

SLEZÁK, J., PETRŽELA, J., ŠOTNER, R. Designing of arc oscillator using CFA amplifier. In Proceedings of $1^{\text {7 }}$ th International Electrotechnical Conference, Slovenija: Portorož, 2008, pp. 47-50, ISBN 1-58145-720-0.

