## Engineer's notebook

## Back-and-forth scanner overcomes slewing-rate limits

by James A. Blackburn Wilfrid Laurier University, Waterloo, Ont., Canada

An incremental plotter or line printer that can store entire lines in a buffer memory can be made to print the lines alternately forwards—from left to right—and backwards—from right to left. This refinement will significantly increase its speed because it will no longer need the carriage return function with its all-too-finite slewing rate. In fact, only the minimum character-to-character print rate will then be affected by the mechanical inertia of the print-head assembly (or, in the case of



**1. Zig-zag scan.** Two-dimensional scan in minimum time is achieved by reversing scan direction on alternate rows, as indicated here. Initial address (0,0) is at lower left, and scan halts at (15,15).

an all-electronic display system, by the finite settling time of the amplifiers).

The technique is applicable to all two-dimensional scanning that must be performed incrementally. However, it is particularly efficient when each horizontal line contains many points, because in such cases the dead time during carriage return is proportionately large.

The circuit described here generates the required address sequences. It was designed as part of a rapid-film-scanning densitometer. The X and Y addresses can be sent via digital-to-analog converters to a servo system for incrementally moving the film holder past a photodetector. Alternatively, the vertical and horizontal count pulses may be used directly to drive stepping motors. If an appropriate clock frequency is chosen, the film may be scanned in the minimum time compatible with motor torque, sample stage inertia, and step size. A digitized replica of the image on the film may then be obtained by logging the densitometer output at each selected address.

The circuit shown in Fig. 2 performs an alternating-direction scan with TTL integrated circuits exclusively and is thus capable of high-speed performance. The clock frequency would normally be selected so that it is optimum for incremental motion in the X direction. In the example presented here a 16-by-16-address grid is employed. Other choices would be relatively easy to implement by cascading counters and/or changing the max-min address testing.

Briefly, the circuit functions as follows. Switch SW is



2. Scan-control logic. Logic circuit for alternating-direction incremental scanner uses 74-series TTL gates, flip-flops, and counters. Flip-flops are triggered by rising pulse edges, and counters by falling edges. Count pulses could drive stepping-motor controllers directly.

## Engineer's notebook

## Back-and-forth scanner overcomes slewing-rate limits

by James A. Blackburn Wiltrid Laurier University, Waterloo, Ont., Canada

An incremental plotter or line printer that can store entire lines in a buffer memory can be made to print the lines alternately forwards—from left to right—and backwards—from right to left. This refinement will significantly increase its speed because it will no longer need the carriage return function with its all-too-finite slewing rate. In fact, only the minimum character-to-character print rate will then be affected by the mechanical inertia of the print-head assembly (or, in the case of



 Zig-zag scan. Two-dimensional scan in minimum time is achieved by reversing scan direction on alternate rows, as indicated here, initial address (0,0) is at lower Jeft, and scan halfs at (15.15).

an all-electronic display system, by the finite settling time of the amplifiers).

The technique is applicable to all two-dimensional scanning that must be performed incrementally. However, it is particularly efficient when each horizontal line contains many points, because in such cases the dead time during carriage return is proportionately large.

The circuit described here generates the required address sequences. It was designed as part of a rapid-film-scanning densitometer. The X and Y addresses can be sent via digital-to-analog converters to a servo system for incrementally moving the film holder past a photodetector. Alternatively, the vertical and horizontal count pulses may be used directly to drive stepping motors. If an appropriate clock frequency is chosen, the film may be scanned in the minimum time compatible with motor torque, sample stage inertia, and step size. A digitized replica of the image on the film may then be obtained by logging the densitometer output at each selected address.

The circuit shown in Fig. 2 performs an alternatingdirection scan with TTL integrated circuits exclusively and is thus capable of high-speed performance. The clock frequency would normally be selected so that it is optimum for incremental motion in the X direction. In the example presented here a 16-by-16-address grid is employed. Other choices would be relatively easy to implement by cascading counters and/or changing the max-min address testing.

Briefly, the circuit functions as follows. Switch SW is



2. Scan-control legic. Logic circuit for alternating-direction incremental scammer uses: 74-series Trib. gates, flip-flops, and counters. Flip-flops are triggered by rising pulse edges, and counters by falling edges. Count pulses could drive stepping-motor controllers directly.

depressed. This sets all counters to zero, presets the three D-type positive-edge-triggered flip-flops (7474), and initializes the R-S flip-flop composed of gates G<sub>7</sub> and G<sub>8</sub>. Note that the output of G<sub>14</sub> is low; therefore clock pulses are passed freely through G<sub>15</sub>. The first rising edge on the clock stream to occur after SW is released triggers flip-flop FF<sub>1</sub>, thus enabling the X and Y counters and G<sub>6</sub>. Gate G<sub>11</sub> is now irreversibly enabled so that the end-of-line test performed by gates G<sub>1</sub>-G<sub>4</sub> directly controls the PRESET function of FF<sub>2</sub>.

As can be seen in the timing diagram (Fig. 3), the output of G<sub>11</sub> rises for a half cycle because G<sub>5</sub> is initially high. However, the clock pulse has preceded this event by an interval equal to the propagation delay of FF<sub>1</sub>. Therefore FF<sub>2</sub> does not toggle, and its Q output re-

mains at logic 1.

Subsequent negative clock edges are passed through G<sub>12</sub> and G<sub>10</sub>, causing the X address to increment steadily. The timing diagram indicates the sequence of events as the end of the first line is reached. A final negative clock edge causes a count of 15 to be achieved. The output of  $G_4$  immediately goes low, toggling  $G_7/G_8$ . As a result  $G_9$  is enabled and  $G_{10}$  disabled, while the outputs of  $G_5$  and  $G_{11}$  rise, enabling  $FF_2$ . A half cycle later, the rising clock-edge toggles FF<sub>2</sub>, enabling G<sub>13</sub> and disabling G<sub>12</sub>. The next falling edge increments the Y address without affecting the X counter. Following this a positive edge again toggles FF2, this time closing G13 but opening G<sub>12</sub>. The X address now will decrement steadily until a zero count is reached, when a similar logical sequence will route a clock pulse to Y and prepare G<sub>7</sub>/G<sub>8</sub> for upcounting. (Note that FF<sub>2</sub> can be toggled by the clock pulses only when the output of G<sub>5</sub> is high-that is, when either a minimum or maximum X address is obtained.)



3. Pulse sequences. Timing diagram shows output states of selected gates and flip-flops in circuit that produces back-and-forth scanning, and the X and Y addresses that control servomotors.

When the fifteenth Y increment occurs, G<sub>14</sub> goes high and enables FF<sub>3</sub>. From the timing diagram it can be seen that G<sub>5</sub> will already be high at this moment. FF<sub>3</sub> does not change state until the next rising edge is applied to its clock input, at the completion of the last horizontal scan. A final falling clock edge causes G<sub>5</sub> to go high, toggling FF<sub>3</sub> and disabling G<sub>15</sub> so that no further clock pulses reach the rest of the circuit. The X and Y addresses are thus frozen at this terminal count.

Once SW is released, the entire scan proceeds automatically and halts at the final address. Logging an entire image therefore requires no attention from the op-