

TM-1079 0818.000

A MICROPROCESSOR BASED MADC TEST FACILITY

K. Seino

December 1981

#### 1. Introduction

A new multiplexed ADC was designed and constructed back in  $1979^{\perp}$ . However, because of budgetary constraints and manpower shortage, we had not produced any beyond five units. Recently, we constructed fifteen units, and we will build twenty-five or forty-five more units.

Each units has 192 connections at the input. If there are some faulty connections, how can we detect and locate them quickly and efficiently? How can we adjust the offset and gain on the ADC fast and without frustration? These questions motivated the author to implement a microprocessor based test facility. A graphic display greatly eases pains in adjusting the offset and gain of the ADC.

The author thinks this is only the first generation, and he intends to try and improve it through experience.

#### 2. Test Method

#### 2.1 Basic Check

The MADC units are assembled by an outside subcontractor. When the units are delivered, the following basic functions are checked out.

1. Check and adjustment on power supply voltages.

2. Check and troubleshoot on controls and displays.

3. Check on one of four MUX cards.

4. Check and adjustment on amplifiers and sample/hold.

5. Rough adjustment on ADC.

After the basic functional check, the units can be locally and remotely controlled, and they can digitize and display analog signals at least on a few channels with a moderate accuracy.

#### 2.2 Basic Tests

Prior to computer aided tests, we document several characteristics, i.e., (1) rough linearity, (2) DC common mode rejection, (3) AC common mode rejection, and (4) channel cross talk.

The amplifier has been properly adjusted and it performs well with reasonably accurate offset, gain and common mode rejection. The sample/hold and the ADC have been adequately adjusted. The unit as a whole appears to be functioning and it produces reasonable readings. We are now ready to do computer aided tests.

- 2 -

#### 2.3 Computer Aided Tests

The first thing that comes across our mind is that there are many physical connections through the input arrangement, i.e., connectors, cables and MUX cards. There are sixty-four differential channels each of which has Hi, Lo, and shield, and therefore we deal with at least 192 connections. If there is something wrong with any one of these connections, how can we detect and locate it quickly and efficiently?

Another thing is how can we adjust the offset and gain on the ADC?, and how can we know whether the ADC performs as it is specified or not? In order to answer these questions, the author introduced a graphics display. When the operator adjusts the offset and gain, he can watch and tell how much the linearity curve changes as he turns the potentiometer. When he finishes with the adjustment, he can watch and tell how good the linearity is on the graphic display.

#### 2.3.1 Channels and their interaction tests

A channel should be properly selected and isolated from other channels. A signal should come through the channel and it should be accurately digitized. On our test facility, we implemented two test programs, i.e., MINTS1 and MINTS2.

Fig. 2.1 shows how to run the MINTS1 program on a CRT terminal. First, the operator makes certain whether Source B on an input switching unit has normal polarity or not. He then specifies a channel group and a reference value. The input switching unit connects only one channel to the

- 3 -

reference and ties the other channels to ground during a cycle. It switches from one channel to another as the cycle advances from one to another. As it is shown in the figure, Channel 0 is selected in Cycle 1, Channel 1 in Cycle 2, Channel 2 in Cycle 3, etc..., and it continues until Channel 15 is selected in Cycle 16. In this test, only the selected channel should have the voltage. If unselected channels have some voltage, there may be miswiring or short circuits. Or, if the selected channel does not have the voltage, there may be open wires or ground short circuits. If the operator selects the other channel groups, he can test all of the sixty-four channels.

Figure 2.2 shows how to run the MINTS2 program on a CRT terminal. Differing from the previous program, this program allows the operator to specify the channel pattern. In the figure, an alternate pattern (AAAA in Hex) is selected. By manipulating the channel pattern, the operator can further diagnose the problem that has been found in the previous test. 2.3.2 Input protection test

The input circuit of all of the channels has to be protected from accidental application of a high voltage. Each one of the connections that are needed for the sixty-four differential channels is protected by two diodes and a series resistors. For the test, we use a mechanical switch box and a power supply instead of the programmable input switching unit and the DAC. Figure 2.3 shows how to run the MINTS2 program

- 4 -

