KEMBAR78
The Home Computer Advanced Course | PDF | Disk Storage | Computer Data Storage
100% found this document useful (1 vote)
1K views24 pages

The Home Computer Advanced Course

Vintage Computer Magazine, 1984

Uploaded by

cstroeh
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
100% found this document useful (1 vote)
1K views24 pages

The Home Computer Advanced Course

Vintage Computer Magazine, 1984

Uploaded by

cstroeh
Copyright
© Attribution Non-Commercial (BY-NC)
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 24

I LII

'I'll..

Pill I1111 11_1u

BIS Publication

CONTENTS
APPLICATION

Next Week
We continue our BASIC conversion course for Spectrum users, concentrating on functions and control structures. Widely acclaimed as the t of the microcomputer ed wordprocessing kages, Micropro's rdstai can turnany CP/M ed machine into a very Werful text processor. mongst the educational s of computers, one lication is particularly active to the home user mination revision jtware, We look at this fastexpanding field.

FIT FOR THE FUTURE An overview of the increasing relevance of computers to our everyday lives
HARDWARE

BEST OPTION An introduction to disk drives, and how they work COMMODORE 64 We examine this popular home computer and look at its portable counterpart, the SX-64
SOFTWARE

4 10
0

ATTACKED BY ANTS A maze-chase game universally acclaimed


COMPUTER SCIENCE

6 8

THE ALGEBRA OF DECISION MAKING The first step towards understanding program design
JARGON

FROM ACCESS TO ADA The first part of a glossary of computing's terms


PROGRAMMING PROJECTS

13

THE SPECTRUM OF ZX BASIC A look at the characteristics of this BASIC dialect


MACHINE CODE

14

INTRODUCING FIRST CONCEPTS Commencing a course of instruction in this lowest common denominator of computer programming
PROFILE

16
C

BILL GATES SETTING THE STANDARD An insight into one of the world's most prolific suppliers of software

20

Overseas rea _ . - this special offer applies to readers in the U.K., Eire and Aust ralia only

cnvrR PHDTOGRAPH v BY IAN McKINNELL I RINITRON COURTESY OF SON SUPERROBOT 28 COURTES` OF HARRODS

; Editor,onatharHilton ConsulhmtEOIOOaGarethJeffeson. Richard Pa,vson. ArtDkrtdorDaviiWhelan, Deputy EdltorAoger Ord; ProductinEdltorCatherineCardwelC SWterribleBrianMorris: PlctveEdrtorClaudia2en: Deaipnee Hazel 6enningttn: Sub Editors Robert'ickerin3, Kern Pans' Art Assstent La Dixon Editorial Assistant Stepnen Malone: Rpearcfae Melanie Dave Contributors Lisa Kelly, Steven Colwit. Marti' Hnprn_- Groep AR DheCEm P`r y u Neville: Wnadng Director Stephen England: Published by Drills Publishing Ltd: (diterfal Director Roan Innes: Project DereNpmsnt eter Bmokesmth Executive Editor This Cooper: Production Co-ordlnatbr Ear Paton: Circulation dreetutDavidBreed MarkaBrgDMdv Michael Joyce, OesignedandxoducedbyBurch Parlvci Ui;Edlbor Office85Charlotte Street. London W1.91954by0rh11114 h" LutlypsnelhyUnNene;ReproductionbyMeelHsMorgan Ltd; Printed In Great &Naln by Artisan Preu Ltd, Lafceeter HOW COMPUTER ADVANCED COURSE - Pr:ce

UK 80P IR 100 kUS 51.35 NZ 92.25 SA R1.95 SINGAPORE S4.50 USA and CANADA SIRS Now to ohtriin your eopis of HOME COMPUTER ADVANCED COURSE - Copes are obtainable by placing a re)ular order at your newsagent, or by taking out a subscription. SLbscripten rates: for six nonths (26 issues) 23.80. for one year (52 sues) 4760 Send your order and remittance to Punch Subscription Services, Watling Street, Bletchley, Millon Key n es, Bucks MK2 28W, being surf to state the number of the first issue required. Beer fimbern UK and Ebe - Back numbers are obtainable from your newsagent or from HOME COMPUTER ADVANCED COURSE. Back numbers, Orbis Prblishine Limited, 20122 RedforJbury, LONDON WC2N 4BT at :over price. AUSTRALIA: Back numbers are obtainable from HOME COMPUTER ADVANCED COURSE. Back numbers, Gorgon & Gotch (Ass) Ltd, 14 William Street, PO Box 7676 Melbourne, Vic3001. SOUTH AFRICA. NEW ZEALAND, EUROPE & MALTA Back r,mbers are ava,.able at cover prce from your newsagent. In case of difficulty write to the address in your country given for binders. South African readers should add sales tax NowtDobtain Indent forHOM(CCAMPUrERAOYANCED CWRSE- UK and Eire: Details o' how to obtain your binders (and of our special offer) are in issue 5. EUROPE: Yrritewith remittance of 5.00 per binder(incl. p6p) payable to Orbis Publishing Lim zed, 20/22 Bedf ordbury, LONDOV WC2N 46T. MALTA: Birders an obtainable thrcugh your local newsagent price 3.95. In case of difficult/ write to HOME COMPUTER ADVANCED COURSE BINDERS, MCI er (Malta) Ltd. M.A. Vassalli Street, Valletta, Malta. AUSTRALIA: For details of how to obtain your binders see inserts in early ssues or write to HOME COMPLTER ADVANCED COURSE BINDERS, First Post Pry Ltd. 03 Chandos Street, Sr. Leonards, NSW 2065. The birders supplied are those illustrated in the magaz ne. NEWZEAIAND: Binders are available through your local newsagent or from HOME COMPUTER ADVAN JED COURSE BINDERS, Gordon & Gotch (NZ) Ltd, PO Box 1595. Wellington. SOUTF AFRICA: Binders are available through any brarch of Central Newsagency. In case of diTiculty write to HOME COMPUTER ADVANCED COURSE BINDERS. Intemag, PO Box 57394, Springfieli 2137. Nob - 3inders and bars numbers are obtainable subject to availability of stocks. Whilst every attempt is made to veep theprice of the issus and b nders constant, the publishers reserve tie right b increase the stated prices at anytime when circumstances Jictate. Binders depictec in thispublicatbe arettose produced fcrtheUKmarketonly and may not necessarily be dentica to binders produced forsale outside theUK. Binders and issues maybe subjectto import duty and/or local taxes, whch a r e rot included in the above prices unless stated.

INTRODUCTION /APPLICATION

FIT FOR THE FUTURE


Most people over school age find learning a new subject from basic principles a daunting prospect, especially when the entire concept of that subject bears little relation to anything in their present experience. So how does the newcomer to the field of computing come to grips with the complexities of the subject?
It's difficult enough for the computer professionals the operators, the programmers and systems analysts to keep up with all the latest developments in computing, but at least these people can expect support from their employers and the suppliers of the equipment with which they work. Where do the amateurs and the hobbyists who must educate themselves in their own time and at their own cost, turn for unbiased advice? What to do first? Go out and buy an inexpensive computer? There are so many, it's difficult to decide on a particular model without reliable advice. And having taken the plunge, what next? Perhaps the machine in question offers more than one programming language. Which one is most applicable to the user's needs? Which software packages offer the best value for money? Cartridges or programs on tape? Should the user buy a disk drive? Or will a cassette tape drive be sufficient? Do you really need a printer now, or should you wait until more refined printers come down in price? If you have children, how do you cope with their constant desire to play game after game, if you feel that the point of the investment was to foster computer literacy and help them with their school work? The revolutionary advance of computer technology has been so fast and its encroachment into our everyday environment home, office, factory and car so comprehensive that many of us endow it with a mystique. It is, after all, not
Advance And Be Recognised In the course of less than a decace, the computer has become an ntegral part of the fabric of our society and every year changes and developments become more and more extensive. Keeping abreast of the situation demands a considerable effort, but for the newcomer the task is even more caunting. A well pacec, compreheisive home studycourss is a great help

THE HOME COMPUTER ADVANCED COURSE 1

APPLICATION/INTRODUCTION
c t::..c

i
i i_ii?itiiii33ts... :!!!}aiffl._. s. s s {i..:.. itimii11 s !c Bf? u3u {i ^ i ^iiiR i!!lli? p ^1 q; i ^ . l^l Bl:: c iil.tl
m}

; t7.::i:f'.i mii

s tiii

!B Bl
i=tt mi

S2
i IE l '

9?:sue 3idii

! iiei i?iit a i tdiil6 l.., :s:lu mjl^lifSi3I i


= ;^ 9ili 19i11111ME-

!!!!^ =

iuli2 t

aiii'`..1 tI idii lBit_}Biti t ; ^ ^p^g ti is !l3E '3illilii4^:ii^ g ^ F

:.ii:

wi{iB di!iiiiiil:EiiiiiI ett t l^

ill

^,ifiiilBB^1^Ili[!i3s:i:tmm:l:l^ ^ " ' t IdiidB' " 'd:i ii "r:"3fid StmL'1^127

3dts

iiiitE

1 ri
1 1 11 1
1 1 1

^ S ii:R r 1
ii ::

iI

!i}-

i .a te I _Iii ?'s M y lllli ill ^^ E!?i^ !

LY.^^ l i { ITZE-'"'1l1l ._...:if

!fslm !!!t ! m"t itst w ii

ll!! lfi

^ t} S

1
1 1 1

t
1

t 11
1

iii

"

.1 ,
11

t
1

.. ^^^^ i'"W^'''i}jalt'."' lli}2tP.6: ^^l9


;^p^ ;t^

Iii Gi

ilt

ii}tFiiii$il;i.' ' ^ 3l:?!:t ii3Eli1}


^i ,

111

1 . 1'
1

.H;

i'li= !!E tlil


i lI itli Y 3i

^j3

1
1 .1 1

111

1
^^^^t A.: ' 11!l Fiiiilt {t llf ili
::s m

1 11
p p
^

il'.i

...

3IilFl

ai:iidiR

i}lib

Ili m::'::'
i t:

Illlit l=.1
Jpf l!l^Ilt 2tl! m

R i

i
i:it6ffi -IS

iii i
I 6f tlel ain

