Introduction
The importance of the analogue part in integrated electronic systems cannot be overstressed. Despite its eminence, and unlike the digital design, the analogue design has not so far been automated to a great extent, mainly due to its towering complexity (Dastidar et al., 2005) . Analogue sizing is a very complicated, iterative and boring process whose automation is attracting great attention (Medeiro et al., 1994) . The analogue design and sizing process remains characterized by a mixture of experience and intuition of skilled designers (Tlelo-Cuautle & Duarte-Villaseñor, 2008) . As a matter of fact, optimal design of analogue components is over and over again a bottleneck in the design flow. Optimizing the sizes of the analogue components automatically is an important issue towards ability of rapidly designing true high performance circuits (Toumazou & Lidgey, 1993; Conn et al., 1996) . Common approaches are generally either fixed topology ones or/and statistical-based techniques. They generally start with finding a "good" DC quiescent point, which is provided by the skilled analogue designer. After that a simulation-based tuning procedure takes place. However these statistic-based approaches are time consuming and do not guarantee the convergence towards the global optimum solution (Talbi, 2002) . Some mathematical heuristics were also used, such as Local Search (Aarts & Lenstra, 2003) , Simulated Annealing (Kirkpatrick et al., 1983; Siarry(a) et al., 1997) , Tabu Search (Glover, 1989; Glover, 1990) , Genetic Algorithms (Grimbleby, 2000; Dréo et al., 2006) , etc. However these techniques do not offer general solution strategies that can be applied to problem formulations where different types of variables, objectives and constraint functions are used. In addition, their efficiency is also highly dependent on the algorithm parameters, the dimension of the solution space, the convexity of the solution space, and the number of variables. Actually, most of the circuit design optimization problems simultaneously require different types of variables, objective and constraint functions in their formulation. Hence, the abovementioned optimization procedures are generally not adequate or not flexible enough. In order to overcome these drawbacks, a new set of nature inspired heuristic optimization algorithms were proposed. The thought process behind these algorithms is inspired from the collective behaviour of decentralized, self-organized systems. It is known as Swarm Intelligence (SI) (Bonabeau et al. 1999) . SI systems are typically made up of a population of simple agents (or ''particles'') interacting locally with each other and with their environment. These particles obey to very simple rules, and although there is no centralized control structure dictating how each particle should behave, local interactions between them lead to the emergence of complex global behaviour. Most famous such SIs are Ant Colony Optimization (ACO) , Stochastic Diffusion Search (SDS) (Bishop, 1989) and Particle Swarm Optimization (PSO) (Kennedy & Eberhart, 1995; Clerc, 2006) . PSO, in its current form, has been in existence for almost a decade, which is a relatively short period when compared to some of the well known natural computing paradigms, such as evolutionary computation. PSO has gained widespread demand amongst researchers and has been shown to offer good performance in an assortment of application domains (Banks et al., 2007) . In this chapter, we focus on the use of PSO technique for the optimal design of analogue circuits. The practical applicability and suitability of PSO to optimize performances of such multi-objective problems are highlighted. An example of optimizing performances of a second generation MOS current conveyor (CCII) is presented. The used PSO algorithm is detailed and Spice simulation results, performed using the 'optimal' sizing of transistors forming the CCII and bias current, are presented. Reached performances are discussed and compared to others presented in some published works, but obtained using classical approaches.
The Sizing Problem
The process of designing an analogue circuit mainly consists of the following steps (Medeiro et al., 1994) :
• the topology choice: a suitable schematic has to be selected, • the sizing task: the chosen schematic must be dimensioned to comply with the required specifications, •
The generation of the layout. Among these major steps, we focus on the second one, i.e. the optimal sizing of analogue circuits. Actually, analogue sizing is a constructive procedure that aims at mapping the circuit specifications (objectives and constraints on performances) into the design parameter values. In other words, the performance metrics of the circuit, such as gain, noise figure, input impedance, occupied area, etc. have to be formulated in terms of the design variables (Tulunay & Balkir, 2004) . In a generic circuit, the optimization problem consists of finding optimal values of the ) ( X f r r ). Thus, a general optimization problem can be formulated as follows:
minimize : ) (x f r − . This goal is reached when the variables are located in the set of optimal solutions. For instance, a basic two-stage operational amplifier has around 10 parameters, which include the widths and lengths of all transistors values which have to be set. The goal is to achieve around 10 specifications, such as gain, bandwidth, noise, offset, settling time, slew rate, consumed power, occupied area, CMRR (common-mode rejection ratio) and PSRR (power supply rejection ratio). Besides, a set of DC equations and constraints, such as transistors' saturation conditions, have to be satisfied (Gray & Meyer, 1982) . The pictorial flow diagram depicted in Fig. 1 summarizes main steps of the sizing approach.
As it was introduced in section 1, there exist many papers and books dealing with mathematic optimization methods and studying in particular their convergence properties (see for example (Talbi, 2002; Dréo et al., 2006; Siarry(b) et al., 2007) ). These optimizing methods can be classified into two categories: deterministic methods and stochastic methods, known as heuristics.
Deterministic methods, such as Simplex (Nelder & Mead, 1965) , Branch and Bound (Doig, 1960) , Goal Programming (Scniederjans, 1995) , Dynamic Programming (Bellman, 2003) … are effective only for small size problems. They are not efficient when dealing with NP-hard and multi-criteria problems. In addition, it has been proven that these optimization techniques impose several limitations due to their inherent solution mechanisms and their tight dependence on the algorithm parameters. Besides they rely on the type of objective, the type of constraint functions, the number of variables and the size and the structure of the solution space. Moreover they do not offer general solution strategies. Most of the optimization problems require different types of variables, objective and constraint functions simultaneously in their formulation. Therefore, classic optimization procedures are generally not adequate.
Heuristics are necessary to solve big size problems and/or with many criteria (Basseur et al., 2006) . They can be 'easily' modified and adapted to suit specific problem requirements. Even though they don't guarantee to find in an exact way the optimal solution(s), they give 'good' approximation of it (them) within an acceptable computing time (Chan & Tiwari, 2007) . Heuristics can be divided into two classes: on the one hand, there are algorithms which are specific to a given problem and, on the other hand, there are generic algorithms, i.e. metaheuristics. Metaheuristics are classified into two categories: local search techniques, such as Simulated Annealing, Tabu Search … and global search ones, like Evolutionary techniques, Swarm Intelligence techniques … ACO and PSO are swarm intelligence techniques. They are inspired from nature and were proposed by researchers to overcome drawbacks of the aforementioned methods. In the following, we focus on the use of PSO technique for the optimal design of analogue circuits.
Overview of Particle Swarm Optimization
The particle swarm optimization was formulated by (Kennedy & Eberhart, 1995) . The cogitated process behind the PSO algorithm was inspired by the optimal swarm behaviour of animals such, as birds, fishes and bees. PSO technique encompasses three main features:
• It is a SI technique; it mimics some animal's problem solution abilities, •
It is based on a simple concept. Hence, the algorithm is neither time consumer nor memory absorber, • It was originally developed for continuous nonlinear optimization problems. As a matter of fact, it can be easily expanded to discrete problems. PSO is a stochastic global optimization method. Like in Genetic Algorithms (GA), PSO exploits a population of potential candidate solutions to investigate the feasible search space. However, in contrast to GA, in PSO no operators inspired by natural evolution are applied to extract a new generation of feasible solutions. As a substitute of mutation, PSO relies on the exchange of information between individuals (particles) of the population (swarm). During the search for the promising regions of the landscape, and in order to tune its trajectory, each particle adjusts its velocity and its position according to its own experience, as well as the experience of the members of its social neighbourhood. Actually, each particle remembers its best position, and is informed of the best position reached by the swarm, in the global version of the algorithm, or by the particle's neighbourhood, in the local version of the algorithm. Thus, during the search process, a global sharing of information takes place and each particle's experience is thus enriched thanks to its discoveries and those of all the other particles. Fig. 2 In an N-dimensional search space, the position and the velocity of the i th particle can be represented as
, which corresponds to the best location reached by the i th particle at time t. The global best location is named ] , , , Influence Social
where w is a constant known as inertia factor, it controls the impact of the previous velocity on the current one, so it ensures the diversity of the swarm, which is the main means to avoid the stagnation of particles at local optima. c 1 and c 2 are constants called acceleration coefficients; c 1 controls the attitude of the particle of searching around its best location and c 2 controls the influence of the swarm on the particle's behaviour. r 1 and r 2 are two independent random numbers uniformly distributed in [0,1]. The computation of the position at time t+1 is derived from expression (2) using: 
It is important to put the stress on the fact that the PSO algorithm can be used for both mono-objective and multi-objective optimization problems. The driving idea behind the multi-objective version of PSO algorithm (MO-PSO) consists of the use of an archive, in which each particle deposits its 'flight' experience at each running cycle. The aim of the archive is to store all the non-dominated solutions found during the optimization process. At the end of the execution, all the positions stored in the archive give us an approximation of the theoretical Pareto Front. Fig. 3 illustrates the flowchart of the MO-PSO algorithm. Two points are to be highlighted: the first one is that in order to avoid excessive growing of the storing memory, its size is fixed according to a crowding rule (Cooren et al., 2007) . The second point is that computed optimal solutions' inaccuracy crawls in due to the inaccuracy of the formulated equations. In the following section we give an application example dealing with optimizing performances of an analogue circuit, i.e. optimizing the sizing of a MOS inverted current conveyor in order to maximize/minimize performance functions, while satisfying imposed and inherent constraints. The problem consists of generating the trade off surface (Pareto front 1 ) linking two conflicting performances of the CCII, namely the high cut-off current frequency and the parasitic X-port input resistance.
An Application Example
The problem consists of optimizing performances of a second generation current conveyor (CCII) (Sedra & Smith, 1970) regarding to its main influencing performances. The aim consists of maximizing the conveyor high current cut-off frequency and minimizing its parasitic X-port resistance (Cooren et al., 2007) .
In the VLSI realm, circuits are classified according to their operation modes: voltage mode circuits or current mode circuits. Voltage mode circuits suffer from low bandwidths arising due to the stray and circuit capacitances and are not suitable for high frequency applications (Rajput & Jamuar, 2007) . In contrary, current mode circuits enable the design of circuits that can operate over wide dynamic ranges. Among the set of current mode circuits, the current conveyor (CC) (Smith & Sedra, 1968; Sedra & Smith, 1970) is the most popular one. The Current Conveyor (CC) is a three (or more) terminal active block. Its conventional representation is shown in Fig. 4a. Fig. 4b shows the equivalent nullator/norator representation (Schmid, 2000) which reproduces the ideal behaviour of the CC. Fig. 4 .c shows a CCII with its parasitic components (Ferry et al. 2002) . Relations between voltage and current terminals are given by the following matrix relation (Toumazou & Lidgey, 1993) :
For the above matrix representation, α specifies the kind of the conveyor. Indeed, for α =1, the circuit is considered as a first generation current conveyor (CCI). Whereas when α =0, it is called a second generation current conveyor (CCII). β characterizes the current transfer from X to Z ports. For β =+1, the circuit is classified as a positive transfer conveyor. It is considered as a negative transfer one when β =-1. γ =±1: When γ =-1 the CC is said an inverted CC, and a direct CC, otherwise.
www.intechopen.com

