Bifurcation diagrams are a convenient way of displaying the variety of behaviors exhibited by nonlinear systems. One of the simplest nonlinear systems is a finite difference equation with a quadratic return map. This system exhibits a range of behaviors: stability, periodic oscillations, and chaos. We present simple inexpensive electronic circuits that perform analog computations of bifurcation diagrams for finite difference equations with quadratic return maps. These bifurcation diagrams, including one for the logistic equation, are easily displayed on an oscilloscope and agree well with analytical and computational predictions.
I. INTRODUCTION
Valuable experience can be gained in understanding nonlinear systems by constructing a physical nonlinear system, and then comparing collected data to theoretical predictions. In 1985 Mishina, Kohmoto, and Hashi 1 described a simple analog electronic circuit of a finite difference equation with a quadratic return map. They showed that interesting dynamic behavior is easily seen on an oscilloscope. In this paper we modify their circuit so that the bifurcation diagram can be easily displayed, even on an inexpensive 20-MHz analog oscilloscope. It is worth emphasizing to students that the analog circuit, unlike a digital circuit, is a nonlinear physical system.
The finite difference equation investigated in Ref.
1 is
If the parameter a is between 0 and 2, and if Ϫ1Ͻx i Ͻϩ1, then x iϩ1 will also be between Ϫ1 and ϩ1, and the resulting iterated values of x exhibit a variety of behaviors, some of which are shown in Fig. 1 . The asymptotic behavior ͑after the transient response has died out͒ includes stability, periodic oscillations, and chaos. A bifurcation diagram is a convenient way of displaying the behavior of a system. 2-4 Figure 2 is the bifurcation diagram computed numerically from Eq. ͑1͒. A bifurcation diagram is a visual summary of the values of x that are visited during the asymptotic behavior for each value of a. The bifurcation points are the values of a where the system changes its behavior, for example, from period 1 behavior as in Fig.  1͑a͒ to period 2 oscillations as in Fig. 1͑b͒ . The creation of this bifurcation diagram, with its complex behavior arising from the simple mapping of an ordinary parabolic function, is likely to be a rewarding aesthetic experience for both students and instructors.
Another parabolic return map is the logistic equation, a well-known finite difference equation used to model population evolution:
If the parameter R is between 0 and 4 and if 0Ͻx i Ͻ1, then 0Ͻx iϩ1 Ͻ1. Because of the popularity of Eq. ͑2͒ as an introduction to nonlinear systems, we also present the experimental bifurcation diagram from a circuit constructed to perform an analog computation of Eq. ͑2͒.
This project combines an introduction to nonlinear dynamics and electric circuit design. It does not require familiarity with differential equations. There are many examples of electric circuits that are analog computers of nonlinear differential equations and that exhibit a variety of behaviors. [6] [7] [8] [9] An in-depth treatment of finite difference equations may be found elsewhere. Figure 3 shows the circuit schematic for producing the bifurcation diagram of Eq. ͑1͒. The analog computation uses the same approach as Ref. 1 with the use of an analog multiplier and sample-and-hold ICs. We use the Analog Devices AD633 multiplier because the AD533 is obsolete. The circuit linearly increases the parameter a in Eq. ͑1͒. This increase allows the display of the bifurcation diagram on an oscilloscope. The circuit uses Ϯ15-and ϩ5-V power supplies. Most of the electrical components are easily available. The AD633 is available from Newark Electronics. Generalpurpose op amps may be used ͑LF411, for example͒.
2-4