U^^^I'' .. g :^{^ 8e lll3


!1?II

tua
1 1

FF
.1 . 1

ii 38HiiiBB 3:311dli{ _ i2=113illtldlliu ii^::satHll!!' B


t,

g ti gE333....... ^,} is = = s mill'1:1111 R=' ^ ^ iii ^ F^ i6:dttt


I
3PIi .m= 111'12;'

^q ^ a

11

i 1l^ :=3iii i}}3 ^s ii slrsxIIU'iaiii3i!l ii IliE^i !sinliu ^1^9.... m:ir.'iH !!^! S um:i S i i ^ ^p iil iiiiii tt=C il3 l I1?I... H llII I lei'3! : lf i iiici ^ !! i13t { ru: {g ^ H N it. !?B iS {{{^ l l! } I ;^lFflili3_i? tf:utetay I 'Mill!!9M! fl !E^ -p :.ns i IU! I g i f ^ II 1^3 ^^ i^^l: tii it { ` I iii ^^i^ !!li ;2 d ^ dii IPI I^iFi m
t t t ^ j m ;

^g!rr u

?p

13!,Ei:
:i.:: ^}

I =3!

^,^^ j p f } { j : BB!! ^ ?t fj i l ? ? !!^

^^'B i ^ ^^:^ 1 '

m:

1 .1 1

1
t 1

1L1
:1

"'
1 11

'

, 1

iiiii :il ' vii E!^3 t f I^^^ ^ ':" ^7^[Iti ': : :: t!31 S S3 ^7^ 1St i 1 I 3 & ! I ^ ^ii! ^Ctit^ i lC F F^ ^^6 l i i: '3 d311lilitfl!# :::!s i. ::msuur^ !'3B3iiiiif lSSt fd!!!!!id 3!!l! l 39!!i!d 31l^lfiiii3ie:. sttsii! lEti si^ "ii^tlf8Ei3^li^!l :sH ! 33!?i ^ ! 3i3iiii3HB^: i ' usmr. ! mr. t iffis ^ s iai 1 ll ll.:i i: ! :i(^A E { iB i! !t Q u I !!^j { ^ [ dii{ tssttrs::its ;^{^ ^ ,i ! 73 t,! 33 t {i ' e..:.i11BB. ^ i iHii iiI ^ i sr p^ ^ 11l12Km g ^l 3 i i .Ii ^:.'t{:^ l ly._.....::^ ^t9 t p ^ ''' 3 3 1{ m213ELC l i :iCiL ^ .^ !!!l3} ^l^l^lt { L:!!^}flptiC2Si! ml F t^ E--- -----}q t ::::? S^t^ i } 3 stlQ msy^ty{{H ' ' i^ jii!!; t i :,:nsns is 89ii as Hilii^ ^liii ^^1!!335id i^l^i [ss?333lE ^ iii^'^ ^^111 ? {'' ': iil Hldi ^^ ^3ii39i 6i ii^f^^E llll# .nme,m:::nmr ,sn nmal,uunii ' 1^5 `, g }li { }^^^^ ; 1 ttttmtt; } i ^3^i3 ff{ ssds dil li :5 }iidE& III ^ 3i;B dddi3i3^^: Ei I !'l I ::. iii 119111 II I Iii I l!i I : J i 19 is' =s II} U i r i ' ^ ^ u. es;.li ^i 84: ti 1 ^I fi st" '' I 1^^^'111 ORE ^f^iih i dpdidddi 0 nsmat:um I i s 1 11 t:u 1' ft ItttQ}i t 1 1 11 s i^ l.s lllils ;" ^^^i 1': M Ili gniiiiii lIl t MIi 111 ip ^i c{Brtia i ^}^} 1 11 11 1 1. 1 1 1 : ':3: ^^^ i lilt "g3 s }u^a} 1333 I ! lH i iil:} J
^} y } ;^y u.}

ri=.d

:: dii! ^^;;; ^l { ll ^{{{:?'Wl^ i j t{ 1 Rg3 E f c^ d!d- if f ^^^ :: : is33l^^!ltila t333l13i:f ilEii :: tL 13g utt:::a ^3t:33ii3ii# lE'sBEE ?3?33ii 1 It }I. I iii6 =i ^ i ikff .;E E!! iiiE1 11i( it;: t:s
l'i.{

'

2119tItttlttttmL212{^::: EHISZ7f71

i} m

tf..

did.' _} 'i } !!! 'ta Iii mii isiiiillllii s n

i l sii

l::,

1/

t t: twii i; i 11W31911iHHal t ^ssuttttl^^^ 1^1{l^ ^tllE er ^ ^ ' 3 13 'iiilFiE33331:: t ^^^^^H^ t i:iBBBiiP 1 tl!i !l l,"::l..; 6 igt'F{ui. mtt,ai i3fsl R1I ? . I1i11113 :: :. ifii .. l^ .. ^ :1" i itt ^^ il ^lll^ ! f ^ IH Hi ` !1 ^ iE?i^3::: ?? i^iili^ lii?^: liiiiil ^ 'mac : 's . 11t1f1 Pi^ :iiiit lilt.'i .lBlBl iii !i}! :!!.t!!!!i!BdIF f ^^ ^ 1 it Ri:l:=1 i i00 = III :^:{ mm ^6}s3iiii!!lfHiil^^ ::::: i II t sm III { : ;p^ : 1111 ^ ^g {F m j .::i:::. hi I 1 It1 11118: 17 i u {!dllidl 11 Zr iit t i t^3^l 1:: ss ^ lit i! e^i!!Ni! Bill :. I I! l^s 41 ^^tl:::m:3Sma II ^1siIlifiii?:I?" 3aIId n::::g { ^ ?t ^. i i " pn tsm:::t:m }3 i ^g yt} :am s 3 ^g^g I;:=ii.N } o{p 3 's y' lif1 8::i:t s!!::le3i!!!F^!!!l :li!!1!!!!!!! a ^diiil. ^t: c ;l^?l^E ; ? li t! :::: r^i::t} ^i i 3^^ p l6 pt { F&i=tiliI ^ ; ` 3f ^ q ! ii^! p g L^ 3!331 t'tt i3 MIN E 3!::::^=s}li'tll [s ^l ss I I I III ::: t liiid^ l$ t 111 iddiii tltm=ie?i !li1^p ^ 9341l1l2 Ieili R }}{ ?tS}L"":II 7 ?l :IiiEi :I:I:1 i ^E::::: 3?iB3 n:i.! i II t i''5 }}^ t j ' iiE: ii Ri ::iE::d:.._. r 1 : E p,^4lIl ii^ ^^g 1 1 1 BIBQ :r c:: ^^^ .I "7:iQ ^l^^^^'^SIBwu:^ii !1111 i t 1 i^u sa'B ^x II i ' i l#'t'i ii 1 fi}i l.1 03^ ^ E^ is f ^ ^` l ; HI H!^Eit I I i { ,. !"99 I ildl 1 lisII ' l}t f{ 1 ^lli#i iilF I 1 1 ii ^^:::=. = z g l !fl Illlli i i I, E{

E sCui3III]H * iu HN p}t iii :;. t ^^l}}} ' ti ?

^Illlli^l.l.s::w_s3'iliiifl S c !! :i:: IBI!i mIiit. ::: #^i ^ it ti: 11:11 i Iid 4': ' is
t

,,,

i il1it:

i}iiifiQi

g^

;IllH100

}}lt:t }?

111iKm

t,

^!gii3if ,1 ^N !^ l

} ^iiit ^ j131llHI 1 . ! ^^ q I I i ! hI l! tilj j Bi ^l^iElHi } . = iL t ^.d P^, `! V z^ s tS^ t^, l ri ddd f 4[E^ i i !!!!!lt:: ? Bi ! li3i * ..' NIl^llai i,qr 3I ^iliE .. !! W3^^ti i iilif ^ ^! i } p ^t ^g }

f! ^= ae -fi c 1'!1: 00 s:
I }^;1

^{^{

i iiw"

SfS FE

{ ^g {

!!1lIEi$iiii^E u ..._. ...{


{:in:

^$^]

t ttiiiim7

!!!!!

.: '

ii!$E
i

1 1

j add,

H !:3 . :

1
1 .1
' '

3ii!1 :;:i^i

'

8^^ . ' il i

X 4

5!"

i ^ 1I

tj

1 1

ai' t sH :.: iii^fit^


.1
,

iilHllllll

1 1

Iii

li{i FMInt R i E

ri `f z m::'

iid ! i :tttNNi.. it rsl"ii HE 0 9i3i c.t= t { d!l...!!B

'uI IR ItllNNttl9 s!!lIIfas^d :, ti It 131;: ; ^^ !: !B:"?::: i^:u ^ ! B ieff E t

ttt p! ,^^:{

l^lli ^^^ ?3^i


'II

?i

::^^^^

Bii llfl S {E ^ll }l ^g t 1IlI^ III Ii 33^^1!!liii^-t Vii}ii i :t': t: ::'.^ T?iEri`^!,t, :, 7i^^iiFii:ti ^:i$: g U 8lild q^ ii g ^3 t !FF^ ^ sit.::r{.'i ^ :!!!i ,.:Ir.:iitlsi^8lN#f^^31Ei^,dii3?idf611 ^^l^Eiti': .:u it i : , a t ^ O R ^f 1, , ai!I 1 I. Ii.
^ y ^ p ^' 111 f

_ . ^_. i r I ^l n (^ (^
.11 i

}pp{c^! 1 } ! 1 ^si.. I^l 1 3 I i iU t:;:3 i!,!:1kEiis I ttm t s liE i t.: it qtq^t^t}t i HH $i :dl:dllt^
:

8,

r^imo ra s ii
1 4i^a
L

i!d 1:!!l^L:t,n:rsi :I:::iai 11III!II III ^in^o utr: stt mini csffFF411 i illd i:iiii ^3ilRi'3sititt[$!i!

!B}iEdiiild idi =1111Il il ti

fj :

:n: :

JI lIt

I u u

3= c.

1 i ivy
!ilium'

t . to ' .:

ii!

8E ^ s ll,

7mtii: ::::mFAiii

}?a33!}iii86 31iif

^q: t ' iiii33 ^

^I

lIBlEe lilf I : t !mm!sa:::

II

^^^ t 11 s .. d: :: s

.^`

3lBll

ii'

