Fortunately for you and me, one happy reader of the book is Siegbert Filbinger from Germany. Among many other things, he is an absolute wizard
Computer described in the book that emulates all aspects of its operation, and he did so. (He also discovered another item now included in the
Further, he has decided to allow me to share his work with other interested parties.
Therefore, many thanks to you, Mr. Filbinger!
In the Control panel are these controls:
run - The computer will run until you press stop.
stop - Stop the current operation, whether run, cycle or step.
reset - Stop, and set RAM and all Registers to zero.
do tick - Step the clock through one of its four phases. You can watch the ticks by watching 'clk e' and 'clk s'. First, both are off. Then clk e turns
on, then both are on, then just clk e, then back to both off. At the stage where they are both on, you can see which Registers are involved in
copying data from place to place.
do step - Run the clock for one clock cycle. The stepper will advance one, or go from 6 back to 1. If you had started a step by doing a few ticks,
then this will finish that step.
do cycle - Run the clock for one instruction cycle (=six clock cycles) (or finish a cycle you may have started above.)
clock speed - How long does one clock cycle take, in milli-seconds (thousandths of a second.)
wire color, width - Wires that are off are black, wires that are on are red, but you can change the color and width of the 'on' wires here.
start at ram address - The RAM address that the program will be loaded to, when you press 'load to ram.'
load to ram - Copy the compiled program (lower window) into RAM so that the model can execute it.
dump ram - This opens a pop-up window that shows the entire contents of RAM, one line per address. There are four columns, the first is 'ADR'
which shows the address (in decimal), The other three columns show the contents of that address in three different number systems, BINary,
HEXadecimal and DECimal.
program code - This window is where you can write a program using the programming language from the book. When you press the <F2> key
or <Enter>, the program will be compiled and shown in the window below it.
As mentioned above, there are links at the bottom of the model for Copyright Details and Help. At the bottom of the window that pops up, there is a
link that says 'Load sample multiplying 5x5'. When you click this, a program will be placed into 'program code', it will be compiled, and loaded to
RAM. This sample program is similar to the demonstration of multiplication from the book, page 142.
The model is copyright Siegbert Filbinger. The design of the Computer contained therein is copyright John Clark Scott. The model may be used
freely for personal and educational use, as long as the copyrights and contact information on the model are visible. For commercial use, please
contact this web site.
|Working Computer Model in your Browser
|Differences Between the Book and the Model
When you click on the picture above, a new window or tab will open containing the CPU model. It may take a few seconds to open. It was designed
for a full HD monitor, so it is suggested that you maximize your browser. There is no spare room in the model for the menus that are on every other
page of this web site, so it is suggested that if you create a bookmark or favorite, or share it with a friend, do it from this introduction page.
The model is quite complex, but it is easy to use. Click the buttons and watch it run, see what the parts do.
The ALU is on the left, the Control Section is in the middle, and the RAM on the right. Above and below are the bus and the various registers. On
the far right is a control panel which has buttons to run or step the cpu, and below is a place to write 'program code' in the programming language
we created in the book. Below that is a place that shows what the language becomes when it is compiled. There are links at the bottom for Copyright
Details and Help. They both open the same pop-up window, which contains Copyright details, contact information, a computer instruction reference,
instructions about how to write and compile programs, a handy link that will load a sample program into RAM, and a picture of the book, which when
clicked goes to the web site.
The model is also zoomable and scrollable if you don't have an HD screen.
-First of all, the model shows the details of the cpu and the control unit all in the same diagram, something that wouldn't fit in the book.
-The model includes all of the fixes that are shown on the errata page.
-In both the book and the model, when registers are shown horizontally, they are the same - you read it as a number from left to right. But in the
book, when registers are shown vertically, they are rotated clockwise, the left becomes the top. In the model, vertical registers are rotated
counter-clockwise, the left becomes the bottom. Because of this, the direction of the shifters are opposite. The shapes in the book and model are
the same, but in the book, the upper one is SHL. In the model, the upper one is SHR. To make this work correctly, the order of the outputs of the
3X8 decoder at the bottom of the ALU are adjusted. From the right, after 000, the next two are 010 and 001. The rest are the same. These are
labelled in the model.
'understands') and it will be shown in the window below it. Clicking 'load to ram' will cause the bytes in the lower does.
Be aware that the line numbers in both windows start at 0 and step up one at a time. BUT, some instructions compile to one byte, and some
compile to two bytes. Therefore, the top and bottom do not always correspond by line number. In the sample program, the first instruction (line 0) is
'DATA R0, 5'. This compiles into two bytes, which show up below as '00100000' (line 0) and '00000101' (line 1). The next instruction in the top will
be on line 1, and whatever it compiles to, will be in line 2 below, as well as line 3 if it is a 2 byte instruction.
You can also write programs with a plain text editor, such as Window's Notepad. You can do a multi-line select/copy of an entire program in the text
editor, and then place your cursor in the 'program code' window, and do a 'paste' operation. You can also copy from the 'program code' window
into your text editor. Thus you can build a library of programs, and not lose them when you close your browser.
Remember the links at the bottom for Copyright Details and Help. These open a pop-up window which contains a reference of the full computer
instruction set, and further instructions about how to write and compile programs.
Here is another program written by Mr. Filbinger. It calcuates fibonacci-numbers and stores them to RAM.You can use your mouse to select the
program below, then copy and paste it into the model.
DATA R2, 34
ST R3, R2
DATA R3, 32
LD R3, R0
ST R3, R1
ADD R0, R1
DATA R3, 33
LD R3, R2
DATA R0, 1
ADD R0, R2
ST R3, R2
ST R2, R1