for this particular test. The operator specifies the channel group, and he can put an arbitrary number on the channel pattern and reference, such as FFFF or XXXX. In the figure, each pair of the input wires of the sixteen channels are connected to a common voltage (Ecm in Figure 2.3). When  $E_{cm}$ =+10V, the amplifier is in a linear range and it can reject the voltage that is commonly applied to the Hi and Lo wires of the channels. Therefore, all the readings are nearly zero. When  $E_{cm}$  is increased to +15V, the amplifier is in saturation and the input to the multiplexer is approaching the supply voltage. All the readings shown resulted from the imbalance between Hi and Lo connections. When  $E_{cm}$  is increased to +17V, protection diodes start to conduct. We repeat these with  $E_{cm}$ in negative voltages. If all the readings that have been taken are reasonably small, we deduce that all the protection circuits function properly.

#### 2.3.3 Linearity tests

A graphic display greatly eases pains in adjusting the offset and gain of the ADC and allows us to examine the entire linearity curve at a glance.

(1) Linearity (Regular)

The operator invokes a command file called MLNTS2 on his terminal. He then enters type of linearity, channel number and delay. He selects 'Linearity (Regular)' by entering RLA. In a second or so, the graphic display will have a picture like the ones shown in Fig. 2.4. The horizontal axis shows

- 5 -

the reference voltage in a linear scale, and the vertical axis shows the different between reference and ADC reading. There are twenty-one data points starting from -10V up to +10V. Figure 2.4(a) shows a curve when gain is too high. A half turn adjustment on the gain potentiometer gives us a curve like the one shown in Fig. 2.4(b). If the operator selects repeat mode, the program repeats digitization and updating of display. Therefore, he can adjust the gain potentiometer as he watches how much the linearity curve is affected. He can do the same thing with the offset adjustment. With this graphic display, we now feel that we have a search light in the dark.

(2) Linearity (Differential)

After invoking a command file called MLNTS2, the operator selects 'Linearity (Diff.)' by entering DFL. In a second or so, the graphic display will have a picture like the one shown in Fig. 2.5. The horizontal axis shows the reference voltage in a binary scale, and the vertical axis shows the difference between reference and ADC reading. There are twenty-four data points, i.e., -10.24, -5.12, -2.56,----0, 2.555, 5.115 and 10.235 (V), or 10000000000, 11000000000, 111000000000, ------, 00000000000, ------, 0001111111, 00111111111 and 0111111111 (Binary).

- 6 -

#### 3. Hardware

#### 3.1 Microcomputer and Peripherals

We purchased card cages, chassis parts, a power supply and cards in order to construct a Multibus-based microcomputer shown in Fig. 3.1. Monolithic Systems' MSC8004 Z80A based CPU board is the heart of the computer. There ae 32K byte on-board RAM and 32K byte off-board RAM. The Z80A communicates with TEC501 terminal via on-board serial I/O interface. A home made disk control board handles two double sided disk drives, Shugart Associates' SA850. Matrox Electronic Systems' MSBC-512 graphic control board, which has a resolution of 256x256, drives Shibaden's VM904U video monitor. Kinetic Systems' 5110 interface board drives Kinetic Systems' 3908 crate controller.

#### 3.2 MADC Test Setup

A CAMAC crate based test setup is shown in Fig. 3.2. Analog Devices' DAC1136K high resolution 16 bit DAC is housed in a chassis. It is optically isolated from the digital environment at the input, and it is buffered by Analog Devices' 234K chopper stabilized amplifier at the output. The chassis has its own power supply, which can be left on for stable output. The input switching unit has 16 solid state, single pole-double throw swiches, which connect the MADC channels to either Source A or Source B. Source B can be selected to either Norm or B=-A. When it is selected to B=-A, Source B will have the reversed polarity of and the same amplitude as Source A. The unit is also optically

- 7 -

isolated from its controller and is self-powering. This unit is replaced with a mechanical switch box when the input protection test is carried out. All of the controller cards that reside in the CAMAC crate are home made, except the crate controller.

#### 4. Software

#### 4.1 System Software

CDOS (Cromemco Disk Operating System) is the disk operating system. It is a single-user, single-task operating system for disk file management. CDOS occupies memory from Location 0 through 100H as well as approximately 8K bytes of memory above the user area (High Memory). CDOSGEN allows CDOS to be built around the user's particular hardware configuration and software needs. It supports up to 64K bytes of memory in 1K blocks and any combination of up to four 8" and 5" disk drives. CDOS utility programs are (1) BATCH, (2) DUMP, (3) INITIALIZE, (4) STATUS, (5) WRITE SYSTEM, (6) TRANSFER, (7) SCREEN EDITOR, and (8) TEXT EDITOR.