II. DESCRIPTION OF CIRCUITS
Acceptable inputs to the AD633 multiplier IC are Ϫ10 to ϩ10 V. The output voltage is the product of the inputs divided by 10 V. So x i in Eq. ͑1͒ is represented by the voltage V i , where x i ϭV i /10. ͑The numerical value of V i is given by the number of volts.͒ V i at both inputs of the first AD633 ͑U1͒ produces V i 2 /10 at the output. The second AD633 ͑U2͒ multiplies V i 2 /10 by a voltage in the range of 0-2 V representing the parameter a. The output aV i 2 /100 is then subtracted from 1 V by the first op amp ͑U4͒ circuit. Multiplication by 10 at the second op amp ͑U5͒ circuit gives the result V iϩ1 and x iϩ1 in Eq. ͑1͒. The LF398 sample-and-hold ICs ͑U6 and U7͒ hold this value for use in the next iteration of Eq. ͑1͒. A 555 timer ͑U8͒ is used to control the sampling times of the LF398 ICs. It is set so that an iteration takes 20 s.
The 1-V reference is provided by a regulator arrangement of NPN transistors Q3 and Q4, resulting in a stable reference that is nearly immune to power supply variations. ͑A 10% variation in the ϩ5-V supply results in about a 1% change in the 1-V reference.͒ Alternatively 1 V can be obtained from a voltage divider. If so, it must be adjusted while connected to the subtraction op amp ͑U4͒ circuit to compensate for the input impedance.
The voltage ramp circuit is designed to ramp the parameter a from 0 to 2 V in 100 ms. A 555 timer ͑U3͒ based circuit controls the ramp. The negative edge of the output of the 555 also provides a convenient trigger for display on an oscilloscope. The 20-s iteration period and the 100-ms ramp time result in 5000 iterations of Eq. ͑1͒ for each sweep of the parameter a. A triangle or saw tooth wave from a signal generator can be used as an alternative to the 555 based voltage ramp. However, one should be aware that the dc level of many signal generators tends to drift, thus changing the initial and final voltages of the ramp.
The resistors R1, R8, and R10 are all shown with nominal values. These values need to be adjusted to precisely set the 1-V reference and the voltage ramp. R10 sets the duration of the ramp, and R1 sets the slope of the ramp. Ramp durations of 20, 50, and 100 ms ͑corresponding to settings of 2, 5, and 10 ms per division on standard oscilloscopes͒ work well for the oscilloscope display. The values shown in Fig. 3 ramp the parameter a by 2 V in 100 ms. For a 50-ms ramp duration, the nominal values for R1 and R10 are 50 and 80 k⍀, and for 20 ms they are 20 and 32 k⍀. Figure 4 shows the circuit used to perform the analog computation of the logistic map, Eq. ͑2͒. The parameter R is ramped linearly from 0 to 4 V in 100 ms. Note that a small voltage ͑Ϸ15 mV͒ is added to the Z input of the second AD633. Equation ͑2͒ has one fixed point ͓where the parabola intersects the line f (x)ϭx] when 0ϽRϽ1 and two fixed points when 1ϽRϽ4. As R increases from zero, the value of x remains at the fixed point xϭ0. When R increases past 1, the fixed point at xϭ0 becomes unstable, and the second fixed point appears at xϭ1Ϫ1/R. To ensure that x moves in the positive direction away from the unstable point at xϭ0, a small positive voltage is added as noted. Otherwise, when xϭ0 becomes unstable, the system may move in the negative direction to the negative supply limit.
Problem 1. Confirm that the circuit in Fig. 4 performs the calculation in Eq. ͑2͒. ͓Note that a 10-V reference is used because the 1 in Eq. ͑2͒ is put into the circuit prior to the AD633s and thus before division by 10.͔ Problem 2. Why is it not necessary to add a small voltage to the Z input in Fig. 3 for calculation of Eq. ͑1͒? ͑Consider the behavior of the fixed point as a increases from 0.͒ The circuit in Fig. 4 uses only half the output range of the AD633 in its calculation of the bifurcation diagram of the logistic equation. The full range of Ϫ10 to ϩ10 V can be used by modifying the circuit in Fig. 3 to calculate the return map
is equivalent to the logistic equation's return map Eq. ͑2͒. This equivalence can be shown by shifting both x and f (x) by 1 and scaling by 1/2. The new variable is y ϭ(xϩ1)/2 and the new function ( f (x)ϩ1)/2 in terms of y is
ϭ2ay͑1Ϫy ͒ϭRy͑ 1Ϫy ͒, ͑4͒
where Rϭ2a. Thus the range Ϫ1 to ϩ1 for x corresponds to 0 to ϩ1 for y, and the range 0 to 2 for a corresponds to 0 to 4 for R. Equation ͑3͒ uses the same range of a as Eq. ͑1͒, so it is convenient to include a switch in the circuit to choose which bifurcation diagram is calculated. As was the case for the circuit in Fig. 4 , a small voltage at the Z input of the second AD633 moves x in the positive direction from the fixed point at xϭϪ1 when x becomes unstable. In this case a small negative voltage ͑ϷϪ15 mV͒ does the job. This small voltage can be obtained as in Fig. 4 except that the voltage divider connects to the Ϫ15-V supply instead of the ϩ15.
Problem 3. Modify the circuit in Fig. 3 to calculate aϪ1 Ϫax 2 . ͑Note that the voltages a and 1 are already available for use in an op amp subtraction circuit.͒ Figure 5 shows the bifurcation diagram as seen on an inexpensive 20-MHz analog oscilloscope. The time scale is 10 ms/div and the vertical scale is adjusted for Ϫ10 to ϩ10 V full scale. Triggering is from the negative slope of the output of the 555 IC in the voltage ramp circuit; 5000 iterations of Figure 5 shows that x is stable and decreases from 1 to 2/3 as a increases from 0 to 0.75. A bifurcation occurs at a ϭ0.75 as the system goes from stable to period 2 oscillations. At aϭ1 ͑the midpoint of the horizontal axis͒, the two x values are 0 and 1. Figure 6 shows the bifurcation diagram displayed on the oscilloscope measured from the circuit constructed to compute the logistic equation, Eq. ͑2͒. The parameter R increases to 4 V in 100 ms or 0.4 V per division. The vertical scale is adjusted for a full scale of 0 to 10 V, or 0.125 units of x per division. Figure 6 agrees well with the bifurcation diagram for the logistic equation.
III. RESULTS
2-4
The modification of the circuit in Fig. 3 to calculate the logistic bifurcation diagram using Eq. ͑3͒ gives a result very similar to Fig. 6 . However the vertical full scale is adjusted for the AD633's full range of Ϫ10 to ϩ10 V.
Of course a digital storage oscilloscope may also be used. If so, it is best to select dot display instead of vector display. The persistence and averaging may be adjusted for optimal appearance.
IV. CONCLUSION
This electronic circuit project provides a good introduction to nonlinear systems. The circuit is based on a simple nonlinear system, a finite difference equation with a quadratic return map. The experimental data are in the form of bifurcation diagrams which are easily displayed on an inexpensive analog oscilloscope and agree with predictions. This project should be considered complimentary to the procedures described in Ref. ͑1͒. The full screen sweep is 100 ms corresponding to parameter a in Eq. ͑1͒ going linearly from 0 to 2. The vertical scale is adjusted for Ϫ10 to ϩ10 V. Fig. 6 . Oscilloscope trace of the output from analog circuit computation of the bifurcation diagram of Eq. ͑2͒. The full screen sweep is 100 ms corresponding to the parameter R in Eq. ͑2͒ increasing linearly from 0 to 4. The vertical scale is adjusted for 0 to ϩ10 V.