I IRISii:i{ul

^u U ^

?3f

di


I i

'1r

tll --

-^. . ,. , ;.

',.

--.

easy to come to terms with a `motive force' that is invisible in action, unlike the satisfying spectacle of, say, a car engine or a hydraulic pump in operation. True, more and more people are being trained to operate computers an d computer terminals. But there is a huge difference between training and education. Training implies lea rning a task by rote. Education allows a leap beyond the bounds of the mere task at hand into a broad understanding of how the systems work, their potential an d limitations. To many people working in the computer industry an d in schools an d colleges the answer seems to be a planned course of computer education presented in such a way as to be
2 THE HOME COMPUTER ADVANCED COURSE

understandable to all from the outset. Individual instruction manuals for specific machines cannot provide a balanced overview that relates one type of computer to another. Nor will they point out the pitfalls inherent in the multiplicity of machines available, or advise you fully on how to make the most of your purchase. After all, what sort of manufacturer is going to give free publicity to his rivals' products? y Following a properl planned home study course, perhaps backed up by a weekly session at an Adult Evening Institute (many of which offer introducto ry courses in computing and computer programming), is a convenient an d inexpensive way to a sound education in computing. The object of such a course should not simply

I NTRODUCTION/APPLICATT

be to learn how to program and operate a home computer, but to gain a wider appreciation of how computers are used in everyday life. As well as providing instruction in programming and basic systems analysis, it should offer an overview of all the computers in use at the moment rather than concentrate on the machine one happens to be using. It should introduce the peripherals and extras available for all of them, with an explanation of their operating principles. To place the computer in context, one must examine in depth the tasks to which it is now applied and the software that makes those applications possible. Finally, the course should include elements of formal logic, number systems and something of the history of computing and computers. In short, a home study course should cover all the topics that would be dealt with in a conventional course in computer studies. In THE HOME. COMPUTER ADVANCED COURSE we have set out to provide the material for just such a course. Building on the average home computer user's knowledge of BASIC and some machine-specific experience of computer graphics and sound synthesis, we aim to take you through the other high-level languages found in microcomputers PASCAL, FORTh, woo and c, for example and to provide grounding in machine code programming, the key that unlocks the power of the microprocessor. A knowledge of machine code enables us to examine the ways in which the higher level languages are defined. Then, when we have studied the way in which compilers and interpreters work, we can amalgamate these two branches of knowledge to start defining our own language and writing a compiler for it. We won't neglect BASIC, however. We'll look at the refinements of the language and work through projects that will result in the generation of useful applications software and screen-based and Adventure games. In addition to the internal functions of the computer, well explore file-handling methods, both on tape and on floppy disk, using the experience gained in defining data structures and hierarchies within the computer's internal memory. In this way we can expand the capacity of even the smallest home computer into a serious information processing system. Bearing in mind that it's not enough to study a subject in isolation, we will consider in depth the wide choice of software packages now available spreadsheets, word processors, database managers and the like with a view both to understanding their operation and methods and to learning more about professional programming techniques, in order to include these in our own programming. Some attention will be given to basic electronics, examining the function and design of individual components and the ways in which they are combined to make up computers and their peripherals. We'll look at the machines

themselves, too: the popular microcomputers, both for home and business use, and their peripherals, examining their price and specification, and assessing their impact on computing in general. We won't neglect the human side of the computer industry, however. The people who design the software and build the machines, and even the computer users who have made a contribution to the field, will have space in the course devoted to them. If you are interested in learning about computers with a view to increasing your employment opportunities, then a home study course can be an effective replacement for the first module or two of a formal course in computer studies, Because it allows the student to proceed at his or her own pace, it is of equal value to the fast learner, as well as those who perhaps need a little more time to come to grips with what is, after all, a complex subject. Finally, if you simply wish to be better informed about a technology that is set to change society in the course of your lifetime, then THE HOME COMPUTER ADVANCED COURSE offers a comprehensive guide. In addition to the fundamentals of computer study, we shall be examining the impact of the new technology on society at large. How will the advent of computers in our everyday lives change the way people relate to each other? What political changes will result from an `information explosion' made possible by the low-cost microprocessor? It is difficult to obtain reasonable answers to these questions. Newspaper articles and television programmes tend to trivialise them, many computer publications seem to make them more complicated than they need be. THE HOME COMPUTER ADVANCED COURSE sets out to give you access to the essential information to answer them for yourself.

A Leap Forward

Announced to the world's press at the begiining of 1984, but not scheduled for delivery until well into the spring, Sinclair's Quantum Leap broke that company's long assoc ation with the Z80 microprocessor. Fittel instead with a version of Motorola's 32 bi: 68000, it has 128 <bytes of RAM (w th a further 512 Kbytes ava fable), and two OL Microdrives built -in. Also abandoned is Sinclair's idiosyncratic single-key-entry BASIC

THE HOME COMPUTER ADVANCED COURSE13

HARDWARE,USING DISKS

BEST OPTION
Until recently, floppy disk drives and socalled stringy floppies were beyond the budget of most home users, but advances in disk technology have reduced the relative cost of purchase, while the advent of the Sinclair Microdrive has bridged the gap. In view of the power of such devices it is worth looking at them in some detail.
Remember not to put floppy disks close to anything that contains a magnet. Even something as seemingly innocuous as the telephone contaims electromagnets (they are used to ring the belt), and a domestic hi -fi speaker has very powerful ones indeed /

Similarly, cartridges are available for some computers containing low-power CMOS (Complementary Metal Oxide Semiconductor) RAM chips that retain stored information via a battery contained within the cartridge. The main argument against EEPROM and CMOS RAM storage is that they are expensive collecting a modest library of such cartridges would cost at least as much as an appropriate floppy disk drive.

Microcomputers are highly versatile tools for manipulating data. However, data manipulation is of little use without a means of storing information when a particular set of data is not required for the moment or when the computer is switched off. This can be achieved in a number of ways. Anyone aware of the real potential of home computing will have acknowledged the limitations of the ROM cartridge and ordinary cassette tape as methods of permanent storage and will wish to investigate the more sophisticated facilities of magnetic disks. But before discussing the merits of disks we will consider the alternative systems.

CASSETTE TAPE

BBC Disk Drive Before d sk drives of this type can be used with the BBC Model B, the DOS (Disk Operating System) ROM must be installed in the machine itself. 'I ntelligent' disk drives, on the other hand, come equipped with a DOS chip already on-board

Originally provided because disk drives were very expensive, cassette tapes are still by far the most popular storage media, mainly because they are cheap, freely available and portable audio cassette players and tape cassettes are familiar to most people. Usually any cassette player of reasonable quality will suffice, although some manufacturers notably Commodore and Atari only allow you to use their own specially designed units. Programs and data are stored in binary form as sequential files via the cassette unit's normal record facility, using different tones to represent Os and is. Normally, identified information such as the file name (and possibly the internal memory address from which the file is copied) is recorded first, followed by the file itself, one bit at a time in one-byte blocks that are further formatted into 256-byte segments. Many computers incorporate an error-checking facility in each segment known as a `checksum', which can be compared with calculations made within the computer during verification to ensure that there have been no recording errors. Typical commands are SAVE to record files and LOAD to play back and retrieve them, Some systems provide additional cassette commands for various special functions, including a facility to read a tape and produce a catalogue of the file names stored, and command formats for storing and retrieving different types of data. The low cost and easily understood command CARTRIDGE format of tape cassette storage is offset by a This method of storage is of little use to the programmer. Most cartridges contain a type of number of major inconveniences: 1.In the majority of cases the user is required to PROM (Programmable Read Only Memory) that provides only a means of inputting data to the operate the cassette unit controls manually for computer, usually in the form of games written in storage and retrieval and this often demands complex and lengthy machine code, or extra careful timing of button pressing and accurate facilities such as extensions to BASIC. It is possible, volume setting. 2. As information is stored sequentially, however, for cartridges to contain Electrically Erasable PROMS (EEPROMs) that can be retrieval of a specific file (except in the case of the written to and read from in a similar manner to software-controlled Hobbit cassette recorder and internal RAM but which are `non-volatile' in that the Epson HX-20's built-in micro cassette) the information is retained when they are removed involves either careful monitoring of an accurate from the computer or the computer is switched off. tape counter (if one is supplied!) to enable fast

4 THE HOME COMPUTER ADVANCED COURSE

forward/rewind to a point just before the desired file, or a search by the computer for the file name from the beginning of the tape. Sequential storage also means that it is impossible to store data efficiently that needs to be read in small sections from any point in a file without processing the whole file. The type of storage that can achieve this is known as `random access' and is necessary for any effective database filing system such as address listings or stock control entries. 3. The above, in conjunction with the small number of bits that are stored/retrieved per second using cassette storage typically between 300 and 1,200 bits means that a cassette tape system is excruciatingly slow in operation. Quite small programs of, say, five Kbytes could take between one and three minutes to load or save. This also means that it is inconvenient to make back-up copies of programs, although this is highly recommended. 4. Even when it has been recorded correctly in the first instance, data can be corrupted after an unpredictable number of replays, owing to wear by the tape head. 5. Because the characteristics of cassette players can vary from manufacturer to manufacturer, data recorded on one model may not play back on another. In addition, cassette tape is frequently damaged by the crude tape transport systems of many portable cassette units and breaks easily.

The layout of the information in tracks and sectors and the accurate positioning of the read/ write head enables the DOS to offer random access filing. Data can be recorded and extracted in chunks as small as a byte at a time, if required. In broad terms, differences between disk drives are confined to the amount of data that can be stored typically between 100 and 400 Kbytes; the speed at which data can be transferred; and the means by which the user can control storage. and retrieval using DOS.

In A Spin Floppy diskettes are composed of Myla , or a similar stretch aid tear resistart plas:ic sheet, coated with a metallic oxide capable of holding a magnetic charge. Enclosed nsidea protective square plastic envelope, the disk is spun from the hub. The recording surface is accessible to th., readrwrite head through the slot shown at the bottom of the illustration

FLOPPY DISK
Compared with the cassette and cartridge storage systems, disk storage has few major drawbacks. Floppy disk drives are complex and delicate in their construction, and expensive from 150 upwards. Floppy disks themselves are also costly at between 2.50 and 4 each. But the user gains a reliable, flexible and fast means of storing large amounts of data, operating at 50 to 200 times the speed of tape storage and retrieval. All disk drives have a form of Disk Operating System (DOS), which contains a routine that formats the distribution of information on a disk into tracks. There are usually between 35 and 80 tracks per side, each track divided into a varying number of arcs called sectors. There are fewer sectors on the shorter tracks near the middle of the disk than on the long outer tracks. Each sector consists of a block of data, usually 256 bytes. The DOS `remembers' where all the information contained on the disk is stored. This is usually achieved by the creation of a Block Availability Map (BAM), either stored on the disk or held in memory, and a catalogue or directory. The BAM holds a record of the blocks currently in use and those free for new storage. The catalogue is a list of the file names, file types and track and sector locations for each file. It is usually held on the central track and can be loaded into computer memory for reference. The DOS positions the read/write head after reference to the BAM, and catalogues and manages the storage and retrieval of data.

4
C

There are three main methods of implementing a DOS. The most efficient is to include it in ROM form within the disk drive, under th. control of the drive's own microprocessor with associated RAM. This is known as an `intelligent' disk drive; on receipt of an instruction from the central processor it can process complex disk-handling routines independently, allowing the processor to continue running a program. All current Commodore disk drives are intelligent in this manner and use no internal computer memory in operation. A more popular system is the type that loads the DOS from disk into computer RAM on command or automatically when the computer is switched on. The third method includes a form of DOS in the computer's own operating system. Spectrums have this facility and Acorn Computers supply a DOS for the BBC Micro called the Disk Filing System that provides limited disk control. Diskhandling routines include SAVE and LOAD commands, a CAT (or directory) command, a command to format a disk (or tape cartridge) and various random access and sequential file creating, handling and deleting commands.

t PROTECTIVE ENVELOPE 2 PROTECTiPERMIT SLOT 3 SECTOR 4 REGISTRATION HOLE 5 TRACK 6 ACCESS SLOT

THE HOME CO1PUrER .ADVANCED COURSES

;i

SOFTWARE/ANT ATTACK

ATTACKED BY ANTS
The significance of Quicksilva's Ant Atttack, a three-dimensional maze game designed for the ZX Spectrum with 48 Kbytes of RAM, lies not in its obvious graphic quality, but in the subtle application of the algorithm that generates the fabric of its maze-like playing ground. Software writers and publishers have never been satisfied with the protection accorded them by the copyright laws - hence the many and various attempts to safeguard programs from being copied. The author of this game, Sandy White, has attempted to prevent his work from being plagiarised, by using another method applying for letters patent on the software technique that produces the screen graphics, Since the 1977 Patents Act specifically denies protection of this sort to computer programs (noting that they cannot be considered to be inventions), one is led to the conclusion that the patent in question covers a mathematical formula or algorithm. This in itself is interesting because one would not normally require a complex algorithm for a game of this sort. What is it about Ant Attack that requires a radically new approach to software protection?
t My Hero! On :he first pass through the game, the'victin is conveniently placed adjacent to the gateway to the city. A quick hop over the protective wall, and the protagonist male or female is greetec with a cry of 'My hero take me away from all thi Fomli-dable Ant-iclimax Sometimes, the fact that ants can't climb stairs is very useful indeed though why our hero has climbed quite so higi, one can only speculate. Climbing obstacles like this allows the protagonist to lob grenades at the attacking ants without fear of retribution, but remember that you are playing against the cluck

His remarkably forward-looking package was, surprisingly, rejected by Sinclair Research, who could not evaluate the videotape of Ant Attack that White sent them because, they said, they had no video cassette recorder! The first novel feature of Ant Attack that a user will encounter is that it allows the player to choose the sex of the chief protagonist. And the first oversight follows hard on its heels. Whether you opt to be a girl or a boy, the opening frame of the game, which sets the scene in 30 or so words, explains how you hear a call of distress 'irresistable (sic) to a hero like you'. One can forgive the spelling mistake, but the program's inability to substitute `heroine' for `hero' is evidence of a lack of attention to detail. Further evidence is to come. The protagonist, chased by monster ants, can defend himself (or, of course, herself) by throwing grenades. Unfortunately, there is no consistency in

Ant Attack is also unusual in that it is not descended directly from any arcade game. Most popular games for home computers have their roots in the conceptions of Atari, Taito and the other manufacturers of dedicated games machines. Ant Attack was conceived by a graduate from the Edinburgh College of Art who protests his ignorance of the arcade games tradition. Sandy White had never previously written games software and his efforts at market research were restricted to inquiring of friends what it was they liked about such games.

the effect these grenades have on the ants, While this might result from a deliberate randomising factor, it is more likely to be the result of indiscriminate programming. Moving the protagonist anti-clockwise through 90 degrees is achieved by pressing the Spectrum's M key, and the Symbol Shift key next to it turns the figure the other way. The Spectrum's moulded rubber membrane keys do not give proper control over this transformation, which . invariably results in frustration for the player. It would appear that Ant Attack was developed in advance of the launch of Sinclair's Interface 2, which accepts two Atari-standard joysticks. The game would benefit greatly from being updated to utilise these peripherals, though it would need two joysticks to handle the command structure. In addition to revolving the token, moving it forward, making it jump or throw grenades (you can also choose between four distances of throw), the player can choose one of four points of view

6 THE HOME COMPUTER ADVANCED COURSE

'A

it each centred on the token. It is this section of the program's graphics generation that sets it apart from most other games occupying less than 48 Kbytes. The transformation is virtually instantaneous, completely overshadowing the normal run of 3D graphics generators available for Spectrum. The ability to change points of view is essential to the game. Without it a considerable portion of the playing ground would often be hidden from view. The author is understandably unwilling to reveal too much about the working methods that he and his collaborator Angela Sutherland have adopted. He does imply, however, that the playing ground is not, as one would expect, held as a 128 X 128 X 6 array. Evidence of this is apparent if, rather than entering the city, the player token is made to turn round and head off into the desert. After a short walk, he or she comes to another city, and then another, and so on. And so to the object of the game itself. It is set in the City of Antescher (named by the game's authors in tribute to the Dutch artist and designer M. C. Escher, who drew ingenious delusive structures that were impossible to actually build). Standing outside its gates, you hear the cries of a person in distress. You jump over the low wall into the city and go off in search of the victim, jumping onto obstacles or turning to avoid them as you go. The city appears in isometric projection and no attempt is made to keep faith with perspective. Only a small portion of the city is in view at any

ANT ATTACK/SO}11W

(iJ

one time, the frame scrolling across as the figure moves left, right, up or down. The scrolling action is excellent, as is the animation of the figures. Full marks, too, for a good sense of humour in the treatment of the animation. It soon becomes apparent that the city is populated by huge ants whose bite, though not immediately fatal, will cause death if you suffer enough of them. If an ant becomes aware of you, it will follow you. You can shake it off if you are skilled enough, otherwise you have to resort to the rather unreliable grenade. Don't throw it at the wall immediately in front of you, because you could blow yourself up. On the first pass through the game the figure to be rescued is in full view opposite the gate. On successive passes it gets harder to find, and harder to reach, It is invariably located above ground level. The rescuer may jump up only one level at a time, so if the victim is not directly accessible from the ground by a stairway, for instance the rescuer is in real trouble. The only way is to wait till the ants attack at a suitable spot, paralyse one, and jump onto its back, using it as the first step up. The rescuer can also get a `leg up' in this way from the victim, should it be necessary the ants won't attack the victim, The pass finishes when rescuer and victim are both outside the city. Despite its few failings, Ant Attack is worthy of the accolades that greeted it when it appeared on the market just before Christmas 1983. It is a fine example to all would-be software authors.

Master Minds Ant A tt ack was a first a tt empt at commercial software writing for its author, Sandy White. Sandy, just 23 years old when the package first appeared in late 1982, had graduated trim Edinburgh College of A rt with a degree in sculpture when he

conceived the notion of creating a games program for home microcomputers. A friend, Angela Sutherland, collaborated in thu design of the structures that make up the city of Antescher

Riddle Of The Sands


This plan of the entire ci ty of Antes,her was constructed after painstakingly photograph ng the monrtor screen huncreds of times, making a ccmplicited photomontage of the results, and then commissioning an artist's impression of the scene. Authors White and Sutherland have given names to the chief structures, but also note that a copyright notce SW appearsin the top left-hani corner!

1 B ^< ^ 3 y12

13
0

^_%

f 10

15 50

-+
1. THE WATCHTOWER 11. THE MONJMENT 2. PHOSPHOR HENGE 12. ANT EDEII 13 ARGON'S LEAP 3 TH E OUAI 14. ARTANT'S VILLA 4. TABLE ANTCHAIR 15. THE ANTIMATTER CUBE 5. THE FORUM 6. THEANTICHAMBER 16. DROXTRAP 17. ACRIANT'S WALL 7. SKAZ YANDOR 18. BCNZAI WALK 8. THE PYRAMID 19. THESUUARENA 9. THE ANCIENT 20. THE CRYPT '0. OXYMINE 17 r

1s

THE HOME COMPUTER ADVANCED COURSE 7

COMPUTER SCIENCE

/BOOLEAN LOGIC

THE ALGEBRA OF DECISION MAKING


Computers carry out their given functions by passing a series of high or low voltages around electronic circuits. These voltages can be interpreted in terms of the binary digits (or bits) 1 and 0. Some functions, such as addition, require specially designed circuits to produce specific outputs for any given input. These are termed `logic' circuits. Boolean algebra, the branch of mathematics concerned with true/false logic, is the theoretical basis from which computer architecture is physically realised. The concepts and rules of Boolean algebra are few and easily understood. In the first instalments of this course, we will study in detail the theoretical and practical aspects of logic circuit design, together with examples of the basic circuits at work inside your own home computer. The rules of Boolean algebra are based on three simple logical operations: AND, OR and NOT These three logical operations conform closely to the way we use these words in everyday English. Look at this statement: If it is fine AND it is a Saturday, David will go for a walk. If David is to go walking or not depends on two things: whether it is fine, and whether it is a Saturday. Incoming to a decision about going for a walk, David is only concerned with whether the statements `it is fine' and `it is a Saturday' are true or false. There are four possible combinations and only one will result in David taking a walk. A table which shows all the possible combinations of a series of statements is called a `truth table'. Here is the truth table for our logical AND statement: IT IS FINE
FALSE FALSE TRUE TRUE R IS A SATURDAY FALSE TRUE FALSE TRUE DAVID WIU GO FOR A WALK FAL E FALSE FALSE TRUE JACK CAN GO FALSE FALSE TRUE TRUE JILL CAN GO FALSE TRUE FALSE TRUE JOHN WILL 6010 THE MATCH =ALSE TRUE TRUE TRUE

The third logical operation (NOT) performs a very simple function. Consider this statement: If it is NOT dark then I will go out. This time the only condition to consider is whether it is dark. This may be true or false; hence there are only two possible conditions for our truth table.
RISDARK FALSE TRUE I WILLGOOU.T TRUE FALSE

LOGIC GATES The simple electronic devices that make up computer logic circuits are called `logic gates'. The three simplest logic gates mimic the function of the logical operations AND, OR and NOT. These gates function by representing a TRUE condition by the binary digit 1, and the FALSE condition by the binary digit 0. So, for each logic gate we can construct a truth table showing all the input combinations together with the resulting output. Each gate has a circuit symbol associated with it and can be written as a Boolean expression. The truth table and diagram for the AND gate with inputs A and B and output C is: A 0 0 1 1 B 0 1 0 1
C
THE AND GATE

0 0 0
1

A
AND

A similar process can be undertaken to illustrate the function of the logical operation OR. Consider this statement: If Jack OR Jill can go, John will go to the match. Once again there are two conditions that will determine whether or not John goes to the match: whether Jack can go, or whether Jill can go. In the same way as the AND statement, we can construct a truth table for the OR statement. Since there are two conditions, each of which may be true or false, there are again four possible combinations. The truth table for the statement will look like this:
8 THE HOME COMPLIER ADVANCED COURSE

The function of the AND gate can be described in words as: `the output will be 1 if both inputs are 1, and 0 otherwise'. The Boolean notation for the output from an AND gate is A.B. The truth table and diagram for the OR gate is: A
D

B 0
1

C 0

THE OR GATE

A
OR

0 1 1

1 1
1

0 1

BOOLEAN LOGIC/COMPUTER SCIENCE

The OR gate can be desc ribed by the following statement: `The output will be 1 if either or both of the inputs are 1'. The Boolean expression for the output from an OR gate is A+B. Unlike AND and OR, the NOT gate has only one input and one output. The truth table is the simplest of the three:
A B
THE NOT GATE

0 0 1 1

0 1 0 1

1 1 0 0

0 0 0 1

1 1 0 1

0
1

1
0

HoT

In words, the NOT gate is expressed as: 'the output will be the opposite of the input', The Boolean expression for the output from a NOT gate is A.

The use of truth tables is not limited to two input and one output circuits but can be extended to any circuit. Here is an example of a three input, two output circuit.

COMBINING LOGIC GATES


Just as several logical statements can be linked together, we can link together logic gates to make combinational and sequential logic circuits. These are in tu rn combined to produce the computer architecture. Any logic circuit can be represented by a truth table that desc ri bes what output can be expected for any possible combination of inputs. Look at this simple logic circuit:
A AND X NOT C

As there are three inputs to this circuit we must consider eight possible combinations:

X 0 0 0 0 1 1 1 1

Y 0

Z 0

B
In this circuit there are two inputs, A and B. and one output, C. To help to construct the truth table for the circuit the output from the first gate has been labelled X. As there are two inputs to the circuit this means that there are four possible combinations of input. A 0 B 0 1 0 1 X 0 0 0 1 C 1 1 1 0

0
1 1

1
0 1

0 0
1 1

0 1
0 1

M N 0 1 0 1 0 0 0 0 0 1 0 1
1 0

S
1 1 1 1 1 1

T
1 1 0 1 1 1

0
0

0
1

0 1 1

The output from the AND gate, X, is put through the NOT gate to produce the final output, C. Here is a more complicated circuit and its truth table. Notice that, as there are only two inputs, the number of possible input combinations is still four. The second half of this truth table (columns P, 0 and C) is a rearrangement of part of an OR gate truth table.
P
A NOT

EXERCISE 1 1) Construct a truth table for the folloning situation: 'Janes may drive a car if he has passed his driving test OR he is accompanied by a quali'ied driver'. 2) Construct a truth table for this situation: 'A program can be loaded into a computer if there is a casse tt e player OR a disk crive available AND the program is NOT wri tt en to run on a different computer'. 3) Const uct a truth table for this logic circuit:
P A

^ OR AND C OR

AND

B Q

THE HOME COMPUTER ADVANCED COURSE 9

` HARDWARE /COMMCDORE 64

COMMODC
At 200, the Commodore 64 contains a lot of hardware 64 Kbytes of memory, sophisticated sound and graphics facilities. It is a very suitable machine for the serious home computer enthusiast, and with the addition of suitable peripherals, could be used for small business applications ,too. The design makes use of `bank switching' to squeeze the memory into the space available.
The physical similarity between the Commodore 64 and the Vic -20 is deceptive. Although there is a measure of software compatibility between the two, in hardware terms the 64 represents a considerable advance. Let's begin by looking at the 64 Kbyte of RAM from which the computer derives its name. This feature is a considerable advantage in selling terms since it was, until the advent of the 16 -bit microprocessor, as much RAM as was available on any business microcomputer. However, there is a certain amount of difficulty associated with equipping a home computer with this much memory. Though an eight-bit microprocessor such as the widelyused 6502 can address a total of 64 Kbytes, this must include all the ROM and the input/output chips for controlling keyboard, screen and peripherals in addition to the RAM. The answer lies in `bank switching', a technique whereby sections of memory are switched into and out of the addressable memory map as they are needed. There is no theoretical limit to the total amount of memory that a computer can incorporate using this method, but because the microprocessor can still only address 64 Kbytes at

The SX-64 is a self-contained portable version of the Commodore 64, which can be purchased in a variety of different c)nfigurations. The most popular version features one disk drive (the space above can be used for storing diskettes) and a five inch colour monitor. The SX-64 will run disk or cartridge based software from the standard Commodore 64 without modification. In nany aspects it is one of the best designed 'luggable' computers a phrase coined to distinguish them from truly portable machines such as the Epson HX-20 and Tandy Model 100. Tfe keyboard features fully sculptured keys with the graphics legends inscribed on the front, and it is detachable f rom the main unit, There is a slot in the top of the casing to take ROM cartridges; when not occupied the opening is covered by a f ap to keep out dust. The casirg itse f is bcth rugged and compact, resembling the portable test equipment used-by service engineers, particulaly ii the way that the carrying handle doubles up as a stand. The handle is ridged to prevent it from slipping on the desk though this makes it slightly uncomfortable :o carry. Overall, the physical des gn is :he best to have ccme from Commodore to date, and is marred only by the fact that the mairs cable and plug cannot )e stored anywhere inside the casing
10 THE HOME COMPUTER ADVANCED COURSE