FORTRAN IV is a complete implementation of ANSI standard FORTRAN X3.9--1966, except that there is no complex data type and that specification statements must appear in a specific order. The FORTRAN IV Compiler produces relocatable code and FORTRAN program modules can be linked with the code produced by the relocatable assembler.

Z80 MACRO Assembler is a two pass assembler which reads source code from a disk file, assembles it, and produces listings and an object file either in relocatable or in Intel hex format.

- 8 -

LINK, relocating linker/loader, loads and links separately assembled modules as desired at run time. These modules may include FORTRAN library routines as well as those generated by the FORTRAN compiler. The linked machine code can then be saved in a disk file for execution.

DEBUG allows machine language programs to be traced, disassembled and patched, and it allows the operator to establish break points, display and alter the Z80 registers, and initiate normal or step by step program execution.

#### 4.2 Program Example

All of our test programs are written in FORTRAN IV. MINTS2.FOR is shown as a program example in Fig. 4.1. There are many subprogram calls in this program. However, in order to illustrate how parameters are passed between the main program and a subprogram, a subprogram named Cl26DA is shown in Fig. 4.1(b). The subprogram call is made at one line below Line 110 of the main program. The subprogram has two parameters, i.e., ICDI and ICDO. ICDI and ICDO are passed by (HL) and (DE) respectively, between the main program and the subprogram.

At the end of the program, the operator is allowed to intervene and select a mode. He has four choices, i.e., (1) C (Continue) repeats another cycle with the same parameters, (2) N (New) starts another cycle with new parameters, (3) R (Repeat) repeats the number of cycles specified, and (4) S (Stop) stops the execution of program. The author has found this feature is convenient and useful, and he is in the habit of using this feature in any program that he writes.

#### 5. Conclusion

Computer aided tests on the MADC units have just begun, and our present implementation is far from being complete. We intend to try and improve it by learning from experience. One thing that we know right from the start is that we have an input switching unit for 16 channels but not for 64 channels. We ought to construct one soon.

#### 6. Acknowledgement

I am grateful to Timothy Gierhart and Richard Klecka for their efforts on the construction of the test facility. Thanks are also due Walter Knopf for his contribution of CDOS and utility programs to the test facility.

#### References

1. A New Multiplexed ADC Unit, K. Seino, TM-931, 1979.

- 2. MSC8004 User's Manual, Monolithic Systems Corp., 1978.
- 3. 32K-128K Dynamic RAM Board Manual, Central Data Corp., 1980
- 4. MSBC-512 Graphic Display Board Manual, Matrox Electronics, 1978.
- 5. Model 5110 Multibus Adapter Manual, Kinetic Systems Inc., 1980.
- 6. Model 3908 Crate Controller Manual, Kinetic Systems Inc., 1979.
- 7. SA850/851 OEM Manual, Shugart Associates, 1977.
- 8. Series 500 Terminal Manual, TEC Inc., 1978.

- 10. -

9. CDOS Instruction Manual, Cromemco, Inc., 1978.

10. FORTRAN IV Instruction Manual, Cromemco, Inc., 1979.

11. Macro Assembler Instruction Manual, Cromemco, Inc., 1978.

XIN TS 1

