Complexity and the Economy
Page 24
puted incorrectly). The circuit for 2-bit-adder is constructed from TECH-712 by adding circuitry to correct this error.
Some of our evolved circuits contain unused parts. The use of the 3-bit-adder
on the right of Figure 3 is an example. In the course of the experiment such
redundancies usually disappear because less “costly” circuits replace ones with needless complication.
Our experiment starts from the NAND primitive. In other versions of the
experiment we used “implication” as the primitive. Similarly complicated
[ 124 ] Complexity and the Economy
not
xor
imply
not
equiv
3 bit xor
3 bit and
Figure 1:
Two circuits “invented” for simple goals.
circuits evolved. The process simply constructs the more elementary needs
such as “not,” “and,” and “xor” from the new “implication” primitive and pro-
ceeds as before.
The emergence of circuits such as 8-bit adders may not seem particu-
larly remarkable. But consider the combinatorics. If a component has n
inputs and m outputs there are ( m)( n)
2 2 possible phenotypes, each of which
could be realized in a practical way by a large number of different circuits.
For example, an 8-bit adder is one of over 10177,554 phenotypes with 16
inputs and 9 outputs. The likelihood of such a circuit being discovered by
random combinations in 250,000 steps is negligible. Our experiment—or
algorithm—arrives at complicated circuits by first satisfying simpler needs
and using the results as building blocks to bootstrap its way to satisfy more
complex ones.
2-bitwise-xor
full-adder
TECH-712
2-way-and
TECH-712
2-bit adder
Figure 2:
TECH-712 is useful towards satisfying the “2-bit-adder” goal because the two high-order bits are computed correctly. (The low-order bit is on the left. For multi-bit adders, input bits are interleaved.)
t He evolu t ion of t ecHnology [ 125 ]
3-bit-adder
full-adder
3-bit-adder
Figure 3:
A “4-bit-adder” circuit with an unconnected module.
THE BUILD-OUT OF TECHNOLOGIES
To talk about the build-out of technologies we need two definitions. The col-
lection of all methods and devices (all circuits) ever used we call the standing reserve. The technologies that are currently viable—in current use—and have not yet been replaced, we call the active repertoire.
Figure 4 shows the growth over time of the standing reserve, the technolo-
gies ever invented. In contrast the growth of the active repertoire, the number of technologies actually in use, is not monotonic. This indicates that important inventions render older technologies obsolete. Figure 4 also shows that
there is continual improvement in accomplishing truth function “needs” as
indicated by growing number of replacements.
Tick marks along the time axis of Figure 4 indicate when one of the
needs has been satisfied. Progress is slow at first: the experiment runs for
some time without meeting any goals exactly, and then functional species
begin to appear leading to further species. The evolution is not smooth. It is punctuated by the clustering of arrivals because from time to time key technologies—key building block components—are “discovered” that quickly
enable other technologies. For example, after a circuit for OR is invented,
circuits for 3-, 4-, and 5-bit OR and bitwise-OR operations follow in short
order. This appearance of key building blocks that quickly make possible
further technologies has analogies in the real world (think of the steam
engine, the transistor, the laser) and with the build-out of species in bio-
logical evolution [2] .
The order of invention makes a difference. Although “negation” is a
simpler function than “implication,” it happens that in some runs of the
[ 126 ] Complexity and the Economy
1000
Standing Reserve
Active Repertoire
Cumulative Replacements
100
Count
10
Satisfied Goals
1 1
10
100
1000
10000
100000
1e+06
Simulation Step
Figure 4:
The standing reserve, by definition, grows monotonically. The same is not true for the active repertoire because new inventions may improve upon and replace several existing ones.
experiment that the latter is invented first and is then used as a key build-
ing block.
Figure 5 shows the result of one such experiment. “Implication” was used in
a large number of other technologies and became much more prevalent than
“negation.” But eventually, its usage as a component declined as negation and
other, less costly components offered themselves for combination. For com-
parison, the figure shows a third technology, TECH-69, which also performs
implication but has 3 additional redundant inputs and contains unneeded
components. Eventually, all uses of TECH-69 are replaced with the functionally equivalent but more efficient implication.
There is a trade-off between the number of needs or goals posted and the
creation of new technologies. To illustrate this, we performed an experiment
masking some of the needs and retaining a subset that we considered useful
for the construction of adders: (“not, imply, 2-way-or, 2-way-xor, full-adder,”
and “k-bit-adder” for 1 ≤ k ≤ 8). (We can also streamline the process by adding more difficult needs, as measured by the number of inputs and outputs, to
the experiment only after simpler ones have been satisfied.) An 8-bit adder
evolved very quickly within 64,000 simulation steps. In contrast, using more
general goals, some simulation runs took over 675,000 steps before even a
4-bit adder evolved. A large disparate set of needs leads to broad generation
of functionalities within the circuit design space, but is slow in arriving at particular complex needs. Narrowly focused goals lead to a deep search that
t He evolu t ion of t ecHnology [ 127 ]
70
imply
not
60
TECH-69
50
40
30
Number of Uses
20
10
01
10
100
1000
10000
100000
1e+06
Simulation Steps
Figure 5:
“Implication,” being invented before “negation” in this example, is used more heavily. Usage declines over time as better technologies are invented.
reaches particular complex needs quickly, but produces a narrow library of
functionalities.
The algorithm does not produce complex circuits without intermediate needs
present. If we start without these, the repertoire of necessary building blocks is missing. For instance, if the “full-adder” goal is omitted from the goals for adders listed above, not even a 2-bit adder was found in one million steps. When the
“full-adder” goal is present, it occasionally happens that the 2-bit adder is found before the “full-adder” is invented. This is because the invention
of technologies that build toward the “full-adder” goal are also useful for the 2-bit adder.
The fact that at each step only circuits combining fewer than 12 existing
components are considered defines a set of possible experimental circuits at
any time—a large number—which we can think as the adjacent probable [4] .
We can think of this as a probabilistic cloud that surrounds the existing technologies and that gradually lead to new ones by being realized by points near
intermediate goals. Thus if a goal is too complicated it cannot be reached—
realized—with reasonable probability, and so if stepping stone goals are not
present the algorithm does not work.
The technologies we have listed as needs or goals are well-ordered in the
sense that the more complicated ones can be constructed from the more ele-
mentary ones by repeating these in simple patterns. For example, a compli-
cated circuit such as a 4-bit adder can be constructed from simpler elements
such as adders and half-adders that repeat in combination.
[ 128 ] Complexity and the Economy
What if we choose complicated goals that are not easy to realize by repetitive patterns? We can do this by selecting random truth tables with n inputs and m outputs as needs. Not surprisingly we find that often these cannot be reached from our standard intermediate steps. By the same token, what if we
replace our intermediate stepping-stone goals by random truth tables of the
same intermediate size? Again, these also do not perform as well. The algo-
rithm works best in spaces where needs are ordered (achievable by repetitive
pattern), so that complexity can bootstrap itself by exploiting regularities in constructing complicated objects from simpler ones.
PROPERTIES OF THE NETWORK
Each technology (or encapsulated circuit) that is currently used to construct
a technology is a node in the network of active technologies, and if two or
more technologies are directly used to create a novel technology they show a
(directed) link to this technology. A given technology A therefore links to its user technologies—the technologies it directly makes possible. As illustrated in Figure 6, some technologies have many links—are used very heavily to construct new ones—others have few. Usage approximates a power law (yielding
a scale-free network) but by no means perfectly.
From time to time a new superior way of executing a certain functionality
(or truth table function) is discovered. The new circuit may have fewer com-
ponents or perform that function better. In this case the new circuit replaces 100
10
1
Frequency of Occurrence
0.1
1
10
100
Number of Uses of Technology
Figure 6:
Very few key technologies are used heavily to directly construct new ones. The plot shows the average over 20 experiments at their termination of 250,000 steps each.
t He evolu t ion of t ecHnology [ 129 ]
1000
100
10
1
Frequency of Occurrence
0.1
1
10
100
Avalanche Size (Technologies rendered obsolete)
Figure 7:
Gales of destruction (or avalanches of collapse in use), average over 20 experiments.
the old one in all its descendant technologies (all the technologies below it in the network that use it directly or indirectly as a component). Replacement is immediate in our algorithm.
Replacement can also cause the collapse of technologies backward in the
network. Suppose Tech 124 is used to construct Tech 136. Then, when a supe-
rior way to achieve Tech 136’s functionality is found, Tech 124 may be left
with no further use (it may neither satisfy any goal, nor be used in any active technology). In this case technology 124 disappears from the active set of
technologies. In its disappearing, some of its component technologies may in turn be left with no further use. These also disappear from the active set.
In this way technologies may be swept from active use in large or small ava-
lanches of collapse—Schumpeter’s “gales of destruction” [1] .
Figure 7 shows that such sandpile avalanches of collapse follow a power
law. The scale on the size axis does not extend far, however, because the num-
ber of technologies in the network is never large. We can take Figure 7 as suggestive that our system of technologies exists at self-organized criticality [5] .
CONCLUSION
Using an artificial system, we have demonstrated how technology can boot-
strap itself from extreme simplicity to a complicated level, both in terms of
the numbers of objects created and their intricacy. In the real world, of course, novel technologies are not usually constructed by random combination, nor
are the needs for which technologies are created specified in a posted list.
[ 130 ] Complexity and the Economy
Nevertheless, all novel technologies are constructed by combining assemblies and components that already exist; the needs they satisfy are usually clearly
signaled economically and technically; and existing technologies form a sub-
strate or library of building blocks for future ones. The model captures certain phenomena we see in real life. Most technologies are not particularly useful
as building blocks, but some (enabling technologies such as the laser or the
transistor) are key in creating descendant technologies. Within our model, we
find a strong indication that our collection of active technologies is subject to similar statistics as earthquakes and sand-piles: it exists at self-organized criticality. Our model also shows that the build-out of technology depends
crucially on the existence of earlier technologies constructed for intermediate or simpler needs. This mirrors the finding of Lenski et al. in biological systems that complex features can be created, but only if simpler functions are first
favored and act as stepping stones [2] .
A COMMENT ON THE ALGORITHM
Just as biological evolution has been the model for genetic algorithms and
genetic programming, technology-based evolution may inspire a new form of
automatic programming and problem solving. The algorithm we develop here,
viewed abstractly, operates by discovering objects of intermediate complexity
and bootstraps complication by using these as building blocks in further com-
binations. It bears some semblance to other evolutionary algorithms such as
genetic programming. But unlike these it does not attempt to solve a given single problem. Rather, it attempts to create a toolbox of useful functionalities that can be further used for further problem solving. In doing so it sets up no parallel population of trial solutions for a problem. Instead it creates a growing collection of objects that might be useful in solving problems of increasing complexity within the same class. In this sense it does not resemble standard programming methods inspired by genetic mechanisms; rather, it is an abstraction of methods already used as combinatorial chemistry or synthetic biology or software
construction that build libraries of objects for the creation of further objects.
EXPERIMENTAL CONDITIONS
Our experimental system is implemented in Common Lisp. Different sets of
goals can be added to the system manually. The detailed behavior of the sys-
tem is controlled by a number of configuration parameters. (The values we
give below are default ones.) Extensive experiments with different settings
have shown that our
results are not particularly sensitive to the choice of
these parameters.
t He evolu t ion of t ecHnology [ 131 ]
To construct new circuits, at each step a small number of components (up to a maximum of 12) is selected and combined. The selection is made each
time by randomly drawing a component either from the set of primitives, or
the constants 0 and 1, or the set of circuits encapsulated as technologies, with probabilities 0.5, 0.015, and 0.485, respectively (and then choosing with equal probability within these sets). (For the purpose of selection, components that satisfy a goal exactly are added to the primitives’ set.) Selected components
may then be combined randomly to each other two circuits at a time, or to
combinations of each other, to form new circuits for testing. To combine two
circuits C and C , each input of C becomes an input of the combination; each 1
2
1
input of C becomes an input of the combination with probability 0.2; other-2
wise it is connected to a random output of C . All outputs of C and C become 1
1
2
outputs of the combination. The step stops when a useful circuit has been
found, or when a limit to combinations tested has been reached.
The cost of a circuit is the sum of the costs of its components. The cost of a primitive component is 1. The cost of a circuit encapsulated as a new technology/component is the number of its components. Thus, the cost of a technol-
ogy is less than the cost of the circuit it encapsulates, reflecting the idea that it becomes a commodity. We use the cost function to decide when to replace
an existing technology by a cheaper one.
Logic functions are represented by binary decision diagrams (BDDs) [6, 7].
The phenotypes of goals and circuits are described by vectors of BDDs, one
for each output wire. BDDs make it efficient to determine the equality of two
logic functions. The representation also makes possible an efficient distance
measure on logic functions, namely the number of input values for which two
functions differ. We use this distance measure to define when one circuit C 1
better approximates a goal G than another circuit C . This is the case if for 2
each output g of G circuit C computes a function f that is closer to g than any 1
of the functions computed by C . Note that this relation is a partial order, 2
i.e., two circuits need not be comparable. A circuit C is encapsulated as a new technology if there is a goal G and no other circuit better approximates G than C. Only outputs of C appropriate for G become outputs of the new component, possibly making some parts of C redundant. In general, several circuits may approximate the same goal G at the same time, as when each circuit best satisfies some aspect (subset of the outputs) of the goal, but neither strictly dominates the other.