Box Of Tricks

COMMODORE 64/ HARDW E


an y one time, the more memo ry there is, the more switching of banks there wi ll need to be, an d that

will subsequently reduce efficiency. What this amounts to on the Commodore 64 is that if you w an t to run a program in BASIC, the
ROMs containing the BASIC interpreter will need to be switched in, an d this will reduce the amount of available RAM to 40 Kbytes ( an d system variables an d screen RAM wi ll still need to come

COMMODORE 64
Approx 200

404x216x15mm 6510 64K RAM, of which 39K is available for BASIC p ograms. 20K of ROM including the character generator 25 rows of 40 columns. In low resolution, 16 colours are available from tie keyboard for characters, border and background. Maximum high resolution is 323x200 pixels. Up to eight sprites can be defined and
used

out of this allocation). Though bank switching has been added to quite a few home computers by way of a modification, it is achieved on the Commodore 64 by using a special microprocessor. The 6510 is very similar to the 6502 that h as proved so popular in home computer desi gn . The instruction set is identical, an d it features an eight-bit data bus, 16-bit address bus, an d vari ous control signals. However, it also sports an eight-bit p rogrammable input/output port. This means that there are eight additional pins on the chip, each of which can be set to 1 or 0, or can be used to read values placed onto them by an exte rn al device. Normally such ports are implemented by means of a special chip (called a PIO, PIA or VIA depending on the manufacturer), and a typical home computer will include several of these to h an dle the keyboard an d peri pheral ports. The port appears as the lowest two memory locations in the map ($0000 an d $0001). The former is for reading and wri ting the individual bits, while the latter location indicates whether each bit is set as an input or an output. Having this port built into the microprocessor means that the 6510 would be ideal for incorporation into numerous domestic devices from dishwashers to programmable toys. On the Commodore 64, it is used to select between the banks of memory (see W p an el). You could do this with BASIC POKE statements, but there is a distinct possibility of
`crashing' the system, forcing you to reset the computer. Most memory switches are therefore
Business Mileage A large proportion of the Comoro ore 64's software base can be m said to have been inherited from its predecessors, the PET and Vic-20. The BASIC interpreter is more or less identical on all tiree machines, and there is much common ground in the disk cperating systems,, too. Because the business scftware ceveloped for the PET range could only be u sed on Commodore's maclines, it is hardly surprising that the software cevelopers were so quick to take advantage of the potential new narket opened up iy the 64. For business application, there isa wide choice of word processing packages, several cf which have spelling checkers. examples Two of the most popular examples are EasyWrite/EasySpell from Commodore, and V'izaWrite/VizaSpell. Two other popular packages, but without the speliing option, are Paperclip 64 and Wordcraft 40. The latter is different from most word processors, in that the screen displays the text in the format in which it will Wally be printed, whilst most others display controls' single character symbols to signify a carriage return, crthata heading is to be centred on the page. Spreadsheets are available starting from just a few pounds One package, however, is worth special mention. At over 100 CalcResult is more expensive than most spreadsheets for lowcost m cros, but it works in full colour, inclides a facility for
If

Joysticks (2) plus light pen, RS232 (adaptor needed), 8-bit para lel, cassette, serial (for dis< and printer), composite monito', audio input and output, TV, cartridges BASIC, FORTH, LOGO, 6502 Assembly language Typewriter-s ty le, with cursor keys and four programmable function
keys

lisp aying barcharts of the figures in any column on the spreadsheet, and works three dimensionally. That is to say, e several pages of memory co g be h ld in memcry at once, andit together figures from all these sheets . is p Magpe to Magpie, too,, is a fairly outstanding piece of software s ie fallirg into the category of applications generators. An appl cation is defined by drawing the layouts for screen records cation ing the and printed forms on the screen, and then specifying i relationships between the fields with n those documents; VAT=TOTA.15 /3, for example " pr n cam.eie ce5 F I ii t er f
price iill.S San ease auto:

The computer comes with an adequate instruction manual, but to taKe fuli advantage of the functions, you should purchase the Programmer's Reference Guide, or one of the many independently published guides to the Conmodore 64 Large standard memo ry . Sprite graphics. Sophisticated sound control. Quality keyboard. Gooc range of peripherals. More business software available than for most home computers
ReqLires manufacturer's cassehe

s^ r
:

r _

w..l.d Pr.ces o 'i^r. z ` F G ^^ ^