ON INPUT SWITCH UNIT, SOURCE B = NORM ? (Y/N) ;Y SELECT CHANNEL GROUP 1 1 3 4 :1 ENTER REFERENCE BANGING FROM -2043 TO 2047 (2.0.0 0 CYCLE = 1 CHANNEL GROUF = 1 1 4 2.00 2 0.00 5 3 ÷ 10.00 0.00 0.00 0.00 0.00 0.00 0.00 12 0.00 0.00 0.00 0.00 0.00 0.00 0.00 13 14 10 3 3 11 CYCLE = 2 CHANNEL CROUP = 1 5 1 2 3 4 0.00 2 3 5 6 7 0 . C O 9.99 0.00 0.00 0.00 0.00 0.00 0.00 11 0.00 0 00 0.00 0.00 0.00 **0.00** -.01 2 9 10 12 13 14 15 CHANNEL GROUP = 1 1 2 CYCLE = 3 2 9.99 3 0 4 5 8 7 . 00 ō.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 12 0.00 0.00 6.00 0.00 0.00 G . G C 10 11 13 14 8 9 15 CYCLE = 4 CHANNEL GROUP = 1 0 1 2 3 0 00 0.00 0.00 9.99 4 .00 -.00 5 6 7 0.00 0.00 0.00 - 00 11 -.01 -.00 0.00 -.00 -.00 -.00 13 14 9 12 5 10 15 CHANNEL GROUP = 1 CYCLE = 5 2 0.00 0 4 9.99 5 0.00 6 7 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 0.00 10 12 13 14 15 8 Э 11 CHANNEL GROUP = 1 1 2 3 3 0 0CYCLE = 6 4 0 00 2 0.00 3 0.00 5 7 Ū – 6 00.0 9.99 0.00 0.00 0.00 5.00 0.00 0.00 0.00 0.00 0.00 0.00 - 01 13 ŝ 9 10 11 12 14 15 CHANNEL GROUP = 1 CYCLE = 7 2 0 - 00 4 5 6 -0 0 0 00.0 0.00 0 . O O 0.00 9.99 0.00 0.00 0 G J 0.00 0.00 0.00 0.00 0.00 0.00 12 14 9 10 11 13 15 8 CHANNEL GROUP = 1 CYCLE = 84 0.00 1 2 0.00 3 0.00 5 6 ū 7 0.00 0.00 0.00 0.00 9.99 0,00 10 0.00 11 0.00 12 0.00 G. G O 0.00 0.00 0.00 14 2 15 8

FIG. 2.1 Channels and Their Interaction Test No. 1

ENTER CHANNEL PATTERN IN HEX : A A A A Select Channel group 1 2 3 4 :1 ENTER REFERENCE -2043 THRU 2047 :2 0 0 0

CHANNEL GROUP : 1

MINTS 2

| <u>0</u> | 1     | 2      | 3     | 4      | 5     | 6      | 7     |
|----------|-------|--------|-------|--------|-------|--------|-------|
| -9.980   | 9.910 | -9.980 | 9.920 | -9.985 | 9.915 | -9.935 | 9.920 |
| -9.980   | 9.900 | -9.985 | 9.910 | -9.985 | 9.910 | -9.985 | 3.920 |
| Ð        | 9     | 10     | 11    | 12     | 13    | 14     | 15    |

FIG. 2.2 Channels and Their Interaction'Test No. 2

MINTSS2.

ENTER CHANNEL PATTERN IN HEX OF F F S Select Channel Group 1 2 3 4 01 ENTER FEFERENCE -2048 THRU 2047 0X X X X

 CHANNEL GROUP : 1
  $E_{cm}$ =+10V

 0
 1
 2
 3
 4
 5
 5
 7

 -005
 -005
 -.005
 -.005
 -.005
 -.005
 0.000
 -.005

 -005
 -.005
 0.000
 -.005
 -.005
 0.000
 0.000

 -005
 -.005
 0.000
 -.005
 -.005
 0.000
 0.000

 -005
 -.005
 0.101
 12
 13
 14
 15

SELECT MODE C N R S : C

| CHANNEL GR | OUP : 1 |      | $E_{cm} = +15V$ |      |      |      |      |  |
|------------|---------|------|-----------------|------|------|------|------|--|
| 0          | 1       | 2    | 3               | 4    | 5    | 6    | 7    |  |
| .095       | .105    | .110 | .110            | .105 | .105 | .105 | .105 |  |
| .105       | .100    | .165 | .105            | .100 | .105 | .105 | .105 |  |
| 8          | 9       | 10   | 11              | 12   | 13   | 14   | 15   |  |

SELECT MODE C N R S C

| CHANNEL | GROUP 1 |     | $E_{cm} = +17V$ |       |     |     |       |  |
|---------|---------|-----|-----------------|-------|-----|-----|-------|--|
| Ĵ       | 1       | Z   | 3               | 4     | 5   | 6   | 7     |  |
| 035     | - 025   | 030 | 030             | - 030 | 025 | 030 | - 025 |  |
| 030     | - 030   | 030 | ŭ30             | 030   | 030 | 030 | - 030 |  |
| 3       | 3       | 10  | 31              | 12    | 13  | 14  | 15    |  |

FIG. 2.3 Input Protection Test



FIG. 2.4 Graphic Display of Linearity (Regular) - 15-







# FIG. 3.1 MICROCOMPUTER & PERIPHERALS



## FIG. 3.2 MADC TEST SETUP

- 18 -

| 000              | NADC INFUT TEST NO.2<br>K. SEINO, 9/11/81                                                                                                                      | C CONTINUE OR REPEAT FROM THIS POINT<br>180 IF(ICHGRP.EQ.1) ICHH(2)=Z'80'                                                 |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|
| С<br>С<br>С<br>С | SPECIFY CHANNEL PATTERN, CHANNEL GROUP AND DAC REFERENCE VALUE.<br>THE PROGRAM DIGITIZES AND DISPLAYS A GROUP OF 16 CHANNELS WITH<br>THE SPECIFIED PARAMETERS. | IF(ICHGRP.EQ.2) ICHH(2)=16+Z'80'<br>IF(ICHGRP.EQ.3) ICHH(2)=32+Z'80'<br>IF(ICHGRP.EQ.4) ICHH(2)=48+Z'80'<br>DO 190 I=1,16 |
| č                |                                                                                                                                                                | CALL CFSA(16, NAUR2, ICHN, QRSP)                                                                                          |
| -                | FROGRAM MINTS2                                                                                                                                                 | C DELAY 30 MICRO SEC                                                                                                      |
|                  | DINENSION ICHW 2), IDAREF(2), ICHPAT(2), CHVOL(16), IADR(2)                                                                                                    | CALL DLYA(3)                                                                                                              |
|                  | DIHENSION ICIDA(8), ICIDB(8)                                                                                                                                   | U GET BATA FRUM AUC                                                                                                       |
|                  | REAL\$8 CYCL                                                                                                                                                   | CALL CF SA(0, NAUK2, TAUK, UKSP)                                                                                          |
|                  | REAL CHVOL                                                                                                                                                     | LHVUL( $1 \neq 1$ AUTOCOL TO BEAU AND THEN BUILD                                                                          |
|                  | INTEGER C.N.R.S                                                                                                                                                | L LUNVERT IT FEGS INTEGER TU KEAL AND THEN DIVID                                                                          |
|                  | IATA CINIRIS/'C'I'N'I'R'I'S'/                                                                                                                                  |                                                                                                                           |
|                  | DATA ICIDA/0,1,2,3,4,5,6,7/                                                                                                                                    |                                                                                                                           |
|                  | UATA ICIDB/8,9,10,11,12,13,14,15/                                                                                                                              |                                                                                                                           |
| С                |                                                                                                                                                                | С<br>С. ББТЫТС БЕСШ ТС                                                                                                    |
| С                | INPUT OPERATION PARAMETERS                                                                                                                                     | C FRINIS RESULIS                                                                                                          |
| C                |                                                                                                                                                                |                                                                                                                           |
| 30               | LHD=N                                                                                                                                                          |                                                                                                                           |
|                  | WRITE(5,40)                                                                                                                                                    | URITE(5,210) ICHCRP                                                                                                       |
| 40               | FORMAT(2X, 'ENTER CHANNEL PATTERN IN HEX !')                                                                                                                   | 210 FORMAT(2X, CHANNEL GROUP : (.T1)                                                                                      |
|                  | CALL HEXING INXI )                                                                                                                                             | (ALL SERVI)                                                                                                               |
|                  | ICHPAT(2)=IHXI                                                                                                                                                 | WRITE(5,220) ICIDA                                                                                                        |
|                  | WRITE(5,50)                                                                                                                                                    | 220 FORMAT( 6X+8( 11+7X ))                                                                                                |
| 50               | FURMAT(2X, SELECT CHANKEL GROUP 1 2 3 4 1')                                                                                                                    | URITE(5,230) CHVO                                                                                                         |
|                  | REAU(5,60) ICHGKP                                                                                                                                              | 230 FORMAT(2X,8(F8,3)/2X,8(F8,3))                                                                                         |
| 60               |                                                                                                                                                                | WRITE(5,240) ICIDB                                                                                                        |
| 70               | WX11E(3770)                                                                                                                                                    | 240 FORMAT( 6X, 2( 11, 7X ), 6( 12, 6X ))                                                                                 |
| 70               | FUNDATION FOR THE REFERENCE -2048 (HKU 2047 ; )                                                                                                                | CALL SLFTX 2)                                                                                                             |
| 54               | KLAU(J)80) IKLF<br>EDDWAT(TE)                                                                                                                                  | C DELAY 2 SEC                                                                                                             |
| - 0V<br>- C      |                                                                                                                                                                | CALL DLYB(2000)                                                                                                           |
| 00<br>00         |                                                                                                                                                                | C CHECK HODE                                                                                                              |
| 70               |                                                                                                                                                                | IF(LMD.NE.R) GO TO 250                                                                                                    |
|                  | CALL CIREC(NADR3.0.0.3.0)                                                                                                                                      | CYCL=CYCL-1                                                                                                               |
| C                | CONVERT REFERENCE FROM 12 BIT TO 16 BIT USE                                                                                                                    | IF(CYCL.EQ.0) GO TO 250                                                                                                   |
| 11               | 0 ICDI=IREF                                                                                                                                                    | GO TO 180                                                                                                                 |
|                  | CALL C126RA(ICDI,ICDO)                                                                                                                                         |                                                                                                                           |
|                  | IDAREF(2)=1CDO                                                                                                                                                 | C SEI MULLI C-CUNIINUE, N-NEW, K-KEPERI, S-SIUP                                                                           |
| C                | SEND REFERENCE TO DAC                                                                                                                                          |                                                                                                                           |
| 12               | CALL CFSA(16, NAUR1, IDAREF, ORSP)                                                                                                                             |                                                                                                                           |
| С                | SEND CHANNEL PATTERN TO INPUT SWITCHING UNIT                                                                                                                   | ZOV FUNITHIZAY DELEUT DUBL UNKOF J                                                                                        |
| 13               | CALL CFSA(16, NADR3, ICHPAT, ORSP)                                                                                                                             |                                                                                                                           |
| C                | DELAY 1 SEC                                                                                                                                                    | 2/V FURNAILAL)<br>TE/IND ED EN ED TO 190                                                                                  |
| 14               | O CALL DLYB(1000)                                                                                                                                              | IF(LDB+EU+C) GU 10 100                                                                                                    |
|                  | CO TO 180                                                                                                                                                      | 171LTU+EU+N/60 10 30<br>TE(180 ED D) FD TD 15A                                                                            |
| C                | INPUT NUMBER OF CYCLES                                                                                                                                         | IF(1MD,F0.S) CO TO 280                                                                                                    |
| 1.               | 50 WRITE(5,160)                                                                                                                                                | CR TR 250                                                                                                                 |
| 10               | 50 FORMAT(2X, 'ENTER NUMBER OF CYCLES :')                                                                                                                      | 280 STOP                                                                                                                  |
|                  | READ( 5,170) CYCL                                                                                                                                              | FNI                                                                                                                       |
| 17               | 70 FORMAT(F16.0)                                                                                                                                               | bad 14"                                                                                                                   |

