# MIBEDIDED C MONTHLY SECTION

# GERGEUS GERGEUS THE COMPUTER APPLICATIONS JOURNAL

## THE COMPUTER APPLICATIONS JOURN #86 SEPTEMBER 1997 GRAPHICS AND VIDEO

HDTV—The New Digital Direction Compressing Audio & Video for Internet Build a Laser Billboard EPC: PC Manages a NASA Plant-Growth Chamber



\$3.95 U.S. \$4.95 Canada

## TASK MANAGER

#### Digital TV Now



m sure you've either seen a live demo or read about future scenarios. As the hype goes, a central part of your amazing, self-maintaining house is going to be the television in your living room. You'll have over 100 channels of local, network, and specialized programming including movies, pay-per-view, and digital music. An intelligent, interactive viewing guide will show you what's on based on personal criteria, give you onscreen summaries of listings, let you search the listings while watching another show, and prompt you when "can't miss" shows come on. Audio and video will arrive at your house digitally, eliminating snow, ghosting, and other irritating noise....

Of course, they always tease you at the end stating something along the line of, "The technology necessary to make this dream a reality is available today." Of course, the only reason most people don't have it now is because their local cable company still uses old technology like blocking filters on the line. Comparatively speaking, local cable companies are still writing monthly bills out longhand.

Well, all that is changing for some lucky cable customers. TCI, the nation's largest cable company, has just finished testing a new service that makes the dream demo real. Dubbed All TV (www.alltv.com), it offers the usual fare of basic and expanded analog cable channels. What it adds is up to 85 more channels (for a total of 118 in our area) of special-interest programming, movies, pay-per-view, and music. To fit all those extra channels into a cable system's limited bandwidth, the new channels are MPEG-2 encoded, allowing more to be squeezed into the same space while making the picture more immune to noise. I'm having the service installed tonight, so drop me a note if you're interested in an evaluation once I've had it for a while.

With the recent introduction of DVD and All TV, and with HDTV just around the corner, these are exciting times for what had become a rather mundane audio/video industry.

Speaking of HDTV, we kick off this month's Graphics and Video issue with an update from Do-While Jones on where HDTV is and what it will mean during the next few years. Next, Mike Podanoffsky explores what's necessary for sending audio and video over another popular communications medium—the Internet. Finally, David Prutchi tries to combat the high cost of highway billboards by putting together a laser image projector.

Starting a new MicroSeries, Ingo Cyliax presents the hardware of an MC68030-based workstation he put together for university courses. In upcoming articles, he'll go over software for the board. Jeff constructs a quick PC keyboard-to-serial ASCII converter, and Tom covers the latest silicon for wireless systems.

In *EPC*, Simon Napper starts with a look at the problems of writing device drivers, and explores solutions for maximizing productivity while minimizing learning curves and bugs. Chuck Raskin takes the PC/104 helm this month with an overview of controlling motion with PC/104 boards. And lastly, Fred introduces us to his latest embedded project: a plantgrowth chamber for the Space Shuttle.

editor@circuitcellar.com



EDITORIAL DIRECTOR/PUBLISHER Steve Ciarcia

EDITOR-IN-CHIEF Ken Davidson

MANAGING EDITOR Janice Hughes

TECHNICAL EDITOR Elizabeth Laurençot

ENGINEERING STAFF Jeff Bachiochi

WEST COAST EDITOR Tom Cantrell

CONTRIBUTING EDITORS Rick Lehrbaum Fred Eady

NEW PRODUCTS EDITOR Harv Weiner

ART DIRECTOR KC Zienka

PRODUCTION STAFF John Gorsky James Soussounis ASSOCIATE PUBLISHER Sue Hodge

CIRCULATION MANAGER Rose Mansella

CIRCULATION CONSULTANT John S. Treworgy

> BUSINESS MANAGER Jeannette Walters

ADVERTISING COORDINATOR Valerie Luster

CIRCUIT CELLAR INK<sup>®</sup>, THE COMPUTER APPLICA-TIONS JOURNAL (ISSN 0896-8985) is published monthly by Circuit Cellar Incorporated, 4 Park Street, Suite 20, Vernon, CT 06066 (860) 875-2751. Periodical rates paid at Vernon, CT and additional offices. Oneyear (12 issues) subscription rate U.S.A. and possessions \$21.95, Canada/Mexico \$31.95, all other countries \$49.95. All subscription orders payable in U.S. funds only, via international postal money order or check drawn on U.S. bank.

VISIT OUR WEB SITE FOR SUBSCRIPTION INFORMATION AT www.circuitcellar.com Direct subscription orders and subscription related questions to Circuit Cellar INK Subscriptions, P.O. Box 698, Holmes, PA 19043-9613 or call (800) 269-6301. POSTMASTER: Please send address changes to Circuit Cellar INK, Circulation Dept., P.O. Box 698, Holmes, PA 19043-9613.

Cover photograph Ron Meadows – Meadows Marketing PRINTED IN THE UNITED STATES

For information on authorized reprints of articles, contact Jeannette Walters (860) 875-2199.

HAJAR ASSOCIATES NATIONAL ADVERTISING REPRESENTATIVES

NORTHEAST & MID-ATLANTIC Barbara (Best) Curley (561) 694-2044 Fax: (561) 694-2051 B.Best-Haar@worldnet.att.net MIDWEST & SOUTHEAST Christa Collins (954) 966-3939 Fax: (954) 985-8457 HajarChrista@worldnet.att.net WEST COAST Barbara Jones & Sheliey Rainey (714) 540-3554 Fax: (714) 540-7103 shelley.hajar@worldnet.att.net

Circuit Cellar BBS—24 Hrs., 2400/9600/14.4k bps, 8 bits, no parity, 1 stop bit, (860) 871-1988. For information, mail to info@circuitcellar.com. World Wide Web: www.circuitcellar.com

All programs and schematics in *Circuit Cellar INK*<sup>®</sup> have been carefully reviewed to ensure their performance is in accordance with the specifications described, and programs are posted on the Circuit Cellar BBS for electronic transfer by subscribers.

Circuit Cellar INK® makes no warranties and assumes no responsibility or liability of any kind for errors in these programs or schematics or for the consequences of any such errors. Furthermore, because of possible variation in the quality and condition of materials and workmanship of reader-assembled projects, Circuit Cellar INK® disclaims any responsibility for the safe and proper function of reader-assembled projects based upon or from plans, descriptions, or information published in Circuit Cellar INK®.

Entire contents copyright © 1997 by Circuit Cellar Incorporated. All rights reserved. Circuit Cellar INK is a registered trademark of Circuit Cellar Inc. Reproduction of this publication in whole or in part without written consent from Circuit Cellar Inc. is prohibited.



## NEW PRODUCT NEWS

#### FLAT-PANEL CRT REPLACEMENT

The **VAMP-PanVista** is a 17.7" CSTN-LCD color flat-panel CRT replacement featuring 1024 x 768 (XGA) resolution. Ideal for high informationcontent screens, it rivals color TFT screens in viewing quality.

reens in viewing quality.

The VAMP-PanVista screen offers the viewing area of a 21" CRT at a fraction of the weight, volume, and power consumption (30 W, compared to the CRT's 150+ W). Its color STN (super-twisted nematic) technology permits a brilliant display of 5 12 colors, 150-nit brightness, and a 25: 1 contrast ratio. The VAMP-PanVista accepts standard VGA signals, sync-on-green, composite, and other custom analog signals. Its design enables the use of the existing computer's video card.

The guided acoustic-wave touch option affords 92% optical clarity,

17.7" HIGH VISIBILITY

PANEL MONITOR

Edited by Harv Weiner

150-points/inch resolution, z-axis for pressure-sensitive feedback, and superb resistance to chemicals and scratching. Overall system dimensions for the open-frame

model are 18.7" x 14.3" x 3.5". The VAMP-PanVista sells for \$4490, including the 17.7" display, guided-wave touchscreen, and all interface electronics.

Computer Dynamics 7640 Pelham Rd. Greenville, SC 29615 (864) 627-8800 Fax: (864) 675-0106 sales@cdynamics.com www.cdynamics.com

#501

#### UNIVERSAL PROGRAMMER

The ALL-11 Universal Programmer features a native Windows interface and supports a wide range of flash, (E)EPROM, BPROM, serial PROMs, PLD/CPLD/FGPA, and microcontrollers. This full-featured programmer is affordable enough for project programming but powerful enough for the most demanding applications.

The ALL-1 1 has a 40-pin DIP socket to support devices with 8-40 pins in a DIP package. Available adapt-



ers and converter sockets support devices in almost any package configuration (8–300+) pins. The programmer connects to the serial port of any PC and communicates at up to 115 kbps. An embedded high-speed CPU controls all programming waveform generation by SMD pin driver circuits for guaranteed accuracy in any PC environment.

A Windows 95/3.1 user interface simplifies programming. For example, the AUTO function lists all available operations supported for a particular device. Simply check off the desired operations and press 0 K. For production operation, an external YES key on the programmer can be used to initiate operations, and an LED by the socket signifies that operations completed correctly. To program another device, just insert a blank IC into the socket and press Y ES again.

Priced at \$1095, the ALL-1 1 measures approximately 8.5" x 9.5" and weighs less than 3.2 lbs., including a built-in universal input power supply.

Tribal Microsystems, Inc. 44388 **S.** Grimmer Blvd. Fremont, CA 94538 (510) 623-8859 • Fax: (510) 623-9925 **sales@tribalmicro.com** • www.tribalmicro.com

#502

## **NEW PRODUCT NEWS**

#### **INCLINOMETER**

The ISU Inclinometer is a rugged, noncontact measurement transducer that uses a capacitive angle sensor working in concert with a microprocessor to provide a wide angular measurement range with excellent resolution and accuracy. The inclinometer comes stan-



The PWM output is 30 Hz, free running, and the pulse width varies 49.3 µs per degree. The unit measures 2.6" x 1.3" x 0.6", and it weighs 0.8 oz. Power input is 5 VDC at 2 mA.

The ISU Inclinometer is priced at \$85. Options include limited angle-range calibration, higher or lower accuracy versions, and 4-bit addressability.

dard with both PWM and serial digital outputs onboard, in addition to optional 4-bit addressability. Typical uses include wheel alignment, medical range-of-motion measurements, antenna elevation, construction equipment, and machine tools.

The ISU Inclinometer features a full 360" range with  $\pm 0.1^{\circ}$  accuracy at level and plumb, and  $\pm 0.2^{\circ}$  at other angles. Its time constant is 0.4 s (typical), and it has an angle output rate of 533 ms. Its serial port output is RS-232, except for voltage levels, and runs at 9600 bps.

OEM (1K) PRICE

SmartTool Technologies 2030B Fortune Dr. San Jose, CA 95131 (408) 434-7000 Fax: (408) 434-7080 mdsmart@ix.netcom.com www.macdunc.com

#503

## Parts List Manager

#### For Engineers, Product Designers, Prototypers





HRS: MON-FRI 10AM-6PM EST

## NEW PRODUCT NEWS

#### SINGLE-BOARD COMPUTER

The CP-320 SBC is based on the 80C320 microcontroller and features a variety of interface options. In addition to a high-speed link to a PC parallel port, an RS-232C buffered serial port, and a bidirectional PC/ATcompatible keyboard interface. this board features an IR data link that operates at speeds up to **115.2** kbps. The card also features an RS-485 interface for multipoint data transmission.

The 80C320 microcontroller is an enhanced 8051 derivative. It now

features optimized instruction execution, up to 33-MHz clock speed, two full-duplex serial ports, dual data pointers, and powerfail reset. It also has a watchdog timer, 13 interrupt sources, and enhanced stop and idle operation. The board measures 4.5" x 6.5" and includes either 32 or 64 KB of EPROM, 32 KB of battery-backed SRAM, 82C55 PPI, and a DS1232 processor supervisory chip. In addition to the PC interface connectors, a number of header connec-



tors bring out various board resources.

The 33-MHz version of the CP-320 sells for \$219. A 25-MHz version is available for \$179. Allen Systems 2346 Brandon Rd. Columbus, OH 432211 (614) 488-7122

#504



100 MSa/s Pattern Generator optio

#### Link Instruments (201) 808-8990

369 Passaic Ave • Suite 100 • Fairfield, NJ 07004 • Fax (201) 808-8786 Web: http://www.Linkinstruments.com/col9 · Email: Sales@Linkinstruments.com

For \$499 you get the model DSO 2102 Scope, Probes, Interface Cable, AC Adapter, and Windows and DOS Software.

8 Issue 86 September 1997 Circuit Cellar INK®

## **FEATURES**

28

| 10 | HDTV<br>The New Digital Direction             |
|----|-----------------------------------------------|
| 22 | Compressing Audio and Video Over the Internet |
| 28 | The Laser Billboard                           |

A Low-Cost Laser Image **Projection System** 

## HDTV

## The New Digital Direction

Do-While traces the evolution of television technology, looking specifically at how compatibility with early technology has shaped current developments. He then introduces HDTV fundamentals, going over how the new monitors, bandwidth, and converters will work.

n rare occasions, decisions are made that affect nearly every body. Some people win; some people lose. The bigger the change, the bigger the opportunity and the bigger the danger.

The invention of the personal computer was one of those things. Bill Gates took full advantage of it. You didn't, so nobody talks about your bad haircut.

But now, there's a second chance at a once-in-a-lifetime opportunity. In 2006, all the televisions in 96 million American homes become obsolete. Nearly every one of those households will buy something new (a TV, converter, etc.).

Your mission, if you accept it, is to build something lots of people will buy. Of course, if you design something like the 8-track cartridge or Beta-format VCR, I will disavow ever knowing you.

Seriously, the FCC's decision to switch to high-definition (digital) television (HDTV) has significant impact.

For example, you won't be able to show any 8-mm camcorder home videos on an HDTV unless you have a converter or one built into your set. Your present VCR doesn't work with HDTV, so you need a new one to record your soaps and watch them after work.

But, I'm not going to tell you what to design or buy. The technical issues are far too intricate to explain here.

#### 10 Issue 88 September 1997 Circuit Cellar INK@

**Do-While Jones** 

**FEATURE** 

ARTICLE



Figure 1a—B/WTV signals consist of a luminance signal with audio modulating a high-frequency carrier. b—The red, green, and blue signals from a color camera combine to form a luminance signal. Two chrominance signals, consisting of two of the three color signals, modulate a high-frequency color carrier and are added to the luminance to create a composite video signal.

Instead, I want to give you a general understanding of the issues.

Digital TV frees us from some limitations that resulted from the need to be compatible with technology of the 1950s. The change, however, is not without difficulties.

#### CONSIDER THE QUESTIONS

The practical ramifications of the switch to HDTV aren't generally understood-even by professionals.

I interviewed TV and satellite-dish employees after the FCC announced its decision to convert from analog to digital TV. Not one fully understood the compatibility problems involving camcorders, VCRs, and cable boxes.

A cable-TV manager's response was most surprising. He said 50% of his customers have cable-ready TVs or VCRs because they don't want to mess with a cable box. Only those wanting pay-per-view or premium channels have boxes, and they don't like them.

When TV stations switch to HDTV in 2006, he plans on converting digital video at the station and broadcasting good old NTSC analog video. He may change his mind if the customers who bought HDTVs drop his cable service and buy satellite dishes instead.

What will your cable company do? Broadcast analog video and add HDTV channels as they become available? After 2006, will they drop the analog or convert HDTV to analog and broadcast both converted video and HDTV? Do you own a satellite dish? It can already decode MPEG-2-encoded standard-definition digital television (SDTV), but what about MPEG-2 HDTV? Will you completely replace your receiver, or will someone sell software that makes the receiver HDTV compatible?

Do you have home videos of birthday parties? How will you watch them after 2006? Will you keep an old TV and VCR (stored beside your 8-mm movie projector) for this? Will you pay someone to convert your videos and 8-mm movies to HDTV-format video tapes or disks?

These are just a few of the far-reaching implications of the format change. To make intelligent decisions, you need to understand the reasons for the changes and the compromises made by the various solutions.

Perhaps the easiest-and most entertaining-way to understand the technological issues is to follow the history of TV in America. The performance of today's sets is poor because they're compatible with 1950s technology. Let's look at the foundation that determined how the entire structure came to be.

#### COLOR COMPATIBLE

In the old B/W days, the video signal (luminance) was added to the audio signal. The audio signal modulated a 4.5MHz carrier and could be separated from the video with a high-pass filter. The combined signal, or composite video, is shown in Figure la.

Color TV introduced a difficult problem. There were lots of B/W TVs-not as many as the 200300 million there are today, but quite a few nevertheless.

The number of TV sets went from 137,000 in 1947 to more than 7 million in 1957 [1]. Stations didn't want to broadcast in color if the programs could not be seen on B/W TVs, and people wouldn't buy color TVs if they couldn't watch their favorite B/W programs.

To solve this dilemma, they took advantage of the fact that the three primary colors of light (red, green, and blue) can be mixed to produce any color in the rainbow, including white.

Color-TV cameras measure the amount of red, green, and

blue light coming from the scene. Color-TV sets produce three pictures (a red, green, and blue] so close together that they are virtually on top of each other. If you mix "equal" amounts of red, green, and blue light, you get white light.

Adding the red, green, and blue pictures together creates a luminance signal like the one produced by a B/W camera. Of course, a color set separates the luminance back into red, green, and blue signals. Two added chrominance signals let the TV set do this. Figure lb shows the general method. (I'm fibbing a bit here, but you'll get the truth later.)

The video signal is applied to an RF modulator whose frequency depends on the broadcast channel. Each channel is allowed a 6-MHz bandwidth. Channel 2 is 54-60 MHz, channel 3 is 60-66 MHz, and so on.

There's a gap between channels 6 and 7 because that's where FM radio stations are. But typically, channels are 6 MHz wide and 6 MHz apart.

The modulation technique is Vestigial Side Band (VSB). All the upper side bands are transmitted, but only some of the lower side bands are. This cuts the transmission bandwidth almost in half.

Figure 2 shows the lop-sided frequency spectrum of the broadcast signal. In other words, old B/W TV signals had 4.5 MHz of upper sidebands, which produced sharp, clear pictures.

The new color-TV sacrificed some clarity by taking away bandwidth to add color. This was necessary to retain compatibility between color and B/W video.

The broadcast video goes from the transmitting antenna to the receiving antenna and into the TV tuner. The tuner demodulates the signal to obtain the composite video signal. Now, let's see what happens to the composite video for the color and B/W cases.



Figure 2—The composite video signal uses 6 MHz. The co/or signals occupy some of the bandwidth formerly used by B/W video.

As depicted in Figure 3a, B/W TV just strips off the audio signal and uses the remaining composite video as the luminance signal. It doesn't process the color signals because the B/W circuits were built before color TV was invented.

In old B/W TVs, the low-pass filter rejected the audio carrier, not the color signals. The high-frequency color signals cause the sharp edges of the picture to be a little fuzzier, but most people don't notice the degradation in quality.

Figure 3b illustrates how color-TV circuitry separates the composite signal back into its red, green, and blue components. The low-pass filter extracts the luminance, which contains the three color signals added together.

The band-pass filter extracts color signals from the upper portion of the spectrum and gives them to the demodulator. It extracts the two chrominance signals that separate the colors again.

In this simplified diagram, one of the chrominance signals contains red and green information. The other holds blue and green. Subtracting the red and green chrominance signals from luminance yields the blue signal. Subtracting blue and green yields red. And, of course, subtracting red and blue yields green.

The red, green, and blue signals go to the red, green, and blue guns in the color picture tube. If the input signal is B/W, then there are no chrominance signals and the R+G and B+G signals are 0. The red, green, and blue signals are all equal to the luminance, so the color TV produces a B/W picture.

Figures 1b and 3b aren't entirely accurate. In practice, it's more complicated. Adding equal amounts of red, green, and blue signals doesn't produce a signal that looks exactly like a B/W luminance signal.

A real B/W signal is more sensitive to green because our eyes are more sensitive to green. I ignored this in Figures lb and 3b to show how one intensity and two color signals produce a B/W-compatible color signal. Now you have the concept, I can risk telling you the truth.



Figure 3a—The B/W TV strips off the audio and uses the rest of the signal to modulate the picture tube. b—The color circuitry separates the composite video info ifs red, green, and blue aspects.

The luminance signal (i.e., Y) gives each color a different weight. So, the two chrominance signals (i.e., R-Y and B-Y) must be specially weighted sums so they can separate the luminance into red, green, and blue signals:

$$\begin{split} Y &= 0.59G + 0.30R + 0.11B \\ R-Y &= 0.70R - 0.59G - 0.11B \\ B-Y &= 0.89B - 0.59G - 0.30R \end{split}$$