a.=o. p^^^ S t Pr oc ed uf! E.. r_= p, page get auto..F G eSe ~=` FI Fnd of Procedure

,tprl f jeId5

unit. BASIC weak on useful commands (unless you purchase a cartridge add-on). Limited choice of graphics modes and resolutions. Disk unit slow

THE HOME COMPUTER ADVANCED COURSE 11

HARDWARE/COMMODORE 64

p
Cassette Port All Commodore compu require the manufacture cassette unit. When it v marketed, the Commo( system was faster and reliable than a domestic Now the opposite is tru Serial Bus This is a special interface des gned by Commodore to drive several devices ;including their disks and printers) l simultaneous y The protoc)l is d similar to the IEEE4 8 )tan ard except that there is just one (serial) data line instead of eight parallel ores

Ca rt ridge Port

If a FOM cartridge (up to 16 Kbytes) is Mugged in here, it will effectively override any othe' men ory that occupies the same locations. if the first nine bytes of the ROM contain a specified sequence of values then the program will 'automatically start wren switched co. This is how games cartridges work

Audio/Video Socket A composite video si)nal is provided to drive a colour mcnitor ithouch not an RUB mcnitor), and there is a separate audio output that can connect with a hi-fi system. There is also an audio input line that allows you to mix recorded music with synthesised sounds

This port has two functions.

N Output Unlike the Vic-20, the Commodore 64 contains a builtin RF modulator, so that the output can be ccnnect^d directly to a TV

First, it can mplement a full RS232 serial interface, though an add-on is needed to :onvert the 64's voltages to those used on most serial devices. It can also double up as a parallel port that can be used for experimentation

Memory Map The 64K of ava fable'nemory space is iividei up into six zones, three of which are usually configured as RAM. The other three contain ROMs for the BASIC, the operating system, and the I/O chips, but for each one there isa 'shadow' area of RAM that car be switched in under software control. This is only practicable, however wher using machine code and the FOM isn't needed

Zone 1 Permanently contains 32K of RAM Zone 2 Normally 8K RAM. If an 8K ROM cartridge is inserted this will overide tie RAM

32K RAM

Zone 3 Normally8K ROM, containing the BASIC interareter It will be overridden if a 16K cartridge is inserted. Alternatively, 8K bf RAM can be switched in to replace the ROM Zone 4 Permanently 4K of RAM 8K RAM
_______ -

r
8K BASIC ROM 4K RAM 4K I/O RAM

Zone 5 Normally contains all the I/O chips and some RAM. Under sof'ware control, however, the ROM-based character generator car be switched in here Zone 6 When the machine is switched on, this contains 8K of ROM, including the Kernel - a minimal
operating system designed to

performed in machine code. Three other chips between them account for the rest of the 64's features. There is a 6526 CIA (Complex Interface Adaptor), which is a more sophisticated version of the PIAS and VIM previously mentioned. In addition to the usual programmable input/output lines, it includes timers and shift registers to convert between serial and parallel data. There is also a 24-hour clock with a programmable alarm, of which the BASIC interpreter appears to make no use at all. The graphics an d video display are handled by another chip, the 6566, which is a further development of the Video Interface Chip, from which the Commodore Vic-20 derives its name. This delivers different modes for both textual an d high resolution graphics displays, and the sprite graphics have been well documented. Though it can handle only eight sprites at once (compared with 32 on the Memotech MTX512, for example), it is possible to simulate rather more. Sprites are defined as a block of bytes in memory, an d their location is indicated by POKEing the address into the Vic-II chip's registers. It is relatively easy to switch the pointer rapidly an d repeatedly between different sets of values to simulate more th an eight
units.

8K KEF NAL ROM

be used on all future Commocore hardware. When using machine code it can be replaced with 8K of RAM

The 6581 chip is referred to as the SID, or Sound Interface Device, and contains functions a great deal more advanced than some of the early purpose-designed music synthesisers. As well as full ADSR control over the volume envelope of each sound, the functions include filtering, different waveforms an d ring modulation modifying one sound with another.

12 THE HOME COMPUTER ADVANCED COURSE

ACCESS - ADA/JARGON

iii

ACCESS TIME
i6 This refers to the time taken to locate a particular item from within a whole collection of data. The term is most commonly used when referring to the length of time needed to locate any particular record within a file especially in database applications. For many business applications, the efficiency of a program will be far more strongly determined by the average access time of the disk than by the clock speed of the CPU. The access time is quite different from the data transfer rate' which is the speed at which bits will be transmitted from disk to computer once the item has been found. On the Sinclair Microdrive, for example, the average access time of a piece of data is 3.5 seconds. The minimum is zero, if the data is opposite the read-head mechanism when the request is made; and the maximum is seven seconds, if it has to wait for a complete circulation of the tape loop. This is very slow when compared with a floppy or hard disk unit, where the average might be nearer to half a second. However, the data transfer rate of the Microdrive (16 Kbytes per second) is very fast, and is as good as any disk.

ensure that the signal to be sent always falls within this range. This is called `modulation'. One system of modulation represents a binary zero as a tone in one frequency (let's say 1000 Hz), and a binary one is represented by another tone in a different frequency (e.g. 2000 Hz). The device for converting between binary data signals and these audio frequencies is called a `modem' ( MOdulatori DEModulator). For best results the modem should be wired directly into the telephone line, but this can only be done for a permanent installation. For portable applications (such as salesmen transmitting the day's figures back to central office, or journalists sending copy to their editors) an acoustic coupler is necessary. An acoustic coupler is simply a modem with two rubber cups (one for the mouthpiece and one for the earpiece) into which a telephone handset is pushed. Were you to remove the handset during a transmission, you would be able to hear the data being transmitted in the form of tones. However, by interrupting the flow of data, you would create errors in the received data.

ACRONYM ACCUMULATOR
Inside a microprocessor or CPU there are several registers. These are individual bytes of memory that perform all the arithmetic and logical functions of the processor. Probably the most active and important of these is the accumulator, which is linked directly into the Arithmetic Logic Unit (ALU). The chief function of the accumulator is its ability to accumulate values: that is to say the contents of a byte can be simply added into, or subtracted from, this register. To the BASIC programmer, the accumulator is both invisible and inaccessible (although it will be used by the BASIC interpreter thousands of times every second). To the machine code programmer, however, the majority of instructions in every program written will involve some manipulation of the accumulator. an acronym, so is PET, and FIFO, RAM, EPROM and SNAFU. An acronym is a word formed by taking the initial letter from each word in a description or title. Acronyms seem to be very popular in the computer industry, both for buzzwords and for proprietary names for products. One suspects, however, that often the final acronym has been thought up first, and then the component words have been fitted to that. Who would really want to call a programming language Beginner's All-purpose Symbolic Instruction Code, or a new computer the Locally Integrated Software Architecture?
BASIC is

ADA
In the late 1970s, C.I.l. Honeywell Bull in France designed and specified a programming language primarily for use by the U.S. Defense Department. It was intended to replace all the other programming languages they were using at the time, and was therefore also intended to vary as little as possible between machines. The language is very highly structured it is described by some as a kind of super PASCAL, but by others as `unwieldy '. It is named in honour of Countess Ada Lovelace, who was a close friend and companion of Charles Babbage and is credited with being the first programmer.
THE HOME COMPUTER ADVANCED COURSE 13

