ABSTRACT
THE ANALOG DILEMMA
The field of engineering design offers a practical yardstick for evaluating automated techniques because the design process is usually viewed as requiring human intelligence and because design is a major activity of practicing engineers. In the design process, the design requirements specify "what needs to be done." A satisfactory design tells us "how to do it."
In the field of electrical engineering, the design process typically involves the creation of an electrical circuit that satisfies user-specified design goals.
Considerable progress has been made in automating the design of certain categories of purely digital circuits; however, the design of analog circuits and mixed analog-digital circuitshas not proved to be as amenable to automation (Rutenbar 1993) . In discussing "the analog dilemma," O. Aaserud and I. Ring Nielsen (1995) (not to be confused with Ivan Riis Nielsen cited later) observe, Pcrmission to make digital or hard copies of part or all of this work for crsonal or classroom use is granted without lee provided that copies are not ~adc or distribt.tcd for profit or commercial advantage and that copies bear 1is notice and the Iidl citation on the Iirst page. Copyrights for components fthis work owned by others than ACM must be honored. Abstracting with rcdit is permitted. I'o copy otherwise, to republish, to post on servers or to :distribute to lists, requires prior specific permission and/or a lee.'" ' 1997ACM0-89791-850-9 97 0002 3.50
David Andre
Computer Science Dept.
University of California
Berkeley, California dandre @ cs.berkeley.edu
Martin A. Keane
Martin Keane Inc. 5733 West Grover Chicago, Illinois 60630 makeane @ ix.netcom.com "Analog designers are few and far between. In contrast to digital design, most of the analog circuits are still handcrafted by the experts or so-called 'zahs' of analog design. The design process is characterized by a combination of experience and intuition and requires a thorough knowledge of the process characteristics and the detailed specifications of the actual product.
"Analog circuit design is known to be a knowledge-intensive, multiphase, iterative task, which usually stretches over a significant period of time and is performed by designers with a large portfolio of skills. It is therefore considered by many to be a form of art rather than a science." Of course, engineers employ human reasoning abilities and intelligence in designing complex structures. In contrast, nature employs an entirely different approach to design. In nature, complex structures are designed by means of evolution and natural selection. This suggests the possibility of applying the techniques of evolutionary computation in order to automate the design of complex structures.
Genetic algorithms have been applied to the problem of circuit synthesis. A CMOS operational amplifier (op amp) circuit was designed using a modified version of the genetic algorithm (Kruiskamp and Leenaerts 1995) ; however, the topology of each op amp was one of 24 pre-selected topologies based on the conventional human-designed stages of an op amp. Thompson (1996) used a genetic algorithm to evolve a frequency discriminator on a Xilinx 6216 reconfigurable digital gate array operating in analog mode. Holland (1975) described how an analog of the naturally-occurring evolutionary process can be applied to solving scientific and engineering problems using what is now called the genetic algorithm (GA) . Koza (1992) described an extension of Holland's genetic algorithm in which the population consists of computer programs. See also Koza and Rice 1992 . Koza (1994a , 1994b ) described a way to evolve multipart programs consisting of a main program and one or more reusable, parameterized, hierarchically-called
subprograms (called automatically defined functions).
Architecture-altering operations provide a way to automatically determine the number of such subprograms, the number of arguments that each possesses, and the nature of the hierarchical references, if any, among such subprograms (Koza 1995) . Recent research papers on genetic programming can be found in Kinnear (1994) , Angeline and Kinnear (1996) , and .
Gruau's cellular encoding (1996) is an innovative technique in which genetic programming is used to concurrently evolve the architecture, weights, thresholds, and biases of neurons in a neural network.
This paper demonstrates that a design for a lowdistortion 96 decibel (dB) op amp (including both the circuit topology and component sizing) can be evolved using genetic programming. The problem-specific information that the user must supply in order to apply genetic programming to a particular new problem of analog circuit synthesis is minimal; it primarily consists of a fitness measure for the operating characteristics of the desired circuit. The user must also specify certain additional basic information such as the number of inputs and outputs of the desired circuit, the set of parts that are to be available to the circuit (e.g., transistors, resistors, and capacitors), and the repertoire of circuit-constructing functions (which generally does not vary from problem to problem).
Additional evidence of the ability of genetic programming to evolve the design for analog electrical circuits was presented by showing genetically evolved designs for other types of circuits, including a lowpass filter, an asymmetric bandpass filter, and a crossover (woofer and tweeter) filter.
CIRCUIT-CONSTRUCTING PROGRAM TREES
Genetic programming can be applied to circuits if a mapping is established between the kind of rooted, point-labeled trees with ordered branches found in genetic programming and the line-labeled cyclic graphs germane to circuits. The principles of developmental biology suggest a way to map program trees into circuits. The starting point of the growth process used herein is a very simple embryonic electrical circuit. The embryonic circuit contains certain fixed parts appropriate to the problem at hand and certain wires that are capable of subsequent modification. An electrical circuit is progressively developed by applying the functions in a circuitconstructing program tree to the modifiable wires of the embryonic circuit (and, later, to both the modifiable wires and other components of the successor circuits).
The functions in the circuit-constructing program trees are divided into four categories:
(1) connection-modifying functions that modify the topology of the circuit, (2) component-creating functions that insert components into the circuit, (3) arithmetic-performing functions that appear in arithmetic-performing subtrees as argument(s) to the component-creating functions and that specify the numerical value of the component, and (4) automatically defined functions that appear in function-defining branches and potentially enable certain substructures to be reused.
Each branch of the program tree is created in accordance with a constrained syntactic structure. Branches are composed from construction-continuing subtrees that continue the developmental process and arithmetic-performing subtrees that determine the numerical value of components. Connection-modifying functions have one or more construction-continuing subtrees, but no arithmetic-performing subtrees. Component-creating functions have one constructioncontinuing subtree and typically have one arithmeticperforming subtree. This constrained syntactic structure is preserved by using structure-preserving crossover with point typing (Koza 1994a ).
. 1 ,
T h e E m b r y o n i c C i r c u i t The developmental process for converting a program tree into an electrical circuit begins with an embryonic circuit. At the beginning of the developmental process, there is a writing head pointing to (highlighting) each of the three modifiable wires ( Z 8 , Z 1, and Z 2 ) . All development occurs at wires or components to which a writing head points. The three modifiable wires provide connectivity between the three distinct elements of a circuit (i.e., the input, the output, and the ground).
The domain knowledge embodied in this embryonic circuit consists of the facts that (1) the embryo has one input and one output, (2) the embryo is a circuit, (3) there are modifiable connections between the output and the source and between the output and ground, and (4) the circuit is to be an amplifier.
Because we are evolving an amplifier, there is also a fixed I00,000,000 Ohm feedback resistor
RFEEDBflCK, a fixed 100 Ohm balancing source resistor R B A L A N C E _ S O U R C E , and a fixed 100,000,000 Ohm balancing feedback resistor RBALANCE_FEEDBACK. This arrangement limits the possible amplification of the evolving circuit to a 1,000,000-to-1 ratio (120 dB).
. . C o m p o n e n t -C r e a t i n g F u n c t i o n s
Each circuit-constructing program tree in the population contains component-creating functions and connectionmodifying functions.
Component-creating functions insert a component into the developing circuit and assigns component value(s) to the component. Each component-creating function has a writing head that points to an associated highlighted component in the developing circuit and modifies the highlighted component in a specified way. The construction-continuing subtree of each componentcreating function points to a successor function or terminal in the circuit-constructing program tree.
The arithmetic-performing subtree of a componentcreating function consists of a composition of arithmetic functions (addition and subtraction) and random constants (in the range-I.000 to +1.000). The arithmetic-performing subtree specifies the numerical value of a component by returning a floating-point value that is, in turn, interpreted, in a logarithmic way, as the value for the component in a range of 10 orders of magnitude (using a unit of measure that is appropriate for the particular type of component involved) as described in detail in .
The two-argument resistor-creating R function causes the highlighted component to be changed into a resistor. The value of the resistor in kilo-Ohms is specified by its arithmetic-performing subtree. Figure 2 shows a modifiable wire 2 8 connecting nodes ] and 2 of a partial circuit containing four capacitors. Figure 3 shows the result of applying the R function to the modifiable w i r e / 8 of figure 2. Similarly, the two-argument capacitor-creating c function causes the highlighted component to be changed into a capacitor. The value of the capacitor in nano-Farads is specified by its arithmetic-performing subtree.
Space does not permit a detailed description of each function herein. See , and Koza, Bennett, Andre, and Keane (1996a , 1996b , 199@, 1996d for details.
The one-argument Q D PNP diode-creating function causes a diode to be inserted in lieu of the highlighted component, where the diode is implemented using a pnp transistor whose collector and base are connected to each other. The Q_D_NPN function inserts a diode using an npn transistor in a similar manner.
There are also six one-argument transistor-creating functions
that insert a transistor in lieu of the highlighted component. For example, the Q POS COLL_NPN function inserts a npn transistor whose collector is connected to the positive power supply.
The three-argument transistor-creating Q. 3 NPN function causes an npn bipolar junction transistor (model Q 2 N 3 9 0 4 ) to be inserted in place of the highlighted component and one of the nodes to which the highlighted component is connected.
The Q 3 NPN function creates five new nodes and three new modifiable wires. There is no writing head on the new transistor.
Similarly, the three-argument transistor-creating Q 3_PNP function causes a pnp bipolar junction transistor (model Q2 N3 9 0 6) to be inserted. Figure 4 shows the result of applying the Q_3 NPN0 function, thereby creating transistor f16 in lieu of modifiable wire Z8 of figure 2. 
Connection-Modifying Functions
Each connection-modifying function in a program tree points to an associated highlighted component and modifies the topology of the developing circuit in some way.
The one-argument polarity-reversing FLIP function attaches the positive end of the highlighted component to the node to which its negative end is currently attached and vice versa. After execution of the FLIP function, there is one writing head pointing to the component.
The three-argument SERIES division function creates a series composition consisting of the highlighted component (with a writing head), a copy of it (with a writing head), one new modifiable wire (with a writing head), and two new nodes. The four-argument PSS and PSL parallel division functions create a parallel composition consisting of the original highlighted component (with a writing head), a copy of it (with a writing head), two new modifiable wires (each with a writing head), and two new nodes. Figure 6 shows the result of applying P SS to the resistor 8 i from figure 3.
Figure 6 Result of the P SS parallel division function.
There are six three-argument functions (called T_GND_0, T_GND_I, T_POS_0, T_POS_I, T_NEG_0, T_NEG_I) that insert two new nodes and two new modifiable wires and then make a connection to ground, positive power supply, or negative power supply, respectively. Figure 7 shows the T GND 0 function connecting resistor B | of figure 3 to groun&
The three-argument PAIR_CONNECT_0 and PAIR_CONNECT_I functions enable distant parts of a circuit to be connected together.
The first PAIR_CONNECT to occur in the development of a circuit creates two new wires, two new nodes, and one temporary port. The next PAIR_CONNECT to occur (whether PAIR_CONNECT_0 or PAIRCONNECT_I) creates two new wires and one new node, connects the temporary port to the end of one of these new wires, and then removes the temporary port.
The one-argument NOP function has no effect on the highlighted component; however, it delays activity on the developmental path on which it appears in relation to other developmental paths in the overall program tree.
The zero-argument END function causes the highlighted component to lose its writing head. The END function causes its writing head to be lostthereby ending that particular developmental path.
The zero-argument SAFE_CUT function causes the highlighted component to be removed from the circuit provided that the degree of the nodes at both ends of the highlighted component is three (i.e., no dangling components or wires are created). 
PREPARATORY STEPS
Our goal in this research is to evolve the design of a high-gain amplifier. Before applying genetic programming to circuit synthesis, the user must pertbrm seven major preparatory steps, namely (l) identifying the embryonic circuit that is suitable for the problem, (2) determining the architecture of the overall circuitconstructing program trees, (3) identifying the terminals of the to-be-evolved programs, (4) identifying the primitive functions contained in the to-be-evolved programs, (5) creating the fitness measure, (6) choosing certain control parameters (notably population size and the maximum number of generations to be run), and (7) determining the termination criterion and method of result designation.
The feedback embryo for the one-input, one-output amplifier circuit of figure 1 is suitable for this problem.
The embryonic circuit has a writing head associated with each of the three result-producing branches and there are three result-producing branches (called RPB0, RPBI, and RPB2) in each program tree. The number of automatically defined functions, if any, will emerge as a consequence Of the evolutionary process using the architecture-altering operations. Each program in the initial population of programs has a uniform architecture with no automatically defined functions (i.e., three result-producing branches).
The terminal sets are identical for all three resultproducing branches of the program trees for this problem. The function sets are identical for all three result-producing branches.
The initial function set, Fccs-initial, for each construction-continuing subtree is For the npn transistors, the Q 2 N 3 9 0 4 model was used. For pup transistors, the Q2N3 9 0 6 model was used.
The initial terminal set, Tccs-initial, for each construction-continuing subtree is Tccs_initia I = { END, SAFE_CUT }.
The set of potential new functions, Fpotential, is fpotential = {ADF0, ADF1, ADF2, ADF3 }.
The set of potential new terminals, Tpotential, is Tpotential = {ARGO }.
The architecture-altering operations change the function set, Fccs for each construction-continuing subtree of all three result-producing branches and the function-defining branches, so fccs = fccs-initial ~ fpotential.
The architecture-altering operations change the terminal set, Taps-adf, for each arithmetic-pertbrming subtree, so Taps_ad f = Taps_initia I w '/potential.
The terminal set, Taps_initia l, for each arithmeticperforming subtree consists of Taps_initia I = {~ }, where 9~ represents floating-point random constants from -1.0 to +1.0.
The function set, Faps, for each arithmeticperforming subtree is, Faps = {+, -}.
The evaluation of fitness for each individual circuitconstructing program tree in the population begins with its execution. This execution applies the functions in the program tree to the embryonic circuit, thereby developing the embryonic circuit into a frilly developed circuit. A netlist describing the fully developed circuit is then created. The netlist identifies each component of the circuit, the nodes to which that component is connected, and the value of that component. Each circuit is then simulated to determine its behavior. The 217,000-line SPICE (Simulation Program with Integrated Circuit Emphasis) simulation program (Quarles et al. 1994 ) was modified to run as a submodule within the genetic programming system. Figure 8 provides additional detail on the calculation of fitness. The calculation starts by initializing the current C I R C U I T to the embryonic circuit.
The individual circuit-constructing program tree from the population is then executed. This execution causes the component-creating and connection-modifying functions in the program tree to be applied to the current C I R C U I T (i.e., these functions side effect the current C I R C U I T ) . When this execution is completed, the current CIRCUIT is translated into a NETLIST.
ISta I [ Set C I R C U I T = I e m b r y o n i c c i r c u i t E v a l u a t e i n d i v i d u a l c i r c u i t -c o n s t r u c t i n g p r o g r a m t r e e b y p r o g r e s s i v e l y a p p l y i n g c o m p o n e n tc r e a t i n g a n d c o n n e c t i o n -m o d i f y i n g f u n c t i o n s to t h e c u r r e n t C I R C U I T i n t o N E T L I S T

÷ Create S I M P L I F I E D N E T L I S T by r e m o v i n g w i r e s , r e m o v i n g d a n g l i n g c o m p o n e n t s , r e m o v i n g r e m a i n i n g i s o l a t e d s u b c i r c u i t s , i n s e r t i n g h i g hr e s i s t a n c e D C p a t h to g r o u n d f o r i s o l a t e d n o d e s , a n d c o n s o l i d a t i n g s e r i e s a n d p a r a l l e l c o m b i n a t i o n s o f l i k e c o m p o n e n t s I I R u n S P I C E s i m u l a t o r o n S I M P L I F I E D N E T L I S T to c r e a t e t a b u l a r v a l u e s o f e l e c t r i c a l b e h a v i o r
Figure 8 More detailed f l o w c h a r t for calculation of fitness.
The N E T L I S T is then simplified in five ways to create a SIMPLIFIED NETLIST. First, all wires are removed. Second, any dangling components are removed. Third, any isolated substructures are removed. Fourth, a very large resistance (a 1 giga-Ohm resistor RHIJl]£) is inserted between ground and any node for which there is no DC path to ground. For example, if two capacitors join at a certain node, there is no DC path to ground from that node. The introduction of a very large resistance between that node and ground has no significant electrical effect; however, it is essential for enabling the SPICE simulator to simulate the circuit. The fifth simplification of the netlist is done for reasons of accelerating the SPICE simulation. The time required for a SPICE simulation generally increases nonlinearly as a function of the number of nodes in the netlist (in an approximately sub-quadratic to quartic way). Thus, it is advantageous to shorten the netlist provided to SPICE. All series and parallel compositions of like passive components are replaced, for purposes of the simulation only, by a single component of appropriate value. For example, two resistors (or inductors) in series are replaced by a single resistor (or inductors) whose value if the sum of the two resistances. Two resistors in parallel are reaplced by a single resistor whose value is the reciprocal of the sum of the reciprocal of the two resistances. Two capacitors in parallel are consolidated in the same manner as two resistors in series and two capacitors in series are consolidated in the same manner as two resistors in parallel.
The starting point for evaluating the fitness of a circuit is its response to a DC input. An ideal inverting amplifier circuit would receive a DC input, invert it, and multiply it by the amplification factor. A circuit is flawed to the extent that it does not achieve the desired amplification; to the extent that the output signal is not centered on 0 Volts (i.e., it has a bias); and to the extent that the DC response is not linear.
Thus, for this problem, we used a fitness measure based on SPICE's DC sweep. The DC sweep analysis measures the DC response of the circuit at several different DC input voltages. The circuits were analyzed with a 5 point DC sweep ranging from -10 millvolts to +10 mV, with input points a t -1 0 mV, -5 mV, 0 mV, +5 mV, and +10 inV. SPICE then produced the circuit's output for each of these five DC w~ltages.
Fitness is then calculated from four penalties derived from these five DC output values. Fitness is the sum of an amplification penalty, a bias penalty, and two non-linearity penalties.
First, the amplification factor of the circuit is measured by the slope of the straight line between the output for -10 mV and the output for +I0 mV (i.e., between the outputs for the endpoints of the DC sweep). If the amplification factor is less than the maximum allowed by the feedback resistor (120 dB for this problem), there is a penalty equal to the shortfall in amplification.
Second, the bias is computed using the DC output associated with a DC input of 0 Volts. The penalty is equal to the bias times a weight. For this problem, a weight of 0.1 is used.
Third, the linearity is measured by the deviation between the slope of each of two line segments and the overall amplification factor of the circuit. The first line segment spans the output values associated with inputs o f -1 0 mv through -5 mv. The second line segment spans the output values associated with inputs of +5 mv and through + 10 inv. The penalty for each of these line segments is equal to the absolute value of the difference in slope between the respective line segment and amplification factor of the circuit.
Many of the circuits that are created in the initial random population and many that are created by the crossover and mutation operations cannot be simulated by SPICE. Such circuits are assigned a high penalty value of fitness (108).
The population size, M, was 640,000. The architecture-altering operations are used sparingly on each generation. The percentage of operations on each generation after generation 5 was 86.5% one-offspring crossovers; 10% reproductions; 1% mutations; 1% branch duplications; 0% argument duplications; 0.5% branch deletions; 0.0% argument deletions; 1% branch creations; and 0% argument creations. Since we do not want to waste large amounts of computer time in early generations where only a few programs have any automatically functions at all, the percentage of operations on each generation before generation 6 was 78.0% one-offspring crossovers; 10% reproductions; 1% mutations; 5.0% branch duplications; 0% argument duplications; 1% branch deletions; 0.0% argument deletions; 5.0% branch creations; and 0% argument creations.
The maximum size, /4rpb, for each of the three result-producing branches in each overall program is 300 points.
The maximum number of automatically defined functions is 4.
The number of arguments for each automatically defined function is one.
The maximum size, Hadf, for each of the automatically defined functions, if any, is 200 points.
The other parameters for controlling the runs of genetic programming were the default values specified in Koza 1994 (appendix D) .
This problem was run on a medium-grained parallel Parsytec computer system consisting of 64 80 MHz Power PC 601 processors arranged in a toroidal mesh with a host PC Pentium type computer. The distributed genetic algorithm was used with a population size of Q --10,000 at each of the D = 64 demes.
On each generation, four boatloads of emigrants, each consisting of B = 2% (the migration rate) of the node's subpopulation (selected on the basis of fitness) were dispatched to each of the four toroidally adjacent processing nodes. See Andre and Koza 1996 for details.
R E S U L T S
We made three identical runs of this problem. The worst of the runs produced an op amp that delivered 92 dB of amplification. We describe the best run here.
About 41% of the circuits of generation 0 cannot be simulated by SPICE; however, the percentage of unsimulatable circuits drops to between 2% and 4% between generations 1 and l0 and never exceeds 8% thereafter.
The fitness of the best-of-generation individual tends to improve from generation to generation.
The best circuit (figure 9) from generation 50 has 33 transistors, no diodes, eight capacitors, and five resistors (in addition to the five resistors of the feedback embryo). It achieves a fitness of 971,076.4. No automatically defined functions are present in this particular circuit. The DC sweep shows that the circuit has an amplification of 89.7 dB (30,545-to-1) and a bias of 9.77 Volts.
Based on the time domain behavior for a 20 microvolt sinusoidal 1,000 Hz input signal, the amplification is 89.7 dB (30,500-to-1) for the best circuit from generation 50; the bias is 9.76 Volts; and the distortion is 6.29%.
Based on the AC sweep for the best circuit of generation 50, the 3 dB bandwidth is 2,300 Hz. The circuit has a flatband gain of 89.7 dB.
The best-of-run circuit (figure 10) appeared in generation 86 and achieves a fitness of 938,427.3. The program tree has two automatically defined functions. Figure 11 shows automatically defined function ADF0 of the best circuit from generation 86 (which has 12 transistors, no diodes, one capacitor, and two resistors). The DC sweep for this best of generation circuit from generation 86 shows that the circuit has an amplification of 96.2 dB (64,860 -to-l) and a bias of 7.44 Volts. Figure 12 shows the time domain behavior of the best circuit fiom generation 86. The vertical axis is voltage from -20 volts to +20 volts. The input is the 20 microvolt sinusoidal signal; however, it appears here as a nearly straight line because of the scale necessary to show the high amplification of the output signal. Based on this transient analysis, the amplification is 94.1 dB; the bias is 7.46 volts; and the distortion is 7.07%. We do not claim that the genetically evolved amplifier satisfies all the additional requirements that a human design engineer might want to incorporate into a practical design. We do, however, claim that genetic programming successfully created a 96 dB op amp circuit based on the fitness measure that it was given. We also claim that the genetically evolved circuit demonstrates the principle that both the topology and component sizing of a complex analog circuit can be evolved using genetic programming -that is, that the synthesis of analog circuits can be automated.
O T H E R E X A M P L E S
Genetic programming has also been successfully applied to a variety of other problems of analog circuit design.
The problem-specific information that the user must supply in order to apply genetic programming to different problems of analog circuit synthesis is minimal. It primarily consists of a fitness measure for the operating characteristics of the desired circuit. That is, structure arises from fitness. In addition, the user must also specify information such as the number of inputs and outputs of the desired circuit, the set of parts that are to be available to the circuit (e.g., transistors, resistors, and capacitors), and the repertoire of circuitconstructing functions (which generally does not vary from problem to problem).
In this section, we describe several additional circuit synthesis problems in order to demonstrate how to modify the basic technique described above for other problems.
. 1 . L o w p a s s F i l t e r
Genetic programming has successfully evolved a design for a lowpass filter with passband below 1,000 Hz and a stopband above 2,000 Hz with requirements equivalent to that of a fifth order elliptic filter Keane 1996a, 1996c ). For the amplifier described above, the fitness measure was based on gain. For a filter, the fitness measure is based on the amount of voltage that the circuit passes at various frequencies. Specifically, fitness is measured in terms of the sum, over fitness cases representing various frequencies, of the weighted absolute value of the deviation between the actual value of the voltage that is produced by the circuit at the probe point !10 UT at node ,5 and the target value for voltage. The smaller the value of fitness, the better (with zero being best). A second difference is that the embryo for a filter circuit does not need a balancing or feedback resistor. A third difference is that the desired filter is a passive circuit created from inductors and capacitors (but without transistors or power supplies).
Numerous runs produced lowpass filters having a topology that is similar to that employed by human engineers. For example, in one run, a 100% compliant evolved circuit (figure 14) had the recognizable ladder topology of a Butterworth or Chebychev filter (i.e., a composition of series inductors horizontally with capacitors as vertical shunts). 
Figure 14
Genetically evolved ladder filter circuit.
. 2 . A C r o s s o v e r F i l t e r
A design for a crossover (woofer and tweeter) filter with a crossover frequency of 2,512 Hz was reported in Koza, Bennett, Andre, and Keane 1996b . This problem requires a one-input, two-output embryonic circuit and requires that the fitness be measured at two probe points.
The lowpass part of the genetically evolved best-ofrun circuit (figure 15) has the Butterworth topology. Except for additional capacitor C 3 8 , the highpass part of this circuit also has the Butterworth topology. This circuit is slightly better than the combination of Iowpass and highpass Butterworth filters of order 7. 
Figure 15
Genetically evolved crossover filter.
Asymmetric Bandpass Filter
A design for an asymmetric bandpass filter with requirements equivalent to a tenth-order elliptic filter was successfully evolved (Koza, Bennett, Andre, and Keane 1996d) . The preparatory steps required to solve this problem were almost identical to that of the two lowpass filter mentioned above, except that the fitness measure reflected the more complicated asymmetric requirements of the problem. Figure 16 shows a 100% compliant evolved as ,mmetric bandpass filter. Genetically evolved asymmetric bandpass filter.
Cube Root Circuit
Analog electrical circuits that perform mathematical functions (e.g., logarithm, square, cube root) are called computational circuits, Computational circuits are of special practical importance when the small number of required mathematical functions does not warrant converting an analog signal into a digital signal, performing the mathematical function in the digital domain, and then converting the result to the analog domain. The design of computational circuits is notoriously difficult even for mundane mathematical functions and often relies on the clever exploitation of some aspect of the underlying device physics of the components. Moreover, implementation of each mathematical function typically requires an entirely different clever insight.
A design for a computational circuit for the cube root function has been successfully evolved. Figure 17 shows a genetically evolved cube root circuit with 36 transistors, two diodes, no capacitors, and 12 resistors (in addition to the source and load resistors in the embryo).
Figure 17
Genetically evolved cube root circuit.
CONCLUSION
Genetic programming successfully evolved a 37-transistor amplifier that delivers a DC gain of 96 dB (64,860 -to-1).