Particle Swarm Optimization 176
Accordingly, the CCII ensures two functionalities between its terminals: • A Current follower/Current mirror between terminals X and Z. • A Voltage follower/Voltage mirror between terminals X and Y. In order to get ideal transfers, CCII are commonly characterized by low impedance on terminal X and high impedance on terminals Y and Z. In this application we deal with optimizing performances of an inverted positive second generation current conveyor (CCII+) (Sedra & Smith, 1970; Cooren et al., 2007) regarding to its main influencing performances. The aim consists of determining the optimal Pareto circuit's variables, i.e. widths and lengths of each MOS transistor, and the bias current I 0 , that maximizes the conveyor high current cut-off frequency and minimizes its parasitic Xport resistance (R X ) (Bensalem et al., 2006; Fakhfakh et al. 2007 ). Fig. 5 illustrates the CCII+'s MOS transistor level schema. 
Constraints: •
Transistor saturation conditions: all the CCII transistors must operate in the saturation mode. Saturation constraints of each MOSFET were determined. For instance, expression (5) gives constraints on M2 and M8 transistors:
where I 0 is the bias current, W (N,P) /L (N,P) is the aspect ratio of the corresponding MOS transistor. K (N,P) and V TP are technology parameters. V DD is the DC voltage power supply.
Objective functions:
In order to present simplified expressions of the objective functions, all NMOS transistors were supposed to have the same size. Ditto for the PMOS transistors.
• R X : the value of the X-port input parasitic resistance has to be minimized, • f chi : the high current cut-off frequency has to be maximized.
www.intechopen.com
A Particle Swarm Optimization technique used for the improvement of analogue circuit performances 177
Symbolic expressions of the objective functions are not given due to their large number of terms. PSO algorithm was programmed using C++ software. Table 1 gives the algorithm parameters. Fig. 6 shows Pareto fronts (R X vs. fci) and optimal variables (W P vs. W N ) corresponding to the bias current I 0 =50µA (6.a, 6.b), 100µA (6.c, 6.d), 150µA (6.e, 6.f), 200µA (6.g, 6.h), 250µA (6.i, 6.j) and 300µA (6.k, 6.l). Where values of L N , L P , W N and W P are given in µm, I 0 is in µA, R X in ohms and fc i (min, Max) in GHz. In Fig. 6 clearly appears the high interest of the Pareto front. Indeed, amongst the set of the non-dominated solutions, the designer can choose, always with respect to imposed specifications, its best solution since he can add some other criterion choice, such as Y-port and/or Z-port impedance values, high voltage cut-off frequency, etc. 
Conclusion
The practical applicability and suitability of the particle swarm optimization technique (PSO) to optimize performances of analog circuits were shown in this chapter. An application example was presented. It deals with computing the Pareto trade-off surface in the solution space: parasitic input resistance vs. high current cut-off frequency of a positive second generation current conveyor (CCII+). Optimal parameters (transistors' widths and lengths, and bias current), obtained thanks to the PSO algorithm were used to simulate the CCII+. It was shown that no more than 1000 iterations were necessary for obtaining 'optimal' solutions. Besides, it was also proven that the algorithm doesn't require severe parameter tuning. Some Spice simulations were presented to show the good agreement between the computed (optimized) values and the simulation ones.
Appendix
In the analogue sizing process, the optimization problem usually deals with the minimization of several objectives simultaneously. This multi-objective optimization problem leads to trade-off situations where it is only possible to improve one performance at the cost of another. Hence, the resort to the concept of Pareto optimality is necessary. 