ACOUSTIC COUPLER
The transmission characteristics of a telephone line are such that it can only be used to transmit frequencies in the range 300 Hz to 3400 Hz the range required to transmit normal speech intelligibly. This `bandwidth' also determines the maximum rate at which binary data can be transmitted. Some system is needed, therefore, to

PROGRAMMING PROJECTS/SPECTRUM BASIC

THE SPECTRUM OF

ZX BASIC

BASIC has

become the standard language of microcomputers, but almost every machine has its own- variation or dialect. In this
se ri es of articles we will be looking at some

referred to collectively as a$. The length of this variable will always be 12, and assignments to it will be padded with spaces or truncated on the right as necessary to preserve this length. Suppose we write: DIM a$(12): LET a$="123456789" then aS will actually contain the characters `123456789' followed by three spaces, making 12 characters in all. If we write instead: DIM a$(12):LET aS="ABCDEFGHIJKLMN" then a$ will actually contain only the 12 characters ABCDEFGHIJKL' the string quantity ABCD EFGHIJKLMN' has been truncated on the right to fit into the DIMensioned length of a$. If we now
write:

of these variations and their func ti ons, as well as explaining how they can be `translated' from one dialect to another. This fi rst article looks at the most widely used dialect Sinclair BASIC.
We begin with variable names always a source of confusion between BASIC dialects. In Sinclair BASIC, string variable names must have only one letter, and there is no distinction between upper and lower case letters. This means that the variables aS and AS refer to the same memory location. String array names follow the same rules as simple variables, and pre-empt them, so that once you've DIMensioned the string array HS, all further mentions of H$ in the program will be taken as referring to the array HS. This follows from the fact that Sinclair BASIC regards all string variables as array-type variables, some of them formally DlMensioned, and others not. Numeric variable names are less constrained than those of string variables: they must begin with a letter, and they must consist of letters or digits, but they may be any length. They may include spaces, and they may be a mixture of upper and lower case letters, but although these factors are helpful to the programmer, they are of no significance to the machine, which will ignore them. Some valid numeric variable names are: gwert, ub40, advanced computer course and the following are exactly equivalent: QWERT, UB 40, Advanced Computer Course Numeric array names must be single letters, but this does not preclude numeric variables of the same name: the array variable v(8) is quite distinct from the simple numerical variable v. Single-letter y non-arra numerical variables such as v must be used as the counters of FOR. . . NEXT loops, so FOR V=1 to 9... NEXT V is legal, but FOR Ioop=1 TO 9 is illegal. The main differences between the Sinclair dialect and other BASICS he in the treatment of string quantities. Let us start with the effect of the DIM statement. In Sinclair BASIC, when the statement DIM aS(12) is executed, 12 bytes of memory are set aside exclusively for the use of the variable a$, and these bytes are initialised with spaces. Each of these bytes can be referred to as a subscripted variable, or the whole 12 bytes can be
14 THE HOME COMPUTER ADVANCED COURSE

LET a$(2 TO 5)="1234" then aS will contain `Al234FGHUKL'. This shows

the power of Sinclair string handling all strings are treated as single-dimension string arrays, the arrays can be subsc ri pted or not, an d in dividual elements of an array can be accessed singly or as part of a sub-string by subscripts. It also shows another major divergence from other versions of snsic. Elsewhere DIM aS 12) creates 12 separate string variables called a$(1), a$(2), etc., each of which has the length of the expression assigned to it. If nothing has been assi gned to a pa rticular string variable, then its length is 0, and it contains only the null string, In other BASICS this way of h an dling strings requires the vari ous string functions, LEFTS, RIGHTS, MID$, an d sometimes INSTR, to enable sub-string manipulation an d string-s li cing in the way demonstrated. But this is not so in Sinclair BASIC. The Sinclair equivalents of these string functions are:
LEFT$(A$,N) = AS(TO N)

(meaning the N leftmost characters of A$);


RIGHT$(AS,N) = A$(LEN AS-N+1 TO

(meaning the N rightmost characters of AS); and


NIIDSiA$,P,N) = AS(P TO P+N-1)

(meaning the N characters from position P onwards in AS).


LET S=INSTR(AS,"teststring")

(meaning find the starting position in AS of the substring "teststring") c an be replaced by:
LET Y$=A$:LET Z$="teststring":GOSUB 9900:LET
S=^OSN 9900 LET ZL=LEN ZS:LET SL=LEN YS-ZL+1:LET

I
POSN=O

SPECTRUM BASIC%PROGR.AMMING PROJECTS

9910 FOR K=1 TO SL 9920 IFY$(KTO K+ZL-1)=ZS THEN LET POSN=K:LET K=SL 9930 NEXT K:RETURN

Notice in this subroutine that the string variable YS is treated as a subsc ri pted a rr ay- type va ri able, even though it has not been DIMensioned. Since in Sinclair BASIC all string variables are array-type variables, a string va ri able that is not DIMensioned is implicitly a va riable-length single-dimension array of single characters; if it is DiMensioned, its element length is fixed by the last number in the DiM statement. Whereas in other BASICS DIM x$ (8,7) creates a two-dimension array, in Sinclair BASIC it creates a single-dimension array of eight elements, each of them fixed in length at seven characters. The st ri ct attention paid to the length of DIMensioned string variables by Sinclair BASIC means that seemingly simple statements can have differing effects, depending upon whether a DIM statement has been executed or not. If aS is a simple string variable, then LET aS='" makes the contents of aS equal to the null string ("') and the length of aS equal to zero. If DIM aS(7) has been executed previously, however, then LET a$=` makes the contents of aS equal to seven spaces, and the length of a$ equal to seven (which it will always be, following the DIM statement). Furthermore, in such a case, even though LETaS="" has been executed, a test such as:
IF aS="" THEN PRINT 'null-string"

SuperBASIC While Sinclairs SuperBASIC has a considerably enhanced range of commands over ZX EASIC, the most significant feature is its abandonment of the single-key reserved word entry system common to the ZX80, ZX81 and Spectrum. This was origin2lly introduced as an econo'ny measure for users (if was felt that pressing a single <ey ra:her than typing a whole word would prove attractive). Thelsystem dictated that a variety of different 'modes' would be necessary to allow the entry of single characters to be differentiated from the entry of key words. This system was attractive to Sinclair users who had never previously encountered a keyboard, but for these who had used a typewriter it proved to be a source of frustration

assuming that a$(12) is never used and so contains only spaces. Notice lastly that, in Sinclair BASIC, the first element in any array has the subscript one, whereas in some other BASICS the first element in an array has subscript zero. In the next instalment of the course, we will conclude this look at
Spectrum BASIC.

ri The mythical Greek character


Procrustean St ngs Proc ustes was an innkeeper
,

who kept only ore size of bed, and stretched or truncated his guests to fit it

will fail, and nothing will be printed aS is equal to seven spaces, not the null-string. If you need to test string array elements in this way, then it's probably best to set aside a string variable for the purpose, DIMension it to the length of the longest array va riable used in the program, and test your array variables against it, like this:
100 DIM a$(12,34) 120 DIM bS(7,56) 140 DIM NS(56) 150 REM NS will be used as the emp ty string
... r ..............

3 4

50 DIM A$(12) 5 s_ a
1

T 7

9 io 11 1

DIM AS(12) in Spectrum BASIC creates afixed-length string variable, AS, which initially contains 12 spaces

100 LET A$ = "ABCDEFGHIJKLMNOP"

rA7 D

T j

3 .4 _ 5

6 7 8 $7_1O/_>7_2 1 1

C D E F G H I J K L

If you tryto assign a string quantityongerthan12 characters to AS, it will be truncated at the right to fit
inb A$

580 IF b$(3)=N$(TO 56) THEN PRINT "empty" 59C IF aS(11)=NS(TO 34) THEN PRINT "empty"
........................

150 LET AS = "*?! +" 1 at

Here NS is used only as the empty string, an d if it wasn't used in this way then the tests in lines 580590 would have to use literals, thus: " THEN PRINT "empty" 58C IF bS(3)=" 58E REM 56 spaces between the quctes This is inconvenient an d prone to error. An alte rn ative to using NS in this way is to DIMension all array variables with one more element than they need, and use that l as t element as an empty string for tests of that array, so that line 590 might be: 590 IF a$(11i=a$(12) THEN PRINT "empty"
I

T
?

7_3

,7 ,7_ + E

6- 7 F G H

g I

g J

1 K

11 L

12

If you assign a shorter string quantity to AS, it is stored left-justified in S. The remaining characters of AS are unaffected

I
200 LET A$ = " 1
11

Setting AS equal to' ", the

4_ 5- 6

8T9

10 11

12

null - strirg, should reduce its

length to 0, and its contents to' ", instead, its length renains at 12 characters, and it is filled with spaces

fs^---' -

I
THE HOME COMPUTER ADVANCED COURSE 15

MACHINE CODE /PART

INTRODUCING
Machine code programming is the key to the real power of the microprocessor, allowing the programmer direct control over all the machine's functions. This first part of a comprehensive course, covering both 6502 and 180 operation codes, will lead to a full understanding of the fundamentals of computer programming.

FIRSTCONCEPTS
precede form. In that case, why call it machine code, and why bother to use it at all? We give the language this name because its instruction set corresponds exactly with the set of `primitive' or fundamental operations that a particular microprocessor can perform. We use the machine code when it is important to direct the operation of the microprocessor exactly, step-by-step, rather than allowing a program language interpreter to control Machine code is a programming language, and it it in a more general way. The commonest reason for wanting to use it is looks Re this: speed: if your program addresses the processor INSTK: SBC SD9FA,X ;Outport flag value more or less directly, then you avoid the relatively lengthy business of program translation. In other or like this: words, by cutting out the middleman you save DE23 FD FA D9 time. Program execution time, that is. The actual coding, testing, debugging, modification and or like this: maintenance of a machine code program is likely 11011110 00100011 11111101 11111010 11011001 to take at least twice as long as the same operations would on a high-level language program. The Sometimes it looks like this: unfriendliness and intractability of machine code 1240 LET ACC=ACC-FLAG (X) stimulated the development of languages such as COBOL and BASIC. and sometimes like this: If the set of machine code instructions is the set PERFORM FLAG-ADJUST THROUGH LOOP1 of processor operations, then what are these It's all code of a sort, and since it's destined for a operations, and what does the processor do? In computing machine it's called machine code. To the simplest terms the Central Processing Unit the machine it doesn't actually look like anything (CPU) of a computer is a switch that controls the at all, being simply a pattern of voltage levels or a flow of current in a computer system between and among the components of that system. Those current of electricity. What we usually mean when we say machine components are the memory, the Arithmetic code is Assembly language, and the first example Logic Unit (ALU), and the Input/Output we gave in this article is an instruction in 6502 devices, When you press a key on the keyboard, Assembly language. The point of giving all the you are inputting some information; in the other examples was to demonstrate that there is no machine, however, you are simply generating a specific machine language as such, only a number pattern of voltages in the keyboard unit. The CPU of different ways of representing a sequence of switches that pattern from the keyboard to part of electrical events, and representing them in ways the memory, then switches a corresponding that we find more or less easy to understand. So pattern from elsewhere in memory to the screen so the first thing to learn about machine code (or that a character pattern appears on the screen. To Assembly language we won't worry about the you this process may seem like operating a distinction for the moment), is that it's just another typewriter, but in a typewriter there is a programming language. However, the mechanical connection between hitting a key and programming must always come before the printing a character, whereas in a computer that language: whether you write your programs in linkage exists only because the CPU switches the IBM Assembler, Atari BASIC, or Venusian right voltage patterns from place to place. PsychoBabble, you have to solve the Sometimes pressing a key doesn't cause a single programming problem in your mind before you character to appear on the screen: the keypress y touch a keyboard. The programming language in ma destroy an asteroid, or save a program, or which you then express your solution will delete a disk file, or print a letter. The operation obviously influence the form of the final program. depends on how and where the CPU switches the Indeed you may choose among various possible electric current. In this simplistic view the CPU is at the heart of languages precisely to make the coding of your program easier, or shorter, or more readable. But the system, and all information (or electrical the solution must always come first: content must current) must pass through it from one component
16 THE HOME COMPUTER ADVANCED COURSE