| ;<br>; ROUT: | ine to c                                                                                                                   | OWVERT 12                                                                                                                      | BIT DATA FOR 1 | 6 BIT DAC USE                                                             |
|--------------|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------|
| ;<br>;<br>;  | FORMAT:                                                                                                                    | C126DA( IC                                                                                                                     | DI,ICDO)       |                                                                           |
| -<br>-<br>   | ENTRY                                                                                                                      | ICDI<br>ICDO<br>C126DA                                                                                                         | (HL)<br>(DE)   |                                                                           |
| C126DA:      | PUSH<br>PUSH<br>LB<br>INC<br>LD<br>SLA<br>RL<br>SLA<br>RL<br>SLA<br>RL<br>SLA<br>RL<br>LD<br>LD<br>INC<br>LD<br>POP<br>RET | AF<br>BC<br>Ar(HL)<br>HL<br>Br(HL)<br>A<br>B<br>A<br>B<br>A<br>B<br>A<br>B<br>A<br>B<br>A<br>B<br>A<br>B<br>(DE),A<br>BC<br>AF |                | ;PUT IT IN A AND B<br>;FROM (HL)<br>;SHIFT 4 TIMES<br>;PUT RESULT IN (DE) |

### FIG. 4.1 (b) Program Example - Subprogram