## **Build your own** digital computer! This is the first of a series of articles describing a complete general purpose stored-program digital computer. Designed specifically for home construction, the computer has an instruction repertoire which includes all of the basic instructions available on most modern minicomputers. Despite this the cost has been kept down to a level far lower than any commercial machine, and the construction made very straightforward by having virtually all the wiring on printed boards. These features should make it an ideal project for anyone keen both to learn in detail how a computer works, and to have a small computer with which to gain experience in programming. #### by JAMIESON ROWE A few years ago when I first became interested in digital electronics, one of the things I found was that there were precious few introductory books on the subject and not many of these were both readable and satisfying. This made the going very tough, and it was because of my own difficulties in getting to grips with the subject that I subsequently wrote the series of articles which became our handbook "Introduction to Digital Electronics. That book has been very popular, with more than 11,000 copies having been sold to date. It has become widely used as a text and reference in schools and technical colleges, and although it is now in need of updating I believe it has been of some value in helping others to gain an insight into the basic ideas involved in digital circuits and their operation. There is one section of the book. however, that I am aware is likely to be found less satisfying than the rest: that dealing with the digital computer. While I believe this section goes a little further than is found in many basic works on the subject. it is still likely to leave the serious reader with a great many questions about the actual design and operation of a stored-program machine Basically I think this shortcoming reflected my own modest understanding of these matters, at the time the book was written. And to this day there are very few, if any, books or other sources from which one can get more than a superficial understanding of the real "nitty gritty" of computers Happily in my own case I was lucky enough to have the opportunity to gain first hand insight into computer operation and programming. Thanks to the generosity of one of our parent companies, John Fairfax and Sons Ltd, and the friendly co-operation of their EDP Managers and staff, I was able to spend many hundreds of lunch-time hours writing programs and running them on their Digital Equipment minicomputers. It was this extremely valuable experience which allowed me to finally grasp many of the points about computer operation which had never quite emerged from reading books. Truly, there is no real substitute for "hands on" experience, at least as far as the basic operation of computers is concerned! However there was still one whole area into which even this experience had not provided insight, even though it had laid a very worthwhile foundation: the actual electrical design of a computer. And being an incurably inquisitive person, this naturally became the most intriguing aspect of all. If, like myself, you've ever tried to get hold of the circuits of a minicomputer, with a view to finding out just how they function in fine detail, you'll probably agree that this is a well-nigh impossible task. I have never found such circuits in any textbook, nor have I been able to find them in any of the voluminous manuals which seem to accompany the machines themselves. I can only assume that the manufacturers prefer to keep the exact details to themselves and their servicing people. There seemed to be no option, then, but to sit down with some modern digital IC data books, and design my own small computer based purely on a knowledge of general operating principles. This, then, is the story behind the project itself. It has been a very interesting and challenging one, and I believe that it has taught me a great deal about the general principles of small computer design. I hope that at least some of these rewards may be passed on to readers, as a result, of its description. I have spent considerable effort in trying to ensure that construction of the unit itself will present as few problems as possible, and will be doing my best in these articles to help the reader get the most benefit from the overall exercise But enough of this preamble. By now, the reader is no doubt wondering if I am ever going to get around to introduce the gadget Perhaps the best way to start is by describing the computer as a scaled-down version of the Digital Equipment PDP-8 machine - at least, in terms of its instruction repertoire and basic console layout. It has the same eight basic types of instruction. and for convenience I have used the same mnemonic names and similar coding. A view of the "works" of the computer, taken before it was fitted into the case. Virtually all of the wiring is taken care of by the PC boards This has not been done purely because of yown initial experience with the PDP-8 family of machines, nor out of a simple desire to fatter the Digital Equipment people – although they have undoubtedly played, and are still playing, a leading role in developing minicomputer technology. While the design no doubt reflects in good measure my familiarity with these machines, and I am happy to pay tribute to the eminence of DEC, this superficial plagiarism has been done for a far more down-to-earth reason. The fact is that Digital Equipment has led in the minicomputer field right from the start, and there are many more DEC machines in use than any other. Therefore the chances are great that if the reader, after building my little computer and gaining preducts to a commercial machine, it is likely to be a DEC machine. By making the operation of my machine as similar to a PDP-8 as possible, I hope that this transition to bigger and better things will be made easier. I should perhaps add that most minicomputers have a great deal in common to the common term of the common term of the common term of the common term of the common term of the common that common the common term of terms "Essentially, then, this computer is rather like a PDP3 and other modern minicomputers, except that it is a good deal smaller. Not so much in terms of physical size, because the latest generation of minicomputers are quite small themselves. The contrast is more in terms of circuit complexity, which has been scaled down whole size of the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of a single individual to the project within the scope of th Probably the most obvious difference is in terms of memory size, and this is because the memory is the most costly part of any computer. Whereas most modern minicomputers have a memory with at least a thousand or so storage locations, the memory of this machine has only a modest thirty-two. While this much smaller memory capacity would make the machine of very limited use in practical computing applications, don't assume from this that it is purely a toy. A memory of 32 locations is entirely adequate for demonstrating virtually all aspects of basic computer operation and programming. In fact, it is surprising just how complex and powerful a program one can fit into a memory this size, as I have been discovering! And in a very real sense, the small size of the machine's memory makes programming that much more of a program of the state of the machine sense of the small size of the machine's memory makes programmen to perform a certain task, as any experienced programmer will tell you – the real trick is to achieve this end as economically as possible. With a memory of only 32 locations, one cannot help being steered automatically in the direction of economic programming! This is not to say, of course, that a larger memory would not have been desirable. A larger memory would certainly broaden the practical scope of the machine, and when the description of the basic machine and its #### About this unique project . . . Our description of this project is, we believe, a unique and historical event in the development of popular electronics journalism. To the best of our knowledge it is the first time, anywhere in the world, that a complete general purpose stored-program dioital computer has ever been described for home construction. digital computer has ever been described for notice construction. We believe it is particularly fitting that Electronics Australia is the first magazine to publish such a project. As one of the longest established electronics magazines in the world, it has always played a leading role in the doi:t-yourself project and learn-whilevou-build turoiaf fields, and this project marks a milestone in both these areas. We are also proud that the project has been developed wholly by Editor Jim Rowe, a member of the EA staff for nearly fifteen years. Although the project has been developed almost entirely in his own time as a "abour of love", it continues the raddition which we have carefully built up over many years: that of describing as many projects as possible which have been developed by our own staff, thoroughly tested, and which therefore may be tackled by readers with confidence. We believe this policy has played an important role in establishing E-A as the leading electronics magazine in Australia, and one of the leading magazines in the world. This project will, we believe, have a particularly strong appeal not only for individuals, but also for high schools, technical colleges and other training establishments. This is because it provides both a means of learning in detail the exact operation of a modern stored-program digital computer, and also the opportudity (when the computer is completed) of gaining direct experience of computer operation and basic programming. There have been many books published which cover the general field of digital electronics, our own "introduction to Digital Beforenies" included. Similarly there have been numerous logic training devices described, like our own Logic Trainer of March and April 1973. However apart from giving the enthusiest a general idea of the John Committee of the o To be sure, one is told that these basic modules are used to make up the broad sections of a computer, such as the "arithmetic unit", the "control unit" and the "memory unit". But little has been said of just what these sections comprise, and exactly how they interact with one another to produce an operating stored-program machine. It was because Jim Rowe himself found these intriguing "fine details" of computer design and operation inadequately explained, that he decided many months ago to tackle the design and construction of a small computer for himself. He believed that by doing this, he would not only learn these elusive secrets for himself, but would also as result be inteliged position to pass them on to others. In addition, there has been the second strong motivation for describing a low cost do-it yourself computer: the fact that, for the first time, this will enable almost anyone to sit down with a computer and obtain the "hands-on" experience which is so essential for a full understanding of how these revolutionary machines work. As anyme who has ever played with a computer will tell you, there is absolutely no substitute for this sort of experience. Until one has actually played with a computer, where machines will always remain partly followed by an element of awe and dischief, these machines will always remain partly followed by an element of awe and dischief, and who will be a substitute that the substitute of o college student. It is our firm belief that Jim Rowe's little "EDUC-8" computer will play an important part in bringing computer technology down to these very people. For it is not only a do-it-yourself construction project but a means of providing a small, yet fully operational computer within the reach of almost everyone's portion. peripheral devices is completed, I plan to look at the possibility of enlarging the machine in this way. But unless memory devices fall dramatically in cost, this will probably involve a significant increase in the overall cost of the machine, so that for the present I must ask the reader to accept my assurance that the present memory size represents an entirely acceptable place to start. Apart from the memory size, there are two other main ways in which the computer is scaled-down in comparison with a typical commercial minicomputer. One is the word length, or the size of the binary numbers used in the machine to represent both instructions and data numbers. Whereas most commercial minicomputers have a word commercial minicomputers have a word of the comparison co Again, this has been done to reduce both cost and circuit complexity. The main penalty arising from the reduced woro lengths that the machine can ormally deal with only modest numbers — between plus 127 and minus 128, inclusive. The relatively short word length has also made it necessary to reduce the number of augmented operate instructions, as will be explained later. I befieve both these limitations are acceptable in view of the savings made possible. The other main way in which the machine has been scaled down is in terms of the humber of input and output devices or "peripherals" which it is designed to communicate with at any one time. Whereas many modern minipromputers are designed to "interface" with up to as many as 20 r64 input and output devices at any one time, this machine will only interface with up to to so with up to the view of the property t This is a very minor limitation in a machine designed mainly as an educational tool, I believe, because the need to deal with large #### DIGITAL COMPUTER numbers of peripheral devices is largely confined to practical data logging applications. Just about all of the basic principles involved in input-output transfer can be demonstrated using two input and output devices, and in fact more devices would probably only confuse the situation. In any case the machine has been in any case the machine has been arranged so that the input and output devices simply connect to it via sockets out her case rear. If a total of more than four peripheral devices are built up or acquired, it is therefore quite easy to substitute devices as needed. Only four devices may be plugged in at any one time, that is all. What peripheral devices may be used with the computer? Within reason, almost with the computer? Within reason, almost anything. As part of the basic description, I hope to describe a suitably simple and low cost input keyboard unit, together with one or two appropriate output display units. After this I hope to give details for interfacing with punched-paper tape readers and punches. It may also be possible to give details of the types of input and output and output. devices, if opportunity permits. To a large extent, the range of possible input and output devices to which the computer may be connected will be limited mainly by your imagination. There seems no fundamental reason why it could not be hooked up to all sorts of equipment, for all sorts of jobs. Imyself aim to try out a few interesting possibilities, and 1 hope that readers will be encouraged to do the same. Of course, in view of the modest memory capacity of the basic machine, it will probably be necessary in some cases to come up with some pretty fancy interfacing circuitry to achieve the desired result. In other words, to make use of some relatively high-powered "hardware" in the peripherals to make up for the fact that the computer itself can't accommodate much "software" – ie, much program. Still, if you're at all adventurous, this should simply add to the challenge. My main aim in these articles will be to help you gain the necessary expertise, so that can go wherever your imagination leads. At this stage I should perhaps devote a few words to explain the basic electrical and physical construction of the computer. All of the main circuitry of the machine is designed around TTL digital integrated circuits (ICs.) There are a number of medium-scale or MSI devices, used mainly for the various registers, and one large-scale or LSI device — the memory IC. Apart from these, the remaining devices are all low cost "garden variety" 7400 devices. All should be readily available. No doubt some will wonder why I have not used one of the new "incroprocessor". LSI devices as the heart of the machine. This would have reduced the number of ICs used, to be sure; in fact the whole computer would probably have fitted on a single small printed board. However I decided against this approach quite early in the development of the project, for two reasons which I believe are conclusive. The first is cost. Microprocessor chips are still quite costly; at the time of writing they sell for about \$110 each. By the time one adds a memory device and the additional circuitry required to interface with a control console and input-output devices, this would make the cost of the resulting machine considerably higher than the one presented here. And I don't know about the reader, but I myself would probably be far too nervous to play around with any single IC costing more than a hundred dollars! But quife apart from the cost, there is the matter of teaching potential. A microprocessor chip is ideal for manufacturers wanting to build a computer into their systems as an integral part, but by its very nature it is not at all suitable for learning how a computer functions. With virtually all of the computer hidden away inside a 40-pin (C package, all of the real mysteries remain the property of the IC maker. As it stands, there are a total of 96 ICs in the basic computer, most of these being low cost 7400 series devices. Some 86 are used in the basic processor and memory sections, while the remaining 10 are used in the in- ternal input-output interface circuitry. If this number seems a bit large, consider that the ICs probably incorporate something like 7,000 identifiable transistor elements. Small wonder that this computer project just wouldn't have been worth considering before MSI and LSI devices became a reality about two years ago. Even with only 96 ICs to worry about, of course, the computer is still not a small project by do-it-yourself standards. If it had to be wired up in the old fashioned way, it would be an enormous job, and I doubt whether anyone would have been even remotely interested. With this in mind! have designed the unit so that virtually all of the wiring is performed by printed boards. There are eight boards in all making up the basic computer: a board which takes care of all the front panel or "console" wiring, an interconnection or "mother" board, and six plug-in boards which make up the various functional parts of the machine. As the mother board performs virtually all of the interconnections between the sockets for the plug in boards, the actual hard wiring involved in building the computer is very small. Essentially it amounts to little more than making the few dozen interconnections between the mother and front panel boards, together with the power sumply and input-quitual connector wiring. I should mention here that to keep the cost down, I have used only single-sided printed boards for the project. This inevitably means that wiring-up each board involves fitting a number of wire links, in addition to fitting the IC's and the few other components. While this approach would not be appropriate for commercial manufacture, where the time needed to fit links might well prove more expensive than double-sided not be appropriate supervision. boards, I believe it is the right choice where a home construction project is concerned. The saving in board cost is quite dramatic, and for the enthusiast should far outweigh the small increase in assembly time and tedium. At least, I hope so. The complete computer is housed in a metal case measuring about 30 x 10 x 35cm (WxHx01), or about 11 ½ x 4 x 14 inches. The basic machine draws about 3 amps at 5 volts DC, or about 15 watts. However! have designed the power supply so that it can supply power to a number of peripherals, to simplify interfacing. As a result the total power consumption may in practice rise as high as 50 watts or so. When one considers that this is probably still going to be less than the power consumed by the light bub in the room you are using the machine, it provides dramatic evidence of the advances which have been made in computer technology over the last few years. The first computers were probably somewhat simpler than this little machine, yet occupied a complete room and needed, their own nowers usinsstation! For the benefit of those who would like to know a little bit more about the computer they would end up with if they embark on his project. I have prepared a brief panel. At this stage the specification may not mean much to you, however, because it really presupposes a knowledge of basic computer operation. For most readers, whole point of the exercise, and if they whole point of the exercise, and if they known you who wouldn't be bothering. The main idea behind giving it here is to show that the computer is quite a capable little machine, despite the fact that it has been scaled down for home construction. It has just about all the basic capabilities found in modern computers, and is therefore able to demonstrate most aspects of computer operation, although for the present you'll prohably have to take my word for this. Incidentally, when the basic machine has been described, I will then spend some time discussing programming. So you need not be concerned that having built the computer, you won't know what to do with it. Naturally you won't become an expert programmer, but I hope you will emerge from all this with a sound basic grounding — if you can stick with it. Two aspects of the project remain to be discussed in this introduction. I think. One is the name we have given the computer. Like all good computers, it must have an impressive-sounding name — that's traditional. In this case we came up with the name "EDUC-8", and our excuse for this #### SPECIFICATION OF THE COMPUTER The machine is a complete stored program general purpose digital computer. Memory storage is provided by means of a bipolar static random-access integrated circuit (RAM), organised to have a capacity of 32 locations. Both instructions and data words use a format of 8 bits. Almost all processing is performed serially, with alternative clock rates of approximately 500kHz and 2Hz. Instruction cycle times are constant at either speed, at approximately 96 microseconds and 28 seconds respectively. Operation may be either continuous or on a single instruction basis, as desired. There are five main registers, comprising the program counter (PC), the accumulator (AC), the memory address register (MA), the memory buffer register (MB) and the instruction register (IR). The front panel of the machine is also provided with a switch register for manual loading of addresses, instructions and data. Six types of memory reference instruction are provided, consisting of logical AND (AND), binary addition (TAD), increment and skip if zero (ISZ), deposit and clear accumulator (DCA), unconditional jump (JMP) and jump to subroutine (JMS). A single address format is used for these instructions, but both direct and indirect addressing are available. Eight augmented operate (OPR) instructions are provided, comprising increment accumulator (IAC), complement accumulator (CMA), clear accumulator (CLA), rotate accumulator 1 bit right (RAR), rotate accumulator 1 bit right (RAR), rotate accumulator (12A), skip on minus accumulator (SMA) and halt (HLT). A number of these instructions may be combined, for programming economy. Three augmented input-output transfer (107) instructions are provided, each of which may be arranged to specify either an input or output device, and one of two possible devices in each category. The instructions are skip on device flag (SKF, SDF), transfer data between device buffer and accumulator (KRS, LDS) and reset device flag (RKF, RDF). The second and last of these may be combined for programming economy. The contents of all registers are displayed on the front of the machine by means of light-emitting diodes (LEDs), allowing the operation to be readily followed. Power consumption of the basic machine is approximately 15 watts, but rises to approximately 60 watts with some combinations of input-output devices. somewhat transparent pun is that the first part stands for "Educational Digital micro (u) Computer", while the figure 8 represents either the number of basic instruction types, or the word length, or both! Anyway, it IS a small or "micro" computer, and we hope it will prove useful as an educational tool. It must have some sort of name, and EDUC-8 is probably as good as any. Finally, there is the matter of cost. You have probably been wondering if I was ever going to be specific about this, and the truth is that I have deliberately left it until now to give you a chance to put the project in perspective. It is very difficult to be accurate about cost, because as most readers will be well aware, prices of electronic components are discustainty all the time. About the best laced do is tell you that as far as we can estimate, the complete basic computer will probably cost you about \$300 — maybe a little more, quite possibly a bit less. Don't forget that because the project is built on a number of boards, you can build it up progressively a module at a time, and distribute the outlay over a period of time. We will be describing the project with this approach specifically in mind, in fact, as quite apart from the cost angle there are other advantages in tackling the project in stoses. With a project this size there is a lot to be said for building up the key sections one at a time, and checking them out individually before the final assembly as a system. Well, that's the basic story on this new project of ours. I hope some of my own enthusiasm for it has rubbed off, and that by this stage some of you will be champing at the bit. Before I close this introduction, I must give grateful thanks to the many people who have helped me very considerably in the development of the project. I am indebted to John Houston and Val Rech of Fairchild Australia, Ron Bell of RCS Radio, Doug Evans of Ferguson Transformers, Peter Carter of A & R Soans, David Segal of Philips Elcoma, Brian Cleaves of Plessey Australia, Norm Volkman of Wardrope and Carroll Fabrications, and Erie Goodwin of Beneral Electronic Services – to name but a low of the many who generously conscious to the control of the many who generously constitution co There are also my fellow staff members at EA, who have been very tolerant of my involvement with and enthusiasm for the project. I must particularly express thanks to Bob Flynn, who has been of great help in the preparation of the printed board particularly. And last, but by no means least, I must express my very grateful thanks to my wife Laraine, for putting up with the long lonely nights and weekends when I have been either submerged in the workshop, or present physically but almost constantly preoccupied with a logic problem or printed board pattern. The things we electronics addicts inflict on our loved ones! #### STOP PRESS! Just as this issue was going to press, an advance copy of the July issue of the US magazine "Radio Electronics" reached us. In it they give details of Mark 8, a minicomputer based around the Intel 800 microprocessor IC and 1101 memory ICs. Our design is not the first, then, as it transpires — we were beaten by a few weeks! Ah well, such is life. Still, readers will now have a choice of two computer designs, each with rather different emphasis. ### Know Where You are Going Choose a career in the field of Electronics — the Nation's most progressive and fastest expanding industry. Advancement in this modern science demands technical ability, a sound knowledge of basic principles and applications. You can master the subject by training at the Marconi School, and be ready to grasp the opportunities that occur in the various branches of Radio Technology. BROADCASTING A thorough grounding is available to students in the broadcasting field, leading up to the P.M.G. Broadcast Station Examination. COMMUNICATIONS (Marine) An extension to the Broadcast Operators course and extending into the fields of Navigation Aids and Electronic Devices used in mobile communications as required by the P.M.G. Certificates of Froficiery. #### APPLIED SERVICING Comprehensive training in the maintenance and repair of radio and television receivers offers substantial rewards to competent technicians. Marconi Societa radio and television receiver radio and television receiver circuit applications, practical exercises in fault finding and alignment procedures. The Marconi School Radio Servicing correspondence course is approved by the N.S.W. Apprenticeship Commission Classes are conducted at: 67 Lords Road, Leichhardt. Day: 9 a.m. to 4 p.m. Evenings: 6 p.m. to 8.30 p.m. or by Home-Study Courses (except practical instruction on equipment). | SEND | FOR | PROSPECTUS | |-------|-------|------------| | There | is no | obligation | | | | | | NAME | | |---------|--| | ADDRESS | | MARCONI SCHOOL OF WIRELESS Box 218, P.O., Leichhardt 2040 A service of Amelicanted Wireless (Australasia) Ltd. # Our do-it-yourself computer: how it works This is the second in a short series of articles describing EDUC-8, our uniquely conceived build-it-yourself digital micro-computer project. Leading on from the introduction given last month, the author describes the various sections and registers making up the machine, and shows how they operate together as an automatic system. #### by JAMIESON ROWE Before worrying about the construction of our microcomputer, no doubt most readers will want to make sure that they have a reasonably clear idea of the way it works. I am therefore devoting this article to a description of the basic operation of the machine At this stage the aim will not be to make the reader intimately aware of every fine detail of the computer's operation, but rather to paint in the broad picture. More detailed discussion of the operation of each section will be given, but later on as we deal with the construction. I believe this progressive approach will belp the reader to assimilate the concests more readily. Let us begin with a brief revision of basic concepts. You will perhaps recall from previous reading that digital computers are rather unique electrical machines, in that they are capable of performing not just one function, but a number of atternative functions. In fact each computer has a one of which it can perform upon command; let in response to an appropriate instruction. By making the tricks ir. its repertoire as basic as possible, and by providing enough of them, the machine is made capable of performing an almost infinite variety of tasks. Any given task to be performed is analysed, and broken down into a logical savequence of the computer's basic tricks. It then follows that if the machine is made to follow the appropriate sequence of instructions, known as a program, it will perform the desired task. By changing the program, the machine can be made to perform different tasks at will. But the point to grasp is that whatever task is to be performed, the appropriate sequence of instructions must be devised, and fed into the machine. Although rightly called a "general purpose" machine, a computer can't do any task at all if it is not provided with a program. provided with a program. The important thing to remember about the instructions which command the machine to do its basic tricks is that they are binary numbers. Nothing more, nothing less. So that the program which tells the computer how to do a certain task is simply a string of binary numbers stored in its string of binary numbers stored in its memory. What is the difference between the instruction numbers stored in the computer's memory, and any other, numbers stored there? There is no difference as such. It is all a matter of interpretation. Essentially, any and every binary number stored in a computer's memory is potentially capable of making the machine perform one of its basis tricks. But at the same time, any given number in the memory only becomes an effective instruction when the computer interprets it as such. So that the trick is to ensure that the machine only interprets as instructions those numbers intended to be such. Basically this is done by indicating the location or address in the memory of the first instruction of a program, before pressing the "run" button to set it in the computer then interprets the numbers in successive memory locations as the subsequent instructions, unless commanded to otherwise by one of the instructions, considerable the conference of the contract Because its operation involves performing a sequence of instructions stored in its memory, a computer operates in a rhythmic or cyclic fashion. In operation it repeatedly fetches an instruction from the memory, interprets it, and then performs or executes the appropriate trick in its repertoire. This cyclic fetch-execute-fetch-execute seguence continues until halted either by the operator, or by an instruction which itself signifies "halt" This basic sequence of operations is shown in Fig. 1, which is a simple example of what is known as a flow chart. Such diagrams are often used in analysing and describing computer operation, as we shall see later, because they make it very easy to visualise what is going on. In this case the chart shows that after starting and performing the fetch-execute cycle for the first instruction, the computer effectively makes a logical decision as to whether it should halt or not. If the answer is no, it returns to fetch and execute a second instruction, and so on. This continues until the answer to the halt decision becomes "yes", either because the operator has pressed the halt button, or because the last instruction performed happened to be "halt" With the foregoing hopefully clear in the reader's mind, let us now look at the main sections of a computer with the idea of seeing just how it performs its tricks. Perhaps the easiest way of doing this is to look first at the sections of the machine involved with instructions, and then at those involved with data. Some sections will turn out to be involved with both, but this should not be a problem as our next step will be to see how the two groups are fused together to form the complete machine. Fig. 2 shows the basic sections of the machine involved with instructions. Probably the most easily recognised of these is the memory, and associated with this are two registers known respectively as the memory address register (MA) and the memory buffer register (MB). A register, you may recall, is a set of flip-flops or similar storage devices capable of containing a binary number. The function of the MA register is to hold and indicate to the memory the binary number address which specifies the memory location with which the machine is concerned at any particular instant. So that during the fetch phase of the machine's cycle, when the next instruction in the program must be read out of the memory the MA must contain the correct address of that instruction. This "next instruction address" is fed to the MA from the program counter (PC), a register whose sole function is to keep track of the computer's progress during a program. Initially, the starting address of the program is fed into the PC, for example by the operator using the console switches Then, when the number is fed from the PC to the MA to allow the first instruction to be fetched, at the same time the number is incremented (increased by one) and fed back into the PC. This ensures that during the next fetch phase, the MA will be fed with the address of the second instruction. At that time, the number is again incremented, and fed back into the PC ready for the third fetch phase, and so on The function of the MB register is to act as an intermediary between the memory itself and the rest of the machine, as far as the numbers actually stored are concerned. Thus when an instruction number is read out of the memory during a fetch phase, it first enters the MB - to regain its composure, as it were. From the MB register, the part of the instruction number known as the operation code is passed on to a further register, known as the instruction register (IR). Don't worry about the significance of the operation code now, as we will look at instruction coding shortly. For the present, it is sufficient to note that this part of the instruction number specifies which type of instruction has been fetched, and the function of the IR is to "remember" this vital information during the subsequent execute phase. Without the IR, the computer would literally forget what it was supposed to be doing! Within the IR register, the operation code is still in the form of a binary number. Associated with the IR is therefore an instruction decoder, whose purpose is to interpret this number and generate the various logic gating signals necessary to perform the appropriate trick. These, then, are the main sections of the computer involved with instructions. Now let us turn to look at the sections involved with data - i.e., the numbers with which the computer is to perform its tricks. These sections are shown in Fig. 3. As you can see, three of the sections from Fig. 2 also appear in Fig. 3 - the memory, the memory address register and the memory buffer register. And these perform the same functions with data as they did 1: BASIC OPERATION with instructions. The MA register is used to specify the address of a memory location into or from which a data number is to be transferred, while the MB register is used as an intermediary store between that location and the remaining sections of the computer. Together with these three sections we now have an accumulator register (AC), an arithmetic and logic section, and an inputoutput interfacing section. Essentially the function of the accumulator register is to retain or accumulate the results of calculations, as they are being performed. If you like, it is the "blackboard" which shows how the sums are progressing. The arithmetic and logic operations are not generally done in the accumulator itself, but in the associated arithmetic and logic section. However this section, the AC register and the MB register are closely associated, and all three are to some extent involved in most calculations. In binary addition, for example, the two numbers being added are placed initially in the MB and AC registers, and after they are added together by the arithmetic and logic section, the answer is placed in the AC register The final main section concerned with data is the input-output interfacing section. As the name suggests, this section carries out the functions involved in transferring data between the computer and its "peripherals" - the input and output devices. This involves not only the simple shuffling of numbers in one direction or the other, but associated tasks such as letting one side know when the other is ready to transmit or receive. At this stage we have looked briefly at those sections of the computer which are involved with handling either instruction numbers, or data numbers, or both. However the thoughtful reader already may have begun to suspect that there are still further sections of the machine, whose functions have as yet only been implied. These are the sections involved with run control and timing, and they are shown in basic form in Fig. 4. Basically the need for these sections arises because the computer operates in a cyclic fashion, as we have seen. Not only this, but in fact both fetching an instruction and executing it each involves a number of steps, which must be done in sequence. Gates must be opened and closed, registers fed with control signals and clock pulses. and so on, all in the right order. And quite apart from this there is the need to be able to control whether the machine is running or not and similar control functions The sections which perform these tasks are the clock oscillator, the run control circuit, the console control switches, the timing pulse generator, and the major state generator. The purpose of the clock oscillator is to generate the master pulse train which activates the entire machine when it is running. It is therefore by controlling the passage of these clock pulses to the remaining sections that the run control curcuit functions. Broadly speaking, it lets the pulses pass following a command to do so by the console control switches, and continues to let them pass until a command to halt is received - either from the switches, as before, or upon the arrival of a halt instruction. When the computer is running the clock pulses pass from the run control circuit to the next section, the timing pulse generator. The function of this section is to use the master clock pulse train to assemble a number of timing and gating signals, each of which may be used in various places throughout the machine to perform operations at certain times in each cycle. Finally there is the major state gener- ator, whose function is to define which of the phases or "major states" the machine is in at any given time. Immediately upon being set running, the machine always enters a fetch state or cycle, as we have seen from Fig. 1. At the end of the fetch state it then normally enters the execute state, although as indicated in Fig. 4 there is a third and intermediate state known as "defer". More will be said about this shortly. Finally at the end of the execute state, the machine either returns to fetch and continues, or halts. I hope the foregoing description has at least given the reader a broad idea of the basic sections which form the computer, and of the general functions they perform. At this stage there will still be many questions unanswered, and you will perhaps be feeling rather unsatisfied. However now that some of the foundations have been laid. we can delve into things in a little more detail. Let us first look at the instruction coding format used - ie, the way in which the binary numbers which act as the in- structions for the machine are actually arranged to specify what is to be done. As you might recall, EDUC 48 uses an 8-bit word format. In other words, both the instruction and data numbers handled in the machine are 8 bits long. For convenience the 8 bits are labelled from 0 to 7, with bit 0 being the least significant bit in terms of binary weighting, and bit 7 the most significant. When such a number is interpreted by the computer as an instruction, the three most significant bits — bits 7, 6 and 5 — are taken to represent the operation code. It is these three bits which are stored in the instruction register and decoded, to specify which type of instruction "tick" is to be performed. Now you will perhaps remember from basic theory that three bits of information can only represent eight different situations, because there are only eight different bit combinations: 000, 001, 010, 011, 100, 101, 110, and 111. This means that there are basically only eight different types of instruction in the machine's repertories. Six of these eight basic types of instruction are known as memory reference struction are known as memory reference instructions, because they each involve some sort of operation with a number stored in a location of the memory. Either a number is taken out of the location and used for an arithmetic or logic operation, or a new number is stored in the location, or the number is interpreted as the machine's next instruction, and so on. The combinations of the three operation code bits used to represent these six instructions are 000, 001, 010, 011, 100 and 101. For convenience we will refer to the equivalent of these in the octal code, which convenient to think in terms of cotal code than in binary, and I suggest you brush up on the simple relationship between the two. We will be using octal notation fairly frequently from row on, but purely because the computer itself deals purely with the computer itself deals purely with the computer itself deals purely with The coding format used for memory reference instructions is shown in Fig. 5la, where it is indicated that the operation code bits 7.6 and 5 here specify one of the six combinations just referred to. The four least significant bits 0-3 inclusive) are used to define the address of the memory location whose contents are involved in the operation concerned. This is known as the operand address. Don't vorry for the moment about the special significance of bit 4; we will return to this shortly. Our more immediate concern is the six types of memory, reference in-struction, and what each involves. Their mnemoric names are probably already vaguely familiar, because they were given in the specifications panel. Hopefully now you will be in a position to follow the operations themselves. The instruction type with operation code O locatil is known as the AND instruction. Basically this involves reading out of the memory the number stored in the location specified by bits 0 to 3, and performing a locatil AND operation between this number location and the store of the community of register. The KN of the work of the register. The KN of the store of the property of the community of property of the community of accumulator. As the accumulator will be left with binary 1's only in those bit positions where both initial numbers were 1's, the effect is to "mask" the number in the accumulator with that in the selected memory location. As such, it can be a very useful operation. The instruction type with operation code I localla is known as the TAD instruction, which is short for "Two's addition." The is rather like the AMD instruction, only the operation performed between the number and that in the accumulator is bispay addition, using 2's complement arithmetic, instead of AMDing. As before the result is left in the accumulator. The TAD instruction is the main arithmetic instruction; it can be so the main arithmetic instruction; it can be forming the 2's complement of the number in the accumulator. But on the number in the accumulator before the TAD operation is performed. The instruction type with operation code 3 (octal) is known as the DCA instruction, short for "deposit and clear accumulator." As this suggests, it simply involves taking stored again in the same memory location. But if the number has become zero after being incremented, the machine also increments the contents of the program counter. This ymeans that the next instruction fetched will not be that in the next consecutive location, but that in the sole after that. In other words, the machine "skips" what would normally be the next instruction. Although it may not be apparent at this stage, the ISZ instruction is a very powerful one. Basically, it allows the machine to make changes in the sequence of instructions automatically during a program, as the result of checking its progress. The final memory reference instruction is that with the octal operation code 4. This is known as the JMS instruction, short for "jump to subroutine." Like the JMP instruction, it involves replacing the contents of the program counter register, so that the next instruction is taken from somewhere other than the next consecutive location. But in this case the existing contents of the PC are the number currently in the accumulator, and storing it in the memory location specified by bits 0 to 3. The accumulator is left cleared —ie, with a content of zero. The instruction type with operation code 5 (octal) is known as the JMP instruction, short for "jump." The effect of this instruction is to cause the address shown by bits 0.3 to be transferred to the program counter (PC) register, replacing the existing content of the PC. This means that instead of the machine fetching its next instruction from the next consecutive location, it will will be the content of the program content of the coation specified in the WP instruction because among other things it makes it possible for the machine to be forced to repeat a sequence of instructions many times. You will probably have noticed that we have so far ignored the instructions with octal operation codes 2 and 4. These are a little more complicated than the others, so they should be studied a little more carefully: The type 2 instruction is known as the ISZ instruction, short for "increment and skip if zero." It involves the following operations. First, the number in the memory location specified by bits 0-3 is read out, and incremented (increased by one). Then the machine tests the number, to see if it has become zero or not. The number is then not lost, as they are with the JMP instruction; instead they are stored, so that in due course the machine can return to the next consecutive location and continue. A subroutine, you may recall, is a small group of instructions which are used repeatedly throughout a program. Rather than simply repeat them at every place they received the simply received with would gobble up an expension of the simply arrange for the machine to jump over and perform them whenever they are needed. Naturally when this is done, it is essential that the computer by the simply are needed. Naturally when needed to simply a simply are needed. Basically what happens during the JMS instruction is that the current contents of the PC are taken and stored in the location the PC are taken and stored in the location specified by bits 0.3 of the instruction. At the same time this opening address is incredible to the PC. This has the effect that the properties of the PC. This has the effect that from the next consecutive location from that in which the original PC contents have been stored. In other words, the computer stores the address in the main computer stores the address in the main location of a subroutine, and will then proceed to work through the subroutine. How it actually uses the stored return ad-"get back" will be explained dress to shortly. Let us now return to Fig. 5(a), and look at the significance of bit 4. As you can see, when this bit is zero it implies something called "direct addressing," while if it is a one it implies something else called "indirect addressing. Thus far in discussing memory reference instructions, we have tacitly assumed that the only possible significance of bits 0-3 was to specify the actual address of the location in the memory occupied by the operand of the instruction. However this is only one way of using bits 0-3, the way known as direct addressing. It is the simplest way, and perhaps the way most readily visualised. However it is not the only way, nor the only desirable way. In fact there is another way of using bits 0-3, which adds very significantly to the flexibility of a computer from the programmer's viewpoint. In this alternative approach, bits 0-3 are interpreted as specifying not the actual operand address, but the address of a further location in memory, in which the actual operand address in itself stored. Not surprisingly, this approach is known as indirect addressing. At first sight, indirect addressing may seem nothing more than a more complicated way of doing the same thing as direct addressing. But in fact it opens up all sorts of new possibilities. For one thing, it provides the means whereby the machine can "get back" to the place where it left a main program, from a subroutine. All that need be done at the end of the subroutine is to provide a JMP instruction with indirect addressing, which specifies the address at the start of the subroutine in which the original return address was stored during the JMS instruction Another very useful application of indirect addressing is where an operation must be repeated with the numbers stored in a whole string of consecutive memory locations. By using a number in another location as an indirect addressing "pointer," the numbers in the consecutive locations can be made accessible very easily, simply by incrementing the number in the pointer location, between operations. Naturally enough, indirect addressing involves extra steps compared with direct addressing. The address specified by bits 0-3 of the instruction word must be fed to the MA register, and the actual operand address read out of that location. The need for these extra steps is the reason behind the third major machine state, defer, which we referred to briefly when dealing with Fig. 4. In short, the machine only enters the defer state, between fetch and execute, if it is necessary to perform the extra steps necessary for indirect addressing. Indirect address memory reference instructions thus involve three machine cycles, whereas direct address instructions involve only two Indirect addressing also has an advantage over direct addressing in terms of access to all possible memory locations. Unless a rather long instruction word format is used. it is not possible to directly address all locations in the memory. This is because the full range of memory locations involves more addresses than there are bit combinations available in the instruction word, after the operation code bits and direct / indirect indicator bit are accounted for. In EDUC-8, for example, only bits 0-3 inclusive are available for the operand address, and these four bits are capable of specifying only sixteen possible addresses, whereas the memory actually has twice that number. (If bit 4 were added, all 32 locations could be directly addressed, but we would then have no way of indicating indirect addressing). A similar situation exists with many computers, particularly those using relatively short words. This difficulty is avoided by arbitrarily splitting up the memory into groups of addresses called "pages," and adopting the convention that an instruction can only address directly those memory locations in the same "page" as the instruction itself. Thus in the case of EDUC-8 the memory is visualised as being split into two pages, consisting of the first sixteen locations and the last sixteen respectively. The computer is then designed so that when direct addressing is involved it automatically adds the missing fifth (most significant) bit of the operand address, making it the same as that of the instruction In effect, it "assumes" that the specified direct address is in the same 'page" as the instruction. While with indirect addressing it is still necessary for the location in which the actual operand address is stored to be in the same page as the instruction, the operand address itself can occupy a full word, and can thus specify any location in the whole of the memory. Thus with EDUC-8 the stored operand address can be anything up to 8 bits long, sufficient to specify 256 locations - ample for the 32 locations actually present, and with room for future memory Let us now look at the two remaining types of instruction provided by EDUC-8, and the coding formats used for them. The first we will look at is that with the operation code 7 (octal), which is known as the OPR 'operate" type of instruction. Although there is only the one operation code associated with this type of instruction, it is actually subdivided into eight different and distinct microinstructions, some of which may be combined to form further microinstructions. What makes this 'subdivision" possible is the availablility of bits 0-4; because this type of instruction does not make reference to the memory, these bits are not required for specifying an operand address. They can therefore be used to extend or "augment" the basic operation code. The way the additional bits are used to specify the eight different OPR microinstructions is shown in Fig. 5(b). Rather like the memory reference instructions, bit 4 is used as an indicator bit. However in this case it is merely used to indicate which of two possible meanings is to be placed on 1's in the remaining four places. When bit 4 is zero, bits 0,1,2 and 3 are used to specify the four micro instructions IAC, RAL, CMA and CLA respectively. On the other hand when bit 4 is a 1, they specify instead the microinstructions HLT, RAR, SMA and SZA respectively The mnemonic IAC stands for "increment accumulator." As the name suggests, this microinstruction simply involves incrementing or adding one to the number in the accumulator. If the AC is initially zero, then it will contain the binary number 1 following the IAC microinstruction The mnemonic RAL stands for "rotate accumulator left." This involves shifting the number in the AC one bit position to the left, so that the content of bit position 0 moves to position 1, 1 to 2, 2 to 3, and so on. The content of bit position 7, if there is any, is shifted around into bit position 0. For binary numbers less than the equivalent of decimal 127, RAL corresponds to multiplication by The third of this group of OPR microinstructions is CMA, which stands for "complement accumulator." It involves taking the number in the accumulator and changing it into its 1's complement - ie, each bit is turned into its complement. Bits which are initially zero become 1's, and those which are initially one become zero. If the AC is initially cleared (all zeroes), the DPERATION CODE (#LIDT MICROINSTRUCTIONS 5: INSTRUCTION CODING FORMATS hite all zero CMA instruction gives it a content of one. The fourth OPR microinstruction is CLA, which stands for "clear accumulator." This is almost self-explanatory: the contents of the AC are simply wiped out, leaving the AC The first of the OPR microinstructions for which bit 4 is a 1 is HLT, short for "halt. The effect of this instruction is simply to cause the run control circuitry of the machine to ston the passage of master clock pulses to the timing pulse generator, at the end of the current execute cycle. The next of these is RAR, standing for rotate accumulator right." This is virtually the opposite of the RAL microinstruction. causing the number in the AC to be shifted one position to the right. The content of bit 1 is moved into bit 0, that of bit 2 into bit 1. and so on. The content of bit 0 is moved around and into bit 7, so that as before no bits are lost. In effect the RAR instruction corresponds to a division of the number in the AC by two. The seventh of the OPR microinstructions is SMA, which stands for "skip on minus accumulator." The effect of this instruction is to cause the content of bit 7 of the AC to be tested, to see if it is a 1 (by convention. the most significant bit of a number is taken to indicate its sign - 0 means positive, 1 negative). If this bit is a 1, the contents of the PC register are incremented, so that the next instruction is fetched not from the next successive memory location but from the struction, which stands for "skip on zero accumulator." This is similar to the SMA instruction, but involves a test of all bits of the AC, not just bit 7. In this case the contents of the AC are incremented only it all AC bits are zero, so that a clear AC causes the next instruction to be skipped. The SMA and SZA microinstructions are both very powerful ones from a programmer's viewpoint, because they provide a means whereby the program can test the result of a calculation, and automatically decide upon a course of action Some of the OPR microinstructions may be combined to form further microinstructions. Thus CLA and IAC may be combined, allowing the AC to be given a content of 1 by means of a single instruction. Similarly CLA and CMA may be combined, which has the effect of setting the AC to a content of 1. The CMA and IAC microinstructions may also be combined, allowing a number in the AC to be changed into its 2's complement using only one instruction. And finally the SZA and SMA microinstructions may be combined, so that the next instruction is skipped if the AC is either zero or minus. The main advantage of these combined microinstructions is that they save memory snace, allowing more program to be fitted into a given number of locations. They also make a program run faster, because in effect two separate "tricks" are done in a single execute cycle. The final type of instruction provided by EDUC-8 is that with the operation code of 6 (octal). This is known as the IOT instruction type is also sub-divided into a number of microinstructions, and as the name suggests, these are all concerned with the transfer of information between the computer itself and any input and/or output devices to which it may be connected. The coding format used for IOT microinstructions is shown in Fig. 5(c). As before bits 7, 6 and 5 are used for the operation code, in this case 6 (or binary 110). And bit 4 is again used as an indicator bit, this time to specify whether the instruction concerned refers to an input device, or an output device. A zero is taken to specify an input device, and a 1 an output device Bit 3 is also used as an indicator bit, in this case to select which of the two devices of each type the instruction is concerned with. Thus if bit 3 is a 0, the instruction is concerned with either input device "0" or output device "0", depending upon the value of hit 4. Similarly if hit 3 is a 1, the instruction is concerned with either input device "1" or output device "1" Between them bits 3 and 4 are thus used to specify which of the four possible inputoutput devices an IOT microinstruction is concerned with. Hence even when four devices are connected to the computer. each can be dealt with individually. Bits 0, 1 and 2 of the IOT instruction format are used for the three different types of IOT microinstruction. In other words, these three hits form the augmented operation code. When bit 0 is a 1, this corresponds to a "skip on device flag" microinstruction. The effect of this microinstruction is to check whether the input or output device con- part in a transfer of data, by setting a flipflop known as its "flag". If the flag is indeed set, the contents of the PC are incremented so that the next instruction is fetched not from the next successive memory location, but the one after. There are two alternative mnemonics for this microinstruction, SKF and SDF, used for input and output devices respectively. In either case the purpose of the microinstruction is to allow the computer to determine when a peripheral device is ready to "do business." The second type of IOT microinstruction is that having a I in the bit I position. This is the "shift data" microinstruction, represented by the memonics KR\$ (input) represented by the memonics KR\$ (input) and ID\$ (output) respectively. As the name suggests, this microinstruction is the one which actually cause data to be transferred between the computer and a peripheral. In standard the computer will be a confident of the computer will be a confident of the computer. With an output unit, the data is transferred from the that AC in the configurer. With an output unit, the data is Finally, there is the third type of I off microinstruction, in which bid 2 is a 1. The is the "reset device flag" microinstruction, presented by the memorices RKF (input) and RDF (output). Fairly obviously, this microinstruction causes the flag flip-flop in the device concerned to be reset, and it allows the computer to signal to the peripheral device that a data transfer is complex. This allows the device concerned complex flip is allows the device concerned the complex flip is allows the device concerned properties. The standard properties are needed to prepare for a further data stansfer. The "shift data" and "reset devote flag." In microstructions may be combined, as they take place at successive times in the accure cycle. This forms the "shift data secure cycle. This forms the "shift data memorias KRB (input) and LDB (output) in which there is a 1 in both bir positions 1 and 2. As before, the advantages of the combined microinstruction are the saving in memory space, and an increase in running order that instructions for the price of order than the combined microinstruction are the price or order. By this stage you are perhaps beginning to wonder just how the computer does all these things. And that is, so to speak, the 50,00 colar question. In the limited space of \$0.00 colar question. It was the interest pace of the principles involved. Hopefully the will be present I will fire to give you a basic idea of the principles involved. Hopefully this will be sufficient to provide the background necessary for the more detailed analysis which will be developed as we look at each which will be developed as we look at each The basic organisation of EDUC-8 is shown in Fig. 6. This is essentially a combination of Figs. 2, 3 and 4, with the addition of a little more detail. You will hopefully be able to recognise the registers, such as the PC, the AC, the MA, the MB and the IR, together with such sections as the memory, the input-output interface, and the timing pulse generator. The arithmetic and logic section has been broken down into its component parts, which are now identified as a serial adder, a carry flip-flop, and an AND gate. The various signal paths between the registers and sections are now shown in more specific form, with controlling AND gates indicated in various strategic positions. These are numbered so that we can refer to each conveniently. Note also that there are four main signal "highways" or bus lines, arbitrarily labelled the A-bus, the B-bus, the C-bus and the D-bus. The main control signals fed to each register and section have also been indicated Essentially, the computer functions by means of control signals applied to the registers and the gates controlling the various signal pathways. And the control signals are formed by suitable combinations of signals from these sources: the timing pulse generator, the major state generator, and the in- struction decoder. At first sight this seems a delightfully general and vague statement, I know. The only real way to give it more meaning is to look at a specific example. Hopefully you will then begin to see the general principles involved, and will be able to visualise more of the machine's operation for yourself. Let us consider the fatch cycle, in which as we have seen the order to the cycle, in which as we have seen the order to the cycle, in which as we have seen the order to the cycle in mext instruction from its memory logation, and decode it ready for execution. You may recall that the address of this instruction is contained by the PC register, prior to the start of the fetch cycle. What happens is this. At the start of the fetch cycle, the carry flip-flop is set fetch cycle, the carry flip-flop is extra to contain a 1 by means of a signal applied to its direct set input. This signal is produced by combining the "fetch" signal from the major state generator with a suitable timing pulse from the timing pulse generator. Following this gate 1 is opened for five clock periods, by means of a control signal produced by combining the "fetch" signal with another signal from the timing pulse generator. And because gate 1 connects the output of bit 0 of the PC register to the C-bus, to which the bit-4 input of the MA register is connected, this has the effect of connection the PC output to the MA input. The same control signal used to open gate is also used to admit clock pulses to the PC and MA registers, so that they are simultaneously activated as shift registers. Thus the number in the PC is shifted into the MA, ready to be used to read out the instruction. At the same time, the same control signal is used to open gates 2 and 3, connecting the C-bus to the A-bus through the serial adder. This has the effect of connecting the output of the PC back to its input, via the adder. And the control is used also to admit clock pulses to the carry flip-flop, so that it can take part in the operation. The effect of this second set of operations is that the number initially in the PC is not only shifted into the MA, but is also shifted back into the PC - incremented. The incrementing takes place because the carry filp-flop was set to contain a 1, before the shifting took place. Hence the number in the PC is now incremented, ready to provide the address of the next instruction — needed for the next fetch cycle. During the next part of the fetch cycle, another control signal of eight clock periods duration is produced by combining the fetch' signal with a suitable signal from signal sig Following this yet another control signal is produced, lasting for a single clock period. and again formed by combining the "fetch" signal with a suitable signal from the timing pulse generator. This control signal is, used to enable the IR register and decoder the two are actually combined in a single ICI, so that the operation code formed by birs 6 and 5 of the instruction are taken from the MB, stored and decoded. with stored and decoders of the feet Finally, the last operation of the feet production of yet another control signal, formed by combining the "feets" signal as before with both a suitable signal from the mining pulse generator, and a signal from the immining pulse generator, and a signal from the mining pulse generator, and signal from the whether or not the instruction fetneds as whether or not the instruction fetneds as memory reference type or not. The control signal flust formed is used to open a gate (not shown) which connects the output of that 4 of the Mit register to a flip-flop in the status flag." The purpose of this last operation is to signal the presence of an indirect addressing memory reference instruction, if one is present, to the major state generator. This is othat the major state generator will enter a defer cycle, if necessary, before starting the execute cycle. I hope this example will start to give you an idea of what was meant by the bold face paragraph above. Although we won't be able to trace through the operation of the machine during the defer cycle or the execute cycle – particularly for each of the various types of instruction (I)—you may by now be able to see the basic principles involved. Table 1 gives an analysis of the steps involved in each of the various machine cycles. Using this and the example just given as a guide, you should hopefully be able to trace out what happens in each case. trace out what happens in each case. In a nutshif, the various major states or do the signals generally states or do the signals generally states or do the signals states of the signals from the signals from the signals from the signals from the support of the signals from As the table shows, each cycle lasts for a total of 24 clock pulse periods. Nor all of these periods are used to generate timing signals and initiate operations, but the 24-period duration of the cycles has been used to simplify the circuitry of the timing pulse generator. At the two atternate clock pulse areas provided, each cycle lasts for 48 microseconds or 12 seconds, respectively, sequence lasts for 58 microseconds and a fetch-defer-execute sequence lasts for 58 microseconds and a fetch-defer-execute sequence. You will perhaps have noticed from the table that besides the fetch, defer and execute cycles, there are two further cycles which we have not yet mentioned. These are marked deposit and examine, and perhaps their names have already suggested their purpose. Basically, these are both special "oneshot" cycles mainly associated with control switches on the front panel of the machine. Deposit is used to manually enter numbers (such as instructions) into selected memory locations, while examine is used to manually read out the contents of selected memory locations, who are the selected memory locations, for checking. Both are used | | | | | | | | | | | | CTIONT | | | | | | | | |---------|-------------|------------------------------------------------------|--------------------------|-----------------------------------------------------------------|-------|-------------|--------------|-----|-------|----------------|---------------------------|----------------|------|--------------------------|--------|-------|---------------------------|----------------------------------------------------------------| | | YCLE | T0 | T1 | T2 - | T5 | | T9 | T10 | T11 | T12 | T13 | T14 | | T17 | _ | | T22 | T23 | | F | ETCH | Clear<br>MA, IR,<br>carry<br>(also<br>mem<br>strobe) | carry | | PC t | to N<br>+ 1 | IA,<br>to PC | | | clear<br>carry | | Read | inst | ruction | n into | МВ | Load IR<br>(last<br>half) | set defe<br>status,<br>MA4 to<br>MB4<br>if m. rei<br>instruct. | | D | EFER | Clear<br>MA,<br>carry,<br>mem<br>strobe | MBO-4<br>to<br>MA | | | | | | | ditto | | Read<br>into N | | perand | ade | dress | | | | | AND | ditto | ditto | Read out operand into<br>MB, AND with AC, result<br>into AC | | | | | | ditto | | | | | | | | | | | TAD | ditto | ditto | Read out operand into<br>MB, 2's add with AC,<br>result into AC | | | | | | ditto | | | | | | | | | | | ISZ | ditto | ditto,<br>set<br>carry | Read out operand, in-<br>crement and put result<br>into MB | | | | | | ditto | Set carry<br>if MB=0 | Write | co | ntents<br>circu<br>throu | late | PC | | | | | DCA | ditto | MBO-4<br>to<br>MA | Write contents of AC, load into MB also | | | | | | ditto | | | | | | | | | | | JMS | ditto | ditto | Write con<br>load MB | tents | of P | C, also | | | ditto | Set<br>carry | | | Shift<br>PC vi | | | | | | | JMP | ditto | ditto | | | | | | | ditto | | | | Shift<br>PC (v | ia ad | der) | | | | | SKF,<br>SDF | ditto | | | | | | | | ditto | Set carry<br>if flag =1 | | | Circu<br>throu | | | | | | | KRS,<br>LDS | ditto | | Shift data<br>and AC | betw | een | device | | | ditto | | | | | | | | | | EXECUTE | RKF ditto | | | | | | | | | ditto | reset i/p<br>flag | | | | | | | | | Ä | RDF | ditto | reset<br>o/pflag | | | | | | | ditto | reset o/p<br>flag | | | | | | | | | | IAC | ditto | set<br>carry | Circulate<br>adder | AC | th | rough | | | ditto | | | | | | | | | | | RAL | ditto | shift<br>AC one<br>bit L | | | | | | | ditto | | | | | | | | | | | CMA | ditto | | Circulate AC through inverter | | | | | ditto | | | | | 4 | | | | | | | CLA | ditto | | Shift contents out of AC | | | | - 2 | ditto | | | | | | ê | | | | | HLT | | ditto | | | | | | | | ditto | | | | | | | | reset<br>run flag | | | RAR | ditto | | | | | | | | ditto | Rotate<br>AC<br>one bit R | | | | | | | | | | SMA | ditto | | | | | | | | ditto | Set carry<br>if AC = - | | | Circu | gh a | dder | | | | | SZA | ditto | | | | | | | | ditto | Set carry<br>if AC = 0 | | | Circu | gh a | | | | | DE | POSIT | ditto | carry | | PC - | | to PC | | | ditto | Load MB<br>from SR | restor | e in | MB | | МВ, | | reset<br>run flag | | EX | AMINE | ditto | ditto | | | ditto | 0 | | | ditto | | | Read | d into | МВ | | | reset<br>run flag | primarily for loading in programs via the console switches, and then checking that the instructions have been loaded in correctly. Associated with the deposit and examine switches on the front panel of the computer is a third switch, marked load address. The function of this switch is to allow a starting memory address to be loaded into the PC register prior to either depositing, examining, or setting the machine running. The remaining controls will be discussed next month, when we start dealing with the construction of the machine. Stay with us! # Our EDUC-8 computer: starting construction Having introduced our unique digital computer project and described how it works, the author now starts to describe its construction. Both circuit and wiring details are given for the power supply, front panel board and mother board sections, which together form the foundation of the machine. #### by JAMIESON ROWE EDUC-8 is built into a case of about the same size and shape as a medium-powered stereo amplifier. The case measures 29,3cm vide, 10,3cm high and 35 7cm deep — or 11.5 x 4 x 14 inches, if you prefer. The prototype case is made from 20 gauge stell, and is finished in chocolate hammertone lacquer. The case is made in two sections, with the main section forming its base, sides and rear. The front and top are provided by the second section, which is designed to slide on from the front. Once assembled the two are held together by a lip at the rear and by four small self-tapping or "PK" screws. No components whatever are mounted on the front panel-top section of the case, which serves purely as a cover and control escutcheon. This has been done deliberately, so that the machine may be operated easily with the cover removed, to facilitate servicing. The power supply wiring of the machine is built into the rear of the case, with the two series-pass power transistors and their finned heatsinks mounted on the case rear itself. Also mounted on the case rear are the sockets for interconnection with the input and output devices. The actual computer proper is an assembly of printed wring or "PC" boards, mounted in the front section of the case. Two of the PC boards are mounted vertically, spaced behind the plane of the case front panel by about 2cm and 3cm respectively. The remaining six boards plug into edge-connector sockets mounted on the second of the two vertical boards, to form a vertical stack array. The vertical board nearest the front panel plane performs all of the wiring and in-terconnections between the front panel components — console switches, LED indicators and so on. For fairly obvinches, LED indicators and so on. For fairly obvinches are second vertical board makes reasons it has been dubbed the "front panel board". The second vertical board makes the plane of the properties propertie In vertical order from the top down the plug-in boards respectively provide the country for the run control, major state country for the run control, major state (EB/T); the instruction register and decoder (EB/T); the memory, memory address and memory buffer registers (EB/M); the program counter and serial address (EB/F) the accumulator (EB/A); and the input output interfacing circuitry (EB/T)(T). Each of these six boards measures 21.5 by 16cm, of these six boards measures 21.5 by 16cm, in the practices of the country Space has been left in the case so that the plug-in PC boards may be easily removed replaced. The space also allows any one board to be "extended out" for convenient access during operation, by means of extender board. This is simply a PC board #### It's growing! Due to the falling prices for memory LG, it is now possible to provide EDUC-8 with a 128-word memory at virtually no more than the original cost of the 32-word version. In view of this we are modifying the design, so that as actually described EDUC-8 will have a 128-word memory — four times the original size. Provision is also being madde for expansion to 256 words, if despression wo with etched contacts along one end, with conductor strips connecting these to the pins of edge connector sockets mounted at the other end. Thus by plugging the extended the pins of edge connector sockets and the pins of edge of the pins of edge of the pins of edge of the pins th To remove a board and replace it with the extender board, the boards above it must be temporarily removed to allow access. The desired board is then removed, and replaced by the extender board — with the sockets on the latter facing upward. The other boards and then be replaced, and finally the temporary of the extender board if the prortuges vertically from the board stack, allowing ready access to both sides. With the exception of the extender board, which is made from normal SRBP, all of the PC boards in the prototype are made from epoxy fibreglass laminate, and this is probably preferable in view of its greater A view of the machine with the top/front panel removed. Note that the front panel board visible is an early version. strength. However it is also a good deal more expensive than SRBP and the newer fireproof bakelite laminates, both because of the higher cost of the laminate itself and because it is tougher on drills. Whether this extra cost is really justified is a moot point. Largely for emotional reasons rather than objective, fibreglass boards have become traditional for "serious" projects such as this, and there will no doubt be some who will want to obtain the boards made from this material regardless of cost. However if you're a little daunted by the cost. I don't by any means suggest that you should regard fibreglass as essential. Provided that they are handled with reasonable care, SRBP boards should be quite satisfactory I do suggest, though, that you get boards which are gold flashed - at least along the edge connector pads. This will make for very much more reliable connections, and is well worth the small additional cost involved. An electro-deposition process, gold flashing gives the copper pads a coating of gold which is thinner than the more expensive plating, but entirely adequate for this sort of situation where the boards are not going to be repeatedly removed and replaced Probably the best place to start construction of the computer is with the power supply, as this can then be used to power the other sections as they are built up. Apart from having the psychological appeal of letting you produce some working circuitry early on, it will also allow you to check the operation of the various boards as they are completed. The order in which the boards will be described has been deliberately arranged so that this "checking as you progress" technique can be exploited as much as possible. As you will perhaps have noticed already, the power supply circuit is very conventional, its only noteworthy aspect being that it has been designed to deliver up to 6 amps at a nominal 5V. It uses a conventional bridge rectifier driven by a suitably rated 10V stepdown transformer. The rectifier bridge is of the type having four highcurrent silicon diodes mounted in a single package, such as the EDI type PB40. The reservoir capacitor should have a value of at least 15,000 uF, to cope with the heavy drain. It should also have a ripple current rating of at least 5A, for the same reason. Generally this means that we are talking about a "computer grade" electro, a suitably impressive price tag-However as this is the main reservoir electro for the whole machine, it is worth getting the best you can afford. There are three types available at the time of writing which appear to be quite suitable. These are the Nippon Chemi-con type EW16LGSN-15.000B, available fron Allied Capacitors; the type ELL-52052, made locally by Plessey Australia; and the type B41455 from Siemens Industries. The first of these is 15,000uF, while the other two are 22,000uF. All are single-ended clamp mounting types. The regulator circuit uses conventional discrete transistors, rather than an IC. This has been done partly because there have been, and still are to a certain extent, supply problems associated with some of the most suitable regulator ICs. A further reason is that I have found it rather difficult to come up with a 6 amp regulator circuit using an IC, which is as stable as this simple discrete circuit, without going to considerably greater complexity and cost. \*\*\*\* \*\*\*\* At top is a close-up shot of the power supply and IOT connector wiring, with the circuit of the power supply above. At right are details of the wiring on the small power EDUC-8 POWER SUPPLY supply resistor panel. There are only five transistors used, with two 2N3055 power devices in parallel as the series pass element. These are driven by a medium power TO-5 PNP driver device. which is driven in turn by two low power NPN devices acting as the error amplifier. The reference source is provided by a 6.2V zener diode, this voltage being close to optimum from the point of view of temperature coefficient. A simple resistive divider across the zener establishes the nominal 5.2V reference against which the output of the regulator is compared. The two 0.33 ohm resistors in series with the 2N3055 emitters are swamping resistors, to ensure that the two devices share the load current equally. The two 10 ohm series base resistors with their 4700pF associated collector-base capacitors, together with the .022uF capacitor across the driver are to ensure that WITH CLIP ON HEATSIN the regulator is stable for all normal load impedances. Without these components to "throttle back the gain" at high frequencies, this sort of circuit can become a very effective oscillator with caproitive loading, due to the excellent gain-bandwidth product of the silicon transistors! The two .047uF capacitors bypassing either side of the power transformer secondary are for RFI filtering, incidentally. Without them, the operation of the machine can be disturbed by mains switching transients and other rubbish which can find its way in via the transformer. The filtering provided by the two simple bypasses has been found quite effective, and no further protection should be necessary providing your machine is housed in a similar earthed metal case. Despite the simplicity of this power supply circuit, is performance is quite good. Output voltage drops by only 0,12V when the load current is changed from 500mA to 6 amps, which is more than adequate for his sort of application. Similarly the output ripple is well down, being less than 50mV peak to peak even at the nominal full load current of 6A. This means that the supply is easily capable of delivering the nominal 3 amps required for the basic computer, with another 3 amps available for powering the logic in peripherals. Incidentally this supply would perhaps be worth considering in its own right as a general-purpose heavy duty 5V supply for logic development work. It is fairly rugged, and will even take direct shorts across the output providing they are of reasonably short duration. As there are only a handful of parts used in the supply apart from the larger components such as the power transformer and reservoir electro, it has been wired up in conventional fashion using a small length of miniature tagstrip. Needless to say, the wiring is not particularly critical, the main thing being to wire up the leads carrying the full load current in fairly heavy wire. The basic wiring of the tagstrip is shown in the small diagram, to serve as a guide. The rest of the power supply wiring should be easy to work out from the close-up photograph. The two series-pass transistors are mounted on individual 10-cm square finned heatsinks, using the usual silicone greese, mice or plastic insulation shim and restricted to the silicone greese, mice or plastic insulation shim and earthed device cases from the heatsinks and earthed farme. Don't forget that the mains flex should enter the case through a grommetted hole, be clamped upon entry, and have the active and neutral wires terminated in a screw connector strip. The earth wire should be soldered to a lug screwed to the case, to ensure a reliable machine earth. Note that the PNP driver transistor should have a small clip-on heatsink. This can be one of the fancy moulded types if you like, although a few square centimetres of 18 or 20 gauge sheet brass bent into a suitable "flag" or "9" shape will do just as well. As soon as the supply is wired up and you have checked to make sure that no obvious errors have been made, it can be switched on — or "powered up", to use the appropriate computerese — and its output voltage checked. Regulation and ripple can also be checked if you have the facilities, although if the open-circuit output is right the rest will probably be in order also. As with most simple supplies, the open circuit voltage tends to be a little higher than when even a small load current is drawn. It should measure between about 5.3 and 5.4 volts, dropping to about 5.12V at about 50mA drain and then dropping much more slowly to around 5.00V at 6A. If your supply is consistently higher or lower than these figures, the cause will almost certainly be due to the zener tolerance. The remedy is simple: adjust the value of either the 120 or 470 ohm resistors across the zener, using higher value shunt resistors, until the desired voltages are produced. Pad down the 120 ohm resistor in this way if the voltage is low, or the 470 ohm resistor if the voltage is high. With the power supply operational, you will then be in a position to start on the actual computer itself. I suggest that you begin with the front panel board, as this will let you see how the finished machine is going to look. And with the board completed and hooked up to the power supply, you will have an impressive array of lights and switches to demonstrate your progress to others! The circuitry which is associated with the front panel board is shown in the diagram. Above are wiring diagrams for the front panel board (top) and the mother board, showing all parts and interconnections. and as you can see it is not particularly complex. Seven of the ICs used are hex inverter (7405) or hex buffer (7417) devices, whose elements are used to drive the 42 LED indicators. The two different circuits used for the LED drivers are shown down in the lower right of the diagram, with a legend showing which signals use each version. Basically those signals available in positive logic form use the inverser element drivers, while those in negative logic form use the inverser ingent the rivers. Immediately above the LED drivers in the diagram is the switch register, which is simply eight switches and the same number of 10k pullup resistors. This is a simple way of generating static high or low logic levels, and is all that is required. No suppression of contact bounce is required, as the switches are not involved in dynamic operation, The remaining front panel circuitry is that associated with the control switches. This uses four low cost 7400 or 9002 quad gates, together with a 9602 dual monostable or "one-shot". The three control switches which initiate running of the machine — the RUN, EXAMINE and DEPOSIT switches — are fitted with bounce suppression flip-flops which each use two 7400 gates. These ensure that only a single, clean level transition occurs whenever these switches are pressed or released. One of the 9602 one-shot elements is used to sense whenever one of these three switches is pressed, and to generate a single pulse in response. This pulse becomes the RUN COMMAND signal (negative logic), which is sent to the timing and control board to set the run flag flip-flop and start the machine running. This attention of the control The output of this flip-flop becomes the DEP+EXM logic signal (negative logic), which is used throughout the machine to distinguish an examine or deposit cycle from normal running. Similarly the output signal from the deposit debouncing circuit is also taken away as a further logic signal, to distinguish deposit from examine. Note that provision has been made for a deposit cycle to be initiated by an external negative logic signal, as an alternative to depressing the front panel switch. This has been done to permit convenient loading of programs by means of "hardware loader" logic in an input device such as a paper tape reader. Before a program can be fed into the machine by a sequence of deposit cycles, or checked by a sequence of examine cycles, its starting address must be loaded into the program counter (PC) register. The same operation is also necessary before the program can be set running, in order that the first instruction fetched will be the correct one. This function is performed by the LOAD ADDRESS key, which as may be seen generates a negative logic signal by simply shorting the lower end of a 10k resistor connected to the 5V line. Provision has also been made for the same function to be performed remotely, by what effectively becomes an external negative logic LOAD ADDRESS signal. In either case the resulting negative logic signal is inverted and used to generate two signals which are fed to the PC register to cause it to be loaded by the logic levels present on the switch register output lines SRO-6 inclusive (or SRO-7 inclusive with the extended memory). The two signals are LA1 (negative logic), which is used to clear the PC, and LA2 which is used to perform the actual loading. As may be seen, the circuit which produces the two signals is quite simple, using a two-input gate, the second one-shot element from the 5802 device, and a further gate used as an inverting buffer. The one-shot is arranged to trigger only on negative-going edges of the inverted land therefore positive logic! LA signal, so that if the load positive logic! LA signal, so that if the load to the shot would not operate until the key were released. If we ignore bounce for a minute, then, it can be seen that the C-bar or complementary output of the one-shot will remain in the high logic state while the LA signal is present, because the one-shot will not yet have trigered. As a result the gate producing the LA1 signal will have two high outputs, and will produce the signal to clear the PC register. Then, when the key is released, or the external LA signal will go in equal to the gate connected to the LA signal will go causing the gate output to go high and thus causing the gate output to go high and thus time the one-shot will trigger, causing the Obor output to go to the low state for a short time. As a result the inverting buffer attached to this output will produce the LA2 produces the control of the control of the stacked to this output will produce the LA2 produces the control of the control of the trigger of the control of the trigger of the control of the trigger tri Although you might think that this neat chain of events would be foulded up by contact bounce in the LOAD ADDRESS (ex, this init is 0.1 you trace through the credit you'll see that the only effect of the contact you'll see that the only effect of the contact you'll see that the only effect of the contact you'll see that the contact you can be caused and the case of the contact you definition cause a negative-going transition of the first left key is released will always by definition cause a negative-going transition at the linguit of the one-shot, the last event at the linguit of the one-shot, the last event pulse. Hence despite bounce, correct loading always takes place. It is because the load address circuit is unaffected by bounce that the LOAD ADDRESS key is not provided with a bounce suppression flip-flop as fitted to the The rear of the case, showing the IOT connectors and regulator transistors RUN, EXAMINE and DEPOSIT keys. There is no point in having a flip-flop if it is not necessary. One of the three remaining switches on the front panel board is the SLOW/FAST switch, which in the slow position completes the earth return incruit of a 47uF tantalum electrolytic capacitor. The other end of the capacitor connects to the main clock pulse generator on the timing board, to alter its operating frequency. The remaining two switches are the HALT key and the SINGLE/CONTINUOUS writch, which as may be seen are both in parallel. Both have the effect of producing as an OR element, to produce a gate as as an OR element, to produce as a set as an OR element, to produce the input of the OR gate is fed from the HLT instruction output line (negative logic) of the instruction doceder, so that the same HALT COMMAND signal is generated in the event of a "halt" instruction. The effect of the HALT COMMAND signal is to acuse a reset pulse to be fed to the run control flag flip-flop in the timing circuit, at the beginning of the second half of 1723 of the next EXECUTE cycle. This in run causes the main run control flip-flop to the reset at the eno of 1723, so that the machine stops running after fully completing the current fetch-execute cycle. The run control flag flip-flop can only be reset during T23 of an execute cycle, and then only if the HALT COMMAND single is present. This has a number of implications, some of which will be discussed later. One implication is that it is guite in order for the RUN and HALT keys to be pressed at the same time — contradictory though this may sound. Since the HALT key is affectively only sensed during T23 of the executes copy pressing both keys together and holding them both down simply couses the machine to run for a single complete fetch-execute (or fetch-defer-execute), cycle. In other words, it performs a single instruction step – nothing more, nothing less. So that if the HALT key is held down continuously and the RUN key pressed repeatedly, the machine will simply step through a program one instruction at a time. This can be very handy for analysing the operation of a program — particularly if it is not doing what you expectant. It can be rather tedious having to hold the HALT key down for any length of time, though, and this is why the SINGLE/CONTINUOUS switch is provided. In the single step position, it is simply equivalent to holding the HALT key down all the time — but a little easier on the operator's finger. Wiring of the front panel board should be found a fairly straightforward task, if you use the wiring diagram as a guide together with the circuit and the photograph. Most of the wiring should be fairly self explanatory, although care should be taken with such matters as correct orientation of the indicator LEDs and the various ICs. Note that provision is made on the board for indicator LEDs corresponding to bits 0-6 inclusive of the PC and MA registers. This is sufficient for the 128-word memory, where only 7 address bits are used, but will not allow indication of the eighth bits (PC7 and MA7) which become active if the memory is expanded to 256 bits. Indicators for these bits will be described later. Probably the only other point to mention about the front panel board at this stage concerns the mourting of the switches. To enable these to be replaced individually at some future time, if they become faulty, they have been mounted on a small metal strip, which is attached to the front of the PC board via small screws and nuts, at each end. The switches are fastered to the strip from the front using the screws and nuts promise the switches are fastered to the strip route the switches are fastered to the strip passing through clearance slots. Finally their rear lugs pass through holes in the PC board, and are soldered to the appropriate copper pads. This technique should allow any of the switches to be removed later on if necessary, by undoing its mounting screws At left are the IOT connector wiring datails, and at right the switch and vartical board mounting arrangements. an unsoldering its lugs using a small in-strument iron introduced between the front panel and mother boards. A little tricky, to be sure, but not too difficult. The small diagram shows the arrangement. There is little to say about the mother board, particularly in terms of its circuit function, because its main function is to perform all of the interconnections between the socket pins of the various plug-in boards Apart from this very necessary and worthwhile function, it also brings out the connections between the plug-in boards and the front panel circuitry, and between the IOT board and the input-output device sockets. It also reticulates the 5V supply power, and mounts the four resistors used to terminate the A.B.C and D data bus lines. Whereas the twin PC edge connectors used for all of the lower boards have their "inner" ends open, to clear the board, the single top board socket has both ends closed needed. The wiring of the mother board should again be fairly evident from its wiring diagram. The connections between it and the front panel board are all marked identically, so that when the two boards are wired up and mounted together via six halfinch tapped spacers, it is simply a matter of joining up the pads with the same markings. In many cases these are exactly opposite one another, so that interconnection involves only a short length of tinned copper wire bridging the gap. Where this has not been possible, the pads are generally in the same order, but merely a little further along so that a short length of hookup wire will be The only exceptions to this rule are the connections to the PC and MA indicators, which are separate on the mother board but interleaved on the front panel board. This is a little more tricky, but if each is wired separately and with care, all should be well. Note that there are no pads on the mother board for the PC and MA register bit 5 and bit 6 indicators - these will be dealt with separately, at a later stage. For the present leave the pads unconnected. Note that there are four groups of four pads at the bottom of the mother board, which provide the input-output device signal interconnections. These should be connected to the appropriate rear panel sockets, using the small connection diagram as a guide. There are three small 6-pin DIN sockets, two of which are used for the output devices while the third is used for input device 1 (ID1). A larger 16-way socket is used for input device 0 (ID0), and the other pins of the socket are connected to the switch register pads SRO-7, the external deposit pad and the external load address pad - the last two being on the front panel board. This allows the ID0 socket to be used for input devices incorporating a hardware loader, such as a paper tape reader. Note that the external DEPOSIT and LA connections between the socket and the front panel board should be made in twin shield wire, to prevent possible malfunction due to spurious pickup. In addition to control and data signal connections, each input-output device socket also receives 5V supply power direct from the regulator output. This avoids trouble due to supply bus transients. The 5V supply connections to the mother and front panel boards should be wired in fairly heavy leads, to ensure low voltage drop. The stranded-conductor leads from a #### EDUC-8 PARTS LIST - 1 MAIN CASE AND POWER SUPPLY 1 Case and lid/front panel, 29.3 x 10.3 x 35.7cm (W x H x D), with switch mounting bracket. 1 Power transformer, 240V/10V at 6A (Ferguson type PF3798, Jones type JT 139 or similar 2 10cm square finned heatsinks, flat mounting type. 3 6-way DIN sockets (McMurdo type 1290-06-01) 1 16-way polarised plug and socket (McMurdo type 1338-12-02, 1338-02- Silicon rectifier bridge, PB40 or similar 2 2N3055 NPN power transistors with mounting accessories TUBON BESS2, AY9139 or similar medium power PNP silicon 2 BC108, BC208, BC548 or similar general purpose NPN silicon 1 BZX79/C6V2 or similar 6.2V 400mW zener diode 2 4700pF LV polyester or polycarbonate .022uF LV polyester, etc .047uF LV polyester, etc 470uF 10VW electrolytic 15,000uF or 22,000uF 16VW electrolytic with mounting clamp Resistors: 2 x 0.33ohm 5W, 2 x 10ohm 1W, 2 x 100ohm ½W, 1 x 120ohm 1/2 W, 2 x 220ohm 1/2 W, 1 x 470ohm Mains cord and plug; grommet and clamp for same; 2-way "B-B" connector strip; 7-lug section of miniature resistor panel; 2 x 2-lug miniature tagstrips; 2 x 12.7mm tapped spacers; rubber feet for case; screws, nuts, washers, solder lugs, etc. FRONT PANEL BOARD 1 Printed wiring board, code E8/F (28.3 x 9.6cml 8 SPDT paddle switch, red paddle (C&K type 7101) 2 SPDT paddle switch, grey paddle (C&K type 7101) 3 SPDT spring return paddle switch, red paddle (C&K type 7108) 2 SPDT spring return paddle switch, black paddle (C&K type 7108) 4 spacers, untapped, 17mm long 4 7400 or 9002 quad gate 5 7405 or 9017 hex inverter (open collector) 2 7417 or 9N17 hex buffer (open collector) 1 9602 dual one-shot 42 Low cost red LED's single ended type (OLD419, FLV110, 5082-4850, 5082-4484, SL103, CQY24 or similar) 1 100pF NPO ceramic capacitor .001uF LV polyester or polycarbonate 6 0.1uF LV polyester or polycarbonate 1 47uF 6VW tantalum electrolytic Resistors: 42 x 180ohm 1/4W, 1 x 1k 1/4W, 18 x 10k 1/4W, 1 x 22k 1/4W Mounting screws for switch bracket; hookup wire for links; solder, etc. MOTHER BOARD 1 Printed wiring board, code E8/C (28.3 x 9.6cm) 4 32-way edge connector sockets, gold PC tail clips (McMurdo type 133-14-17) One socket closed both ends (closed end foot type 4862-01-08) 7 16-way edge connector sockets, gold PC tail clips (McMurdo type 133-12- 3 0.1uF LV polyester or polycarbonate capacitors 2 680ohm 1/4W resistors 2 x 4700 ohm 1/4W resistors Hookup wire for links, connections to front panel board IOT connectors and power supply; 6 x 12.7mm tapped spacers for assembling boards; screws, etc. length of 3-core plastic insulated mains flex are quite suitable. The mother board-front panel board assembly is mounted into the main case by four 1/2 in Whitworth by 1 inch countersinkhead screws, two at each end in the corners. The screws pass through countersunk holes in the wide turnover lips at the front of the case, and are then fitted with clearance spacers approximately % inch long. When the board assembly is in position, the screws then pass through the holes in the front panel board, and mate with the tapped holes in the spacers between the two boards. Tightening the screws carefully thus completes the assembly of the two boards, and also fixes them rigidly behind the final plane of the front panel. With these boards wired up, connected to the power supply and mounted in the case. you can power up again and check progress. It won't be easy to check the operation of the control switches at this stage, but you can certainly check the LED indicator circuits and the operation of the switch register switches. When you switch on, all of the register indicator LEDs on the left-hand side of the front panel board should light, while the rest should all remain dark. Then, with a piece of hookup wire with one end connected to power supply negative (ie, the case), it should be possible to turn off each of the register LEDs by touching the appropriate interconnecting link with the wire. With the same wire it should be possible to light up any of the normally dark LEDs, by touching their interconnection links or pads. If any of the register LEDs don't come on when power is applied, look for a wiring error. The most likely cause will be a LED wired in the wrong way around. Failing a wiring error, you could have a faulty LED or IC, which will have to be replaced. Similarly if any of the instruction indicator or machine state LEDs on the right-hand side of the board can't be turned on by earthing the input of their buffer, again look for a wiring error or a faulty component and remedy it as soon as possible Finally, you can check the operation of the switch register by temporarily connecting its inter connection pads to the input pads of one or more of the register indicator drivers. You can do this either one switch at a time, or all at once - say by connecting them to all of the MB or AC register drivers. In the up position each switch should cause its indicator LED to light, while in the down position the LED should be extinguished. Barring a faulty switch or pullup resistor. all should be well at this stage. You should now be ready to tackle the timing and control board, which will be the next section described. # **Building our computer:** three more sections The description of our unique digital computer project continues here with construction details for the timing and run control board, the instruction decoder board and the accumulator board. The author also explains how to check the operation of these boards, in preparation for the addition of the remaining sections. #### by JAMIESON ROWE The timing and run control board is the uppermost of the EDUC-8 plug-in board stack, and is coded E9 /T. The circultry on this board comprises the master clock oscillator, the run control logic, the timing pulse generator, and the major state generator. The logic diagram for these sections of the machine is shown in Fig 1. The master clock oscillator uses a circuit which I have used in previous digital projects, and found to be stable and reliable. It is basically a releasation coellistor using a comparable of the stable s capacitance. In this case the basic oscillator uses a 10k resistor and 220p F capacitor, priving a "fast" clock frequency "foot frequency "foot frequency "foot" clock frequency of from clock from the participation of parallel with the 220p. The connection to the switch and capacitor is made via contact pad 7 of the board edge connector, as shown. The second half of the 7413 device is used as a buffer between the master clock oscillator and the run control logic. At the heart of this latter section is the run control flip-flop; this is a J-K element – half of a 7473 device – which controls the main gate admitting the clock pulses to the timing circuitry. The clock input of the run control flip-flop is driven by the master clock pulses themselves, so that it operates the main gate synchronously. This ensures that the gate always opens and closes to pass complete clock pulses, and never fractional pulses. Opening and closing of the main gate clock pulses, and never fractional pulses. Opening and closing of the main pulses of the main pulses of the main pulses of the main pulses. The pulses of the main pulses of the main pulses of the main pulses of the main pulses of the main pulses. The main pulses of mai ossignation flag file office is a simple R.S type from d from two 7400 gate lements. It is initially present to the state which produces a low logic level at the J input of the run control flip-flop, so that the main gate is closed. However a negative logic RUN COMMAND pulse fed to the run flag from the rorn panel for flip to which the state shipping a logic high to the J input of the run control flip-flop. At the completion of the run control flip-flop. At the completion of the next master clock pulse the latter will therefore change state, opening the main gate to begin the machine running. Before we go any further, let me digress briefly for a moment to introduce some abbreviations which I will be using frequently in the remainder of the present description, and those to follow. Without these abbreviations, the description would become both unwieldy and difficult to follow. No doubt you will have noticed already that some logic signals we have encountered use the positive logic convention (high equals true), while other use the regative convention (low equals true) conventions for each signal having been chosen in order to simplify the logic and minimise the number of devices. In some cases the same signal is used in Jonative and regative logic forms, for dif- To simplify discussion from now on, a negative logic convention to the particular signal or signal version being referred to will be shown by means of the letter L in brackets. Lack of this symbol will therefore imply the positive logic convention. Hence RUN and RUN (L) would be the positive logic and negative logic versions of the same signal, respectively. "Other abbreviations which will be used or "FF" to stand for filip-flop, and "McD" for master clock pulses. There will be others too, but these will be introduced as we go along. Note that negative logic signals are along to the standard of the standard designation, and also by a "bubble" at logic element inputs and outputs. The diagrams as show the logical RN operation as a plus sign, whereas this will be spelled out in the text as the symbol is not available in our We should now be able to continue, in a slightly more elegant manner. Halting of the machine is achieved by Halting of the machine is achieved by applying a negative pulse to the second input of the run flag FF, to change its state and apply a logic high to the K input of the run control FF so that it will close the main gate at the end of the current MCP. Two different signals are used to reset the run flag FF for halting, the two being applied via a pair of 7400 gate elements connected to form a negative logic OR gate. One signal is a turn-on resett signal shown on the diagram as RLL, which will be discussed further shortly. The second signal is the normal "halt" signal (LL), used to stop the machine running at the end of a deposit or of a deposit or examine cycle, or at the end of an execute cycle in response to a front panel control or a "HALT" instruction. a "HALT" instruction. The hat (L) signal is produced by a 2-input gate, one input of which is fed by a positive logic pulse produced by the timing generator during the second at 23. Second input of the gate is fed from another gate which performs an OR between the DEP OR EXAM (L) signal from the flag on the front panel board, and the output of a further gate which ANDs the HLT. COM EXECUTE signal produced by the major state generator. This sounds more complicated than it really is, as the diagram shows. All it means is that during normal running, the run flag FF is turned off at time T23.5 if the machine is either performing a deposit or an examine, or if it is performing an execute cycle and the HLT COM signal is present. Both the run control and run flag FFs are reset initially when power is applied to the machine, to prevent it from running until this is specifically commanded. This turn-on reset function is performed by the RILI signal, generated by a simple circuit using a 7400 gate element whose two inputs are taken to earth via a parallel combination of a 100k resistor and a 47uF tantalum electrolytic capacitor. When power is first applied, the capacitor is an effective short-circuit to ground applied at the gate inputs. This produces a logic high at the gate inputs. This produces a logic high at the gate output, and hence the R(L) signal at the output of its following buffer inverter (V7420). However the capacitor soon charges through the gate input circuit, allowing the gate inputs to rise to the high level. The R(L) signal to disappears after the put power of the product of the power purpose of the 100k resistor is to act as a bleed, so that the charge on the capacitor leaks away reasonably soon after the machine in which are seen and off at the same time, the contract of the same time, the contract of the same time, the same time, the same time, the same time, the same time, the same time that the turn oneset signal is not generated unless power to the machine has been interrupted for at least 2 or 3 seconds. This means that very short mains interruptions which would not upset operation, due to the reservoir action of the power supply electry, do not cause a reset to be generated. As well as being used to reset the run flag and run control FFs upon turn-on, the R(L) signal is also used to perform the same function for the main timing counter and the other FFs in the timing and major state generator logic. The main timing counter is a Fairchild 9316 4-bit synchronous binary counter, which receives master clock pulses directly from the main gate. A synchronous counter is necessary here, to ensure that all four counter outputs change state simultaneously. This allows groups of counter states to be combined to form continuous timing signals lasting for a number of MCP periods. If a normal non-synchronous counter is used, the small delays between outputs causes "notches" in the resultant timing signals, which can upset machine operation. The octual timing signels are generated from the verious states of the timing outner by means of a 9311/74154 decoder with a network of gates connected to the first 12 of its 16 outputs. The twelfth or 11(1) or to 10 output of the decoder is also to 9 beach to the output of the decoder is also to 9 beach to the effectively cousing it to be reset after every 12 dock pulses. This establishes the 12-pulse sequence on which the various cycles of the machine or be beed. The cycles are actually 24 clock pulses long, so that for each mechine cycle the siming counter and decoder run twice through their basic 12-pulse sequence. Identification of the "first half" and "second helf" sequences of the cycles is performed by the sequence counter Fr, whose clock pulse input is fed with an inverted version of the 11ft. I decoder output. As mey be seen, a number of gates connected to the outputs of the timing decoder are used to produce raw timing signels corresponding to various time intervals in the basic timing counter sequence. In most cases the two outputs of the sequence counter FF ere then used to separate the raw timing signels into the final timing signals required. The exception is the cocurs in both sequence of the cycle to cocurs in both sequences of the cycle cocurs in both sequences of the cycle country. To illustrete the generation of the other timing signals, look at the logic involved in generating the T2-9 and T14-21 signess. These are both used for seriel shifting of instruction end date words, and both lest for 8 MCP periods which by despin occupy second 12-outles sequences of each cycle. Note that the raw signel is first derived by the getes connected to the decoder outputs 2 – 9 (L), inclusive, and this signel is then geted by the sequence counter FF outputs to produce the final T2-9 and T1-21 timing to produce the final T2-9 and T1-21 timing "Signess generated directly by the imining circuitry for use throughout the rest of the mechine comprise T0-OR-T12 (L), T0.5 (L), T1, T3, T2-9, T14-21, and T22.5. A further signal T23 is also generated, but this is used solely by the major state major state T2-9 signals and two T14-21 signals, with duplicated logic. This is a carryover from the original 32-word memory version of the mechine, where the second sets of getting were required to produce T5-9 and T17-21 signels. Rather then redesting the board signels. Tather then redesting the board sowung ower to operate in tandam with the original T2-9 and T14-21 logic. The major stetes of the machine are defined by the logic circuitry associated with the two remaining J-K flip-flops on the timing board, those labelled "execute control" and "defer control". This circuitry operates as follows. When power is first applied, both the When power is first applied, both the execute control and defer control FFs are reset by the R (L) signal. The deposit or exemine flag EF on the front panel board is also reset, by means of a signel produced by also reset, by means of a signel produced by of the edge competor. This preliminary condition is equivelent to the FETCH state, and accordingly a low level logic signal is produced by a 3-input gate at the FETCH LLI output of the circuit — pad 2a. A high level version of the same signal is produced by an inverter and fed to pad 21. If the machine is set running by means of the RUN key, the first cycle will therefore automatically be a fetch, as required. The next cycle entered depends upon the type of instruction fetched and decoded, and on whether or not bit 4 of the instruction is a 1, in the case of memory reference instructions. The decision is effectively made by the 4-input gate whose output is connected to the R-S flip-flop marked "defer flag". The input to this gate are arranged so that the only situation in which it delives a legative memory reference instruction has ben fetched (i.e., not IOT or OPR), bit 4 of the MB register is a 1, and it is the first half of 1723 of a fetch cycle. If any of these conditions are not scattled, the deferring Ff is In other words, the defer flag FF can only be set during the first helf of T23 of the fetch cycle, and then only if there is both e memory reference instruction fetched, end it is also an indirect address instruction having a 1 in the bit 4 position. Note in passing that some of the conditions necessary before the defer flag FF can be set are actuelly tested by the 3-input gate with its output connected to edge connector ped 18. This gets produces e signel designated F.T23.not(OPR OR IOT) (L), which is did via an inverter to one input of the 4-input gate as well as being fed out for use elsewhere in the machine. The 173.5 pulse genereted by the timing logic is fed to the clock injust of both the execute control and defer control FFs, so that both FFs are potentially capeble of switching to the set state et the end of T23 (which is also the very end of the fetch cycle). However the outputs of the defer flag FF are connected to the 1 inputs of the base set. If the defer flag FF remains in its initial reset steet, the execute FF will be set, alternatively if the defer flag FF remains contained to the the defer flag FF FF will be set, alternatively if the defer flag FF Fs basen set, then the defer FF will be set instead. Hence the machine is automatically led into an execute or defer cycle, depending upon whichever is appropriate. In either case the FETCH and FETCH (L) signel outputs are reversed in polarity, to signify that the fetch cycle has ended, and either the EXEC and EXEC (L) outputs are taken high and low respectively, to indicate an execute cycle, or the DEFER (L) output is taken low to indicate a defer cycle. If the execute control FF is set, the machine enters an execute cycle and performs the instruction concerned. Then at the end of the cycle, the T23.5 timing pulse will reset the execute control FF so that the machine will return to a new fetch cycle. On the other hand if the defer control FF is set, the machine enters a defer cycle and reads out of the memory the actual address of the instruction operand. At the start of the cycle the defer flag FF is also reset, as the DEFER (L) signal is fed back to the gate and inverter connected to its reset input. As a result, when the end of the defer cycle is reached, the T23.5 timing pulse not only causes the defer control FF to be reset, but also sets the execute control FF. Hence the machine ends the defer cycle and correctly enters an execute cycle. If the machine is set running normally by means of the RUN key, it therefore con-tinues to run through alternate fetch and execute cycles, with defer cycles automatically interposed between fetch and execute wherever necessary for indirect memory reference instructions. This operation only stops if a halt command is encountered, as a result of the operator pressing the HALT key, or by execution of a halt instruction The machine also starts running if either the deposit or examine keys are pressed, as explained earlier. However in this case the deposit or examine flag FF on the front nel will be set, so that the DEP OR EXM (L) signal will be fed to the timing and control board via edge connector pad 6. This signal has a number of effects. One is that it ensures that the run flag FF is reset by the first T23.5 timing pulse generated, so that the machine automatically halts after a single cycle. At the same time, the 3-input gate which produces the FETCH (L) signal is blocked, so that the machine does not confuse a deposit or examine cycle with fetch. This also has the effect of preventing the defer flag FF from being set during the first half of T23, by blocking the 4-input gate (via the F.T23.not(OPR or IOT) (L) 3-input gate). In addition, the DEP OR EXM (L) signal also prevents the execute control FF from setting at the end of the cycle, by holding down one input of the 2-input gate attached to the latter's J input. These actions all ensure that for deposit or examine, the machine runs only for a single 24-pulse cycle and then stops without upsetting the major state circuitry. Note that at the end of the cycle, the deposit or examine flag FF on the front panel is automatically reset by means of the CANCEL DEP OR EXM (L) signal produced by the gate attached to edge connector pad Two further logic and timing signals a derived on this board. One is (F OR DEP OR EXM) (L), fed to pad 24. The other is a version of the same thing gated by T2-9, and fed to pad 19. Hopefully the foregoing description will have given you a reasonably good idea of the operation of the run control, timing and major state generator logic. It has not been possible to describe the exact function of every gate and inverter, but if this were attempted it would take far more space than is available - and probably be rather confusing. The wiring of this board should be fairly self-evident from the diagram of Fig. 2. There are 21 ICs, a few small components and a number of wire links. The main things to watch are the position and orientation of the ICs, and that the links are fitted correctly. It is a good idea to use insulated wire for the links, to prevent accidental shorts. I used single-conductor PVC covered hookup wire Don't forget to cut the slot next to pad 32 of the edge connector strip, so that the board can be plugged into the top socket. It may be necessary to file the side of the slot nearest pad 32, and also perhaps the end of the board next to pad 1, to ensure that the board will fit into the socket with all of the pads mating correctly with the socket clips. The same sort of preparation will probably be necessary with the other plug-in boards, as there will inevitably be small errors in the boards as they come from the manufacturer. #### Decoder board We can now turn our attention to the second plug-in board, which is that for the instruction register and decoder, with the code E8 / D. The logic for this "decoder board" is shown in Fig. 3. As you can see, the heart of this board is a Fairchild 9334 IC, which actually functions as both the instruction register (IR) and the instruction decoder. This is because the 9334 is what the maker describes as an 8-bit addressable latch. In effect it comprises a 3bit binary decoder with inputs AO, A1 and A2, whose eight outputs are coupled in- ternally to eight R-S latch flip-flops. When a low logic level is applied to the C input, all of the internal FFs are reset. Then if a low logic level is applied to the E input, whatever logic level is present at the D input will be stored in whichever of the eight FFs corresponds to the decoded 3-bit number applied at the A0, A1 and A2 inputs. In effect, it is an eight-bit memory, where D is the data input, E the write enable input and the three A connections the address inputs In this application we clear all the internal FFs of the device at time TO.5 of the fetch cycle, by means of the simple gating shown connected to the C input. Then, at time T22.5 in the fetch cycle, after the instruction has been fetched from the memory and has settled in the MB register, a low logic pulse is applied to the E input. As the D input of the device is connected to logic high, and the three A inputs are connected to bits 7, 6 and 5 of the MB register via edge connector pads R, Q and P, this has the effect that the operation code of the instruction decoded, and the corresponding 9334 output FF set. Hence if the operation code is 010 (octal 2), output Q2 would be set. Or if it is 110 (octal 6), output Q6 would be set. Whatever the operation code, one and only one of the outputs will go high, and will remain high until T0.5 of the next fetch cycle. Although the 9334 output concerned thus provides the decoded form of the instruction operation code from T22.5 of its own fetch cycle until T0.5 of the following fetch, this signal is in most cases only used during the execute cycle. Hence the 9334 outputs are not used directly, but are gated by the EXEC signal from the major state generator. This produces the eight primary instruction outputs, all of which are fed to edge connector pads A-H inclusive, in negative logic form: AND (L), TAD (L), ISZ (L), DCA (L), JMS (L), JMP (L), IOT (L) and OPR (L) An (OPR OR IOT) signal ungated by the EXEC signal is also produced, and fed to connector pad 16. The reason why the signal is not gated by the EXEC signal is that it is used primarily on the timing and control board (pad 20), to prevent the defer flag FF being set for IOT or OPR instructions. To be effective it must therefore be present during T23 of the fetch cycle. The additional gating attached to the Q6 and Q7 outputs of the 9334 is involved in decoding the augmented operation code of the IOT and OPR instruction formats. Thus the IOT signal is further gated by the signals from MB register bits 0,1 and 2 to produce the CLEAR IOT FLAG (L), IOT SHIFT (L) and SKP ON IOT FLAG signals respectively, fed to connector pads 6, 11 and 7. #### EDUC-8 PARTS LIST - 2 TIMING AND CONTROL BOARD 1 PC board, code E8/T, 21.5 x 16cm 1 BC108, BC208, BC548 or similar NPN transistor 7400 or 9002 auad 2-input gate IC 4 7404 or 9016 hex inverter IC 2 7410 or 9003 triple 3-input gate IC 7413 or 9N13 dual Schmitt IC 7420 or 9004 dual 4-input gate IC 2 7473 or 9N73 dual J-K flipflop IC 9311 or 74154 16-way decoder IC 9316 synchronous 4-bit counter IC 470 ohm ¼W resistor 2.2k ¼W resistors 10k %W resistor 100k ¼ W resistor 220pF polystyrene or NPO ceramic 4 .047uF LV polyester or ceramic 1 47uF 6VW tantalum electrolytic Insulated hookup wire for links DECODER BOARD 1 PC board, code E8/D, 21.5 x 16cm - Similarly the OPR signal is gated by both 8 7400 or 9002 quad 2-input gate IC - 2 7404 or 9016 hex inverter IC 2 7410 or 9003 triple 3-input gate IC - 1 7420 or 9004 dual 4-input gate IC 1 9334 eight bit addressable latch IC - 2 2.2k % W resistors 3 .047uF LV polyester or ceramic Insulated hookup wire for links ACCUMULATOR BOARD 1 PC board, code E8/A, 21.5 x 16cm 2 7400 or 9002 quad 2-input gate IC 2 7401 or 9012 guad 2-input gate with open collectors 7404 or 9016 hex inverter IC 2 7405 or 9017 hex inverter with open collectors 7410 or 9003 triple 3-input gate IC 2 7495 or 9395 four-bit shift register 1 820 ohm 1/4 W resistor 3 2.2k ¼W resistors 4 .047uF LV polyester or ceramic Insulated hookup wire for links THE PROPERTY AND A SECOND PROPERTY OF THE PROP the MB bit 4 and its complement, and in each case then further gated by MB bits 0,1,2 and 3 to produce the eight OPR microinstruction signals CLA (L), CMA (L), RAL (L), RAC (L), SZA (L), SMA (L), ARA (L), and HLT (L). These are fed to connector pads 31 – 24 inclusive, as shown. The remaining logic circuitry on the instruction decoder board is involved in producing secondary gating and triming signals, by combining the foregoing primary signals with triming signals. Thus a T14-21. (JMS OR JMP) (1 signal is produced by combining the JMS (1) and JMP (1) signals in a gate performing the OR truction, and then gating this with the T14-21 timing and the produced by combining the signal signal signals. Similarly a T2-9. (TAD OR IAC OR CMA) (L) signal is produced and fed to pad 13, and a T2-9 ISZ(L) signal produced and fed to pad 14. A (JMS OR DCA) signal is also produced and fed to pad 15. Signals corresponding to those instructions and microinstructions which involve PC register incrementing or "akipping" – ISZ IJ, SZA (IJ, SMA (IJ) and SKP ON 10T FLAG (IJ – are also combined by a 4-input gate performing the OR function, and gated with the T14-21 signal to produce a signal designated T14-21.SKP (IJ, which is fed to pad 18. And finally, signals corresponding to both the major states and instructions which involve the memory are assembled by a 4-input gate and a 3-input gate, both performing the OR function, and gated with the appropriate T29 and T14-Z1 timing signals. The outputs of the two gates are then combined by a further gate performing the OR function, to produce a signal designated MEMORY ENABLE. This is feet to pad 23. Wiring of the decoder board should be diarly self-evident from the diagram shown in Fig. 4. There are only 14 ICs, five minor parts and again a number of wire links. As before the main things to watch are that the ICs are correctly orientated, in their correct positions, and that the wire links are in their correct positions. The decoder board plugs into the mother board position second from the top, immediately below the timing and control board. #### Accumulator board The third section of EDUC-8 to be described at this stage is that comprising the accumulator (ACI register and its associated logic. This section is on the plug-in board coded E8 /A, and for convenience described as the accumulator board. The logic diagram is shown in Fig. 5. As may be seen, the heart of this section is the AC register itself, which is simply formed by two 7495 four-bit shift register. The 7485 devices are the register. The 7485 devices are the register. The 7485 devices are the register. The 7485 devices are the register of the register in the register of the register in the register of the register, and also for the RAM microinstruction. To achieve the left shifting required for the RAL microinstruction, the parallel inputs PA—PO or both devices are register. The PD input of the right 7495 is connected to the A output of the left, to. complete the loop so that all 8 bits are retained. The RAL (L) signal input at pad F is taken to the "mode" (M) inputs of the two 7498s, via an inverter to give the correct logic polarity. Thus when the RAL intronn-struction occurs, the devices are switched to the parallel loading mode. As the parallel load clock inputs (CP2) are connected to the T1 timing signal input on pad 12, a left shirt of one bit thus occurs at time T1 of an RAL execute cycle. The outputs of all eight AC bits are taken to connector pads J.-R inclusive, for connection to the LED indicator drivers on one from panel board. AC bit O is also the front panel board. AC bit O is also the lOT in the Del J. Line Bitting of data to the IOT in the Del J. Line Bitting of data to the IOT in th The shift right clock pulse inputs CP1 of the two 7495 iCs are commoned and fed via an inverter from a gate which ANDs master clock pulses arving at pad 9 with one of a number of signals fed to it via the associated gates. Thus a single clock pulse is fed to the gates. Thus a single clock pulse is fed to the gates. Thus a single clock pulse is fed to the execute cycle, due to the T13.RAR (L) signal from pad 8. Similarly eight pulses are applied during T2-9 of the execute cycle of a TAD instruction or an IAC or CMA microinstruction, due to the T2-9,TAD OR IAC OR CMAI, IL signal from pad 14, and The bit 0 output of the AC is applied to one input of the gate marked AND, the other input of Which connects to the 0-bus input on pd. 7. After passing through an inverter to restore the logic polarity the output of the AND gate is then greated by an inverted version of the AND (IL) signal from inverted version of the AND (IL) signal from the control of the AND instruction, a path is provided for serial ANDing of the number in the AC with the number read from the memory via the D-bus. The resultant is fed to the A-bus, pad 4, and then back to the input of the AC Via an and then back to the input of the AC Via and The remaining logic of this section is involved with connection of the AC bit 0 output to either the B-bus or C-bus (pads 5 and 6), as required, for various instructions and 6), as required, for various instructions through this in detail, to call and track through this in detail, to call and track through this in detail, to call and through this in detail, to call and the showever it may be worth noting that the effect of the CLA (LI signal from pad H is to block two of the paths between AC0 and the B-bus, whereas the effect of the other the B-bus, whereas the effect of the other either the B-bus of C-bus. The logic has also been arranged so that the CLA microinstruction can be combined with either the IAC or CMA microinstructions, and IAC also combined with CMA. As before the wiring of the accumulator board should be straightforward, using the diagram of Fig. 6 as a guide. There are 10 ICs, some nine minor parts and a number of wire links, and here again the IC orientation and position should be watched carefully to avoid errors. This board plugs into the second bottom position on the mother 10 % 2 34W 4 7400 A 2248 6 7004 3.8 . 9 7420 7400 13 14 115 17 18 19 7400 20 ..... 21 € 2.24 h CHANN 22 23 1 % 24 Ch 2 26 7410 7400 27 28 29 - Serve 30 00 00 ge 31 10081/4 32 7404 7400 A STATE OF N B 7410 7400 SHEET C WHITE D PERSONAL PROPERTY. COMMON P DESCRIPTION H STATE J 9334 TANKED ! SESSIFICATION M A SECURE N -900000 p - 839939 O -- discount a board, which is the uppermost of the two positions having two 16-way edge connectors. When the three boards described in this section have been wired up and checked against the diagrams for errors, they may be plugged into their respective sockets — assuming that all seems well. It will now be possible to test many of the basic functions performed by these sections of the machine, and this is a good idea before you proceed to build up the remaining sections. #### Testing progress In order to perform the tests it is necessary to make temporary connections between the switch register pads \$80.7 on the front panel board (siake available on the late front panel board (siake available on the MBO-7 connector pads on the left-hand and of the mother board. \$RO should be connected to MBO. \$RI to MBI, and so on, down to \$R7 and MB7. This is to allow the own to \$R7 and MB7. This is to allow the substitute of With these temporary connections made, apply the power. If all is well, the only LED which will light on the right-hand side of the front panel will be that for FETCH, which is normally III when the machine is not running. On the left-hand side of the front panel, the LEDs for the PC and MA registers the PC and MA registers MB registers should correspond to the positions of the SR switches – up switches producing a glowing LED, and down switches producing a dear LED. The LEDs to the AC register will light in a random to the AC register will light in a random of the AC register will light in a random on the AC register will light in a random on the AC register will light in endough on the AC register will light in a random on the AC register will light in endough on the AC register will light in a random on the AC register will light in a random on the AC register will light in a random on the AC register will light in a random on the AC register will light in the AC device. For a first test, make sure that you can set the MB register LEDs to any desired binary number by setting it up on the SR switches. This ensures that you have the temporary connections right, so that the SR can indeed be used as a substitute MB register to feed in instructions. Now set the FAST/SLOW switch to the upper or slow position, and the SINGLE/CONT switch to the upper or single step position. The machine will now be set for slow running, and single stepping. Then set all eight of the SR switches to the down or 0 position, in effect giving the machine an AMD instruction directly addressing the step of s You are now ready for the first big test. Watching the LEDs on the right-hand end of the front panel, press the RUN key. The run LED should light, showing that the machine has started running, while the fetch LED should remain lit - showing that it is valiantly trying to perform the fetch cycle, slightly handicapped at this stage by the lack of both the PC register and the complete memory system! The fetch LED should remain lit for about 12 seconds, then it should go dark and the execute LED should glow, showing that the machine has correctly entered an execute cycle. At the same time the AND instruction LED should light, showing that the correct "instruction" has been decoded and its execution is being attempted. Both the execute and AND instruction LEDs should remain lit for another 12 seconds or so, whereupon both they and the run LED should go dark, indicating that the machine has stopped running. When this happens the fetch LED should come back on again. During the execute cycle you may have noticed that if there was a number other than 00000000 in the AC register, it was apparently shifted around eight bits to the right, to end up where it began. This is normal, as the machine performs the AND operation between the number in the AC and a logic "1" effectively present on the Dbus when the memory board is absent. The resultant is returned to the AC If all is well so far, set SR switch 4 to the up position, to simulate the MB4 bit being set to 1 for indirect addressing. Then press the RUN key again. The previous chain of events should now be repeated, except that before entering the execute cycle the machine should spend about 12 seconds with the defer LED glowing. If this checks out also, set switch SR4 down again and set SR5 to the up position, to simulate a TAD instruction. Pressing the RUN key should produce a repeat of the first sequence, except that this time the TAD instruction LED should glow during execute. The number in the AC will also be lost, as the machine will shift it out to attempt passing it through the serial adder (at present non-existent). In similar fashion you can check the decoding of the remaining primary in-structions, simply by setting SR5, SR6 and SR7 to the appropriate operation code. And you can check that with bit 4 set to a 1 by having SR4 up, the machine will pass through the defer state between fetch and execute, for the six memory reference instructions. You should conversely check that it does NOT enter a defer cycle for the IOT and OPR instructions, despite SR4 being up! Finally, you can test those of the OPR microinstructions which change the content of the AC, without requiring the adder. These are CLA, CMA and RAL. The other two content-changing microinstructions (IAC and RAR) can also be partially checked, but at this stage will not work properly because of the absence of the adder. To perform these checks, first set the SLOW/FAST switch to the down, or fast position. Then set switches SR7, SR6 and SR5 to the up position, to simulate the OPR operation code (octal 7). Leave the SINGLE/CONT switch in the up position, for single step operation. As the AC register content is probably zero by this stage, the best microinstruction to try first is probably CMA. So set switch SR2 to the up position and switches SR4, SR3, SR1 and SR0 to the down position, to set up the full CMA coding (octal 704). Then press the RUN key, whereupon the AC should be set to 11111111 (equivalent to minus 1 in two's complement binary arithmetic) Pressing the RUN key again should restore the AC content to all zeroes again. and further presses should simply cause the two AC content situations to alternate back and forth. Make sure that you end the test 52 that you are ready to perform the next test. This time set switch SR2 down, and SR3 up instead. This produces octal code 710, or that for CLA. Pressing the RUN key should now simply wipe out the AC content, leaving it zero. Continued pressing should have no effect. To test the RAL instruction, it will be necessary to have an AC content other than zero or minus 1, because these both look the zero or minus 1, because these both look the serior of the serior than 200 zero nor minus 1. If you are unlucky, and the AC does come up with zero or minus 1 consistently, there is still a way to produce a suitable AC content. This is by using the RAR microinstruction, which as yet will function only partially but sufficient for our purpose. First set the SR switches back for CMA (octal 704), and press the RUN key to give the AC a content of minus 1. Then set the SR switches to octal 722, representing RAR (SR7, 6, 5, 4 and 1 up. SR3,2 and 0 down). Pressing the RUN key a few times should then move zeroes into the AC from the left hand end. Do this until you have about 3 or 4 bits left in the AC set to 1. Having produced a suitable content in the AA to was the SR switches for the RRL microin-struction (octal 702). Pressing the run key should cause the number in the AC to be shifted one bit position to the left, with the value of AC bit 7 being transferred around into bit 0. Further shifting should be produced by continued pressing of the RUN. key. At this stage you will have tested all of the microinstructions capable of being promoting the property of the machine in its incomed property. Of the machine in its incomed property, which is the property of pro Hopefully, your machine will have passed all these tests, and you will be ready to work on the program counter and adder board, and the memory board. These will be described next, so that before long you will be able to get the machine actually running in its basic form. #### Troubleshooting If you have struck trouble, in that your machine doesn't perform as it should, there are probably three likely causes. One is that you may have made a wring error, such as an IC in the wrong position or around the wrong way, or a wire link in the wrong position. The second possibility is that you have a faulty connection in one of the PC edge connections—in which case cleaning socked in methylated spirit may help, or falling this judicious bending of a guilty socket tip may be required. The third possibility is a faulty IC, which does occasionally occur. Here the trick is to find the guilty device, of course, after which the remedy is obvious. I myself have encountered only two faulty ICs, both of which were 7400 quad 2-input gate devices. In both cases only one of the four gates was faulty, but the symptoms were identical: the gate operated purely as an inverter from one input, completely ignoring the other input. This suggests a broken bonding wire from the package pin to the chip, and it was perhaps significant that both devices were of the moulded plastic variety. In both cases the effect of the fault in terms of machine operation was to cause the machine to perform an operation not only when it should, but at other times well. In one case it skipped on the SMA microinstruction regardless of whether the AC was actually negative or not, for example. In a nutshell, the approach to use when troubleshooting is to first study carefully he symptoms, noting exactly what is going wrong, and when (use the slow running mode to help spot timing). Then look carefully at the logic diagram, and you will often be able to narrow down the fault area quite closely. Finally, test out your theory about where the fault may lie, using a logic probe or a soope to analyse what is going probe or a scope to analyse what is going It takes a while to get the hang of this, but you'll find it will probably come to you fast than you may anticipate. At first, the logic circuits may seem bewilderingly complex, but in reality only a small part of the total circuit is generally involved at any one time. #### PLEASE NOTE In the initial explanation of EDUC-8 operation, it was stated that with a cleared AC register, the effect of the CMA microinstruction is to give the AC a content of 1. This is of course wrong; it leaves the AC with all bits set to 1, equivalent to minus 1 in 2's complement notation. It should also be noted that the RAR microinstruction only corresponds to division by two when the initial AC register content is an even number — i.e., with bit 0 zero. This is because the content of bit 0 moves to the bit 7 position following RAR. In Fig. 6 of the same section, showing the basic organisation of the machine, the inverter shown after gate 14 should be before this gate. The inverter is used for the CMA microinstruction. Finally, please note that the PC and MA registers have now both been enlarged from 5 to 8 bits, to cope with the 8-bit address words required for the 128/256 memory. ### The EDUC-8 computer: getting it going — at last! Continuing with the construction of our unique digital computer project, the author describes here the program counter and adder section, and also the memory section. This completes the basic machine, which should now be capable of running in a limited way via the console controls and indicators. #### by JAMIESON ROWE Having completed the assembly and testing of the timing and run control. decoder, and accumulator sections, you should now be in a position to complete the basic machine by adding the program counter and adder section, and the vital memory section. These will be described here, together with details of how to check operation as you progress. If you are keeping up with the description. all going well you will have by the end of this stage a complete basic computer, capable of storing a program and executing it. The only thing is that it will be an "introvert", capable of communicating with the outside world (i.e., you!) only via the console switches and indicators. So that while it will be capable of running, it won't perhaps seem very spectacular or impressive. This will have to wait until we give it the ability to deal with input-output devices, and provide it with some of these to communicate with. These preliminary comments are just to let you know where we're heading, and perhaps to encourage you if you were beginning to falter. With that done, I hope we can proceed. For convenience, the program counter (PC) register and the serial adder circuitry are grouped together on a single plug-in board, coded E8/P. This board is the same size as the other plug-in boards described, 21.5 x 16cm, and has connector pads to mate with both a 32-way and a 16-way edge connector socket. It plugs into the sockets fourth from the top on the mother board, immediately above the accumulator The logic for the program counter and adder sections is shown in Fig. 1. As you will perhaps have already noticed, the PC register itself is formed by two 7496 five-bit shift register devices, with only three flipflops being used in the first device. This gives a total of eight bits, so that the PC is capable of handling the 8-bit address words needed for 256 memory locations The five parallel inputs of the 7496 which is fully used are connected to pads 24-28 inclusive of the board edge connector, and thence to SRO-SR4 of the switch register Similarly the three active parallel inputs of the second 7496 are taken to SR5, SR6 and SR7, in this case via flying leads (this device has been added to the original design, as part of the memory expansion to 256 words, and this is the reason for the flying leads). The connections between the eight parallel inputs and the switch register are for loading addresses into the PC The actual load address operation is carried out by means of the LA1 (L) and LA2 control signals, which you may remember are generated on the front panel board by logic connected to the "load address" key These signals arrive at the PC board via pads 17 and 18. The LA1 (L) signal is connected to the clear inputs of the 7496s, to clear them of any previous content. The LA2 signal line connects to the parallel load enable inputs (PL), and this signal thus causes the new address to be loaded from the SR after clearing. The least significant bit (LSB) output of the PC is connected to the C-bus output line, pad 6, via a control gate. The control signal for this gate is produced in turn by a second gate, connected as a 2-input OR element. The two signals fed to this gate are the T2-9. (F OR DEP OR EXM) (L) signal fed to the board via pad 20, and a T2-9.JMS (L) signal derived from the T2-9 and JMS (L) signals which arrive at the board via pads 13 and D, respectively. Thus the LSB output of the PC is connected to the C-bus and the B2 input of the serial adder during T2-9 of either a fetch deposit or examine cycle, and during T2-9 of a JMS execute cycle. Similarly the LSB output of the PC is also connected to the B-bus output line, pad 5. and the A1 input of the serial adder, by means of a control gate fed with a T14-21.SKP signal derived from pad 22. Thus this pathway is enabled during T14-21 of the execute cycle of any of the instructions involving instruction skipping. The serial input of the PC is permanently connected via an inverter element to the Abus input, pad 4. The output of the serial adder is connected to the A-bus line via a control gate, whose control signal is produced by a 4-input gate functioning as an OR element. And among the signals fed to this element are the T2-9. (F OR DEP OR EXM) (L) signal, and indirectly via further gating the T14-21.SKP (L) signal. These signals also fed to other gates connected to the control inputs Ac and Bc of the serial adder, which will be described in more detail in a moment. MCP pulses arriving at the board via pad 11 are fed to the clock pulse inputs of the 7496 devices via yet another control gate, whose control signal is again produced by a 3-input OR element. And not surprisingly, the signals which thus enable the clock pulse gate are T2-9. (F OR DEP OR EXM) (L), T2-9.JMS (L), and T14-21.SKP (L). The net result of all this is that during T2-9 of a fetch, deposit, or examine cycle, or T14-21 of the examine cycle for a skip in- struction, the contents of the PC are effectively shifted out of the register to the Abus, through the adder, and back into the register again. Providing the carry FF of the adder is set to one before this operation, the PC content is therefore incremented at these times In addition, the content of the PC is also shifted out onto the C-bus during T2-9 of a JMS execute cycle, ready to be written into In tracing through these logic paths you probably also noticed that a path from the probably also noticed that a path horn me C-bus to the serial input of the PC, via the serial adder, is also enabled during T14-21 of either a JMS or JMP execute cycle. This is performed by the signal T14-21.(JMS OR JMP (L), which arrives at the board via pad 21. This signal also enables the clock pulse gate of the PC. The purpose of this further logic is to allow the content of the PC to be replaced as required during a JMS or JMP execute cycle, from the MA register. This completes the PC register logic, which as you can see is not very complex. The remaining logic on the board is that associated with those serial adder functions which do not involve the PC The serial adder consists of a 7480 full adder device, with a 9001 high-speed J-K flip-flop to store the carry. The adder inputs A1 and B2 connect to the B-bus and C-bus respectively, and are controlled by logic signals applied to gating inputs Ac and Bc respectively. The two unused inputs A2 and B1 are tied together and taken to the 5V rail via a protective resistor. The output of the adder is taken to the Abus via a control gate, as we have already noted. It is also taken to the C-bus via another control gate, fed with a T2-9.ISZ signal derived from pad 19. This is used for the "increment" part of the ISZ instruction. The carry FF is reset at times T0 and T12 of every machine cycle by the (TO OR T12) (L) signal applied to its R-bar input from pad 8. Where the adder is to be used for incrementing either the PC, the AC or a number fed from memory, the carry FF is then set to 1 at either of times T1 or T13, by means of the logic connected to its S-bar input. For brevity this will not be described in detail; but note, for example, that setting occurs at T1 for either fetch, deposit, examine, IAC or ISZ. The setting at T13 occurs for a variety of other signals and signal combinations, such as ISZ again, or SZA together with a clear accumulator. When the adder is used for incrementing the signal to be incremented is applied to either the A1 or B2 inputs, from the B-bus or C-bus, and appropriate control signals applied to the adder control inputs and the output control gates to enable the right paths. The same procedure occurs for true binary addition, which occurs only during T2-9 of the TAD execute cycle. In both cases MCP pulses are also fed to the clock input of carry FF, so that it correctly stores the individual bit carries. Apart from incrementing and addition, the adder is also used as a passive data path from the B-bus to the A-bus, during T2-9 of the CMA execute cycle, and at time T13 of the RAR execute cycle. It is similarly used as a data path from the C-bus to the A-bus. during T14-21 of the JMP execute cycle. The latter path is used to transfer the new 'next instruction" address from the MA into the PC. You may care to follow through the detailed logic paths involved in the operation of the adder for yourself, using the basic organisation diagram and cycle and instruction timing table given earlier as a guide. The wiring of the program counter board is shown in Fig. 2. This board is coded E8/P, and like those plug-in boards already described measures 21.5 x 16cm. There are 14 ICs on the board, together with a handful of minor components and some wire links. Wiring up the board should be fairly straightforward using the diagram as a guide; the main points to watch are that the ICs are correctly orientated and that the links are between the correct pads. Note that there are connection pads near the 7496 device whose axis is parallel to the "back" of the board, for the attachment of flying leads to switch register switches SR5, SR6 and SR7, and to the LED indicator circuits for PC5,PC6 and PC7. Flying leads are needed here because this is the device which I have added to expand the PC for the larger memory; it has not been possible to provide for the connections via the plug-in connectors and the mother board. The flying leads to the switch register should be fairly self evident. Of those for the LED indicators, the leads marked PC5 and PC6 simply go to the points on the top edge of the front panel board which are marked (PC5) and (PC6) in the previously given wiring diagram. The remaining lead, that marked PC7, will be dealt with shortly; it requires special treatment because the front panel board has no provision for an eighth PC indicator LED or driver. The logic circuit for the memory board is shown in Fig. 3. As you can see, this board includes the memory itself, the memory buffer (MB) register, and the memory address (MA) register. The memory itself consists of two Fairchild type 93415 random-access memory (RAM) devices, although if only a 128-word memory is required, one device may be omitted. Both are needed for the full 256-word memory. The 93415 device is actually a 1024-bit bipolar RAM, organised as 1024 single bits. However, for this application I have in effect "re-organised" the two devices so that they each store 128 x 8-bit words. The technique used for this relies on the fact that EDUC-8 is a basically a serial machine, and moves both instructions and data words around one bit after the other, in 8 clock pulse sequences The address number fed to the memory devices from the MA register is fed to the most significant address inputs of the 93415 devices, with the 8th and most significant bit used to determine which device is selected. This leaves the three least significant address bits of each device unspecified, so that the addresses provided by the MA basically correspond to groups of eight adjacent memory locations in either one device or the other. The three least significant address bits of the memory devices, A0, A1 and A2, are connected together and also to the outputs of a 3-bit binary counter, formed by part of a 7493 device. 7493 device. This has been called the 'memory strobe" counter, because its action is to cycle the total memory address applied to the two 93415 devices through the eight appropriate bit positions, during the eight MCP periods in which a word is either written in or read out. In effect, the strobe counter and the decoding logic inside the 93415 devices for the three least significant address bits form an 8-way multiplexer and demultiplexer, which connects each of the locations in a group of 8 to the write or read circuitry in turn, during an 8-bit write or read sequence. The main "address" specified by the content of the MA simply determines which group of 8 bit locations is involved. You can visualise this action as one whereby a number is stored by "spraying" its 8 bits into the 8 locations of the group selected by the MA address. Conversely, a number is read out serially by in effect sniffing" each of the 8 locations at its address, in turn. The MEMORY ENABLE signal arriving at pad 23 of the board (from the decoder board) is used to enable the memory devices whenever they are involved in machine operation. The signal is fed to the "chip or CS-bar inputs of the 93415 devices via two gates, one fed with the MSB ouput from the MA register, and the other fed with the complement of this signal. Thus when bit 7 of the address is 0, only memory device "0" is enabled; conversely when bit 7 is 1, only memory device is enabled. The signal from pad 23 is also used to gate MCP pulses to the strobe counter and the MB register devices, so that both operate whenever the memory is enabled. If the memory devices are enabled with the "write enable" or WE-bar control inputs held at the logic high level, they perform the read function. During the 8 MCP periods concerned the content of the 8 memory locations at the specified address are sensed in turn (non-destructively), and appear one after the other at the Do outputs of the devices, which connect to the D-bus (pad Further gating also provides a path from the Do outputs to the B-bus (pad 4) during T2-9 of an ISZ execute cycle, and to the C bus (pad 5) for all read operations other than To achieve the memory write function rather than read, the WE-bar control inputs #### For fine detail work - a hands free magnifier The Magna-Sighter is a precision 3-D binocular magnifier that leaves your hands completely free for work. It has hundreds of applications. and is invaluable for scientists technicians, craftsmen, toolmakers, hobbyists, etc. Slips easily over the head-over glasses, too, Proved and used by many U.S. universities, space research bureaux, government departments and major industrial organisations. Available in 3 different magnifications. Price \$18.00 | Technical Correspondence College Pty. Ltd.)<br>159 Flinders Lane, Melbourne, Vic., 3000 | |-----------------------------------------------------------------------------------------------------------------| | Please send me full information on the 3-D Magna-Sighte<br>I understand that no Sales Representative will call. | | Name | | Address | | Postcode | ME/A674 STOTT TECHNICAL SERVICES R-666 the ALL-band #### COMMUNICATIONS RECEIV that gives you the world and an FM option, too. All-band/ell-mode reception on frequencies 170 kHz to 30 mHz covered by 6 bands. Receives broadcests in eny mode AM, SSB, CW or FM—with the optional scoessory ORS-FM, Super sensitivity from duel gets MOS types FET's, double signal selectivity and AGC cherecteristics. FE circuit with mechanical end ceremic filters designed for circuit with mechanical end ceremic filters designed rot high selectivity, resistance to interference; single button selection of wide bend (5 kHz/6dB) or narrow bend 2.5 kHz/6dB) or narrow bend 2.5 kHz/6dB, Altogether e high performance compact, smertly styled unit of advenced design at a suggested "Todey" price of \$332,20.5 Mail coupon NOW!-Weston Electronics Company 215 North Rocks Rd., North Rocks, N.S.W. 2151 Phone 630-7400 NAME Please send details of ADDRESS the Kenwood QR-666 POSTCODE. ELECTRONICS Australia, December, 1974 #### EDUC-8 computer of the 93415 device selected must be held at the logic low level during the time when the device is enabled. This is achieved by means of a "write" control signal, applied to the Wite bar inputs via a gate used to AND the signal with the MCP pulses. This is to restrict the actual writing operation to the second half of each clock period, to ensure that logic levels on data lines and address lines have all stabilised before writing commences. The memory address or MA register is formed by two 7496 five-bit shift register devices, connected in very similar fashion to those for the PC register. Here, however, the parallel inputs of the devices are con-nected to the outputs of the MB register. The clear (CL-bar) inputs are connected to edge connector pad 7, so that the MA is cleared at time T0.5 of every machine cycle. There are only four actual situations when the memory write cycle is required: T2-9 of either a JMS or DCA execute cycle, or T14-21 of either a deposit cycle or an ISZ execute cycle. The "write" control signal is therefore generated by four gates fed by signals from pads 11,18,8,C and 19. The complement of the write control signal is also used to disable the data path between the Do outputs of the memory devices and the C-bus, as this bus line is used to feed in the data to be written. The parallel load enable (PL) inputs of the 7496s are also connected together, and fed with a signal formed by a simple logic circuit combining signals from pads 12,16 and 22. This causes the MA register to parallel load the number in the MB register at time T1 of either a defer cycle or an execute cycle involving any of the memory reference instructions -ie, time T1 for all cycles other than fetch, deposit, examine, IOT execute and OPR execute. The MA register operates as a shift-right register at times T2-9 of a fetch, deposit or examine cycle, and at times T14-21 of a JMS or JMP execute cycle. Clock pulses are fed to the CP inputs of the 7496 devices by the gates deriving signals from connector pads 9.15, and 17. Note that the bit-0 output of the MA is also connected to the Cbus line, via a control gate fed with the T14-21. (JMS OR JMP) signal. This is used to feed the operand address from the MA to the PC via the adder, which either increments it in the case of a JMS cycle, or passes it unchanged in the case of a JMP cycle. The memory buffer or MB register is formed by two 7495 four-bit shift registers, and in that respect is similar to the ac-cumulator. The outputs of the 7495 devices are here also taken to eight inverter elements, wired as before to form an 8-input elements, wired as perore to form at 5-input. NOR gate. This is used to generate a "MB equals 0" signal, required for the conditional skip part of the ISZ instruction. For most of the time, the MB register operates in tandem with the memory, storing and displaying the number being written into or read from a memory location. For these operations the MB operates as a simple shift-right register, and this is achieved by holding the 7495 mode control (M) inputs at low logic level, with clock pulses applied to the CP1-bar inputs when appropriate. There are two situations where this mode of operation is not used, and where the 7495 devices are made to accept parallel data input. The first of these situations occurs during time T13 of a deposit cycle, when the parallel inputs of the MB are connected to the switch register switches, to load in the number to be deposited. A T13. DEP signals derived from the signals on connector pads 10 and 19 for the signals on connector pads 10 and 19 for the purpose, and is used to drive the five light of the MP period. As 100 pich that level for one MCP pariod. As 100 pich that level for one to the CP2 bar input of the devices, the devices of the CP2 bar input of the devices, the deposit cycle. Note that whereas the parallel inputs of the 4 least the 7495 device corresponding to the 4 least significant bits of the MB connect directly to SRO, SR1, SR2 and SR3, the parallel inputs of the second device connect to the remaining four switch register lines via a remaining four switch register lines via a least of the connect to the termination of the connect to the coupture of the four most significant MA register, bits, for the second MB parallel locking situation. This situation occurs at time 123 of the fetch cycle, when a memory reference instruction has been fetched. Here, you may recall, the four most significant bits of the instruction address must be transferred from the MA to the MB, so that the mechine will "remember" the page of memory from which it has fetched the instruction. It needs this information to complete the operand across, in the case of a direct memory across, in the case of a direct memory across, in the case of an indirect instruction. The switching (S-bat) input of the \$322 or multiplexer is normally held at logic high level, and thus the "1" inputs of the device are connected to its outputs. The parallel server is not connected to Institute the MB are thus normally connected to SR4, SR5, SR6 and SR7, and remein so during the deposit operation. However the S-bar input of the \$322 to its laten to pad 1d, which input of the St22 is taken to pad 1d, which the M input of the Coupled 7495. As a result, the M input of the coupled 7495. As a result, such a strike of the F.T23, not (OPR OR IOT) (L) signal at pad 14 causes the 3322 to the survival of the F.T23, not (OPR OR IOT) which is the M input of the coupled fines, and at the same time the 7495 M inguises of them high same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises of the toleration of the same time the 7495 M inguises place. The wiring diagram for the memory board is shown in Fig 4. Like the other plug-in boards this one also meesures 21.5 x16cm, being coded EB/M. As you can see, it involves 18 IC's, e small number of pessive components, end egein e number of wire Wiring the board should present few if eny problems if this diegrem is followed cerefully. As before the mein points to wetch are that the ICs ere correctly orienteted end in the correct positions, end that the wire links ere wired correctly. Note thet the memory device positions ere merked "0" end "1", to signify which device is designated by the appropriete velues of bit 7 of the MA register. In other words, device "0" is thet which forms the "first helf" of the 256-word memory, end device "1" the second helf. I would suggest that you use sockets for the two memory devices, as they ere by fer the most expensive ICs in the whole mechine. Use high quality sockets, preferably of the "low profile" type so that they do not reise the devices too high from the board. Otherwise you may have trouble with the device peckeges foulling the decoder board, when the board is plugged Like the progrem counter board, the memory board has some flying leeds connecting to it. As before these heve been made necessary because of the expansion of the memory to 256 words. The two flying leeds marked MA5 end MA6 should be feirly self-explenetory. They go to the points on the top edge of the front penel boerd which ere merked (MA5) end (MA6), to drive the eppropriete LED indicators. You may recell that the front penel board has no provision for the eighth indicator LEDs of the PC end MA registers, PC7 end MA7, or for their drivers. These LEDs must be mounted on e small supplementary penel, cut from Veroboard or similer material, which is mounted in front of the front penel board so that the LEDs ere correctly positioned in line with the others. Two inverter elements on the memory board, which would otherwise heve been unused, heve been arranged to serve es the drivers for the two edditionel LEDs. The input of the inverter for the MA7 LED is connected to MA7 by the memory board pattern, end only its output need concern the constructor. This is the flying lead the constructor. This is the flying lead to the supplementary of the supplementary of the supTo allow the second inverter to be used es the PC7 diver, e leed must be wired between its input end the PC7 output on the progrem counter boerd. This is the flying lead marked PC7. The output of the driver then goes to the supplementary penel, like thet for the MA7 LED, vie the leed merked PC7-ber. Deteils of the supplementery penel used to support the PC7 end MA7 LEDs and their series 180 ohm resistors ere shown in Fig.5. The board meesures 21 x 32mm, and is cut from a screp of Veroboard with 0.1in conductor specing. Only one conductor strip need be cut on the penel — the third from the top, used for termineting the two resistors end the flying leads to the memory boerd. Note that the resistors should be the small "A-west size, to fit comfortebly. The two LEDs should elso be of e type heving e fairly short body, and mounted herd egelinst the penel to produce e shallow overell essembly. As shown, the penel is supported in front of the front-penel PC boerd in such e position thet the two LEDs are in line with those in the rest of the errey. The panel is supported by two smell "U" sheped strips, feshioned from a scrap of 18G sheet bress or similar. As well as supporting the panel, the strips also complete the 5V supply connection for the LED anodes, as they are soldered to the 5V copper area on the front panel board. With both the program counter and memory boards completed and checked over carefully, you should now be ready to try them out. The first step is to plug in the program counter board, after having carefully cleaned its edge connector pads and made sure that it mates correctly with its sockets. It plugs into the mother board in the fourth position down, don't forget, immediately above the accumulator board. Now turn on the power. Things should be much the same as with the first three boards in position, except that now the LED indicators for the PC register should show some random number instead of being all lit (apart from PC7, which has only just been added) If all is well so far, set the SR switches all to zero (down position) and press down the load address key. All PC indicator LEDs should go out, and should stay out when the key is released. Now try loading an address into the PC, by setting the SR switches to a number other than zero, and repeating the process. The LEDs should remain dark when the load address key is pressed, but adopt the bit pattern set by the SR switches when it is released. Try a variety of numbers in this way, just to make sure that all is well. Note that when the load address key is pressed, the previous content of the PC should be cleared, with the new content being loaded in only when the key is released. You can now test the PC incrementing function. To do this, set the FAST / SLOW switch to the lower position (fast), and the SINGLE / CONT switch to the upper position (single). Then press the examine key, whereupon the number in the PC should increment - increase by one. Further pressing of the examine key should repeat the process, and in fact you should be able to run the PC right through its full 256 bit combinations, by simply pressing the key enough times. Pressing the deposit key instead of the examine key should have the same effect at this stage, so try this also. And you can also try pressing the run key, which should have the same effect again, at least in terms of the PC being incremented. It may also have other effects, depending upon the setting of the SR switches (which will still be doubling for the MB register, assuming you have left in the temporary connections used in the previous tests). You can now check the "skip" incrementing of the PC, or at least one instance of it - the SZA microinstruction. Do this in the following way. First, set the SR switches to octal 710, corresponding to CLA. Then, leaving the FAST / SLOW and SINGLE / CONT in their present positions, press the run key. This should clear the AC Now set the SR switches to octal 730, corresponding to SZA, and note the number in the PC register. Then press the run key again, and you should see the PC increment. Further presses of the run key should produce further increments If all is well this far, your PC is working as it should, and the serial adder must also be fairly right. However to test the adder further, you can run through the various OPR microinstructions, and check that they are working correctly. Perhaps the best one to check first is CMA, whose octal code is 704. So set the SR switches to this, and press the run key. This should cause the AC content to change from all zeroes to all ones. Further presses of the key should simply cause the AC to swing back and forth between these two situations. You have already tried the SZA microinstruction to check that it causes PC incrementing with an AC content of zero. but just to make sure that all is well, end up the CMA test with the AC set to all ones. Then set the SR switches to octal 730 again, and try pressing the run key. This PC board, code E8/M, 21.5 x 16cm 7400 or 9002 quad 2-input gate IC 1 7401 or 9012 quad 2-input gate with 2 7405 or 9017 hex inverter with open 7495 or 9395 4-bit shift register 7404 or 9016 hex inverter 7493 or 9393 4-bit counter MEMORY BOARD open collectors collectors time the PC should not increment. Now set the SR switches to octal 701, corresponding to IAC. Pressing the run key should now cause the AC to clear, as the "all ones" content corresponds to minus 1 in 2's complement notation, and minus 1 incremented gives zero. Further presses of the run key should cause further increments, so that the AC content should become 1, 2, 3, 4 and so on. Now try testing the RAR microin-struction, by setting the SR switches to octal 722. Pressing the run key this time should cause the number in the AC to be rotated to the right by one bit, with the content of bit 0 transferred to bit 7. Each time you press the run key the number in the AC should move by one bit in this way, so that a total of 8 presses should restore the number to its original position. If you stop the number with a 1 in the bit 7 (most significant bit) position, this will let you try the SMA microinstruction. Do this by setting the SR switches to octal 724, whereupon pressing the run key should cause the PC register to be incremented. Do this a few times, just to make sure that incrementing occurs each time. Then set the SR switches to octal 702 (RAL) or 722 (RAR), and rotate the number in the AC until there is a 0 in the bit 7 position. Now reset the SR switches to 724, and press the run key once more. This time the PC should not be incremented, as the AC content is no longer "negative" (according to 2's complement notation). The combined OPR microinstructions can also be tested at this stage, although if all has been well so far, they should all work as a matter of course. Thus CLA.IAC (octal 711) should cause the AC to be set to 1, while CLA.CMA (octal 714) should cause it to be set to minus 1 instead. Similarly CMA.IAC (octal 705) should cause the number in the AC to be changed into its 2's complement, while SZA.SMA (octal 734) should cause the PC to be incremented if the number in the AC is either zero or negative. Having now tested just about all of the functions of the machine in its incomplete form, the next step is the big one: adding the memory board, to complete the basic machine and make it capable of running. Prepare for this by turning off the power, and then removing the temporary connections between the SR switches and the MB register outputs. Note that if you have only one 93415 memory device at this stage, it would be best to plug it into the "0" socket. The discussion which follows will in fact assume Clean the edge connector pads on the #### **EDUC-8 COMPUTER** PARTS LIST - 3 PROGRAM COUNTER & ADDER BOARD - 1 PC board, code E8/P, 21.5 x 16cm 5 7400 or 9002 quad 2-input gate IC - 1 7401 or 9012 quad 2-input gate with open collectors - 7404 or 9016 hex inverter IC 7410 or 9003 triple 3-input gate IC - 7480 or 9380 gated full adder IC 7496 or 9396 5-bit shift register - 1 9001 high speed J-K flip-flop 2 2.2k % W resistor - 5 .047uF LV polyester or ceramic Insulated hookup wire for links, flying leads - 7496 or 9396 5-bit shift register 9322 quad 2-input multiplexer 2 93415 1024-bit RAM (or only 1, for 128-word memory) - 820 ohm 1/4 W resistors .047uF LV polyester or ceramic 2 16-pin DIL sockets. Low profile high - quality type Insulated hookup wire for links, flying that this is the case. memory board carefully, and plug it into the sockets on the mother board between the program counter and decoder boards. Then turn on the power once more. Set the SR switches to zero (all down), and load this into the PC by pressing the load address key. Then, with the SLOW / FAST switch set to the down or fast position, press the examine key. A random number should appear in the MB register, representing the turn-on bias bits of the flip-flops in the first B bit locations of the 93415 device in the "0" memory socket. Press the examine key a few more times. Press the examine key a few more times. This should bring out more random numbers into the MB, probably a different number each time (but not necessarily). Now you can try loading in a few numbers, using the deposit function. To do this, first load a suitable starting address into the PC, by setting it up on the SR swirtches and pressing the load address key. You can load in any convenient starting address you fancy, although an easily remembered one is the very first: location zero. After having loaded the starting address into the PC, set up a suitable number on the SR switches. Then press the deposit key, and you should see the number appear on the MB registers LEDs. At the same time the starting address should have transferd from the PC to the MA, while the PC content should have incremented. If all seems well, set up another number on the SR switches, and press the deposit key again. The process should be repeated, with the new number appearing in the MB. Note that you do not have to load in a new PC has already incremented after the first. You can deposit a third and fourth number (or more) if you like, by further deposits. By these steps, you should have stored the numbers into a consecutive group of memory locations. To check that this has in fact happened, set up your initial starting fact happened, set up your initial starting in the starting has been seen to be supported in the fact and rest key. Then press the examine key, and the number you stored in the first address should appear in the MB again. Further should appear in the MB again. Further second, third, fourther sey should cause the second, third, fourther second, third, fourther second to appear also. If all is well so far, the odds are that your memory is working correctly, and the machine should now be capable of running. So probably the best thing to do next is to load in a simple program, and see if it runs. The simple test program shown is probably a good one tory, as it is quite short and easily loaded. Don't worry too much about the program itself, as we will deal with programming soon. At this stage all you need to know is that it is a very simple one, using mainly the ISZ and JMP instructions, which causes the accumulator to be incremented 256 times. First set up a suitable starting address on the SR, and load it into the PC. Then deposit each of the eleven octal code numbers of the program inturn, as before. After this has been done, check that you haven't made any mistakes by loading the starting address into the PC once again, and examining the stored numbers. If they check out correctly against the list, you are just about ready. The final step in preparation is to move the SINGLE/CONT switch to the down position, to allow the machine to run #### EDUC-8 PROGRAM #### "FIRST TEST" | STEP | MNEMON | IIC | CODE | |------|--------|----------|------| | 0 | START, | CLA | 710 | | 1 | INCR, | IAC | 701 | | 2 | BACK, | NOP | 700 | | 3 | | NOP | 700 | | 4 | | ISZ INDX | 211 | | 5 | | JMP BACK | 502 | | 6 | | ISZ INDY | 212 | | 7 | | JMP INCR | 501 | | 10 | | HLT | 721 | | 11 | INDX, | 0 | 000 | | 12 | | 0 | 000 | A simple program you can use to check that your machine is capable of running. It merely increments the AC register 256 times, and then stops. continuously. The FAST/SLOW switch should already be in the down position, for fast operation, and this is correct. Are you ready? All you have to do now is load the starting address once more into the PC, and press the run key. Upon doing so, the RUN indicator should light, with the FETCH and EXECUTE indicators also lighting a little less brightly to indicate that the machine is filting back and forth between them. The ISZ, JMP and OPR indicators should also be partially it, showing that the machine is doing these twee of instruction. But more dramatic than these should be the AC register LEDs, which if all is going well will be showing a brisk counting operation. The binary number in the AC should be incrementing, probably at a rate upset to get a considerable of the properties of the properties. The incrementing probably at a rate upset to get a considerable of the properties t In the discussion of progress testing given at the end of the description of the timing, decoder and accumulator boards, it was stated that the CMA microin-struction could be tested with only these plug-in boards in position. In fact this is not so, as the CMA recirculation loop uses the serial adder as its return pathway. So if you tried this test and it didn't work, don't worry! The CMA microinstruction will work correctly when the program counter board is now added, however, as described in the present discussion. If you have had trouble in finding a reservoir capacitor for the power supply, please note that 33,000uF 25VW units are readily available from Siemens Industries. Order via your supplier. This situation should continue for about 30 seconds, until the accumulator fills up and overflows. The machine should then promptly stop running. If you used location zero as your starting address, as shown, the registers should now show the following octal contents: PC: 011 MB:721 MA: 010 AC:000 If this is the case, you can be fairly sure hat your machine is working correctly. At this stage we have not tested some of the memory reference instructions, but this can wait. For the moment, you will no doubt want to try feeding the test program into other parts of the memory, and make sure that it runs there also. You can also try setting the FAST/ SLOW switch to the upper or slow position, and try running the program at the slow clock rate. This will enable you to follow its operation in detail, as it fetches out each instruction and then executes it. But please note one important point: when depositing or axemining, ALWAYS make sure that the FAST/SLOW switch is set to the down or fast position. Otherwise, the machine will not correctly recognise that a deposit or examine cycle is required, and will start running. This will do no harm, but can be annoying! Incidentally, you don't have to feed in the test program again simply in order to re-run it; merely load the starting address into the PC as before and press the run key. That is all, unless of course you want to store it in another part of the memory, and run it there. In this case, you will have to feed it in again. Your machine should now be ready for the addition of the sixth plug-in board, the input-output transfer or IOT interface board. This will be described next, along with a simple input keyboard device and a simple output display — your first two "peripherals". ## EDUC-8: adding the input/output interface If you've been keeping up with the description of our computer project, by this stage you're probably eager to add the final section, so that it will be able to interact with peripherals. Details of this section are given here, together with a simple input keyboard unit and a lowcost outbut display unit. #### by JAMIESON ROWE The remaining section of the basic machine to be described is the IOT interfacing logic, which handles programmed transfer of data between the menine itself and any input and output "peripherals" which may be connected to it. This logic is mounted on the last plug-in PC board, which plug pin to the lowest position on the measures 16 x 21.5cm like the boards previously described. The logic diagram for this section of the machine is shown in Fig. 1. As may be seen, it is the simplest and most straightforward section in the machine, involving a relatively small number of gates and invertex. You may recall that the design of the machine is such that it will interface with a total of four input-output devices at any one time; two input devices and two output devices. These connect to the machine via four rear-panel sockets, which for convenience are labelled "Input device o" (IDI), "Input device o" (ODD), and "Output device" (DOD), devic Broadly speaking, it is the task of the IOT interfacing logic to select the device designated by an IOT instruction, and perform one or more of the three balls operations involving that device. These are testing the device's flag, transferring data to or from the device, and a setting the flag. Generally they are performed in that order, although this is not necessarily the case. From earlier discussion you may recall that bits 3 and 4 of an 107 instruction are used to specify the device concerned. Bit 4 is used to differentiate between input and output devices, while bit 3 is used to indicate either a "0" device or a"1" device. Interested versions of the signals corresponding to these two instruction bits, derived from MB3 and MB4 of the memory buffer register, reach the IOT board vie edge connector pads 5 and 6. The inverters and gates connected to these pads form a simple one-of-four decoder, whose outputs are seen used to gate one of the four sets of input-output device logic. Thus only one of the latter sets can be operative at any one sets of the latter sets can be operative at any one sets of the latter sets can be operative at any one sets of the latter sets can be operative at any one sets of the latter sets can be operative the logic thus sets as a "Gate selector". As you have probably already noticed by now, sech device interface involves four logic signals: flag sensing (L), flag reset (L), shift clock pulses (L), and date (L for output devices). Of these the first is always in effect an "input" signal, the second and third are always, "output" signals, and the last is an input signal for input devices, but an output signal for output devices. The flag sensing inputs for all four device interfaces use negative logic polarity (true equals L). This has been done to ensure that Picture below shows the besic mechine together with the two simple peripherel devices described in the present section. At left is the simple keyboerd unit, while at right is the octal display unit. if a selected device interface has no device actually connected, a program will be also to detect the condition, and not proceed in error. An unconnected TII input floats to high level, so that with negative logic the flag sensing input of an interface floats to the "flag not set" state if no device is plugged into the corresponding socket, to the corresponding socket itself apparent to a program in terms of a continuously "reset" flag condition. Upon entering the interface, the flag sensing signals are inverted and gated with the appropriate device select signals are open-time decoder. The gates used are open-time device and the select signals are open-time to the select signals are combined to achieve a wired-OR function. The resultant signal is then inverted and gated with the "SKP on IOT FLAC" signal from the main instruction decoder, which enters the board via edge that the selection of selecti A signal to reset input device flags at time 1713 of a "dear IOT flag" instruction is generated by inverting the CLR IOT FLG (L) signal entering the board via pad 7, and using this to gate the T13 timing signal which enters via pad 13. This is then inverted and gated by the device selector signals as before, to produce the final FLAG RESET (L), signal for each device. The cir iot flag.113 signal can also be used to reset the output device flags, in the same way, and this is in fact the normal way of connecting the output device flag reset logic. However to allow for possible situations where a particular output device may require its flag to be reset before date transfer, rather than after, provision has been made for an alternative CLR IOT FLAG.T1 signal to be used. This is generated in the same way as the first signel, using the T1 timing signel from pad 15. Either reset signal may be used for each of the two output device interfaces, simply by fitting the eppropriete wire link in one of two possible positions. The actual date transfer between peripherals and the machine takes place during times T2-9 of an IOT shift instruction. Accordingly an IOT shift instruction. Accordingly an IOT Shift T1.23 signal is produced by taking the IOT Shift T1 inverting it, using it to opet the T2-8 timing signel entering at ped 14, and inverting the resultant. This is then used for three tasks, the first of which is to gate master clock upuses MCP entering the board of ped 10. After inversion the resultant signal is ded reput IO. After inversion the resultant signal is produce propriate device select signal to produce each CLOCK (L) output signel. The second application of the IOT SHIFT. The second application of the IOT SHIFT. 29 signal is to gate the AC BIT O signal entering vie pad 12, to enable the output After inversion the output of the gate is had to each output device interface for further eging by the device select signels, to produce each DATA LI output. Thus during IOT shift instruction specifying an output the 8 ders bits from the AC register during interface. Finelly, the IOT SHIFT. T2-9 signal is elso used to enable e date path between the input device interfeces and the mechine thousand the input device interfeces and the mechine the second of seco Only eleven low-cost ICs ere used on the IOT interface boerd to perform these functions, and the wiring is quite streightforward. The diegram of Fig. 2 shows the position end orientation of the UCs on the board, together with the position of the wire interconnection links end the few minor components used. cycle rest many devices the second colors and the second colors are set again links in the "T13" positions, with the alternetive link positions for "I" resetting shown deshed. Suggest you wire the board initially with the links in the T13 positions, as shown, as this is likely to be suitable for most output devices you will be a suitable for most output devices you will not be changed over at some letter stage, if you find this necessary for a perticular peripheral. The link furthest from the edge connector is that for OD0, while the other is that for OD1. When the board is wired, end you are confident that no errors heve been made, clean its edge connector pads with a soft cloth moistened with methylated spirit, and plug it into the lowest socket position on the mother boerd. All going well, your EUC-8 microcomputer should now be complete, and potentially capable of "conversing" with the outside world via peripharel devices. There is en elmost endless variety of devices to which e micro-computer like EDUC-8 can be connected. On the input side, almost any piece of equipment whose bit binary number is e potential input device. Device is the property of Don't just assume, then, that the only possible peripherals for your EDUC-8 are the conventional stretchments" one associates with e traditional computer —like a paper tape or card raedar, a punch or e line printer. These heve thair uses, end becouse you will no doubt want to know how thay can be hooked up to your machine, I will try and give deteils for as many of tham es possible in following sections. But the field. is wide open for you yourself to experiment with all sorts of ideas, using the computer to monitor and control the operation of anything that takes your fancy. Only by people experimenting in this way will the applications of computers be extended, and their full potential be realised. So once you have your EDUC-8 machine operational and you have a few simple peripherals under your belt, don't be shyl Let your imagination loose, and see if you can't come up with a completely new computer application. So that you will have a couple of simple peripherals to "cut your teeth on", es it were, I have produced a very simple and low cost input keyboard unit, and a companion cost display output unit. These are very cost display to the cost of The keyboard unit is a very simple unit using only five ICs together with en array of low-cost silicon diodes for encoding. A sixth IC may be added if desired, to drive LED indicators for showing the buffer register contents and flag status. The heart of the unit is a 16-key keyboard assembly made by Mechanical Entarprises, Inc. of Virginia, and available in Australia from General Electronic Services Pty Ltd. The catalog number of the keyboard is type SK 780, and it is fitted with mercury keyswitches — which feature bounceless contacting. The keyboard is evallable with east of double-shot moulded keytops, with the inscriptions shown in the photographs. The logic for the keyboard unit is shown in Fig. 3, except for the idode encoding array. As may be seen, a 7496 / 9396 five bit shift register, to keep things simple and minimize costs. Although the register has a basic capacity of 5 bits, it is used to generate 8-bit shift of the As the encoding table shows, the encoding used is a slightly modified version of the standard known as "ASCII" (American Stendard for Computer Information Interchange). The ten numerals ere encoded simply as their binary equivalent, while the other symbols are encoded as the binary | SIMP | E KEY! | BOA! | RD - | ENC | ODIN | G<br>Piro | |------|--------|------|------|-----|------|-----------| | 4 | | | | | DILL | DILO | | ,0 | 0 | 0 | 0 | 0 | 0 | 0 | | 1 | 0 | 0 | 0 | 0 | 0 | 1 | | 2 | 0 | 0 | 0 | Ó | - 1 | 0 | | 3 | 0 | 0 | ō | ň | i | 1 / | | 4 | 0 | ō | ŏ | · 1 | á | | | 5 | ō | ŏ | ŏ | - 1 | ŏ | 1 | | 6 | ŏ | ŏ | ŏ | - 1 | ٠ | | | 7 | ŏ | ŏ | ŏ | - ! | 1 | 0 | | 8 | ŏ | | | 1 | 1 | 1 ) | | 9 | ň | 0 | - 1 | 0 | 0 | 0 | | LF | Ü | 0 | 1 | 0 | 0 | 1 | | | 1 | 0 | 1 | 0 | 1 | 0 | | + | 1 | 0 | 1 | 0 | 1 | 1 1 | | X | 1 | 0 | 1 | 1 | Ó | 0 | | - | 1 | 0 | 1 | i | ň | 1 1 | | ÷ | 1 | ō | 1 | i | ĭ | ó | | CTRL | _ | ī | | | | | equivelents of decimel 10, 11, 12, 13 end 14, except that the three most significent bits are elso set. The key inscribed "CTRI." is used to control the value of the fifth bit in the encoded word. Its action is thus rather like a shift key on a typewriter, enabling each of the other 15 keys to be used to produce e second code. By this simple meens, the 16-key unit is able to produce 30 different output characters, making it quite flexible. The didde excodinating if quiter lossing encoding, so that he perellate encoding and encoding, so that he perellate encoding, so that he perellate encoding, so that he perellate encoding, so that he perellate encoding e the initiating key, the fifth bit will also be set. The trailing edge of the one-shot output pulse is also used to trigger a second one-shot, formed by other the half of the 9602. This produces a further pulse (negetive logic), which is used to set the fleg flip-flop. The fleg FF is e simple R-S type formed from two cross-coupled gets. Its ouput is buffered by e 7437 gets element connected as an inverting driver, to become the fleg output line of the unit. The ELAT SET (I) signal appearing on this line thus indicates to the computer that a character has been received by the keyboard, and is available. As soon as the program in the computer tests the flag line and senses that it has been set, if accordingly sends a set of eight shift clock to the condition of the sense of the sense of the condition of the sense s The eight data bits leave the buffer vie the E output, and pess through two 7437 gates connected as buffer elements. They then go along the DATA output line to the computer IOT interface. Note that the shift clock pulses reaching the keyboard from the computer interface are also passed through a 7437 buffer element, which acts as a line as receiver and pulse restorer. When the date hes been trensferred to the AC register of the computer, the last phase of the IOT transfer takes place. The IOT interface sends a RESET FLAG (L) pulse to the keyboard unit, and this is used to reset the flag FF. It is also used to clear the buffer register, making sure that the latter is ready to receive a new character. As you can see, it is quite an elementary input unit, using a bare minimum of logic. At the same time, it provides all that is really necessary, at a fairly low cost. The main cost will be the keyboard assembly itself. This will involve a little more outlay than for similar units using mechanical keyswitches, but the zero bounce of the mercury switches allows the logic to be kept simple I used some of the flst bonded multi-wire cable from the wiring between the keyboard and the logic board, as you can sae from the photograph. This makes the job a little easier, because of the colour coded wires, and also makes the final result more at- tractive I have produced a small PC board pattern for the keyboard. This is coded E8 / K1, and measures 15.2 x 10.2cm. The wiring for the board is shown in Fig. 4; as you can see, the board includes the wiring for the diode encoding srrsy. The connector pads for the interconnection wires linking the diodes to the keyboard are arranged in the same order as the keyboard output pads, to simplify the wiring (see Fig. 5). This assumes, of course, that you fit the keytops to the switches in the positions shown. Otherwise you will have to rearrange the connections. Although space is provided on the board for the 7405 IC, this is not required for basic operation of the keyboard unit. It is only needed if you want to provide the unit with a set of LED indicators to show the contents of the data buffer and the status of the flag FF. The additional wiring is shown in Fig. 3 using dashed lines. If you decide to add this facility, note that no provision has been made on the PC board for mounting either the LEDs or their 180-ohm series dropping resistors. The six LEDs would be mounted on, or behind a small window in the case front panel, with the resistors on a small tagstrip nearby. The works of the keyboard unit are housad in a small utility box. I used one of the hammertone finish cases from Wardrope and Carroll Fabrications Ptv Ltd. measuring 14 x 11.5 x 5cm and having a wrap-around lid. The logic board is mounted in the bottom of the case, using four screws which are also used to attach rubber feet to the case underside. Nuts are used to space the board up from the case, to prevent shorts The keyboard assembly is screwed to the underside of the case lid, using 16.5mm long spacers to ensure that the keys protrude by the appropriate amount. The EIG 5 This top view of the simple keyboard shows the keytop inscriptions end positions. The connections for the switch assembly are shown et left. A full alphanumeric keyboard may be described et e latar stage. clearance hole in the lid for the keys is square, and messures 76mm per side. The keyboard unit receives its 5V power from the computer, via the same cable used to make the logic connections. The cable used must therefore provide a minimum of six conductors. I used a multi-wire cable of the type made for TV remote control units, and this particular cable has six insulated wires together with a single shielded wire. I used the shielded wire for the data line, with the shield brald connected in parallel with one of the other wires as the earth line. The spare unshielded wire was connected in parallel with the active 5V line, to hopefully lower its impedance also The cable enters the keyboard unit case through a grommeted hole, and is clamped to prevent strain on the connections. The wires are then separated and connected directly to the PC board pads. The other end of the cable is fitted with a 6-pin DIN plug, ith the connections corresponding to the IOT socket connections given In an earlier section Before we leave the simple keyboard unit, there are a couple of minor points which should be borne in mind when the unit is in operation. Because of the simple logic used, the unit cannot store the three most significant data bits of the output character prior to the actual data transfer. This means that for correct encoding from the non-numeric keys (except CTRL), these keys must be kept pressed at least until three of the eight shift clock pulses have occurred. When the computer is operating at its fast clock rate, this is a rather academic point, because the computer will typically shift the character out of the keyboard within about 300us of the flag being set. It is unlikely that you will be able to press a key down for less han this However if the fast / slow switch on the computer is set to the slow rate, to make it essier to analyse operation, you will have to remember to hold the non-numerical keys down until the character is shifted out. Otherwisa, the three most significant bits will not be ancoded. This is a minor point, but one which should be remembered. The second point to note is that the CTRL key does not itself initiete loeding of the keyboard buffar, or setting of the flag FF. Pressed elone, it will heve no effect. Rathar, it must be prassad in conjunction with one of the other keys. The corract procedure is to press the CTRL key first, hold it down, and than prass the dasired active key. The two are best raleased in the raverse order—ective key first, than the CTRL key. From the keyboard unit lat us now turn to the simple display unit. Like the keyboard, this has been designed to demonstrate the basic assentials of e practical peripheral —in this cese an output device. In broad tarms, the display unit simply receives an 8-bit deta, numbar from the computer and displays it as an equivalent 3-digit cotal number. The octal digits 3-digit cotal number. The octal digits 3-digit cotal number. The octal digits and displayed on threa 7-segment LED readouts, and the particuler LEDs used are a fairly naw typa from Litronix having brighter and larger (0.6in high) digits than usual. The reason why octal digits are used for the display, rather than decimal, is that conversion from an 8-bit pure binery number to the acquivalent decimal digits is not easy. In comparison, conversion to the equivalent octal digits is quite straightforward, since it is meraly a matter of decoding each group of three bits in- dispendently. Although the fact that the display reads out in octal may seam a disadvantage, in fact it is quite useful sinde the instructions refer the quite useful sinde the instructions of the display disp DAY (S.S. A). REPART FLAT OF THE PART To ancode threa full cottel eight, nine shis would be required, and see when this case only 8 bits, this means that the display is really only one of "2.8" digits. To make it more flastble, I have provided the display more flastble, I have provided that display in the most significant position, and a display of the section sect cantra posteon, giving the "737" format. The first format is in some ways that logical ona, and is tha ona you would normally use for displaying data numbers. However the second format corresponds to that used for the EUUC-8 instructions, which use the three most significant bits for which use the three most significant bits for which use the three most significant bits for which you can readily salect the format and some significant bits to format souts with the being displayed. displayed. The logic for tha display unit is shown in Fig. 6. As you can saa, it is again fairly straightforwerd. Data from the computar passes through a 7437 gata acting as a line recaivar and rashapar, and than antars the buffer register. This is a 74164 / 93164 8-bit shift registar davice, vary handy for this sort of application. The alght outputs of the buffer registers are than connected, some vie the format selector switch, to three \$930\* decivices. These are normally designated as decimal to 7-segment decoders, but by designated as decimal to 7-segment decoders, but by the connected of the connected selection DL750 readouts should be available through your normal supplier, on order from the Australian agants for Litronix, Cema Distributors Pty Ltd. As well as changing the decoding connections; the format switch is also used to control the leading zero blanking feelity provided by the 3937 decoders. One switch pole is used to enable the blanking for 377 format readout, and inhibit it for 737 format. Lasding zeroes are thus blankad whan the display is being used for deta words, but unblanked for display of instruction words whare all bit combinations have a Above is a view of the interior of the simple keyboard unit, showing the switch assembly and the PC board complete with diode encoding matrix. At right is the extender board used for servicing the computer itself. significance and must be displeyed. The R-C network connected to the reset (R-bar) input of the 74164 buffer is used to autometically cleer the buffer when the SV supply is connected to the unit. This gives the displey its own "turn-on reset" facility, preventing spurious displeys even if the unit is plugged into the computer with power applied. This does meen, however, that if the format selector switch is in the 377 position, so that leeding acto blanking is operative, so the teleding acto blanking is operative, blank when power is applied. To ensure that is always easy to check that the display unit is "ective", with power explied, the "decimal point", LED on the DL750 for the most significent digit is connected via e 220-blank ensurements and the section of sect Strictly speaking, because the displey unit does not have to perform any time-consuming mechanical or electrical processing of the 8-bit numbers fed to it, there is little need for it to indicate its stetus to the computer vie e fleg system. After ell, in itself it is capeble of displeying numbers just es repidly es the computer is capeble of shooting them out! However, from the humen user's point of view, each number displeyed should lest e reesonable time, to allow it to be recognised and perhaps recorded on peer before it is succeeded by the next number. Because of this requirement, then, rether then from a need to ellow time for its internel processing, the displey unit is provided with a fleg system. As before, the fleg flip-flop is formed from two getes from e 7437 IC, with e third gete used es a buffer-driver for the FLAG (L) output line back to the computer. The remaining circultry is simply a time deley, arrenged so that efter the computer sends the displey a number end resets the fleg, a predetermined time elapses and then the fleg is set egien to indicete that the displey has been held for e suiteble time. The displey unit itself cen thus be used to regulete the rete at which numbers are fed to it. This cen simplify progrems, es e time-delaying instruction loop might otherwise be necessary to regulete the displey rete. However note that the computer and its program ere under no obligation to test flags status before sending enother number; es the fleg system is en erbitrary one, it cen be ignored if desired. In this respect the display is rather different from most peripherels. The ectuel deley circuit used is one which is quite simple, yet ellows stable end easily edjusted deleys. The PUT is triggered by the RESET FLAG (L) pulse from the computer, discherging the 47uF cepecitor, and turning off the two Derlinoton transistors. The input COMMUNICATIONS RECEIVER that aives vou the world and an FM option, too. All-band/all-mode reception on frequencies 170 kHz to 30 mHz covered by 6 bands. Receives broadcests in ear mode AA, SSG, Ofer FM—with the optional ecosystem of the control contro -Mail coupon NOW!- on Electronics Co 215 North Rocks Rd., North Rocks, N.S.W. 2151 Phone 630-7400 NAME Please send details of ADDRESS. the Kenwood QR-666 POSTCODE The Trade Practices Act 1974 ceme into force on October 1, 1974. Certain provisions of the Act relating to consumer protection place a heavy burden upon edvertisers, edvertising agents and publishers of ad- Section 52 of the Act imposes a general duty on everyone (individual and corporation alike) not to engage, in trade or commerce, in conduct that is 'misleading or deceptive." In addition Section 53 (read with Sections 6 (3) (c) and 79) makes it a criminal offence (punishable in the case of an individual by a fine of \$10,000 or 6 months' Imprisonment and in the case of a corporation by a fine of \$50,000) for an Individual or corporation to do any of the following in trade or commerce in connection with the supply or possible supply of goods or services or in connection with the promotion by any means (for example advertising) of the supply or use of goods or services, namely: -"(a) falsely represent that goods or ser-vices are of a particular standard, quality or grade, or that goods are - of a particular style or model; (b) falsely represent that goods are new: - represent that goods or services have sponsorship, approval, per-formance characteristics, accessories, uses or benefits they do not - (d) represent that the individual or corporation has a sponsorship, approval or affiliation [he, she or] it does not have: - make false or misleading state-ments concerning the existence of, or amounts of, price reductions; make false or misleading state-mants concerning the need for any goods, services, replacements or - rapairs; or (g) make false or misleading statements concerning the existence or effect of any warranty or quaran- Apart from the criminal sanction for a breach of Section 53, an individual or corporation infringing Section 52 or 53 is liable to proceedings for injunction and for damages suffered by an injured party. In view of the obvious impossibility of our ensuring that advertisements sub-mitted for publication comply with the Act, advertisers, and advertising agents will appreciate the absolute need themselves to ensure that the provisions of the Act, including the sections specified above, are complied with strictly, It is suggested that in cases of doubt advertisers and advertising agents seek SUNGRAVURE PTY. LTD. ### EDUC-8 PARTS LIST - 4 IOT INTERFACE BOARD - 1 PC board, code E8/IOT, 16 x 21.5cm 3 7400 or 9002 quad 2-input gate IC 2 7401 or 9012 qued 2-input gete with en collectors - 7404 or 9016 hex inverter IC - 3 7437 quad 2-input buffer IC 4 1k 1/4 W resistors - .047 LV polyester or caramic - capacitors Insulated hookup wire for links, atc. ### SIMPLE KEYBOARD UNIT (OPTIONAL) - 1 PC board, code E8/K1, 152 x 101mm - 1 7496/3396 5-bit register IC 1 7400 or 9002 quad 2-input gete IC 1 7402 quad 2-input positive NOR gate - 7437 quad 2-input buffer IC 9602 dual one-shot IC - 37 General purpose silicon diodes, type - 1N914, AN2003, etc. - 1k %W rasistor 1 10k 1/4 W resistor 6 27k 1/4 W resistors - 1 33k 1/4 W resistor - 100pF polystyrene or ceremic 1000pF polystyrene or ceremic - .047uF LV polyester or ceremic - Metal case (see text) 16-switch keyboard, Machanical Enterprises type SK760, with sat of key- - tons as described 1 6-pin DIN plug Length of cable for interconnection (see - text) - Rubber feet, screws, nuts, 16.5mm spacers, etc. for - Required only LED indicator facility: 7405 or 9017 hex inverter with open - LEDs, type OLD419, FLV110, 5082-4850, CQY24 or similar. - 6 180-ohm ¼ W resistors ### OCTAL DISPLAY UNIT (OPTIONAL) - PC board, coda E8/S, 140 x 101mm 3 DL750 7-segment LED displeys 3 9307 decoder ICs - 74164/93164 8-bit register IC - 1 7437 quad 2-input buffer IC 1 7413 Schmitt triggar IC 21 BC108 or similar NPN silicon - 2 BC109 or similar NPN silicon tran- - D13T1, 2N6027 or MEU21 PUT W resistors: 1 x 10-ohm, 21 x 82-ohm, 1 x 220-ohm, 1 x 470-ohm, 1 x 1k, 1 x - 2.2k, 1 x 6.8k, 1 x 10k, 1 x 22k, 1 x 47k 500k linear pot 1000pF polyester or ceramic - .047uF LV polyester or ceremic - 0.1uF LV polyester or ceramic 47uF 6VW tantalum electro Metal case (see text) - 5-pole 2-position minieture rotary - switch 6-pin DIN plug - Length of interconnacting cable (sae text), 4 rubber faat, pieca of orange erspex for viawing window, 2 knobs for controls, grommet, screws, etc. At right is a view of the completed octal display, while above is a close-up of the PC board mounted on the back panel. of the 7413 Schmitt trigger is thus teken low, and its output switches to the high state. This condition remains until the 47uF capacitor re-chergas, through the 47k resistor and 500k pot. As soon as the capacitor voltage rises to two Vbe drops above the Schmitt trigger threshold, the trigger switches and its output drops to the low-state. The JOUIF coupling cepecitor therapyon feeds a negative-poing pulse to the flag FF, to set it. The 500k pot may be used to adjust the time dalay from a minimum of about 2 seconds to a maximum of around 20 seconds. When the computer program uses the flag system of the display to regulate the display time edjustment. As with the simple keyboard unit I have produced a PC board pettern for the octel display. The board is coded E8 / S, and measures 14 x 10.2cm. The wiring diagram for the board is shown in Fig. 7. The only parts of the displey unit which do not mount on the board are the format switch and the 500k timing pot. The construction of the displey unit should be feirly clear from the photographs. I built the prototype into e vinyl-covered steel case made by the Austrelien Transistor Compeny. Coded type 70-50-40, it maesures 191 x 127 x 102mm, end hes e brushed eluminium front penal. The PC board is mounted on the removebla rear penal of the cesa, using 2-inch long scraws and nuts as spacers. The format selector switch and displey time pot ### PLEASE NOTE The components for the mother board, shown in PARTS LIST 1, should show 2 x 470 ohm resistors, not 2 x 4.7k. ara also mounted on the reer panel, undameent the board, while the connaction ceble enters the cese vie e grommeted hole and is clemped there elso. This keeps tha construction very simple, as ell the "works" are atteched to the reer penel end cen be removad es en assembly for asay accass, removad es en assembly for assy access. The cass front penel hes a rectanguler cutout 10 x 4cm, opposite the reedouts, with a piaca of orenga-tinted parspax camentad insida to improva viewing contrast. In this wey the case itself acts as e viewing hood for the case itself acts as e viewing hood for tha displey, end thay ere clearly seen from a distence of meny matras. Four rubbar faat on the bottom of tha casa complete tha unit itself. As with the simple keyboard, the displey unit obtains its 5V power from the computer, and must therefore connect to the letter vie a cable having at least six conductors. I used e length of the same "TV remote control" cable e sefore, and agrin used the shielded wire for the DATA line. The cable egain terminates in a 6-pin DN plug, to meta with one of the EDUC-8 IOT device sockets. Well, you now have the information to complate your EDUC-8 increomputar, together with the details of two simple peripheral units to connect to it. More advenced peripherals will be described and discussed shortly. But before we deal with more herdwere, some discussion of besic programming would no doubt be apprecised, and this will be the subject of the next section. # Programming your EDUC-8 microcomputer At this stage you will no doubt be keen to try your hand at writing some programs, so that you can really start making your computer jump through hoops. With this in mind, we take a break here from talking about hardware, and discuss basic programming. ### by JAMIESON ROWE Computer programming is a big subject, and in the space straights here we will confue able to scrape the surface. We will deal only with basic machine lenguage programming, as it affects a simple machine like our EDUC-8. Even so, it will be necessary to assume that you have a fairly good grasp of the basic operation of the machine given in an earlier section. If this material has become a little hazy, I would sugest that you read through it a gain before gest that you read through it again before proceeding. To recapitulate briefly, it is worth stressing again that a digital computer like EDUC-8 deels only with binary numbers. This applies to both the data upon which it operetes, and the instructions which specify its operations. In fact the only difference between data and instruction numbers is that the latter are interpreted as such, a point which should become clearer as we do on. In the case of EDUC-8, the binary numbers used for both data and instructions are of eight bits. Any eight bit number is capable of being interpreted by the machine as an instruction, in the sense that all combinations of eight bits have a significance when interpreted as an For example the binary number 00000000 corresponds to zero when it is interpreted as a data number, but if interpreted by EDUC-8 as an instruction it causes the machine to perform a logical AND operation between the number in the accumulator register (AC) and the number is the accumulator register (AC) and the number stored in the memory location whose address in 0000 in the current memory page—that 16-word portion of the memory in which the instruction itself is set. In the same way, the number 11111111 is equivalent to decimal 256 in simple binary, or minus 1 in two's complement binary. But if interpreted by EDUC-8 as an instruction, it would cause the machine to increment the program counter if the number in the AC register to interprete the is either zero or negative, at the same time rotate the number in the AC register one bit to the right, and finally helt the program. As noted earlier, there are eight basic types of instruction "trick" in the machine's repertoire, with some of these having a variable form determined by the location in memory of the operand to which they refer, and others being subdivided into specific sub-tricks or micro-in-structions. Every different micro-in-structions and instructions Every different micro-instruction form has its own specific 8-bit binary code number. In the truest and most basic sense, then, a computer program is a sequence of binary numbers, in this case each of 8 bits. The computer itself is quite incapable of interpreting instructions in any other form. A program written in binery number form is thus said to be in mechine lenguage", Unfortunately, we human beings who must write the programs do not find it particularly easy to remember all of the binary code numbers corresponding to the various ristructions. For convenience, then, it is usual for programmers to visuelise and write machine language programs in cotal notation. This gives code numbers which are quite readily remembered and manipulated, after a little prectice. For example an instruction whose binary form is sey 01101101 becomes 375 in octal form, while another whose binary form might be 11110010 becomes 722. You can see from these how much easier machine language programming becomes by using octal notation. It is important to realise, however, that if programs are written in octal notation, or in any other non-binary form, this is done purely for the convenience of the human programmer. Computers themselves "understand" only binary numbers, and regardless of their initial form, all programs must ultimately be fed into the machine in hinary. A program written in cotal notation is somewhat easier to handle than in binary, bur still tends to be rather abstract and inconvenient from the human viewpoint. There is no obvious functional correspondence between the code numbers and the instructions they represent, meking it necessary for them to be learned by rote. Even when this is done, it is by no means easy to visualise the operation of a program simply by scanning the code numbers. It is for this reason that programs are often written in what is called "mnemonic language". Here each type of instruction is represented by a three or four letter symbol, whose form is arranged to make its significance easily remem- bered. Hence the symbol "AND" is used to represent the logical AND instruction, for example, while "JMP" is used to represent the jump instruction. Other essily remembered symbols are used to represent varietions in the form of instructions, and as labels for memory addresses. For exemple an instruction might be written as "TAD I POINTR", where TAD stands for two's complement addition, I indicates that the instruction involves indirect addressing, and POINTR is the label given to the eddress in AD POINTR is the label given to the eddress in the current memory page contenting the ad- dress of the operend. So that you can start to become familier with the octal coding end mnemonic symbols for the instructions in EDUC-8's repertoirs. I have drawn them up as a table. This can be used as a convenient guide when writing program, until you get to the stage where you know them all by heart. all by neart. By writing a progrem initially in mnemonic languege, it is relatively easy for the programmer to visuelise its operation. Of course it is still necessary to translate the program into binary coding for the machine, but this is not difficult if handled in cotal. After a while, you'll be able to set the SR switches of the machine in binery, from octal coding, without batting an eyelid! Needless to say, the translation from mnemonics into code is rather tedious, and the ideal solution is to have the computer do the job itself. In fact this is elways done with full-scale machines, where a program known as an "assembler" is supplied as part of the software package sold with the mechine, for this very The idea is that the assembler program is stored in the machine, and under its control the mechine reeds the symbolic version of the new program—say from punched paper pape—and translates it to produce the binary code equivalent. This may be punched out as a second paper tape, known as the "object" sape. It is the object tape which is then used to feed the new program into the machine, when it itself is to be run. Programs written in mnemonic form are often said to be written in "assembly language", to emphasise that they are one stage removed ### Recommended for further reading Of necessity, the discussion of besic computer programming given here is only a brief introduction to the subject. It covers the basic principles, to a degree which should be about to begin writing simple programs with a fair amount of confidence and success. But there will insuitably be questions raised in your mind which will remain unanswered. For a more complete introduction to the subject, I can only suggest that you refer to a modern extraols on the subject. A book I cen warmly recommend is "Introduction to Programming", published by the Digital Equipment Corporation. It is available from Digital Equipment Australia Pty Ltd, at a cost of \$2.50 including post and packing. To obtain a copy, send a cheque for the above amount to the Education Manager, Digital Equipment Australia Pty Ltd. 123 Willoughby Road, Crows Nest 2065, with the envelope marked "Electronics Australia Enquiry". from true machine language. But it should be noted that there is a simple 1. I relationship between the two, in the sense that for every machine language instruction to be performed ultimately by the machine, there must be a corresponding assembly language instruction. As you are probably aware, this process of using the computer itself to simplify programming and reduce the tedium is often certified a stage further. By providing the mechine with a more elaborate translation program known as a "compiler", it can be made to translate programs written in more abstract language. The compiler program can be arranged to generate whole sequence of machine language instructions in response to a single input command, freeing the programmer from the need to worry about every tedious detail. he JC- or as o's in- nd in ıd- ith for VR ed am nic m- is ıot ďII ne ng a ob ıs ry ol ٦e ег ry as ٩d e, to ы You have no doubt come across the names of the more abstract or 'higher level' programming languages which have been developed to take advantage of compiler translation: FOR-TRAN, ALGOL, COBOL, BASIC, FOCAL, and so on. Because these programming languages make it particularly easy to write problem-soly-make it particularly easy to write problem-soly-compiling), they are often called problem-soly-defer compiling), they are often called problem-soly-maked groereming languages. As you might expect, e compiler program tends to be quite long; very much longer than could be fitted into the 256-word memory of EUC-8. This meens that the convenience of europe of the convenience th On the other hand it may well be possible to write an assembler program small enough to fit into the machine's memory, to permit automatic essembly of programs written in memonics. I have not had time to try writing such e program say that hope to do so soon. Dealis will certainly be published, if this proves practical. In the meantime, I suggest that you write your programs in meamonic form, and then annually code them in ceal using the guide table. This is not difficult, and will be good practice. With the programs in cotal form, for the time being you can feed them into the time being you can feed them into the clief on, when you perhaps five a paper tape punch and reeder, you can turn them into binary thanks of reeder you can turn them into binary thanks of reeder in the clief on. Before we turn our attention to the actual 'nitty gritty' of programming, a few broad comments on techniques are probably in order. The first step in programming is to make sure that you define clearly the task which the computer is to perform. This may sound trie, but it is not. It is very important, for unless the task is clearly defined, it is all too easy to produce e program which may perform a task other than the one you really wanted. As it may be herd or tedious to modify it later on, the bast way to avoid a lot of wested effort is to meke sure of defining the gool in the first place. Having defined the job to be done, the next step is to decide upon the way in which it can be achieved. This step often tends to blend with the third step, which is that of analysing the task and breeking it down into the specific computer operations which will be necessary. A vary useful sechnique which can be used to simplify these steps is flowcharting. This involves drawing a greph or flowchart, which shows the verious steps which will meke up the progrem, and the logical sequence in which they ere performed. By letting you visualise more cleerly the steps involved, the flowchart makes it easier to refine and simplify the progrem before you progress any further. It also | Mnemonic Operation Co | de | |-------------------------------------------|----| | MEMORY REFERENCE INSTRUCTIONS | | | AND logical AND 0 | ХX | | | ×Χ | | ISZ increment and skip if zero 2 | XX | | | XX | | | XX | | JMP jump 5 | ΚX | | (XX = operand address and mode) | | | OPERATE (OPR) MICROINSTRUCTIONS | | | | 00 | | | 01 | | | 02 | | | )4 | | | 20 | | | 20 | | | 22 | | | 24 | | | 30 | | COMBINED OPR MICROINSTRUCTIONS | ,, | | | 11 | | | 4 | | | 34 | | CMA.IAC complement and increment AC | ,4 | | | )5 | | INPUT/OUTPUT TRANSFER (IOT) INSTRUCTIONS | | | SKF skip on input flag 601.6 | 11 | | SDF skip on output flag 621,63 | | | KRS read input buffer 602.6 | | | LDS load output buffer 622.63 | | | RKF reset input flag 604,6 | | | RDF reset output flag 624,63 | 34 | | COMBINED IOT INSTRUCTIONS | | | KRB read input buffer, reset flag 606.63 | 6 | | LDB load output buffer, reset flag 626,63 | 6 | makes it possible to compare various epproaches in tackling the problem (there are usually a number of possible ways, and it may not be easy to pick the most efficient). After using flowcharts to settle upon the approach and refine the exect way in which staps are to be performed, the next phase start s FIG. 1 is to actuelly write the program. This is generally known as the "coding" phase. You might imagine that this would be the last real stage in the process of programing, followed only by assembly and storage in the machine before operation. However this is rarely the case. Generally there is a further stage, because human fallibility elmost always ensures that a program won't work in its initial form. The final stage is therefore one in which you perform "debugging". This involves running the program one or more times, noting the errors it makes, anelysing these with the flow-cherts and the written version of the program, and making the appropriate modificeions to remedy matters. The modified assembly language version is then assembled once more, to produce the finel object teep (hoppfully). Let us now turn to the detail of programming. Probably the best way to stert is with a very elementary example. Suppose we have two numbers, stored in memory locations, and we wish to add one to the other and store their sum in a third memory location. This is a very simple task, and would not normally involve e progrem of its own; it would simply form e minor step in e larger program. However for the sake of the exercise, a flow-chert for the steps involved is shown in Fig. 1. This is a very simple flow-chert, es you can see. There are only two different sorts of operation symbol, and the logical flow is in a simple lineer fashion between the rounded START and HALT terminations. The rectangular boxes represent the functional steps, with the arrows on the connecting linas showing the direction of flow. The reasoning behind the various steps should be fairly self-wident. The accumulator register is first cleared, to make sure that there is no residue from e previous operation to confusa the issue. Then the first number is added into the accumulator, followed by the second number. This forms their sum in the eccumulator, which is deposited in the desired memory location. Finally the machine is helted. The mnemonic or assembly language form of a simple program to parform this tesk might look like this: | CLA | /start: clears AC | |-------|-----------------------------------| | TAD A | /adds first numbar | | TAD B | /adds second number | | DCA C | /deposits sum | | HLT | /halts | | A, | /location of first number | | В, | /location of second number | | C, | /location in which sum is stored. | The first thing to note is that the actual program itself consists only of the left-hand column. All of the words to the right of the oblique slashes are comments, puraly for the benefit of anyone trying to follow what is going on-including perhaps the programmer himself, at some later stage. Whather you add such comments to your own programs is entirely optional, a few at strategic points in a program of the program of the properties of the properties of the properties of the program prog When a program written in assembly language is translated into binary code, these comments are completely ignored. Assembler programs mey be arranged to do this automatically, by ignoring all characters on the symbolic tape which follow a slash and precede a carriage return. The other main thing to note about our first program exempls is that the three memory locations used to store the two numbers and the sum have been given labels—"A."". B" and the sum have been given labels—"A.".". B" and the sum have been given labels—"It is not so maintained these can generally be any con-but in practice these can generally be any con-but in practice these can generally be any con-but in substances. The sum of Normally if the two numbers to be added together were to be loaded into the machina as part of the program, thair numerical values would be shown after the commas following their address labels. On the other hand if they were going to be loaded separately, the initial content of the two locations might be shown as zero. Similerly the content of the sum storage location would normally be shown as zero, to emphasise that the initial content is not significant. (But the latter is not necessary for correct operation of the program, as storing the sum in this location would automaticelly erasa any previous content.) Some of these points may become clearer Some of these points may be some clear if we look at the octal code equivalent to our program example. If the program were going to be stored in the computer's memory starting at the very first location, i.e., address 000, its coding would be as follows, where the locations in memory have been shown at the left for in memory have | erence. | | |----------|-------------------| | Locetion | Code . | | 000 | 710 | | 001 | 105 | | 002 | 106 | | 003 | 307 | | 004 | 721 | | 005 | (first numbar) | | 006 | (second number) | | 007 | (sum storad here) | | | | I suggest you spend a little time comparing this with the assembly language form, as this is probably the best way of gresping soma of the ideas of coding. Note that the program occupies eight memory locations, five for the setual instructions and three for the storage locations. The two numbers to be added to-locations. The two numbers to be added to-locations that have numbers to be added to the coding that the setual instruction and the setual results and added the program has been run their sum will be found in location QOT. If you look carefully at the coding for the three memory reference instructions, some of the points made sertier about the details of memory location should start to become clearer. Because they must refer to the location of the operand concerned, the exact coding for such instructions varies with the position of the operand in the common of the coding for such instructions varies with the position of the operand in memory. This is in contrast with the operate microinstructions, whose coding remains fixed. To emphasise this, here is how the coding for the same program would look if we were to store it in the next group of eight memory locations, at the same time changing the positions of the three data storage locations so that they precede the instructions instead of follow them: | Location | Code | |----------|-------------------| | 010 | (first number) | | 011 | (second number) | | 012 | (sum stored here) | | 013 | 710 | | 014 | 110 | | 015 | 111 | | 016 | 312 | | 017 | 721 | Notice how the exact form of the memory reference instructions has chenged, to correspond to the now addresses of the operands, while the operate microinstructions are unal-teed. The fact that the data storage locations are now "sheed" of the actual instructions has one now "sheed" of the actual instructions has even to be added to the program. The program is also shall be added to the program to the program to be added prog In practice it is often convenient to place at least some of the data storage locations before the actual instructions. The only thing to watch when this is done is that you remember to always start the program at the first actual instruction. If this is not done, the machine will fetch data numbers and interpret them as instructions — which can produce some rather strange results! I hope this very elementary programming example has helped you to gresp some of the rather subtle concepts involved. If nothing else, you will hopefully have begun to see by now the way in which instructions and data numbers stored in the machine differ only in tarms of intercretation. Let us now consider a programming axample that is a little more complex. Say we have two numbers storad in the machina's memory, as before, but this time we wish to find the difference between the two and store it again—but elways as a positive numbar. This tima the flowchart would be as shown in Fig. 2. Here we cause the two numbers to be subtracted, instead of added, by turning the fix into its negative equivalent (in 2's complement binary notation) before the second is added. This leaves their difference in the AC; but as we have no way of knowing which of the two numbers will be the larger, this difference may be either positive or negative. As we wish to store the difference in positive form, it is therefore ancessary to make the program perform a logical decision (diamond shaped box), and branch in one of two directions depending upon the result of that decision. If it finds the result is positive, it should store it away unchanged, but if the result is negative, it should convert it into the equivalent positive number before storing it. This is dona by forming the two's complement of the difference, in the same way used to negate the first number. A program written in assembly language to perform this task might look rather like this: /clears AC TAD NUMA /adds first number CMA, IAC /forms 2's complement TAD NUMB /produces difference SMA /is diff negative? JMP STORE /no, go to store it CMA IAC /yes, form 2's complement DCA DIFF /store it HLT /halt STORE, DCA DIFF, HLT / first number NUMB, / second number / difference stored here Here the labels "NUMA". "NUMB" and "OIFF" have been used for the three deta storage locations, just to show you another possibility. Similarly a label "START" has been atteched to the first instruction, mainly to clarify exactly where the program start. This can be very worthwhile if there are date storage locations ahead of the instructions. The second last of the start s The conversion of the first number into its 2's complement is performed by a single instruction, the combined operate microinstruction CMA.IAC. The second number is then added to the AC as before, in this case forming the difference. The logical decision and program branching is achieved by using the operate microinstruction SMA, together with a JMP instruction, if the difference solved in the AC is negative, the effect of the SMA microinstruction is to cause the control of the SMA microinstruction is to cause studies, so that it automatically goes to the seventh instruction (CMA-IAC) and forms the seventh instruction (CMA-IAC) and forms the seventh instruction (EMA-IAC) and forms the definition of the difference as required, before storing it. But on the other hand, if the difference is elready positive, the SMA microinstruction will not cause a skip, and the program will insisted go to the next consecutive instruc- This instruction is the JMP instruction, and its purpose is to allow the progrem to proceed directly to store the difference. This is achieved by yiding the "COA DIF" store instruction the label "STORE", and writing the jump instruction on e. JMP STORE. If the program is coded on the substance of instruction which is effectively the operand of the jump instruction. If it were to be stored in the computer's memory starting at location 000, the octal coding for this second program example would be: Location Code 000 710 001 111 002 705 013 003 112 004 724 005 507 006 705 007 313 010 721 011 (first number) 012 (second number) (difference stored here) This is a very simple example of a program involving a logical decision and so-called "conditional branching", but even so it illustrates that a program is not necessarily confined to the simple execution of a linear sequence of instructions. The ability of the mechine to test for certain conditions, end branch in various directions according to the result of the test, expands the whole scope end flexibility of programming considerably. Of the operate microinstructions in EDUC-8's repertoire, there are three which are used in this way for conditional branching: SMA, SZA and their combination SZA.SMA. Instructions which may also be used for conditional branching are the IOT skip instructions SKF and SDF, and the memory reference instruction ISS. The ISZ instruction is in fact very powerful. One of its other applications is for another important programming technique known as "looping". The best way to illustrate this is with another simple example. Let us say you want to repeat a certain sequence of instructions five times. One way to do this would be to simply repeat the group of instructions five times, so that the machine performed them one after the other. However this would tend to take up a considerable amount of memory. This space cen be almost completely saved by arranging for the program to loop around and perform the single group of instructions five times, before continuing. The principle used to achieve looping is shown in Fig. 3. Ahead of the sequence of instructions to be performed a number of time, a storage location is loaded with a number known as the "index", whose value is made caula to the 2 complement of the number of times the instruction sequence is to be performed to the property of the complex of the property of the complex comp After the ectual sequence of instructions to be repeated, the index number is arranged to be incremented. Then the program is arranged to test whether the value of the index has become zero or not. If not, the machine is made to jump beck to the start of the sequence. If on the other hand the index has become zero, the machine is allowed to continue with the next consecutive instruction. Becsuse the index hes initially been set to the 2's complement of the number of times the sequence should be repeated, it will not actuelly reach zero until the correct number of loops has occurred. Thus with our example where the index is set to minus 5, the program will eutometically loop five times before proceeding. The ISZ instruction can be used to perform both the index incrementing, and the testing to see if its value has reached zero. The looping back is then arranged simply by following the ISZ instruction with a JMP back to the start of the loop, as follows: CLA TAD CONST DCA INDX /initialises index to -5 GO, /sequence /instructions ISZ INDX /increment index, test JMP GO /not zero yet, keep going Note that CONST would be a storage location with the number minus 5 as its content, while INDX would be another location used to store the index. The rows of dots represent the instructions before, inside and after the loop. Note that the loop mey include any desired number of instructions. Looping is a particularly useful technique, as you can imagine. It allows considerable reduction in the length of programs, as most programs involve a certain amount of repetition. Or looking at it in enother way, looping allows more efficient use of computer memory, so that more elaborate programs can be fitted into the available space. Note that the ISZ instruction is not the only one which can be used as the basis of looping. Broadly speeking, any of the skip instructions can be used to achieve branching. The most appropriate instruction to use for looping december of the propriate instruction to use for looping pends upon the type of loop required—whether the program should loop for a fixed number or until some condition has been nesched. The ISZ instruction is often the most suitable for the former, but instructions like SMA ZSA, SKF and SDF are generally more suitable for the latter. An interesting exemple of the use of looping is where two numbers are to be multiple together. Here one number may be used to control the number of times the other is added to itself, by converting the first number into its 2's complement and using it as the index for a loop around an instruction added the second number to the AC: TAD NUM1 CMA.IAC DCA INDX /initialises ADD TAD NIIM2 /finished yet? ISZ INDX JMP ADD /no, keep going /ves. halt NUM1. /first number NUM2 /second number INDX /index stored here Note that in this case the program would halt with the product of the two numbers in the AC register. It could be arrenged to store the result in a suitable location, like the earlier examples, simply by adding the appropriate DCA instruction between "JMP ADD" and "HLT". A flow chart for the example just given is A flow chart for the example just given is shown in Fig. 4, to allow you to follow through the idea a little more essily. Apart from its use in arrenging progrem looping, the ISZ instruction can also be used to actuelly modify the instructions within the loop, so thet the program need not simply repeat a sequence exactly the required number of times, but can perform a series of similar operations. An example of this is well worth looking at, because it demonstrates that instructions are not necassarily "sacred" and unalterable Say you have a sat of eight numbers stored in consecutive memory locations, and you wish to add them all together to form their sum in the AC register. One way of doing this would be to have a sequence of eight different TAD instructions, each one referring to one of the eight locations. But it is more efficient to use looping around a single TAD instruction, and simply modify the address par of the instruction. each time. Thus if the locations in which the numbers are stored are given the labels "A", "A+1", "A+2", etc. the program would look like this: | START, | CLA | | |--------------|-----------|---------------------| | | TAD CONST | | | | DCA INDX | /initialises index | | GO. | TAD A | | | | ISZ GO | /modify instruction | | | ISZ INDX | /done B times? | | | JMP GO | /no, keep going | | | HLT | /yes, halt | | CONST. | 370 | /minus B | | INDX. | 000 | | | Α, | | /first number | | A+1,<br>A+2. | | | | A+2, | | | | | | | Only the first three data number locations have been shown, with dots to suggest the remaining locations. Note that the value given for CONST is the 2's complement of decimal B, in "377" format octal notation. Of the two ISZ instructions used in this example, only the second is used "fully"—i.e., to both increment and test whether the operand has reached zero. The first ISZ instruction is used purely to increment the TAD instruction, and this is a perfectly valid way of using an ISZ instruction. The only thing the programmer must do when using the ISZ instruction in this way is make sure that the number or instruction being incremented will never reach zero, or alternative ensures thet the program does not make an error if it does. In this example we know that TAD instruction will only be incramented B times, so that there is no problem. In cases, where it is not easy to predict if zero will or will not be reached, and no branching or looping must occur, the best idea is to follow the ISZ instruction with a NOP or "no operation" instruction. Although the method just illustrated can often be used to perform a series of similar operations, it is not always convenient to directly modify an instruction or sequence of instructions. For one thing, this complicates matters if the program is to be re-run, because the modified instruction or sequence of instructions will have to be changed back to their initial coding. In such cases, use can be made of a similar technique, but one which uses indirect addrassing via a "pointer". Here the pointer is incremented to change the memory locations referenced, not the basic instructions. For an example of this, consider a situation where we have a set of eight numbers in consecutive memory locations, as before, but this time we want to edd a constant—say octal 60—to each one, and replace it in its initial location. A program to do this could take the following form: /initialises index /first number first no. /fetches add. of TAD CONST TAD BUFSA DOL BOILITED DCA INDX START, CLA A+2. evercice | GO, | TAD I POINTER | /fetch number | |---------|---------------|---------------------| | | TAD CON60 | /adds 60 | | | DCA POINTER | /replace number | | | ISZ POINTER | /increment pointe | | | ISZ INDX | /finished yet? | | | JMP GO | /no. continue | | | HLT | /yes, halt | | CONST. | 370 | , | | INDX. | 000 | | | BUFSA. | | /address offirst no | | POINTER | ,000 | /pointer stored | | | | here | | CON60, | 060 | | It is possible to use the one number as both index and pointer, in some situations, and this can be used to simplify and shorten the program still further. In the axemple just given, this could be done laifly seally, by arranging for the eight be done laifly seally, by arranging for the eight contains in memory. The value of INDX seah time would then automatically correspond to the required pointer address. You may care to try re-writing the program to do this, just for the Along with the technique of using a pointer, the example just given also shows one important application of indirect memory addressing. Another important application of this should become apparent in a moment, as we discuss another very useful programming tachnique the subroutine. Like looping, subroutines are used to allow a particular sequence of instructions to be used repeatedly during a program. But the advantage of the subroutine is that the sequence may be used in many different parts of a program, not necessarily in contiguous fashion. The sequence is made a separate entity, with the program jumping to it as raquired—and then returning back to where it jumped from, each time. back to writer in jumplet from, sean 'time. The general idea is shown in Fig. 5. As you can see, the subroutina is in effect a separate program module, so which the machine jumps program module, so which the machine jumps time sequence is needed. After having used the subroutine, the machine then jumps back to the main program, to continue on from where it was. The instruction which is used to provide subroutines is the JMS instruction. This is a little like the JMP instruction, in that it has the effect of replacing the existing content of the PC register so that the machine takes its next instruction from a place other than the next consecutive location. But in contrast with the AMP instruction, where the existing content of the PC register is lost, with the JMS instruction the PC content is storted in the address given in the instruction, and the next instruction taken on that address, but from the one after This is used in the following basic way. The first location of a subroutine sequence is set saide as a storage location, immediately before the saide as a storage location, immediately before the saide as a storage location. The main program, a JMS instruction is used, specifying the address of the storage location. The feets of the JMS instruction is to store in that location the address of what would otherwise have been the next consecutive instruction in the main program, and to take the first subroution in the storage location. The In other words, the JMS instruction causes the machine to jump to the subroutine, but at the same time stores the address in the main program to which it should return, in the subroutine storage location. This stored address is known as the "return address", for fairly obvious reasons. To arrange for the machine to jump back into the main program at the end of the subroutine, it is merely necessary to make the last subroutine instruction en indirect JMP instruction, specifying the storage location at the start of the subroutine. The machine than automatically fetches the return addrass from the storegul location, and places it into the PC register. In terms of actual instructions, a subroutine and its associated JMS instructions tend to look as follows, when encountered in an assembly language program: JMS SUBRT JMP I SUBRT / fetches return add . to axit Here the top section represents the 69 main program, with JMS instructions wherever the subroutine is needed. The subroutine itself is baneath it, with its storage location for the return address at the start, and indirect JMP instruction used to exit at the end. Note that although the label "SUBRY" has been used hare for simplicity, any other suitable label may be used. This is the basic way of providing a subroutine, and is probably the way most often used. It is possible to alaborate on the basic idea for example if you want to transfer additional data numbers into and out of the subroutine (normally the only data transferred is the content of the AC register), but space limitations prevent us from going into this further here. An important application of subroutines is in servicing input/output devices, and we will look at this shortly. However before we do, it may be worthwhile to mention briefly the general use of indirect addressing for memory refarence instructions, in connection with mamory pagination. As mentioned in the earlier section dealing with basic machine operation, the eight-bit instruction words used in EDUC. 8 do not allow direct addressing of all memory locations. This is because a full eight bits would be needed to address 256 locations, and at least three of the eight instruction bits are already required, for the operation code. In fact, there are only four bits available for the actual operand address portion of a memory refarence instruction, as bit 4 is used to indicate tha addressing mode. As there are only 16 combinations possible with four bits, this means that any given memory reference instruction can only specify one of 16 partial addresses. This problem is not unique to EDUC-B, but is in fact shared with many minicomputers. The only difference is one of scale—with a typical commercial machine, some 256 partial addresses may be specified, rather than just 16. And with EDUC-B, we get around the problem in the same way used in a commercial machine. The convention adopted in the machine is to divida the memory effectively into "pages", in this case of 16 locations aach. The full 256-word memory of the machine is thus considered to consist of 16 pages, each comprising 16 locations, and with octal addresses as shown: | 000-017 | 200—217 | |---------|---------| | 020-037 | 220—237 | | 040-057 | 240—257 | | 060-077 | 260—277 | | 100-117 | 300—317 | | 120-137 | 320—337 | | 140—157 | 340-357 | | 160—177 | 360-377 | In effect, the instruction decoding logic of the machine "sexumes" that the partial address given in a memory reference instruction review of the machine "sexumes" that the partial address lying in the same page as the instruction isself. Thus if a TAD instruction is in the first page of memory and has the octal code 105, the machine will regard the location specified as that with the address 005. However a TAD instruction with the seme coding, but in the last page of memory, will be taken as specifying the locetion with the cortal address 305. This applies to both direct end indirect addressing, in the sense that the address of the actual operand eddress specified in an instruction is also essumed to lie in the same page as the instruction. So that if an indirect DCA instruction with octal code 313 is located in the first page of memory, in executing the instruction the machine will seek the number stored in memory at address 013 as the address at which to store the AC register contants. But if the same instruction code were encountered on the second isst page of memory, the machine would seek the storage address at memory address 363. From the programmer's point of view, the effect of all this to restrict the range of locations which may be specified by a direct addressing manny reference instruction, to those locations within the same memory page as an instruction itself—income as the "current page". However if you want to specify a location out to use indirect addressing instead, with a location on the current page used to store the actual operand address. An example should illustrate the ides. Say ou are in the first page of memory, and need to deposit the AC contents into the location with cotel address 246, in the eleventh page. The way to do so is to assign a suitable storage location on the current page, say at address 077, and store in that location the desired of the content t If you find that "337" a little hard to work out, it is made up as follows. The first figure is the operation code for a DCA instruction, octal 3, which is no problem. The remaining two figures are actually a combination of 017, the address of the current page storage location, and 020, which is the octal representation of the bit (bit 4) which indicates an indirect addressing memory reference instruction. To round off this introductory look at programming, let us now consider briefly what is involved in programmed transfer of data to and from peripheral devices. This is usually called "IOT servicing" As mentioned in an earlier section, IOT servicing involves three distinct operations. One is testing the flag line of the IOT device concerned, to see if the device is rasky to "do solviness", this is other described as testing flag settles. The second operation is transfarring the device of the second operation is transfarring the flag. Then and the third is resetting the device flag. Then and the third is resetting the device servicing cycle, but generally settle services are indicate to the device that the data stransfer is complete, at least from the comparer's viewpoint. The three instructions which parform these operations for an input device are nominally labelled SKF, KRS and RKF—shfbugh these memonics are arbitrary and could be varied to suit different types of input device. The second and third instructions may be combined to produce the instruction nominally called KRB, which transfers data and resast the device figg in the same execute cycle. These instructions are used to service an input device such as the simple keyboard unit by arranging them in the following sequence: As you can see, the SKF instruction is arranged to form part of a small program loop, by following it with a JMP instruction which forces the program to jump back DKF again. While the device flag remains raset, the program thus "twiddles its thumbs" by jumping back and forth between the two instructions. However as soon as the device flag is set, indicating that the keyboard has a character ready for transfer, the program can ascape from he loop because the SKF instruction will cause the JMP instruction to be stipped. The machine will then fetch and execute the KRB instruction, transferring the character into the AC register and resetting that keyboard flag. Fig. 6 illustrates the technique in flow-chart flow. A similar instruction sequence is used for servicing output devices, where the corresponding instructions are SDF, LDS and RDF, or LDB combining the second and third. However many output devices like papar tape punches and printers have drive mechanism, which may be deactivated when the flag FF is set. For this reason, the instruction sequence The program coding blank at right may help you in writing programs. Rather than use the blank itself, however, run off photocopies and use these. for output device servicing are often rearranged thus: LDB /load device buffer, reset flag TEST, SDF /device used char yet? JMP TEST /no, keep looking By doing this the character is loaded into the device buffer first, and the flag reset to activate the punching or printing mechanism. Then the program is forced to wait until the device indicates that the character has been processed, before proceeding. As before this achieved by using a JMP instruction to pro- duce a small loop. IOT device servicing sequences such as these are often needed many times in a program, and when this occurs it is usual to make them subroutines. Thus a program to make the masubroutines. Thus a program to make the masuing the simple input keyboard and octal display devices, might have two IOT servicing subroutines Isbelled "READ" and "DISPLY". Then whenever characters were to be read from the keyboard, his would be simply schieved by the instruction. MISTIRE WAS DISPLY. Who in Instruction and the service of the servicing subroutines Isbelled "READ", while to display MISTIRE WAS DISPLY. The two subroutines themselves would be written as follows: READ, 000 TEST, SKF SKF JMP TEST KRB JMP I READ DISPLY, 000 LDB BACK, SDF JMP BACK JMP IDISPLY With EDUC-8, these are the only besic methods available for IOT device servicing. More complex machinas generally offer the ability to service IOT devices in elternetive ways, some of which may avoid the time-wasting flag test loop. A common epproach is one employing en "interrupt" system, where the mechine continues with its main program until a device signals its aveilability. And with those biref details of IOT programming I must bring this section to a close. It has only been possible to deal with basic programming in a very limited way, and you will not doubt have many questions as yet unasswered. But hopefully you will now have enough basic insight into the concepts involved to provide a foundation for further study, es well as for trying your hand at some programs. To help you in this regard. I here prepared artwork for a simple program coding sheet. This has space for 32 instructions, or two pages of memory, and provides for both writing the instructions in assembly lenguage, and insert program writing a little easier and more convanient. I suggest that you run the page through a copier, and provide yourself with a steck of copies to actually write programs on The study of the printed reproduction as a It has not been possible to give eny examples of complete practical programs here, because of space limitetions. However I will try to give some axamples along these lines as we deal with further input and output devices. 35 70 15 ### EAL EDUC-8 PROGRAM | | EDUC-0 I HOGHAW | | | |------|---------------------------------------|------|--| | STEP | MNEMONIC | CODE | | | 0 | | | | | 1 | | | | | 2 | | | | | 3 | | | | | 4 | | | | | 5 | | | | | 6 | | | | | 7 | | | | | 10 | | | | | 11 | | | | | 12 | | | | | 13 | | | | | 14 | | | | | 15 | | | | | 16 | | | | | 17 | | | | | 20 | · · · · · · · · · · · · · · · · · · · | | | | 21 | | | | | 22 | | | | | 23 | · · · · · · · · · · · · · · · · · · · | | | | 24 | | | | | 25 | | | | | 26 | | | | | 27 | | | | | 30 | | | | | 31 | | | | | 32 | | | | | 33 | | | | | 34 | 3 | | | | 35 | | | | | 36 | | | | | 37 | · · | | | ### Interfacing EDUC-8 with punched paper tape Resuming the discussion of peripherals, the author explains here how to go about interfacing surplus paper tape readers and punches to your completed EDUC-8 microcomputer. Full logic circuits are given for typical reader and punch units, together with details of how to modify the circuits for other types. Software is also discussed, and a useful program presented to enable convenient punching of program tapes. ### by JAMIESON ROWE By this stage, quite possibly you have your DUC-8 microcomputer and its two basic peripherals working, and have been trying your hand at some programs. If so, you've no doubt begun to find it tedious loading each program into the machine via the front panel switch register, and will probably be keen to provide a more convenient and speedy means of achieving the same result. There are a number of atternatives to the manual method of feeding programs and data into a computer, as you are probably aware, and these generally involve a storage medium optical marks or magnetic coating, magnetic step, or emapered citize or feed to a storage of the state of these has its own combination of advantages and advantages, although some erow looked disadvantages, although some erow looked computer application than others in commercial computer application than others in commercial computer application and the state of the state and faster operation. sends to be on faster and faster operation. For the present I am going to deal with only one of these storage media and its handling, although I hope to be able to discuss certain others in later installments. The medium chosen for this initial foray into the subject is punched Why purched paper tape? Well, it seems to me one that is particularly well sustinct for storage of the modest-size programs used for an educational microcomputer like EUC-S. The program tapes are short—at the most they are program tapes are short—at the most they are not trailer. This makes them easy to handle, and quickly loaded into the machine even with a slow reader until At the same time the encoded information they contain is quite accessing the program of The equipment required to handle punched paper tape is also quite compact, and relatively simple. There is also a very practical reason for the choice: I believe you are more likely to be able to pick up surplus punched paper tape equipment than any other. There is a lot of this equipment then any other. There is a lot of this equipment being "persioned foff" from commercial data processing facilities at present, it generally being replaced by key-to-disc systems. Probably the most suitable sort of punch tape. equipment to look out for in this context is the hardware making up what was generally known in the EDP industry as a "keypunch station". These were not connected directly to a computer, but were used merely for off-line preparation of data input tapes from typewriter-style keyboards. There are two broad types of keypunch station. The simpler type was used for initial tape preparation, and has only a keyboard and tape preparation, and has only a keyboard and tape preparation, and the state of the state of the state known as a "verifier station", because it was known as a "verifier station", because it was used to compare the tape produced by the first operator with ostensibly the same information restured by a second operator (to try and detect, and correct, operator errors), this type opunch, but a face reader as well. The verifier station aguipment is the one to aim for, in other words, because this will, yield both a paper tape punch and reader, together with the necessary power supply unit to operate them. And for a bonus you'll get a keyboard unit — I hope to describe how to use this also with the computer, later on. If you're lucky, you may well be able to get hold of a complete verifier station for a few tens of dollars. Quite large numbers have been literally dumped in recent years, which seems almost criminal — particularly since most were made no more than twenty years ago, and cost more than a thousand dollars each! By the way, it is important to make sure that you get tape equipment designed to take paper tape 2.54mm (I inch) wide, and that it punches and reads the full 8 bit positions or "levels" possible with this tape. There are other types of equipment around, some of which use the same width tape but only 7 of the bit positions, while others use a narrower tape and either 5 or 6 bit positions. None of these would be anything like as suitable for interfacing with EDUC-8 as is the 8-level tape equipment, because the instruction and data words for the machine are all of 8 bits. To help you in checking that a set of equipment is a set of equipment of the equip To help you in checking that a set of equipment is designed for the correct 8-level tape, Fig. 1 shows the main features of this tape. It also shows the standard way of interpreting the bit position, with the three least significant bits on one side of the sprocket hole track, and the remaining five on the other. Note that the type of encoding used in surplus keypunch geer is not important for our present purpose, as this part of the equipment is not Incidentally, new punched tape equipment is available, if you can afford it. For example McMurdo Australia have a basic tape reader of Italian manufacture, the Ghielmetti type DTR 40K. This operates at up to 40 characters per second, but costs \$270. The reader and punch unit pictured are both from a verifier station marketed by a big British computer firm, and are fairly yejical. Both units were originally made by the Welmec Corporation, of London. The reader unit is designated type R8.1, and the punch unit type \$18.8. Both operate from a nominal 120V DC supply, and are capable of working at speeds up to around 10-15 characters per second. The Walmer RB. 1 reader unit uses mechanical sensing of the punched holes, by means of eight small spring-leaded sensing pins. These are attached to a yoke assembly, which is moved upward towards the tape by a pair of heavy-duty solenoids. Each sensing pin is connected by a mechanical linkage to a set of switch contacts, so that the contacts close if their pin meet a hole and is able to travelrits full upward stroke. Conversely if a sensing jin does not reader that the contacts is the stroke contacts and the contacts is the reader of the contacts. At the top of its stroke, the yoke assembly At the top of its stroke, the yoke assembly At the top to bistable switch contacts, which during the other than the top of o The yoke assembly has a pawl which engages with a ratchet mounted on the same shaft as the reader's tape sprocket. In falling back to its rest position the yoke assembly thus causes the tape to be incremented to its next row of punched information — after the sensing pins have been withdrawn. Finally, at the bottom, the properties of Note that with this type of reader mechanism, the number actually encoded on the tape is only "read" by the sensing pins, and reflected in their switch contacts, at the top of the stroke. This tends to make interfacing a little more complex than with other types, which generally Above are two views of the Welmec tape punch, as modified by the author, with the power pack visible in the right-hand shot. At right is the companion reader unit, as modified for loading. tend to read the tape in a static fashion—i.e., whenever the tape is not actually moving. This means that the simple circuits' I have developed for use with the Welmer creader and similar "on the fly" types should work even more reliably with static types, and in that sense they should be suitable for almost any mechanism. On the other hand a static reading mechanism will generally work quite well with even simpler circuits, should you wish to take advantage of this. Let us now look at the logic circuits required to interface a reader mechanism with our EDUC-8 computer. There are actually two different types of circuit, because there are two distinct functions which a reader may be called upon to perform. One of the functions is to read input data into the machine, under the control of a program, in the same way data is fed in via the keyboard. This can be the major function of a reader with a large machine, but with a small machine like EDUC-8 it is likely to be of rate less importance than the second function: loadion, noncrease. It is of course possible to load programs in the same way as data is read into the machine, under program control. Here the machine must contain a small program known as a "loader" or "bootstrap"; whose sole purpose is to direct the machine in loading in the real programs. The bootstrap program may either be stored in the normal memory of the machine, after having been led in manually via the consoline that the programs are program may either the store that the programs are considered in the programs of the programs of the programs of the programs of the programs of the school will be programs of the th While a bootstrap program may be used with EDUC-8, this is not a very attractive proposition because the bootstrap would take up valuable memory locations. Even if it took up only 10 or 15 memory locations, this would be a significant and irking proportion of the total 256 available. Happily this can be avoided, by providing acade unit itself with the necessary logic "know how" to enable it to load programs automatically. Provision was made in the basic EDUC-8 design to allow this to be done, by means of the external "load address" and "deposit" sionals. Logic circuits will be presented here for both types of tape reader function. They will be presented separately, but could be combined if you so desire. The first, that for program loading, is shown in Fig. 2. This circuit has been designed to load program tape junched in the following way. First, the tapes have a length of "feader". blank except for the sprocket holes; this allows the tape to be inserted into the reader gate without concern for the actual information. Then at the end of the leader, the start of the information itself is indicated by a single hole punched in the most significant bit position (track 7 in Fig. The row (or 'frame', as they are called, immediately following the start bit is then used to contain the address of the first memory location in which the program is to be stored, centrol in which the program is to be stored to the program is the program is the stored in the program is the order they are stored in memory. No further address information is required after giving the first storage address, as the instructions are automatically stored in consecutive locations. As the proposed the stored in consecutive locations are the start stratuction. This format is illustrated in Fig. 3. Note that it is usual to cut the start and end of tapes as shown, to make it clear which end is which. The heart of the loader logic in Fig. 2 is the two RS flip-flops FFA and FFB, formed by t the cross-coupled gates G2-G3 and G4-G5 resps to tively. These effectively form the "memory" of the loader, and control its operating sequence. When power is first applied, both flip-flops are reset by the R-C circu it connected by diodes to the free injusts of G13 and G5. To initiate loading after a tape has t been inserted into the reader, the operator m analy presses the "load button". This takes the associated input of gate G1 to logic high, and because the other input of G1 will normally el so be high (more about this soon), the output of G1 will go low. The effect of this is to switch FA to the set state, with the output of G2 high and that of Slow. Beas current thus flows in transistor 17, we the series dio de and resistor connected to the output of G3. Accordingly 12 conducts, and epighs forward, bits to the gate of the formation of the output of G3. Accordingly 12 conducts, and exposed to the critical is thus completed for the resider activator solenoids, and the reader mechanism thus starts operatin q. Pulsed by the action of the latching reader switch contacts, which alternetively make and break the solenoid | circuit at the bottom and top of the strokes, the reader begins scanning the tape. A small low-volt lag ratialy RLYA is connected was 2.7kf / 10W dropping resistor in parallel with the reader subemplied resistor with the reader subemplied resistor with the reader subemplied with the reader subemplied with the reader subemplied with the reader subemplied with the reader subset of the reader subset of the reader source contacts on RLYA is then used to generate a feedback it ogic signal, whose bounce transients are a suppressed by the RS fligh-floor formed by gates (38 and G9. When the reader is operating, the output of gate G8 is thus a rectangular wave, whose high-to-low transition occurs at the true of the reader subset This transition in is important, because it corresponds to their instant in the reading cycle when the sensing pi in contact have been stabilised in their "read" positions. Hence the signal from GB is used to trigger three cascade-connected mycostables (cneah-olds) DI, D2 and D3. The oppositions the properties about 50us "long, important power about 50us" long, important power about 50us "long, important power about 50us "long, important power about 50us" long, important power about 50us "long, important power about 50us" long, important power about 50us "long, important power about 50us" long, important power about 50us "long, important power about 50us" long, important power about 50us "long, important power about 50us" long, important power about 50us It is the it nird pulse, from 03, which plays the first part in the loading sequence, via gate G7. The set ond input of this gate is driven by a PNP trans listor, T3, whose base is connected to the read er sensing contacts associated with bit position 17. During 1 he sensing of the paper tape leader where the re are no information holes punched, all of the r sader sensing contacts remain open. However, upon the arrival of the "start" frame, the contracts for bit 7 close at the top of the stroke, 5 to that 13 conducts and takes the second in put of G7 high. When the pulse from monosti bile 03 arrives at G7, the gate output therefor e goes low, and this causes FF8 to be The setting of FFB causes two things to happen , Chne is that the inputs of gate G16 are tak-an low, so that its output goes high; this or iables gates G17-G24, to open the data paths between the eight sets of reader sensing contacts and the switch register circuits of the comp jutar. The second thing that happens when FER sets is that gate 68 now has both inputs taken high, so thist its output goes low and that of 12 goes high. This enables gate 614, so that at the top of the reader stroke for the next crinscuttive frame, the 60 up pulse from monostable DII causes 614 to deliver a LOAD 400RESS (U) pulse to the computer. Because the reader sensing contacts will simultaneously be sensing the initial loeding address on the tape, this causes the computer to load the address into the PC via the switch register This is providing, of course, that all of the switch register switches are in the "up" or 1 position, so that gates G17-G24 in the logal can control the logic levels. This is also necessary for correct depositing, so that when the loader is operated, the SR switches must alweys be in the up position. Immediately after the address is loaded, the short pulse from monstable D2 arrives at the input of gate G10. As the second input of this gate is now high, because FFB has been set, the output of G10 is thus driven low briefly. And this in turn resets FFA, so that now only FFB is left in the set state. Despite the resetting of FFA the reader mechanism continues to operate, because of the second diode and resistor connected from the base of T2 to the output of G5. Gate G6 is diaboled, as the output of G2 has now gone low, but G11 is now enabled, because the outputs of G3 and G4 are now both high. This causes the output of G1 it to g0 low, and the output of G1 it to g0 low, and the output of G1 it to g0 low, and the output of G1 it to g0 low, and the As a result, at the top of the next consecutive reader stroke, the 60us pulse from monostable D1 is now passed by G15, to deliver a DEPOSIT (I) pulse to the computer. And this occurs when the reader sensing contacts are registering the first instruction, so that the computer will deposit this instruction as required in the first desired memory location. This last sequence of events will be repeated for succeeding frames of the tape, depositing each of the instructions in turn. The loading sequence will normally only come to an end when the tape end sensing awitch of the reader when the tape end sensing awitch of the reader has been applied to the sensing awitch of the reader. The switch breaks the 120V supply to the solenoids, stopping the mechanism. At the same time it causes the "tape fault" lamp to light, and resets FFB of the loading logic, by connecting to the latter's base. When FFB resets, the output of G16 goes low, disabling gates G17-G24 and thus freeing the switch register circuits for normal operation. At the same time G15 is disabled, so that both the LOAD ADDRESS (I) and DEPOSIT (I) lines are also freed. And as both FFA and FFB are reset, the loader circuit is back to its initial state, ready, for loading another program when ready. As you can see, the operation is not particularly complicated, wet the circuit performs the required loading sequence simply and reliably. I contains only eight 10.5, o which is are of the low-cost 1 garden variety. 17.400 x 3, and 17.41 to 3. The remaining two are 900 devices, and 17.41 to 3. The remaining two are 900 devices, on the 100 devices of the 100 devices of 100 devices, and 17.41 to 17 Note that because the reader solenoids are highly inductive, they tend to generate a high back-EMF when their current is switched. This is the reason for the R-C circuit across the 120V switch contacts, for the EMAG diode, and for the R-C network across the SCR. The latter is to reduce the rate of rise in anode voltage, which would otherwise cause the SCR to turn on spuriously — and to its detirmant. The 10k pull-up resistors connected to the outputs of gates 617-624 are effectively in parallel with similar value resistors on the front panel board of the computer itself. I have found them necessary in order to ensure completely reliable operation of the loader with "worst case" 7401 gates, whose output leekage in the high output state cen be as high as 250uA. the high output state cen be as high as 250uA. The edditional resistors would not be required if the existing resistors in the machine were reduced from 10k to 4.7k, but this is not easy once the machine is essembled. The pull-up resistors shown on the outputs of G14 and G15 are for the same purpose. Again it is easier to fit additional resistors in the loader, rather than to change the existing resistors in the machine itself. Note also — and this is very important— that for correct loader operation, the 0.1 uF capacitor shown bymassing the external deposit line of the possibility of the control of the moved, and replaced by a unit of .00 uF. This is necessary to prevent featily operation due to distortion of the loader's DEPOSIT (b) pulses from G15. The easiest way to make the change is to clip the original capacitor from the front panel board, and to write the new one in at the 16-pin loader socket on the machine's rear panel. The exact physical form of the loader logic just described will depend upon the reader unit you obtain, and this is left to you. In my case all of the circuitry except the SCR, its R-C circuit and RLY A with its dropping resistor were mounted on one of our "Multi-DIP" boards — the larger size, having space for eight ICs. The other parts just mentioned were mounted on other parts just mentioned were mounted one of the parts just mentioned were mounted on some size of the parts just mentioned were mounted on some size of the parts just mentioned with the size of the parts just mentioned with the size of the parts just mentioned with the parts just mentioned with the parts just mentioned with the parts just mentioned with the parts just described in t The loader connects to the computer vie a multi-way cable, which brings 5V OC to the loader as well as meking the signal connections. The cable ends with a 16-way McMurdo plug, mating with the loader socket on the computer rear panel. High voltage for the loader is derived from the original keypunch power pack, which is e simple transformer and selenium bridge unit with a 1000ubr reservoir electro and a rating of about 2A continuous. I used a "Bulgin" 3-way panel-mounting plug on the loader, meting with a cord-type socket on the cable from the power pack. Note that the purpose of G1 in the loader logic circuit is to prevent the load button from setting FFA if the high voltage is not connected, or if the reader gate is open (which open cent) the tape end switch). When there is no high voltage, the contacts of RILY A revert to their normal positions, so that the output of G8 remains low and prevents G1 from responding to the load and prevents G1 from responding to the load. button. This has been done to prevent the reader from suddenly "bursting into life" while the tape gate is being closed, if the load button has accidentally been pressed. Such a sudden start could well damage the tape, by morging it before the gate is properly closed end latched in position. I should perheps point out that the circuit of Fig. 2 does not show the 5V supply connections to the various ICs: these are assumed. Also not shown but nevertheless required are the usuel bypess capecitors on the 5V line. I used two 0.1 Lin EV polyester capecitors in the loader, one where the 5V enters the board, and the other at the far end. The other logic circuits given here will assume the same power supply and bypessing provisions. As mentioned earlier, this loader circuit should be suitable not only for "on the fly" reader mechanisms like the Welmec R8.1, but also for those with static reading. However, if the reader mechanism uses a stepping moot or a motor and clutch escapement for tape drive, in place of the solenoids, you will need to modify the circuit slightly. Such reader mechanisms are generally not capable of self-cycling like the Welmec unit. They must usually be triggered into operation for each read cycle, by means of a pulse fed to the driver circuit controlling the stepping motor or clutch escapement solenoid. As an example of what is required for mix type of mechanism, Fig. 4 shows the changes I found necessary to adapt the loader logic for low with a type 1741 reader made by the Tally Corporation of Seattle. This reader has a synchronous motor and clutch escapement being drive system. the clutch escapement being drive system, the clutch escapement being the system of the clutch and the system the appropriate language that the six a power transistor field by a monostable, both of which are built mot he reader that of which are built mot he reader unit. You can see from Fig. 4 has der unit. You can see from Fig. 4 has en mainchange to to the fogic is the addition of a simple clock oscillator, whose output these from Fig. 2 the reducted logic internal Set in Fig. 2 the reducted logic ingoing from GB in Fig. 2 the gaste formerly used for GB is now used as an OR gate, which enables the clock oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator when either FFA or FFB are set. The oscillator The trigger pulses required for the monostable and driver circuits of the reader are derived from the output of D1, via the gate formerly tively slowly to the drive pulse — compared with the 70-odd microseconds required for the logic to operate. In fact the tape typically does not start to move until about 3ms after the start of the drive pulse, and the sensing contacts do not begin moving for another 3 or 4ms. There is thus more than enough time to sense the tape before the sensing contacts are disturbed. Note that there are other motor-clutch readers, like the Tally model 424, which do not provide the clutch solenoid driver or its monostable. For such readers the remaining 9602 element in the loader logic may be used to generate the required pulse (4.5ms long for the Tally 424), and a suitable power transistor used to drive the solenoid. The Tally model 424 has either a 48V solenoid, of 220 ohms resistance, or a 24V solenoid with 50 ahms resistance. In either case a series R-C circuit of 0.25uF and 10 ohms should be R-C circuit of 0.25uF and 10 ohms should be R-C circuit of 0.25uF and 10 ohms should be R-C circuit of 0.25uF and 10 ohms should be R-M098 or similar diode as with the solenoids of Fig. 2. With these to suppress transients, the driver transistor could well be a 2N3055, or the smaller 2N3054. The Tally readers may be fitted with a tape end sensing switch, but this is not connected into the clutch escapement circuit. It is left free, for use in the associated logic: I simply connected it as shown in Fig. 4, so that it merely turns on T1 to reset FFB as before. Having looked at the logic required for a program loader, let us now turn to the logic required for program-controlled reading. This is considerably simpler, as you can see from Fig. 5. Note that this circuit has again been designed for a Welmec type R8.1 reader, or THE STRENGTH TO A MODIFIC LOSS REAL MODIFIC COLUTE CHARGE STRENGTH COLUTE CHARGE CHARG used as G9. The 60us pulses from D1 are quite suitable for tiggering the escapement monostable, so that the clutch increments the reader sprocket to move the tape one frame forward after each H-L transition in the lock oscillator output. The pot in the oscillator circuit thus becomes the loading rate adjustment, and with the Tally 1741 reader it can be set for speeds up to 50 characters per second. As the clutch escapement pulse is being derived from D1, it might seem as if loader operation would be disrupted, with the tape being moved at the very time sensing takes place. However, this does not happen, because the reader clutch escapement responds relative to the property of a similar 'on the fly' type. Here there are only five ICs, of which two are 7496 devices which form the buffer register. The others are a 7437 forming the flag Fr G1-G2) and the line drivers, a 7400 forming the feedback bounce integrating FF (G5-G6) and the clock pulse and data inverters (G7 and G9), and a 9602 dual monostable for D1 and G9), and a 9602 dual monostable for D1 and Operation is as follows. Initially, the flag FF formed by G1 and G2 is reset, with the output of G2 in the low state. This causes transistor T1 to conduct, triggering the SCR and starting the reader. Then at the top of the reader stroke, RLY A is turned off, along with the solenoids. This produces a clean H-L transition at the output of G6, triggering monostable D1 and subsequently D2. In this case these produce pulses of length about 10us and 1us respectively. The pulse from D1 is produced first, and this is fed to the parallel load enable inputs of the buffer register. This causes the information from the reader sensing contacts to be loaded into the buffer. Then D2 produces its pulse, and because the Q-bar output of D2 is connected to the free input of 62, this sets the flag FF. When the flag FF sets, this removes the forward bias from transistor T1, preventing the SCR from conducting at the end of the return stroke, and hence stopping the reader. At the same time the flag line to the computer is driven low by G3, indicating to the machine that the reader has a character ready for transfer. As soon as the program in the machine tests the flag line and finds the flag set, it can accordingly shift the contents of the reader buffer out, by feeding clock pulses in via G7. The number in the buffer leaves via G8 and G4, the latter being the line driver and the former an inverter to maintain correct logic polarity. Note that when the contents of the buffer are shifted out, the buffer is automatically cleared because of the earthed PA, PB and DS inputs on the first 7496. This causes zeroes to be shifted into the buffer as the character is shifted out, clearing it ready for a new cycle. The final phase of the reader cycle occurs when the computer sends its RESET FLAG (L) signal, which resets the flag and restarts the mechanism ready for a new cycle. The RESET FLAG (I) signal is also fed to the Cubar inputs of the buffer (IS even though during normal reading the buffer will already be cleared when the signal arrives. The reason for the connection is that the buffer (IS will generally contain a spurious character when power is first applied, due to either the random unron effect or to the reader ping through unron effect or to the reader ping through unron effect or to the reader ping through unron effect or to the reader ping through generally contain the general ping and generally contained to generally gen As with the loader logic, the circuit of Fig. 5 may be adapted for use with a stepping-motor or motor-clutch type reader. The modifications for a Tally type 1741 reader are shown in Fig. 6. As before the main change is the addition of a clock oscillator which in this case is enabled directly by the output of G1 in the flag FF. The output of all in the flag FF. The output of all as the original forms of the clock oscillator connects directly to 17 as before. Drive pulses for the clutch escapement monostable and driver are taken from the output of £1, as before, in this case using the second 7413 element as an isolating gate. Although the pulse is only 10 usin this case, shorter than with the loader, this is still quite adequate. If you are going to use the reader logic with a Tally type 424 reader, without the inbuilt monostable and driver, a second 9602 will be needed to generate the 4.5ms pulse, with a 2N3054 or 2N3055 as before. Incidentally, the two 7496 devices used for the buffer register in the reader logic could easily be replaced by a single device, or of of the never 74 165 type. This is an 8-bit parallel to serial register, more or less a mirror image of the 74164 in terms of function. The main logic change required if you want to use this device is that the parallel load pulse will need to be taken from the C-bar output of D1, as an active low pulse is required. The final logic circuit to be given is that for a tape punch, shown in Fig. 7. This has been developed for the Welmec type \$18.8 punch, as pictured, although it should be fairly suitable for most surplus punch units. Mechanically the Welmec punch is not unlike the companion reader, in that the drive is provided by a large solenoid and yoke system which can cycle is their Via a bistable switch. As the control of their via the control of their via the When the yoke of the punch mechanism is pulled up by the solenoid, it is potentially able to force eight hardened punch pins through the tape, which is hold between two die plates. But which of the punch pins are actually forced upward depends upon the position of each of eight spacer bars, controlled by the coding solenoids. Only those point of the plates are considered to the plates are plated to the plates actually punch holes, so the pattern of holes punched is controlled by the solenoids. As you can see from the circuit, the punch logic is not very different from that for the program-controlled reader. Relay RIY B. controlling the main punch solenoid is controlled by an SCR driver, triggered by transistor T1. This in turn is ocntrolled by gate G3, and also by the manual tape feed button. A second relay RIY A1 is used as before to provide a feedback logic signal, conditioned by the flip-flop formed by gates G3 and G7. In his case the H-L end of the cycle of the punch downward stroke, at the very end of the cycle. In normal operation, the computer first shifts the character to be punched into the punch's buffer register, which is formed by the 74164 device. It then resets the punch flag FF. This causes a high-to-low transition at the output of G2, which triggers monostable D1. The output pulse from D1 does two things. One is to enable gates GB-G15, which transfer the character code stored in the buffer register to the coding solenoid drivers. These are transistor-SCR circuits like that used for the main solenoid relay. Those solenoids corresponding to the buffer bits set to 1 are thus turned on, pulling the appropriate spacer bars into position. The second effect of the pulse from D1 is to enable gate G5, whose other input is currently held high by the output from G6. The output of G5 thus goes low for the duration of the pulse, causing T1 to trigger the SCR and so activate RIV B and the main punch solenoid. The combination of holes determined by the coding solenoid is then punched, when the punch yeld reaches the top of its stroke. At the top of the stroke the hi-stable switch disconnects the 20V supply from relay B, so that it turns off and switches off the main solenoid. At the same time the hi-stable switch also connects 120V so RIY A, so that it activates. This causes the fill-plip formed by G6 and G7 to change state. The output of G7 goes high, and remains there until the punch yoke falls to the bottom of its return stroke. Then the bistable switch reverses, turning off RIY A and reapplying power to the RIY B circuit ready for the next punch cycle. When RLY A turns off, the output of G7 falls to the low state, and this triggers monostable D2. The output from D2 then sets the flag FF, indicating that punching has been completed. Note that when the bi-stable switch removes the 12OV supply from RLY B at the top of the punch stroke, it also removes the supply from the coding solenoids and their SCR drivers. The coding circuits are thus reset, ready for a new As before, the mechanical form of the punch logic circuitry will depend very largely upon the punch unit you have. With the Welmec unit was able to wire up all of the low-voltage wiring on a cut-down version of the large wiring on a cut-down version of the large winded plot and the two redundant Costions being cut off to allow the board to be fitted united the punch tasse. The eight coding solen-inside the punch tasse, the eight coding solen-will be the compared to the control of t It is not practical to build the power pack into the punch case, and in any case this operates the reader unit as well as the punch. It is left in its original case, with a heavy-duty 5-wire cable connecting it to the punch unit | EQUC-8 PROGRAM | BINARY TAPES FROM<br>KEYBOARD OCTAL CODE<br>starts at \$86 | |----------------|------------------------------------------------------------| | STEP | MNEMONIC | COOE | |------|------------------------------------------|------------| | 0 | R FAD, Ø | 000 | | 1 | TEST, SKF | 611 | | 2 | JMP TEST | 501 | | 3 | KBB | 616 | | 4 | JMP I READ | 520 | | 5 | BUFF,ø | 000 | | 6 | START, RKF | 614 | | 7 | JMS READ /fetches A | 400 | | 10 | DCA BUFF | 305 | | 11 | TAD BUFF | 105 | | 12 | LDB /display A | 626 | | 13 | TAD BUFF | 105 | | 14 | RAL | 702 | | 15 | RAL | 702 | | 16 | DCA BUFF | 305 | | 17 | JAS READ /fetch S | 400 | | 20 | TAD 1 BUYD | 137 | | 21 | RAL | 702 | | 22 | PAL | 702 | | 23 | RAL | 702 | | 24 | XA 1 Biffo | 337 | | 25 | TAD I BUFD | 137 | | 26 | LDB /display AB | 626 | | 27 | Jis 1 REXD /fetch C | 436 | | 30 | TAD I BUFD | 137 | | 31 | DCA 1 BUED | 337 | | 32 | TAD 1 BUTO | 137 | | 33 | L'MB /display ABC | 626 | | 34 | J:IP 1 CCHT | 535 | | 35 | CDITT, g4g* | 100 | | 36 | REND, ### | 000 | | 40 | B'JFD, \$\$\$5* | | | 1 | JHS I RE'B /fetch command<br>SIW /punch? | 433<br>724 | | 2 | J:P SCRB /no,scrub | 310 | | 3 | CLA /yes, go ahead | 710 | | 4 | TAD 1 BUFB /fetch word | 134 | | 5 | LPB | 636 | | 6 | CHEK, SPF | 631 | | 7 | J:IP CHEK | 506 | | 10 | CLA | 710 | | 11 | L'MB /clears Hisplay | 626 | | 12 | JiP 1 STAD /buck to start | 535 | | 13 | 578, ###* | 000 | | 14 | BUFB, ##5* | 005 | | 15 | STAD, ##7* | 007 | | 16 | | | | 17 | | 1 | You can use this simple program to punch out program tapes, using the simple input keyboard and display. It occupies only three pages of memory. Note that the constants identified with asterisks are initially in "377" format octal, but are then converted into "737" format to avoid possible confusion. The program starts at location 006 to provide both 240V AC and 120V DC as required; the fifth wire is earth Apart from the power pack, the punch unit was made fully self-contained by transferring into its case the back space button and the "tape fault" lamp. These were originally in the small control console of the keypunch station. The old multi-way connector was removed from the side of the punch case, and replaced with a small aluminium plate. This mounts the back space and manual feed buttons, the tape fault lamp and the 6-way "Bulgin" captive plug used to connect with the power pack cable The connection to the computer is made via a length of multi-conductor "TV remote control" cable, as with the simple keyboard and octal display units. The cable leaves the punch case via a grommeted hole, and terminates in a 6-pin DIN plug mating with the output device connectors on the rear panel of EDUC-8. Since probably the main use of the punch with EDUC-8 will be to prepare program tapes. I have reproduced here a small program which allows you to punch program tapes easily using the simple keyboard unit and the octal display. In effect, the program is a very elementary 'assembler", producing binary code from 3digit octal mumbers To use the program, connect the keyboard unit to EDUC-8's input device socket number 1, the octal display unit to output device socket number 0, and the tape punch to output device socket number 1. Then turn on both the computer and the punch power supply and, using the manual feed button on the punch, run off a suitable length of leader - say 20cm Now load the program into the machine, and enter 006 into the PC register as the starting address. Then set the machine running by pressing the run key. The program is now ready to begin punching a program tape. First press the "4" key on the keyboard, and after this press the "O" key twice. The octal display should now show "400", and if it does. press the "LF" key. This will cause the punch to encode the start bit on the program tape, in bit position 7. The reason for pressing the keys to give octal 400 is simply that this corresponds to the binary number 10000000, in the "737" format assumed by the encoding program. A similar process is used to encode the first loading address on the tape, and the actual instructions. Simply use the keys on the keyboard to enter in the octal code for the numbers to be punched, and if the octal display shows that you have made no mistake in keying in the three digits, press the LF key to have the resulting binary number punched If, on the other hand, the octal display shows that you have made an error keying in the digits, it is merely necessary to press one of the numeral keys instead of the LF key. This will cause the program to ignore the number keyed in and clear its buffer ready for a new character. You can then try over again. This is a very simple little encoding program, and you will no doubt be able to write more pretentious and elaborate ones yourself, if not immediately then later on. However, I have found it quite adequate for preparing program tapes and offer it to you as something to get you started. Incidentally if you have a program already in the computer's memory, there is a quick way to punch it on tape for future use-providing that it doesn't take up all of memory. This is by using a "dump" program, written to punch out all of the numbers stored in a designated section of memory Such a program can also be used for duplicating tapes, if you have only a tape loader. Simply load the tape in, then dump it as many times as required. You may care to try writing such a dump program-it is a worthwhile exercise, and you'll find the program useful. I hope the foregoing gives you a fairly good idea of the way in which punched paper tape equipment may be interfaced with your computer. As you can see, it is not difficult or unduly complex. If you are able to get hold of the necessary hardware, it is well worth the effort to make up at least the loader and bunch units not only for the exercise, but also because it makes program loading much more convenient A discussion of other peripheral devices will follow QUAD 50 E **PROFESSIONAL** A single channel mono amplifier designed for Broadcast, Recording and other applications in the Audio Industry. The multiple output windings of the Quad 50 terminate in a multiple output socket on the amplifier. Choice of matching is obtained by various connections in the output plug which is part of the installation itself. Quad 50 amplifiers may, therefore, connections in the output jug which is part of the installation itself, Quad 50 amplifiers may, therefore, be moved from one application to another without in the part of mum distortion resulting from such overload POWER RESPONSE: —1 dB at 30 hz and 20 kHz ref to maximum o spot some of the source NUM & NOISE: Batter than 80 dB referred to full output FREQUENCY RESPONSE: -1 dB 30 Hz and 20 kHz ref; 1 kHz —1 dB 30 Hz and 20 kHz ref; 1 kHz. 600 ft bridging: — 2dB 30 Hz and 20 kHz ref; 1 kHz. MPUT LEVEL: 0.5V for full output, belenced or unb Preset edjustment for higher lavels. MPUT IMPEDANCE: -50 KA depending on preset gain 00 bridging 14 K Q in parellel with 50 H. onelly stable with any load Price and full particulars obtainable from the Australian Agent: British ivierchandising Fty. Ltd., 49-51 Yark Streat, Sydney Telephone: 29-1571. ## Interfacing EDUC-8 with a Philips 60SR printer unit Continuing the discussion of interfacing peripherals with the completed EDUC-8 microcomputer project, the author describes here the interfacing necessary for a Philips 60SR mosaic printer unit. With such a printer, your computer is able to print out messages, requests or the results of calculations in easily read form. ### by JAMIESON ROWE Most computers have a printing unit of some kind among their output peripherals, to allow them to communicate easily with a human operator and at the same time provide a permanent record of their interaction. With small machines there may be only the printing section of a teletypewriter, while larger machines tend to have one or more high-speed line printers as west: Integral part of mest computer systems, as minergal part of mest computer systems, as minergal part of mest computer systems, as minergal part of mest computer systems would not really be completed if it did not include a discussion of this aspect. Even if you don't actually get around to obtaining a printer and hooking it up to your computer. I hope you will find the discussion of interest and value. I have selected the Philips 60SR mosaic printer unit as the basis for discussion, for two main reasons. One is that it appears to be the only small printer unit offering a full alphanumeric character set which is readily available at the time of writing. The second reason is that Philips Elcome very kindly ande a sample unit available, to allow me to test and debug the power supply and interfacing circuitry? The 60SR printer must be bought new, and as such will cost you considerably more than surplus paper tase gear. In fact, together with its associated leatronics module, it will cost more than the EDUC-8 computer itself. This shows how far the cost of computers has fallen, thanks to modern IC technology, while the cost of mechanical peripherals like printers has tended to remain state. The cost differential is likely to increase even further in unless we are more breast even further in which you was a rout breast on the cost of th made more creapy. In any event, the 60SR printer appears to be the most economical way of providing full alphanumeric printout facilities for a small computer like EDUC-8. The only possible exception would be a surplus teleprinter, but these are in very scarce supply. As shown in the photograph, the complete printing unit consists of the 6058 mechanism itself, together with two PC boards forming its successed MS4 electronics modulo to PCPS. known as the CDS4 characters and as account of the consistency of the consistency logic necessary to generate any one of 64 different alphanumeric characters, when commanded. The other PCB provides the power stages to drive the printer head solenoids from another circuit. United the printer head solenoids from another circuit, loss, its shown as the ACS4 another circuit. The 60SR printing mechanism is a compact one, designed to print lines of up to 20 characters in length on paper 60mm wide takes readily available rolls of paper, as sold for adding machines and printing desk calculators. It takes standard typewriter ribbon although an alternative version (60SA) is available which takes pressure-sensitive paper, and does not use a ribbon. The character printing is not performed by the familiar rised-symbol hammers or "Optiball", but by a set of seven blunt-tipped needles which strike the paper from the rear and force it against the inked ribbon. The needles arranged in a vertical column, although the solenoids which drive them against the paper are disposed horizontally. The needle and solenoid array form the printing head, which is driven horizontally across > HELLO, I'M EDUC-8 --SPEAKING TO YOU YIA THE PHILIPS 60SR MATRIX PRINTER Above is a sample of the print-out, reproduced actual size. Fig. 1, below, shows the printer motor circuits. the paper by a small synchronous motor. As the head travel's across the paper, the needle solenoids are driven by the scanning electronics so that they produce the desired characters as a pattern of dots. Each character is formed as the head moves through approximately 1.5mm, corresponding to five needle-widths, and thus consists of a pattern of dots selected from a matrix or mosaic 7 dots high by 5 dots wide—hence the name "mosaic printer". One advantage of this method of printing is that there are a very small number of moving parts compared with a conventional typewriter or telep/pewriter mechanism, juving improved reliability. The fact that the characters are "formed" by the scanning electronics also makes such a printer very flexible, because the character set may be changed easily by exchanging the ROM in the electronics for another As a result of these advantages, mosaic printers are becoming increasingly used, and seem likely to replace other types eventually. The 60SR printer is therefore very much an example of "upcoming technology", as far as printers are concerned, although only a small ta Ti ba ELECTRONICS Australia, April, 1975 This is the complete Philips printer package 60SR printer mechanism, CC64 character generator board, and AC64 driver board. Only a small amount of additional logic is needed to drive them from the EDUC-8 computer. Switch D is used to sense whether or not the printing head is in its resting or "home" position, at the extreme left-hand side of the paper, it operates as soon as the head leaves the printing head of the paper, it operates as soon as the head leaves when the head has moved a short distance from when the head has moved a short distance from when the home position, when the drive motor has reached full speed; it is used to signal the electronics module that printing may begin electronics module that printing may begin the right-hand extreme of its travel, and is used to time the operation of the paper feed motor. The operation of the mechanism for a typical printing cycle is as follows. Initially the printing head is in the home position, and the switches are all in the positions shown. The cycle begins when terminals C3 and C4 are connected together externally, completing the head motor circuit through contacts C1-3. The head motor starts turning, and moves the head away from the home position. Switch D then operates, closing contacts D1-3 and thereby latching the head motor circuit for the remainder of the cycle. This ensures that operation is independent of the external C3-C4 contacts, as soon as they have initiated the cycle. After about 80 to 100 milliseconds the head motor has reached its full synchronous speed. The position of switch F is such that it is now operated by the head, and this can be used to indicate to the electronics module that printing can begin. As the head continues to move across the paper at constant speed, the solen-cids then drive the printing needles against the paper under the control of the electronics module, printing little desired characters. When the head nears the end of its forward travel, switch E is operated, opening contacts E1-3 and closing E2-3. This has no immediate effect, but serves to prevent the head motor from operating the instant that the head reaches the end of its travel and operates the main memory bar. When the bar is operated, it reverses switches C, A and B. Switch contacts C1-3 are opened and contacts C2-3 closed, causing the head motor to reverse. The printing head thus begins moving back to its home position. The reversal of switch A at the end of the forward head travel causes contacts A2-3 to open, and contacts A1-3 to close. However because contracts E3-1 are open, there is no because contacts E3-1 are open, there is no moved back towards its home position by a short distance, releasing switch E, that the paper motor its energised via contacts A1-3 and E1-3. The paper motor thus begins to feed the paper for the value of the product of the value The paper motor only operates for a short time, however; just enough to advance the paper by about 5mm. It stops as soon as the head completes its return to the home position, operating the memory bar once again and reversing switch A. Shortly before the head reaches the home position it operates switch F, forcing it back to its resting position to prevent restarting of the electronics model until the head has regained full speed in a new cycle. And finally when the home position is reached, switch D is operated along with the memory bar switches, resetting all switches to their initial positions and de-energising the head motor until a new cycle is triggered by external closure of C3.C4. of C3-C4. During the whole of the cycle the ink ribbon motors have been energised along with the headmotor, via contacts D1-3. They have therefore moved the ribbon along as required, in a direction determined by the ribbon memory ber and switch G. You will no doubt have noticed that switch B plays no direct part in the operation of the printer mechanism. Like switch F it is provided for control of the electronics module, primarily to inhibit printing during the return travel of the head. Note that the operation of the paper drive motor during the cycle may be inhibited if desired, by opening the connection between switch contact E3 and its 24V supply rail. The paper may also be advanced manually, if desired, by using an external pushbutton or switch to join contacts A1 and A4 when the printer is stopped. The CM64 character module provides all of the character generation and head driving electronics for mosaic printers like the 60SR. It has a repertorie of 84 different alphamuric and punctuation symbols, which are generated in response to the application of a 61 different conditions of the speciation of a 61 different plant of the speciation of a 61 different plant of the speciation of a 61 different plant of the speciation of a 61 different plant of the special The 8-bit code used to specify which character is to be printed is a subset of the American Standard Code for Information Inter-change, or "ASCII" code. A Chart of the 84 characters available, together with the 2-digit code out a quivalent of their 6-bit selection code numbers, is shown in Fig. 2. This table was actually printed by the 60SB printer itself, under the control of a small program running in the prototype EDUC-8 computer. The heart of the CM64 module is the character generation ROM on the CG64 PC board. This is a 2240-bit device, organised as 64 35-bit words. Each of the 35-bit words is pre-programmed with the 5 x 7 mosaic dot pattern for a printing character. The 6-bit character selection number fed to the CM64 module is used as an address for the ROM, to determine which of the 35-bit words is made. available to the scanning circuitry. The scanning circuitry consists of a start cir- cuit, a scanning oscillator, an 8-bit shift counter and a decoder, and a set of gates controlling the ROM data outputs. When the START PRINTING (1) input is applied to the module. \*\* Linguers the start applied to the module. \*\* Linguers the start circuit which enables the scanning oscillator. The shift countries again countries, and its out-puts are decoded by the decoder to sequentially select each of the 5 groups of 7 bits in the 35-bit ROM word corresponding to the vertical columns of the character to be printed. When the ROM data outputs stabilise each time, the output gates are enabled to allow the 7 bits. concerned to pass to the AC64 driver circuits, and thence to the head solenoids. The dot information for each of the five vertical columns making up the character are thus read out and fed to the printing needles, one after the other, so that the character is printed as the printing head moves along the paper. After the fifth column of data is read out from the ROM, the decoder generates a "Demand new character" (I) output pulse at the QDNC output, to signal that the current character has been printed and another should be supplied. At the same time the output gates are inhibited, so that the printing needles are prevented from socillator cycles, giving a space after each character equivalent to the width of two columns. The scanning oscillator is then turned. off, so that the scanning cycle for that character The scanning oscillator runs at approximately 400Hz, so that the columns of the characters are read out at approximately 2.5ms intervals. The exact scanning/printing rate can be adjusted, by means of a preset potentiometer on the C664 PC board, to give between 18 and 20 characters per line. Note, by the way, that the Philips 60SR printer is rated different from a telepoperarier, in that once the international telepoperarier is a line, it must complete that line. It must complete that line is that once the more than the state of To achieve the more usual and tidy format of having the characters and words grouped together to form reasonable length lines, the individual characters must be supplied to the CM64 module one after the other, as requested by the "Demand new character" signal. This means that before sending the first character that the printer, you must make sure that the rame has the character that the rame has the character that the character is signal. This was the support that the character is the state of the character that the character is the support to the send of the character is the character of the character is the character of the character is the character of c The "whole line at a time" requirement of the 60SR printer does tend to make it a little unsuitable for certain applications, such as echoing an input keyboard. It also tends to complicate other applications such as printout of a text string, unless a "trick" is pulled in the interfacing logic. More about this shortly, the The ACS4 amplifier circuit PCB of the printer The ACS4 amplifier circuit PCB of the printer stages are consists of the seven driver stages selected, for the last half of each column scan selected, for the last half of each column scan ing interval—about 1.25ms seach time. The solenoids operate from 24V DC, sech drawing epproximately 850mA when activated. The peak current from the 24V supply can therefore be as high as 6A during a 1.25ms printing interval (for exemple, when a full column of does it being printed), but due to the 1:1 mach does its being printed), but due to the 1:1 mach characters, the average peak current is neared characters, the average peak current is neared. The interfacing logic I have developed to connect the Philips 60SR up to the EDUC-8 computer is shown in Fig. 3. As you can see, it is fairly straightforward, and uses only 4 low-cost ICs, two transistors, a relay and a handful of minor parts. You have probably identified by this stage the two main parts of the logic, because they are similar to those used in previously described peripherals: the flag FF, formed by gates G1 and G2, and the data buffer register, formed by the 74164 8-bit register. The six leest significant bit outputs of the 47.164 data buffer register are connected to the six ROM address inputs of the CC64 cheracter circuit, so that 5-bit works feel from the computer may be used to speedly which the computer may be used to speedly which computer may be used to speedly which cC64 is connected to the flag FF, so that the CC64 is connected to the flag FF, so that the CC64 is connected to the flag FF, so that the CC64 is connected to the flag FF, so that the MOM is not exturely allowed to sense the address code until the computer resets the flag. This prevents spurious operation as the 6-bit may be added to the sense of the computer. By the simeth of the size of the computer, by the simeth of the computer. By the simeth was computer by the computer. By the computer is compute The two transistors form a driver circuit for the relay, which is used to activate the primer mechanism stert contacts C3-C4. The input to the driver circuit is teken from the flag FF, so that the relay closes the circuit between the printer contacts whenever the flag FF is in the reset state. Thus when the computer resets the flag after fleeding out a character code number, the printer mechanism is started at the same time es the ROM address inputs are enabled. Note that the flag resetting does not itself rigger the start circuit of the CC64 character circuit. This is because the actuel printing must be controlled by the printer mechanism. Hence if the character fed to the circuit from the computer is the first of a new line, printing will not begin for some time after the flag is reset—until the printer signals via switch F that the head is up to speed. The START PRINTING (L) signal applied to the 1st-bar input of the CC64 board is supplied by G7. This acts es an AND gate, fed by signals derived from printer microswitches F and B via PHILIPS 60SR CHARACTER CODE | (77 | | TAL) | | |-----|--------|------|------| | CHA | R CODE | CHAR | CODE | | 9 | 9.9 | | 40 | | A | 81 | 1 | 41 | | В | 92 | | 42 | | С | 03 | £ | 43 | | D | 84 | \$ | 44 | | Ε | 95 | z | 45 | | F | 96 | Ł | 46 | | G | 07 | , | 47 | | н | 10 | ( | 50 | | I | 11 | ) | 51 | | J | 12 | | 52 | | K | 13 | + | 53 | | L | 14 | , | 54 | | Ħ | 15 | - | 55 | | N | 16 | | 56 | | 0 | 17 | , | 57 | | ₽ | 20 | 9 | 60 | | 9 | 21 | 1 | 61 | | R | 22 | 2 | 62 | | S | 23 | 3 | 63 | | T | 24 | 4 | 64 | | U | 25 | 5 | 65 | | ٧ | 26 | 6 | 66 | | M | 27 | 7 | 67 | | × | 30 | 8 | 78 | | Y | 31 | 9 | 71 | | Z | 32 | : | 72 | | C . | 33 | , | 73 | | ` | 34 | < | 74 | | ) | 35 | = | 75 | | - | 36 | > | 76 | | - | 37 | ? | 77 | | | | | - 1 | Fig 2: A listing of the characters in the CC64 character generator's repertoire, together with the corresponding octal equivalent code numbers. As you can see, the listing was printed out by the 60SR printer itself, controlled by EDUC-8. bounce suppression flip-flops. In contrast with the bounce suppression flip-flops in previous peripherals, these use inverter elements (1-12 and 13-14), but work in the seme way. Inverters ere used here merely for economy. Due to the action of 6.7, the CC64 stert circuit is triggered into operation only for that part of the forward head trevel in each printing cycle between the operation of switch F (signalling that the head is up to speed) and the reversal of switch 8 (signalling the end of forward head travel). It is prevented from being triggered during the entire return travel, and also for the first 100ms or so of the forward travel, before the head motor reaches full speed. Gates G5 and G6, inverters I5 and I6 and diodes D1 and D2 are used to control which of two available signels are used to set the flag FF, to signal to the computer that a new character is required. Predictably, the "demand new character" signal from the CC64 board QDNC-bar output is one of the two signals, its being provided by the CC64 decoder precisely for such purposes. And this is in fact the signal normally used. It is fact to the input of G2 via I5, G5 and D1, and then via the differentiating circuit formed by the .00 TuF capactor and the 2.2k resistor. relation of the differentiating circuit is necessary bethe dispail from the CG64 output is provided to the control of c While setting the flag in this wey using the "demand new character" signal is entirely adequate for many purposes, it is not sufficiently flexible to permit efficient and convenient printout of text strings. This is because of the "one full line at a time" requirement of the GOSR mechanism, which has no facility for executing a carriage return before the end of the line. If the "demand new character" signal were the only signal evaluable to set the flag, this would mean that each line of a text string would have to be ended with a number of spaces, designed to ensure that the printer did not versels in the middle of a word, it would be reverse in the middle of a word, it would be of spaces must be stored in the one About as the spaces must be stored in the one should only along with the rest of the text string, they would take up valuable memory spaced. It is to avoid this that I have provided the alternative flag set signal. This is derived from the printer microswitch B, again via the bounce suppression flip-flop formed by I3 and I4, and is applied to the G2 input via G6, D2 end the differentiating circuit as before. When the logic selects this flag set signal instead of the "demand new character" signal, the flag FF is not set until the printer head completes its current printing cycle, and returns fully to the "home" position. This means that the character whose code is currently epipled to the ROM eddress inputs is simply repeated to the ROM eddress inputs is simply repeated to the current ine. The printing the complete complete is the complete of the current in the printing the return head travel, end the fig FF is reset only when the cycle is complete. Thus if the code for space (octel 40) is epplied to the ROM eddress inputs, the effect of selecting this alternative flag set signal is to autometically fill in the end of the line with speces. The selection of the two alternative flag signals is performed by the date word itself, fed into the buffer by the computer. This is possible because while the computer handles 8-bit words, only at of the eight bits are required printing character. The two remains printing character. The two remains and I have used one of these to perform the required selection of set signals. The bit used is the most significant one, waitable to 30 of the most significant one, waitable at 0a of the set of the most significant one, waitable at 0a other than Thus if a cheracter is to be printed normally, with other cheracters to follow in the current line, this is achieved by leeving the most significant bit a zero. This has the effect of inhibiting gate 65, but enabling gate 65 is 16. Hence the "demand new charecter" flag set signal is selected. On the other hand if the character is required to be repeated until the end of the current line, all that is necessary is to make the most significant bit of its code number a one. This causes gate G5 to be inhibited, and gate G6 to be enabled instead, so that the "end of cycle" flag set signal is selected. It may not be immediately apparent, but this facility greatly increases the efficiency and convenience of the printer. For example all that is necessary to end each line in a text string is to store a single "repeating space" (octal code 240). This is simple, convenient and economical in terms of memory space. In effect, a "repeating space" becomes the functional equivalent of a carriage return—line feed combination with other printers, and offers most of the flexibility this gives. But this is not all, because the repeating facility may be used with any of the 64 characters in the 60SR's repertoire. And because you can make such a repeated character the first—and only—character of a line, this makes it possible to "stretch" a single character into a line the full printing width of the paper. Thus for a line of asterisks all you need is a single character, with the octal code 252. Similarly code 255 gives a line of dashes (minus signs), or code 237 a line of underlines—either of which makes a very suitable way of providing top and bottom rules for list-out tables, etc. And the beauty is that they only require a single character code! Note that the character repeating facility uses only one of the two "spare" data word bits, so that there is still one bit available for controlling any other function you may care to add to the printer. All that is necessary is to take the output from Ob of the 74164 data buffer, and provide the required circuitry. One possibility would be to have this bit control the line feed facility of the printer, by using another small relay to perform the switching function shown dashed in Fig. 1. The relay could be driven from the Ob output of the data buffer via a transistor driver circuit rather like that shown for the printer start relay. Another possibility would be to provide the printer with a "bell" facility, so that the computer can alert the operator when desired. Again this would involve a transistor driver circuit rather like that used for the printer start relay, in this case driving a small electric bell—or perhaps a Sonalert. If you would like more than one such additional facility his could also be done, by using a one-of-four decoder driven by the two spars bits, rather than use the two bits direct. A suitable decoder would be one-half of a 93.2 device, driven from the Oa and Ob outputs of the 74.164. The existing flag reset logic could be driven from the "2" output of the decoder, or the second of the property of the decoder of the 14.164. The existing flag reset logic could order the second of the 93.21 decoder are active low, the inverter 16 would need to be swapped over into the Gastaini protuct, from the GS gating input. There are five distinct power supply requirements for the printer peripheral as a whole. The printer merchanism itself needs 24V AC, at a current of around 420mA. The printing needle solenoids and the relay run from 24V DC. with an average current requirement of around 1.5A (6A peak). The electronics in the 1-3V at 0.5 mA, while + 5V DC. on an of 1-3V at 0.5 mA, while + 5V DC. on a foot 370mA is required for the CC64. AC64 and the interfacing logic. Of the five supply requirements, only the 5V DC supply is available from the computer, via the IOT connector cable. The remaining four must be supplied by a separate power supply built into the printer unit, and the circuit developed for this is shown in Fig. 4. With a little ingenuity I have been able to provide all four of the required supplies from a single power transformer, one having two secondary windings each rated at 12V/1.33A. The transformer actually used is the Ferguson type PL307 40VA, one of their "low profile" 40VA family. This actually has two 15V windings, tapped at 12V, and it is the 12V portion of each winding that is used here. The two windings are connected in series to form a centre-tapped 24V winding, which directly provides the 24VAC required for the GOSR printer mechanism. At the same time a bridge rectifier is connected across the full winding, and this is used both to produce both floats at half the main bridge output voltage. A simple shunt regulator using a 13V/1W zener is used for regulation, with a 2200uF/16VW electro across the output to reduce ripple to an acceptably low level. Note that because the transformer winding floats at a DC voltage of approximately 18V above earth, fiether side of the printer mechanism winding may be earthed. This has no adverse effects, and no complications in terms of interconnections with the electronics—the contacts of the printer start relay simply float with the printer circuit; while the contacts of micro-switches F and B connect only to the logic circuity, and not to the printer circuit. A separate half-wave shunt rectifier circuit connected to one side of the transformer winding is used to produce the negative supply voltage. Again a 13V/1W zener diode is used for regulation, and a 2200uF/16VW electro for improved filterina. Fig 4: The power supply circuit for the printer. This provides 24V AC for the printer motors, 24V DC for the relay and needle solenoids, and two 13V DC supplies for the CC64 character module. the 24V solenoid-relay supply and the low-current +13V supply. The full output from the rectifier bridge, is fed to a 1600ut (650W reservor leavor. A simple series pass regulator circuit is then used to regulate the output at the required 24V. The series-pass transistor is a readily available. 28/3055 transistor, which is driven by a T1801, 28/3055 or similar T0-5 transistor or morninal IW rating. Two IW zener diodes, one a 10V type and the other a 15V are used to provide the reference. A 2000ut-725W electro is used across the output of the supply to provide the reference. A 2000ut-75W or lectro is used across the output of the supply to provide the reference. A 2000ut-75W electro is used across the output of the supply to provide the reference. A 2000ut-75W electrons is used across the output of the supply to 2.7k./ 1W bleed resistor to improve regulation. Although the peak current drawn by the printer solenoids is 6A, this simple circuit maintains the 24V line well within the allowed tolerance at all times. In fact peak-to-peak ripple when printing a line of "B" characters (a fairly severe test) is barely 1V, and for typical lines is only about half this figure. The +13V supply is derived from the centre-tap of the transformer winding, which Although the total power consumption of all four supplies connected to the power transformer in the power supply can be as high as 50VA when the printer is actually printing a 50VA when the printer is present to the printer special condition of the printer cycle means that average load on the transformer is well within its 40VA rating. This is so even if the printer is used continuously, so that the train of the printer cycle is the printer cycle of the printer is so that the train of the printer is in the printer is the printer in the printer is the printer in the printer is the printer in the printer is the printer in the printer is the printer in the printer in the printer is the printer in the printer in the printer in the printer is the printer in the printer in the printer in the printer is the printer in the printer in the printer in the printer is the printer in Note that the five rectifier diodes used in the power supply are specified as A14 series devices. These devices are transient protected, and in view of their great ruggedress; recommend that you use them at least for the main rectifier bridge. Although the 100V rated A14A type is shown, the 50V A14Y could be used instead if available, or falling these the more readily for available, or falling these the more readily experience of the protection protec An important point to watch when connecting up the printer circuitry to the power supply is that the eart's return of the 240 sclenoid wiring that the eart's return of the 240 sclenoid wiring the control of eart or of erectly back from the ACS4 PCB schools pin to the negative lug of the 2000ut electro. There are heavy current pulses flowing in this lead during printing, and if they are not kept out of the rest of the electronics, the voltage spikes caused by lead inductance can cause all sorts of misfunction. The separate earth return ensures that this does not occur. The remaining earth pin on the ACS4 board should be run to a common earth point, established where the earth braid of the computer OT cable is seminated. The earth connection of the CCS4 board should also be made to the pint, which is then initially and back to the earth lugs of the two 2200uF filter capacitors in the power supply. The 5V supply line from the computer should be bypassed to the earth lugs of the two 2200uF filter capacitors in the power supply. The 5V supply line from the computer should be bypassed to the earth line with .042 if V polyseter capacitors in the power supply line from the computer should be bypassed to the earth and the computer should be supply line from the computer should be supply line, and also near the 74 164 and 7437 devices. No dealis will be given here for the mechanical side of the printer, as this will depend upon as lade of the printer, as this will depend upon the way you want to package it. As there are only four ICs, two transistors, a small cradle relay and a handful of small parts in the interfacing logic, these can easily be mounted on a small PCB or square of Veroboard cut to match the CCG4 and ACG4 boards. The power supply wiring can be built up easily on a small length of ministure resistor panel, apart from the major parts. Note that the CC64 and AC64 PC boards are designed to plug into 35-way edge connector sockets, having 0.11 connector spacing, and I suggest that you use sockets rather than solder direct to the boards. As the exact dimensions of subject to the plant of the control t New connection details for the CCS4 and ACG4 boards is provided on leaflets supplied with them. Note that the CCS4 is provided with outputs from the scanning counter and the oscillator, but these are not used here. The ACG4 is also provided with outplicate output connections from the solenoid drivers—both as a row of pins of the top of the board, and as a group of pads on the edge connector. The latter are not used here, as the cable from the printer head is provided with a connector which masse with the row of pins. The connections for the printer mechanism are clearly marked along the terminal board at the reer of the frame, and also on small connectors supplied "plugged on" to the various connector pins. The connection code is the same as used in Fig. 1, so that you should have no trouble in wiring this up. Finally, a word about programming for the printer. Sascially, the printer is handled in much the same manner as any other output device, the usual way being to service it via a subroutine which transfers the data word out to the device buffer from the AC register, resets the device fleg, and then waits until the flag is set again. The deta words sent to the printer will be the codes for the particular characters to be printed, supplemented by the control bit—or bits, if you have wired the printer to respond to both. If you have wired the printer according to | STEP | ELESEMODIC . | COO | |------|---------------------------------|------------| | 0 1 | STAFT, CLA | 718 | | 1 1 | TA ) BIS /fetch start of buffer | 117 | | 2 | | 316 | | 3 | CLN,TA: 1 PTF /fetch char | 136 | | 4 | SZA /terminate code? | 738 | | 5 | 3PP .+2 /nc, krep going | 5,977 | | 6 | HLT /yes, stop | 721 | | 7 | 1PB ) | 626 | | 10 | SPT print sequence | 621 | | 11 | Jup ,-1 | 51# | | 12 | ISZ PTF /increment pointer | 216 | | 13 | JMP CON /continue | 5//3 | | 10 | HLT /ord of buffer no term. | 721 | | 15 | | | | 16 | PTF , \$58\$ | 884 | | 17 | BFS, #2# | <b>#2#</b> | | 29 | (firet char to be printed) | | | 21 | (second char) | | | 22 | (third char) | L | | 23 | | L | | 20 | | l | Fig 5: A simple program to print out text strings, from a buffer starting at location 020. Note that the instructions in 005 and 011 use a full point to represent the "current memory location"; this is a fairly common mnemonic convention. Fig. 3 the basic character code will be as shown in Fig. 2, with the control bits normally both being set to zero. To make any desired character repeat until the end of a line, the code is simply modified by setting the most significant bit to 1—equivalent to adding octal 200. It a program must print out an instruction to the operator, an explanation or some other string of text characters, this is normally done to the operator, an explanation or some other working the appropriate string of code numbers in sequence in the memory, other operations of the program is provided with a small instruction loop, wherein an indirect TAD instruction using a point of the provided with a small instruction loop, wherein an indirect TAD instruction using a point of the provided with a small instruction loop, wherein an indirect TAD instruction using a point of the provided with a small instruction loop, wherein an indirect TAD instruction using a point of the provided with a small instruction using a point of the provided with a small instruction using a point of the provided with a provide As the "at" symbol corresponding to octal code 00 is very rarely used in text strings, this can be used as a message terminate code. Thus the string of characters forming the message in the text buffer need only be followed by a 000, and the instruction toop used for the printing out arranged to jump out of the loop immediately if recognises that his allows the code of co The simple program shown in Fig. 5 should high to illustrate these techniques. It is purely a program to print out a "pre-recorded measage", and you can make it print out any message you like simply by depositing the appropriate character codes in the location beginning at the with address C20. Now the program will can 100 on to end the day program will can 100 print out whatever random numbers are present in the rost of the memory, and will only stop when it has printed the contents of location 377. This illustrates the very simplest type of programming for a printer, where the characters are simply stored and "played back". There are many other possibilities, for example the program which was used to print out the table of fig. 2 used this technique for the eart the top of the about value which was printed out to give the first character, then analysed to produce the codes for the equivalent octal digits, which were then printed out slow—after printing 6 spaces. Then the index was incremented, and the process repeated the before passed for a total of 64 times (77 octal), to print out all 64 characters and their octal codes. Space prevents me from giving the program itself here, and in any case it would be a good exercise for you to try writing one yourself, knowing what has to be done and the gernal line of attack. Here's a clue, though: to print out a 3-bit binary number as the equivalent octal digit, ell you need to do is edd octal 60, to get the required code number. Incidentally, in writing progrems which involve the printer, don't worry too much about the fact that it needs to be fed with a stream of characters once a line printing cycle has been started. Even though EDUC-8 is not a particularly fast computer, it is still quite fast compared with the print. In fact the time interval available to the computer to generate and deliver a new character, after the printer flag has been set by the "demand new character" signal, is typically 6.25ms. This is equivalent to about 65 fetchexecute instruction cycles—so that there should normally be more than enough time for the computer to keep up. Unless you have a very complex program, it is more likely to be spending most of its time waiting on the printer! I hope the discussion given here of the Philips 60Sp printer and its operation with the EDUS 8 microcomputer is of interest to you. While only a small printer, it makes a very worthwhile addition to the overall EDUC-8 system, and illustrates very well the way in which larger printers are used. ### PLEASE NOTE Further testing of the interfacing logic given for the Welmec paper tape punch, in the last section, hes revealed that malfunction can occur during fast repetitive punching due to a timing problem. ling, due to a timing problem. Because RIVA, used to generate the "end of cycle" flag setting signal, is driven from teop contacts, it can reset the flag slightly before the cycle has catually ended. If the computer immediate the cycle has catually ended, if the computer immediate the cycle has catually ended, the punch will ignore the new character. At the same time the computer program continues to wait for the punch to set its flag, to indicate that it has punched the character. Thus the system The are a number of ways in which this can be prevented, but the neests and most effective way is to simply slow the operation of RIYA down, using a R-C circuit between the top contact of the bisteble switch and the + 120V supply line (in parallel with the existing spark suppressor capacitor). Hound that e 4.7µC+150V electrolytic in series with a 220 ohm 1W resistor did the job very well. ### A full ASCII-type input keyboard for EDUC-8 Continuing the description of suitable peripheral devices to interface with his EDUC-8 microcomputer project, the author here gives details of a full alphanumeric input keyboard unit. The logic is capable of fully encoding all 128 characters of the standard 7-bit ASCII code. ### by JAMIESON ROWE Although the simple 16-key input keyboard unit described earlier is likely to be adequate for many purposes, there will no doubt be some constructors who will want to provide their EDUC-8 microcomputer with a full type-writer-style keyboard unit. Apart from offering increased communication flexibility and convenience, a full keyboard also allows you to work with programs requiring full alphanumeric input, such as symbolic editors, assemblers and With this in mind I have developed a design for a full ASCII-type input keyboard, which will be described here. so asscribed retre. The logic with as been designed to work. The logic with as been designed to work with any keyboard assembly having the re-with a second second to the logic with a second to the logic with a second when the key is pressed, The switches need not be bounceless, as the logic will cope with any normal amount of contact bounce. have built up the design and checked it out with a surplus keyboard switch assembly, topical of the type available in obsolder keypunch equipment. This type of keyboard is likely to be that most accessible to you, at reasonable cost. Providing the switch contacts are in reasonable condition, such a keyboard should be quite suitable, although most will need a thorough dusting, lubrication and treatment with contact cleaning fluid before use. You can, of course, elect to wire up the keyboard using a new keyswitch assembly, of which a number are available—at an appropriate price. For example General Electronic Services (99 Alexander St, Crows Nest, NSW 2065) can supply a 56-key keyboard assembly made by Mechanical Enterprises, Inc., of Viriginia. Designated type A-L2-R2, it has gold contacts, an 8-keylength space bar, and two 1½-keyléngth shift keys. The price is approximately \$13.6. A new keyswitch assembly will undoubtedly give you a better looking keyboard, and ultimately greater reliability. However, as the cost of a surplus keyboard is unlikely to cost you more than about \$10-20, there is a considerable cost incentive in "making do" with one of these. incentive in making do with one of mess,. The keyboard unit shown in the pictures is from the same surplus keypunch station which provided the Weimer reader and punch units provided the Weimer reader and punch units provided the Weimer state of the provided pr The keyboard logic presented here is capable of encoding all 128 characters of the standard 7-bit ASCII code, in contrast with some of the alphanumeric keyboard designs published elsewhere. In addition, the logic incorporates reverse shift mode encoding, for those keys where this is normally used. Incidentally, if you've forgotten what the acronym "ASCII" stands for, it is the American Standard Code for Information Interchange. For the benefit of those not too familiar with the ASCII code, it is shown in Table 1. As you can see, the 128 characters are arranged in eight columns, each column having 16 rows. The 16 row positions are defined by the four least significant bits of the code, bits 0-3, while the three remaining bits are used to define the columns. Each one of the 128 character cells in the array is therefore defined by a unique combination of the 7 encoding bits. Columne 2, 3, 4 and 5 comprise the printing characters normally used on teletypowriters and printers (such as the Philips 60SR printer, for example). These columns include all of the upper-case alphabetic symbols, the decimal numerals, and all of the commonly used punctuation marks. The 64 characters concerned are often considered as a distint sub-set of the full 1,28-character code, known as "6-bit ASCII". As far as keyboards are concerned, the horarcters in columns 4 and 5 are normally provided with keys of their own, while those of columns 2 and 3 are usually arenged to share common keys, with a "shift" key used to change the encoding and distinguish between one column and the other. Usually the haracters for these keys, and those in column 2 the "shift" haracters—accept for the character pairs in rows 12, 13, 14 and 15, with comman must, fullstop and oblique the "normal" characters and their corresponding characters the "shift" equivalents." This special treatment of the four keys concerned tends to complicate the logic, saw will see shortly. However it has apparently become standard because of the greater use normally given to the four characters in column 2. compared with those in column 3. It would be a nuisance having to press the shift key every time one wanted a comma or fullstop, for example. Columns 6 and 7 of the table comprise the lower case alphabet and some infrequently used symbols and control codes. Many keyboards do not provide for these codes to be generated, apart from "del" (delete or rubout) and perhaps "alt mode". This is because lower case characters are not necessary in most communication, and are not even available on many printers. At left is the prototype keyboard unit, which is built inside the case of a surplus keypunch keyboard. The view above shows the logic board, mounted on the bottom plate of the case. | | TABLE 1 : ASCII CHARACTER CODE | | | | | | | | | | | | | | | |--------|--------------------------------|--------|---|--------|---|--------|-----|--------------------|--------|-------|---|-----|-------|-----|------------------| | F | | | | | | 0 | 0 | 0 | 0 | 1 | 1 | 1 1 | 1 | | | | П | <b>—</b> | | | | | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | | | | μ | <u> </u> | | | | | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | | | | 6<br>6 | 5<br>5 | 8<br>4 | 3 | B<br>2 | 1 | B<br>0 | ROW | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | | L | L | L | 0 | 0 | 0 | 0 | 0 | NUL | DLE | SPACE | 0 | @ | Р | \ | P | | L | L | | 0 | 0 | 0 | 1 | 1 | soн | DC1 | J | 1 | A | Q | a | q | | L | L | | 0 | 0 | 1 | 0 | 2 | STX | DC2 | " | 2 | В | R | b | r | | L | L | | 0 | 0 | 1 | 1 | 3 | ETX | DC3 | # (£) | 3 | С | s | c - | · s | | L | L | | 0 | 1 | 0 | 0 | 4 | EOT | DC4 | \$ | 4 | D | T | d | t | | L | L | | 0 | 1 | 0 | 1 | 5 | ENQ | NAK | % | 5 | E | U | е | u | | L | L | | 0 | 1 | 1 | 0 | 6 | ACK | SYN | & | 6 | F | v | f | v | | L | L | | 0 | 1 | 1 | 1 | 7 | BELL | ETB | , | 7 | G | w | 9 | w | | L | L | | 1 | 0 | 0 | 0 | В | BACK<br>SPACE | CAN | ( | 8 | н | х | h | х | | L | L | | 1 | 0 | 0 | 1 | 9 | HOR.<br>TAB | EM | ) | 9 | 1 | Y | i | у | | L | L | | 1 | 0 | 1 | 0 | 10 | LINE<br>FEED | SUB | * | : | J | Z | i | 2 | | L | | | 1 | 0 | 1 | 1 | 11 | VERT.<br>TAB | ESCAPE | + | ; | К | Е | k | { | | L | L | | 1 | 1 | 0 | 0 | 12 | FORM<br>FEED | FS | , | < | L | \ | 1 | J | | L | L | | 1 | 1 | 0 | 1 | 13 | CARRIAGE<br>RETURN | GS | _ | - | М | ٦ | m | } (ALT<br>MODE) | | L | L | | 1 | 1 | 1 | 0 | 14 | SHIFT<br>OUT | RS | | > | N | Λ (†) | n | ~ | | L | | | 1 | 1 | 1 | 1 | 15 | SHIFT<br>IN | us | / | ? | 0 | _ | 0 | DEL<br>(RUB OUT) | Above is a table showing the 128 characters of the 7-bit ASCII code, with their coding. At right is the standard keyboard format used for this code. the same reason it is usual for the upper case characters to be the "normal" characters, with the lower case characters in columns 6 and 7 encoded by using the shift key—just the opposite of the convention used with type-writers. The characters in the remaining two columns, columns 0 and 1, are known as the non-printing or "control" characters. These are used to indicate changes in encoding mode, to control printer formatting, and for other facilities which may need to be controlled by "transparent" character codes—distinguishable from printing characters. Generally most of the codes in columns 0 and 1 are generated using a "control" key, which acts rather like a second shift key. Any desired code in column 0 is generated by pressing the control key in conjunction with the key in column 4 corresponding to the desired row code. Thus "form feed" may be generated by pressing "control" and "L", while "horizontal tsh" is equivilent to control." In some cases special keys are provided for column O character codes, because they are used fairly frequently. This is generally done for "carriage return", "line feed", "back space" and "bell"—the last of these being used to activate the signalling bell of a teletypewriter. The codes in column 1 are normally gen- erated by using the control key in conjunction with the keys for columns 3/2, although some teletypewriters provide a special key for "escape." Note that the characters in the ASCII code are not completely rigid, with certain codes 3 DEL ά Q W Ε R CR Α S D G CTRL Н LF Z χ R N 1.5 SHIFT being used to represent two different characters on occasion. Thus the character in row 3 of column 2 is generally the "number" sign on American equipment, but the "pound" sign on machines of UK origin. Similarly the code in row 13 of column 7 is sometimes used to represent "wiggly closing bracket", and some-represent "wiggly closing bracket", and some- times the non-printing control key "alt mode". All off the character codes shown in the table may be generated using the logic circuit which will not be described. As many special keys will not be described. As many special keys 10 and 1 codes, depending upon the number of keys available on the keyboard you use. The remaining codes may be generated using the control key. Smilling't the shift key may be used control key. Smilling't the shift key may be used control key. Smilling't the shift key may be used of the control key. Smilling't the shift key decided with a special key if you so desire. As you can see from the circuit diagram, the main alphanumeric keyswitches are wired in an array, whose rows and columns correspond to those of columns 2, 3, 4 and 5 of Table 1. There are 16 "row" keylines, and three "column" keylines—two of which correspond directly to columns 4 and 5 of the table, while the last corresponds to both columns 2 and 3 (which use common keys). At the heart of the encoding logic is an IC specially designed to perform keyboard encoding. This is the HD-0165, made by Harris Semiconductor in the USA. It is available on order through your usual parts supplier, from the local agents for Harris, Cena Distributors Pty Ltd of 21 Chandos Street, Crows Nest, NSW 2065. At the time of writing it costs about \$9, but performs a job which would otherwise involve many didose, transistors and ICs. The HD-0165 is a 16-line to 4-line binary encoder, which also generates both a "strobe" or "key pressed" signal and a "rollover" "more than one key pressed" signal. As you can see from the circuit, the HD-0165 is used to perform the basic encoding of the four least significant bits. As this corresponds to the row encoding for Table 1, its 16 inputs accordingly connect to the 16 "row" keylines of the keyswitch array. Encoding of the remaining three bits of the ASCII code is performed by the logic circuity involving gates G6. 67, 610-12, and inverters I1-6, using signals derived from the "column" keylines. The actual column keyline signals are generated by PNP transistors T1, T2 and T3. ### amazing MAGNA-LITE lets you focus on fine detail regardless of lighting! Illuminates and magnifies whatever you are viewing! What a useful combination! A concentrated light beam and magnifier all in one! So compact it fits in your hand, pocket, purse or glove box. Precision made in the United States, amazing Magna-Lite is yours for just \$5.95! With a money back quarantee! Hurry while shipment lasts! Mail no-risk coupon today! Optical magnifying lens. 2 batteries included. Powerful flashlight. Lightweight, only 1 % oz. fits pocket All hobbies! purse or desk. in the dark! chemists. . Road mans & street quides! MONEY Read phone books at a glance. BACK GUARANTEE HOW TO ORDER: Fill in BOTH sections of the coupon. In each section print you name and full postal address in hlock letters. Cut the entire coupon out around the dotted line. Send it with your money order or crossed chaque to Electronics. Australia, Reader Service (Magna-Lite) P.O. Box 93, Beaconsfield, N.S.W. 2014. renlacement available hatteries readily ### Cheques should be endorsed on the back with senders name and address and made payable to Electronics Australia. This offer is open to readers in Australia only. CLIP COLIPON - MAIL TODAY I | Name | |----------------------------------------------------------------------------------------------------------| | State Postcode | | Electronics Australia Magna-Lite Offer No . 36/75 | | Name | | Address | | StatePostcode | | Please send me (state quantity) Magna-Lite/s. I enclose my cheque, postal/money order to the value of \$ | ### **EDUC-8** computer These are wired so that when any of the keys in the associated keyline is pressed, the resulting input current drawn by the HD-0165 passes through the base-emitter junction, turning the transistor on Further logic signals are generated by the shift" keyswitch, and the "control" keyswitch. Special keys such as "carriage return feed" (LF), "back space" and "bell" are arranged to have the same effect as if the control key were pressed along with the corresponding column 4 alphabetic key, by means of diodes D3-D10. Thus D3 and D4 ensure that the carriage return key generates the "control" and 'M" signals, as well as causing T3 to conduct. As the "space ber" key is equivalent to 'shift-0", diodes D1 end D2 ere used to achieve a similar result when this key is pressed. Here the key causes activation of the "O" input of the HD-0165, generation of the "shift" signal, and conduction of T1-all three of which are needed to achieve the same result as shifted The actual encoding for bit 4 is generated at the commoned outputs of gate G6 and inverter 13. These are both open-collector elements, with their outputs tied together to achieve a wired-OR function. Similarly the bit 5 encoding is generated at the commoned outputs of G7-I4, and the bit 6 encoding at the commoned outputs of 15-16. The inputs of these elements are fed with the column keyline logic signals from T1, T2 and T3 together with the control and shift keyline signals, to achieve the correct encoding. For example I4 is fed with the control keyline signal, to ensure that bit 5 is false (0) whenever the control keyline is activated-corresponding to a column 0 or 1 character. Gate G7 is fed with the inverted shift keyline signal from I1. together with a wired-OR combination of the column 4 and 5 keyline signals from T3 and T2, so that bit 5 is again made false whenever a column 4 or 5 key is pressed without the shift key Similarly I5 and I6 are fed with the column 2/3 keyline signal from T1, and the control keyline signal, respectively, which ensures that bit 6 is false whenever a key or key combination corresponding to a character in columns 0, 1, 2 or 3 Inverter I3 is fed with the column 4 keyline signal from transistor T3. As columns 0 end 7 are equivalent to column 4 characters combined with either the control or shift keys, this automatically ensures that bit 4 is always felse for all column 0, 4 and 7 characters The signals fed to gate G6 are used to obtain the correct bit 4 encoding for columns 2 and 3. Because of the inverted shift mode operation of the row 12, 13, 14 and 15 keys, this is a little more complex than it might otherwise be. What must occur is thet for the rows 0-11 keys, bit 4 must be false when the shift key is pressed, while for the rows 12-15 keys bit 4 must be false if the shift key is NOT pressed. This is echieved by using gate G9 to monitor the bit 2 and bit 3 outputs from the HD-0165. so that its output is low whenever both these Shown opposite is the complete circuit of the ASCII keyboard encoder. Encoding of the 4-bit row address portion of the code is performed by the Harris HD-0165 16-line to 4-bit encoder IC. at top centre. finds light switches keyholes in the dark! · Perfect for bedside use! bits are high — signifying a row 12, 13, 14 or 15 character. This signal and its complement are then gated with the shift signal and its complement, by gates (10) and 611. The outputs of these gates are then combined by G12, performing an OF function. Finally US 2/3 keyline signal from 11. If you trace all his through, you'll find that it does the required job. Monostable elements M1 and M2 are used to generate a clean. Tkey pressed 'signal from the strobe (1) and N-key-rollover (1) outputs of the IDO (16). In the configuration shown, they prevent encoding errors due to accidental prevision of the configuration shown. Gate GS is an open-collector element, used as an inverter for the HD-0165's strobe (t), signal, When a single key is pressed, the output of St thus goes high, and carries with it the open and its output goes high for a period of paper, and its output goes high for a period of approximately 20mm. This internal is set by the 2µC capacitor and 15k resistor, with diode D12 used to compensate for possible capacitor leakage. The 20ms delay is to allow for keyswirch covers are initiated. It is set to the covers are initiated. The Q output of M1 is connected to the complementary trigger input of monostable M2, so that when the output of M1 falls back to the low state at the end of the 20ms delay, M2 is normally triggered at its Q-bar output. However because the reset input of M2 is connected to the output of G5, and both are tied to the "N-key-rollover" (I) output of the HD-0165, triggering of M2 can only take place if a single key remains pressed. If a second key has been pressed of the control of the M2 of the M3 M If this occurs, correct triggering will take place when the second key is released, assuming that the intended key remains pressed. The clean "key pressed" (() signal produced at the O-bar output of M2 is a pulse of approximately 500ns duration. The pulse is used to perform two functions, one being to enable the parallel-load input of the data buffer register — a 74165 deviree. This causes the encoded 7-bit ASCII character to be loaded into the buffer, ready for despatch to the computer. The second function performed by the key pressed pulse is to set the flag FF, formed by cross-connected gates G1 and G2. Buffer gate G3 is thus able to take the flag line low, indicating to the computer that a character is available. As with the other input peripherals described, the computer itself performs the actual data transfer, sending clock pulses to the data buffer register and accepting the data via the inverter /driver G4. Note that as the EDUC-8 input/output circultry is designed to handle 8-bit numbers, the keyboard data buffer is an 8-bit register. This means that there is a spare bit, as only seven are used for the ASCII encoded characters. The eighth bit may be set permanently to either a high (H) or tow (L), as desired, by trying the PA input of the 74165 either to +5V (via a protective resistor) or to ground, as desired. In many minicomputer systems the eighth bit produced by an alphanumeric input keyboard unit is permanently set to high (1), as this allows ### MODIFIED TAPE READER LOGIC—CORRECTION There is an old rule in electronics publishing, that it is very unwise to publish a circuity out haven't actually tried. It is almost newable that if you do so, he circuit won't work! I have proved the rule still applies, much to my embarrassment. In the description of punched paper trapp perspherals, he circuit I gave in Fig. 6 showing how to modify the program-controlled readed logic for use fine the program-controlled reader logic for use modify the program-controlled reader logic for use fine the program of for the computer to know when the clutch mechanism has incremented the tape. Bather than attempt to patch up this circuit. I have started again from scratch. And the effort was worthwhile, because it turns out that the job can be done much more simply, using only three (S== a 74.16 5 as the data buffer, a 960.20 dual monostable for timing, and a 743.7 for the flag FF and line drivers. The circuit is shown below, and it should be fairly self-explanator, it should be taken to replace the original Fig. 6. PLEASE NOTE ALSO that the parts list given for the program counter and adder board (main computer parts list 3) is in error. It should list only 4 x 7400 or 9002 quad 2-input gates, not 5, and it should list 1 x 7420 dual 4-input gate. SIMPLIFIED P.P. TAPE READER LOGIC FOR EDUC- ready identification of alphanumeric or "symbolic" character strings. I have used the same convention, and I suggest you do too. In the prototype keyboard unit shown in the photographs, most of the logic was wired up on one of our multi-DIP utility PC boards. This was then mounted on the bottom plate of the keyboard case, using suitable spacers. Pieces of flat multi-coloured abile were used to connect the board to the keyswitches, and to transistors T1, T2 and T3. These were mounted for convenience on some existing tagstrips inside the main keyswitch fram keyswitc Before using the keyboard assembly, it was before using the keysting switch wiring as this was arranged in a connection array quite different from the one required Before wiring the switches according to the new array, the complete assembly was cleaned thoroughly and the key contacts sprayed with one of the aerosol contact cleaning fluids. At the same time, the opportunity was taken to rearrange some of the keybors, so that the keyboard became closer to that used in a type-writer or teleprinter. You may care to do this have the keys in rather different positions. The keys and positions of a normal ASCII key-board are shown in the diagram, to help you fly ow man to aim for an arrangement as close to this as possible. I recommend that you do the unknown that was possible. In the commend that you do the surface you have a good reason to do other- As before, the keyboard unit connects to the computer via a length of multi-way cable, and a 6-pin DIN plug. As well as performing the logic signal connections, the cable also supplies the keyboard logic with its 5V DC power. ## Teaching your EDUC-8 to play a melody As a change from the more conventional peripheral units so far described as part of the EDUC-8 system, the author here describes a "music player" output device. Producing musical notes which are under program control in terms of pitch, octave and duration, it may be used either purely for demonstration purposes, or to form the foundation of a digital music synthesiser system. ### by JAMIESON ROWE At this stage, having described a number of input and output peripheral devices of the conventional "Computer attachment" variety, it seems appropriate to describe something rather less so. If nothing else, I hope this will perhaps start to show you that there is a whole area of largely unthought-of computer applications and interfacing possibilities, which is wide open for you to explore. The device I have chosen to do this is a music player, output device, which is capable of producing a monophonic melody under the direction of a suitable program in EDUC-8. While only a simple device, it provides program control of note pitch, octave and duration, and thus allows the computer to play tunes in quite a convincing manner. As it stands, it is just the thing for demonstrating the EULCR system to non technical people. Such people generally don't find the more conventional peripherals and functions of the control con If you wish, however, it could be used as the start of a more elaborate arrangement. By adding facilities for programmable attenuation, filtering and so on, it could well be expanded into a digital music synthesiser system. The potential seems to be there for quite a lot of development work along these lines, if you find the idea of digital music synthesis interesting. Whether you intend building it up purely as a simple music player or as the start of a more complex synthesiser, I think you'll find the device well worth constructing. And good fun, At the heart of the device is one of the new MOS LSI top-octave note frequency synthesiser ICs, which takes an input signal at the lowest common multiple frequency, and simultaneously performs all of the frequency divisions necessary to produce the 12 notes of the "even-temperament" musical octave. There are two almost identical devices of his pice currently available, either of which may be used in the player. One is the type AYS—50 (J. 7, made by General Instrument Microalic-Colorable of the pice Whichever chip is used, in this circuit it is ded with an input signal at very close to 500kHz. As a result the 12 locked semitone outputs produced correspond to the octave beginning with the third C-sharp above middle C—i.e. the octave with A equal to 1750Hz. These notice are then fed to four cascaded binary dividers, so that the actual output pitch range of the player unit covers the four octaves below this initially synthesised octave. In other words, the player produces output notes extending for two octaves either side of middle C. In electronic organs, for which these top octation graphs are primarily intended, the input reference signal is generally derived from a crystal oscillator. This gives an appropriately high order of absolute pitch accuracy, as well as high stability. However for the present application a crystal oscillator has not been used as high accuracy and stability are scarcely necessary. Note, by the way, that we are talking here of absolute pitch accuracy and stability, not relative pitch accuracy. The intervals between the notes are automatically locked by the IC; it is only the absolute pitch of all the notes as a whole which can be varied. As you can see from the circuit diagram, the oscillator used to generate the 500kHz signal is a simple R-C oscillator using half a 7413 Schmitt trigger device. This feeds the note synthesise crip via a logic level converter stage using a BC108 or similar transistor. The oscillator frequency may be adjusted using the 25k pot, which thus becomes the "absolute prich" tuning control for the player. Strictly the exact oscillator frequency required will depend upon the absolute pith reference used. because the IC division ratios used to give the various note intervals are enily 3-digit approximations. Thus if you use A = 440Hz as the pith reference, the correct oscillator frequency will be 499.640Hz, but if you use will be 499.640Hz, but if you use will be 499.640Hz, but if you use the differences are rather exacted, and 500Mz is probably quite close enough for most purposes. The 12 outputs of the note synthesiser IC are each provided with a buffer stage, using a BC108 or similar NPN transistor. This is again for logic level conversion, so that the signals may be fed to the TTL note multiplexer. The note multiplexer is a 74150 device, which in effect forms a digitally programmable 16-position switch. Only one of its 16 inputs may be connected to the output at any one time, and the particular input selected is determined by the logic levels applied to the "address" inputs A, B, C and C. As these inputs are connected in turn to the H, G, F and E outputs of the 74164 data buffer register, respectively, this means that the four least significant bits of the 8-bit number fed to the player from the computer provide the "instruction" to the note multiplexer. Each of the 16 possible combinations of these four bits Perhaps it doesn't look much like a music box, but hook it up to your EDUC-8 and an amplifier and it will play almost any tune you care to encode. This prototype was built up in a small utility case, with the ICs mainly on one of the EA. "Multi-DIP" PC boards. The full logic diagram is shown unwiked. will force the 74150 device to connect the corresponding input to its output There are only 12 signals to be multiplexed. in this case, so that four of the 16 combinations provided by the 74150 are not used. These are 0000, 1101, 1110 and 1111, corresponding to octal 00, 15, 16 and 17. If specified by the computer data word, all four combinations produce silence, or a musical rest The 12 address combinations corresponding to octal numbers 01-14 inclusive are used for the active notes. The coding used is in simple progression, i.e., C-sharp is octal 01. D is 02. D-sharp: 03, and so on up to C: 14. The output of the 74150 note multiplexer is fed to a 7493 binary divider, which consists of four flip-flops connected in cascade. Thus the selected note frequency is divided by 2, 4, 8 and 16, with signals at the appropriate sub-multiple frequencies available at the four device outputs. The four 7493 outputs thus effectively provide the selected note, but in each of four octaves. To select which octave is required, a 7401 quad 2-input gate is used to produce a simple 1-of-4 multiplexer. The four open-collector outputs of the 7401 are connected together, with a single 470-ohm output load. This forms a wired-OR configuration, so that any one of the four gates can feed the output. Gating signals for this simple octave multiplexer are derived from outputs C and D of the data buffer register, via half of a 9321 dual decoder device. Each half of the 9321 is a 2-bit decoder, with active low outputs. For each half of the device, only one of the four outputs can be low at any one time, and the output concerned depends upon the state of the two input bits. Thus the input bit combination 00 causes output 0 to go low, while input combinations 01, 10 and 11 cause outputs 1, 2 and 3 to go low respectively. Each half of the 9321 has a separate enable (L) input, which must be low before any output can go low As the 9321 device has active low outputs, and the 7401 device used as the octave multiplexer requires active high selection signals. a 7404 device is used for inversion. The two 'left over" inverters in the 7404 are not used in the present player circuit, and could be used for other things if desired. The output of the 7401 becomes the audio output of the music player, and is fed to an output socket via a simple R-C shaping circuit to provide a moderate amount of smoothing. This helps remove switching transients, and helps to make the square-wave signal a little less "harsh" The audio output signal is of about 3V peakto-peak, and has a source impedance of about 1k. You can therefore feed it into almost any audio amplifier, via the "radio" or "auxiliary inputs. At this stage, it should be fairly clear that the circuitry so far described is capable of taking the six least significant bits of a data number fed to the player from the computer, and using A simple power supply circuit for the music player device, to provide the supply voltages not available from the computer itself. Note that the -12V section is only required for the AY-1-0212 chip, and may be omitted for the Mostek MK50242. them to select and play any one of the 12 musical notes, in one of 4 octaves. Thus, for example, octal 22 will result in the sounding of the D in the second lowest octave, while octal 67 will produce the G- of the topmost octove The remaining circuitry of the player device has been provided to automatically time the duration of notes. Four programmable note durations are provided, controlled by the remaining two bits of the data word-available at outputs A and B of the 74164 data buffer register The way in which the two control bits are used to control note duration is by having them determine the delay period of a simple timing circuit, used to set the flag flip-flop after the latter has been initially reset by the computer following delivery of the data word. By connecting the enable (L) input of the 9321 de coder feeding the octave multiplexer to the flag FF, this means that the note produced by the player only lasts for the interval between resetting of the flag FF by the computer, and the subsequent setting by the timer, after the programmed delay The timing circuit is basically the same as that used in the simple octal display unit, described earlier. It uses a D13T1 programmable unijunction or PUT to discharge a capacitor, when triggered by the flag reset signal. The capacitor is then allowed to charge, and when it reaches a certain charge level a flag setting pulse is produced by a level detector circuit. The level detector uses two BC 109 transistors. feeding the other half of the 7413 Schmitt trigger device. The delay time is programmed by using four PNP transistors to switch in four different values of charging resistance. The transistors may be type 2N3638, BC178, BC327 or similar, and they are controlled by the four outputs of the second half of the 9321 decoder device, connected in turn to the A and B outputs of the data buffer The four timing resistors have values which vary in binary ratio, so that each gives a delay time and note duration twice as long as its successor. Thus if the two most significant bits of the data word are both zero (octal 0-), the resulting note duration will be of say one unit long. If the less significant bit is 1 (octal 1--) the note will last for 2 units of time, while if the more significant bit is 1 (octal 2-) the note will last for 4 time units. Finally if both bits are 1 (octal 3-) the note will last for 8 time units The binary time ratios have been provided not because of some slavish desire to "keep everything binary", but merely because this is the normal relationship used in music. Thus, octal 3-- could correspond to a minim or halfnote, octal 2-- to a crotchet or quarter-note, octal 1-- to a quaver or eighth-note, and octal 0-to a semiquaver, or sixteenth-note. Naturally the correspondence between the binary-octal coding and the various notes will depend upon the actual delay time and the musical tempo. By varying the timing capacitor, shown on the circuit as 0.22uF, you can adjust the relationship at will. Larger capacitor values will give a slower tempo, or longer note values for the same tempo, while smaller capacitor values will give either a faster tempo or shorter note values You could provide a number of capacitor values, selected by a manual switch on the player, if you wish. Ideally the values should be in binary ratio, so that you could start with values of 0.1uF and 0.47uF in addition to the existing 0.22uF To recapitulate, then, the music player unit operates as follows. To play a note, the computer must send an appropriately coded data word into the player's data buffer register. The four least signficant bits of the word cause the 74150 note multiplexer to select the desired note, while the next two bits are applied to the octave multiplexer half of the 9321 decoder. ready to select the octave in which the note NOTE LENGTH ENCODING 000 = 1 (1) 100 = 2 (1) 200 = 4 (1) 300 = 8 (1) I E AT MIDDLE C = 134 (377 FORMAT OCTAL) Using this note encoding guide, you should find it fairly easy to encode any desired tune for playing by the device. Note that the final code for a note is formed by adding the basic note code to the desired duration code, as shown by the example. is to be played The computer must then reset the flag FF, which enables the 9321 decoder, and this in turn enables the octave multiplexer to begin sounding the note At the same time the D1311 PUT in the timing circuit is triggered, discharging the timing capacitor. The second half of the 9321 decoder is also enabled, turning on one of the four timing resistors according to the coding of the two most significant data word bits When the timing capacitor recharges, after the appropriate period of time, the level detector circuit sets the flag FF once more, disabling the 9321 decoder and hence causing the note to end. At the same time, the flag line of the player goes low, indicating to the computer that the note has been played. The computer may then send another note, if this is appropriate, to repeat the cycle. Note that the player may be arranged to play "rests" or periods of silence, by feeding it words whose note coding corresponds to one of the four unused note multiplexer addresses. The duration of the rest may be programmed just as with normal notes, by using the two most significant bits. Thus cost code 100 will produce a rest of 2 time units duration, while code 300 will produce a rest B units long. Note also that the 74.164 data buffer register is fitted with an R-C circuit connected to the clear (L) input. This is to reset the register when power is first applied to the player, so that it doesn't burst into spontaneous song. Most of the ICs in the music player are of the TTL type, and are powered from the SV supply of the computer, via the connection cable. The only exception is the note synthesiser chip, where both of the alternative ICs requires +12V, with the AY-1-0212 requiring -12V as well. To provide these voltages the player includes a small power supply, whose circuit is shown in the small diagram. The current drain from the +12V rail is only about 20-25mA, while that for the -12V rail is even lower—around 4mA. As a result the power supply is very straightforward, using a ministure 12V/150mA transformer such as the Ferguson type F22B1 or similar. Two half-wave voltage doubling rectifiers are used, with simple zener clides shunt regulators. Note that the -12V part of the supply may be omitted if the Mostek 50242 note synthesiser chip is different formal control of the Mostek 50242 note synthesiser chip is I built up the prototype player unit in a small utility box, of the type used for small stereo amplifiers, etc. Most of the components and wiring were mounted on one of the EA "Multidip" boerds, which are very suitable for this sort of one-off project using a number of ICs. The only parts of the circuit not mounted on the Multi-dip board were the note synthesise IC with its thirteen transistor buffer stages and power supplies and the power transformer. The latter was simply mounted in the case near the rear, with its primary connections taken to 8-8 connector strip to mate with the mains cord wires in the approved manner. To mount the note synthesiser chip, its buffers and power supplies conveniently, lused one of the PC boards originally designed for the "Cystal Locked Musical Tone Generator", described in the August 1974 issue of Electronics Australia. The board is coded EA 74/09, and was designed to take the chip and buffers, as well as power supply circuitry. Although the present voltage-doubler rectifiers are a little different from those used in the original project, the power supply wiring can still be fitted on the PC board quite easily. To give you an idea of the programming required for the music player. I have reproduced here a simple tune-playing program which will play a sequence of notes, automatically spaced by rests. Each rest is equal in duration to the note which immediately precedes it, a simple arrangement which gives a fairly natural sound to most tunes. The coding for the tune to be played must. The coding for the tune to be played must. The coding with the program in the memory of the computer, beginning at location 930 cotal. The tune can occupy the envire remainder of the memory, which forms the tune buffer of the memory, which forms the tune buffer of the memory, which forms the tune buffer of the memory which forms the tune buffer of the memory which the program can play quite lengthy tunes. (Only the actual notes of the tune are stored, the program itself inserting the standard residual can be program the standard residual can be program to the program the standard residual can be program to the program the standard residual can be program to the program the standard residual can be program to the progra You can make the program play the notes of a tune without the specing rests by replacing the instructions in locations 15, 16 and 17 (octal) with "NOP" instructions (octal 700). This will give a "legato" effect, which can be more appropriate with some tunes. This is a very simple program, and you will no doubt want to try your hand at a more elaborate effort later on. But this one should at least serve to get your music player going. To help you in encoding tunes for the player, we have prepared a diagram which shows the notes laid out in piano keyboard fashion, with their corresponding coding alongside. The note length encoding is also shown beneath; this is added to the note encoding to form the | €, | EOUC-8 PROGRAM (LESS TUNE) | SA-Ø1Ø | |------|----------------------------|--------| | STEP | MNEMONIC | CJDE | | 0 | PLAY,# | 555 | | 1 | 1MB | 626 | | 2 | SMF | 621 | | 3 | JNP1 | 5/52 | | 4 | JWP 1 PLAY | 526 | | 5 | IN N. B | pala | | 6 | BUFS, #3# | ฮเล | | 7 | MASK,388 /377 format | 688 | | 10 | STFT,CLA | 71,8 | | 11 | TAD BUFS | 1,86 | | 12 | DGA 1NJY | 3,65 | | 13 | GO, TAD 1 INJY | 125 | | 14 | JMS PLAY | 486 | | 15 | TAD 1 1NJY | 125 | | 16 | AND MASK | 887 | | 17 | JMS PLAY | 4,88 | | 28 | ISZ 1 IN A | 226 | | 21 | JMP 1 GOAD | 525 | | 22 | HLT | 721 | | 23 | JMP 1 STTA | 524 | | 24 | STTA, ØLØ | øig | | 25 | GOAD, #13 | Ø13 | | 26 | INDA, Ø#5 | 885 | | 27 | | | | 30 | (start of tune buffer) | | | 31 | | | | 32 | | | | 33 | | | | 34 | | | | 35 | | T | | 36 | | | | 37 | | | This simple program will play tunes with each note followed by a rest of the same duration. The notes of the tune are stored in memory along with the program, beginning at location 030 (octail) complete code number for each note. Hence if you want a note to be middle C, and to last for 2 units of time, the coding is 100 + 34, or 134. Note that the octal format assumed by the note encoding diagram is "377" format, which is fairly obviously the more appropriate in view of the way in which the player interprets the 8-bit words fed to it. the tune ends, for better effect. I suggest that you punch this coding onto paper tape, using a modified version of the program given earlier for program tape punching from the keyboard unit. Modify the program so that it will accept the octal input digit in 377 format, instead of the 737 format used for program encodino. If you start this and all subsequent tune tapes with an "end of leader" bit code, followed by code 030, they can be loaded into the computer tune buffer at any time, without disturbing the tune playing program itself. This way, you can change tunes at will, without having to load in the program itself each time. Incidentally, if you load in the tune playing program without an intentional tune, and to tit going, it will "play" whatever random numbers are already in the computer's memory—either the remains of earlier programs, or the turn-on bias bits of the memory RAM flipflops if you have just turned on. Eithar way, the sounds produced can be quite weirdly the sounds produced can be quite weirdly. Well, that's the basic music player device, which will let your EDUC-8 play a simple tune. It's fairly straightforward, as you can see, and leaves plenty of room for elaboration should you be so inclined. One idea would be to build a companion unit, which would take the raw audio output from the player and put it through a programmable attenuator and filter system, to vary both amplitude and harmonic content under the control of a second 8-bit word. Three of the bits could be used to give eight different amplitude levels, say, while the remaining five could be used to control the characteristics of a programmable formant filter. For the attenuator you could use three NPN transistor switches, driven from the three epopropriate outputs of the data buffer register, and switching the shunt resistors in a ladder-type resistive attenuator circuit. The filter scheme could be implemented in a similar way, considered the same statement of the similar sections in and out of the signal path. The whole unit implift involve say, a 74164 for the data buffer, eight 80108 or similar transistors, and Some R1 and Cs. Anothar idea would be to expand the player itself, with edditional data buffers, so that it could play a number of notes at once—for chords. The data words from the computer could be directed to the various buffers using a simple multiplexer scheme. No doubt other ideas along these lines will occur to you as you go along. Have fun! ### **Interfacing EDUC-8 to** teleprinters & mag. tape To conclude the description of his basic EDUC-8 microcomputer system, the author presents here a design for a flexible receivertransmitter circuit capable of interfacing the computer with asynchronous peripheral devices such as teleprinters. Full details are given for interfacing with typical teleprinters, together with details of a simple system for magnetic tape recording using an elementary "modem" ### by JAMIESON ROWE No description of a computer system designed for educational work would be complete without at least a brief look at asynchronous interfacing. Apart from any other reasons, there is the very practical one that in most schools, colleges and universities the peripheral device most likely to be available for interfacing is the femiliar teleprinter or "Teletype" (the latter name is a trademark) I realise that for the individual private constructor, the interest in teleprinter interfacing is likely to be more theoretical than practical. as teleprinter machines are neither plentiful nor cheap. Brand new machines of the most appropriate 8-bit ASCII coded type cost anywhere from about \$850 to \$1500, depending upon options. Even secondhand mechines in moderate condition tend to cost upwards of \$200, and they are not available very often Second-hand machines using the older 5-bit Baudot or Murray code are available slightly more frequently, end for a more reasonable cost. However while these can be interfaced with the computer, they are less attractive than the 8-bit ASCII type because of the need to arrange for code conversion. Happily there is e second and quite practical application of the asynchronous interfacing technique, which should be well within the grasp of the individual constructor. Most people have a tape recorder, of either the reel-to-reel or cassette veriety, end by using the esynchronous interface with e simple frequency-shift "modem" to be described, such recorders may be used for convenient storage of both progrems end data. But even if you don't have access to a teleprinter, nor feel disposed to build up the circuit for magnetic tepe interfacing, I hope the discussion of esynchronous interfacing will prove interesting and worthwhile background information. It is efter ell en important erea within the broad spectrum of computer interfacing, end as such is worth knowing about. To begin, then. With ell of the peripheral devices described so fer, elthough the flag signels which initiate information transfer are generally not fixed in time reletionship with respect to the computer's clock pulses, the actual transfer operation itself is always controlled by end locked to the clock pulses. In that sense they may be regarded as 'synchronous' peripherals Inevitably, there arise situations where one wishes to interface e computer to devices which by their very nature do not lend themselves to this sort of synchronous trensfer. Broadly speaking, the devices concerned are designed to transfer information at their own fixed speed, which cannot readily be altered to synchronise with the computer. Probably the most common such device is the teleprinter machine Developed around 1906 es an improvement on the simple Morse key and sounder telegraph system, the teleprinter machine has a keyboard and printer mechanism resembling a typewriter. However unlike a typewriter the two are not connected permanently together; they are functionally separated, and share a common case purely for convenience. In the simplest possible telegraphy system using teleprinters, the keyboard of the machine at one end of the line is connected electrically to the printer of the machine at the other end, and vice-versa. However as this doesn't allow type designed to deliver either 20 or 60 mA With no key pressed, the clutch is disen- gaged, and the distributor remains stationary The brush contact touches a commutator seqment permanently connected to the output line, so that the line receives current. This is known as the idle or "mark" condition When a key is pressed, a mechanical encoding system first operates a number of fixed switches. These open or close the connections between each of the various "data bit" segments of the commutator and the output line, setting up the coding of the character to be sent. Then the drive clutch is engeged, whereupon the motor rotates the distributor through one revolution. As it rotates, the brush contact effectively "scans" the various segments After leaving its idle position, the brush first contacts e segment which is permanently open circuit. This breaks the line circuit, to generate a no-current or "space" bit at the start of every character-i.e., the start bit. Then the brush scans the data bit segments, in each case making (mark) or breaking (space) the line circuit depending upon the coding set up for the character concerned. Finally the brush contacts one or more segments which are permenently connected to the line, to generate one or more The serial data format used by 8-bit ASCII teleprinters, showing the way that the start and stop bits are appended each operator to see whet they have transmitted, the connections are usually arranged so that each printer is also able to monitor or 'echo" the information sent by its own keyboard. Being designed for telegraphy, teleprinters ere on-off or digital devices. And as they were developed for use over two-wire lines (or single wire and earth), they transfer the information in serial digital form. Each character is sent and received as a sequence of bits, with the number of bits per cheracter and their transmission rate being fixed for a given type of machine and Each character bit sequence has a fixed 'start" bit, to identify the beginning of the character. This is followed by from 5 to 8 'data' bits, representing the actual character itself encoded in one of a number of codes. Finally there are one or more fixed "stop" bits, to identify the end of the character sequence. The character bit sequences are generated et the teleprinter keyboard by a rotary commutator switch, known as the ' trensmitter distributor". This has a number of fixed contact segments, one for each of the total number of bits in the character sequence, and a rotating brush contect driven by a fixed-speed motor via a clutch. The rotating brush is connected to a power supply, generally a constant-current merk bits-the ston bits At the end of the cycle the clutch disengages to bring the distributor to a halt, with the brush still in contact with the last stop bit segment. The machine thus stops with the line circuit made once more-i.e., in the merk condition The besic format of a teleprinter trensmitted character thus consists of a stert bit, e number of data bits, end a number of stop bits, where the start bit is always a "spece" (no current), and the stop bit or bits are elweys "marks (current). Meny computer-type teleprinters use 8 dete bits and 2 stop bits, giving the formet shown in the small diagrem The printer mechanism of the receiving teleprinter uses a similar technique to the keyboard in order to produce printed characters from the incoming seriel bit sequences. There is again a rotating essembly driven via a clutch from a constant-speed motor, but in this case it is a set of selector cams which control the ectuation of mechanical decoding linkages from an electromagnet. The electromagnet, known as the "selector magnet", is elso used to control the driving clutch The signelling current flowing in the line is used to energise the selector magnet, and accordingly the magnet remains energised while ever the trensmitting teletype is idling. In this situation the printer clutch is held disen- FIG. 1 ASYNCHRONOUS SERIAL INTERFACE gaged by the magnet, and the printer does not operate. As soon as a character begins to be transmited, the line current is broken for the duration of the start bit. This causes the printer selector magnet to release, allowing the clutch to engege. The selector cams begin to roste, from their rest position. As they rostes, they allow their corresponding printer mechanism decodtheir corresponding printer mechanism decodmagnetic, sto to activate by the selector magnetic and the corresponding printer to the various data bits. At the end of the last data bit, the printer decoding linkages have thus been set up according to the coding of the transmitted character. A further linkage actuated by the selector magnet at the beginning of the stop bit (or first stop bit. if there are more than one). is then used to activate the printing mechanism and print the character. At the seme time the energised selector magnet disengages the selector cem clutch, to end the cycle. As you can see, the system relies upon the motors of both machines rotating their respective mechanisms at identical speeds. Angular synchronism is echieved by having fixed idling positions, and by heving the primiter 'irriggered' into synchronism with the transmitted character by the action of the start bit in causing the selector magnet to engage the clutch. There are basically two problems to be solved. There are basically two problems to be solved in order to interface a teleprinter machine with a computer. The first and simpler is that the machine can only transfer information serially, and at a fixed speed, which is generally much lower than the computer clock rete. Thus most 8-bit ASCII coded teleprinters intended for use with computers ere designed to run at a speed corresponding to 110 bits per second, or 110 baud. As there ere a total of 11 bits used per character, this corresponds to a maximum of 10 characters per second. Mechines designed for the older 5-bit system generally run even slower, at 50 baud. In most cases these machines use a stop bit of 1.5 times the duration of the other bits, which is loosely termed "1.5 stop bits". This gives an effective 7.5 bits per character, or a meximum of 6.66 characters per second at 50 baud. Although it involves a certain amount of fidding, the lows speed requirement is not too much of a problem. So that providing the charactors may be encoded approprietely, aucharactors may be encoded approprietely, aucharactors with the required start and stop bits, and sent at the correct low speed, it is really and sent at the correct low speed, it is really not too difficult to drive a teleprinter printing FIG. 2 ASYNCHRONOUS INTERFACE PCB WIRING mechanism from a computer. As the printing mechanism is alreedy dasigned to automatically synchronise with incoming characters, it will operate normelly. However it is when one comes to consider using the teleprinter keyboard to send charactars to the computer that the second problem arises. This is because the keyboard cannot be synchronised with the computer; it sends eech character bit sequence at its own rete, and immediately following a keystroke. What is needed for keyboard interfacing is therefore a logic circuit capable of electricallyduplicating the operation of the teleprinter selector mechanism—one which is able to recognism the arrival of a start bit, and synchronise with it to stroba in the following data bits. This is by no means an easy task, as a few moments' reflection may raveal. Until a few years ego, teleprinter keyboard interfacing thus involved quite a lot of complex circuitry. Individe quite a lot of complex circuitry. Happily here are now evaleties inswinding operation of interfacing with asynchronous devices like teleprinters—both the transmitting and receiving sides. They are called "universal" asynchronous receiver-transmitters", or "LARTIs" for short. Tha word "universal" is used because the devices are entiretes", or "LARTIs" for short. Tha word "universal" is used because the devices are entiretes", or but the support of the state of the support UARTs generally come in an impressive 40pin dual-in-line package, and considering their complexity they come surprisingly cheap around \$8-10. This seems to be because they are used in lerge quantities in the data communications industry. As you can see from Fig. 1, e UART is used as the heart of the asynchronous interfacing unit I have developed for the EDUC-B system. And using such a device, the interface becomes deceptively simple and straightforward. There are three alternative UART devices which may be used: the American Microsystems S1BBS (available from Cema Distributors), the General Instrument Microslectroinc Syst—5.01.02 (from General Electronic Services), and the Signetics 2536 (from Tenior Electronics). Strictly the three devices are not quite identical, because the S1B8 3 is capable of being programmed for "1.5" stop bits, in addition to the single and double stop bits programming to the single and double stop bit programming this is really only an academic difference, as it only affects the maximum rate of character transmission when working with 5-bit teleprinters. All three devices will work with such machines, as well as with most others, and thus as dentical purposes they make regarded as identical. We don't heva the space here to enelyse the operation of a UART in detail, and if you operation of a UART in detail, and if you are interested I suggest you try and get hold of a data sheet and epplications brochure from one of the distributors. However if you bear in mind the foregoing description of teleprinter operation, the general idea should become cleer to you as we look at the circuit of Fig. 1. The trensmitter and receiver sections of the UART both need e source of external clock signals, at a frequency of 16 times the desired boud rate. Thus, for normal 110 boud teleprinters, the required clock rate is 1760Hz. As generator using a 55 time IC. The 50 preset generator using a 55 time IC. The 50 preset generator using a 55 time IC. The 50 preset sect bour large required. The values of the por, sect bour large required. The values of the por, its series resistor and the 0.1 uF charging capacior may all be changed, if necessary, to adopt the interface to beud rates very much higher or lower than the nominal 110 baud rate shown. À single set of logic inputs are used to program both that resmitter end receiver sections of the LART for the serial word format required, bit, NSB (number of stop bits), POE (perity bit), NSB (number of stop bits), POE (perity odd/even), NDB1 end NDB2 (both used for setting the number of deta bits). These are taken to either the high of low logic level to program the device for the formet required. For our purposes, the most appropriets format is words having B date bits, no perity, end 2 stop bits. This is very suitable for hendling both instruction and data words from EDUC-B, and is also the format used on many 110 baud teleprinters. As it happens, this format is programmed by taking all five of the UART logic inputs to the logic high level, as shown. Probably the only other format you are likely to want is that for 5-bit teleprinters, which use 5 data bits, no perity, and "1.5" stop bits. To program the UART for this former, simply take the NDB1 end NDB2 inputs down to low lavel, leeving the others at high level. Strictly only the 51883 device will give the correct only the 51883 device will give the correct "1.5" stop bits, but the other devices will still give satisfectory operation. The UART transmitter section has B parallel inputs for the deta bits to be treasmitted, le-bellad TD1-B. To provide thase with the data word to be transmitted, the interfece uses 74164 device as a buffer. The word is shifted into the buffer serially, et the computer clock rete, as with the other output devices which have been described. The word is actually loaded into the UART's internal deta buffer from the 74164 by the RESET ELAG. (I) pulse from the 40 members which is fed not only to the sensemiter flag which is fed not only to the sensemiter flag input of the UART. This imput not not consider the word to be fed into the UART. but also triggers the transmitter circuitry to begin transmitting it. Accordingly the UART adds the sant but and stop bits required, and feeds the word to the stop that When the lest data bit has been trensmitted, the UART signals that a new number may be loaded for trensmission, by producing a high logiclevel at ISTBMT (trensmission, by producing a high logiclevel at ISTBMT (trensmitter buffer entry) output. This signel is fed through inverter 12, and used to set the trensmitter flag FF via the .001 uF differentiating capacitor. The flag FF is formed by getes G2 and G3, with G1 users. as a buffer for the FLAG (3) line to the computer. When the UART sets the fleg FT to signal that the last data bit of the currant word has the transmissed, the stop bits said heve to be been transmissed, the stop bits said heve to be sephenous rate. I will be supported a suit with the support of suppo The raceivar side of the UART accepts the asynchronous serial input at its RSI (receives sarial input) terminel. When a character arrives at this terminal, the receiver circuitry automatically detects its start bit, synchronises with it, and strobes the following date bits into an internal buffer. It then indicates that a received word is available at its sight perallel output RDI-B, by producing a logic high level at its ODA (output date available) output. The external receiver interfecing circuitry inverts this signel through inverter I3, and uses it to trigger a monostable, D1. The output from D1 is a narrow pulse (about lus), and is used to load the data from the UART outputs into the external receiver buffer register, formed by a 74165 device. The pulse is also used to set the receiver flag FF, formed by gates G5 and G6. Gate G7 is used as before to provide buffering for its USA (I) line. The output of monostable D1 is also fed to a second monostable D2, whose output is a second lus pulseimmediately following the first. This is used to reset the UART's internal receiver flag circuitry, readying it for the arrival of another character. or antomer characters. When the receiver flag FF is set, the computer is thus made aware that a character has been received and is ready for transfer in the receiver buffer. It can then transfer the character into the AC register as with any other input device, by supplying clock pulses and receiving the data via the line driver GB. Note that the UART requires both 5V end – 12V power supplies, being a MOS device. The 5V supply comes from the computer, and is used to power the other interface ICs as well. The – 12V supply involves only about 40 mA, and is provided by a small supply in the interface unit itself. Inverter I4 and its associated R-C network are used to reset various internal UART circuity when the power is first applied. To make it essier for you to build up the basic asynchronous interfacing circuit of Fig. 1. I have designed a small PC board for the job. It is coded E8 / SR-T, and the wiring for the board is shown in Fig. 2. As you can see, links are provided to allow the unit to be programmed for various word formats. but various bout our topic state of the control TSO and RSI terminals of the UART are no seigned to connect directly to a teleprinter line. In fact they are basically stendard TTL logic terminals, with the convention such that the logic high level represents the "mark" condition for both, and logic low the "späce" level. Both normally remain high when the UART is idling. FIG. 3 TELEPRINTER INTERFACING (33 SERIES TELETYPE) To connect the interface with a typical modern teleprinter like the Teletype series 3 mechines (KSR-33 or ASR-33), you will need supplementary circuitry as shown in Fig. 3. This also includes the small power supply required to produce the —12V rail for the UART. The 33 series Teletypes have an internal selector magnet driver circuit, so that the incoming signal line does not drive the megnet coils directly. This simplifiles the external circuitry required, as there is no need to worry about inductive spikes, beck-EMF, etc. All that is required is a logic inverter end e simple PNP transistor stegs, shown at the top of Fig. 3. Note that as shown, the PNP stage is designed to provide 2 DmA of single current into Note that as shown, the PNP stage is designed to provide 2DM of signel current into the teleprinter selector megnet driver. This of curse assumes that the driver is adjusted to expect this current level, rather then the alternative 6Dm Alevel. The changeover from 60m to 20mA input is quite easily made, if required, by swepping over elink in the driver circuit. The remaining logic shown in Fig. 3 forms an input shaping and Schmitt rigger circuit to produce a signal from the teleprinter key-board distributor contacts, suitable for feeding to the UART seriel input on the interfece PC board. The R-C components end diodes ere used to clean up the signal fed to the 7413. Schmitt trigger element, to remove bounce and other spurious transients. Note thet the distributor contact circuit is connected to both the 5V supply reil and to a source of —15V from the small power supply. The resulting 20V swing helps in producing a clean signal from the rotating distributor contacts. You have probably noticed that the second half of the 7413 Schmitt trigger device is used FIG. 4 SELECTOR MAGNET DRIVER FOR OLDER TTYS es the inverter for the PNP selector driver emplifier. This makes it possible to provide "hardware acto" facility, so that if desired the primate can be made to automatically exho whatever is transmitted to the computer from whatever is transmitted to the computer from whatever is transmitted to the computer from of the 7413 from logic high, and connecting of the 7413 from logic high, and connecting it instead to the output of the lower 7413 element. The top element thus becomes a negetive-input OR gate, feeding signals to the intrinsf from either the UART or the suborder. Older teleprinter machines differ from the newest 33-series Teletype machines in that they generally do not heve en internal selector megnet driver circuit. In other words, the incoming signel line drives the selector megnet windings, which reconnected in series for 20mA operation or in perallel for 60mA operation. To operate one of these older mechines with the interface, you will need to modify the circuit of Fig. 3 es shown in Fig. 4. The change mainly involves the addition of a further rectifier circuit to the power supply, to generate about 25V, together with a medium power NPN transistor to switch the selector megnet current. As you cen see, the megnet windings are connected in perallel for 60mA operation, as this gives more reliable operation from a 25V supply. The two 180 ohm resistors are to set the current level, while the two diodes and the R-C circuit essocieted with the magnet windings are to suppress the inductive back-EMF. Don't forget that in order to operate an older teleprinter of the 5-bit variety with the EDUC-B system (or with any other computer, for that matter), you will have to perform code conversion somewhere in the system. This is because 5-bit machines use the Baudot or Murray code, not ASCII. The code conversion could be done by the computer program itself, but this will of course involve valuable memory space. Perhaps a neeter way would be to interpose read-only memory circuitry between the UART date inputs and outputs and the 74164 and 74165 buffers, in the interface circuit of Fig. 1, You could use either Ic ROMs, or diode arrays. I hope the foregoing information will enable you to connect up a teleprinter to your EDUC-8 system, if you want to do so, with a fair degree of confidence and success. As mentioned earlier, the esynchronous interfacing unit of Figs. 1 end 2 may also be used for storing program and data on megnetic tape. Before closing, I will give a brief description of how this is done. Almost any mono recorder may be used, of either the cessette or reel-to-reel variety. As with a teleprinter, it is not all thet difficult to transfer information from the computer to to transfer information from the computer to megnetic tape—providing the transfer is made at a suitable rate, in this case one which will fall within the modest bandwidth of en euclio recorder. The problems tend to occur in the reverse transfer direction: from the tape beck to the computer. Like the teleprinter, e tape recorder tends to supply information at its own fixed rate, and cannot be synchronised readily. with the computer clock pulses. Happily the same asynchronous dete format used for teleprinters may be used for tepe recording and playback—all that is needed is to encode the data in audio tones, so that the recorder is not required to handle DC levels. The most reliable results are obtained using the technique of frequency-shift keying, or "FSK", where the two digital data levels are recorded as tones of differing pitch. This means that the tape is always recorded with a tone of one pitch or the other, which allows the effects of dro-pout to be minimisad. Generating and demodulating FSK signals used to be a fairly complex business, but thanks to modern IC technology It is now fairly straightforward. As shown in Fig. 5, only two ICs and a transistor are required in order to edapt the besic asynchronous interface circuit of Fig. 1 for magnetic tape recording. Both of the ICs are made by the Exar Corporation, and are available in Australia from A. J. Ferguson Pty Ltd (order through your usual supplier). They are the XR-2206 waveform generator device, and the XR-2211 tone and SKM etector device. Each costs around \$5.00. The XR.206 device is designed to produce where square, tringular or sine weeterms over a wide frequency range, and has the edditional feature that its frequency may be switched between two values by a TTL logic signal applied to pin. 9 Here it is used to penerate sine waves of either 1400Hz or 1200Hz, with the higher frequency corresponding to "mark" and the lower to "space". The signal from the TSO the equivalent St. Signal, which a spaces at pin 2 of the device. This is fed to the recorder values are present on the spread product recording an errest pot, to adjust recording a digust recording a preset pot, to adjust recording a digust recording a preset pot, to adjust recording a digust recording a digust recording a digust recording a digust recording a digust recording a digust recording and the size of To decode the FSK signals on playback, the output from the recorder is fed to the XR-2211 device. This device is especially designed for FSK demodulation, and works on the phaselocked loop principle. It will lock onto input signals anywhere between 2mV and 3V RMS, so that the output from the recorder can vary over a very wide range without causing a data error. The XR-2211 device has two outputs, a tone-detect (Jo output which eppears at pin 5, and the actual FSK demodulation output which spears at pin 7. By writing transitior T1 as shown, the output from the device tentales low shown, the output from the device tentales low the tape is stopped. By using one of the spare inverters on the interface board, this low is changed to a high, so that the RS input of the UART receives the correct "mark" signal of the UART receives the correct "mark" signal played back from the sace. As soon as the tape is started and tone appears, the level at pin 5 of the XR-2211 falls to the low logic level, and transistor T1 turns off. However the level at pin 7 will still be low whilever the tone from the tape is at the "mark" frequency. It will only go high when the tone changes to the "space" frequency, and the inverter will thus feed the correct logic levels to the IAIAT. For correct operation the VCO of the XR-2211 must be set to give e free-running frequency midway between the incoming mark and space frequencies—i.e., 1300Hz in this case. This is set by means of the 5k preset pot in series with the 18k resistor, connected to pin 12. You can perform this adjustment reasonably well by recording a section of tape with a single cheracter repeated, and monitoring the output signal going to the RSI input of the UART with an oscilloscope. Then adjust the 5k pot while pleying back the tape, until you are getting a clean, noise-free signal. (Continued on page 107) ### INFORMATION CENTRE (Continued from p. 105) it would be more convenient if editorial pages were separated by a full page advert, in practice this situation is virtually impossible to achieve. We would refer you to the Forum pages of the January 1974 issue of EA, where we answered a previous critic in some detail. Thank you for your suggestion and your kind remarks. LOW FREQUENCY RESPONSE: I am 15 years old and have been interested in electronics for about 2 years now. I must congratulate you on a clearly set out and informative magazine. I have recently built the PM 156 amplifier and thanks to the simple instructions and clear diagrams managed to get it operating first go. I connected the amp to a turntable fitted with a sultable cartridge and a pair of speakers, and I am extremely pleased with the resulting sound. As I operate the set in a very small room (about 12'x 9'), it requires a fair degree of bass lift to achieve a "flat" sounding response. This, however, dramatically increases turntable rumble as well as low frequency surface noise to a very large extent, causing the wooler cone to travel about 2" excursions at half volume setting. is there any way of attenuating the response below about 20Hz, without major circuit changes to the amplifier? It seems to me that this must be quite a common problem, so I am hoping you can answer this in the pages of "Information Centre". (N.G., Carlingford, NSW.) Thank you very much for your comments about the magazine. It is possible to design circuits to roll off the bass response at 20Hz, although we have never presented such a design. From the description of your symptoms, it appears that you may be suffering from acoustic feedback between the speakers and the turntable unit. A simple test for this is to move the turntable to another room. If the large cone excursions stop, it is almost certain that acoustic feedback was the cause of the excursions. It will now be necessary to return the turntable to the original room, while still retaining the acoustic isolation. It may be necessary to increase the isolation by providing extra suspension for the plinth, or by placing it on some sort of flexible mounting, similar to that used to support the turntable on the plinth. Another approach is to use a wall shelf to support the plinth and turntable, to avoid coupling of vibrations from the floor. If acoustic feedback is not causing your troubles, then there is little which can be done. A high pass filter with a cutoff frequency at 20Hz will not eliminate any audible rumble and surface noise. However, it may eliminate distortion caused by bottoming of the woofer cone due to large subaudible signals. Any filter with a higher cutoff frequency will eliminate rumble and surface noise, along with any signals which have similar frequency components, and for this reason is not recommended. We can only suggest that it may be necessary to use less bass boost LOST IN CAVES: An idea occurred to me while instening to the current record "journey To The Carter Of The Earth" concerning a possible project. Two people had become separated while exploring acts but were able to find each other and determine their distance apart "by use of their chronometers". I expect this was done by measuring the time lag between their speech. I have thought out a way in which this idea could be implemented (details enclosed), and was wondering if this could possibly form the basis of a project. (Tony Picone, 99 Rowena Street, Richmond, Vic. 3121). Due to the rather specialised nature of the device you have in mind, we do not think that it would be suitable as a project. However, we will keep your idea in mind. We have published your full name and address so that any interested readers can contact you direct. DIMMER BUZZ-Recently, I had an opportunity to tape an amatter stage show at a nearby hall. Lighting for the stage was dimmed by modern solid state triac control using all three phases of the electric supply. The result was a quite troublesome buzzthroughout the whole length of the recorded puzper manner except for the start when the lights were not working. The microphone leads were 12 yards long, of shielded cable. My questions are: Was the interference induced through the input to the tape recorder via the microphones and long leads or via the mains upply which the tape recorder and light dimmers were connected to or both of the above! How can I eliminate the or both of the above! How can I eliminate the line and the ship of the short of the short of the ship o Dit is quite likely the buzz you experienced was radiated via the supply lines as R interference which could be induced directly into the mic cables or picked up directly by the tape recorder. In addition, the mains interference could be fed directly into the tape recorder via the power supply. Without being in a position to eliminate each possibility, it is not possible to nominate the principal cause. As a first acceptable of the power of the power of the possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible to maintain the principal cause. As a first possible DEAD LETTER: We are holding material originally addressed to Mr D. Shropshall, PO Box 216, Roebourne, W.A. 6718. This has been returned by the postal authorities, presumably because they could not deliver it. If Mr Shropshall will advise us of his present address we will forward the material to him. (Continued on p. 110) ### **NOTES & ERRATA** PHILIPS 10GHZ DOPPLER MODULE (May 1975): The circuit of the prototype intruder alarm should show the 100k load resistor of the BC109 preamp transistor connecting to the 8.2V supply rail, not to the 10V rail. ### EDUC-8 computer—from page 73 For slightly better results, it is necessary to neasure the actual output frequencies of the XR-2206. Using a digital counter. These will probably be slightly different from the nominal figures, due to the effect of component tolerances. Then work out the mean of the two frequencies, by adding them together and dividing by two. Finally, set the free-running frequency of the KR-2211 to this mean frequency, in the following manner. With the power off, disconnect the 033uF capacitor from pin 3, and connect a temporary link between pins 2 and 10. Then turn on the power, and with no tone input signal, connect the digital counter to pin 3. Adjust the 5k pot until the counter indicates the correct mean frequency. Then turn off the power, and restore the circuit as it was. The XR-2211 should now give very clean and reliable demodulation of the FSK recordings. Note that the XR-2206 device requires a 12V power supply rail, so that a small rectifier circuit must be added to the interface power supply as shown. The XR-2211 operates from the 5V computer rail. In closing, it might be worthwhile to point out that the simple FSK modulator-demodulator, or "modem" of Fig. 5 could also be used for transmitting data signals over radio links. ### ANNOUNCE THE ARRIVAL OF A BULK SHIPMENT OF DUKE AM/FM/MPX STEREO TUNERS ### Specifications: FM-88-108MHz S/N ratio better than 50dB IF Rejection better than 90dB Stereo separation better than 30dB Muting and AFC switches Linear scale dial Signal strength meter FM stereo auto mpx. AM-535-1605kHz Sensitivity 50dB IF rejection 45dB Selectivity 25dB Ferrite bar antenna Flywheel tuning ### DUKE A100 STOCK AVAILABLE THIS MONTH ### WHOLESALE ENOURIES TO: John Carr & Co Pty Ltd 405 Sussex St, Sydney. Phone 211-5077 ### RETAIL ENGUIRIES TO: Jaycar Pty Ltd PO Box K39, Haymarket 2000. Phone 211 5077. ### INTERFACING A BURROUGHS SELF-SCAN DISPLAY PANEL TO YOUR EDUC-8 A Burroughs Self-Scan display panel is very suitable for use with the EDUC-8 computer system, offering full alphanumeric readout with large, brightly lit characters. The interfacing needed to hook up such a panel to your machine is quite straightforward, as explained below. There are a number of display panels in the Burroughs range which could be used with the EDUC-8 system. I elected to try the SSD1000-0041, which has an internal refresh memory and can display a line of 16 characters 10mm high. Alternatively you could use the SSD1000-0040, which can display a line of 32 characters about 5mm high. There is also a panel which will display up to 80 characters 5mm high. All panels are available from Cema Distributors Pty Ltd, of 21 Chandos St, Crows Nest NSW 2065. The SSD1000-0041 costs \$204, plus \$2 for a matching 10-way PC connector (SR-127), and plus 15% sales tax where applicable. This seems quite reasonable considering that it offers inbuilt refresh memory. Cema are providing data sheets with each unit purchased. For details on the operation of Self-Scan discharge panels, I can only refer you here to Greg Swain's article in the October 1974 issue of Electronics Australia. The interfacing required for the 16-character panel is shown below, and as you can see it is quite straightforward. A 74164 device is used as a data buffer, to provide the panel with its required 6-bit ASCII characters. The RESET FLAG(L) pulse is used to enable the panel's DATA PRESENT (L) input, while the panel's subsequent DATA TAKEN (L) output is used to set the flag FF via monostable D2-used to stretch the pulse to ensure overlapping the input pulse. Gates G5, G6 and G7 and monostable D1 are used to clear the display whenever a carriage return or similar non-printing control character is received, to begin a new line. The Self-Scan panel requires two additional supply voltage apart from the +5V from the computer: +250V for the actual display, and -12V for the MOS refresh memory. These are provided by the simple power supply shown. Note that zeners are used to regulate the 250V line, which must be maintained within plus/minus 5%. ### printed circuit - Accurately machine printed / etched - Phenolic & fibreglass-gold / tin plated - Special manufacturers' packs of 10 EA, R&H, ET, Philips, Mullard - available. - Specials to your drawing Plus post 40c. Imm despatch | ET/533A-B | 2.50 | ET801H | 2.60 | 72120 | 2.20 | |-------------------|--------------|------------------|--------------|------------------|--------------| | ETH440 | 4.50 | ET8016 | 2.80 | ET023 | 2.80 | | ET1400 | 2.00 | 74A1 | 2.20 | ET021 | 2.80 | | 75W3 | 2.00 | 74HPL | 2,00 | 72T2ABC | 4.40 | | ET1532 | 2.20 | 7312T2.80 | | 73V1B | 3.30<br>5.50 | | ET16258 | 3.38<br>4.50 | ETB010<br>ETB01C | 2.20 | 73V1A<br>72SA1 | 3.30 | | ETI529A<br>ETI702 | 2.50 | ET420C | 2.40 | ET022 | 2.80 | | ETED1R | 2.50 | ET4200 | 2.40 | 71012 | 4.40 | | ET601P | 2.50 | ET4208 | 2.80 | ETO19 | 2.80 | | ENSRT | 3.00 | ET420A | 2.20 | ET018 | 2.80 | | 75EM6 | 2.50 | ET524 | 2.80 | ET017 | 2.80 | | 75504 | 2.50 | ET8018 | 3.30 | ET014 | 2.60 | | 75A01 | 2.50 | ET601N | 3.80 | ET007 | 2.50 | | ET414E | 2.50 | ET601F | 2.80 | 71112 | 3.30 | | ET414D2 | 3.20 | ETB01E | 3.80 | ETO11 | 2.00 | | ET430 | 2.00 | 737U11 | 3.30<br>2.80 | 71PB<br>ETDOR | 2.80 | | ET314<br>ET116 | 2.60 | 737011<br>73P11 | 2.80 | 72C2 | 3.90 | | EBS | 3.00 | FT520A | 4.40 | ETO12 | 2.20 | | FRK1 | 3.00 | FT5208 | 4.40 | 72A5 | 2.50 | | FT628 | 2.00 | 73012 | 4.80 | 72PS6 | 2.20 | | ET312 | 3.00 | 73BA9 | 2.80 | ETOG6 | 2.80 | | 7601 | 2.60 | ET113 | 3.10 | ET034 | 2.90 | | 74MX120 | 3.50 | ET419 | 2.20 | 71SA4C | 3.30 | | 74MX12C | 2.80 | ET218 | 3,60 | 71SA48<br>71SA4A | 2.80<br>2.80 | | 74MX128 | 3.20<br>2.80 | ET417<br>ET308 | 1.70 | ETO25 | 2.80 | | 74MX12A<br>ET701 | 2.50 | ET414D | 1.30 | 71W7B | 2.00 | | E1701 | 2.00 | 73107 | 2.80 | 71W7A | 2.20 | | ET428 | 2.80 | 7356 | 1.30 | ET003 | 2.80 | | ET313 | 2.00 | ET521 | 3,50 | 7103 | 4.00 | | ET530 | 2.00 | ET213 | 1.10 | ET005A | 2.50 | | ET427 | 2.50 | ET416 | 3.30 | 71TU2 | 2.20 | | ET426 | 2.00 | 7301 | 1.70 | 70SL1 | 4.00 | | 74MX8 | 2.00 | ET518 | 2.20 | 70PA1<br>70R01 | 4.00 | | 74EM9<br>7ATUR | 2.50 | 733C<br>7311 | 2.80 | 70TX2 | 4.00 | | FT428 | 2.20 | ET414C | 2.80 | 70F10 | 2.20 | | FRX | 5.00 | FTATAR | 2.80 | 70A2 | 4.00 | | EATOT | 5.00 | FT414A | 2.80 | ET004 | 4.00 | | ERP | 5.00 | 72M12 | 2.80 | 70C01 | 2.20 | | EBM | 5.00 | 72SABM | 2.80 | 7181 | 2.20 | | ESD | 5.00 | ET413 | 2.80 | 70G7 | 2.00 | | E8A | 5.00 | ET034A | 3.10 | 7076 | 4.00<br>2.50 | | EBT | 8.00 | 72S11 | 2.80 | 71A8<br>70K5 | 4.00 | | EBF<br>ERC | 6.00 | 72110 | 1.30 | 708F03 | 2.20 | | 74C9 | 4.20 | 7211T | 3.30 | 7181 | 4.00 | | 7408 | 4.00 | ET037-40 | 6.00 | 70TX1 | 5.00 | | FT424 | 2.60 | 72SA10 | 3.10 | 78C4 | 8.00 | | ET311 | 2.50 | 72C8 | 2.80 | 7001 | 4.00 | | ET528 | 2.50 | ET028 | 2.20 | 70P1 | 2.50 | | ET114 | 2,50 | 72510 | 2:80 | 58C11 | 5.00 | | ETEW | 2,60 | 72R8 | 2.80 | 89F10<br>70A1 | 2.60<br>2.50 | | 74SA5 | 4.00<br>2.50 | 72SA9<br>ET033 | 2.80 | 88010 | 6.00 | | ETGO1M<br>ETGO1L | 2.50 | 72MX6 | 3.10 | 88C10 | 3.00 | | ET422 | 3,30 | 72T3 | 3.30 | SEPE | 3.00 | | 7483 | 2.50 | ET028 | 2.80 | 8909 | 8.00 | | ETR01J | 3.00 | 72IF6 | 2.20 | 88P5 | 3.00 | | ET423 | 2.20 | 71A8 | 2.80 | 8810CL | 8.00 | | ET420E | 3.30 | 72P3 | 2.20 | 8823 | 6.00 | | ET5218 | 2.00 | 72R2 | 2.80 | 8815 | 4.00 | ALL SILICON 30/60w PA PORTABLE AMPLIFIER 615"W x 314"H x 815"D 12-16V, two inputs, 5 & 100mV, 15 ohm output, No. 763D, Also 125, 250, 500 ohm output No. 763A, 418 70 each For 240V operation \$33 axtra. COILS and IF's %" x %" x 2"H All \$2.50 es. plus RF CHOKES Plus post 40c 381 AIR: 2.5mh 50me-Pys 70c. 381 IRON: 10uh to 1,000uh 25ma 70c FILTERS Plus post \$1. Line filter 2 smp \$12. Line filter 10 / 20 smp \$37.50. Pulse filter 2 amp \$12. MAIL cheque or money order (add postage) direct to:— radio pty Itd 651 FOREST RD BEXLEY NSW 2207 587 3491