ONE/MACHINE CODE

to another. In fact, the CPU and the system are more complicated than that, but it's not a misleading view. You can think of the CPU as a master controller that sets lesser switches throughout the system to control the flow of electricity, and thus controls the flow of information indirectly, rather than routing all information physically through itself. The effects of the CPU's switching operations can be classified for our purposes as: arithmetic operations, logical operations, memory operations, and control operations. These operations are all the results of switching information through different paths in the system and in the CPU, and to the CPU they all seem like the same sort of thing. Arithmetic operations are really the most important feature of the machine. The CPU can add two numbers together, or subtract one from the other. Subtraction is achieved by representing one of the numbers as a negative number and adding that negative number to the other number; 7+5 = 12 really means: (plus 7) added to (plus 5) equals (plus 12). 7-5=2 really means: (plus 7) added to (minus 5) equals (plus 2). Multiplication and division are regarded as repeated additions or subtractions, so the CPU can be programmed to simulate these processes as well. If the CPU can cope with the four rules of arithmetic, then it can cope with any mathematical process. It is well to remember, however, that all its mathematical potential relies on the ability simply to add two numbers. Logical operations for our present purposes can be described as the ability to compare two numbers: not merely in terms of relative size, but also in terms of the pattern of their digits. It's easy to see that seven is bigger than five because we can take five away from seven and still have a positive result. The CPU has the ability to do that sort of comparison, and it can also compare 189 with 102 and recognise that both numbers have the same digit in the hundreds column. It may not seem a very useful ability as yet, but its use will become more evident later. The CPU can perform essentially two memory operations: it can copy information from a memory location into its own internal memory, and it can copy information from its internal memory to another memory location. By doing these two things one after another it can therefore copy information from any part of memory to any other part of memory. For the memory to be any use, the CPU must be able to do both these things, and these two operations are all it needs for complete management of the memory. Control operations are really decisions about the sequence in which the CPU performs the other operations we have described here. It's not important at the moment to understand them any better than that: if you accept that the CPU can