Y, R-Y, and B-Y are the signals that come out of the S-Video connector on a satellite-dish receiver or high-end VCR. (For a slightly different formulation of these equations, see Mike Podanoffsky's "Compressing Audio and Video Over the Internet" in this issue.)

Adding Y to R-Y produces R. Adding Y to B-Y produces B. And, knowing R and B, lets you compute:

$$\frac{Y-0.30R-0.11B}{0.59} = G$$

R, G, and B are the signals that modulate the red, green, and blue of color TV.

But, you probably want to know *how* the RGB signals produce a color picture. The various mechanisms each set some limits on the picture's maximum resolution, so let's put off this discussion until we talk about resolution limits.

#### ASPECT RATIO

The first picture tubes were round because they were easier to build than rectangular ones. The ideal format for a round tube is a circular picture, but it needs a spiral scan. It's easier to design and build a system that scans a rectangular area horizontally and vertically.

The best rectangle, from a round picture tube's point of view, is a perfect square. Most people prefer rectangles because more interesting information lies to the left and right of center than above and below it. We live in a world where more things are laid out horizontally than vertically.

A square fits in a circle with the least wasted

space. A 16:9 rectangle (16 units wide x 9 units high) wastes a lot of space on the top and bottom.

As a compromise, the 4:3 aspect ratio rectangle was chosen. It gives more viewing area than the 16:9 rectangle and is more pleasing to the eye than the 3:3 square.

Modern picture tubes are rectangular rather than circular. They don't waste space at the top and bottom.

The first rectangular picture tubes were measured diagonally so they could be accurately compared with the predominant round picture tubes of the day, which were specified by diameter. We still use this measuring technique.

Since we can now make picture tubes in any shape, there's no reason to stick with the ugly 4:3 aspect ratio. HDTV uses the 16:9 aspect ratio, which is more visually pleasing and more compatible with commercial motion pictures.

The problem is, how do you display a 16:9 aspect ratio picture on a 4:3 tube? You have three choices-get rid of a picture's right and left edges, make the picture smaller and waste space on the top and bottom, or distort the picture.



Figure 4—Phosphor starts glowing when the electron beam hits if and continues glowing for some time after the beam turns off due to oersisfence.

When movies are broadcast on TV, the first approach is usually taken. Things on the right and left sides of the screen are sacrificed, and the legal disclaimer, "formatted to fit your television screen," is displayed.

Often, this approach can't be used for the opening and

closing credits because the lettering goes from edge to edge. So, the picture is then distorted. Another option is to shrink the whole picture and add black bars at the top and bottom.

If you're going to build an HDTV-toanalog-TV converter, you must decide whether to throw edges away or make the picture smaller.

When you want to display an old 4:3 home movie on a new HDTV, you have the opposite problem. You can throw away the top and bottom or shrink the picture, which wastes space at the sides.

#### SCAN PROBLEMS

Pictures are rectangular-not circular-because they're painted onscreen via a raster scan. In other words, they're painted in the same way you read this magazine. You start with the line at the top of the page, read it left to right, move your eye down one line, back to the left, and read the next line.

American standard analog TV draws 525 lines -30 times per second (but not all appear onscreen). So, a line is drawn approximately every 63 us, and a frame takes about 33 ms. This 33-ms refresh rate causes a problem related to the phosphor in TV picture tubes.

Phosphor glows when struck by an electron beam. Picture-tube manufacturers can adjust the phosphor's chemical formula to alter its characteristics and make it glow red, green, blue, or white. (Remember this fact.)

Right now, it's important that they can make phosphor turn on and off very quickly or very slowly. Adjusting the phosphor's speed is critical.

Figure 4 shows the visible response of phosphor to an electron beam. It doesn't start glowing until the beam hits it. And then, it takes little time to reach full brightness. Once the beam turns off, the phosphor glows for a while. This afterglow is called persistence.



Figure Ca-An interlaced scan draws the odd-numbered lines first and then draws the second field of even-numbered lines to reduce flicker. The dotted lines show the horizontal retrace during the horizontal blanking period. The dashed lines show the vertical retrace. &Progressive scan draws the lines in order, from top to bottom.

The early picture-tube pioneers discovered that if the phosphor was too slow, then moving images looked smeared and blurry. They needed a fast phosphor that could display rapidly changing scenes.

Faster is better-to a point. If phosphor is too fast, it has no persistence. It stops glowing as soon as the electron beam stops shining, causing a flicker.

It turned out there wasn't a good compromise for phosphor speed. When the phosphor was fast enough to show moving scenes, it flickered badly at 30 Hz. To keep the flicker down, the screen had to be repainted at 60 Hz.

The solution was to paint 60 half frames (i.e., fields) per second instead of 30 full frames per second (fps) via a interlacing. All the odd-numbered lines are painted in the first field, and the even-numbered ones go in the second field, as shown in Figure 5a.

Some modern computer monitors draw complete frames at 60 Hz using progressive (noninterlaced) scan. This method is shown in Figure 5b.

Whether the TV signal is analog or digital, cathode ray tubes (CRTS) are analog devices. The electron beam is steered by magnetic fields produced by analog voltages.

There are both horizontal- and vertical-sweep oscillators. Figure 6 offers simplified versions of their waveforms. For American TV signals, there are 525

cycles of horizontal sweep for every 2 cycles of vertical sweep.

In TV's early days (before networks and video tape), all programs were transmitted live from a local studio. The beam moving across the viewer's TV screen had to match the position of the beam in the studio's B/W camera.

So, the horizontal- and vertical-sweep oscillators in the camera and TV had to be phase-locked to each other. If they weren't, the picture resembled Figure 7.

At the time, the only commonly available frequency

reference in America was the 60-Hz power line. The TV station locked its camera vertical-sweep oscillator to it, as did the TV set in each viewer's home.

A vertical-hold knob on the TV controls let viewers adjust the phase to keep the picture from rolling off the top or bottom of the screen. The horizontalsweep oscillator was synchronized to a harmonic of the vertical-sweep oscillator. The user had a horizontal-hold knob that was even trickier to adjust than the vertical hold.

As the years went by, TV manufacturers built sets that automatically locked to horizontal and vertical sync pulses (I'11 explain shortly). No more horizontal- and vertical-hold knobs!

The early requirement to lock the sweep oscillators to the power line explains why American TVs use 60 Hz. In Europe, where the power lines use 50 Hz, the TVs have a 50-Hz field rate.

Older readers will remember that the picture used to "tear" when the channel was changed because signals originating from TV stations in different parts of the country were on different power grids running at slightly different frequencies. The propagation time between the places changed the signal's phase.

Now, we get so many signals from satellites and repeaters that none are



Figure 6—The horizontal- and vertical-sweep oscillators move the electron beam across the screen.

phase-locked to each other. But modern TVs phase lock before you notice it.

Color TV makes part of this possible. Recall that Figure lb showed a color modulator with two chrominance inputs. It's a synchronous modulator whose output must be synchronously demodulated. Every color TV must have a 3.58-MHz oscillator precisely locked to the transmitter's 3.58-MHz oscillator. You can't get that from a 60-Hz power line! So, let's talk about sync pulses and color bursts.

If you look at a TV signal on an oscilloscope, you see sync pulses every  $63.5 \ \mu s$  (see Figure 8a). The TV set can't mistake them for video information because they go outside the range of values from black to white.

Figure 8b shows an 8-cycle color burst that was added to the sync pulse so color TVs could synchronize their color demodulator to the transmitter's color modulator. Every 63  $\mu$ s, the TV adjusts its color oscillator against this color burst. The reference signal must be 3.579545 MHz  $\pm$  0.0002793%.

Since the color TV needs a precise reference to demodulate the color signal, that reference is used to generate the horizontal and vertical oscillators. The horizontal scanning frequency is exactly 2/455 times the color reference signal (i.e., 15.7 kHz).

Since there are 525 lines per frame, the frame rate is 29.97 Hz. There are two fields per frame, so the field rate is 59.94 Hz. Since B/W TVs use a field rate of 60 Hz  $\pm$  a few percent, the 59.94-Hz rate is within a B/W circuit's tolerance.

In Europe, there are 625 lines per frame. Dividing the 15.7-kHz horizontal scanning frequency by 625, you get a frame rate of 25.17 for a field rate of 50.3 Hz-very close to their power-line frequency (not a coincidence!).

Just to muddy the waters some more, movies are recorded on film at 24 fps. Maybe you've seen old movies of Babe Ruth hitting a home run and running the bases. He sure could run fast!

Each frame was scanned twice to produce two fields of video, which is 48 fields per second. But, they're broadcast at 60 fields per second, so he seems to run 25% faster than he really did. The time compression enhances the comic effect of silent films starring the



Figure 7—The picture at the left is properly centered, but if the horizontal or vertical sweep oscillators are out of sync, the picture will run off the screen as shown in the center and right pictures.

Keystone Kops or Charlie Chaplin, but it isn't acceptable for modern films.

The reason you don't notice the same effect on modern films on TV is that 3:2 pull down is used. The first frame of film is scanned three times to produce three video fields. The second frame is scanned twice to produce two fields.

During a 1 -s period, 12 film frames are scanned three times, producing 36 video fields. The 12 film frames are scanned twice to make another 24 video fields (e.g., 60 video fields per second).

When they broadcast at 59.94 fields per second, the speed error is only 0.1 %, which isn't noticeable. Neither is the jitter introduced by the 3:2 pull down. The new digital TV standard provides for several different aspect ratios at several different frame rates. The new sets will have to be much more flexible, potentially leading to a completely new display technology.

#### VCR ISSUES

VCRs record 6-MHz analog video. Since HDTV occupies the same 6-MHz channel as analog TV, you'd think your present VCR could record HDTV. Sorry.

VCRs aren't just tape recorders with a 6-MHz bandwidth. When they first came out, a friend tried to get a highquality recording of some l-MHz signals he was working with. It didn't work.





Figure 9 shows how a standard audio cassette-tape recorder records data along the length of tape. It only uses half the tape at a time so the cassette can be flipped over to record on the other side.

Although VHS now stands for Video Home System, when the technology first came out, it stood for Video Helical Scan. The original name gives some insight into how the recorder works.

Not only does the tape move, but the record heads move, too. The path of the head along the tape is helical, like lines on an old-fashioned barber's pole. The video signals are recorded almost perpendicular to the motion of the tape, as shown in Figure 10.

Although there are some obvious discontinuities at the tape edges, they don't cause a problem for analog video. The tape head's motion is synchronized with the vertical sync pulses.

Each stripe represents a whole frame. That's why you can push the VCR's pause button and see the same frame over and over. The head is moving, but the tape isn't, so the same stripe gets read again and again.

Since the tape isn't moving, the stripe of recorded video isn't perfectly aligned with the head's motion. It scans several adjacent stripes and the blank space in between, producing the snow you see onscreen when you hit pause.

The reason my friend couldn't get a good recording of the l-MHz signal was that there was a break at the edge of the



Figure 9-A stereo cassette tape stores audio information in four parallel tracks that run the length of the tape.

Figure 8a—A sync pulse goes from black to blacker-than-black at the end of every line of B/W video so the TV can synchronize ifs horizontalsweep oscillator (not to scale). b-A color reference signal is added to the sync pulses to keep the color demodulator properly synchronized.

tape every 33 ms. There, the data was lost and the VCR tried to insert a vertical sync pulse. That's why you can't record a 6-MHz digital bitstream on a 6-MHz VHS tape recorder.

You can build a VCR with a converter that changes HDTV to analog TV and records it in VHS format. It would include another converter changing the analog TV back to HDTV format, but with poor quality and a 4:3 aspect ratio. That solution may suffice for the short term, but eventually it will become unacceptable.

No doubt you've noticed that people are so accustomed to color TV, nobody watches B/W anymore. The day will probably come when people are so used to HDTV, they won't like analog video, either. When that day arrives, they'll demand digital VCRs that reproduce HDTV perfectly.

#### **VIDEO RAM**

Most personal computers (excluding laptops) use CRT monitors for the screen display. The interface between the digital data and the analog signals moving the electron beam across the screen is a video card that appears as memory to the computer.

Each memory location corresponds to a particular screen location. The program simply writes the desired color to that memory location, and the video card does the rest.

The video card scans the video memory synchronously with the horizontal- and vertical-sweep signals. Unless you *want* snow onscreen, you better not be changing the value in RAM at the same time as the video card's display circuitry is reading it!

About 10 years ago, I worked on a system that used a video insertion card to superimpose text on analog video. We had to update the card only during the vertical blanking interval when the electron beam was moving from the bottom of the screen to the top. I suspect modern video cards do that automatically now. They probably double-buffer the data so you can write to the buffer whenever you want. The card transfers data from the buffer to the video memory at the appropriate time.

The video RAM decouples the input data rate from the display refresh rate. I'm certainly not typing 29.97 characters per second. The screen doesn't flicker every time I press a key.

The computer remembers what I typed and updates RAM at whatever rate I type. The video card displays it using the proper screen-refresh rate.

The practical implication is that if I program my computer to decode MPEG-2 compressed digital video (from a disk file, broadcast video, the Internet, or other source), it doesn't matter if the display rate matches the frame rate or if the monitor paints the screen using progressive or interlaced scans.

As long as the data is buffered so a video RAM location isn't changing while the output circuitry scans it, there won't be a problem. If the frame rate is slower than the display refresh rate (almost certainly the case), then the video memory automatically displays



Figure 10—In a VHS recorder, the record head moves perpendicular to the tape, painting diagonal stripes of data on the tape.

the last frame [or half-frame, if interlaced) while waiting for new data.

So, there's more freedom (opportunity) for designing HDTV monitors. Just because the monitor receives digital information at a particular rate (e.g., 30 Hz) doesn't mean that the picture tube has to be refreshed at that rate. If it could, the monitor might display each frame three times, refreshing the screen at a 90-Hz rate.

The important point is that analog TVs had no capability to store the picture. They had to display every pixel the moment it was received.

Digital TVs receive compressed blocks of information, which are decoded and stored in memory. The TV



monitor can display the information stored in memory any way it wants to, as often as it wants to.

The digital-TV standard only specifies how the information is encoded and transferred. It tells how the TV *could* process the encoded information once it is received, but it's not required to work that way.

#### THE BANDWIDTH ISSUE

Although we commonly refer to American analog TV as having 525 lines, not every line is displayed onscreen. Some lines at the top of the screen contain calibration signals. The actual resolution is approximately 480 lines of 640 picture elements (pixels). Figure 1 **1a**—Early picture tubes had roughly 300,000 clusters of colored phosphor dots. Each color was illuminated by a different electron beam. b-Modem picture tubes have vertical bands of differently colored phosphors.

The HDTV standard lists four frame shapes broadcast at frame rates of

23.976-60 Hz. The most talked about is 1080 lines of 1920 pixels (16:9 aspect) at 29.97 Hz, which has about twice as many lines as analog TV and three times as many pixels per line.

Since HDTV has six times as many pixels as analog TV, you may expect it to take six times as much bandwidth to transmit. Since each analog TV channel is 6 MHz, early estimates were that digital TV would need roughly 36 MHz. It doesn't. It takes about 6 MHz.

How? The amount of bandwidth required depends on the amount of information transmitted. Sampling Walter Chronkite's face six times as often doesn't increase the information you get from him sixfold. From an information-theory point of view, each pixel in a high-definition picture doesn't contain as much data as each pixel in a standard-definition picture. That's because the high-definition picture is oversampled.

Each sample is not statistically independent from the ones around it. Whenever there's redundant information, there's an opportunity for compression.

The Motion Picture Experts Group (MPEG) has defined a standard data compression technique called MPEG-2. Although a complete discussion of MPEG-2 is beyond the scope of this article, I want to go over some general principles of data compression it uses.

You've probably seen a color-bar test pattern. One style has eight vertical bars that run white, yellow, cyan, green, magenta, red, blue, and black.

If you transmit this pattern on analog TV, each line is equivalent to 80 white pixels, followed by 80 yellow pixels, and so on. If you transmit this pattern on uncompressed digital TV with 1920 pixels per line, it would be 240 white pixels, followed by 240 yellow pixels,





#### **E-Series**

EPROM - FLASH - SRAM emulation and LIVE editing, 1 to 8Mbit, 70ns access time. Low voltage (3v)options.



Tel (902) 425 3938 Fax (902) 425 4098 Sales & Info (800) 352 9770

Design

Inc.

and so on. It's not more information, just more bits.

A compression technique called runlength encoding dramatically reduces the number of symbols to be transmitted. Instead of sending the message "white, white (240 times), yellow, yellow (240 times), etc.," you send the message "240 white, 240 yellow, etc.," reducing the number of symbols you need to send to describe one line.

In the color-bar pattern, if you've seen one horizontal line, you've seen them all. So, instead of transmitting the

same line 1080 times, you can send a message that says the next 1079 lines are identical to the previous one.

Taking this a step further, once you've seen a frame of color bars, you've seen them all. There's no need to transmit the same picture 30 times per second. Just transmit a message saying this frame is identical to the last

frame is identical to the last one.

It's possible to compress a color-bar test pattern to practically nothing since it contains little information. It takes very little bandwidth to send a color-bar test pattern regardless of the resolution. Real TV pictures contain more data.

From an information-theory perspective, however, TV is still a vast wasteland of little information. All TV signals can benefit substantially from compression techniques.

Generally speaking, MPEG-2 takes advantage of the fact that adjacent pixels tend to have the same value and that each new frame is similar to the preceding one. It effectively breaks the picture into little squares and scans them in a diagonal zigzag, hoping to find long runs of pixels that are the same value so it can do run-length encoding.

MPEG-2 also compares frames with previous frames. Imagine a camera sitting on a tripod looking at a mountain. The scene doesn't change, so no new information needs to be transmitted.

Suppose the camera pans slowly to the right. Some new pixels appear to the right, and some old ones fall off the left side. The pixels in the middle stay the same, just shifted left.

All you need to do is to transmit the amount to shift the old image and the

few new pixels on the right side of the screen. That greatly cuts down the number of pixels you have to send.

Suppose the camera is sitting on the tripod, not moving, looking at a mountain, when an airplane flies through the field of view. You just need to create a tiny subpicture that contains only the pixels that tell how the airplane looks.

Send this subpicture, and tell the receiver where to put it on the screen. As the airplane flies through the screen, keep telling the receiver how much to move the airplane on the background.



With so much motion, camera rotation, and frame-to-frame difference, the required bit rate might not fit in the allotted bandwidth. Frames will get lost, and the ones you get will be smeared and cluttered with so many artifacts that the commercial might be unwatchable. (Is this is a bad thing?)

In some instances, such as live TV news broadcasts, the encoding will be done in real time. But, in certain cases,

some processing will be done offline.

If you cut the ads, a halfhour TV show is about 22 min. It consists of 39,600frames ( $22 \times 60 \times 30$ ).

Suppose you had an old IBM PC XT sitting around to process those 39,600 frames at a rate of 1 fps. It would take 11 h to compact

the entire program and store it in a file.

At the scheduled broadcast time, you'd simply transmit the compressed file at 30 fps. Or, you could put the file on an optical disc and sell it. Or, you could put the file on the Internet and let subscribers pay to download it whenever they want. You don't have to do everything in real time.

The important new thing about digital video is that display rate is no longer tied to transmission rate, or power line frequency, or anything else. The receiver gets a bitstream that contains compressed frames of data.

Normally, the receiver decodes them on-the-fly and displays them at the rate that it receives them, but it doesn't have to. This is an advantage that can be exploited.

#### MONITOR LIMITATIONS

Building something that can display 1000 lines of video with that much real resolution won't be easy. To understand why, consider the color picture tube.

The first color picture tubes had three electron guns at the back and clusters of three phosphor dots (red, green, and blue) at the front as you see in Figure 1 la.

These three-gun tubes produced three electron beams. The beams were aimed



Figure 12-The electron beam has to refresh the phosphor frequently to keep it glowing.

The MPEG-2 encoding scheme uses a mixture of I-, P-, and B-frames. Iframes are pictures coded using information present only in the picture itself. Predicted P-frames are pictures coded with respect to the nearest previous Ior P-frame. B-frames use both past and future picture frames as a reference.

How does an MPEG-2 encoder know what the future frames will be?

There are both "hard" and "soft" real-time situations. A video teleconference is a hard real-time situation. You can't delay the video too long, or people will find it hard to communicate.

Most broadcast video, however, is a soft real-time situation. Those I *Love Lucy* reruns have been delayed for decades already. A few more seconds won't make any difference.

Therefore, you can delay the transmission a few frames and compare each frame with the next frame as well as the last one. Since it's easier to predict the future when you already know it, this technique greatly simplifies encoding. That's why MPEG-2 encodes a group of pictures rather than single pictures frame by frame.

Compression algorithms generally make compromises, and MPEG-2 is no exception. MPEG-2 is optimized for a typical program. It probably won't work slightly differently so that, for a particular horizontal- and vertical-sweep voltage, the first beam hit the red dot, the second the blue, and the third the green.

The red, green, and blue signals controlled each beam's intensity. As you can imagine, they were difficult to keep aligned-which is why they don't make them anymore. Modern color TVs use a single gun with vertical phosphor strips as shown in Figure 11b.

They sweep a single electron beam across vertical bands of phosphors. The beam's intensity is time-division multiplexed between the red, green, and blue signals.

An HDTV signal has 1920 pixels per line. To get 1920 pixels of color, you need 5760 (3 x 1920) bands of phosphor. If the picture tube is  $4'9'/_2''$  wide (57.6"), then

each phosphor band is 0.01" wide. If the CRT has to paint 1080 lines 30 times per second, that's 32,400 lines per second. Each line must be painted in 30.8 μs.

But, the beam has to be multiplexed 5760 times per line, so each phosphor is illuminated for 5.36 ns. An extra 5-ns delay makes everything red look blue, everything blue look green, and everything green look red. A stray magnetic field deflecting the electron beam 0.01" has the same effect.

Can someone build a TV that keeps the horizontal sweep synchronized to the intensity modulation to within 1 ns and keeps the electron beam shielded from magnetic and electrostatic fields? Probably so.

Can anyone mass produce such a TV at a price consumers will pay? I doubt it. Will such a TV require constant adjustment? You bet your assets it will.

Front-projection TVs have a better chance of achieving high definition than CRTs. These systems have what amounts to three separate B/W picture tubes mounted in a single chassis.

One tube is driven by the red signal and projected through a red lens onto a movie screen on the wall. The other tubes are driven by the green and blue signals and projected through green and blue lenses, respectively.

The CRTs can be smeared with a continuous layer of phosphor (like an

oscilloscope), so there's no problem with hitting specific phosphor dots or bands.

The tricky thing for projection TVs is to get the three pictures aligned. We have several of these systems at work, and they go out of alignment frequently. Every few weeks, we notice the white letters have a red tint to the left edge and a blue tint on the right edge (or some other color aberration), and the technician has to adjust things again.

The place to build a high-definition display is at a baseball park. You could build a big outdoor screen out of 5-lb.



Figure 13a—To convert analog video to MPEG-2 video, use conventional echniques to separate the composite video into three 525-line S-Video co/or signals and an audio signal. Encode the bottom 480 lines using the MPEG-2 encoder algorithm. b-To convert HDTV to analog NTSC video, store the digital image in memory and then convert a portion of that memory to a video signal.

coffee cans with three colored light bulbs in each can.

To get full 1920 x 1080 resolution, you'll have to drink a lot of coffee (5184 tons) to get the 2,073,600 cans you need. If they start selling coffee instead of beer at Dodger Stadium, you'll know why.

Such a screen could be made of modules, each consisting of a matrix of 96 x 54 cells. They'd need 400 modules to construct the entire screen. Each module could have a micro taking color information from a section of shared memory and setting the brightness of the 15,552 bulbs it's responsible for.

Technically, there's nothing to this. But anytime you have over 6 million light bulbs, you have to wonder, "How many maintenance workers does it take to change 6 million bulbs?"

Of course, there's a higher-tech way to build giant outdoor screens. Consider a video wall of CRT screens. You may have seen a TV news anchor standing in front of an array of I2 video monitors (3 rows x 4 columns, due to the 4:3 aspect ratio of analog TV).

The monitors can display 12 individual pictures or one-twelfth of a single huge picture. You could build a 1920 x 1080 outdoor display with 120 x 120 monitors, each displaying a 16 x 9 array of pixels. Or, you could build an array of 16 x 9 square monitors where each displays 120 x 120 pixels.

The design of an outdoor screen is primarily a study of tradeoffs. Several ways aren't technically challenging. Just

pick the best one after looking at performance in daylight, power consumption, cost, and maintenance issues. The real challenges come in making a high-definition display fit a living room.

#### NEW MONITOR TECHNOLOGY

Home HDTV requires a breakthrough in monitor technology. I believe the solution requires parallel processing. Here's why.

Let's go back to Figure 4, which shows the response of a phosphor dot to a single electron beam pulse. To reduce flicker, the electron beam must refresh each phosphor dot before persistence dies away, as shown in Figure 12.

Figure 12 isn't drawn to scale because doing so would be impossible. Earlier, I said that for a 1920 x 1080 color picture tube, the electron beam illuminates the each phosphor dot for 5.36 ns every 33.3 ms [assuming a 30-Hz scan).

Suppose I drew the 5.36-ns pulse 0.01" wide. The pulses would be 5182 apart. Imagine the fold-out drawing!

The basic problem is that, regardless of the frame rate, the duty cycle (the ratio of illumination time to time between illuminations) of the illumination pulse is O.OOOOI%! This is a natural result of serial processing.

In a 1920 x 1080 color CRT, 6.22 million phosphor dots have to be illuminated one after another. Such volume causes a serial processing bottleneck. In computing, we solve this problem via parallel processors.

Imagine a CRT with not one, not three, but 1080 electron guns. Each gun illuminates one line, so all 1080 lines can be illuminated in parallel. Suppose you want to refresh the screen not 30, but 300 times per second. There are 5760 (1920 x 3) phosphor bands per line. Each line is drawn every 3.33 ms, so each band is illuminated for 578 ns every 3.33 ms for a duty cycle of 0.017%.

I doubt it's practical to build a CRT with 1080 guns. But, maybe you could build a linear array of tiny red, green, and blue LEDs.

If you put 5760 LEDs in a line and multiplex the drive current to them, you can produce a line of video. Then, stacking 1080 of them would give you a full 1920 x 1080 display with a 300-fps refresh rate.

If you receive 30-Hz American video, you just display each frame 10 times. If you receive 25-Hz European video, you display each frame 12 times. Frame rate becomes irrelevant.

I don't expect anyone to build CRTs with 1080 electron guns or displays with 6 million LEDs. But, I do expect someone to develop a flat-panel display (perhaps using liquid crystals, phosphors deposited on silicon, or another technology) that's driven by a large array of simple processors which scan a section of video RAM and illuminate small portions of the screen in parallel.

#### **BUILDING CONVERTERS**

Figure 13a shows a general approach for converting analog video to SDTV.

The ATSC (Advanced Television Systems Committee) Digital Television Standard defines several data formats. One is 640 x 480 at 29.97 Hz, interlaced, which has a 4:3 aspect ratio. It was clearly designed for encoding the current American standard analog video.

Remember, the first several lines of 525-line analog video contain reference signals for diagnostic and automatic calibration purposes, so they don't need encoding.

You can use them to adjust the gains of your color circuits, but otherwise, they can be ignored. Use 480 of the lines below the calibration signals when encoding the picture.

Converting digital TV to analog is a bit trickier. Digital TV signals may be 640 x 480 SDTV, 1920 x 1080 HDTV,

or the somewhat less popular 1280  $\times$  720 and 704  $\times$  480 formats.

You need an intelligent decoder to figure out which format is being transmitted. Once you've done that, you can store the frame as an array in memory. Then, you need to process some (or all) of the data in this array and write it to a video RAM that produces 525-line analog video, as shown in Figure 13b.

When converting 1080-line HDTV to 525-line analog TV, you must decide if you want to simply discard every other line or average two adjacent lines together. (I suspect the former is the better choice.) You also need to decide if you want to throw away the right and left sides of the picture or shrink the picture and add black lines at the top and bottom.

#### MORE TECHNICAL INFO

Although this discussion barely scratches the surface, I hope you're now more familiar with the problems that need to be solved as well as the background material which the more advanced technical references assume you already know.

If you want to do some research on your own, start looking on the Internet. The HDTV standard adopted by the FCC is the one proposed by the Advanced Television Systems Committee [2].

MPEG's home page is a good place to get information on the MPEG-2 algorithm. This algorithm is at the heart of HDTV, and I really skimmed over it. It deserves a whole article all by itself.

DVD looks like a good candidate for recording digital television programs and movies. Work your way down the MPEG home page for a really good FAQ page.

Of course, lots of manufacturers have Web pages that bury useful information in with their sales pitches. Use your favorite search engine to look for ATSC, MPEG-2, DVD, or HDTV.

The sci.engr.television.advanced news group has an excellent information/flame ratio. Post specific questions, and you're sure to get good responses.

#### HOW WE GOT HERE

Our TV broadcast system is a legacy of 1950s technology.

Frame rates are tied to the powerline frequency and the persistency of phosphor. The picture area is driven by the compromise of fitting a rectangle in a circle. Every advance had to be backward-compatible with a 1950 TV.

Breaking tradition is hard. Backward compatibility is good, but there comes a time when you have to switch from DOS to Windows. It's painful at first, but once you make the change, you're free to do much more.

With HDTV, pictures will be clearer and screens larger. You can have fivechannel surround sound in your living room. Eventually, you'll be able to choose among different languages for some programs.

You will be able to store (and manipulate) the images in your computer. You can have picture-in-picture-inpicture-in-picture, so you can watch all the games (or soaps) at the same time. You can even watch TV while surfing the Internet. It is hard to imagine all the possibilities.

It's an exciting time to be working (for fun or profit) in the television or computer industry.  $\Box$ 

Do-While /ones has been employed in the defense industry since 1971. He has published more than 50 articles in a variety of popular computer magazines and has authored the book Ada in Action. You may reach him at do\_while@ridgecrest.ca.us.

#### REFERENCES

- A.G. Williams, Motorola general sales manager, quoted in "40 Years Ago in Electronic Design," *Electronic Design*, 45:8, 64, 1997.
- [2] ATSC, ATSC Digital Television Standard, Document A53, September 16, 1995.
   ftp.atsc.org/pub/Standards/A53

#### Internet

DVD FAQs, www.mpeg.org/~tristan/ MPEG/dvd.html#dvd-intro sci.engr.television.advanced

#### IRS

401 **Very** Useful 402 Moderately Useful 403 Not Useful

## FEATURE ARTICLE

Mike Podanoffsky

# Compressing Audio and Video Over the Internet

With the advent of video technologies and the Internet, the plain old telephone service just doesn't cut it any more. Mike tells how a hardware/software codec maintains highperformance CD sound, full color, and highquality image size. uring the past year, I've been part of a team at PictureTel developing LiveLan 3.0, an Internet/Intranet video-conferencing system. As I'm sure you know, the Internet is a set of protocols (e.g., sockets, HTTP, ftp, news, gopher, and POP3 mail) that runs on top of basic TCP/IP.

Video conferencing over TCP/IP is based on the ITU H.323 standard. Other standards exist for video conferencing over ISDN (H.320) and POTS (H.324).

If you're in the market for H.323 products, there are other options. Microsoft is giving NetMeeting 2.0 away free as part of its Internet Explorer 4.0 suite, and Intel is pushing ProShare. Or, you could check out White Pine Software's popular Enhanced CU-See-Me system. All of these products require at least 32 MB of RAM and a Pentium processor for effective use.

With 28.8-kbps modems, it's difficult to achieve anything greater than 3 frames per second (fps) for gray images with little or no audio. You can appreciate this relatively low quality of service when you compare it to a 24-fps rate of motion pictures in the U.S. or to broadcast TV, which transmits color images at 30 fps in the U.S. and Japan and 25 fps in Europe.

For business-quality communications, you need 15-20 fps. This rate is difficult to sustain over typical T1 and T3 Internet connections using softwareonly video-conferencing systems.

PictureTel overcomes these limitations by using a hardware/software codec. This provides higher performance, including audio-CD sound, full color, and CIF [high quality) image size.

The codec is the heart of video conferencing. It's the component that compresses and decompresses video and audio datastreams.

The compression scheme is set by international standards and recommendations. Under H.323, the H.261 and H.263 proposal/standards define video codecs; G.711, G.721, G.722, G.723, G.728, and G.729 handle audio codecs; and H.245 defines how a call is established and capabilities exchanged.

Some of these protocols are also part of the ISDN and POTS standards, making it possible to communicate packets of data between different types of systems.

#### VIDEO COMPRESSION

H.261 video compression is essentially MPEG compression. This lossy compression scheme allows some information to be lost in order to gain substantial compression ratios (on the order of 10:1 to 20:1). Visible quality loss can be perceived at the higher compression ratios.

Under H.261 and H.263, there are two basic image sizes-CIF or QCIF. CIF (Common Intermediate Format] defines an image of 352 x 288 pixels, roughly 4" x 4", or one-quarter of an 800 x 600 screen. QCIF is 176 x 144 pixels, which is about one-quarter the size of a CIF image (-2" x 2").

Undersampling of color data is possible without perceptible loss because the human eye is far more sensitive to changes in brightness than color. Color frames are actually only 176 x 144 for CIF and 88 x 72 for QCIF. In other words, only a quarter of the color data is ever sampled, stored, or transmitted.

MPEG exploits motion detection as part of its compression algorithm. That is, successive frames in a videostream need only send and detect differences. Each transmitted frame, whether it's a full or fractional part of an image, is encoded using JPEG's Discrete Cosine Transform (DCT) compression.

The value in each MPEG frame is encoded using YUV-the same color representation system employed by video cameras. This system represents the value of luminance (brightness) as Y, followed by the blue and red chrominance. Green can be derived from these values.

Blue chrominance is always represented as the value of blue color minus the luminance value. Similarly, red chrominance is always represented as the value of red minus luminance.

This color coding technique creates values that can be converted to traditional RGB values via: 
$$\begin{split} |Y'| &= 10.299 \ 0.587 \ 0.1141 \ |R| \\ |B' - Y'| &= | \ -0.299 \ -0.587 \ 0.8861 \ |G| \\ |R' - Y'| &= | \ 0.701 \ -0.587 \ 0.1141 \ |B| \end{split}$$

(Do-While Jones offers slightly different versions of these equations in "HDTV— The New Digital Direction," pp 10–21.)

MPEG frames are divided into 16-x16-pixel macroblocks. Each macroblock consists of four 8 x 8 luminance blocks and two 8 x 8 chrominance blocks-one for blue and one for red chrominance.

Each block is compressed using DCT. Macroblocks are created only if they represent a difference in motion.

Frames can be encoded in three types: intra-frames (I-frames), forward predicted frames (P-frames), and bidirectional predicted frames (B-frames).

Listing1 — This portion of the JPEG decoder shows how JPEG information is packed to take advantage of every bit. Four fables exist at the beginning of every JPEG file to store the actual DCT coefficients. The remainder of the frame uses offsets to these values, which further reduces the size of every image.

```
Huffman Decoder for dct_coeff_first and dct_coeff_next. It
  examines the next 8 bits of the input stream and performs the
 following cases:
  '0000 0000'-examine 8 more bits (i.e., 16 bits total) and perform table lookup on dct_coeff_tbl_0.
   0000 0001'-examine 4 more bits (i.e., 12 bits total) and perform
               table lookup on dct_coeff_tbl_1.
  0000 0010'-examine 2 more bits (i.e.,
                                            10 bits total)
                                                            and perform
               table lookup on dct_coeff_tbl_2.
 '0000 0011'-examine 2 more bits (i.e.,
                                           10 bits total) and perform
               table lookup on dct_coeff_tbl_3.
 Each time, one more bit is examined to determine sign of level.
static void decodeDCTCoeff
  (unsigned short int *dct_coeff_tbl,
                   int *run,
   unsi gned
                   int *level)
  show bits32(next32bits);
  flushed = 0;
                                          /* show_bits8(index); */
  index = next32bits >> 24;
  if (index > 3){
    value = dct coeff tbl[index];
    *run = (value & RUN-MASK) >> RUN-SHIFT;
    if (*run == END OF BLOCK) {
      *level = END-OF-BLOCK; }
    se if (index == 3)
    index = next32bits >> 22;
                                          /* show_bits10(index); */
    value = dct_coeff_tbl_3[index & 31; }
    else if (index) {
                                          /* show_bits12(index); */
      index = next32bits >> 20:
      value = dct_coeff_tbl_1[index & 151: }
      el se {
        index = next32bits >> 16;
                                          /* show_bits16(index); */
  value = dct_coeff_tbl_0[index & 2551; }
*run = (value & RUN_MASK) >> RUN-SHIFT:
  *level = (value & LEVEL-MASK) >> LEVEL-SHIFT:
  flushed = (value & NUM_MASK) + 2;
  if ((next32bits >> (32-flushed)) & 0x1) *level = -*level;
                                          /* Update bitstream; */}
    flush_bits(flushed);
```

An MPEG image always begins with an I-frame. These I-frames are inserted at regular intervals in the stream, usually every 400 ms.

This timing is crucial for synchronization. For instance, should the stream only contain differences, once some data becomes lost or corrupted, the remainder of the video is useless.

I-frames are encoded as a single image with no reference to past or future frames. The encoding scheme is similar to JPEG compression.

Each 8 x 8 block is encoded independently, and its values are transformed using a DCT, which separates the image into independent frequency bands. The resulting data is quantized and run-length encoded in a zigzag pattern, as shown in Figure 1.

If you take an image as shown in Table la, the coefficients produced by the DCT logic produce the result in Table 1b. Notice the unique zigzag pattern produced by the algorithm.

Quantization is the lossy part of JPEG compression. It reduces the size of the resulting data by removing the difference between like values.

So, if an image contains ten hues of red, they are reduced to three (or fewer). How much is removed from the datastream dictates how much compression is achieved.

A P-frame-or, forward-predicting frame-is encoded relative to the past reference frame, which is the closest preceding reference frame. It can be either a P- or an I-frame.

Each macroblock in a P-frame can be encoded as an I- or P-macroblock. An I-macroblock is encoded just like one in an I-frame. But, a P-macroblock is encoded as a 16 x 16 area of the past reference frame plus an error term.

To specify the 16 x 16 area of the reference frame, a motion vector is included. A motion vector (0, 0) means the 16 x 16 area is in the same position as the macroblock being encoded. Other motion vectors are relative to that position and may include half-pixel values, in which case, pixels are averaged.

The error term is encoded using the DCT, quantization, and run-length encoding. A macroblock may also be skipped, which is equivalent to a  $\{0, 0\}$  vector and an all-zero error term.





#### SOFTWARE

- C Cross Compilers
- Macro Assemblers
- Simulator Debuggers
- Integrated Development Environments (IDEs)
- Real Time Operating System (RTOS)

#### HARDWARE

- In-Circuit Emulators
- Eprom Programmers

#### CHIP SUPPORT

- 8051/251/930
- 80C51XA
- 68XXX / 68HC16
- Z80/Z180/64180
- 68HC05
- 68HC11 / 68HC12
- 8096 / 80196
- PIC 16 / 17CXX
- 6800 / 6801 / 6803
- 6500 / 6502

and Much Much More



Rockport, Maine 04856 USA sales@avocetsystems.com http://www.avocetsystems.com

(800) 448-8500
(207) 236-9055

The search for a good motion vector (i.e., one giving a small error term and good compression) is the heart of any MPEG video encoder. It's also the primary reason why encoders are slow.

A B-frame can be encoded relative to the past reference frame, the future reference frame, or both. The future reference frame is the closest following reference frame (I or P).

Encoding for B-frames is similar to P-frames, except motion vectors may refer to areas in the future reference frames. For macroblocks using both past and future reference frames, the two 16 x 16 areas are averaged.

Frames don't have to follow a static IPB pattern. Each individual frame can be of any type. For simplicity, however, a fixed IPB sequence is often used throughout the entire videostream.

Frames can also be sequenced in an IBBP BBP order. In this case, the B frames may depend on information in future P-frames, which is why they're referred to as future frames.

The codec may have two frames in memory-I and P-and may be sending B-frames that appear to the receiver to be referencing future frames. In other words, the sender may have sent frames in the order IBBP BBP BBP, but the receiver must process them in the order IPBB PBB PBB.

Obviously, B-frames aren't much good until the future frame arrives, but the transmission channel is used as soon as the information is available. Dead channel time gets wasted.

Since the encoding is figured out, let's try decoding. This article's source code includes MPEG and audiostream decoders, located in Vi deoConf. zi p. The MPEG code is taken from <br/>bmrc. berkeley.edu/projects/mpeg/mpeg\_play. html>.

Listing 2—Sound in ADPCM encoding (taken from a ud  $i_0 \setminus a$  dcpm. c) is represented as specific offset values from a base or step value. Those values are taken from the *i* n dex Tab 1 e array shown in step 5. The previous steps determine whether a new step is required.

for (; len > 0 ; len--){ val = \*i np++:diff = val - valpred; /\* Step 1-Compare with previous value \*/ sign = (diff < 0)? 8 : 0;if (sign) diff = (-diff); delta = 0;/\* Step Z-Divide : \*approx\* computes: \*/ vpdiff = (step >> 3);/\* delta = diff\*4/step; \*/ if (diff >= step) { /\* and vpdiff = (delta+0.5)\*step/4; \*/ delta = 4: diff -= step; vpdiff += step; } step  $\rightarrow = 1;$ /\* shift >> step by 1 \*/ if (diff >= step) { delta |= 2: diff -= step; vpdiff += step; } step  $\rangle\rangle=1;$ /\* shift >> step by 1 \*/ if (diff >= step) { delta |= 1; vpdiff += step; } i f (sign) /\* Step 3-Update previous value \*/ valpred -= vpdiff; el se valpred += vpdiff; if (valpred > 32767) /\* Step 4-Clamp prev value to 16 bits \*/ val pred = 32767;else if (valpred < -32768) val pred = -32768;/\* Step 5-Update index and step values \*/ delta = sign;index += indexTable[delta]; if (index < 0) index = 0; if (index > 88) index = 88;step = stepsizeTable[index]; if (bufferstep) /\* Step 6-Output value \*/ outputbuffer = (delta << 4) & 0xf0;el se \*outp++ = (delta & 0x0f)| outputbuffer; bufferstep = !bufferstep;}



Figure 1—The Discrete Cosine Transform used by JPEG converts pixel information into coefficients in cosine functions. These values are usually distributed in a zigzag pattern. The encoder takes advantageof this by ordering the coefficients in this pattern to eliminate all unnecessary zeros.

The code is thorough, fairly well documented, and very useful in analyzing MPEG streams. It's written for Unix and X/Windows and has not been ported to Windows, but it should run under Linux. (I didn't write this code, so please don't call me with problems.)

The MPEG macroblock decoder, where everything starts, is handled by the ParseMacroBlock functionin **mpeg\vi deo.** C. It decodes macroblocks and reconstructs motion vectors, which in turn leads to reconstructing DCT values and setting pixel values.

The code that decodes the DCT values from the input stream is more interesting. It is handled by decode - **DCTCoeffinmpeg\decoders.c.** Listing 1 shows a portion of this code.

As you can see, an MPEG image has lots of control information and manipulation of bits. Bandwidth shouldn't be wasted, even at the expense of computer time.

#### AUDIO COMPRESSION

The human ear is much more sensitive than the human eye. Hearing can typically perceive frequencies between 20 Hz and 20 kHz, with the human voice capable of producing frequencies between 40 Hz and 4 kHz. For desktop video-conferencing systems, the challenge is reproducing the highest fidelity of sound in real time. To faithfully reproduce a signal, it must be sampled at twice the highest frequency. The high-quality audio of audio CDs is sampled at nearly 44 kHz, while the telephone samples voice at 8 kHz. Encoding the entire 8-kHz range requires at least 12 bits of data.

To achieve compression, 256 values are selected that can be encoded in 8 bits. Since human voice is concentrated at the lower frequencies, the algorithm uses a logarithmic scale to determine which frequencies to code.

Each value in the raw analog input is mapped to the closest lower frequency in a technique called Pulse Code Modulation (PCM). **G. 711** uses this technique to encode audio and achieves a 1.5: 1 compression ratio (12:8 bits).

Two different logarithmic curves are used as standards-u-law and a-law. u-law is used in North America and Japan, while a-law is used elsewhere.

Neither one really has a technical advantage over the other. They reproduce audio slightly differently, and any preferences between them tend to be based primarily on personal taste.

A sampling rate of 8 kHz encoded as 8-bit data using a single mono channel requires a bandwidth of 64 kbps-much higher than a 28.8-kbps modem can sustain. Some compression is necessary.

Experience shows that adjacent values in an audiostream can be similar to each other. Moreover, a sample's value can be predicted with some accuracy using the value of adjacent samples.

ADPCM (Adaptive Differential Pulse Code Modulation) encodes the differences between the predicted and actual values of a sample. In G.721, these differences are encoded as 4-bit values, requiring only 32 kbps. G.723 uses the same technique to provide 24- and

|        |   |   |   |     |     |    | - |   | -  |     |   |     |     |     |     |     |      |
|--------|---|---|---|-----|-----|----|---|---|----|-----|---|-----|-----|-----|-----|-----|------|
| a)     |   | 0 | 1 | 123 | 345 | 56 |   | 7 | b) | 0   | 1 | 2   | 3   | 4   | 5   | 6   | 7    |
| 0      | 0 | 0 | 0 | 0   | 1   | 0  | 0 | 0 | 0  | 4   |   | 0 - | 2 ( | 0   |     | 0(  | ) () |
| 1      | Ō | Ō | 0 | 1   | 1   | 1  | 0 | 0 | ľ  | 0.  |   |     |     |     |     |     |      |
| 2<br>3 | 0 | 0 | 1 | 1   | 1   | 1  | 1 | 0 | 2  | - 2 |   | 0   |     | 0 ( | ) 1 | 0.0 | 0 (  |
| 3      | 0 |   |   |     |     |    |   |   | 3  | 0   | 1 | 0 ( | 0 ( | ) - | 1   | 0   | 0    |
| 4      | 1 | 1 | 1 | 1   | 1   | 1  | 1 | 0 | 4  | 0   | 0 | 1   | 0   | 0   | 0   | 0   | 0    |
| 5      | 0 | 1 | 1 | 1   | 1   | 1  | 0 | 0 | 5  | 0 ( | 0 | 0 - | - 1 | 0   | 0   | 0   | 1    |

Table 1 -A simple pixel image (a) will convert to the coefficients shown in (b). All coefficients are stored in one of several fables located at the start of a JPEG file. All references to values in frames are represented as offsets in these fables.

6

0 0 0 0 0 0 0 0

0 0 0 0 0 1 0 1

0

40-kbps audiostreams. These all use 3 and 5 bits for encoding audiostreams.

G.722, developed by AT&T in the U.S. and CNET in France, is another standard using ADPCM. It samples data at a higher 16-kHz rate and then divides this data into two channels-one for higher and one for lower frequencies.

It uses 8 bits to encode differences. The output is Huffmanized (run-length encoded) and can be transmitted on one or two channels simultaneously, providing a 4: 1 compression ratio.

Audio compression is a little more readable, so let's take a look. This example is similar to that used in G.721 and is also easier. Listing 2 is part of audio\adcpm cfromVideoConf. zip.

ADPCM is encoded by taking the difference between the current and previous values. The difference value may be too large to encode in 4 bits, so a step value is adopted, which forms the basis for future values.

When a call is placed, it's unlikely that both systems will have the same capabilities. Given the likelihood of mismatched systems, using the H.245 standard is probably best. It recognizes and negotiates the best-quality audio and video possible.

When two systems connect under H.245, they select a random wait time. One system wins and drives the process of finding the best quality of service based on an exchange of capabilities.

That process starts by transmitting a set of options supported, ordered with the preferred services. The receiver responds with the services it can accept. Obviously, no conferencing results if the systems cannot agree on common formats.

#### SEE YOU SOON?

Now that video conferencing is for real on TCP/IP and Internet connections are reaching the 1 -Mb range with ADSL, there'll be lots of growth with this type of service.

See you soon. 🗖

Mike Podanoffsky is an independent software engineer who has worked at PictureTel, Lotus, and Sybase. He authored RxDOS, a DOS clone, and is

6 0

0

0 1 1 1 0 0

0 0 1 0 0 0 0

now working on a Java Virtual Machine for embedded systems (www. internetobjects.com/java.html). You may reach Mike at mikep@world.std. corn.

#### SOFTWARE

Source code for this article can be found on the Circuit Cellar Web site and at <wwwdsp.ucd.ie/speech/ speech\_code.html>.

#### REFERENCES

bmrc.berkeley.edu/projects/mpeg www.landfield.com/faqs/compression-faq/ www.tbi.net/-jhall/voice/digitize.htm wwwdsp.ucd.ie/speech\_speech\_

code.html icsl.ee.washington.edu/~zjin/thesis

#### SOURCES

LiveLan 3.0 PictureTel Corp. 100 Minuteman Rd. Andover, MA 01810 (508) 292-3500 Fax: (508) 292-3327 info@pictel.com www.picturetel.com

Enhanced CU-See-Me White Pine Software 542 Amherst St. Nashua, NH 03063 (603) 886-9050 Fax: (603) 886-9051 info@wpine.com www.cu-seeme.com

#### ProShare

Intel Corp. 5000 West Chandler Blvd. Chandler, AZ 85226-3699 (602) 554-8080 Fax: (602) 554-7436 www.intel.com

NetMeeting 2.0 Microsoft Corp. One Microsoft Way Redmond, WA 98052 (206) 882-8080 Fax: (206) 936-7329

#### IRS

**404** Very Useful 405 Moderately Useful 406 Not Useful

It's a very simple formula. Buy a PromICE from Grammar Engine and you'll save money 3 ways. First, PromICE is amazingly affordable, start-We figured out a way ing at just \$495. to save you money Then, you can while you're re-use PromICE ЩJ. on project after developing! project because it works with any micro, allowing you to avoid highcost custom tools. Finally, there is the investment you've made in a tool that is easily upgradeable as  $J_{m-1}($ your needs change. Call us today and try PromICE FREE for 30 days. It may just be the best investment dz you can make in firmware development tools. **1-800-PROMICE**  $J_0^{2}(z)z \, a$ 



## Grammar Engine Inc.

6

921 Eastwind Dr., Suite 122 •Westerville, OH 43081 Phone 614/899-7878 • Fax 614/899-7888 • Sales 800/776-6423 email:info@gei.com • Web: http://www.gei.com

#111

## The Laser Billboard

## FEATURE ARTICLE

#### **David Prutchi**

#### A Low-Cost Laser Image Projection System

In Texas, there aren't many distractions for drivers, so billboards are priced skyhigh. David finds an alternative by developing his billboard using lasers. He gives some laser basics before walking us through the steps of how to build our own. outheast Texas roads are long and desolate. Driving for a few hours is so boring, we often find ourselves naming the cows. "Hey, honey!" I'm often reminded,

"Better not get too attached. Betsy there might end up as dinner some night." Considering that only the infrequent

considering that only the infrequent sight of a bobbing oil pump tops cownaming as a distraction, it's no surprise that roadside billboards in this area are so effective. Yet, when my wife recently tried leasing one to advertise a new hotel, they were next to impossible to find and ridiculously expensive.

It was time to bring high tech to the rescue. Let's see, where did I put my laser? We'll also need a large barn wall facing the road...

#### LASER PROJECTOR

Unlike the electron-beam raster scanning method that reproduces TV images on the face of a CRT, lasergraphics projectors usually employ vector scanning. The laser beam is steered along the contour to be drawn to form a cartoon-like picture.

Vector scanning happens at the heart of a laser projector through the scanner assembly. Inside, two electromechanical galvanometers ("galvos") move small mirrors that steer the laser beam under computer control. A galvo resembles a small DC motor with a restricted range of rotation (see Figure 1). A current flowing through the drive coil induces a magnetic field that interacts with the constant magnetic field of the pole-piece coil.

Torque created by the magnetic interaction causes the rotation of a small mirror affixed to the shaft of the galvo's moving armature. An impinging laser beam is then deflected along a line perpendicular to the mirror's axis of rotation. The laser dot's position on the image line depends on the current flowing through the drive coil.

Two galvos mounted orthogonally with respect to each other can position the laser dot anywhere on a 2D image plane. Scanning this dot at high speed forms the cartoon-like image.

In a CRT, a complete image is fully available for a brief instant because phosphor on the screen keeps glowing after the electron beam crosses over it.

But, laser-graphics image formation can't rely on the persistence of the projection screen. It relies solely on the limited temporal response of the human visual system. So, the projected image's quality depends highly on the speed with which the beam can be steered and retraced.

Unfortunately, the electromechanical deflection mechanism in a laser projector has a high inertia compared to the electromagnetic or electrostatic deflection used in CRTs. Inertia and other dynamic parameters make it increasingly difficult to accurately position a laser beam on the image plane as high-frequency components are introduced in the control signals.



Figure 1 -A galvo resembles a small DC motor with a very restricted range of rotation. The mirror affixed to the armature moves via magnetic repulsion or attraction between the drive coil and pole piece.

Under these conditions, a laser projector's bandwidth is typically limited by the first uncontrolled mechanical resonance of the galvos. As a rule of thumb, laserdot positioning as a function of drive current is repeatable only if the drive signal is bandwidth limited to below one-fifth of the first resonant frequency.

Despite efficient design and Use lightweight mirrors, a professional system's first resonance usually appears at 1-5 kHz. It's difficult to retrace a complex image slow enough not to generate drive components beyond a few hundred Hertz, yet fast enough for retinal image formation with minimal flicker.

High-end projectors employ closedloop control to extend the system's useful bandwidth. Galvos with integral position sensors are used within a servo control loop.

Performance doesn't come cheap. Professional-grade galvos run at about \$500-800 per axis. (Recall that two are required for 2D scanning.)

An affordable alternative that will get your feet wet in laser graphics is a \$75 two-axis open-loop scanner sold by Meredith Instruments (see Photo 1).

With a first resonance at -200 Hz, its performance cannot be remotely compared to its more expensive-counterparts'. Still, it can be used as the basis for a laser-graphics system capable of projecting simple vector graphics and geometrical pattern animations.



Figure 2-A crude galvo can be built from a speaker and a small mirror. Use RTV silicon adhesive to attach the PCB material lever to the speaker casing and to hold a wooden dowel between the paper cone and lever.

There's one more alternative to computer-controlled laser graphics on a shoestring. As Figure 2 shows, you can build a crude galvo from a small speaker (e.g., 1 W) and lightweight mirror.

Construct the lever from a piece of PCB or prototyping board. Carefully glue a small wooden dowel to the center of the speaker's paper cone. Use RTV silicon adhesive to form the fulcrum and link the dowel tip to the lever.

For the two orthogonal galvos needed for 2D projection, you may find all the parts in your junkbox. But, due to this arrangement's extremely poor frequency response, don't expect to reproduce more than the crudest graphics and geometrical patterns.

#### **GALVO AMPLIFIERS**

The pole magnetic field in a galvo is usually established by energizing a coil with a DC current. The drive coil, on the other hand, is powered by a DCcoupled amplifier.

Driving a small open-loop servo is simple with widely available power

op-amps. The pair of LM759s in Figure 3 provide up to 325 mA of drive current to each galvo.

The amplifiers are operated at unity gain from symmetrical  $\pm 12$ -V power supplies. A separate +12-V line powers the polepiece coil.

It's difficult to damage the LM759s, given their internal current limiting and thermal shutdown. However, they do run

hot, so ample heat sinking is necessary.

Although galvo-amplifier design may look relatively straightforward using any suitable commercial power opamp, a more complex design is needed once you decide to upgrade to professional-grade galvos. Driving the higher power units can be particularly challenging since they present a reactive load as well as reverse electromotive force (EMF) to the driving amplifier's output stage.

This EMF is generated when the drive signal works against the galvo's inductance and inertia, and it must be considered in the driver's design. In general, DC coupling into inductive loads is problematic because the current waveform lags the applied drive voltage, resulting in higher instantaneous and average power dissipation.

Interestingly, however, the same reverse EMF can be fed back to the driving amplifier to dampen unwanted oscillations and extend the usable galvo bandwidth. The coil drive voltage  $V_{drive}$  for a certain galvo may be expressed by:

#### Laser Safety

Even low-powered laser beams may cause irreversible damage if aimed directly at the human eye. Higher powered beams can start fires, burn flesh, ignite combustible materials, and cause permanent eye damage from even scattered reflections.

Therefore, a laser beam or its reflections should never be aimed at yourself or anyone else. Lasers and laser projectors should be used only by adults or with adult supervision. Although used for entertainment, a laser projector is not a toy. It must be used safely and responsibly.

Laser projectors and laser light shows are regulated by the federal government in addition to many state and local authorities. The Center for Devices and Radiological Health (CDRH) handles certification.

Laser projects often involve power supplies capable of producing severe electrical shock. Proper safety precautions

must be taken by the designer and builder to ensure proper handling, construction, and labeling of these supplies.

This laser-projector project is presented exclusively for informational purposes. The author does not make representations as to the completeness or accuracy of the information contained herein and disclaims any liability for damages or injury, whether caused by or arising from lack of completeness, inaccuracy of information, misinterpretation of directions, misapplication of circuits and information, or otherwise.

CDRH-Food and Drug Administration U.S. Dept. of Health and Human Services 1390 Piccard Dr., HFZ-312 Rockville, MD 20850 (301) 427-l 172

$$V_{\rm drive} = T \frac{d\theta}{dt} + L_{\rm coil} \frac{di}{dt} + iR_{\rm coil} \qquad [1]$$

where T is the torque constant, a galvo parameter (expressed in Nm/A) that describes how much torque is produced on the rotor assembly by each ampere of current *i* flowing through the drive coil.

The absolute angular position of the rotor assembly at any time *t* is expressed by  $\theta$ .  $L_{coil}$  and  $R_{coil}$  are the inductance and resistance of the drive coil, respectively.

Considering that the torque should ultimately equal the inertial resistance of the rotor and mirror, oscillations may be dampened by tailoring the system's transfer function as shown in Figure 4. Here, I included the measurable terms of equation 1 within the output amplifier's feedback path.

The instantaneous current through the drive coil i is converted to a corresponding voltage signal by the current sense resistor:

$$R_{sense} = 1\Omega$$

The resistors and capacitors on the input and feedback paths of A3 differentiate this signal and simulate the effect of such current variation on an RC equivalent of the coil's inductance.

To do so, the equivalent resistance  $R_{eq}$  and the equivalent capacitor  $C_{eq}$  are chosen such that:

$$L_{coil} = R_{eq}C_{eq}$$
 [2]

A3's output approximates the term  $L^{di/dt}$  of equation 1. At the same time, the instantaneous voltage across the coil is sampled by op-amp A2, providing a measurement of  $V_{drive}$ .

Extending this control concept, closed-loop galvos have an integral position sensor to provide position feedback signals to a servo amplifier. It's easy to understand, then, that servo amplifiers for closed-loop scanning take full advantage of equation 1 by providing an actual measurement of the angular position  $\theta$  to a suitable transfer function relating position to the drive current [1].

Due to their low inertia, capacitive sensors have been the most popular position detectors in closed-loop galvos. The servo controller is typically implemented by an analog circuit that places



Figure 3—Low-cost power op-amps can drive the galvos of the two-axis scanner. Currents flowing through the drive coils induce magnetic fields that interact with the constant magnetic field generated by the pole-piece coil in each galvo. The laser beam is deflected in each axis proportionately to the drive voltage applied to the respective power op-amp.

the position sensor within the amplifier's feedback path.

In general, the servo system is designed with a bandwidth broad enough to reject dynamic disturbances to the galvo's position, such that the scanner's output closely reproduces the control input signal.

As well, notch filters at the galvo's resonances are often used on the control signal input path. This technique makes it possible to extend the servo's control bandwidth by skipping over problematic phase crossover frequencies.

A discussion on the theoretical background required for designing closed-loop control circuits is beyond the scope of this article, but you should have no problem finding good references with varying degrees of sophistication [2].

#### PROJECTOR CONTROL

Driving the galvo amplifiers of the low-cost laser projector requires playing the image's vector coordinates through two DACs into the amplifier inputs. The circuit of Figure 5 enables the PC to drive two Analog Devices AD667 (or Maxim MAX667) 12-bit DACs from the parallel printer port.

The DACs receive data from three 8-bit latches. The printer port presents the required 24 bits of data as three sequential 8-bit words which are demultiplexed by the three 74LS374 latches.

U4 holds the four least significant bits of each DAC. U3 holds the 8 most significant bits of the x-channel DAC, while U5 holds those of the y-channel DAC.

If desired, S-bit operation can be selected through J2. Once the 24-bit



Figure 4—Oscillations may be dampened by tailoring the galvo system's transfer function. The measurable terms of transfer function can be included within the feedback path of the output amplifier. The components on the input and feedback paths of A3 differentiate the current through the coil to simulate current variation on the coil's inductance. A3's output approximatesL<sup>th</sup><sub>a</sub>, and the instantaneous voltage across the coil is sampled by A2. These signals combine to dampen the galvo at critical operafing points.



Photo 7-A simple computer-controlled lasergraphics projector can be built around an inexpensive two-axis open-loop scanner. The fop circuit board comprises the power op-amps that drive the scanner's galvos, as well as the power-supply components. The lower circuit board has two 12-bit DACs and an inferface connecting to the PC printer port

information defining a coordinate pair i s the DAC outputs are simultaneously updated by strobing pin 16 of the printer port.

Power is obtained from the circuit shown in Figure 6. Current from a 1-A 12-VAC transformer is rectified and regulated to ±12 V for the DACs and galvo amplifiers. A separate +12-V regulator powers the pole-piece coils of the galvos. In addition, +5 V is generated to supply the 74LS374 latches.

#### USING VECTOR GRAPHICS

LASER. BAS, a Quick BASIC program, is used to draw vector graphics that can then be displayed by the laser projector. The vector-graphics drawing tablet is controlled through the cursor-movement keys (i.e., keyboard arrows or numeric keypad).

The spacebar is used to toggle on and off the line to be traced by the laser. Coordinates of points that appear red onscreen are stored in a vector-image file, while green points are disregarded.

To draw a figure, take the cursor to the desired initial point using a green line [tracing off) and toggle on the saving of coordinates (red tracing). Draw the image point by point, turning the tracing off as necessary.

Keep in mind, however, that this laser projector has no retrace blanking. As such, a line is generated between successively traced segments.

You'll soon notice it's not easy to draw just by attempting to trace over an imaginary cartoon of the desired figure.

It's much easier to first draw the figure a vailable at U3-U5p ut ponut transparent film (e.g., the transparencies used for overhead projection), overlay it on the computer screen, and trace the figure with the cursor keys.

> By keeping the flow of the figure as smooth as possible, with generous curves and few discontinuities, you will band limit the drive signals and hopefully not excite undesirable resonances. If you plan to project letters or words, use smooth cursive writing and add an artistic return path for the retrace beam connecting the first and last points.

Projection is accomplished by writing the stored coordinates in an endless loop. Since the writing speed to the DACs is highly dependent on system factors (e.g., CPU clock speed, OS shell, and Quick BASIC compiler version), you'll need to tweak the program's operation to achieve proper results.

The program includes code to skip over unnecessary coordinate points, as well as introduce delay loops between successive write operations to the DACs. In general, keep the writing speed sufficiently low to obtain good beam steering, yet high enough to generate a flicker-free image.

This software is intended only as an example of implementing an open-loop vector-graphics control program. Major enhancements could be made to it.

First of all, an FFT-based spectralanalysis routine (see "Spectral Analysis: FFTs and Beyond," INK 52) could help analyze the beam's path and look for frequency components which could

CONNECTS TO RS-232 AR-16 RELAY INTERFACE (16 channel) \$ 89.95 Two 8 channel (TTL level) outputs are provided for connection to relay cards or other devices (expandable to 128 relays using EX-16 expansion cards). A variety of the second relays cards and relays are stocked. Call for more into RR-2 RELAY INTERFACE (2 relays, 10 amp)....\$44.95 RD-8 REED RELAY CARD (8 relays, 10 VA)......\$49.95 RH-8 RELAY CARD (10 amp SPDT, 277 VAC)...\$66.66 ANALOG TO IGITA

PROVIDES SOFTWARE

8, 10 & 12 BIT RESOLUTION CONNECTS TO RS-232 DC-16 A/D CONVERTER\* (16 channel/8 bit) ADC-8G A/D CONVERTER' (8 channel/10 bit).\$124.90

Input voltage, amperage. pressure. energy usage, light, joysticks and a wide variety of other types of analog signals. RS-422/RS-485 available (lengths to 4,000'). Call for info on other A/D configurations and 12 bit converters (terminal block and cable sold separately). Includes Data Acquisition software for Windows 95 or 3.1 ADC-8E TEMPERATURE INTERFACE" (6 ch)..\$ 139.95 s term. block & 8 temp. sensors (-40' to 148' DIGITAL INTERFACE\* (6 channel) ...... STA-8 DI ..\$ 79.95 ..... \$ 39.95 \*EXPANDABLE...expand your interface to control and monitor up to 512 relays, up to 576 digital inputs. up to T28 analog inputs or up to 128 temperature inputs using the PS-4, EX-16, ST-32 8 AD-16 expansion cards.

FULL TS-4, EA-16, S1-32 8 AD-16 expansion Cards.
 FULL TECHNICAL SUPPORT...provided over the telephone by our staff. Technical reference 8 disk including test software & programming examples QuickBasic, GW Basic, Vilua Bc, VisueC++, Turbo C. Assembly and others are provided.

 HIGH RELIABILITY...engineered for continuous 24 hour industrial applications with 10 years of proven performance in the energy management field. CONNECTS TO RS.232, RS-422 or RS-485...use with IBM and compatibles, Mac and most computers. All standard baud rates and protocols (50 to 19,200 baud) PREE INFORMATION PACKET...use our 800 numbe Fax or E-mail to order, or visit our internet on-line catala URL: http://www.seci.com Technical Support (614) 464-4470 24 HOUR ORDER LINE (800) 842-7714 Visa-Mastercard-American Express-COD Internet E-mail: aeci1@ibm n International & Domestic FAX: (614) 464-Use for information, technical support & o ELECTRONIC ENERGY CONTROL, INC

380 South Fifth Street, Suite 6 Columbus, Ohio 43215-5491

trigger unwanted resonances in the galvos.

A suitable algorithm could then smooth over the hard transitions to limit their spectral content to a level the galvos can handle. Or, the signal can be notch filtered to skip over the resonance frequencies to gain bandwidth.

Other interesting improvements can be implemented through software. For example, if a mechanical resonator is driven with a stair-step function consisting of an intermediate level approximately halfway between the initial and final drive values with a duration equal to half the period of the resonator, overshoot and ringing are suppressed.

As such, the inertial load tends to arrive to the final rest position at zero velocity with a total time of one-half the resonance period for the move.

You may also add a more powerful graphics editor that enables freehand drawing using a mouse or light pen, fancy graphic and animation routines, and a nice Windows-based GUI. If you write such software, please share it with the rest of us.

#### ANIMATED GEOMETRIC PATTERNS

It's not always necessary to manually enter a figure for display. Interesting graphics can be synthesized using mathematical functions. Rotating "spirograph" patterns are easy to generate and display using the laser projector.

These patterns are created by driving the x- and y-axes with continuous sinusoidal signals of different frequency, amplitude, and phase. Since the frequency content of these signals is limited and no discontinuities exist in the signal or its derivatives, even rudimentary galvos like those in Figure 2 can project these patterns with good performance.

In LASER. BAS, Lissajous patterns are generated by driving the x-axis galvo with a sinusoidal frequency  $\omega_1$  while driving the y-axis with an quadrature sinusoidal of frequency  $\omega_2$ .

The ratio between  $\omega_1$  and  $\omega_2$  determines the number of peaks in the Lissajous pattern. Introduce rotation by slightly increasing the phase difference between the signals each time a complete pattern is traced.

Polar roses are generated by not only feeding the x- and y-axis with quadrature signals, but by also varying the amplitude of the sinusoidal components with another sinusoidal function. The number of loops in the polar rose is given by the frequency of this third sinusoidal component. Complexity can be taken one step further by making the driving function for each galvo contain various sinusoidal components of varying phase and amplitude. One result is to generate collapsing spirals that give the illusion of a rotating black hole.

Go ahead. Dig out your old trigonometry and analytic geometry books and keep on playing!

#### LASERS

Of course, an indispensable part of a laser projector is the laser. And, almost any visible kind can be used for display.

Low-powered (5–10mW)Helium-Neon (HeNe) lasers are suitable for indoor and limited exterior light shows. They're inexpensive-surplus units can be found for as little as \$35.

Typical HeNe lasers produce red light at 633 nm, but green (543 nm), yellow (594 nm), and orange (612 nm) ones are now available, albeit at higher prices than their red counterparts. For a few thousand dollars, high-power (30-50 mW) versions are also available for serious light-show displays.

Another low-cost alternative is to use a visible laser diode. Since it's not usually possible to effectively drive a laser diode at room temperature from a





Figure **6**—The projector is powered by a 12-VAC wall transformer. The circuit uses linear regulators to produce  $\pm 12$  V for the DACs and galvo amplifiers,  $\pm 12$  V to power the galvos' pole-piece coils, and  $\pm 5$  V to supply the 74LS374 latches.

DC source, laser diodes are available with a photodiode used for driving control. The photodiode yields a signal that automatically controls the laser diode's power output as a function of the current delivered by the driver circuit.

Diode lasers can also be found as part of modules that include a diode, driver, beam-collating optics, and case that operates as a heat sink. Battery-operated pencil-like laser modules are widely sold as laser pointers.

In any case, these modules require only a DC power source and typically produce red beams at either 670 or 635 nm. If possible, select the 635-nm wavelength, since at the same power, it's four times brighter to the human eye than the 670-nm wavelength. Because of their reduced power (3-5 mW), however, diode lasers are suitable only for indoor and studio work.

For outdoor graphics, argon or mixedgas argon/krypton (green-blue or redyellow-green-blue) do the best job. Medium-power lasers (30-100 mW) can handle most indoor graphics as well as indoor beam effects.

Events in which beams must be visible under adverse conditions (e.g., outdoor shows in high-brightness areas) usually demand water-cooled lasers with optical power outputs that often reach 5 W!

Regardless of the laser you select, please keep safety in mind at all times

(see sidebar, "Laser Safety"). Never aim a laser beam or its reflections at yourself or anyone else, and always use appropriate safety eyeware[3].

#### THE BIG PICTURE

Recently, a sports commentator on NPR complained that today's basketball games are perceived as necessary disturbances in between the pregame and intermission laser shows.

Despite his exaggeration, laser shows seem to be everywhere these days-from small tradeshow booths to the Olympic Games. Their frequent use is mostly due to the advanced technology that has emerged in the last few years.

Galvo writing speeds in high-end professional projectors are now in the 30,000-points/s range, and acousto-optic modulators can create full-color images from "whitelight" laser sources. In addition to the vector graphics that can now be created, modern laser projectors can display full-color raster graphics.

These images are not VGA-quality, since the achieved resolution is only about 50 pixels x 50 lines. But, through image-processing magic, subtly shaded photos can be scanned and projected in a fraction of the time it takes an artist to draw a vector-graphics cartoon [4].

Well, using the laser to project an ad on the old barn along the highway might not be such a good idea after all. But, I'm sure to make the other dads jealous when my kid's birthday party is preceded by a cool laser-show.

David Prutchi has a Ph.D. in Biomedical Engineering from Tel-Aviv University. He is a staff engineer at Sulzer-Intermedics, and his main  $R \oplus D$  interest is biomedical signal processing in implantable devices. You may reach him at adnav@tgn.net.

#### SOFTWARE

The **LASER. BAS** Quick BASIC source code for this article can be found on the Circuit Cellar Web site along with LOVE.DAT and MOUSE2.DAT, demo graphics for the project, and **SOURCES. TXT**, additional sources for laser equipment.

#### REFERENCES

- P. J. Brosens, "Scanning Speed and Accuracy of Moving Magnet Optical Scanners," *Optical Engineering, 34, 200-207, 1995.*
- [2] F.P. Tedeschi, How to Design, Build, & Use Electronic Control Systems, TAB Books, Blue Ridge Summit, PA, 1981.
- [3] D. Zandowsky, "Laser Safety Eyewear Offers Essential Protection," *Laser Focus World*, 33:3, 127-133, 1997.
- [4] P. Murphy, "Software Stretches Laser Artists' Imagination," *Laser Focus World*, 32:12, 148-150, 1996.

#### SOURCES

AD667

Analog Devices One Technology Way Norwood, MA 02062-9106 (617) 329-4700 Fax: (617) 329-1241

Galvo assembly (LSP3) Meredith Instruments 5420 W. Camelback, Ste. 4 Glendale, AZ 85301 (602) 934-9387 Fax: (602) 934-9482

#### IRS

407 Very Useful 408 Moderately Useful 409 Not Useful





#### PULL-OUT DRAWER UNIT

The Model 6600-K provides a Windows 95-compatible keyboard, touchpad pointing device, and 10.4" active matrix color flat-panel VGA monitor in a single pull-out drawer unit. The unit makes a compact and complete operator-interface solution for any standard PC. Installed in a standard 19" industrial rack, it requires only 3.5" of height.

This drawer unit is ideally suited for industrial conditions because its sealed keypad and **keylock** security prevent unauthorized access on the factory floor. If security isn't a concern, the keyboard/monitor drawer may be unlocked for instant accessibility. If you want to control several PCs within the same rack, the **6600-TC** can be attached via expanders.

The **6600-TC** features a 1 **04-key** keyboard with an AT DIN connector, touchpad, and two buttons. It **is** Microsoft serial mouse compatible, with an active-matrix SVGA **color flat-panel display and a** DA-15 analog connector. Measuring **3.5**"×19"×15", the unit is available for 1 **10-** o r **220-VAC** fpower mequitements at 25 W. It sells , which includes the complete drawer unit, manual, and driver disk.

Industrial Computer Source 6260 Sequence Dr. San Diego, CA 92 **12 1** (619) 677-0877 Fax: (619) 677-0618 www.indcompsrc.com

#510

#### PC/ 104 DC/DC POWER SUPPLY

WinSystems has introduced two DC/DC modules for PC/I 04 expandable systems. The **PCM-DC/DC** modules span a 9–75-VDC input-voltage range. They are PC/I 04 compliant, measure 3.6" x 3.8", and mount anywhere in a PC/104 stack.

Both single-output +5 V at 2 A or triple-output +5 V at 2 A and  $\pm$  12 V at 0.416 A models are available. The power supply requires no minimum current loading on the output(s). It maintains regulation on all output voltages down to zero current, eliminating the need for load resistors.

The PCM-DC/DC family is based on two wide-input, highefficiency DC/DC converters-one supplies the +5-V DC output, and the other, the  $\pm 12$ -V DC output. The PCM-DC/DC-12 nominal input voltage is 12 VDC, but it accepts 9-36 VDC. The PCM-DC/ DC-48 nominal input voltage is 48 VDC, but it accepts 18-75 VDC.

Each power supply has short-circuit protection and an in-line fuse on its inputs. As well, each module has a six-sided metal case for **E/MI/RFI** protection and an I/O isolation of 1500 VDC. Overvoltage protection is provided on each output.

A 4-pin standard connector (disk-drive style) located on the board edge makes it easy to test and power a system with a +12-VDC local power supply. Three LEDs provide a visual status of each power-supply voltage.

List prices for the modules range from \$150 to \$250, depending on configuration. 
 WinSystems,
 I
 n
 c
 .

 715
 Stadium Dr.
 • Arlington, TX 76011
 .

 (817)
 274-7553
 • Fax: (817)
 548-1358

 www.winsystems.com
 #511





edited by Harv Weiner

**CIRCUIT CELLAR INK SEPTEMBER 1997** 



#### QUAD RS-232 MODULE

The PCM-3460 is a high-speed, four-port RS-232 serial interface module in the PC/I 04 form factor. It uses the fully programmable, industry-standard 16C550 UART to provide four independent RS-232 COMcompatible serial interfaces at speeds up to 1 15 kbps. The module also features LED activity indicators, jumper-selectable COM ports and interrupts, full RS-232 interface support, and compatibility with PC software drivers. Power requirements are 180 mA at +5 V and 70 mA max at ±12 V.

The PCM-3460 sells for \$205 in quantity.

Versalogic Corp. 3888 Stewart Rd. Eugene, OR 97402 (541) 485-8575 Fax: (541) 485-5712 www.versalogic.com

#512

#### PENTIUM-BASED MODULE

The **EPM-1** embedded processor module reduces the **complex**ity of Pentium processor-based embedded designs by separating the **processor/chipset** core from This module interfaces to a specially designed I/O baseboard via four connectors for the PCI. ISA, and IDE buses, reducing

the application-specific portion of the design. This setup isolates the I/O circuitry from the highspeed electronics associated with Pentium designs and protects the I/O portion from being affected by future changes in processor architecture.

This compact, integrated 4.2" x 5.3" Pentium processorbased CPU board is available with a choice of 100-MHz STD, 133-MHz VRT, 166-MHz VRE, or 200-MHz Pentium processor with MMX technology. It has all the essential elements of a computer core, including the Intel 430HX PCI set with the PIIXPCI/ ISA accelerator, SODIMM sock interface to the I/O baseboard to a set of well-defined low-speed signals. The fastest of these signals-the PCI bus-runs at 33 MHz and works across **bus**connector interfaces. The board is designed to stand high enough above the I/O board that circuitry can be laid on the board below it, enabling compact baseboard design.

The EPM-1 can be used by OEMs to develop a custom embedded computer, or it is available as part of a wide range of embedded computer architectures. Prices range from \$478 to \$941 in 1 OOO-piece quantities, depending on configuration.

ets accommodating up to 256 MB of DRAM, and **82C42PE** keyboard/mouse controller. The board also contains a processor power supply, L2 cache memory, real-time clock, battery-backed CMOS RAM and clock synthesizer, and flash-based configurable Phoenix BIOS.

#### RadiSys Corp.

5445 NE Dawson Creek Dr. Hillsboro, OR 97124 (503) 615-1100 • Fax: (503) 615-1150 www.radisys.com

#513



## Sfmon Napper



# Writing Device Drivers for Embedded PCs

With less and less time to design a product, it's even more important to streamline **he** design cycle. Simon shows how writing device drivers via a code aenerator tightens **the** schedule, reduces errors, and organizes a **team's** code.

mbedded systems, particularly in communications, are growing rapidly in response to the demand for faster and easier access to data and people. As a result, microcontroller vendors are developing tailored processors with specialized functionality embedded in the periphery.

While these processors enhance system performance and enable designers to develop new features, configuring and using their complex peripheral functionality is a major headache.

Writing and testing device drivers is a challenging interdisciplinary task requiring in-depth hardwareand software knowledge.

The lack of automation means this phase is a center of risk in terms of schedules and costs, as well as an ongoing source of maintenance problems.

In this article, I look at the increasingly important role device drivers play in embedded systems, the growing challenges of writing them, and the options available for dealing with these challenges.

#### **ROLE OF DEVICE DRIVERS**

As Figure 1 illustrates, device drivers are central to embedded system design. With peripherals consuming 50% of the die area and functionality in advanced microcontrollers, configuring and using them efficiently is key to performance and capability of the final system.

Drivers are also central because they touch most aspects of the design. They link the applications code to the microcontroller and enable the hardware to be fully tested.

Device drivers unlock the power of the microcontroller. They are important to performance because they're called repeatedly, and they dictate real-time performance both in terms of response time and use of memory and other resources.

Device drivers compose the layer interfacing the hardware to the software. As well, they can dictate the time required for system integration.

Various groups require different device drivers for a myriad of tasks. The hardwaredevelopment team needs them for system testing. The software team needs a production set of drivers. And, the production engineering group needs a set for product testing.

Writing device drivers by hand is so lengthy and difficult that designers are often unable to fully use the microcontroller's peripheral capabilities. Performance is sacrificed, time is wasted in integration, and different groups have to be satisfied with a less-than-optimum, one-size-fits-all compromise.

Rewriting device drivers is a specter that haunts the program manager and con even result in reluctance to move to new microcontrollers.

The result can be unacceptable development delays and lack of performance in the end system.

But, in a competitive market, it's essential to fully use the performance of the microcontroller and minimize development time and cost (see sidebar, "Methodology, Hardware Independence, and Automation are Key to Efficient Innovation"). Figure *I-Device* drivers touch **hard**ware and software design.

#### WRITING DIFFICULTIES

Driver design and implementation isn't especially difficult in terms of algorithmic complexity, but it is demanding in terms of the sheer volume of data that must be coded. Device drivers are unforgiving-one small error will cause an entire system to fail.

Configuring a set of peripherals often means setting over 1000 bits of data in over 60 registers. If you get one bit wrong, the whole system fails. And, trying to track down that one wrong bit is a debugging nightmare.

Writing device drivers is an interdisciplinary skill requiring extensive hardware and software abilities. You must understand the peripheral's details and be able to configure them to meet the requirements of the end system.

You must also have enough software skill to build the layer so the applications writer can interface to the driver easily and intuitively.

The final challenge is that device drivers are virtually impossible to test in isolation.



They are the key to the puzzle of integrating the hardware and the software to perform system-integration testing.

When you find a problem, it is not clear whether it's the hardware, the drivers, or the software. You have to sort out where there's misinterpretation of how the drivers are used, when there's a bug, and what its source is.

This process must all be done at a point in the design cycle where there's no room for mistakes and no opportunity to recover lost time.

#### COSTS

The costs of writing device drivers can be placed in one of three categories.

Writing, debugging, and documenting a library of device drivers constitute one area of consideration. This process is something that can be outsourced with a definitive cost. But when developed inside, costs are less easy to quantify.

Hidden costs include the time it takes to manage the activity plus the overhead of interfacing with the users and ensuring that the requirements are well understood. For complex microcontrollers, this task takes anywhere from four to twelve months of engineering effort.

Theengineeringcostof integrating hardware and software is where the device drivers enable the system to be integrated. It's also where any misconceptions or bugs become obvious.

Although you're still dealing with device driver creation and debug, two other teams now depend on the results. Any rewriting at this time creates quite a production bottleneck. The cost of rewriting is multiplied by the number of people kept waiting.

Documentation and maintenance are the initial and ongoing costs of ensuring that the system is maintainable and that minor enhancements and updates can be managed. They typically require one to three months of engineering effort.

Obviously, these costs can vary. However, cases of device drivers taking 18 months to develop and integrate are not uncommon, with costs ranging from \$70,000 to \$200,000.

#### Methodology, Hardware Independence, and Automation are Key to Efficient Innovation

Embedded-system designers know too well the pressure to turn out new products more quickly. Unfortunately, today's processes for designing and implementing embedded systems are often slow, costly, and error-prone. Adding bodies to the design team often complicates rather than solves problems.

The time has come to better leverage the time and talents of a limited engineer design pool, so you can focus on innovating new products or reimplementing old ones. This leveraging can be accomplished via:

- development of structured design methodologies
- tools that enable hardware independence
- tools that automate manual and error-prone design steps

Adesign methodology-ordesign flow-provides a roadmap for continual improvement. It lets companies define bottlenecks and provides standard design interfaces. A consistent methodology also gives an essential framework for code reuse and integration of standard components (e.g., TCP/IP stacks) that are more efficient to buy than build. A key element of an embedded design methodology is to achieve hardware independence. Using high-level languages removes the designer from the processor. In embedded-system design, however, coding for the on- and off-chip peripherals is still hardware specific. Every time processors or off-chip peripherals change, substantial low-level code must be rewritten, affecting productivity and often introducing hard-to-find errors. This problem is becoming acute as manufacturers turn out families of processors with specialized peripherals that radically change the price-performance equation.

To meet reduced design cycles, engineers must be relieved of implementation details and get usable code from a high-level specification. Tools that generate tested and documented code from a functional specification (e.g., the Driveway 3DE tools) handle such mundane, error-ridden code in a timely manner.

Of course, there are always tradeoffs. A methodology that enables a team to work cohesively overrides individual design style. Designers can no longer write all the code. But, the loss of control lets the engineer focus on the elements deemed critical to the end product.

#### **DEVICE DRIVERS**

Building a setofdevice drivers and integrating them into the system reauires six steps for each peripheral:

- learn the microcontroller-learn the peripherals and what they can support, the register map, how to configure each peripheral's mode of operation, and how it behaves during operation
- design drivers-define initialization sequences, normal op eration, and error conditions handling
- code drivers-encode the mode of operation and document the calling sequence for the applications writer
- debug-one of the most challenging tasks. A single incorrect bit in a register can cause the entire system to fail. As well, it's difficult to test the code when no hardware is available, making debugging a tedious trial-and-error process.
- integrate-the debugged drivers are integrated into the application software and run on me target hardware. I his step often involves another lengthy debugging process.
- document-sufficient documentation is needed for maintaining and supporting drivers. Documentation covers the function names and algorithms, calling sequences, restrictions, and examples.

A microcontroller may have 20 or more peripherals, and each manufacturer requires its own set of device drivers.

#### CREATING DEVICE DRIVERS

Today, the task of creating device drivers is typically handled in one of three ways. Most common is the "do-it-yourself" approach where the system designer writes the drivers by hand.

Another approach is outsourcing—hiring a consultant to write the drivers. Finally, and most promising, are the latest automation tools beginning to emerge. Let's review each of these approaches briefly.

For the do-it-yourself approach, it's necessary to invest sufficient effort up front to ensure that no surprises crop up later in the design cycle. There are several things to do before the device drivers are written and throughout the coding process.

First of all, invest in training. These microcontrollers can be very complex, and a training session helps ensure that you have the most up-to-date information about the chip.

Define the functions that are required early. All required functions should be fully



Photo I-Define the **UART's** functions **by selecting** the Asynchronous Port, selecting the Transmit and Receive operation, and **clicking** on the functions required by the application.

discussed, and the usage and calling sequences must be documented.

When you code, keep in mind that changes are likely. So, carefully document the code and ensure that it is possible to add or change functions.

As soon as possible, test the code. Invest in a separate board that allows functions to be tested in isolation. This process helps minimize the source of bugs later in the project.

As a final step, document fully what's done, and give the applications software writers a complete set of documentation so they know how to use the driver code.

With outsourcing, on the other hand, it's possible to buy expertise for a particular microcontroller and application, thus reducing the time required for learning the hardware and software (perhaps shaving a couple of months off the process).

However, driver creation, debugging, and integration are still done by hand with

to vide a generic set of device drivers for specific microcontrollers. the Although they provide a head start, templates still require a great deal of work.

templates still require a great deal of work. You must understand the hardware in detail and edit the drivers to meet your system's specific peripherals and functions. Also, there's no tech support if problems arise while you're adapting the template.

To date, the automation tools available for designing device drivers have been limited to free help tools that enable you to explore the microcontroller and learn its features more quickly.

Tools such as MCUInit and ApBuilder also provide some templates as starting

all the inherent problems of the do-it-yourself approach.

And, when the project is complete, it's the contractor—not the in-house engineer who has the knowledge about the drivers. So, it's difficult to change the drivers when a feature changes in the application or a bug is found.

If you're doing to work with an outside vendor, follow these tips.

Check that the contractors are already expert in the processor. (Don't

pay for them to become experts on your design.)

Allow room in. the budget for changes, maintenance, and training. It is not just the drivers you want. You need to know how to use them. And, be sure you build changes into the cost.

From the start, make sure your requirements are as clear and well understood as possible. Although you've budgeted for it, you want to minimize changes.

As well, verify that documentation and training are included in the bid. These drivers will have to be maintained, and documentation is critical unless the outside contractor is going to maintain the drivers indefinitely.

Although automation tools are just beginning to emerge, this approach shows the greatest promise. Some tool options are already available to help you get the job done faster.

Drivercodesamplesand templates available on the Web can be downloaded for

use in development. These templates pro-

Photo 2-Confiaurina the UART's operational parameters is achieved by completing the parameter dialog window.

points for devicedriver design. They help you through the first step but leave the remaining steps to be done by hand.

A new technology-the Device Driver Design Envi-

ronment (3DE)-provides a morecomplete automation solution.

The 3DE encapsulates the microcontroller with a personality database built from tuned, documented device-driver modules that are fully tested on hardware. The database also includes controller-specific help and data to aid the learning process.

The 3DE lets you select the functions needed to control each peripheral and

| Carity<br>None<br>Odd parity<br>Even parity | Stop Bits<br>© One stop bit<br>© Two stop bits | - <u>W</u> ord Longth<br>← 7 bits<br>← 8 bits | Break Val        |
|---------------------------------------------|------------------------------------------------|-----------------------------------------------|------------------|
| PIO Pina Func<br>7 PIO 27 ia TX             |                                                | i L<br>terrupts<br>Generate Receive           | Castria laterary |
| 7 PIO 28 in RX                              |                                                | _                                             | -Low             |
| laud Rate Sell<br>aud Rate: 19              | <u></u>                                        | Main Clock: 4                                 | 0 (Mhz)          |
| ctuat 192                                   | 30.769 (Bps)                                   | Baud Divisor: 0                               | ¢40              |
| nor[2]; 0.1                                 | 603                                            |                                               |                  |
| OK                                          | Cancel                                         | Default                                       | K8 Hel           |

then combine them with specific variables (e.g., buffer size, crystal frequency, memory locations). Then, it tiles the code fragments together and produces a complete library of device drivers.

#### UART EXAMPLE

Let's discuss what's required to configure one of the peripherals for a system using an AMD 186EM microcontroller. In this example, built one of the device drivers to communicate to a monitor (dumb terminal) using a UART. To achieve this, used the asynchronous serial port and configured it as a UART.

I chose the Driveway-86 to configure the peripheral. But, whether configuration is done with an automation tool, by a contractor, or on your own, the same data must be generated.

The 3DE provides a logical and efficient approach for defining what you need to know before you start coding. So, no matter which method you use for writing the driver, it outlines an effective hierarchical design methodology.

I'm just implementing one device driver in this example. However, some important work is still required up front.

The relative priorities of the interrupts need to be assigned, and the buffer sizes and exceptions need to be defined. It's essential to work these out at the start since they can be very time consuming to work out after the event.

The next step is to configure the peripheral's mode of operation and define



Listing la--The initialization function *of the* serial port relies on the definitions file for *the* serial port. b-The definitions *file is automatically generated and documented for the user.* 

```
a)
 void SerialInit(void)
   UINT16 RegData;
   RxBuffLen = 0;
    TxBuffLen = 0;
   SetVect(SERIAL_INTR_NUM , SerialIsr); /* Serial ISR to int. tbl */
 /* Sets serial-port int priority level and unmasks this int. */
/* Note! Priority level is also set at int-controller code. */
   SerialSetIntr( SER_INTR_PRIORITY );
    SerialDisable();
                           /* Disable serial port */
   SetRegister(SPSTS, 0); /* Clear status reg (SPSTS, offset 82h) */
   GetRegister(SPRD, RegData);
                                   /* Read pending rx char to clear
                                            RDR bit at status reg */
   SerialSetBaudDiv(SER_BAUDDIV); /* Set baud-rate divisor */
 /*
 Sets Serial Port Control Register (SPCT, Offset 80h)
 - Set TX, RX and Status mode
 - Loopback (LOOP)
 - Send Break (BRK)
 - Break Value (BRKVAL)
 - Parity Mode (PMODE)
 - Word Length (WLGN)
   Stop Bits (STP)
 */
   SetRegister(SPCT,
      (NO_LOOP + NO_BRK + BRKVAL_LOW +
      PMODE_NONE + LEN_8BITS + ONE-STOP-BIT +
      NO_TXIE + TMDDE + NO_RXIE + RMDDE + NO_RSIE));
 /* Sets Serial Port I/O pins. I/O pins also set at PIO code */
    ResetRegBits( PIOMODE1, PIO27_IO);
ResetRegBits( PDIR1, PIO27_INPUT );
                                            /* Set PI027 as TXD pin */
    ResetRegBits( PIOMODE1, PIO28_IO);
                                            /* Set PI028 as RXD pin */
    ResetRegBits( PDIR1, PI028_INPUT );
b)
  * Definitions */
                             /* Am186EM/Am188EM main c]k rate (MHz) */
 #define MAIN CLK 40
 #define SER_BAUDDIV 0x40 /* Divisor for internal clk generates
                                on phase (half period) of serial clk */
 #define SER_BAUD_RATE 19200L
                                     /* Async serial port baud rate */
 #define SER_INTR_PRIORITY 7
                                     /* Serial port int priority */
 /* Variables */
 extern volatile UINT16 RxBuffLen; /* Serial port Rx buffer length */
 extern UINT8 * RxBuffPtr;
                                     /* Serial port Rx buffer */
 extern volatile UINT16 TxBuffLen; /* Length of TX buffer */
 extern UINT8 * TxBuffPtr:
                                     /* Pointer to TX buffer */
```

the functionsthatcomposethedevicedriver. It'simportanttotradeofftherichnessofthe functionsagainstthesizeofthedrivercode.

Itook the typical function set shown in Photo 1. There, you seehow the serial port will operate as well as the list of functions that the applications software can access.

Now, I need to define how the lower level functions operate the hardware. The panel in Photo 2 lets **you** define the details of the communications and its interface to the hardware.

Havingworkedthrough anddefinedthe peripheral's operation, the required functions, and the operational parameters, it's possibletocodethedrivertospecification. Jumping into the coding process can lead to extra work and extended developmentschedules. Defining the operation so rigorouslyhelpsminimizedevelopmenttime, but it's vital to document code clearly.

Whiletherearemanycodingstandards, ensuring that the code is well enough documented for someone else to pickitup later is a minimum requirement. Bear in mind that documenting the code will be leveraged, since it can be used as part of the documentation package **you** SUPply to the applications writers.

Listing 1 shows a restricted example that doesn't deal with how different peripheral saregiven priority through an interrupt

SEPTEMBER 1997 INBIDDEDPC

scheme. However, it demonstrates the complexity of writing the drivers for one peripheral and the value of a hierarchical design methodology. Using *a* structured approach lets you maximize the value of the documentation and coding and helps pinpoint errors.

However the device drivers are written, automate the process as much as you can. Use templates where possible, and reuse what you can. And, assume that changes will be necessary, so keep the code easy to read and migrate.

#### EFFICIENCY = SUCCESS

Writing device drivers is a hidden key to successful products. They play a central role in determining much of the performance and to what extent you can leverage the capabilities embedded in the microcontroller's silicon.

They are also complex and can dictate the time it takes to deliver the design to production. It seems likely that the complexity of peripherals will continue as new silicon technology enables more and more to be encapsulated on a single microcontroller.

So whether you write drivers yourself or outsource them, it makes sense to apply a rigorous methodology and use as much automation as possible. EPC

Simon Napper is vice president of marketing for Aisys. He has held a number of technical and marketing positions in the U.S. and Europe and, prior to joining Aisys, was vice president of marketing for EPIC Design Technology. You may reach Simon at simonn@aisysinc.com.

SOURCES **3DE,** Driveway-86 Aisys, Inc. 4633 Old Ironsides Dr., Ste. 105 Santa Clara, CA 95054 (408) 327 8820 Fax: (408) 327 8830 mkt@aisysinc.com www.aisysinc.com

186EM Advanced Micro Devices, Inc. P.O. Box 3453 Sunnyvale, CA 94088 (408) 732-2400

#### IRS

410 Very Useful 411 Moderately Useful 412 Not Useful

## PC/104QUARTER

## Chuck Raskin



## Motion Control with PC/104

PC/7 **04** enables precise motion control to reach into the compact capacity of the industrial application's closet. Chuck guides the **reader** in what kinds of choices need to be **made when** PC/104 and motion control come together.

Many motion applications may be addressed by the simple on/off I/O methods thateveryone'sfamilarwith. Precise motion control, on the other hand, requires highspeed control of actuators (e.g., motors and hydraulics] via computers or DSPs.

Typical motion applications range from simple material handling along one axis to robotics involving many axes of coordinated motion, and CNCs. Modern controllers control position with submicron accuracy and velocities to less than 0.0 1% tolerance.

When motion has to be precisely coordinated, computer systems generally provide the control. But, writing motion-control algorithms that adequately handle real-time update requirements within a specific application time frame isn't easy.

Off-the-shelf motion-control products are designed to handle real-time motion require ments and integrate simply into your applications. Both servo and stepper motor controller devices are available as add-in boards for several industrial standard microcomputers-including PC/I 04. The flexibility gained from motioncontrol processors or DSPs gives designers more powerful predefined algorithms for designing board-level control. Hence, the art to control is coordinating the needed motion with machine timing requirements.

Obviously, you don't want to reinvent motion software. But, software written for a single computer environment isn't necessarily the best answer.

A single processor-be it an XT, '486, or even a DSP-is usually tasked to the limit when calculating, processing, and controlling more than four axes of linear servo motion and two axes of circular algorithms in the time required to maintain smooth motion and accomplish collateral tasks.

Truesingle-level multitasking isachieved via single-board multiple-axis motioncontrol cards in systems operating under software control. They enable faster motion update periods (under 256 µs per axis) for any number of axes, solid machine control, and, with the proper I/O board, increased system flexibility and modularity.

#### WHY PC/ 104?

Of all the system types on the market, what does PC/I 04 offer motion control?

In industrial applications, cabinet space is at a premium. PC/104 yields the most operational capability in the smallest available footprint.

Since PC/104 uses open-frame construction, dedicated cooling fans may not be required, especially if they're installed in industrial enclosures already cooled by fans.

With a 32-bit PC/I 04 system, you can install multiple processor cards on a single card-cage bus. One card handles the operator or perhaps both machine and operator safety needs, while another handles system operation. You then get the best real-time solution withoutlosing performanceorsafety.

The open structure of PC/I 04 systems also provides easier access. To replace or add a card in a PC/104 system, just pull apart the bus and service the board. By contrast, a PC board requires the removal of one or more cabinets and at least one fastener per board.



Obviously, in industrial environments, the time needed to service or access a board is part of customer down time. Although 10 minutes doesn't sound like much down time, if you service an operation that runs at 30' per minute with product costing \$40 per foot, the customer loses over \$1200 per minute!

I/O option boards for PC/I 04 offer a wide variety of control capability. Engineers can therefore take a more direct and noncompromising approach to **motion-con**trol design with minimal effort.

#### ENCODER BASICS

Optical encoders fall into two basic categories-absolute and incremental.

Output from an absolute encoder repre sents the absolute position of the encoder rotor to within one shaft rotation. Each bit of resolution requires additional coding on the optical disc.

The primary advantage of an absolute encoder is its ability to give absolute position information at powerup. Its disadvantages are the larger code disc size and higher cost associated with increased resolution.

Incremental encoders fall into several subcategories-pulse (tachometer), pulse and direction, up/down, and quadrature.

When designing in encoder feedback, consider both system and encoder resolution, maximum encoder output frequency (pulses or lines per second), maximum acceleration rate needed for the encoder, and the interface (voltageand current) requirement.

#### SERVO-SYSTEM BASICS

Servo controllers come in several styles including DSP, processor, and ASIC based. Typically, they include a feedbackcounting mechanism, a gain structure that coordinates the actual and desired system positions, and an output interface signal to control the motor. These elements ensure that the system load reaches the command position via the requested move profile.

The system load, inertia, profile, environment, and similar factors govern the choice of any motor/amplifier package. The electrical and physical differences of the motor types listed in Table 1 offer enough performance variety for you to judge which packagesatisfiesyoursystemneedsand budget.

When designing a system with a servo motor, consider the system and encoder resolution, as well as the maximum velocity and acceleration rate. Also, thinkabout the system type (see Figure 1), system inertia and stability, and the motor amplifier power and current requirements.

If your application requires high-speed, short index moves or short duty-cycle moves with high torquecontrol, use a DC brushless servo. It gives a high power-to-size ratio and high acceleration/deceleration capabilities.

A PWM DC brush servo motor works well for long, high-speed moves, low-to-mediumspeed short moves, or index moves with lightto-medium loads. This motor needs brush replacement and provides medium powerto-size ratios, armature inertias, and acceleration/deceleration capabilities.

Stepper motors provide low-to-medium acceleration/deceleration along with high power-to-size ratios. For any application, check how the stepper performson its speed, torque, and curve. A stepper's positional accuracy is generally  $\pm 3\%$  of a full step but can be less for a higher cost.

General-purpose DC motors aren't designed for true servo applications, but they can move light-toheavy loads requiring lowto-medium acceleration/deceleration covos sometimes end up in applications otherwise ideally suited for stepper systems.

toad inflections, acceleration rates, top velocity, high-velocitytorque reduction, zero following error, and other factors all contribute to the success of a stepper application.

#### STEPPER CONTROLLERS

It's critical to understand both the operational and system-reaction differencesamong various types of steppers. For example, a chopper drive always causes stepper motors to vibrate when not commanded to move.

In photo-film handling, a vibrating stepper motor directly coupled to a drive roller can cause the film to vibrate, which is not acceptable for positioning, developing, or splicing. A bilevel current-limited, nonchopper-type drive is a better system fit.

If the translator is current limiting via an external resistor, the power-supply voltage may be increased, improving the **speed**-torque curve. However, consider power supply limitations, external resistor power dissipation, and motor driver constraints.

Two common translators, as defined by current flow, are bipolar and unipolar.



Figure I--There are three basic motor motion styles, each with their own applications. The **inline** motor [a) is **used** primarily for CNC applications, while the rotary(b) and tangential (c) systems are used for robotics and conveyor/material handling, respectively.

pabilities. They're well-suited for velocity mode and low-accuracy positioning.

AC motors-brushless servo, vector, or any other variety-provide low-to-medium acceleration/deceleration capabilities, moderate servo positioning using bruteforce on/off control, and medium-to-high armature inertias.

#### STEPPER BASICS

While servo systems seem to be favored over stepper systems, the latter has recently gained attention through breakthroughs like microstepping and five-phase control.

But since stepper motion operating in open-loop mode is more complex to control and requires more preliminary analysis, serBoth are available in resistance-limited, bilevel, VSI, and two- and fourquadrant chopper models.

The microstep translator is so-named because the stepper motor's current-generated magnetic field enables the armature to be positioned anywhere between its actual detent positions. The most popular microstep ranges available (at reasonable cost) are 2, 4, 8, 16, 32, 64, and 128 steps per full step.

#### STEPPER MOTORS

When designing a steppersystem, think about the required maximum resolution, accuracy, repeatability, and step resolution. Also, consider the maximum needed velocity, acceleration rates, system type, inertia, and the stability of the product to be handled.

Once you address these issues, you greatly improve your chances for project success. Table 2 lists several different stepper types and their characteristics.

Be cautious of servo controllers where voltage-to-frequency converters run the step per. The nonlinearity of these converters generally compromises that stability.

Some types of stepper motors include the moderately priced variable reluctance motor (i.e., a nonlinear device with nonsinusoidal characteristics) and the nonlinear PM (e.g., canstack or claw type).

The variable reluctance motor has no magnets, operates at virtually any angle, and has a good torque-to-inertia ratio, but it's noisy.

The PM is the lowest priced stepper motor and is suited only for low-to-medium power operation. Its bearings can affect motion stability, and its step angles are coarse. But if it can do the job, the PM is often the most effective choice.

The two- or five-phase hybrid is a moderately priced, nonlinear device with good availability. Detent torque depends on tooth design, and it has good torque/watt accuracy. The hybrid is a moderate power workhorse for limited duty.

The axial air gap disc rotor and enhanced hybrid cost more than other steppers. The axial air gap disc rotor is linear, gives the best torque-to-weight ratio of the group, is efficient and snappy, but has limited power. The enhanced hybrid yields the highest power output for a given driver power rating.

#### **MOTION-SYSTEM TOPOLOGIES**

Three basic load-driving topologies, or a combination thereof, define all motioncontrol applications. In each system type, if more than one axis of motion is involved because of mechanical design, you must coordinate the calculations of each axis. Small load changes in one axis can have a substantial dynamic effect on the others.

The inline system consists of a load moving in an axial direction to the load driver. For instance, when a lead screw is directly attached to the load and followed by a screw follower, the load is transported in the axial direction of the lead screw (load driver) asthescrew rotates, osshown in Figure 1 a.

The rotary system in Figure 1 b consists of a motor attached directly or through a gear train to a load rotating about the load center. The load needn't be balanced or move in a path around the load-driving device, but it must move in a radial fashion.

A rotating spindle exemplifies a typical rotary system. It either rotates the work (e.g., a lathe) or the tools that contact with the work.

The tangential system consists of a load moving in a direction perpendicular to the axial direction of the load driver (see Figure Ic). In a simple conveyor belt, the motion is perpendicular to the axial direction of the drive roller.

#### S CURVES AND TRAPEZOIDALS

Trapezoidal and S-curve profiles are the two main types considered when developing a motioncontrol requirement.

In the motion-control industry, "profile" describes a complete and controlled motion event. That is, the move accelerating from a base velocity to a slew or run velocity, continuing at the slew velocity to a designated deceleration point, and then decelerating back to the base velocity.

Base velocity doesn't have to start at zero. A profile can begin from any previously established velocity  $V_1$  and be considered complete at any other velocity.

In a trapezoidal profile, theacceleration and deceleration rates of a motion are constant, as you see in Figure 2a. The velocity accelerates linearly until the profile reaches the required slew velocity. During deceleration, velocity decreases linearly until motion reaches its target velocity  $\{V_{i}\}$ .

By contrast, an S-curve profile is a controlled velocity (or ramped acceleration) profile. As Figure 2b shows, the S curve is more complex than a trapezoid since it's based on two linear incrementing or **decre**menting variables over time.

A trapezoidal profile applies only half as much torque loading as the S.profile does at halfway up thevelocity profile in the same time frame. However, the S curve generates a softer move at the profile's leading and trailing ends, thus lowering impulse torque loading (i.e., jerk).

To goin theseadvantages, carefully match the update timing for the S acceleration profile to system dynamics.

Medium-to-high friction systems, noncounterbalanced vertical systems, or other similarly imbalanced systems may defeat S curve's ability to perform. Gain structures can be implemented to overcome this deficiency.

Using only a PID gain structure without any other form of gain assistance, the S curve may not perform any better than the trapezoidal when placed in a high-friction environment (above a 0.15 coefficient). The same holds true when operating in a medium-friction environment (0.075-O. 15) and applying a current motor operation without tachometer feedback.

Interestingly, to achieve the same acceleration time versus distance, the peak acceleration achieved at the S's crossover is twice that of a trapezoid. Wherever the product is not secured to the conveying surface, the G-force exerted on the product may cause it to slip.

| Motor<br>Type | Moves                                                                             | Loads                          | Power:Siz<br>Ratio | e Armature<br>Inettias | Accel/Decel<br>Capability | Notes                                                                                                                |
|---------------|-----------------------------------------------------------------------------------|--------------------------------|--------------------|------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------|
| Brushless     | High-speed short index short duty cycle                                           | Heavy (high<br>torque control) | High               | Low-Medium             | High                      | Resolver to quadrature converter option                                                                              |
| PWM           | Long high-speed;<br>Low-Medium-speed<br>short index;<br>Light-Medium loaded index | Medium                         | Medium             | Low-Medium             | Medium                    | Brush replacement required                                                                                           |
| DC            | Low-Medium speed                                                                  | Light-Heavy                    | Low                | High                   | Low-Medium                | Velocity mode or low accurate positioning;<br>Not designed for true servo application;<br>Brute-force on/off control |
| AC            | Low-High speed                                                                    | Light-Heavy                    | Low                | Medium-High            | Low-Medium                | Brute-force on/off control;<br>Moderate servo positioning capability                                                 |

Table I-Selecting the correct motor is important since not **all** motors suit all applications. Make sure the motor's capabilities fit the job.

#### MONITORING THE ENVIRONMENT

If you can see it, you can control it. So, sensing devices lie at the heart of any system. They must work in the most extreme **environments** vibration, dust, dirt, oil, grease, temperature, and electrical noise-and yet they're often ignored until they fail.

To ensure full sensor compatibility and system integrity, it's crucial to know the application's specifications for voltage, current sink or source operations, propagation delays, hysteresis, as well as any need of solid state or hard contact, before a sensor is selected.

Endurance requirements, environmental temperature, NEMA housing style, noise, solid state versus mechanical, and many other characteristics are critical to sensor selection. Power source requirements (e.g., voltage, current and acceptable leakage current levels, and AC or DC system operation) play a significant role.

Also, think about the properties of the item to be sensed. Is it sensitive to light or heat? Can it be touched?

These factors, along with accuracy and repeatability requirements, are important in choosing the appropriate sensor. But, it's the specific task to be accomplished that defines the initial sensor requirement.

#### TIMING DIAGRAMS

The secret to coordinating multiple axes of motion control with hundreds of possible discrete I/O signals on a multimillion-dollar machine is to design with the aid of system or machine timing diagrams. The timing diagram is to a system what a flowchart is to software. The timing map specifically details theactions of the machine parts and product at any point in the process, both mechanically and electrically.

Once the system is ready for startup, the timing diagram becomes your best debugging tool. Since it serves as a function map of the system, real-time machine operations that require multitasking become immediately evident.

Figure 3 shows a timing diagram for developing the operating requirements of a rotary brush machine (used in floor buffing and scrubbing machines). The graph shows the required machine function operation during a 360" head cycle.

A 360" rotary head motion is converted into linear motion and drills holes in round wooden discs. After each hole is drilled, the disc is indexed (without stopping the drill head), which results in a circular pattern of holes around the disc. At assembly, bristles are inserted into the holes to form the brush.

The actual machine uses five axes of motion-two rotary and three in-line-operating speeds up to 250 holes per minute. An algorithm triangulates the positions of the inline axes for disc tilting and radius placement, while the rotary axes rotate thewooden discs for drilling and bristle insertion.

All this must keep up with a hydraulic head that cycles at 250 rpm or one revolution in 0.24 s. Also, operators can load new brush data from a master/host where new brush patterns are produced, or it may be producing daily work logs and set-up information for building other brushes.

#### COMMUNICATION

"Embedded control communications protocol" can mean designing so that total computer control, part of it, or none at all (nodes only) is onboard the main system.



Figure **2a—The** trapezoidal profile has linear acceleration and deceleration ramps. b-By contrast, the S-curve profile has softened ramps.

While communications plays a significant role in all of these cases, in the first example, communications may be useful only for loading or saving premade programs. But if you have nodes only, communications becomes the heart and soul of the control's capability.

A nodetypicallydefinesa small, compact computer since a node takes instructions from a host at another location. The degree or intensity of the communications, the interface (e.g., Ethernet, RS-232, RS-485, etc.), and the communications protocol must be selected so the system performs as needed.

If, when using node control, the ability to synchronize axes is necessary, then an off-the-shelf protocol that yields high-speed data transfer has a definite advantage.

When using node control, you need to answer the following questions:

- what's the best way to format the data to allow the fastest transfer of information?
- how are very low data-transfer crash situations between multiple modes maintained?

| Stepper Types               | cost     | Linearity                        | Detent Torque              | Angles                               | Notes                                                                                                 |
|-----------------------------|----------|----------------------------------|----------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------|
| Variable reluctance         | Moderate | Very nonlinear,<br>nonsinusoidal | No<br>(no magnets)         | Virtually any                        | Noisy; Spins free; Good torque to inertia                                                             |
| PWM (Canstack<br>or claw)   | Lowest   | Fair                             | Significant                | Coarse step only                     | Bearings can affect motion stability<br>Low-Medium power operation only<br>Best, if it can do the job |
| Two-/Five-Phase<br>Hybrid   | Moderate | Nonlinear,<br>but repeats well   | Depends on<br>tooth design | 0.36-l 5" available<br>1.8" prevails | Limited duty, moderate power workhorse<br>Good torque/watt accuracy                                   |
| Axial Air Gap<br>Disc Rotor | High     | Very linear                      | Depends on design          | 1.8" and 3.6" only                   | Easy to model; Best torque to weight ratio<br>Efficient, snappy, but limited power                    |
| Enhanced Hybrid             | High     | Fairly good                      | Depends on tooth design    | 1.8" only                            | Models like the hybrid type;<br>Highest power out for a given driver VA<br>Highest power per volume   |

Table Z-While the correct stepper motor type is generally determined by the application, it's also a balance of system performance and cost.

 how much information needs to be transferred to maintain good-to-superior axis control?

To answer, you need to understand exactly how fast the communications required by the embedded application should be.

While plotting might look like an intensive operation, the real-time requirement is loose. If the plotter has to wait while more data is transferred, no loss of integrity is noted. The data-transfer rate can range from as low as 300 bps to 9600 bps.

On the other hand, a labeling unit at 1200' per minute typically has a real-time requirement of less than 250  $\mu$ s for I/O handling. Assuming 1 .5" labels are needed, it takes only 0.0085 s to produce each label. Using a xl 0 rule to ensure all label data is appropriately transferred, the maximum allowable data-transfer time is 625  $\mu$ s.

If each label contains ten characters, the minimum transfer rate is 160 kbps, yielding a new character every 62  $\mu$ s. The data rate automatically eliminates the RS-232 protocol and requires a minimum of RS-485 or Ethernet interfacing.

Wake Up, Address, Command Byte, Bytes to Follow, Check Sum A, or one-byte ACK or NAK are returned to the host, verifying safe receipt of the message.

If multiple axes are used, messages can **be** acknowledged by pulling a common I/O line low (NAK) or leaving it high (ACK). The line shift would occur in the same timing frame as the ACK and NAK bytes, but all units might respond at the same moment, increasing the band requirements.

While this transfer mechanism isn't necessarily the most efficient, it gives a high probability that the embedded controller's messagesare being transferred intact, which is exactly what we're looking for.

let's consider how to invoke move from a remote hostwithout using upvaluable time. The five basic types of move are immediate, point-to-point, time, **spline**, and stop.

#### IMMEDIATE MOVE

An immediate move starts an axis moving similar to a jog routine. Velocity and acceleration are downloaded to the node along with the immediate move byte.

The velocity and acceleration information can be modal, which means it stays in effect until changed, so future i mmed i ate move commands comprise only the command and direction bytes.

#### POINT-TO-POINT MOVE

The point-to-point move is used for simple axis motions. It's well-suited for operations like peck drilling, which uses a mechanical drill bit or laser device.

Repeatable step motions enable this operation to be accomplished quickly since the distance to move can be relative motion. In this situation, the move, along with the velocity and acceleration, is modal.

#### TIME MOVE

A time move moves the axis to a specified position in a specified time. The

operator enters the acceleration, but the velocity to achieve the position in time is calculated by the node.

Time movecanalsobemodalin context, enabling simple repeatable **mo**tion using only a command-byte transfer.

#### SPLINE MOVE

For any controller-especially for embedded controllers-s p 1 i n e move is the most flexible form of motion. It enables the host to send down complicated motion profiles with a minimum of required commands.

#### IF YOU'RE **EMBEDDING** A PC, TAKE A LOOK AT THESE



#### SMX/386 OEModule™

No, it's not a very large chip, it's a very small computer. A complete, 40MHz 386SX computer in a 240-pin surface-mount package just 2.20"x 3.00"x.35" that mounts on your board like a chip. Harsh Environment?

Forget unreliable cables and vibration problems. Everything you need is built into the OEModule. It boots from its internal Flash disk and even has 256K of user available program space. There are two COM ports, a parallel port, full core logic, keyboard & speaker ports, IDE and floppy disk support, and 2Mb of internal DRAM with support for up to 64Mb externally. Only 5V at 2W (power management & sleep modes available). Mounted directly on your proprietary board, connections are rock-solid even in harsh conditions.

#### A familiar platform.

The SMX/386 is PC/AT compatible, so all your standard development tools will work perfectly.

BIOS & DOS license included. No licenses to negotiate. Power on the SMX/386 and you have a DOS prompt.

#### ZF3/104 CPUModule™

The creator of the PC/104 concept brings you more features per dollar than any PC/104 CPU on the market. 386SX, up to 18Mb DRAM &16Mb Flash, floppy, IDE, 4 serial, 2 parallel ports!

#### SBX/386 SlotCard™

The SBX/386 development kit comes with everything you need to put your project on the fast track to market: hardware, software, schematic and component libraries. It includes both AT and PC/ 104 expansion busses. **AKT/386 SystemCard**<sup>TM</sup>

Jointly developed by IBM <sup>®</sup> and and ZF for the transportation industry. Only 5.75" x 8", SMX/386, 8 serial ports, 2 parallel ports, 51708 interface, slave processor controls RS485 multidrop network, and a resident interface for GPS.

The Solid Solution in Embedded Control<sup>SM</sup>



ZFMicroSystems, Inc. 1052 Elwell Court Palo Alto, CA 94303 Tel: 1-800-683-5943 Fax: 415-965-4050 www.zfmicro.com



Target projection using cubic polynomials enables the software to produce continuous or discontinuous motion (e.g., sharpcorners). Withspline motion, the cubic spline algorithm can be the sole device producing straight lines, circles, or any other coordinated motion.

The cubic spline algorithm can be given in the form <Point><Point><Time>, so the trajectory can be calculated by a polynomial in the form:

$$x(kt) + x = k_{d}^{T} \frac{d}{t} \tilde{k}_{e0} + k^{2}c_{1} + k^{3}c_{2}$$

where *k* is the sample increment since the start of the move, k = 0 is the time at the beginning of the move, x(kt) is the target velocity at each sample time *t*, and *c*<sub>1</sub> and *c*<sub>2</sub> are calculated terms based on known starting and transmitted ending values.

#### START MOVE

Start move gets one or more axes moving.Don'tuseitforimmediate move, but it can be used for all other moves.

If single-axis moves are required, they may or may not require a start command depending on the variation of the specified move. For example, a 25-hex command byte makes a timed move after a start command is issued, while a 26-hex command begins the timed move at message transfer.

Start move gives the host at least some control over the node, yielding a higher degree of control flexibility.

#### STOP

Stop is the most important motion command. Unlike steppers, which "like" to stop, servo motors like to run away.

While running away doesn't necessarily imply being out of control, it does mean the motion is not doing what it was told to do. Thisfailuremay beduetomechanical breakage or electrical noise, among other things.

It's impractical for a node to always know the actions of other nodes. The host, on the other hand, should know what's going on within the system and be able to require all nodes to stop whatever they're doing.

The stopping action may be smooth, decelerated, abrupt (full-power regeneration), or a coast, which happenswhen motor current is removed and the motor winds down at its own rate.

Based on the system's move and realtime requirements, a node controller is



Figure S-Timing **charts** enable the designer tooptimize feedback requirements and motor type versus cost. Infor instance, a rotary system es performance/cost ratio.

selected. The PC/I 04 computer can be an excellent choice. It's small, cost-effective, and easy to program. It also packages well and uses minimal power.

Looking at the prime objective using nodes, system capability is affected only if the PC/104 system can't support the required motion, I/O, or language.

Computerschosen for embedded applications should be industrially hardened since they will be in environments nonconducive to its electronic construction (e.g., welding and plasma cutting).

#### PC/ 104 ADVICE

PC/104 is a good little workhorse for many embedded applications, and it fits in most. It's small and inexpensive, too, so most customers won't mind maintaining a PC/ 104 inventory.

When choosing an operator interface (i.e., keyboard and display), standardize on it so you won't find out you can't do what you want. And, practice with it before being tossed into a situation. This will free you up to focus on the application and not get sidetracked with the PC/I 04 form factor.

And finally, when designing for embedded operations, keep in mind that embedding the control means more than just sticking the computer into a machine cabinet. It means designing the computer into the machine so it looks like an integral part of the main design objective. Smaller may not always be better. But, don't believe that just because it's small, it can't do the job. PCQ.EPC

Chuck Raskin has written and lectured extensive/y on motioncontrol issues. He recent/y finished the fifth edition of Designing with Motion Handbook. Chuck is an American Institute of Motion Engineers board member as well as manager of technical service for Technology 80. You may reach him at (6 12) 542-9545 or chuckr@tech80.com.

REFERENCES

- D. Hauge, "PC/I 04 Servo Software," Technology 80 Newsletter, Technology 80, Minneapolis MN, Winter 1991.
- S. Holle, Interfacing Encoders to Microcomputers, Technology 80, Minneapolis, MN, Article 5.
- S. Holle, Step Motor Control Using the PCL-240K, Technology 80, Minneapolis, MN, Article 7.
- A.C. Leenhouts, Step Motor System Design Handbook, Litchfield Engineering, Kingman, AZ, 1991.
- C. Raskin, Designing with Motion HandBook II, Technology 80, Minneapolis, MN, 1992.
- Ziatech Corp., "Expanding PC/I 04 Bus Performance Through Multiprocessing," Ziatechniques, 9, 1990.

SOURCE

PC/ 104 encoder card Technology 80 658 Mendelssohn Ave. Minneapolis, MN 55427 (612) 542-9545 Fax: (6 12) 542-9785 www.lech80.com

#### IRS

425 Very Useful 426 Moderately Useful 427 Not Useful

# Applied PCs

Fred Eady

# Managing a NASA Plant-Growth Chamber

Part 1: Picking the Hardware

With our feet *firmly* planted on the ground, it's hard to imagine the adjustments necessary to *take* a *plant* experiment into space. Fred walks us through the sensors and hardware he needs to truck humidity,, temperature, and CO,.

As the seagull flies, I'm 20 miles southwest of Kennedy Space Center's Pad 39. I have a perfect view of every orbiter launch.

If I'm not on the Cape proper, I stand in front of **my** TV until the ship clears the tower. A few seconds later, the windows reverberate with the unmistakable sound of powerful solid rocket motors, and a plume of white smoke pushes the spacecraft upwards.

Within seconds, what I know to be a rather large aerodynamic object is the size of a pinhead. On a clear day, without the aid of looking glasses, I can see the solids separateand begintheirfall into the ocean.

I've seen nearly all of the launches, and I always shake my head in amazement. All that technology, men, and women successfully launched again into what we Earthlings call "outer space."

Although it may seem glamorous, the astronaut's lob is hard work. If you step back and look at this space-program thing, one of the real needs for humans in space is to tend the experiments that will ultimately make life better for us back on Earth. For some time, I've been close to one of those experiment packages. And, thanks to engineers at a space flight-oriented **com**panycalled BioneticsandMark"TheSpace man" machinist, I'**II** show you a day in the life of another species of astronaut-plants.

#### THE PGC

I saw my first PGC (plant-growth chamber) in Mark's machine shop. Photo 1 gives you your first look. After sleeping on it for a few weeks, I decided to "embed," in my own way, the functionality of the PGC.



Figure **1—This** sensor can play **dirty.** The grime mightrlowit down some, but **it will still** be accurate.

I'm not privy to some of the actual flight hardware, software, and firmware, so I needed to select components to automate and monitor the processes the PGC was originally designed for.

Fortunately, through the generosity of the Bionetics engineers, I got my hands on a working PGC and the main sensor stock. I'd already run this idea by Christine at Tempustech, and she was **onboard** to supply the hardware.

Although Bionetics and Tempustech provided the bulk of what I required, I need a bit more hardware and software to embed the PGC. But first, a PGC tutorial is in order.

#### PGC BASICS

The PGC is built using NASA-approved polymers that strictly adhere to the safety standardsofa manned-spaceflightprogram. Six PGCs fly in a special housing placed in a mid-deck locker aboard the orbiter.

The PGC housing contains all the necessary elements to promote plant growth. For those of you new to this planet, that's light,



water. **atmospheric** gases, and plant nutrients.

#### SENSING CO,

Plants like carbon dioxide. and thanks to the presence of humans, there's plenty of that in the orbiter cabin. A Telaire 2001 Vcarbon-dioxide monitor is included to ensure the plants in each PGC receive their prescribed amount of the gas. CO, is gated to the PGC from the crew cabin via a duct when gas levels fall below nominal concentrations.

The Telaire 2001V shown in Photo 2 was originally designed to monitor CO, levels in the air and control a ventilation system. That explains its 24-VAC/DC power requirement. In the flight package, the 2001 V is removed from its decorative covers and mounted within the PGC housing.

Carbondioxide measurements are taken via NDIR (nondispersive infrared). The sensor comes from the factory equipped with a membrane-covered samplechamber that helps provide highly accurate readings.

Normally, the 2001V is set to trip an internal relay depending on the CO, concentration. The controller is factory set to close the relay at 800-ppm concentration.

This trip value can be altered using the UIP program. The UIP is a PC-based program that interfaces to the 2001V controller via an RS-232 connection and enables the user to set the 2001 V's sensor parameters.

The measurement range is fully adjustableovertheentire bandwidth of the 2001V sensor. The program also simulates sensor environments and displays the results.

The 2001V would be little more than dead weight if it could only make decisions on a predetermined concentration and trigger a relay. The proportional O-I O-V analog output voltage makes it a useful tool.

By simply swapping a jumper, the 200 1 V is also capable of 4-20-mA loop operation. With the 2001V, the UIP, and

variable analog output, not only can I fully control environmental objects by referencing *CO*, levels, I can log data, too.

#### SENSING CONDITIONS

Those of you who arrived from other spaceports know that weightlessness is a fact of life when traveling in space. During a weightless sojourn, liquids find their way into the worst possible places.

Since plants on Earth require water, the PGC houses a sponge of sorts in the darker portion of the assembly. The sponge contains the liquid and nutrient mix needed for the PGC's plant life. It also reduces the probability of the liquid becoming droplets that could foul up a humanoid astronaut's day.

Murphy and his lawarecapable of space travel, too. So, to keep Mr. Murphy strapped tightly in his seat, a dual-duty sensor called Survivor II is mounted within each PGC to monitor humidity and temperature levels.

The sensor is installed on a stainless-steel mast. Theentireassembly (i.e., mast, sensor, and connector) is known as the sensor stock. Although our sensor has an integral hydrophobic filter, the hollow cylindrical mast elevates the sensor well above the sponge to prevent flooding the sensor's face.

HyCal Sensing Products supplies the Survivor II Relative Humidity Active Sensor used in the PGC. It's a +5-V CMOS integrated circuit with a thin-film RH sensor embedded in a monolithic structure.

Output is a voltage proportional to the relative humidity. Each Survivor II is factory calibrated and hassensor-unique calibration voltages for 0% and 75.3% RH. Humidity **voltages** are referenced to the sensor power ground. My PGC's sensor outputs 0.807 V at 0% RH and 3.015 V at 75.3% RH.



Photo I-Mork does good work, huh? Note the sensor stock and the fancy latches.

Survivor II uses an integrated platinum RTD for temperature measurement. Platinum exhibits a very linear resistance versus temperature function.

Although less sensitive than some other metals or thermistors, platinum provides an accurate and sensitive way of measuring temperature over time. Platinum's resistance versus temperature function is modeled by the Callendar-Van Dusen equation (its constants are shown in Table 1):

#### $R_{T} = R_{0}(I + AT + BT^{2} - 100CT^{3} + CT^{4})$

where  $R_{\tau}$  is resistance at T, T is temperature in degrees Celsius, and  $R_0$  is resistance at 0°C.

My RTD measures 1 k at 0°C. The RTD resistance is available on two pins of the Survivor II metal TO-5 sensor casing. At  $0^{\circ}C$ , the RTD measures 1001 .O

The Survivor II is an absorptionbased thermoset polymer, three-layer capacitance sensor with an additional platinum RTD mounted in the



Photo 2-When in the orbiter, do as the astronauts do. Here's a **shot** of a naked 200 IV.

CIRCUIT CELLAR INK SEPTEMBER 1997

same package. A typical sensor is depicted in Figure 1.

Allowing water vapor in the dielectric layer to equilibrate with the surrounding gas provides the means to sense humidity. A porous platinum layer shields the dielectric from external influences. A protective polymer layer provides mechanical protection.

According to the HyCal tech notes, the sensor still takes accurate readings when it's pretty dirty. Dirt affects the equilibration process, which slows in proportion to the amount of dirt on its protective layer.

Temperature plays a big part in determining relative humidity. Accurate humidity readings must be temperaturecompensated.

It's best to have the humidity and temperature sensors close together. This lets both sensors share the environment and provide more accurate readings.

The Survivor II accomplishes this by incorporating a 1000-Q platinum RTD on the back of the sensor substrate. You get a thermoset polymer-based capacitive relative-humidity sensor with humidityreadings that are a function of relative humidity and temperature.

Figure 2 is a surface diagram gleaned from the following functions:

True RH = 
$$\frac{\text{Sensor RH}}{1.0546 - 0.002 \ 16 \ \text{x}}$$

for Tin degrees Celsius, or

True RH = 
$$\frac{\text{Sensor RH}}{1.093 - 0.0012 \times \text{T}}$$

for Tin degrees Fahrenheit.

Special venting membraneson the upper PGC body let the atmosphere within the housing circulate through the enclosure. A constantly rotating air-movement device assists with circulation.

The Survivor II sensor data is accessed at the bottom of the sensor stock outside the PGC casing via a seven-pin subminiature female connector. Gas samples from within the PGC are taken via a hypodermic vent integrated into the sponge area of the PGC.

Artificial light **comes** from a specially designed fixture. And, the PGC can be opened via a couple of fancy latches, allowing the astronaut caretaker to physically encounter the plant life.

#### THE ELVIS FACTOR

Let's tally what needs monitoring and controlling. First, humidity and temperature must be monitored and **possibly** controlled. We can? directly affect the humidity within the PGC because there's no way to add or delete moisture. You could indirectly alter the humidity by air circulation, but we can't count on that. So, humidity is a logged monitor-only function. Just in case the humidity falls below a predetermined point, I'll set aside some code to trigger an alarm.

Temperature doesn't fall into that hole. The PGC housing doesn't contain a humidifier or dehumidifier, but Peltierdevices regulate the temperature. Thus, it is a loggable monitor function that triggers PGC housing heating or cooling via a **Peltier** array. As stated, the crew cabin is carbondioxide rich, so it's just a matter of opening a valve and venting CO,-rich atmosphere into the PGC housing. Looks like monitor and control functionality is necessary here.

Theartificial lightsourceandcirculation fan are never interrupted because flight time is precious. Maximum growth conditions must be initiated and maintained.

Neither the light source nor the fan is controlled, but they must be monitored to ensure they are operational. I've got code for them, too.

Elvis did it his way. So can we.

Are you still wasting your money On **Run-Time Royalties?** More than 4000 On Time customers aren't! If you feel you've paid enough, check out our development tools for x86 embedded systems!

> RTTarget-32 Cross development system for 32-bit embedded systems. Boot code, locator, cross debugger. Supports Intel 386 and higher, as little PI 6kRM/ROM. for Borland C/C++, Microsoft C/C++, watcom C/C++, and Delphi. Libraries: \$1 700 Source Code: add \$1000









#### **RTKernel** Professional, high-performance realtime multitasking kernel for DOS and **I6-bit** embedded systems. For Borland C/C++, Microsoft C/C++, and Borland Pascal.

Libraries: \$550 Source Code: add \$500



Coming soon: TCP/IP stack and FAT file system!

North America: On Time 88 Christian Avenue Setauket, NV 11733, USA Phone (516) 689-6654 Fax (516) 689-1172 email info@on-time.com International: On Time Informatik GmbH Hofweg 49 22085 Hamburg, GERMANY Phone +49-40-2219405 Fax +49-40-22192403 email 102212.3101@compuserve.com http://www.on-time.com



SEPTEMBER 1997 ENBLDDEDPC







Figure 2-Here's a sensor eye view versus the real thing. This graph needs a skier, **don't** you think?

#### FLIGHT HARDWARE

Although innovative in design and **application**, there's nothing exotic about the sensor stock and CO, sensor. The embedded hardware to monitor these devices needn't be complicated nor expensive. However, you need to plan how the PGC embedded system should be configured.

It would be simple (and wasteful) to select a single-board solution that encompasses all of the common PC-compatible peripheral components. This isspaceflight. Power and mass must be conserved.

But, what if the PGC mission requirements change? What if Ethernet is needed and our golden SBC doesn't have onboard Ethernet capability? Or  $|^2C$ ? (Seen any SBCs lately with built-in  $|^2C$ ?) What if the display type changes or we need a more powerful CPU later? Can the SBC be serviced, or is the whole thing chucked when one part fails? What if...what if?

The only logical solution is to select an

embedded system that can be built peripheral by peripheral with minimal impact to the mission software.

Almost every day, I'm pushing and pulling

Photo **3—Here's** the VMAX groundsupport configuration. Just plug in and play with it. peripheral cards out of desktops. Why not apply that no-brain technology to the PGC project? I just need a system that can be configured on a backplane and stand alone during the mission.

The card-by-card-on-a-backplane idea has some drawbacks. First of all, if we really end up flying the backplane, our embedded footprint just got a bunch bigger.

Next, power consumption will be higher because of multiple peripheral cards versus specialized silicon. Finally, troubleshooting now stretches across a backplane and multiple firmwareladen cards.

To minimize the impact of a multicard system, choose the embedded CPU board wisely. It must be at home on a bus, have the power to be used as the development system, and be able to stand alone when the mission requires it.

#### VMAX SBC 301

During normal operation, the PGC doesn't need a desktop display, keyboard, or physical magnetic media to monitor the plant environment. The actual flight configuration must be a single-board solution.

At this point, the only other card required for PGC software development is a display card, assuming that our chosen CPU card contains standard I/O ports and a way to implement silicon disk emulators. Everybody's on a budget, so the CPU must be inexpensive and powerful enough for our application on the ground and in space.

Our PGC will fly with the Tempustech VMAX SBC 301 single-board computer.



CIRCUIT CELLAR INK SEPTEMBER 1997

| α (°C <sup>-1</sup> ) | 0.00375                   | 0.00385                    | 0.003902                  |
|-----------------------|---------------------------|----------------------------|---------------------------|
|                       | ±0.0004 (S)               | ±0.0003 (S)                | ±0.0004                   |
|                       | f0.0002 (T)               | ±0.0002 (T)                | ±0.0004                   |
| δ ("C)                | 1.605±0.009               | 1.4999±0.007               | 1.52±0.01                 |
| β ("C)                | 0.16                      | 0.10863                    | 0.11                      |
| A (°C⁻¹)              | 3.81 x 10 <sup>-3</sup>   | 3.908 x 1 0 <sup>-3</sup>  | 3.96 x 1 0⁻³              |
| B (°C⁻²)              | -6.02 x 1 0 <sup>-7</sup> | 5.775 x 1 0 <sup>-7</sup>  | -5.93 x 1 0 <sup>-7</sup> |
| c (°C⊸)               | -6.0 x 1 0 <sup>-12</sup> | -4.183 x 10 <sup>-12</sup> | -4.3 x 1 0 <sup>-12</sup> |

**able** I--This equation uses constants A, **B**, and C, which correlate to resistance measurements at  $0^{\circ}$ , 100°, and 260°C, respectively. Uncertainties followed by (S) or (T) are associated with standard and tight *trim RTDs*, respectively.

The SBC 301 is an industrial-grade CPU card that's 100% IBM/AT compatible.

The SBC 301 can operate stand alone or in a 16-bit passive ISA-bus backplane and has a 66-MHz 486SXLC processor. Onboard peripherals include the standard serial and parallel ports with floppy, IDE, and 2.5 MB of solid-state disk support.

On the firmware front, Datalight's CardTrick is included so the flash array appears as a DOS disk. Photo 3 shows the SBC 301 mounted in the backplane.

I'll use the peripheral capability of the SBC 301 to initiate the PGC software. And, I'll employ the services of Datalight's ROM-DOS and Microsoft's Visual C++.

Since I have an Ethernet LAN in the Circuit Cellar Florida Room, I'|I include an Ethernet connection to access data from the other computers here.

Once the software is debugged and loaded into solid-state disks, the SBC 301 will be on its own with the PGC.

#### WEIGHTLESS ANALOG-TO-DIGITAL

The SBC 301 does not contain any onboard A/D circuitry. Therefore, I have to supply an A/D front end.

Since the PGC needs may change, I'll include an analog front end with smarts. tow parts count and minimum power consumption are essential.

tow power and high functionality for IClevel embedded applications spells Microchip PIC 14000. With it, I can effect a super low-fat A/D front end for this project.

The PIC 14000 is self-contained. Its oscillator is onchip, and the only external components needed are capacitors for the A/D clock and power bypass.

The chip was designed for battery-monitoring applications. It's a mixed-signal device with internal temperature sensing, analog comparators and a multiple-input ADC. The dual-slope conversion technique of its A/D subsystem supplies the accuracy we need to take readings from the PGC. The output voltages of the HyCal and Telaire sensors are perfect for the A/D circuitry of the +5-V powered PIC-14000. There are eight analog inputsavailable. I'll use three of them for the HyCal humidity sensor, Telaire CO, sensor, and RTD.

#### GROUND EQUIPMENT PACKAGE

All the major pieces of the equipment needed to monitor this PGC are in place.

Next time, |I'|| show the code and the processes that make the PGC system functional. |I'|| also explore different methods of getting the data from the PIC 14000 using the VMAX SBC 301 's resources. APCEPC

Fred Eady has over 20 years' experience as a systems engineer. He has worked with computers and communication systems large and small, simple and complex. His forte is embedded-systems design and communications. Fred may be reached at fred@edtp.com.

SOURCES CardTrick, ROM-DOS Datolight 18810 59th Ave. NE Arlington, WA 98223 (360) 435-8086 Fax: (360) 435.0253

www.datalight.com Survivor II Sensor HyCal Engineering 9650 Telstar Ave. El Monte, CA 9 173 I-3004 (8 18) 444-4000 Fax: (8 18) 444-I 3 14 www.hycalnet.com

PIC 14000 Microchip Technology, Inc. 2355 W. Chandler Blvd. Chandler, AZ 85224-6199 (602) 786-7200 Fax: (602) 786.7277 www.microchip.com

Telaire 2001 V KELE & Assoc. 2975 Brother Blvd. Bartlett, TN 38133 (901) 382-4300 Fax: (901) 372-2531 www.kele.com

#### VMAX SBC 30 1

Tempustech 295 Airport Rd. Naples, FL 34104 (941) 643.2424 Fox: (94 1) 643-498 1 www.tempustech.com

#### IRS

4 13 Very Useful 414 Moderately Useful 415 Not Useful

SEPTEMBER 1997



URL:www.rtdusa.com E-Mail:sales@rtdusa.com RTD Scandinavia Oy

Helsinki, Finland Tel:358-9-346-4538 Fax: 358-9-346-4539 RTD is a founder of the PC/104 Consortium

# **DEPARTMEN**TS

62 **MicroSeries** 

74

78

Silicon Update

# MC68030 Workstation

# The Hardware

What do you do when components

are no longer sold? Ingo built his own system. It was the only cost-effective way he could get a 68k platform to teach assembly-language programming when Motorola's MC68000 ECB was discontinued.

he MC68030workstation project started when our faculty group realized that there was no good 68k platform for teaching assembly-language programming. The traditional MC68000 ECB from Motorola is no longer sold, and the evaluation kits for the 683xx MCUs weren't exactly right for some tasksnot to mention that they're overpriced. So, I suggested building our own teaching platform.

We quickly decided this new system had to be 68k based, since many textbooks use this processor as one of the architecture examples. It was also decided that it needed an ISA-compatible expansion bus as well as a scancode-based keyboard and some kind of memory-based display interface.

Why ISA bus on a 68k-based system? ISA bus is a very cost-effective system, so it fit our limited budget. Since most of the PCs in the department are being continuously upgraded, I was able to rescue many 8-bit VGA and Ethernet cards from our surplus bins.

I also considered "cleaner" buses such as PCI and VME, but could not justify buying cards for these buses when free cards were available.

In addition to the ISA-bus slots. I added three custom "cpubus" connectors which provide access to the unbuf-

# From the Bench

# **MICRO** SERIES

**Ingo Cyliax** 



fered CPU signals. So, coprocessors and fast memory can be added to this system.

I also decided to use LSI/MSI TTL components when possible. This way, every part in the system is identifiable, so it should be easy for students to infer what each component does from standard datasheets.

There are two exceptions. One is a PAL for decoding the bank selects for the DRAM memory. Also, I used an MC68901 MFP-a companion I/O chip to the 68k line. It contains some timers, parallel I/O, and the serial port used for the keyboard interface.

Since this machine is essentially built from scratch and I wanted to follow the open methodology in hardware and software, this meant writing many components from scratch and using freely available tools if the source code was available. Later in the series, I'll describe the software-development tools I used and the software I wrote for this system.

By the way, the schematics, PCB artwork, and program sources are



| Address                                                                                                                                                                                                                           | Si ze                                 | Description                                                                                                                                                          |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00000000 - 000fffff<br>00100000 - 001fffff<br>00200000 - 002fffff<br>00300000 - 003fffff<br>00400000 - 004fffff<br>00500000 - 005fffff<br>00600000 - 006fffff<br>00700000 - 007fffff<br>00800000 - 7fffffff<br>80000000 - 803ffff | 8<br>8<br>8<br>16<br>16<br>8<br>8<br> | 64-Kb EPROM<br>32-Kb SRAM<br>MFP<br>illegal<br>ISA-bus I/O<br>ISA-bus memory<br>ISA-bus I/O<br>ISA-bus memory<br>repeat above (0-7fffff)<br>4-Mb DRAM<br>repeat DRAM |

available via ftp, and you're free to use them for noncommercial purposes.

#### HARDWARE OVERVIEW

The system can be roughly divided into four major groups-the CPU, ISA bus, DRAM interfaces, and onboard I/O. There's only one onboard I/O device on this system-the AT-compatible keyboard interface.

I chose the MC68030 for my CPU. It has a flexible bus interface and an integrated MMU module. Since it has dynamic bus sizing, it was easy to provide interfaces for 8-/16-bit ISA bus, 32-bit DRAM, and 8-bit EPROM and SRAM with minimal logic.

The processor asks for an object, and the system responds with the port size available. If the system port size is smaller than the object to fetch, the internal bus interface in the MC68030 automatically sequences and muxes the data to the appropriate place.

The MC68030 has two bus termination modes. The asynchronous termination mode, indicated by asserting a combination of DSACKO and DSACK1, is used when dynamic bus sizing is required.

Its timing is also compatible to the 68k bus cycle. It is asynchronous because it assumes the data and DSACKx signals are asserted asynchronously and have to be synchronized to the CPU clock before processing.

The synchronous bus cycle, indicated by asserting the STERM signal, shows that the data and STERM are synchronous to the processor clock and can be processed without an extra synchronization cycle. Also, the STERM signal indicates that the port size is 32 bits. STERM allows the fastest possible bus timing on the MC68030. Table I--Since *the* MC68030 processor *has no I/O* instructions, *the ISA* **bus is broken up into** *four* **address** *maps.* **Each causes** *a different bus cycle to occur on the ISA bus.* 

The MC68030 also has a burst-mode operation to fill its cache from page-mode DRAMs

using an extension of the synchronousbus-cycle mode. But since this system is low end, this mode wasn't implemented. The data and instruction caches also work well with the asynchronous and nonburst-mode synchronous-bus-cycle modes.

Given the flexible bus interface, the MC68030 is easy to design with. I ended up using asynchronous-bus-cycle modes when addressing the ISA bus (8- and 16-bit ports), PROM/SRAM (8-bit port), and onboard I/O resources (8-bit port). I used synchronous cycles for speed when addressing the system's DRAM (32-bit port).

A 74LS138(8:1 selector) decodes the I/O, ISA bus, PROM, and SRAM address space in the lower 2-Gb address space. The higher order address bit selects the DRAM which, even though 4 Mb is implemented, repeats in the 2-Gb upper address space.

By placing the DRAM in the upper address space, I was able to decode the 8-bit PROM in the lower memory where the process fetches its reset vector and initial stack pointer. Table 1 shows the address map of the whole system.

A shift register generates differently timed bus acknowledge signals. These are selected using a 8: 1 selector-one for each DSACKx signal-to generate different wait states for each decoded object. Hence, the ISA-bus I/O cycle has to be longer than an SRAM access.

Another shift register generates a bus-error exception if no bus acknowledgement is received. This feature implements a bus timeout for references to illegal address ranges.

All that remains to interface to the 68030 is the interrupt interface and a single-phase 1 6-MHz clock, which is derived from a TTL clock module.

## If you need I/O...

#### Add these numbers up:

80C552 a '51 Compatible Micro 40 Bits of Digital I/O
8 Channels of 10 Bit A/D
3 Serial Ports IRS-232 or 422/485)
2 Pulse Width Modulation Outputs
6 Capture/Compare Inputs
1 Real Time Clock
64K bytes Static RAM
1 + UVPROM Socket
5 12 bytes of Serial EEPROM
1 Watchdog
1 Power Fail Interrupt
1 On-Board Power Regulation

#### It adds up to real I/Opower!

That's our popular OEM 552SBC-40, priced at just \$299 in single quantities. Not enough I/O? There is an expansion bus, too! Too much I/O? We'll create a version just for your needs, and pass the savings on to you! Development is easy, using our Development Board: The 552SBC-50 Development board with ROM Monitor for \$349.

#### New Versions of the 8031SBC

Our popular 803 1SBC can now be shipped with your favorite 8051 family processor. Models include **80C5** 1 FA, **DS80C320,80C550, 80C652,80C154,80C851** a n d more. Call for pricing today!

#### Truly Low-cost In-Circuit Emulator

The DryICE Plus is a low-cost alternative to conventional ICE products. Load, single step, interrogate, disasm, execute to breakpoint. Total price for the base unit with most pods is a low \$448. Call for brochure, or World Wide Web at www.hte.com.



MC68030's interrupt system is also very flexible. (What did you expect?) It uses multilevel priority-based interrupts (IRQ1–7) to request an interrupt. IRQ7 is the highest level and is not maskable. The external interrupter asserts an interrupt by encoding it into the three interrupt signals IPL[0:2].

In this design, I used a 74LS148 (8-1 priority encoder). Figure 2a shows the interrupt circuitry and ISA-bus and keyboard interfaces, while Figure 3a shows the CPU.

Once the MC68030 sees the interrupt request by noting that one or more of IPL[0:2] are asserted, it responds to the interrupt if the interrupt-request level is higher than its current interrupt mask or if it's a level 7. It starts an interruptacknowledge cycle that resembles a regular bus cycle, except that a special bus cycle is indicated with the FC[0:2] function codes.

The interrupt-acknowledge cycle can be terminated by a peripheral by supplying an external interrupt vector and asserting one of the bus termination signals or by asserting AVEC. If the cycle is terminated with AVEC, it uses a predetermined internal interrupt vector.

A large real-time system may use many interrupt vectors to tell the processor what the source of the interrupt was and how to handle it without spending much time hunting down the cause. In this design, it's acceptable to spend time polling devices for the interrupt cause, especially since ISA-bus devices don't generate interrupt vectors.

Generating the autovector bus termination was easy. I simply decoded the function code FC[0:2] to indicate an interrupt-acknowledge cycle and assert AVEC.

The integral MMU was an interesting option, since it enables the use of this platform in a serious OS-type class project (e.g., virtual memory or memory management in modern OSs). In fact, I developed a version of Minix that uses the MMU, which the students can dissect and explore. No external hardware is needed to enable the use of MMU functions on the MC68030.

The ISA-bus interface uses four of the select lines to form the address decoder to implement four address maps. Each address map indicates one of the possible ISA-bus cycles.

There are 8- and 16-bit memories and 8- and 16-bit I/O accesses. The memory accesses use the signals MEMRD and MEMWR to indicate a memory read and write on the ISA bus. An I/O cycle uses the IORD and IOWR signals.

Figure 2b shows how the ISA-bus interface is implemented. An ISA-bus card can also extend a bus cycle by asserting the signal IORDY. It was necessary to implement this signal, since many VGA cards stretch the CPU bus cycle to deal with memory contention to the video memory.

In addition to expanding the interrupt system by implementing the 16-bit expansion interrupts, the MC68901 Multifunction Peripheral (MFP) handles the AT-compatible keyboard interface.

The MFP expands the number of interrupts by using six of the eight general-purpose I/O pins as external interrupt pins. They can be programmed to be edge as well as level sensitive. The MFP interrupt controller makes it easy for software to find the interrupt source by providing some registers that indicate pending interrupts.

There are also facilities for masking any of the interrupts and clearing pending interrupts. Table 2 shows the interrupt map of this system. As you can see, many of the interrupts are handled by the MFP and are presented as a single interrupt request at level 6 to the CPU.





ERSON i di H L ST. OF TECHNOLOGY 113 • CALIFORNIA STATE • ADEMY MILWAUKEE SCH. P Engr. • Case Western Reserve Mercer • Aalborg • Amarillo C. • Appalachian • MIT • State U. • **U. OF ARIZONA** 

If you're an engineering professor or teach qualified technical students, we'd like to give you and all of your students free subscriptions to *Circuit Cellar INK*. Contact:

Rose Mansella • Circulation Coordinator • Circuit Cellar INK 4 Park St. • Vernon, CT 06066 • (860) 875-2199 • Fax: (860) 871-0411 rose.mansella@circuitcellar.com • www.circuitcellar.com

## EMBEDDED DOS CONTROLLERS AT 8051 PRICES



| Level | Source         | Function        | Level | Source | Function      |
|-------|----------------|-----------------|-------|--------|---------------|
| ipl7  | "break" buttor |                 | ipl6  | MFP(4) | Timer D       |
| ipl6  | MFP(15)        | ISA-bus IRQ9    | ipl6  | MFP(3) | ISA-bus IRQ14 |
| ipl6  | MFP(14)        | ISA-bus IRQ10   | ipl6  | MFP(2) | ISA-bus IRQ15 |
| ipl6  | MFP(13)        | Timer A (60 Hz) | ipl6  | MFP(I) | KBD data      |
| ipl6  | MFP(12)        | KBD receive     | ipl6  | MFP(0) | KBD clock     |
| ipl6  | MFP(11)        | KBD error       | ipl5  | direct | ISA-bus IRQ3  |
| ipl6  | MFP(8)         | Timer B         | ipl4  | direct | ISA-bus IRQ4  |
| ipl6  | MFP(7)         | ISA-bus IRQ11   | ipl3  | direct | ISA-bus IRQ5  |
| ipl6  | MFP(6)         | ISA-bus IRQ12   | ipl2  | direct | ISA-bus IRQ6  |
| ipl6  | MFP(5)         | Timer C         | ipll  | direct | ISA-bus IRQ7  |
|       |                |                 |       |        |               |

Table 2—These are all the possible interrupt sources on the MC68030. Many of the interrupts are routed through the MC68901 MFP, which prioritizes all of its interrupt sources (0–15) and uses interrupt priority level 6 to notify the CPU.

The MFP implements the keyboard interface by using its internal USART. The USART has a receive clock input that enables a lx baud-rate clock, even in asynchronous mode.

This feature is perfect for the AT keyboard interface, since it uses a clock signal to indicate when the serial data needs to be sampled. The data format for the AT keyboard scan codes is 1 start bit, 8 data bits, even parity, and 1 stop bit. Figure 2b shows how the keyboard interfaces to the MFP.

To make the design more interesting and useful for larger projects, I added DRAM. A single 72-pin SIMM module doesn't take up much real estate, but since it uses 50-mil staggered pins, it's a little harder to prototype with. The DRAM interface port size is 32 bit and uses a 74LS163 shift register to sequence the CAS and RAS, which are presented to the PLD for further decoding.

I used 74LS150 2: 1 muxes to multiplex the address bus. Since the 68030 needs to be able to write byte data to memory, I implemented a bank decoder in the PLD to assert the correct combination of CASx selects and satisfy any possible data-transfer situation.

Figure 3b shows how the DRAM subsystem interfaces with the CPU. Table 3 shows the truth table for the byte-selection logic implemented by the PLD.

Of course, you have to refresh all the rows in the DRAM once every 2 ms. This task is accomplished by dividing the system clock down to 4 us. That gives one total refresh cycle in 2.048 ms, which I thought was close enough.

The 4- $\mu$ s clock edge triggers a 74LS74 flip-flop to indicate a pending refresh

request. Once the current CPU cycle finishes, a separate shift register will time a CAS before RAS refresh cycle and present the PLD with an RCAS signal to indicate that this is a refresh cycle, while the next CPU is blocked.

Once the refresh cycle is done, the refresh-request flip-flop is cleared using an async clear input. It's unlikely that a refresh request is skipped, since a CPU cycle and one refresh cycle take less than  $4 \ \mu s$ .

I also considered that someday I might want to add a floating-point processor to the system, but I didn't want to clutter the design. So, I added a CPU bus instead.

This bus essentially brings all the CPU pins into a 96-pin DIN connector. There's also a signal that inhibits the onboard decoder and enables the CPU card to decode address spaces which shadow the onboard resources.

#### MOTHERBOARD DESIGN

The wire-wrap version of the motherboard was done on a special wire-wrap proto board we developed at IUCS for chip testing and system-level prototyping. This board-the Logic Engine contains a parallel port interface that enables a PC to set and read 128 bits of I/O, program timers, and so forth.

For this project, we didn't use this interface and build the system as a stand-alone prototype. I actually created two wire-wrap prototypes.

The first was a 68020 system that included a prototype ISA-bus interface to demonstrate the feasibility of writing software that could interface with PC peripherals (e.g., the VGA graphics card and floppy interface).

The 68020 system was short-lived, since it only implemented 8-bit devices



| adrl              | adr0             | sizl             | siz0             | cas3             | ca               | s2 ca            | s1cas0           |
|-------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|
| 0<br>0<br>1<br>1  | 0<br>1<br>0<br>1 | 0<br>0<br>0<br>0 | 0<br>0<br>0      | 1<br>0<br>0<br>0 | 1<br>1<br>0<br>0 | 1<br>1<br>0      | 1<br>1<br>1      |
| 0<br>0<br>1<br>1  | 0<br>1<br>0<br>1 | 0<br>0<br>0<br>0 | 1<br>1<br>1      | 1<br>0<br>0<br>0 | 0<br>1<br>0<br>0 | 0<br>0<br>1<br>0 | 0<br>0<br>1      |
| 0<br>0<br>1<br>11 | 0<br>1<br>0      | 1<br>1<br>1<br>1 | 0<br>0<br>0<br>0 | 1<br>0<br>0<br>0 | 1<br>1<br>0<br>0 | 0<br>1<br>1<br>0 | 0<br>0<br>1<br>1 |
| 0<br>0<br>1<br>1  | 0<br>1<br>0<br>1 | 1<br>1<br>1<br>1 | 1<br>1<br>1<br>1 | 1<br>0<br>0<br>0 | 1<br>1<br>0<br>0 | 1<br>1<br>1<br>0 | 0<br>1<br>1<br>1 |

Table 3—Thistruth table for the byte-selection circuitry for the DRAM interface is implemented in the PLD. For each combination of address location and size request, the appropriate CAS selects fo the DRAM must be generafed.

and had no DRAM. After testing some of my assumptions about the ISA-bus interface on this system, I proceeded to design and build a wire-wrap prototype of a 68030 system.

I documented the design as I went along and was able to design in steps that made the design more modular and kept my confidence high that I could get everything to work.

Contrast this approach to designing the whole system and then building a wire-wrap prototype only to discover that many things you assumed would work didn't. It's much easier to debug an incremental design.

Once the design was working and verified to match the documentation, I passed it on for PCB layout. The board was laid out to ensure that all the mounting holes, ISA-bus slots, and power connectors could fit in a standard baby-AT case.

While this choice enables us to use ultra-cheap PC cases with power supplies, I think it makes for an unattractive machine. It looks just like a PC! This situation has, of course, evoked many funny situations when an unsuspecting user gets a totally foreign bootmonitor prompt instead of the familiar Windows look.

After the PCB layout was complete, we spent a nervous two weeks waiting for the first samples to come back from the board house. We distracted ourselves by working out the logistics of ordering components to build 20 of these systems and by putting some finishing touches on the software. The first board worked, although it had a few erratas that we incorporated in the final layout. To date, the final layout has only had to have one errata in three years of service.

#### HARDWARE WRAPUP

Even though the design is fairly complex, we ended up with 20 out of 20 working systems. This process shows that wire-wrap prototype designs running at 16 MHz are no major challenge as long as you use well-designed prototype boards that have a ground plane.

Next month, I'll talk about the monitor software and how it boots, as well as some of the issues involved with programming ISA-bus peripherals in a 68k.

Ingo Cyliax is a research engineer in the Analog VLSI and Robotics Lab and teaches hardware design in the computer-science department at Indiana University. He also does software and hardware development with Derivation Systems, a San Diego-based formal-synthesis company. You may reach Ingo at cyliax@EZComm.com.

#### SOURCES

Schematics and PCB artwork for this system can be found at <ftp. cs.indiana.edu/pub/goo/mc68030>.

#### REFERENCES

L.C. Eggbrecht, Interfacing to the IBM Personal Computer, SAMS, Carmel, IN, 1990.
Motorola, MC68030 Enhanced 32bit Microprocessor User's Manual, Phoenix, AZ, 1990.
Motorola, MC68901 Multi-Function Peripheral, Phoenix, AZ, 1988.
Motorola, Motorola Memory Databook, Phoenix, AZ, 1989.
E. Solari, ISA & EISA: Theory and Operation, Annabooks, San Diego, CA, 1992.

#### IRS

**416** Very Useful 417 Moderately Useful 418 Not Useful

# KBDXLATOR

## A Cure for the 16.6-kbps odd Parity Blues



At times, irritations in life become intolerable.

This month, it happened to Jeff. He needs his keyboard to work as an asynchronous serial device. So, it's back to the drawing board.

# FROM THE BENCH

#### Jeff Bachiochi



last weekend."

Why should I worry? Dan's a college graduate now. He should have moving in and out of dorm rooms down pat.

"We'll be fine," I thought. "With the Honda and the Caravan, there'll be room for the nine of us."

We made a dozen trips to the Honda. With the rear seat folded flat, there was room for the oddest shaped items. The back seat filled quickly, then the trunk. We pushed stuff into the smallest spots. After the passenger seat filled, we stopped. Someone had to drive home.

"We're not gonna get any more in here. Let's go. It's almost time for commencement."

"All packed?" my wife asked when we returned.

"Not exactly. Dan seems to have underestimated a wee bit. We'll have to put a few things in the van after the ceremony."

Commencement exercises were filled with the usual abundance of laughter and tears. And suddenly, four years of work were over.

"Everybody grab something. We're not coming back," Dan exclaimed as we left his apartment. We looked like an African safari. A single file of bodies, each carrying a staggering burden.

I think Dan carried the biggest burden of all. I saw it in his eyes as he shut the door for the last time.

"Where's all this gonna go?." was everyone's question. But, I had a secret weapon. Bungees.

The table and all the luggage fit on the van's roof rack, thanks to the bungees. After spinning the web of elastic thread, it was a simple engineering task to fit the remaining objects in.

Each person was packed into their seat. My parents were in the center. Mom was pinned in by a folding chair, while Dads feet were on the cooler.

Our Caravan reminded me of Dr. Who's tardis-a wonderful police-box– shaped time machine with an inside larger than its outside.

The whole packing process reminds me of trying to fit more circuitry onto ever-shrinking real estate. It's the facet of engineering I find most challenging.

High on the list is making use of items that are already available...

#### LIKE THE KEYBOARD

The most widely used input device connected to the PC today was, is, and



Photo 1 --The KBDXLATOR circuitry fits easily info a small PacTec enclosure. I like the fact that a DB-25 fits info the package and the whole thing plugs right info a serial port.

will be (at least in the near future) the keyboard. Although it has gone through a few redesigns, it remains pretty much the same as the day the first PC rolled off the assembly line.

Although the PC has always had serial ports, the PC keyboard wasn't designed as an asynchronous serial device. Considering the price of a keyboard, it could be cost effective in many projects requiring ASCII input.

The PC/AT keyboard uses a twosignal clocked synchronous serial format. The keyboard supplies the clock for the 1 l-bit data transmission.

Eight data bits of least-significantbit-first format are surrounded by start, odd parity, and stop bits. The 60-µs bit time provides a 16.666-kHz data rate (not exactly one of the most common).

Because the keyboard samples the clock and data lines, its transmissions can be halted while it receives data from the host. In this case, it still provides the synchronous clock for the transfer.

The host can command the keyboard to restart the power-on self test, resend the last data byte, and enable or disable the three LEDs (num, caps, and scroll lock) in the keyboard's enclosure.

Actually, the keyboard doesn't need any feedback from the host to operate. It's happy just outputting key make and break codes.

#### FOUR KEYS SHORT OF A PIANO

Unlike the normal serial terminal where you press the letter A and receive the universal ASCII code for the letter A, the PC/AT keyboard outputs a value which seems to have no logical sense.

Each keycap (or switch position) has a number associated with it in an almost natural left-to-right top-to-bottom format. Each numbered position has a different number associated with it called a make code (i.e., the value sent when a key is pressed). This number has no relation to either the position or the ASCII code.

Think of it as a secret code. When the A key, position 3 1 (decimal), is pressed, a make code of 1Ch is sent to the host. When A is released, an F0h is sent, followed by a 1Ch code indicating a break code.

So as you see, the 84-key PC/AT keyboard is really stupid. It doesn't



Figure I--Not much external *circuitry* is needed around the *PIC16C84* processor. Configuration *inputs could* be used to select baud rate and/or invert the serial output.

know an A from an a, and it doesn't know the three-fingered salute (Ctrl-Alt-Del). It's the system that remembers which keys are held down and adjusts the translation accordingly.

It was nasty when the AT came onto the market. The AT's keyboard format wasn't compatible with that of the XT. Now, XT keyboards are all but extinct.

When the newer 101-key AT keyboards came on the scene, they at least retained a mode emulating the 84-key make-/break-code format. However, they do reset into a different mode and must receive a change-of-mode command to emulate their older brother.

#### FORMAT TRANSLATOR

To correct this engineering faux pas, you must be able to read keyboard transmissions. Since they're synchronous and data is valid during clock low, I'll use a falling-edge interrupt.

When a falling edge triggers an external interrupt, the interrupt routine grabs the data line's state and reverts it to the in-line code.

The first in-line routine, K-START, checks for a proper start bit (i.e., a 0). In addition, the parity flag is preloaded with a 1 and the timer is set so an overflow will occur after -1 ms.

The next eight bits route through the K\_DATA routine, which rotates them into the byte-variable K\_VAL. If any of the data bit values are 1, the parity flag is complemented, which keeps a running correction to the parity flag.

Next, the odd-parity routine checks whether the computed parity flag and the received bit are the same. Finally, the stop-bit routine checks to see that a proper stop bit (i.e., a 1) is received.

If an error occurs with any of the checks along the way or if the timer overflows, the data is dumped and control jumps back, looking for another keyboard start bit. Otherwise, the data byte is carried into the second half of the in-line code. So much for grabbing the keyboard's transmissions.

To prevent the keyboard from potentially transmitting more data, I turn the CLK input line into an output and drive it low. Now, I decide what to do with the code received from the keyboard.

Since this key code is *not* the ASCII equivalent to the key pressed, we have a chance to do some character translation. A few codes need trapping before they're translated. Most are responses to commands sent to the keyboard. Once they are trapped, the program flow is steered around the UART routine so no output is produced.

The next codes trapped also produce no output, but they do have important functions. They set flags to help navigate the program flow toward the proper tables (described below). They are the break code (FOh) and the shift, control, and alternate key codes.

#### NO ROOM AT THE INN

A table that can hold all the possible characters sent by the keyboard would require 255 entries. Some characters require multiple keys to be pressed simultaneously (e.g., shift + m = M). The characters can be broken down into four groups-unshifted, shifted, control, and alternate.



With 255 possibilities for each group, that's 1000 table entries. The 16C84 only has room for 1 KB of code, so this many table entries leaves nothing left.

Of the total 255 possible key codes (excluding the ones trapped), none are above 7Fh. So, the high bit is cleared, and they now fit into a table of only 128 for each group. The four tables reduce to 0.5 KB, and there's still 0.5 KB left for the executable code.

To track the two shift keys, caps lock, control, and alternate combinations, the trapped codes set or clear flags based on whether or not the break flag is set or cleared.

For the caps-lock key code, the shift flag bit is complemented since it toggles and doesn't have to be held down. The other flags (i.e., shift, control, and alternate) are set while the key is pressed. Or, they are reset if the previous key code was an F0h and a break flag was set, indicating that a key was released. All other key codes are passed on to the in-line UART routine.

The code looks at the control, alternate, and shift flags to determine which of the four character-translation tables to use. The tables can be filled with any constants you want, which allows for ASCII output as well as customized key translation.

I chose to shift the control table translations for A-Z down by 40h to output the ASCII control codes 00h– 1Fh. In the alternate table, translations for O-7Fh are shifted up 80h to output 8-bit extended ASCII codes covering the graphic-drawing characters.

The shift table translates key codes into uppercase or upper-row ASCII characters, while the unshifted table translates them into lowercase or lowerrow ASCII characters.

Untranslatable characters (e.g., F1– F12) send out null characters. But, they can send out any ASCII character you put in their translation-table positions.

Once the key code is translated into a character code, the byte is ready to send via a UART. The 16C84 doesn't have a hardware UART, so the asynchronous output has to be bit banged.

To ensure accurate bit timing for the asynchronous serial transmissions, the timer is set to produce an interrupt for each bit. The in-line code uses three



Figure 2—The fop trace shows the PCA J KBD's clock and the second is the data. The bottom trace shows KBDXLATOR's ASCII serial output. Notice that KBD's clock line is held low to prevent more output until \*BDXLATOR has finished ifs transmission.

routines--U-START, U\_DATA, and U\_STOP-to set the data bit to be output.

The timer-overflow interrupt routine outputs the data to the port pin. A configuration input bit lets the serial output be normal or inverted, depending on whether true RS-232 levels are needed. I added an external MAX232 level shifter (see Figure 1), but you can cheat and use a straight TTL interface.

Once the character is sent out the (software) UART, the keyboard is again enabled (by returning the CLK to an input configuration] and the code jumps back to the top, and is ready to grab the next keyboard transmission. Figure 2 shows the results of a scope trace of the keyboard's transmission.

#### ROOM ON THE INSIDE

Unfortunately, the processor in most PC/AT keyboards isn't low power (probably because they were designed to run off the PC's power supply).

The interface could steal enough power off a serial port to operate. But since the keyboard needs its own power, I might as well power the whole mess off a wall-wart supply.

I chose the 16C84 because, while it doesn't have a hardware UART, it does have a few interrupt sources that make coding easier.

Also as many of you know, I'm a crash-and-burn kind of guy. The fact that the 16C84 is reprogrammable keeps me from filling my wastebasket with dumb mistakes.

Although I initially planned to fit this circuit into the empty corner of a PC/AT keyboard and eliminate the cord, I thought it would be simpler to put the circuitry on a cord and keep the keyboard standard, as Photo 1 shows.

Pac Tec makes a new line of plastic cases with a variety of molded ends. A case with a DB-25 cutout at one end and an RJ1 1 at the other works well. Opposite the DB-25, I added a hole for the power supply and one for an LED, while the keyboard jack fits into the RJ11's square hole.

The next time I need a serial input device, I won't have to drag over a whole PC. Now, I can just whip out the KBDXLATOR.

Too bad it doesn't move furniture. 🗖

*Jeff* Bachiochi (pronounced "BAH-key-AH-key") is an electrical engineer on Circuit Cellar INK's engineering staff. His background includes product design and manufacturing. He may be reached at jeff.bachiochi@circuitcellar.com.

#### SOURCES

#### **PIC16C84**

Microchip Technology, Inc. 2355 W. Chandler Blvd. Chandler, AZ 85224-6199 (602) 786-7200 Fax: (602) 786-7277 www.microchip.com

Digi-Key Corp. 701 Brooks Ave. S Thief Falls, MN 56701-0677 (218) 681-6674 Fax: (218) 681-3380

CNL-X-X enclosure Pac Tec 8425 Executive Ave. Philadelphia, PA 19 153-3893 (215) 3658400 Fax: (215) 365-4420

#### **MAX232**

Maxim Integrated Products 120 San Gabriel Dr. Sunnyvale, CA 94086 (408) 737-7600 Fax: (408) 737-7194

#### RS

419 Very Useful420 Moderately Useful421 Not Useful



## ly, Standard RS-485 Networ

With Cimetrics' 9-Bit µLAN you can link together up to 250 of the most popular 8- and 16-bit microcontrollers (8051, 80C196, 80C186EB/EC, 68HC11, 68HC16, 68332, PIC16C74).

#### The Q-Bit **µLAN** is:

- Fast A high speed (62.5k baud) multidrop master/ slave RS-485 network
- Flexible- Compatible with your microcontrollers
- ► Reliable Robust 16-bit CRC and sequence number error checking
- Efficient Low microcontroller resource requirements (uses your chip's built-in serial port)
- ► Friendly Simple-to-use C and assembly language software libraries, with demonstration programs
- Complete- Includes network software, network monitor, and RS-485 hardware
- Standard The 9-Bit µLAN is an asynchronous adaptation of IEEE 1118



55 Temple Place • Boston, MA 02111-1300 • Ph 617.350.7550 • Fx 617.350.7552 #139



Microcontroller

or PC Master

# SILICON UPDATE

#### **Tom Cantrell**

# Radio Chip



Tom, a long-time hater of computer cords,

reaches into the not-sodistant future to see what's coming to the rescue. His crystal ball shows RF chips unsnaggling the rat's nest under his desk. he micro business seems to go in cycles, with focus shifting between major applications arenas such as control, computation, and communications.

Notwithstanding Apple 11s and S100 boxes, for most of its preteen years, the micro mainly served control applications. It wasn't until the appearance of the IBM PC-almost ten years after the 4004 was introduced-that computing became a major micro market.

Computing has remained king for the last decade or so, and what a Golden Age it's been. The micro has evolved from yesterday's toy to deliver the power of yesterday's mainframe onto your desk or even into your pocket.

Now, computing is entering an era of less revolutionary growth rates. All of the easy and many of the hard problems have been solved. Those truly tough ones that remain-everything from the quest for instruction-level parallelism to readable documentation-won't succumb easily.

Fortunately, just as computing is getting a little ho-hum, communication is stepping to the fore. Nowadays, getting gadgets to talk to each other is all the rage. Of course, sometimes it isn't clear whether meaningful discourse will result, but establishing the connection and seeing what transpires is the only way to find out. When it comes to communication, there's progress on both the wired and wireless fronts. Frankly, I find the latter much more interesting. As I contemplate my own miles of spaghetti-cable inventory, I'll be glad when they dispense with wires altogether.

To get a sense of which way the wireless wind is blowing, let's check out the MicroStamp Engine from Micron Communications (a subsidiary of well-known DRAM supplier Micron Technology). Though specifically targeting the ID-tag niche, a look inside gives a glimpse of what the wireless future might hold.

Before hitting the datasheets, however, let's consider some of the market and technology forces at work.

#### TAG ALONG

RF (radio frequency) ID isn't a new concept, having been around for almost 50 years. Probably the most familiar incarnation is the antishoplifting tag familiar to most shoppers. If the tag isn't removed by the clerk, a gateway positioned at the exit sounds the alarm when the absconder passes it.

Other forms of wireless (e.g., bar codes, IR) and semiwireless (e.g., Dallas Semiconductor Touch Memory) asset-control and -tracking schemes exist. However, they presume a nonhostile user and wouldn't be suitable for security applications. The ability of RF to look inside a pocket, briefcase, or box is a big advantage.

Consider reports that 100,000s of laptops are stolen each year, most from companies and universities. In many situations, at least those where ingress and egress is controlled (i.e., a gateway), an RF-ID tag buried inside might well deter the light-fingered.

Essentially, the tag listens for a query from an interrogator positioned at the gateway and responds with ID info when asked. Typically, range is limited to a few feet or less.

This feature not only reduces power and improves noise immunity, but it also confines activity to the proximity of the gateway. Obviously, the antishoplifting system is more annoying than helpful if it can't discriminate between someone walking near and someone walking out the door. Tag technology is primarily classified as active or passive-a terminology that's a little confusing. Usually, it refers to whether or not the tag requires a power source (i.e., a battery) or derives power from the interrogator's transmission.

It can also refer to whether the return [from tag to interrogator) radio link requires emission by the tag or uses a reflective tech-

۶F BPF Carrier Balanced То Mixer OSC Modulator Demodulator Pseudonoise Balanced Pseudonoise Generator Modulator Generator <sup>r</sup> Carrier ftf 1 RF Carrier A cos W₀ t MMMM Received Signal 4 2 PN Code Code Reference 5  $Pn(t) = \pm 1$ 3 Modulated Carrier Recovered RF 6 

Figure 1 --Here are the basics of a direct-sequence spread-spectrum system [1]. A pseudonoise (PN) code sequence modulates (in this case, biphase) the carrier at the transmitter and recovers if at the receiver. A frequency-hopping system is similar, except the carrier is shifted rather than modulated by the code.

nique. A simple analogy for the latter, known as backscatter modulation, is signaling using a mirror (tag) to reflect the sun (interrogator).

The cheap (\$3) passive tags down at the mall are being joined by a new generation of more powerful units with more intelligence and range. Rather than just a read-only ID number, these units feature larger read/ write memories and, thanks to the FCC release of unlicensed bands, higher frequency operation for better reliability and throughput.

Such units, which Micron calls RICs (Remote Intelligent Communication) extend the RF-ID concept into new applications. For instance, fleet (e.g., bus, taxi, truck, etc.) applications can combine an RIC with GPS and a data logger for pervasive, yet unobtrusive, tracking. When vehicles return to the depot, a complete dump of when and where they've been is left at the gate as they drive through.

Another idea is automated semicustom manufacturing and distribution. Say you phone in an order for a PC with a certain configuration and selection of add-ons. A tag can be stuck on the motherboard to accompany your system down a production line.

At each stage, an interrogator queries the spec and presents any work order to the assembler, whether human or robotic. The tag accompanies your PC into the box, out the door, onto the truck, and off the truck, thereby securing against "shrinkage" and eliminating finger pointing when the inevitable mixup occurs.

#### THE LOW-PRICE SPREAD

Like many technologies we take for granted in daily civilian life, spreadspectrum communications has its genesis in conflict-WWII, the Cold War, and even the space race. We've sure come a long way from a 1947 patent for "Secret Communications" to the average Joe's cordless phone.

I'm certainly no expert on the subject, which fortunately suffers no shortage of those who are. One reference I find both rigorous yet intelligible is Dixon's Spread Spectrum Systems with Commercial Applications [1].

Needless to say, I won't be dissecting the 600-page tome in detail. But, it's worth hitting a few of the high points for those who aren't familiar with the subject.

Actually, many of you probably are but just don't know it. For instance, most computer enthusiasts are familiar with the concept of ECC (Error Correcting Codes), in which extra check bits the reliability, addressability, and security of transmission.

Turns out, there's a lot of similarity with the historically analog spreadspectrum concept. In comm-speak, the difference between the bandwidth available in the channel and that required for data is known as the "process gain." It can be traded off for more robustness and security.

Of course, FM radios are spread spectrum in that the radio frequency (~ 100 MHz) far exceeds the data bandwidth (-1 MHz for CD-quality audio). However, use of the spread-spectrum moniker is usually reserved for systems in which some signal (other than the data) overtly spreads the transmission.

Two of the most popular forms are direct sequence and frequency hopping. They're similar in that both require a code sequence that's known a priori by both transmitter and receiver.

In a frequency-hopping system, the code orders the shifting between differ-

Figure 2—The MicroStamp IC combines a complete 2.5-GHz spreadspectrum radio subsystem with an d-bit micro, RAM, and serial I/O.



## are packed along with the data.

Or, how about the concept of multidrop communications, in which addressing allows multiple units to share a single medium? Or, consider encryption systems that rely on a key to decode data.

Notice that in all cases, extra bandwidth in the channel (beyond that required for data alone) is given away in the interest of boosting em subbands of the entire bandwidth available. This type of system is best for spy-versus-spy stuff since such frequency-agile gear is quite difficult to eavesdrop on or jam.

For less expensive (or paranoid) commercial applications, the directsequence approach of Figure 1 (reproduced from Dixon) is most popular.

A pseudonoise (PN) code sequence modulates the signal at the transmitter, and the receiver looks for the same code. The receiver passes those transmissions that match the local code reference through while spreading everything else across the entire channel bandwidth, allowing the final Intermediate Frequency (IF-the frequency at which the code is clocked) filter to mask unwanted interference.

The PN codes themselves are quite interesting. As the name implies, they exhibit a random noise-like nature that spreads the signal evenly across the bandwidth and stymies surveillance to the degree the code is kept secure.

Of particular note are code sequences derived from feedback-connected shift



Figure 3-h addition to direct antenna connections, the MicroStamp 20-pin SO/C package supports digital transmit and receive ports as well as a bidirectional clock serial port.

registers (an old trick at the core of most random-number generators). The key characteristic uniting two different, but same length, sequences is that the statistical distribution of 1s and 0s and their run lengths is the same, though position in the sequence differs.

The most interesting facet of these sequences is the minimal correlation with their phase-shifted equivalents. Table Ia (also from Dixon) compares a seven-code (i.e., three-stage shifter) sequence with all possible phase shifts of itself by subtracting the number of disagreements (D) from agreements (A) at each bit position.

Notice the clear yay/nay distinction between in- and out-of-phase comparisons. Minimizing such autocorrelation between a code and itself helps to overcome multipath and self-generated interference.

Minimizing cross-correlation between different codes is, of course, important when multiple transmitters and receivers share proximity. Table 1b shows a comparison similar to 1a, except using a different code.

Notice that the results are less clear and might cause false sync or other disruptions. If you want your applications to exploit coding for multidrop addressing, take great care to choose codes with minimal cross-correlation.

#### ON THE AIR

Oops, halfway through my space and haven't even talked about the MicroStamp yet. Hopefully, the background info will help keep the explanation short and sweet.



| <b>a)</b> Shift C | code/Shifted Code  | A-D | b) | Shi ft | Code 1/Shifted Co  | de 2 A-D |
|-------------------|--------------------|-----|----|--------|--------------------|----------|
| 0                 | 1110100<br>1110100 | 7   |    | 0      | 1110100<br>1110010 | 3        |
| 1                 | 1110100<br>0111010 | - 1 |    | 1      | 1110100<br>0111001 | - 1      |
| 2                 | 1110100<br>0011101 | - 1 |    | 2      | 1110100<br>1011100 | 3        |
| 3                 | 1110100<br>1001110 | - 1 |    | 3      | 1110100<br>0101110 | - 1      |
| 4                 | 1110100<br>0100111 | - 1 |    | 4      | 1110100<br>0010111 | - 1      |
| 5                 | 1110100<br>1010011 | 1   |    | 5      | 1110100<br>1001011 | - 5      |
| 6                 | 1110100<br>1101001 | - 1 |    | 6      | 1110100<br>1100101 | 3        |
| 7                 | 1110100<br>1110100 | 7   |    | 7      | 1110100<br>1110010 | 3        |

 Table 1 —For
 reliable code detection, codes should be chosen for low self- and cross-correlation. a-A code sequence exhibits good (low) self-correlation with phase-shifted replicas of itself.
 **b**—Two codes exhibit high cross-correlation, making discrimination more ambiguous.

Figure 2 diagrams the MicroStamp, which includes a complete 2.44175GHz spread-spectrum radio coupled with an 8-bit micro. A portion of the latter's RAM (256 bytes) is intended for application data storage. Ten bytes are designated ID info, using a format that assigns a portion for industry, specialty, and user codes (four, two, and four bytes, respectively).

Together, the radio, micro, and RAM compose a complete RF-ID solution, but the real potential lies in the digital hooks that are also provided. Let's run through the pinout in Figure 3, and you'll see what I mean.

Dispensing with the seven of the chip's 20 pins devoted to power (5, 3.3, and 2.6-3.6-V versions are available), ground, and no connect leaves only 13 to deal with. Of these, three are needed for RF-only applications.

One (RXANT) serves as the receiver antenna, while two others (MBSANT1 and MBSANT2; the MBS stands for Modulated Backscatter) connect to the transmitter antenna.

For short range (10-15') benign applications, a few inches of PC trace work fine (see Figure 4). However, both the transmitter and receiver support external boosters with pins MBSANT3 and RXIN, respectively. MBSANT3 modulates a 1-mA current into a PIN diode, while RXIN connects to a Schottky diode for increased sensitivity.

When the external receiver option is used, the MicroStamp asserts the WAKEUP\* output periodically to turn on the external receiver and listen for interrogation. Complementing that function, the RXEN\* input offers something like earmuffs. When deasserted, it prevents MicroStamp from waking up.

The six remaining pins make the digital connection. DIGTXEN/DIGTX-DATA and DIGRXEN/DIGRXDATA enable transmission or reception (or both) to be routed through pins rather than airwaves. Besides use in one-way applications, these prove a boon to hardware and software debug.

However, employing the DIG pins for application use does demand rather profound software to deal with the details of the communication protocol. (More in a moment.)

If you just want to send a byte or two, take advantage of the DPCLK and DPDATA pins, which implement a bidirectional clock serial (i.e., shift register type) interface. MicroStamp's command set includes commands to read/write the DP port (l-64 bytes per command), along with those to read/ write the ID and RAM.

#### RADIO ROUND TRIP

Let's follow a complete interrogation and response to see what's involved in consumating a wireless connection.

The interrogator issues a command or query with a packet composed of preamble (16–256-ms Os), a 13-bit barker (i.e., start or sync) code, 13-bit data (8 data and 5 ECC bits), followed by a 16-bit packet checksum.

Each bit in the packet is transmitted as one full cycle of a 31-code (i.e., five stage) PN sequence: If it's not PowerDAQ<sup>™</sup> it's not PCI

UEI's new PowerDAQ<sup>™</sup> family of PCI-bus data acquisition cards gives you the latest and most complete implementation of the PCI specification. They include the features that other PCI data acq. manufacturers "forgot":

- Motorola 66 MHz on-board processor supervises%perations
- Bus-mastering data transfer with scatter/ gather DMA
- 1 MHz A/D sample rate
- Continuous, multi-channel streaming to system memory
- Simultaneous analog and digital input and output
- Clean 32-bit drivers for Windows 95 &Windows NT
- DLL library supplied with each board (includes source code)

Call today for your free catalog:



United Electronic Industries

10 Dexter Ave, Watertown, MA 02172

Tel: (617) 924-l 155 Fax: (617) 924-1441

internet: www.ueidaq.com E-mail: sales@ueidaq.com



Figure 4—For an RF-only (i.e., no *DIO*) application, only a *few pins* (*i.e.*, *RXANT and MBSANT1 and 2*) are needed. For *most* applications, *PCB* antennas are adequate.

#### $001101001000010 \ 1011 \ 101100011111$

The interrogator simply on/off modulates the 2.44-GHz carrier using the PN sequence for 1 or the inverted PN sequence for 0. The modulation clock (often referred to as the code or "chip" rate] is 9.5375 MHz.

Thus, the baseband (i.e., your) data rate, considering data ECC (but not other packet overhead like the preamble and checksum) is about 190 kbps:

$$\frac{9.5375 \text{MHz}}{31} \times \frac{8}{13}$$

That's plenty fast for most applications and certainly much faster than low-frequency (i.e., garage-door-opener class) units.

Figure 5 happens to show the power-consumption profile of the MicroStamp, but it serves equally well to walk through operations at the receiving end.

Sometimes I wish I was a chip-at least one like this that spends most of its time sleeping, consuming a few microamps. Periodically (programmable as **16, 64,** or **256** ms), the Micro-Stamp wakes itself up (750  $\mu$ A) and turns the receiver on (**1.8** mA) to listen for a query [preamble) from the interro-

gator. If the preamble is detected, the chip goes to full power (5 mA) to receive the message.

After a short delay ( $t_{PROC} = 3$  ms max., 3.8 mA), the chip switches to return link mode (4.2 mA). The back-scatter technique relies on the interrogator sending a raw (2.44175 GHz) carrier.

The MicroStamp biphase modulates the response onto a 596.1-kHz subcarrier that opens and closes the transmit antenna switch (MBSANT1 and MBSANT2).

Connected to a simple dipole (i.e., equal wires connected to each pin), this setup effectively switches between the electrical equivalent of a single half-wavelength antenna that reflects much of the interrogator's transmission or two quarter-wavelength antennas which don't.

A couple other features just about wrap it up. First, you may be wondering how multiple units in proximity manage with just a single PN code.

As it happens, arbitration is handled at higher layers of the protocol. To that end, a pseudorandom number generator (more shift registers) is included to assign node IDs, schedule retries, and otherwise resolve or avoid collisions.

Finally, the MicroStamp includes a low-battery detector that returns the status with each query. The interrogator can issue an alert when it detects a tag whose battery is running low.

#### TUNE IN

Micron offers a complete line of tools and training, though most of it is rather pricey. For example, an entrylevel simulator that enables exercising a MicroStamp connected via cable to a PC runs \$975.



Figure 5-The MicroStamp wakes up periodically to check for queries from an interrogator. It responds by reflecting a modulation of the interrogators carrier back to if. A full-blown development system costs \$5525, while the all-important interrogator is \$5200. The MicroStamps themselves start at under \$50 in singles, dropping to \$10 in high volume (i.e., 10 million).

If there are any clouds on the horizon, they revolve around standards-or more accurately, contention for control between a number of vested interests. Micron points out that the Micro-Stamp, thanks to on-chip MCU, can programmably adapt as the standards situation evolves.

Specifically, they mention work in progress under the auspices of ANSI X3T6. Notably, that proposal also relies on 2.45 GHz, a frequency that seems to be emerging as a worldwide favorite.

Connecting radios and computers isn't a new idea. Search old hacker archives, and you're likely to find programs for Altairs or **PDP-1** 1s that can play a little ditty on a nearby radio.

Clearly, technology like the Micro-Stamp is going to enable much more meaningful communication, without all the wires that bind.

Tom Cantrell has been working on chip, board, and systems design and marketing in Silicon Valley for more than ten years. You may reach him by E-mail at tom.cantrell@circuitcellar. corn, by telephone at (510) 657-0264, or by fax at (510) 657-5441.

#### REFERENCE

[1] R.C. Dixon, Spread Spectrum Systems with Commercial Applications, Wiley & Sons, New York, NY, 1994.

#### SOURCE

MicroStamp Micron Communications, Inc. 3 176 S. Denver Way Boise, ID 83707-0006 (208) 333-7481 Fax: (208) 333-7307 www.microncommunications.com

#### IRS

422 Very Useful 423 Moderately Useful 424 Not Useful

# PRIORITY INTERRUPT

## I'm the Reader



nless you have a particular axe to grind, an endangered species to save, or piles of money to burn, becoming a publisher wouldn't be among an engineers normal career objectives on the way up the corporate ladder. Trading a career at the edge of electronic discovery for a job that's a figure-juggling balance of editorial expenditure, advertising receipts, and printing-press physics can leave a lot to be desired. Fortunately, I'm the Editorial Director/Publisher, so I get to delegate a bunch of that stuff and select from the rest.

Anyone looking at *INK* for the first time these days hopefully comes away with the impression that it's a combination of superbly crafted editorial, careful targeting, and the results of painstakingly studied analyses. I say this rather tongue-in-cheek. In actuality, *INK* was started because I really did have an axe to grind, an endangered species to save (us!), and I didn't care about the money.

Of course, while a cause drives the spirit, only hard cash runs the press. Fortunately, I've had good people and good advice over the years, and we've prospered together. The business of publishing is still nothing more than a numbers game, but I can tolerate the periodic discomfort of making financial decisions because the other half of the job still feels like we're supporting a cause and a direction that shouldn't be abandoned. The focus title of *INK's* first issue was "inside the Box Still Counts." It was my way of saying that for all the **off-the**-shelf computer solutions available, somewhere back in the lab, there had to be an engineer who fabricated that solution. It's not enough that everyone learns how to build brick houses. Somewhere, there has to be somebody who knows how to make bricks.

By coincidence or subconscious design (I can't really say which), whatever I've been interested in technically has also interested a great deal of other solution-oriented engineers. Ken shares the same intuition. Selecting the projects and articles we publish is simply a matter of deciding whether we like them ourselves, We both know that there will be lots more people interested in building houses, but we still enjoy making the bricks.

The major consequence of using yourself as the sole data point in an analytical conclusion is that if you count it wrong, it's 100% wrong! These days, age has tempered my eagerness to join causes, but it hasn't resulted in dementia yet. The shear momentum of an established magazine and the fiscal responsibilities it implies does occasionally invite challenge to an editorial direction based solely on intuition, however.

To reaffirm the validity and consequence of gut feelings, last month, we sent a detailed questionnaire to a randomly selected group of *INK* subscribers. While the results are still being tabulated, I'm happy to say that it still appears the vast majority of *INK* readers have interests similar to yours truly. Most of you like *INK* just the way it is. You still want hardware projects, devour anything and everything on analog or digital interfacing, and think sensors, signal processing, and robotics are worthy topics. The prevailing conclusion of the survey is that your primary interest is application, application, and application. I guess everyone agrees with our subtitle.

Most frequently, you are a technical specialist or engineer working primarily on product design or manufacturing. Like me, you have a pile of trade magazines on the corner of your desk, and after you've completely read *INK*, you keep it for reference. If you have time to read the trades, after *INK*, you most frequently read *EDN,EE* Times, and Electronic Design. 95% of us still purchase things by mail order, but these days, we're more than twice as likely to go check out a company's Web site rather than call directly for more information. Best of all, virtually everyone thinks the price of an *INK* subscription is just right!

I feel confident that our cause and spirit is reiterated. Surveys are expensive and not something you do on a whim. Most gratifying is that it tells us that we don't have to make any major course corrections and that gut instinct can be right.

Of course, instinct is hard to sell to ad reps and advertisers. They like to see scientific surveys. OK, no problem. Got questions about our audience demographics? Send 'em to me. Apparently, I'm well-qualified to fill out the survey.

Slave

steve.ciarcia@circuitcellar.com