make decisions about its own operation, then that is sufficient at this stage. So the CPU can do arithmetic, it can compare numbers, it can move information around in memory and it can decide its own sequence of operations. This is a simple list of procedures, and yet it completely descibes or specifies an ideal computing machine! If the CPU can do those four things, then by doing them in the right sequences it can perform any computable task. The right sequence, of course, is the computer program for the particular task, and that's where we as programmers come in. If the CPU had the ability to generate its own operation sequences, then there would be no need for us. You may not be convinced that the four types of operation we have described are a sufficient description of a conceptual computer, so let's think about a BASIC program in terms of the general operations performed. What are these fundamental operations? In any program you have variables, which are simply the names of places in memory where information is stored. Most programs perform some sort of arithmetic upon some of these variables. Having done the arithmetic, a program will often compare two pieces of information and as a result will execute one set of instructions or another. Information usually comes into a program from the user at the keyboard, and goes out to the user via the screen. Except for the sentence about input and output, this description contains no more than the four elemental CPU operations put into different words. And, if you accept for the moment that to the CPU all Input/Output devices are just special areas of memor y, then the picture of the ideal computer executing actual programs is complete. Consequently, the execution of a program can be described as a directed flow of information into, around, and out of the computer; you supply some information via the keyboard, that information is manipulated by your program, and some information appears on the screen. If the idealised computer is just a CPU and some memory, then before going any further we should investigate computer memory: what is it, and how does it work? Imagine a simple electrical circuit consisting of a battery, a switch, and a light bulb: if the switch is closed the light goes on, and stays on until the battery runs down or until the switch is opened. Then the condition of the light bulb ON or OFF is a piece of information, and the whole circuit is a memory device recording that information. Suppose now that the switch is placed at the entrance to a factory, and the light is placed in the Manager's office. When the first employee arrives at the factory, he or she closes the switch at the entrance, and the Manager in the office can see that the light is on and therefore knows that someone has turned up for work. The Manager doesn't have to be in the office when the light goes on; he or she can look at the light bulb at any time to find out whether someone has
[HE HOME COMPUTER ADVANCED COURSE 17

MACHINE CODE /PAST CNF

arrived. The information that someone has turned up for work is stored in the circuit. That's almost exactl y how information is stored in computer memory: all information reduces to the presence or absence of electricity in a circuit. Naturally there's more to it than that, so let's improve the management information system. Suppose we have four separate switch/bulb circuits (the four switches in a row at the door, and the four bulbs in a corresponding row in the office), so that closing the leftmost switch illuminates the leftmost bulb, and so on. Now imagine that every employee is told to close the switches in a unique way, so that when Catherine arrives she closes the first and second switches and opens the third and fourth; Richard closes the fourth switch and opens all the others; Bobby closes the first and third and opens the second and fourth; and so on for all the employees. The lights in the office now show the Manager which of the employees has turned up for work. Suppose that the OFF position of each switch is labelled 0, and the ON position is labelled 1: therefore Catherine has to set the switches 1100 (first two switches ON, third and fourth OFF), Richard has to make the pattern 0001 (fourth switch ON, the others OFF) and Bobby has to set 1010 (first and third ON, the other two OFF). If the Manager reads each light bulb as 1 if it's ON, and 0 if its OFF, then both the employees and the Manager will be speaking the same identification language. `0001' means 'Richard' to both people. How many unique patterns of switches are there? Each switch can be in one of two positions, and there are four switches, so there are 2X2X2X2=16 different patterns. Let's consider all the possibilities: 0000, 0001, 0010, 0011, 0100, 0101, 0110, 0111, 1000, 1001, 1010, 1011, 1100, 1101, 1110, 1111 Try as you like, you can't make any more patterns than these, and there are 16 of them. Notice how quickly we've moved from the concrete picture of light bulbs in a room, to the abstract matter of patterns of 1's and 0's. If we can abstract a little further we can turn these patterns into numbers. Think about counting and writing down as you count. You can count from nought to nine very easily because each of those numbers has a unique name and a symbol to represent it, But what do you write down after nine? You have a name, ten, for that number, but no separate symbol to represent it. Therefore you must re-use some of the other symbols: 10, 11, 12, and so on until 99, when you run out of possibilities again, so the next number has three columns (100). This seems trivial, but you may remember how difficult it was when you learned it at school: all that squared paper with Hundreds Tens and Units written at the top of each sum? You now know that the number 152 means "1 in the Hundreds, 5 in the Tens, 2 in the Units", or 100+50+2=152. Counting works like this because we have ten
18 THE HOME COMPUTER ADVANCED COURSE

digits (0,1,2,3,.. .,9) which we arrange to represent all possible numbers. How does counting work, however, if there are only two digits: 0 and 1? We can count to I easily, but how can we represent the next number? We have run out of unique digits, so we must re-use what we have (just as we did when counting with ten digits), and write the next number as 10. Now we know that the next number is called `two', so in this system 10 represents the number two. The next number as we count is three, and we must write that as 11. Then what? We've run out of twodigit combinations, so the next number, four, must be represented as 100; five must be 101, six is 110, and seven is 111. Here, we are counting in decimal numbers (nought, one, two, etc), but we're writing these down in binary numbers (0,1,10,11,100,101,...). In the same way as a decimal number such as 152 means: (1X100)+(5x10)+(2x1), the binary number 101 means: (1X4)+(0x2)+(1x1). Instead of having hundreds, tens, and units columns for our numbers, we must use columns marked: fours, twos, and units. In a decimal number the value of a digit is multiplied by ten for every column it moves to the left; in a binary number the value of a digit is multiplied by two for every column it moves to the left. So that's the binary system: just a different way of representing numbers. If you know Roman numerals you don't find it hard to accept that there are VII dwarfs in Snow White; so why not write 111 dwarfs? The actual number of dwarfs is not changed by the way we represent it, but it is a good idea to say the binary number as `binary one one one', and to write it as `111 b' so that you don't confuse it with a decimal representation. Now we can return to our original analogy of how the factory workers switch patterns, and decide on a method of making these a little easier to use. The most sensible thing to do is to treat these patterns as four-digit binary numbers. This means that Catherine's signal is 1100 binary, which is 12 decimal. Richard's signal is 0001 binary (1 decimal), and Bobby's signal is 1010 binary (10 decimal). When the Manager looks at a pattern of lights in the office, he or she can read it as a binary number, convert it to its decimal equivalent, and look down the list of employees to see who that number corresponds to. Thus we can say that information is stored in the current of electricity, and the switches make it meaningful. Our analogy has given a simple picture of how information is represented in a computer: to the computer it's just patterns of voltages (i.e. lights are ON or OFF), but we humans find it easier to consider those patterns as binary numbers. It's all a matter of representation. If you now think of 1010 as the code meaning `Bobby', then you may start to see how all of this relates to machine code itself. In the next instalment of the Machine Code course, we will look at how binary numbers are used to represent information inside your home computer.

61 3SdflOD Q33 NYACIY 2 3MMOJ 3WOH 3H.L

********* ** **^ KK*

IHl

'1 bS {N 3N TOC)q
Nb

'N'ZZ
22`8

n13 a 6 Z09 ^41 Q b 3N OSi09 01 Hb_,l8 3 'd 04TGq


3:10d:

* ***

S': sSH
,H zi

C9T0o 09 2 ZZ'Oy^ ZSZ' 0L'2' hS2r59T ' 6T bdbQ 0 6 gOZ`TS 2'pf BpZisZ'16i9 'GSZr. z 0 i' tr'r r ^' b jbQ Or 49T` ZZ'bb

02'Zr

bOd

*X#*^t#W3a T
##If****Wtla0 **

S$8^
b8

S0

Zl

8q

k 3

`Sq r09 SZ?y ^. 00109

6ZT

NSawd:W

**625S-j03'8T,Q8 ^ S:G
b3a o-1 W
iF

8Z 3dOd Z 09
0009

a 66L0 3NI'O 1SI"1 ION #a313tl r f #TFi ^E ##iFIF^F^FiF^E*^ ^k#W3 ^,*W3a T 000 kY ^ ^^ ^(k^F^t OOLCL *^FIF^ ad- k^E# *W a #Y o *#^(iFX I4 kIF^k#IF*^F 3ad3fl 3ntl5 66ZOL ONINNntI ******##*^F^FW3 a Naf13a oOZOL *^ ##TF*1FF^E*^Y1FkY* 08 AS 1 > 3N
o0T o

n;

NINN1a

OL 0 tr0t pd*W3a GobOS

*aF# W U opo
0

OW=(/.fi1Z 0^fla0A 09101


Zzt1a1Sd O1 La1SdZ 2 dtl3b OS'0 96 '691 d1tlQ 0101 r96'96`STZ'8oZ'ZTI`LLtZZ`SOZ`ZTT `d(I OZ IO r dl `96`T80Z'SII`L6QOZ`t' ' 6 s ' Z I r 0Z LTT`S9I<< yltl6 01101 ' 69T' ^ OLZ`Z`SOZ`bTT OL^S9T`ZTT`LLI Z s yTT coo L T SSZ`LZZ`ZL 9TT`S9T dltla
`Z'ObZ`b`Sb`

^V

OLT0L

dl'g lh 1S OU6

SH`r b^ 3NO d ^r^b b 3HOd 009 T S 3?fpd:S^.bS d31y S52 pj d 00 r


a4y.6

000 3N:HJ

01

T=

" oI SFJg by b M O b^2fi L 3a lIh$b: , dNOISb311 ^Lr)gbl r ^NddNJ o0T1 0

dl

3J 13

',

Qg

Z! .Jo

dI:d

'L 3N OOT 3HOd 00a


ap j

9T

T=t dTbT

'

` Z !

O1NI=H- 0Z00o al yn

d Wj

Ny y^ 0 d
W3b: rS HJ:l^ N 33MJ5^

01

j^:SHIF9SZ-?l1Sn'S"1:(9S alSn:8+3`Obd1a15d****w N OTOO Z6ItW3


WIH=

#ik##alS

tl O aOIs W*****^FW3?! 00001 0061 a3Q o08T

0_33 009

c d15

LX3N

6i0p009 Mb3lJ waa: M SIH1 SNSO'J 006


1NI6 d 0
**

3Hb1 .NO
:

f nOn 00LI

1NI^JdI0o

l #******K**** IGbT1tbN3 ** ** * ku *ifK


W QO

^ ****iF**i^ OO KW3e; 001

W *^*N3^ Toy

^9 p,^Q^*o".l^3ao6o

NWWW^

lalsdl8Sn=AWWn(1 0p9T ( dH=l1+tl3IL'3, IHS'.^ OObT 0_n SH=cI,dSIu*S1= 8 0d OOLT NOISaan 0 Ol =fl a0d ST S^0'$d NI COZT 1 d3 15 SSZ Nan13a LIN .Lnd OOil 7tlW ap3 3x00 3NIH dS SeM IdH1.,:lT)Stl1aL1X3N 0001 IH1j. 006 OIS ZLb
+N1

(dW.."=.A 008

Z6T=>I( N3H1 6L9p1^ 016 I=c a03 OOL O


6409

Ik^E1F^FiFaFIF#dE-IF^kiF^Fik#dFaFdE^tiEil'rrN3i! TORT 0d38 0088 3AVS* +136 *Nnd

Z08T

*NOd 380832 80ad 3t\tiS*43d OOST

it^Fi4iF*** *#*##&**iFR^F* dO 1S 0061


X 1X9N 0091 (9SZ113Sjj011NISZSZl1Sdd00dI30091
iW

#it*#x# ^ ^ k a *W3 OS\ itIF^F^^ * J/W 083 ^F^F^F*^^F*##fit## #x^^FX^FW3a 6bT OW3d 3800 * iF ^E ^ FM ^F^F*##kiFF#^F^iFItX#X #iFW3a*001 ***##OdflX^t^#*fit*** ^F^F^F

finS00 000016 300W 00'_ Al % * F F* bSZ T5\

W3H1 9 13 - 1LI+13S-AiC=l3Sdd0 13'1 OObI


d t1S asn= y_ 136830'1.0 x3N3d 0ZI 0011 O1 0= WO 811 0=131880 131 0001
X LX3N 00r

*# # * *##* # * ** oa^^I X88 ^k ^F ^F

OW'X+tlS 3NOd 00' 3W ^V3 a 00' TT 01 0=X 803 00


O'p , i g 6S , O r 4T ,

T0Z'91T'L5 'p'i d1tlQ OS Z d3dWO 8 CC

L+((Ttald)N33d*95Z1+(alc 1 0 H33d=tlS 131.59tZ=ald 13


iF^fiFiEi4i#+(;t#444tif'itiFk#**'#it*#W3'^ y '0 088 0NINNa a31dd *W3a I 314I, 1SI-1 ION Oa *W3a ****3aO3 0!l WnM173dSIF*

uaaios a i l uo I(wnlloadS) s>oolq:nlooio'(a88 pue ) Jopowwoy)1as Jaloeieaa aa^lueaq !aqua6ui/eldsip cq apo 3 eu!L 1 pue 3 ISV8 LaaMI;q uo i lejado )o peals U! aOuaJapp aq alellsuow3p
'y9 a.opowwo 3 ayl JO) iaglo 941 pue 01a!W 3 88;g1

ao{ auo 'wnipadS Xi jol auo 'swei6oid ljogs eaiul esaal peagd iuipeads

3 oo 3NIHY WZ 3NO ,L2^^Id

_^

OFM/MICR0S0FT

BILL GATES-SETTING THE STANDARD


Microsoft has become, in one short decade, the world's most influen tial supplier of microcomputer software. It was courted by the world's biggest supplier of computers, IBM, and effectively helped shape the specification of the IBM PC, the world's largest-selling personal computer.
advice on how to specify and equip a single-user personal computer. Initially, Gates suggested that Gary Kildall of Digital Research, riding high on the burgeoning success of CP/M, was the man for the job. But eventually IBM came back to Microsoft. Microsoft rewrote PASCAL, FORTRAN and MBASIC for the 16-bit implementation, and also came up with the GW (for `gec-whizz') BASIC with its extended music and graphics capabilities. At the same time, Gates realised that an untidy but powerful multi-user OS by Bell Laboratories could be usefully adapted for the more powerful micros based on the new 16/32-bit microprocessors, and transformed Unix into Xenix. Both Tandy and Apple adopted Xenix in their own 16/32 bit models in 1983. It even transpires that Microsoft did much of the work for Apple's newest creation, Mackintosh. Microsoft has a firm footing in the hobby market, too. In 1981 it set up ASCII-Microsoft with a keen young Japanese, Kay Nishu, to sell their OS and BASIC to far Eastern manufacturers of the new generation of lap-held micros like the NEC PC 8201 and Tandy Model 100. Out of the Japanese manufacturers' desire for a common standard, not only in languages, but in interfaces to desirable home peripherals such as colour plotters and printers, lightpens, joysticks, trackballs, robot arms, FM tuners and so forth, came the common MSX standard. Now, it seems, we shall soon have a standard common disk format from Microsoft that will enable data to be transferred among the three principal operating environments MSX, MS-DOS, and Xenix. With its emphasis on software that is easy to use, illustrated in such phenomenal advances as screen windows and the mouse, Microsoft would
appear to have a bright future ahead of it.

GUIDING PRINCIPLES

The Microsoft company, now a multi-million dollar operation, is a classic story of enthusiasts
made good. Bill Gates, at 28 the chairman of the board, was in 1972 only a talented amateur. At Seattle High School, where the parentteacher association had the foresight to equip the students with a timesharing terminal attached to the popular DEC PDP-11 minicomputer, Bill learned about the workings of computers. He went to Harvard University and on his graduation went into business back in Bellevue with schoolfriend Paul Allen. The firm they set up was called Traff-O-Data, and their work was to monitor traffic flow for the Seattle public authorities. It was a momentous period in the development of the microcomputer: the first microprocessors were making an appearance and those with imagination and enthusiasm saw a great future for devices such as Intel's 4004 and, later, 8008 chip. Bill was by now thoroughly familiar with the DEC PDP-11 and one of his first jobs was to track down bugs in this computer. It occurred to him that it would be a good idea to adapt its BASIC for use on the 8080. He had no development system, and the first occasion on which the code and the machine were mated was when Gates took the tapes down to Altair in Albuquerque, New Mexico. Incredibly, it ran first time. Thus was born MBASIC, which has ever since been the standard to beat. Microsoft was becoming known as a software house with expertise at fitting new computers with operating systems filling the empty box, as it were and IBM contacted Gates to ask for his

In 1970, at the age of 28, Shiina Takayoshi abandoned

a promising career in the military and formed the Surd Corporation (1982 sales: $40 million). He immediately
formulated 11 guiding

principles to help him govern

his oew computing business, These included: 'The company's foremost obligation is to humanity. The company must do its
best to determine what

products and services are best for society, and provide these at a reasonable east. 'There must be no division
between labour and

management. All persons in

the company must respect one another and co-operate for The benefit of all

Industry Standard
BASIC Beginners' All-purpose Symbolic Instruction Code was developed in 1965 at Dartmouth College, US, by J Kemeny and T Kurtz, and thus predates the microprocessor by at least seven years. While many dialects of :his language have been formulated, MBASIC, Microso't's own version, has come to be recognised as the industry standard. Microsoft established its reputation with the success of MBASIC. and has continued to thrive by producing a serious challenger to Digital Research's CP/M in MS-DOS, an operating system designed to be applicable to a wide range of microcomputers. Following the lead given by Xerox's Star terminal system. and developed by Apple with Lisa, Microsoft has novi diversified slightly and orodu ed a package tha: combines software wits a hardware device necessary to its operation MS-WINDOWS
and th y; mouse. M crosoft's mouse, ike that of its two

competitors uses a trackball-like arrangement couples with two selectors to 'Bove the cursor around the screen

20 THE HOME COMPUTER ADVANCED COURSE

[!JE

The Home Computer Advanced Course will take you far beyond the novice stage, widening your knowledge and making you a more sophisticated user. To help you keep your copies immaculate, we will be making a very

special free binder offer in Issue 5 be sure not to miss it!


Overseas readers: this special offer applies to readers in the U.K., Eire and Australia only

Binders may be subject to import duty and /or l ocal tax.

p ream Warn h1Wa wntqAsirreIeye$! in*aTargJt


WIN 1st Prize, an I.B.M. P.C. system to the value of 5,000.
WIN 2nd Prize, a holiday for two in the U.S.A. with a visit to Silicon Valley. r---WIN 3rd Prize, one of ten high resolution This week (issue 1), the well-known computer word or phrase is hidden in the words "EXCLAIMED'AH' ' colour monitors,
ALL YOU HAVE TO DO "AH! DRESS THE APE RIGHT," EXCLAIMED AMOS, BUGLE SALES MANAGER. This crazy sentence contains anagrams of four familiar pieces of computer jargon. Each week for the next four weeks we will be featuring the particular parts of the above sentence that make up one of the four words or phrases. HOW TO ENTER To enter the competition, first you must correctly identify each week until issue 4 all four hidden words or phrases. Then use your skill and knowledge of computing and your sense of humour to invent a new piece of computer jargon, no more than 5 words long, and give its definition in no more than 15 words. REMEMBER Retain your answers to issues 1, 2, 3 and 4. Issue 4 will contain the address and rules for competition entries. THIS COMPETITION IS OPEN TO "ADERS IN THE U.K. AND EIRE ONLY

aM

You might also like