Commodore 64 User's Guide
Commodore 64 User's Guide
Document names are limited to the 8.3 file convention of DOS. The
first characters of the file name are an abbreviation of the original
document name. The version number of the etext follows next. After
that a letter may appear to indicate the particular source of the
document. Finally, the document is given a .TXT extension.
*********
*********
Note: To extract the ascii text basic programs all at once from this
etext use "tok64" by Cris Berneburg <74171.2136@compuserve.com>. Or to
extract the uuencoded basic programs all at once use "uud" by Edwin
Kremer <edwin@zlotty>.
*********
There was a great work, but finally, after 2 weeks of correcting and
formatting the text to the format what you now see, it is ready. I hope
that this manual is the second greatest project after COMMDODORE 64
PROGRAMMER'S REFERENCE GUIDE. It is dedicated to C64 users who haven't
the original manual or buy 64 without it. Enjoy it!
Generally it is the original US manual with all programs and near all
pictures. There was many bugs & mispells corrected by me. Also the index
now is more usable instead original.
If you find errors in the text, please report them so that they can be
fixed. There should not be many, though...
*********
Published by
Commodore Business Machines, Inc.
and
Howard W. Sams & Co., Inc.
FIRST EDITION
THIRD PRINTING-1983
TABLE OF CONTENTS
INTRODUCTION
1. SETUP
1.1. Unpacking and Connecting the Commodore 64
1.2. Installation
1.3. Optional Connections
1.4. Operation
1.5. Color Adjustment
2. GETTING STARTED
2.1. Keyboard
2.2. Back to Normal
2.3. Loading and Saving Programs
2.4. PRINT and Calculations
2.5. Precedence
2.6. Combining Things
4. ADVANCED BASIC
4.1. Introduction
4.2. Simple Animation
Nested Loops
4.3. INPUT
4.4. GET
4.5. Random Numbers and Other Functions
4.6. Guessing Game
4.7. Your Roll
4.8. Random Graphics
CHR$ and ASC Functions
6. SPRITE GRAPHICS
6.1. Introduction to Sprites
6.2. Sprite Creation
6.3. Additional Notes on Sprites
6.4. Binary Arithmetic
7. CREATING SOUND
7.1. Using Sound if You're Not a Computer Programmer
7.2. Structure of a Sound Program
7.3. Sample Sound Program
7.4. Making Music on Your Commodore 64
7.5. Important Sound Settings
7.6. Playing a Song on the Commodore 64
7.7. Creating Sound Effects
7.8. Sample Sound Effects To Try
APPENDICES
Introduction
A: COMMODORE 64 ACCESSORIES AND SOFTWARE
B: ADVANCED CASSETTE OPERATION
C: COMMODORE 64 BASIC
D: ABBREVIATIONS FOR BASIC KEYWORDS
E: SCREEN DISPLAY CODES
F: ASCII AND CHR$ CODES
G: SCREEN AND COLOR MEMORY MAP
H: DERIVING MATHEMATICAL FUNCTIONS
I: PINOUTS FOR INPUT/OUTPUT DEVICES
J: PROGRAMS TO TRY
K: CONVERTING STANDARD BASIC PROGRAMS TO COMMODORE 64 BASIC
L: ERROR MESSAGES
M: MUSIC NOTE VALUES
N: BIBLIOGRAPHY
O: SPRITE REGISTER MAP
P: COMMODORE 64 SOUND CONTROL SETTINGS
INDEX
INTRODUCTION
NOTE:
Many programs are under development while this manual is being
produced. Please check with your local Commodore dealer and with
Commodore User's Magazines and Clubs, which will keep you up to date on
the wealth of applications programs being written for the Commodore 64,
worldwide.
1. SETUP
1. Commodore 64
2. Power supply (black box with an AC plug and supply cord)
3. Video cable
4. TV Switchbox (small silver box with short antenna leads).
If any items are missing check back with your dealer immediately for a
replacement.
First, let's take a look at the arrangement of the various connections
on the computer and how each functions.
/####\--------^--\
/#### |
/#### |
____/#### |
/ |
| ---- ---- __ /-\ |
| \--/ \--/ == \_/ |
\________________\___/______/____|__/
\/ / |
3 2 1
GAME POWER POWER
PORTS SWITCH SOCKET
___/###\__/##_##_##_##_##_##_##_##_##_##_##_##_##_##_##_##\__
|-------------------------------------------------------------|
| |
| |
| |
| +--------------+ /-\ /-\ +------+ +----------+ |
| |==============| [=] O \_/ \_/ |======| |==========| |
+-----/-------------/----/-----\-----\--------\---------\-----+
/ / / \ \ \ \
4 5 6 7 8 9 10
CARTRIDGE CHANNEL TV AUDIO/VIDEO SERIAL CASSETTE USER
SLOT SELECTOR CONNECTOR CONNECTOR PORT INTERFACE PORT
1. POWER SOCKET. The free end of the cable from the power supply is
attached here to supply power to the Commodore 64.
2. POWER SWITCH. Turns on power to the Commodore 64.
3. GAME PORTS. Each game connector can accept a joystick or game
controller paddle, while the lightpen can only be plugged into the
game port closest to the front of your computer.
REAR CONNECTIONS
1.2. Installation
CONNECTIONS TO YOUR TV
TV
Switchbox +--+-----------------+--+
+-----+ | | /-------------\#| |
/---------------#= =| |= | | | |#| |
| +--#--+ | | | |#| |
| \\_ | | | | | |
| \_ | | | | | |
To TV | To 300 Ohm | | \-------------/ | |
Signal # Antenna Input +==+=================+==+
Jack |
/------------------------\
| |=---\
| #################### ## | |
| #################### ## | |
| ################## ## | |
| ############## ## | |
\________________________/ |
|
|
|
+---+
| | Power
| | Supply
+---+
|
|
1. Attach one end of the TV cable to the phono type TV signal jack at the
rear of the Commodore 64. Just push it in. Either end of the cable can
be used.
2. Connect the other end of the cable to the antenna switchbox. Just push
it in.
3. If you have a VHF antenna, disconnect it from your TV set.
4. Connect your VHF antenna cable to the screw terminals labeled "antenna
input" on the switchbox. If your antenna cable is the round 75-ohm
coax type, use a 75-ohm to 300-ohm adapter (not supplied) to attach
your antenna cable to the switchbox.
5. Connect the twin lead output cable of the antenna switchbox to the VHF
antenna terminals of your TV set. If your set is one of the newer
types with a round 75-ohm VHF connector, you will need a 300-ohm to
75-ohm converter (not supplied) to connect the switchbox to the 75-ohm
VHF antenna input on the set.
6. Set the TV's VHF tuner to the channel number indicated on the
computer's channel selector switch (channel 3 move the switch to the
left, channel 4 move the switch to the right). If a strong local TV
signal is present on one of these channels, select the other channel
to avoid possible interference.
7. Plug the power supply cable into the power socket on the side of the
Commodore 64. Just push it in. It is "keyed" to allow insertion in
only one direction, so you can't connect the power cord the wrong way.
The power supply converts household current into the form the computer
uses.
/+---------------+
+ | |
| | | |
| | | |
/ | | | |
|========| | |
|========| | |
/ | | | |
| | |
| | _ _ /
| | |O| |O| |
+ | # # |
\+-----\---/----+
\ /
| |
| |
| |
++-++
75 Ohm to |___|
300 Ohm ----> | |
Adapter | |
+---+
\=/
###
Your 75 Ohm ----> | |
Coax VHF Antenna | |
/----------- -----------\
| /==\ /==\ /==\ |
| ||__|| ||__|| ||__|| |
| \__/ \__/ \__/ |
\__________________________/
^ To VHF
_|___ ANT.
+---+/
300 Ohm | ||
to 75 Ohm --> | ||
Adapter ++-++/
| |
| |
|_|/
/
___/###\__/##_##_##_##_##_##_##_##_##_##_##_##_##_##_##_##\__
|-------------------------------------------------------------|
| |
| |
| |
| +--------------+ /-\ /-\ +------+ +----------+ |
| |==============| [=] O \_/ \_/ |======| |==========| |
+-------------------------------------------------------------+
^
To |
TV Signal |
Jack
| Back of Your TV
# _/-----------------------------
| | /
\ / +--------------------------------
| |
\__________I______________________
| \
|-------+ |
| UHF | |
| O O | |#|
| VHF | |
||O| |O|| /---------=-\
/| # # | | COMPUTER |
/ |-|---|-+ | | |
200 Ohm | | | | | |
VHF | | \_____| | |
Input | \_________| | |
| | | |
| | TV |
| Antenna ->| |O| |O| |
| Switch \___#___#___/
| Box | | __
| |___|/
__/
Your VHF
Antenna
(If Used)
__###__################################__
/ \
| Audio/Video |
| Output |
|-----------------_---_-------------------|
| ========= = o | | | | ===== ========= |
+-----------------------------------------+
^
|
/-\
| |
| |
#
|
|
To AUXILIARY |
INPUT or |
____________ TUNER INPUT |
/ \ / \ To VIDEO IN
+----++------------++----+ <-#-/ \-#-> +------------+---+
| || ### ====== || | | /--------\ | O |
| || === OoooO || | || || = |
| ||------------|| | || || o |
| || | | | || | | \________/ | |
| || | | | || | +------------+---+
+----++============++----+
TV Monitor
Audio System
[ Picture omitted ]
1.4. Operation
1. Turn on the computer using the rocker switch on the right-side panel
when you're looking at the computer from the front.
2. After a few moments the following will be displayed on the TV screen:
READY.
_ <----------- Cursor signals Commodore 64 is waiting for your input
3. If your TV has a manual fine tuning knob, adjust the TV until you get
a clear picture.
4. You may also want to adjust the color and tint controls on the TV for
the best display. You can use the color adjustment procedure described
later to get everything setup properly. When you first get a picture,
the screen should appear mostly dark blue, with a light blue border
and letters.
If you don't get the expected results, recheck the cables and
connections. The accompanying chart will help you isolate any problem.
TROUBLESHOOTING CHART
+-----------------------------------------------------------------------+
| Symptom Cause Remedy |
+-----------------------------------------------------------------------+
| Indicator Light Computer not "On" Make sure power switch |
| not "On" is in "On" position |
| |
| Power cable not Check power socket for |
| not plugged in loose or disconnected |
| power cable |
| |
| Power supply not Check connection with |
| plugged in wall outlet |
| |
| Bad fuse in Take system to authorized |
| computer dealer for replacement of |
| fuse |
| |
| TV on wrong Check other channel |
| channel for picture (3 or 4) |
| |
| Incorrect Computer hooks up to |
| hookup VHF antenna terminals |
| |
| Video cable not Check TV output cable |
| plugged in connection |
| |
| Computer set for Set computer for same |
| wrong channel channel as TV (3 or 4) |
| |
| Random patterns on Cartridge not Reinsert cartridge after |
| TV with cartridge properly inserted turning off power |
| in place |
| |
| Picture without Poorly tuned TV Retune TV |
| color |
| |
| Picture with Bad color Adjust color/hue/ |
| poor color adjustment on TV brightness controls on TV |
| |
| Sound with excess TV volume up high Adjust volume of TV |
| background noise |
| |
| Picture OK, TV volume too low Adjust volume of TV |
| but no sound |
| |
| Aux. output not Connect sound jack to |
| properly connected aux. input on amplifier |
| and select aux. input |
+-----------------------------------------------------------------------+
CURSOR
The flashing square under READY is called the cursor and indicates
where what you type on the keyboard will be displayed on the screen. As
you type, the cursor will move ahead one space, as the original cursor
position is replaced with the character you typed. Try typing on the
keyboard and watch as characters you type are displayed on the TV screen.
[ Picture omitted ]
To use a control function, you hold down the <CTRL> key while
depressing a second key.
Try this: hold the <CTRL> key while also depressing the <9> key. Then
release both keys. Nothing obvious should have happened, but if you touch
any key now, the screen will show the character displayed in reverse
type, rather than normal type -- like the opening message or anything you
typed earlier.
Hold down the <SPACE BAR>. What happens? If you did the above procedure
correctly, you should see a light blue bar move across the screen and
then move down to the next line as long as the <SPACE BAR> is depressed.
READY.
____________________________
__________
Now, hold <CTRL> while depressing any of the other number keys. Each
of them has a color marked on the front. Anything displayed from this
point will be in that color. For example, hold <CTRL> and the <8> key and
release both. Now hold the <SPACE BAR>.
Watch the display. The bar is now in yellow! In a like manner you can
change the bar to any of the colors indicated on the number keys by
holding <CTRL> and the appropriate key.
Change the bar to a few more different colors and then adjust the color
and tint controls on your TV so the display matches the colors you
selected.
The display should appear something like this:
READY.
_________________________ <------ <3> Red bar
_______ ____________ ____ <------ <3>,<6>,<7> Red, Green, Blue bars
__________ ______________ <------ <7>,<8> Blue, Yellow bars
____________ <------ <8> Yellow bar
At this point everything is properly adjusted and working correctly.
The following chapters will introduce you to the BASIC language. However,
you can immediately start using some of the many prewritten applications
and games available for the Commodore 64 without knowing anything about
computer programming.
Each of these packages contains detailed information about how to use
the program. It is suggested, though, that you read through the first
few chapters of this manual to become more familiar with the basic
operation of your new system.
2. GETTING STARTED
2.1. Keyboard
Now that you've got everything set up and adjusted, please take a few
moments to familiarize yourself with the keyboard which is your most
important means of communication with the Commodore 64.
You will find the keyboard similar to a standard typewriter keyboard
found in most areas. There are, however, a number of new keys which
control specialized functions. What follows is a brief description of the
various keys and how they function. The detailed operation of each key
will be covered in later sections.
[ Picture omitted ]
<RETURN>
The <RETURN> key signals the computer to look at the information that
you typed and enters that information into memory.
<SHIFT>
The <SHIFT> key works like that on a standard typewriter. Many keys are
capable of displaying two letters or symbols and two graphic characters.
In the "upper/lower case" mode the <SHIFT> key gives you standard upper
case characters. In the "upper case/graphic" mode the <SHIFT> key will
display the graphic character on the right hand side of the front part of
the key.
In the case of special YELLOW function keys, the <SHIFT> key will give
you the function marked on the front of the key.
EDITING
<CRSR>
There are two keys marked <CRSR> (CuRSoR), one with up and down arrows,
the other with left and right arrows. You can use these keys to move the
cursor up and down or left and right. In the unshifted mode, the <CRSR>
keys will let you move the cursor down and to the right. Using the
<SHIFT> key and <CRSR> keys allows the cursor to be moved either up or to
the left. The cursor keys have a special repeat feature that keeps the
cursor moving until you release the key.
<INST/DEL>
If you hit the <INST/DEL> key, the cursor will move back a space,
erasing (DELeting) the previous character you typed. If you're in the
middle of a line, the character to the left is deleted and the characters
to the right automatically move together to close up the space.
A <SHIFT>ed <INST/DEL> allows you to INSerT information on a line. For
example, if you noticed a typing mistake in the beginning of a line --
perhaps you left out part of the name -- you could use the <CRSR> key to
move back to the error and then hit <INST/DEL> to insert a space. Then
just type in the missing later.
<CLR/HOME>
<RESTORE>
FUNCTION KEYS
The four function keys on the right side of the keyboard can be
"programmed" to handle a variety of functions. They can be defined in
many ways to handle repetitive tasks.
[ Picture omitted ]
<CTRL>
The <CTRL> key, which stands for ConTRoL, allows you to set colors,
and perform other specialized functions. You hold the <CTRL> key down
while depressing another designated key to get a control function. You
had an opportunity to try the <CTRL> key when you changed text colors to
create different color bars during the setup procedure.
<RUN/STOP>
Now that you've had a chance to look over the keyboard, let's explore
some of the Commodore 64's many capabilities.
If you still have the color bars on the screen from adjusting your TV
set, hold <SHIFT> and <CLR/HOME>. The screen should clear and the cursor
will be positioned in the "home" spot (upper left-hand corner of the
screen).
Now, simultaneously hold <C=> and the <7> key. This sets the text color
back to light blue. There is one more step needed to get everything back
to normal. Hold <CTRL> and <0> (Zero not Oh!). This sets the display mode
back to normal. If you remember, we turned REVERSE type on with the
<CTRL><9> to create the color bars (the color bars were actually reversed
spaces). If we were in the normal text mode during the color test, the
cursor would have moved, but just left blank spaces.
TIP:
Now that you've done things the hard way, there is a simple way to
reset the machine to the normal display. First press the <RUN/STOP> key
and then press the <RESTORE> key. <RUN/STOP> must always be held down in
order to use the <RESTORE> key function.
This will clear the screen and return everything to normal. If there is
a program in the computer, it will be left untouched. This is a good
sequence to remember, especially if you do a lot of programming.
If you wish to reset the machine as if it were turned off and then
switched on again, type, SYS 64759 and press <RETURN>. Be careful using
this command! It will wipe out any program or information that is
currently in the computer.
3. DISK: Using your disk drive, carefully insert the preprogrammed disk
so that the label on the disk is facing up and is closest to you. Look
for a little notch on the disk (it might be covered with a little piece
of tape). If you're inserting the disk properly the notch will be on the
left side. Once the disk is inside close the protective gate by pushing
down on the lever. Now type LOAD "PROGRAM NAME",8 and hit the <RETURN>
key. The disk will make noise and your screen will say:
When the READY comes on and the _ is on, just type RUN, and your
prepackaged software is ready to use.
Loading a program back from tape or disk is just as simple. For tape,
rewind the tape back to the beginning and type:
If you don't remember the program name, just type LOAD and the first
program on the tape will be loaded into memory.
After you press <RETURN> the computer will respond with:
After you depress the play key, the screen will blank, turning the
border color of the screen as the computer searches for the program.
When the program is found, the screen will display:
To actually load the program, depress the <C=> key. To abandon the
loading procedure, hit <RUN/STOP>. If you hit the Commodore key, the
screen will again turn the border color while the program is loaded.
After the loading procedure is completed, the screen will return to the
normal state and the READY prompt will reappear.
The 8 is the code for the disk, so you're just letting the computer
know that you want the program loaded from the disk.
After you hit <RETURN> the disk will start whirring and the display
shows:
NOTE:
When you load a new program into the computer's memory, any
instructions that were in the computer previously will be erased. Make
sure you save a program you're working on before loading a new one.
Once a program has been loaded, you can RUN it, LIST, or make changes and
re-save the new version.
Press both the record and play keys on the datassette. The screen will
blank, turning the color of the border.
After the program is saved on tape, the READY prompt will reappear,
indicating that you can start working on another program, or just turn
off the computer for a while.
SAVING PROGRAMS ON DISK
The 8 is the code for the disk, so you're just letting the computer
know you want the program saved to disk.
After you press <RETURN> the disk will start to turn and the computer
will respond with:
PRINT "COMMODORE 64" <----- Type this line and hit <RETURN>
COMMODORE 64 <------ Computer typed
READY.
_
If you make a typing mistake, use the <INST/DEL> key to erase the
character immediately to the left of the cursor. You can delete as many
characters as necessary.
Let's see what went on in the example above. First, you instructed
(commanded) the computer to PRINT whatever was inside the quote marks. By
hitting <RETURN> you told the computer to do what you instructed and
COMMODORE 64 was printed on the screen.
When you use the PRINT statement in this form, whatever is enclosed in
quotes is printed exactly as you typed it.
If the computer responded with:
?SYNTAX ERROR
ask yourself if you made a mistake in typing, or forgot the quote marks.
The computer is precise and expects instructions to be given in a
specific form.
But don't get worried; just remember to enter things as we present them
in the examples and you'll get along great with the Commodore 64.
Remember, you can't hurt the computer by typing on it, and the best way
to learn BASIC is to try different things and see what happens.
PRINT is one of the most useful and powerful commands in the BASIC
language. With it, you can display just about anything you wish,
including graphics and results of computations.
For example, try the following. Clear the screen by holding down the
<SHIFT> key and <CLR/HOME> key and type (be sure to use the '1' key for
one, not a letter 'I'):
PRINT 12 + 12 <----- Type this line and hit <RETURN>
24 <------ Computer printed the answer
READY.
_
ADDITION
The plus sign (+) signals addition: we instructed the computer to print
the result of 12 added to 12. Other arithmetic operations take a similar
form to addition. Remember to always hit <RETURN> after typing PRINT and
the calculation.
SUBTRACTION
MULTIPLICATION
DIVISION
Division uses the familiar "/". For example, to divide 144 by 12, type:
EXPONENTIATION
PRINT 12 * 12 * 12 * 12 * 12
248832
TIP:
BASIC has number of shortcut ways of doing things. One such way is
abbreviating BASIC commands (or keywords). A '?' can be used in place of
PRINT, for example. As we go on you'll be presented with many commands;
Appendix D shows the abbreviations for each and what will be displayed on
the screen when you type the abbreviated form.
Up to this point we've just used small numbers and simple examples.
However, the Commodore 64 is capable of more complex calculations.
You could, for example, add a number of large figures together. Try
this, but don't use any commas, or you'll get an error:
If you took the time to add this up by hand, you would get a different
result.
What's going on here? Even though the computer has a lot of power,
there's a limit to the numbers it can handle. The Commodore 64 can work
with numbers containing 10 digits. However when a number is printed, only
nine digits are displayed.
So in our example, the result was "rounded" to fit in the proper range.
The Commodore 64 rounds up when the next digit is five or more; it rounds
down when the next digit is four or less.
Numbers between 0.01 and 999,999,999 are printed using standard
notation. Numbers outside this range are printed using scientific
notation.
Scientific notation is just a process of expressing a very large or
small number as a power of 10.
If you type:
? 123000000000000000
1.23E+17
This is the same as 1.23 * 10^17 and is used just to keep things tidy.
There is a limit to the numbers the computer can handle, even in
scientific notation. The limits are:
Largest: +/- 1.70141183E+38
Smallest (different from zero): +/- 2.93873588-39
2.5. Precedence
20 + 8 / 2
you can't tell whether the answer should be 24 or 14 until you know in
which order to perform the calculations. If you add 20 to 8 divided by 2
(or 4), then the result is 24. But, if you add 20 plus 8 and then divide
by 2 the answer is 14. Try the example and see what result you get.
The reason you got 24 is because the Commodore 64 performs calculations
left to right according to the following:
Follow along according to the order of precedence, and you will see
that it the above example the division was performed first and then the
addition to get a result of 24.
Make up some problems of your own and see if you can follow along and
predict the results according to the rules set down above.
There's also an easy way to alter the precedence process by using
parentheses to set off which operations you want performed first.
For example, if you want to divide 35 by 5-plus-2 you type:
? 35 / 5 + 2
9
you will get 35 divided by 5 with 2 added to the answer, which is not
what you intended at all. To get what you really wanted, try this:
? 35 / (5 + 2)
5
? (12 + 9) * (6 + 1)
147
Even though this might seem a bit redundant, what we've done is simply
use both types of print statements together. The first part prints
"5 * 9 =" exactly as it was typed. The second part does the actual work
and prints the result, with the semicolon separating the message part of
the statement from the actual calculation.
You can separate the parts of a mixed PRINT statement with punctuation
for various formats. Try a comma in place of the semicolon and see what
happens.
For the curious, the semicolon causes the next part of the statement to
be printed immediately after the previous part, without any spaces. The
comma does something different. Even though it is an acceptable
separator, it spaces things out more. If you type:
the numbers will be printed across the screen and down on to the next
line.
The Commodore 64's display is organized into 4 areas of 10 columns
each. The comma tabs each result into the next available area. Since we
asked for more information to be printed than would fit on one line,
(we tried to fit five 10-column areas on one line) the last item was
moved down to the next line.
The basic difference between the comma and semicolon in formatting
PRINT statements can be used our advantage when creating more complex
displays: it allow us to create some sophisticated results very easily.
Clear the screen by holding down the <SHIFT> key, and then depressing the
<CLR/HOME> key.
Type NEW and press <RETURN>. (This just clears out any numbers that might
have been left in the computer from your experimenting.)
Now type the following exactly as shown (remember to hit <RETURN> after
each line)
10 ? "COMMODORE 64"
20 GOTO 10
Now, type RUN and hit <RETURN> -- watch what happens. Your screen will
come alive with COMMODORE 64. After you've finished watching the display,
hit <RUN/STOP> to stop the program.
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
BREAK IN 10
READY
In our example, the program prints the message in line 10, goes to the
next line (20), which instructs it to go back to line 10 and print the
message over again. Then the cycle repeats. Since we didn't give the
computer a way out of this loop, the program will cycle endlessly, until
we physically stop it with the <RUN/STOP> key.
Once you've stopped the program, type: LIST. Your program will be
displayed, intact, because it's still in the computer's memory. Notice,
too, that the computer converted the '?' into PRINT for you. The program
can now be changed, saved, or run again.
Another important difference between typing something in the immediate
mode and writing a program is that once you execute and clear the screen
of an immediate statement, it's lost. However, you can always get a
program back by just typing LIST.
By the way, when it comes to abbreviations don't forget that the
computer may run out of space on a line if you use too many.
1. You can retype a line anytime, and the computer will automatically
substitute the new line for the old one.
2. An unwanted line can be erased by simply typing the line number and
<RETURN>.
3. You can also easily edit an existing line, using the cursor keys and
editing keys.
10 PRINT "COMMODORE",
Don't forget to move the cursor past line 20 before you RUN the program.
3.3. Variables
10 X% = 15
20 X = 23.5
30 X$ = "THE SUM OF X% + X ="
X% 15
X 23.5
X$ THE SUM OF X% + X =
A%
X%
A1%
NM%
The '$' following the variable name indicates the variable will
represent a text string. The following are examples of string variables:
A$
X$
MI$
Floating point variables follow the same format, with the type
indicator:
A1
X
Y
MI
NEW
10 X% = 15
20 X = 23.5
30 X$ = "THE SUM OF X% + X ="
40 PRINT "X% = "; X%, "X = "; X
50 PRINT X$; X% + X
If you did everything as shown, you should get the following result
printed on the screen.
RUN
X% = 15 X = 23.5
THE SUM OF X% + X = 38.5
READY
We've put together all the tricks learned so far to format the display
as you see it and print the sum of the two variables.
In lines 10 and 20 we assigned an integer value to X% and assigned a
floating point value to X. This puts the number associated with the
variable in its box. In line 30, we assigned a text string to X$. Line 40
combines the two types of PRINT statements to print a message and the
actual value of X% and X. Line 50 prints the text string assigned to X$
and the sum of X% and X.
Note that even though X is used as part of each variable name, the
identifiers '%' and '$' make X%, X, and X$ unique, thus representing
three distinct variables.
But variables are much more powerful. If you change their value, the
new value replaces the original value in the same box. This allows you to
write a statement like:
X = X + 1
This would never be accepted in normal algebra, but is one of the most
used concepts in programming. It means: take the current value of X, add
one to it and place the new sum into the box representing X.
NEW
10 CT = 0
20 ? "COMMODORE 64"
30 CT = CT + 1
40 IF CT < 5 THEN 20
50 END
RUN
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
What we've done is introduce two new BASIC commands, and provided some
control over our runaway little print program introduced at the start of
this chapter.
IF ... THEN adds some logic to the program. If says IF a condition
holds true THEN do something. IF the condition no longer holds true, THEN
do the next line in the program.
A number of conditions can be set up in using an IF ... THEN statement:
SYMBOL MEANING
< Less Than
> Greater Than
= Equal To
<> Not Equal To
>= Greater Than or Equal To
<= Less Than or Equal To
10 CT = 0
+--> 20 ? "COMMODORE 64"
| 30 CT = CT + 1
+-<- 40 IF CT < 5 THEN 20
|
!
50 END
In the sample program, we've set up a "loop" that has some constrains
placed on it by saying: IF a value is less than some number THEN do
something.
Line 10 sets CT (CounT) equal to 0. Line 20 prints our message. Line 30
adds one to the variable CT. This line counts how many times we do the
loop. Each time the loop is executed, CT goes up by one.
Line 40 is our control line. If CT is less than 5, meaning we've
executed the loop less than 5 times, the program goes back to line 20 and
prints again. When CT becomes equal to 5 -- indicating 5 COMMODORE 64's
were printed -- the program goes to line 50, which signals to END the
program.
Try program and see what we mean. By changing the CT limit in line 40
you can have any number of lines printed.
IF ... THEN has a multitude of other uses, which we'll see in future
examples.
NEW
10 FOR CT = 1 TO 5
20 ? "COMMODORE 64"
30 NEXT CT
RUN
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
COMMODORE 64
As you can see, the program has become much smaller and more direct.
CT starts at 1 in line 10. Then, line 20 does some printing. In line 30
CT is incremented by 1. The NEXT statement in line 30 automatically sends
the program back to line 10 where the FOR part of the FOR ... NEXT
statement is located. This process will continue until CT reaches the
limit you entered.
The variable used in a FOR ... NEXT loop can be incremented by smaller
amounts than 1, if needed.
Try this:
NEW
10 FOR NB = 1 TO 10 STEP .5
20 PRINT NB,
30 NEXT NB
RUN
1 1.5 2 2.5
3 3.5 4 4.5
5 5.5 6 6.5
7 7.5 8 8.5
9 9.5 10
If you enter and run this program, you'll see the numbers from 1 to 10,
by .5, printed across the display.
All we're doing here is printing the values that NB assumes as it goes
through the loop.
You can even specify whether the variable is increasing or decreasing.
Substitute the following for line 10:
4.1. Introduction
The next few chapters have been written for people who have become
relatively familiar with the BASIC programming language and the concepts
necessary to write more advanced programs.
For those of you who are just staring to learn how to program, you may
find some of the information a bit too technical to understand
completely. But take heart ... because for these two fun chapters, SPRITE
GRAPHICS and CREATING SOUND, we've set up some simple examples that are
written for the new user. The examples will give you a good idea of how
to use the sophisticated sound and graphics capabilities available on
your COMMODORE 64.
If you decide that you want to learn more about writing programs in
BASIC, we've put a bibliography (Appendix N) in the back of this manual.
If you are already familiar with BASIC programming, these chapters will
help you get started with advanced BASIC programming techniques. More
detailed information can be found in the COMMODORE 64 PROGRAMMER'S
REFERENCE MANUAL, available through your local Commodore dealer.
NEW
NOTES: The ':' in lines 25 and 40 indicates new command. The spaces in
lines 40 and 90 are intentional.
TIP: All words in this text will be completed on one line. However, as
long as you don't hit <RETURN> your 64 will automatically move to the
next line even in the middle of a word.
The program will display a bouncing ball moving from left to right, and
back again, across the screen.
If we look at the program closely, you can see how this feat was
accomplished.
Line 10 is a REMark that just tells what the program does; it has no
effect on the program itself. Line 20 clears the screen of any
information.
Line 25 PRINTs 10 cursor-down commands. This just positions the ball in
the middle of the screen. If line 25 was eliminated the ball would move
across the top line of the screen.
Line 30 sets up a loop for moving the ball the 40 columns from the left
to right.
Line 40 does a lot of work. It first prints a space to erase the
previous ball positions, then it prints the ball, and finally it performs
a cursor-left to get everything ready to erase the current ball position
again.
The loop set up in lines 50 and 60 slows the ball down a bit by
delaying the program. Without it, the ball would move too fast to see.
Line 70 completes the loop that prints balls on the screen, set up in
line 30. Each time the loop is executed, the ball moves another space to
the right. As you notice from the illustration, we have set up a loop
within a loop.
This is perfectly acceptable. The only time you get in trouble is when
the loops cross over each other. It's helpful in writing programs to
check yourself as illustrated here to make sure the logic of a loop is
correct.
To see what would happen if you cross a loop, reverse the statements in
lines 60 and 70. You will get an error because the computer gets confused
and cannot figure out what's going on.
Lines 80 through 120 just reverse the steps in the first part of the
program, and move the ball from right to left. Line 90 is slightly
different from line 40 because the ball is moving in the opposite
direction (we have to erase the ball to the right and move to the left).
And when that's all done the program goes back to line 20 to start the
whole process over again. Pretty neat! To stop the program hold down
<RESTORE> and hit <RUN/STOP>.
For a variation on the program, edit line 40 to read:
40 PRINT"O"; To make the O, hold SHIFT key down and hit the letter "Q"
Run the program and see what happens now. Because we left out the
cursor control, each ball remains on the screen until erased by the ball
moving right to left in the second part of the program.
4.3. INPUT
10 INPUT A$
20 PRINT "YOU TYPED: ";A$
30 PRINT
40 GOTO 10
RUN
? COMMODORE 64 <--------------- You typed
YOU TYPED: COMMODORE 64 <----- Computer responded
What happens when you run this simple program. A question mark will
appear, indicating that the computer is waiting for you to type
something. Enter any character, or group of characters, from the keyboard
and hit <RETURN>. The computer will then respond with "YOU TYPED:"
followed by the information you entered.
This may seem very elementary, but imagine what you can have the
computer do with any information you enter.
You can INPUT either numeric or string variables, and even have the
INPUT statement prompt the user with a message. The format of INPUT is:
Or, just:
INPUT VARIABLE
NOTE: To get out of this program hold down the <RUN/STOP> and <RESTORE>
keys.
NEW
If you entered and run this program, you'll see INPUT in action.
Line 10 uses the input statement to not only gather information, but
also print our prompt. Also notice that we can ask for either a number or
string (by using a numeric or string variable).
Lines 20, 30, and 40 do some checks on what is typed in. In line 20, if
nothing is entered (just <RETURN> is hit), then the program goes back to
line 10 and requests the input again. In line 30, if F is typed, you know
the user wants to convert a temperature in degrees Fahrenheit to Celsius,
so the program branches to the part that does that conversion.
Line 40 does one more check. We know there are only two valid choices
the user can enter. To get to line 40, the user must have typed some
character other than F. Now, a check is made to see if that character is
a C; if not, the program requests input again.
This may seem like a lot of detail, but it is good programming
practice. A user not familiar with the program can become very frustrated
if it does something strange because a mistake was made entering
information.
Once we determine what type of conversion to perform, the program does
the calculation and prints out the temperature entered and the converted
temperature.
The calculation is just straight math, using the established formula
for temperature conversion. After the calculation is finished and answer
printed, the program loops back and starts over.
After running, the screen might look like this:
After running the program, make sure to save it on disk or tape. This
program, as well as others presented throughout the manual, can form the
base of your program library.
4.4. GET
GET allows you to input one character at a time from the keyboard
without hitting <RETURN>. This really speeds entering data in many
applications. Whatever key is hit is assigned variable to the variable
you specify with GET.
The following routine illustrates how GET works:
NEW
1 PRINT "{CLR/HOME}"
10 GET A$: IF A$ = "" THEN 10
20 PRINT A$; ^
30 GOTO 10 |-------------- No SPACE here
If you RUN the program, the screen will clear and each time you hit a
key, line 20 will print it on the display, and then GET another
character. It is important to note that the character entered will not be
displayed unless you specifically PRINT it to the screen, as we've done
here.
The second statement on line 10 is also important. GET continually
works, even if no key is pressed (unlike INPUT that waits for a
response), so the second part of this line continually checks the
keyboard until a key is hit.
See what happens if the second part of line 10 is eliminated.
To stop this program you can hit the <RUN/STOP> and <RESTORE> keys.
The first part of the temperature conversion program could easily be
rewritten to use GET. LOAD the temperature conversion program, and modify
lines 10,20 and 40 as shown:
NEW
10 FOR X = 1 TO 10
20 PRINT RND(1), <------------ If you leave out the comma, your list
30 NEXT of numbers will appear as 1 column
After running the program, you will see a display like this:
.789280697 .664673958
.256373663 .0123442287
.682952381 3.90587279E-04
.402343724 .879300926
.158209063 .245596701
Your numbers don't match? Well, if they did we would all be in trouble,
as they should be completely random!
Try running the program a few more times to verify that the results are
always different. Even if the numbers don't follow any pattern, you
should start to notice that some things remain the same every time the
program is run.
First, the results are always between 0 and 1, but never equal to 0 or
1. This will certainly never do if we want to simulate the random toss of
dice, since we're looking for numbers between 1 and 6.
The other important feature to look for is that we are dealing with
real numbers (with decimal places). This could also be a problem since
whole (integer) numbers are often needed.
There are a number of simple ways to produce numbers from the RND
function in the range desired.
Replace line 20 with following and run the program again:
20 PRINT 6*RND(1),
RUN
3.60563664 4.53660853
5.47238963 8.40850227
3.19265054 4.39547668
3.16331095 5.50620749
9.32527884 4.17090293
That cured the problem of not having results larger than 1, but we
still have the decimal part of the result to deal with. Now, another
function can be called upon.
The INTeger function converts real numbers into integer values.
Once more, replace line 20 with the following and run the program to
see the effect of the change:
20 PRINT INT(6*RND(1)),
RUN
2 3 1 0
2 4 5 5
0 1
20 PRINT INT(6*RND(1))+1,
20 PRINT INT(25*RND(1))+1,
Since we've gone to some lengths to understand random numbers, why not
put this information to use? The following game not only illustrates a
good use of random numbers, but also introduces some additional
programming theory.
In running this program, a random number, NM, will be generated.
NEW
You can specify how large the number will be at the start of the
program. Then, it's up to you to guess what the number is.
A sample run follows along with an explanation.
PROGRAMMING TIPS:
The following program simulates the throw of two dice. You can enjoy it
as it stands, or use it as part of a larger game.
From what you've learned about random numbers and BASIC, see if you can
follow what is going on.
10 REM MAZE
20 PRINT "{CLR/HOME}"
30 PRINT CHR$(205.5+RND(1));
40 GOTO 20
As you may have expected, line 20 is the key here. Another function,
CHR$ (Character String), gives you a character, based on a standard code
number from 0 to 255. Every character the Commodore 64 can print is
encoded this way (see Appendix F).
To quickly find out the code for any character, just type:
PRINT ASC("X")
PRINT CHR$(X)
you will see the two right side graphic characters on the M and N keys.
These are two characters that the program is using for the maze.
By using the formula 205.5 + RND(1) the computer will pick a random
number between 205.5 and 206.5. There is a fifty-fifty chance of the
number being above or below 206. CHR$ ignores any fractional values, so
half the time the character with code 205 is printed and the remaining
time code 206 is displayed.
If you'd like to experiment with this program, try changing 205.5 by
adding or subtracting a couple tenths from it. This will give either
character a greater chance of being selected.
1 2 3 4 5 6 7 8
Black White Red Cyan Purple Green Blue Yellow
If you hold down the <C=> key along with the appropriate number key,
these additional eight colors can be used:
1 2 3 4 5 6 7 8
Orange Brown Lt.Red Gray 1 Gray 2 Lt.Green Lt.Blue Gray 3
Type NEW, and experiment with the following. Hold down the <CTRL> key
and at the same time hit the <1> key. Next, hit the <R> key without
holding down the <CTRL> key. Now, while again depressing the <CTRL> key
at the same time hit the <2> key. Release the <CTRL> key and hit the <A>
key. Move through the numbers, alternating with the letters, and type out
the word RAINBOW as follows:
RUN
RAINBOW
Even though the PRINT statement may look a bit strange on the screen,
when you RUN the program, only the text will be displayed. And it will
automatically change colors according to the color controls you placed in
the print statement.
Try a few examples of your own, mixing any number of colors within a
single PRINT statement. Remember, too, you can use the second set of text
colors by using the Commodore key and the number keys.
TIP: You will notice after running a program with color or mode (reverse)
changes, that the "READY." prompt and any additional text you type is the
same as the last color or mode change. To get back to the normal display,
remember to depress: <RUN/STOP> and <RESTORE>.
NEW
10 PRINT CHR$(147) : REM {CLR/HOME}
20 PRINT CHR$(30); "CHR$(30) CHANGES ME TO?"
RUN
CHR$(30) CHANGES ME TO?
The text should now be green. In many cases, using the CHR$ function
will be much easier, especially if you want to experiment with changing
colors. The following program is a different way to get a rainbow of
colors. Since there are a number of lines that are similar (40-110) use
editing keys to save a lot of typing. See the notes after the listing to
refresh your memory on the editing procedures.
NEW
Type lines 1 through 40 normally. Your display should look like this:
EDITING NOTES
Use the <CRSR UP> key to position the cursor on line 40. Then type 5
over the 4 of 40. Next, use the <CRSR RIGHT> key to move over to the 5 in
the CHR$ parentheses. Hit <SHIFT> <INST/DEL> to open up a space and type
'28'. Now just hit <RETURN> with the cursor anywhere on the line.
The display should now look like this:
Don't worry. Line 40 is still there. LIST the program and see. Using
the same procedure, continue to modify the last line with a new line
number and CHR$ code until all the remaining lines have been entered.
See, we told you the editing keys would come in handy. As a final check,
list the entire program to make sure all the lines were entered properly
before you RUN it.
Here is a short explanation of what's going on.
You've probably figured out most of the color bar program by now except
for some strange new statement in line 30. But let's quickly see what the
whole program actually does. Line 5 prints the CHR$ code for CLR/HOME.
Line 10 turns reverse type on and prints 5 spaces, which turn out to be
a bar, since they're reversed. The first time through the program the bar
will be light blue, the normal text color.
Line 20 uses our workhorse, the random function to select a random
color between 1 and 8.
Line 30 contains a variation of the IF ... THEN statement which is
called ON ... GOTO. ON ... GOTO allows the program to choose from a list
of line numbers to go to. If the variable (in this case CL) has a value
of 1, the first line number is the one chosen (here 40). If the value is
2, the second number in the list is used, etc.
Lines 40-110 just convert our random key colors to the appropriate CHR$
code for that color and return the program to line 10 to PRINT a section
of the bar in that color. Then the whole process starts over again.
See if you can figure out how to produce 16 random numbers, expand ON
... GOTO to handle them, and add the remaining CHR$ codes to display the
remaining 8 colors.
No, we're not talking about jobbing the computer, but we will be able
to "look around" inside the machine and "stick" things in there.
Just as variables could be thought of as a representation of "boxes"
within the machine where you placed your information, you can also think
of some specially defined "boxes" within the computer that represent
specific memory locations.
The Commodore 64 looks at these memory locations to see what the
screen's background and border color should be, what characters are to be
displayed on the screen -- and where -- and a host of other tasks.
By placing, "POKEing", a different value into the proper memory
location, we can change colors, define and move objects, and even create
music.
These memory locations could be represented like this:
BORDER BACKGROUND
COLOR COLOR
Above we showed just four locations, two of which control the screen
and background colors. Try typing this:
POKE 53281,7 <RETURN>
+-----------------------------------------------------------------------+
| 0 BLACK 8 ORANGE |
| 1 WHITE 9 BROWN |
| 2 RED 10 Light RED |
| 3 CYAN 11 GRAY 1 |
| 4 PURPLE 12 GRAY 2 |
| 5 GREEN 13 Light GREEN |
| 6 BLUE 14 Light BLUE |
| 7 YELLOW 15 GRAY 3 |
+-----------------------------------------------------------------------+
Can you think of a way to display the various background and border
combinations? The following may be of some help:
NEW
10 FOR BA = 0 TO 15
20 FOR BO = 0 TO 15
30 POKE 53280, BO
40 POKE 53281, BA
50 FOR X = 1 TO 2000 : NEXT X
60 NEXT BO : NEXT BA
Two simple loops were set up to POKE various values to change the
background and border colors. The DELAY loop in line 50 just slows things
down a bit.
For the curious, try:
? PEEK(53280) AND 15
You should get a value of 15. This is the last value BORDER was given
and makes sense because both the background and border colors are GRAY
(value 15) after the program is run.
By entering AND 15 you eliminate all other values except 1-15, because
of the way color codes are stored in the computer. Normally you would
expect to find the same value that was last POKEd in the location. In
general, PEEK lets us examine a specific location and see what value is
presently there. Can you think of a one line addition to the program that
will display the value of BACK and BORDER as the program runs? How about
this:
COLUMN 1063
0 10 20 30 39 /
+------------------------------------------------------------/
1024 | | 0
1064 | |
1104 | |
1144 | |
1184 | |
1224 | |
1264 | |
1304 | |
1344 | |
1384 | |
1424 | | 10
1464 | |
1504 | | ROW
1544 | |
1584 | |
1624 | |
1664 | |
1704 | |
1744 | |
1784 | |
1824 | | 20
1864 | |
1904 | |
1944 | |
1984 | | 24
+------------------------------------------------------------\
\
2023
Now, let's say that you're controlling a ball bouncing on the screen.
The ball is in the middle of the screen, column 20, row 12. The formula
for calculation of the memory location on the screen is:
POINT = 1024 + X + 40 * Y
^ ^
| |__ Column
|___________ Row
POKE 1524, 81
POKE 55796, 1
^ ^
| |______ Color
|___________ Location
A ball appears in the middle of the screen! You have placed a character
directly into screen memory without using the PRINT statement. The ball
that appeared was white. However there is a way to change the color of an
object on the screen by altering another range of memory. Type:
POKE 55796, 2
^ ^
| |______ Color
|___________ Location
The ball's color changes to red. For every spot on the Commodore 64's
screen there are two memory locations, one for the character code, and
the other for the color code. The color memory map begins at location
55296 (top left-hand corner), and continues on for 1000 locations. The
same color codes, from 0-15, that we used to change border and background
colors can be used here to directly change character colors.
COLUMN 55335
0 10 20 30 39 /
+------------------------------------------------------------/
55296| | 0
55336| |
55376| |
55416| |
55456| |
55496| |
55536| |
55576| |
55616| |
55656| |
55696| | 10
55736| |
55776| | ROW
55816| |
55856| |
55896| |
55936| |
55976| |
56016| |
56056| |
56096| | 20
56136| |
56176| |
56216| |
56256| | 24
+------------------------------------------------------------\
56295
NEW
10 PRINT "{CLR/HOME}"
20 POKE 53280,7 : POKE 53281,13
30 X = 1 : Y = 1
40 DX = 1 : DY = 1
50 POKE 1024 + X + 40 * Y, 81
60 FOR T = 1 TO 10 : NEXT
70 POKE 1024 + X + 40 * Y, 32
80 X = X + DX
90 IF X <= 0 OR X >= 39 THEN DX = -DX
100 Y = Y + DY
110 IF Y <= 0 OR Y >= 24 THEN DY = -DY
120 GOTO 50
Line 10 clears the screen, and line 20 sets the background to light
green with a yellow border.
The X and Y variables in line 30 keep track of the current row and
column position of the ball. The DX and DY variables in line 40 are the
horizontal and vertical direction of the ball's movement. When a +1 is
added to the X value, the ball is moved to the right; when -1 is added,
the ball moves to the left. A +1 added to Y moves the ball down a row;
a -1 added to Y moves the ball up a row.
Line 50 puts the ball on the screen at the current cursor position.
Line 60 is the familiar delay loop, leaving the ball on the screen just
long enough to see it.
Line 70 erases the ball by putting a space (code 32) where the ball was
on the screen.
Line 80 adds the direction factor to X. Line 90 tests to see if the
ball has reached one of the side walls, reversing the direction if
there's a bounce. Line 100 and 110 do the same thing for the top and
bottom walls.
Line 120 sends the program back to display and moves the ball again.
By changing the code in line 50 from 81 to another character code, you
can change the ball to any other character. If you change DX and DY to 0
the ball will bounce straight instead of diagonally.
We can also add a little more intelligence. So far the only thing you
checked for is the X and Y values getting out of bounds for the screen.
Add the following lines to the program:
21 FOR L = 1 TO 10
25 POKE 1024 + INT(RND(1)*1000), 166 <------------------ Screen Code
27 NEXT L
85 IF PEEK(1024 + X + 40 * Y) = 166 THEN DX = -DX : GOTO 80
105 IF PEEK(1024 + X + 40 * Y) = 166 THEN DY = -DY : GOTO 100
6. SPRITE GRAPHICS
COLUMN
The next step is to convert the graphic design into data the computer
can use. Get a piece of notebook or graph paper and set up a sample grid
that is 21 spaces down and 24 spaces across. Across the top write 128,
64, 32, 16, 8, 4, 2, 1, three times (as shown) for each of the 24
squares. Number down the left side of the grid 1-21 for each row. Write
the word DATA at the end of each row. Now fill in the grid with any
design or use the balloon that we have. It's easiest to outline the shape
first and then go back and fill in the grid.
Now if you think of all the squares you filled in as "ON" then
substitute a 1 for each filled square. For the one's that aren't filled
in, they're "OFF" so put a zero.
Starting on the first row, you need to convert the dots into three
separate pieces of data the computer can read. Each set of 8 squares is
equal to one piece of data called a byte in our balloon. Working from the
left, the first 8 squares are blank, or 0, so the value for that series
of numbers is 0.
The middle series looks like this (again a 1 indicates a dot, 0 is a
space):
128 64 32 16 8 4 2 1
+-----+-----+-----+-----+-----+-----+-----+-----+
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
+-----+-----+-----+-----+-----+-----+-----+-----+
^ ^ ^ ^ ^ ^ ^ ^
| | | | | | | |
0 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = 127
The third series on the first row also contains blanks, so it, too,
equals zero. Thus, the data for the first line is:
DATA 0, 127, 0
The series that make up row two are calculated like this:
+-----+-----+-----+-----+-----+-----+-----+-----+
Series 1: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
+-----+-----+-----+-----+-----+-----+-----+-----+
1 = 1
+-----+-----+-----+-----+-----+-----+-----+-----+
Series 2: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
+-----+-----+-----+-----+-----+-----+-----+-----+
^ ^ ^ ^ ^ ^ ^ ^
| | | | | | | |
128 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = 255
+-----+-----+-----+-----+-----+-----+-----+-----+
Series 3: | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
+-----+-----+-----+-----+-----+-----+-----+-----+
^ ^
| |
128 + 64 = 192
In the same way, the three series that make up each remaining row would
be converted into their decimal value. Take the time to do the remainder
of the conversion in this example.
Now that you have the data for your object, how can it be put to use?
Type in the following program and see what happens.
[ PICTURE OMITTED ]
Register(s) Description
0 X coordinate of sprite 0
1 Y coordinate of sprite 0
2 - 15 Paired like 0 and 1 for sprites 1-7
16 Most Significant Bit -- X coordinate
21 Sprite appear: 1 = appear, 0 = disappear
29 Expand sprite in "X" Direction
23 Expand sprite in "Y" Direction
39-46 Sprite 0-7 color
Now let's outline the exact procedure to get things moving and finally
write a program.
There are only a few things necessary to actually create and move an
object.
There are only a few items in the program that might not be familiar
from the discussion so far.
In line 10,
V = 53248
sets V to the starting memory location of the video chip. In this way we
just increase V by the memory number to get the actual memory location.
The register numbers are the ones given on the sprite register map.
In line,
POKE V+21,4
SPRITES
instructs the computer to get the data for sprite 2 (location 2042) from
the 13th area of memory. You know from making your sprite that it takes
up 63 sections of memory. You may not have realized it, but those numbers
you put across the top of your grid equal what is known as 3 bytes of the
computer. In other words each collection of the following numbers, 128,
64, 32, 16, 8, 4, 2, equals 1 byte of computer memory. Therefore with the
21 rows of your grid times the 3 bytes of each row, each sprite takes up
63 bytes of memory.
This line handles the actual sprite collision. The 63 bytes of data
that represent the sprite you created are READ in through the loop and
POKEd into the 13th block of memory. This starts at location 832.
30 FOR X = 0 TO 200
40 POKE V+4, X <---- SPRITE 2'S X COORDINATE
50 POKE V+5, X <---- SPRITE 2'S Y COORDINATE
and RUN the program again. The balloon has expanded to twice the original
size! What we did was simple. By POKEing 4 (again to indicate sprite 2)
into memory sections 23 and 29, sprite 2 was expanded in the X and Y
direction.
It's important to note that the sprite will start in the upper left-
hand corner of the object. When expanding an object in either direction,
the starting point remains the same.
For some added excitement, make the following changes:
11 POKE V+21, 12
12 POKE 2042, 13 : POKE 2043, 13
30 FOR X = 1 TO 190
45 POKE V+6, X
55 POKE V+7, 190-X
In line 11 this time, another sprite (4) was made to appear by POKEing
28 into the appropriate "ON" location of the sprite memory section. Now
sprites 2-4 are on (00011100 = 28).
Line 12 indicates that sprite 4 will get its data from the same memory
area (13th 63 section area) as the other sprites by POKEing 2044,13.
In line 25, sprites 2 and 3 are expanded by POKEing 12 (Sprites 2 and 3
on) into the X and Y direction expanded memory locations (V+23 and V+29).
Line 48 moves sprite 3 along the X axis. Line 58 positions sprite 3
halfway down the screen, at location 100. Because this value does not
change, like it did before with X=0 to 200, sprite 3 just moves
horizontally.
Now that you've experimented with sprites, a few more words are in
order. First, you can change a sprite's color to any of the standard 16
color codes (0-15) that were used to change character color. These can be
found in Chapter 5 or in Appendix G.
For example, to change sprite 1 to light green, type: POKE V+40,13 (be
sure to set V = 53248).
You may have noticed in using the example sprite programs that the
object never moved to the right-hand edge of the screen. This was because
the screen is 320 dots wide and the X direction register can only hold a
value up to 255. How then can you get an object to move across the entire
screen?
There is a location on the memory map that has not been mentioned yet.
Location 16 (of the map) controls something called the Most Significant
Bit (MSB) of the sprite's X direction location. In effect, this allows
you to move the sprite to a horizontal spot between 256 and 320.
The MSB of X register works like this: after the sprite has been moved
to X location 255, place a value into memory location 16 representing the
sprite you want to move. For example, to get sprite 2 to move to
horizontal locations 256-320, POKE the value for sprite 2 (which is 4)
into memory location 16:
POKE V+16, 4
Now start from 0 again in the usual X direction register for sprite 2
(which is in location 4 of the map). Since you are only moving another 64
spaces, X locations would only range between 0 and 63 this time.
This whole concept is best illustrated with a version of the original
BALLOON SPRITE program:
10 V = 53248 : POKE V+21, 4 : POKE 2042, 13
20 FOR N = 0 TO 62 : READ Q : POKE 832+N, Q : NEXT
25 POKE V+5, 100
30 FOR X = 0 TO 255
40 POKE V+4, X
50 NEXT
60 POKE V+16, 4
70 FOR X = 0 TO 63
80 POKE V+4, X
90 NEXT
100 POKE V+16, 0
110 GOTO 30
200 DATA 0,127,0,1,255,192,3,255,224,3,231,224
210 DATA 7,217,240,7,223,240,7,217,240,3,231,224
220 DATA 3,255,224,3,255,224,2,255,160,1,127,64
230 DATA 1,62,64,0,156,128,0,156,128,0,73,0,0,73,0
240 DATA 0,62,0,0,62,0,0,62,0,0,28,0
Line 60 sets the most significant bit for sprite 2. Line 70 starts
moving the standard X direction location, moving sprite 2 the rest of way
across the screen.
Line 100 is important because it "TURNS OFF" the MSB so that the sprite
can start moving from the left edge of the screen again.
To define multiple sprites, you may need additional blocks for the
sprite data. You can use some of BASIC's RAM by moving BASIC. Before
typing or loading your program type:
Now, you can use blocks 32 through 41 (locations 2048 through 4095) to
store sprite data.
128 64 32 16 8 4 2 1
+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
+-------+-------+-------+-------+-------+-------+-------+-------+
and its value will be 0. All BITs "ON" is:
128 64 32 16 8 4 2 1
+-------+-------+-------+-------+-------+-------+-------+-------+
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
+-------+-------+-------+-------+-------+-------+-------+-------+
which is 128+64+32+16+8+4+2+1=255.
+-----------------------------------------------------------------------+
| Decimal Value |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 | |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 2^0 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 2^1 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 2^2 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 2^3 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 2^4 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 2^5 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 2^6 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
| 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 2^7 |
+-------+-------+-------+-------+-------+-------+-------+-------+-------+
Using combinations of all eight bits, you can obtain any decimal value
from 0 to 255. Do you start to see why when we POKEd character or color
values into memory locations the values had to be in the 0-255 range?
Each memory location can hold a byte of information.
Any possible combination of eight 0's and 1's will convert to a unique
decimal value between 0-255. If all places contain a 1 then the value of
the byte equals 255. All zeros equal a byte value zero; "00000011" equals
3, and so on. This will be the basis for creating data that represents
sprites and manipulating them. As just one example, if this byte grouping
represented part of a sprite (0 is a space, 1 is a colored area):
7 6 5 4 3 2 1 0
2 2 2 2 2 2 2 2
+-------+-------+-------+-------+-------+-------+-------+-------+
| 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
+-------+-------+-------+-------+-------+-------+-------+-------+
128 + 64 + 32 + 16 + 8 + 4 + 2 + 1 = 255
TIP: To save you the trouble of converting binary numbers into decimal
values -- we'll need to do that a lot -- the following program will do
the work for you. It's a good idea to enter and save the program for
future use.
This program takes your binary number, which was entered as a string,
and looks at each character of the string, from left to right (the MID$
function). The variable C indicates what character to work on as the
program goes through the loop.
The VAL function, in line 30, returns the actual value of the
character. Since we are dealing with numeric characters, the value is the
same as the character. For example, if the first character of A$ is 1
then the value would also be 1.
The final part of line 30 multiplies the value of the current character
by the proper power of 2. Since the first value is in the 2^7 place, in
the example, TL would first equal 1 times 128 or 128. If the bit is 0
then the value for that place would also be zero.
This process is repeated for all eight characters as TL keeps track of
the running total decimal value of the binary number.
7. CREATING SOUND
Most programmers use computer sound for two purposes: making music and
generating sound effects. Before getting into the "intricacies" of
programming sound, let's take a quick look at how a typical sound program
is structured ... and give you a short sound program you can experiment
with.
Before you start you have to choose a VOICE. There are 3 voices. Each
voice requires different sound setting numbers for Waveform, etc. You can
play 1, 2 or 3 voices together but our sample uses only VOICE NUMBER 1.
Type in this program line by line ... be sure to hit the <RETURN> key
after each line:
To hear the note you just created, type the word RUN and then hit the
<RETURN> key. To view the program type the word LIST and hit <RETURN>. To
change it, retype the lines you want to alter.
20 POKE 54277,3
30 POKE 54278,0 <--------------- Sets no sustain for banjo effect.
As you've just seen, you can make your COMMODORE 64 sound like
different musical instruments. Let's take a closer look at how each sound
setting works.
POKE 54296,0
You only have to set the volume ONCE at the beginning of your program,
since the same setting activates all three of the Commodore 64's VOICES.
(Changing the volume during a musical note or sound effect can produce
interesting results but is beyond the scope of this introduction.)
POKE 54276,17
where the first number (54276) represents the control setting for VOICE 1
and the second number (17) represents the start for a triangular
waveform. The settings for each VOICE and WAVEFORM combination are shown
in the table below.
Although the control registers are different for each voice the
waveform settings are the same for each type of waveform. To see how this
works, look at lines 85 and 90 in the musical scale program. In this
program, immediately after setting the frequency in line 80, we set the
CONTROL SETTING for VOICE 1 in line 85 by POKEing 54276,17. This turned
on the CONTROL for VOICE 1 and set it to a TRIANGLE WAVEFORM (17). In
line 70 we POKE 54276,16, stopping the note. Later, we changed the
waveform start setting from 17 to 33 to create a SAWTOOTH WAVEFORM and
this gave the scale a "harpsichord" effect. See how the CONTROL SETTING
and WAVEFORM interact? Setting the waveform is similar to setting the
volume, except each voice has its own stetting and instead of POKEing
volume levels we're defining waveforms. Next, we'll look at another
aspect of sound ... the ADSR feature.
Here, we're using VOICE 1 to create one note at a time ... with a
MEDIUM ATTACK RATE and ZERO DECAY. The key is line 30. POKEing the
ATTACK/DECAY setting with the number 64 activates a MEDIUM attack rate.
The result sounds like someone bouncing a ball in an oil drum. Now for
the fun part. Hit the <RUN/STOP> key to stop the program, then type the
word LIST and hit <RETURN>. Now type this line and hit <RETURN> (the new
line 30 automatically replaces the old line 30):
30 POKE 54277,190
Type word RUN and hit <RETURN> to see how it sounds. What we've done
here is combine several attack and decay settings. The settings are: HIGH
ATTACK (128) + LOW ATTACK (32) + LOWEST ATTACK (16) + HIGH DECAY (8) +
MEDIUM DECAY (4) + LOW DECAY (2) = 190. This effect sounds like a sound
an oboe or other "reedy" instrument might make. If you'd like to
experiment, try changing the waveform and attack/decay numbers in the
musical scale example to see how an "oboe" sounds. Thus ... you can see
that changing the attack/decay rates can be used to create different
types of sound effects.
4. SUSTAIN/RELEASE SETTING. -- Like Attack/Decay, the SUSTAIN/RELEASE
setting is activated by the ADSR/WAVEFORM CONTROL. SUSTAIN/RELEASE lets
you "extend" (SUSTAIN) a portion of a particular sound, like the "sustain
pedal" on a piano or organ which lets you prolong a note. Any note or
sound can be sustained at any one of 16 levels. The SUSTAIN/RELEASE
setting may be used with a FOR ... NEXT loop to determine how long the
note will be held at SUSTAIN volume before being released. The following
chart shows the numbers you have to POKE to reach different SUSTAIN/
RELEASE rates.
In line 30, we tell the computer to SUSTAIN the note at a HIGH SUSTAIN
level (128 from chart above) ... after which the tone is released in line
80. You can vary the duration of a note by changing the "count" in line
70. To see the effect of using the release function try changing line 30
to POKE 54278,89 (SUSTAIN = 80, RELEASE = 9).
As you can see, there are 2 settings for each voice, a HIGH FREQUENCY
setting and a LOW FREQUENCY setting. To play a musical note, you must
POKE a value into the HIGH FREQUENCY location and POKE another values
into the LOW FREQUENCY location. Using the settings in our VOICE/
FREQUENCY/NOTE VALUE table, here's the setting that plays a C note from
the 5th octave (VOICE 1):
The following programs may be added to almost any BASIC program. They
are included to give you some programming ideas and demonstrate the
Commodore 64's sound effect range.
Notice the programming shortcut we're using in line 10. We can
abbreviate those long cumbersome sound setting numbers by defining them
as easy-to-use letters (numeric variables). Line 10 simply means that
these easy to remember LETTERS can be used instead of those long numbers.
Here, V=Volume, W=Waveform, A=Attack/Decay, H=High Frequency (VOICE 1),
and L=Low Frequency (VOICE 1). We then use these letters instead of
numbers in our program ... making our program shorter, typing faster, and
the sound settings easier to remember and spot.
DOLL CRYING
10 READ X
20 PRINT "X IS NOW :"; X
30 GOTO 10
40 DATA 1, 34, 10.5, 16, 234.56
RUN
X IS NOW : 1
X IS NOW : 34
X IS NOW : 10.5
X IS NOW : 16
X IS NOW : 234.56
?OUT OF DATA ERROR IN 10
READY.
_
In line 10, the computer READs one value from the DATA statement and
assigns that value to X. Each time through the loop the next value in the
DATA statement is read and that value assigned to X, and PRINTed. A
pointer in the computer itself keeps track of which value is to be used
next:
Pointer
|
40 DATA 1, 34, 10.5, 16, 234.56
When all the values have been used, and the computer executed the loop
again, looking for another value, the OUT OF DATA ERROR was displayed
because there were no more values to READ.
It is important to follow the format of the DATA statement precisely:
You can, however, use a string variable in a READ statement and then
place string information in the DATA line. The following is acceptable:
NEW
10 FOR X = 1 TO 3
15 READ A$
20 PRINT "A$ IS NOW : "; A$
30 NEXT
40 DATA THIS, IS, FUN
RUN
A$ IS NOW : THIS
A$ IS NOW : IS
A$ IS NOW : FUN
READY.
Notice that this time, the READ statement was placed inside a FOR ...
NEXT loop. This loop was then executed to match the number of values in
the data statement.
In many cases you will change the number of values in the DATA
statement each time the program is run. A way to avoid counting the
number of values and still avoid an OUT OF DATA ERROR is to place a
"FLAG" as the last value in the DATA line. This would be a value that
your data would never equal, such as a negative number or a very large or
small number. When that value is READ the program will branch to the next
part.
There is a way to reuse the same DATA later in the program by
RESTOREing the data pointer to the beginning of the data list. Add line
50 to the previous program:
50 GOTO 10
You will still get the OUT OF DATA ERROR because as the program
branches back to line 10 to reread the data, the data pointer indicates
all the data has been used. Now, add:
45 RESTORE
and RUN the program again. The data pointer has been RESTOREd and the
data can be READ continuously.
8.2. Averages
NEW
5 T = 0 : CT = 0
10 READ X
20 IF X = -1 THEN 50 : REM CHECK FOR FLAG
25 CT = CT + 1
30 T= T + X : REM UPDATE TOTAL
40 GOTO 10
50 PRINT "THERE WERE"; CT ;"VALUES READ"
60 PRINT "TOTAL ="; T
70 PRINT "AVERAGE ="; T/CT
80 DATA 75, 80, 62, 91, 87, 93, 78, -1
RUN
THERE WERE 7 VALUES READ
TOTAL = 566
AVERAGE = 80.8571429
Line 5 sets CT, the CounTer, and T, Total, equal to zero. Line 10 READs
a value and assigns the value to X. Line 20 checks to see if the value is
our flag (here a -1). If the value READ is part of the valid DATA, CT is
incremented by 1 and X is added to the total.
When the flag is READ, the program branches to line 50 which PRINTs the
number of values read. Line 60 PRINTs the total, and line 70 divides the
total by the number of values to get the average.
By using a flag at the end of the DATA, you can place any number of
values in DATA statements -- which may stretch over several lines --
without worrying about counting the number of values entered.
Another variation of the READ statement involves assigning information
from the same DATA line to different variables. This information can even
be a mixture of string data and numeric values. You can do all this in
the following program that will READ a name, some scores -- say bowling
-- and print the name, scores, and the average score:
NEW
10 READ N$, A, B, C
20 PRINT N$;"'S SCORES WERE :"; A ;" "; B ;" "; C
30 PRINT "AND THE AVERAGE IS :";(A+B+C)/3
40 PRINT : GOTO 10
50 DATA MIKE, 190, 185, 165, DICK, 225, 245, 190
60 DATA JOHN, 155, 185, 205, PAUL, 160, 179, 187
RUN
MIKE'S SCORES WERE : 190 185 165
AND THE AVERAGE IS : 180
In running the program, the DATA statements were set up in the same
order that READ statement expected the information: a name (a string),
then three values. In other words N$ the first time through gets the data
"MIKE", A in the READ corresponds to 190 in the DATA statement, "B" to
185 and "C" to 165. The process is then repeated in that order for the
remainder of the information. (DICK and his scores, JOHN and his scores,
and PAUL and his scores.)
In the past we've used only simple BASIC variables, such as A, A$, and
NU to present values. These were a single letter followed by a letter or
single digit. In any of the programs that you would write, it is doubtful
that we would have a need for more variable names than possible with all
the combinations of letters or numbers available. But you are limited in
the way variables are used with programs.
Now let's introduce the concept of subscripted variables.
A(1)
^ ^
| |___ Subscript
|_____ Variable
+------------------------+
A(0) | |
+------------------------+
A(1) | |
+------------------------+
A(2) | |
+------------------------+
A(3) | |
+------------------------+
A(4) | |
+------------------------+
If you wrote:
+------------------------+
A(0) | 25 |
+------------------------+
A(1) | |
+------------------------+
A(2) | |
+------------------------+
A(3) | 55 |
+------------------------+
A(4) | -45.3 |
+------------------------+
5 PRINT CHR$(147)
10 INPUT "HOW MANY NUMBERS :"; X
20 FOR A = 1 TO X
30 PRINT "ENTER VALUE #"; A ;: INPUT B(A)
40 NEXT
50 SU = 0
60 FOR A = 1 TO X
70 SU = SU + B(A)
80 NEXT
90 PRINT : PRINT "AVERAGE ="; SU/X
RUN
HOW MANY NUMBERS :? 5
ENTER VALUE # 1 ? 125
ENTER VALUE # 2 ? 167
ENTER VALUE # 3 ? 189
ENTER VALUE # 4 ? 167
ENTER VALUE # 5 ? 158
AVERAGE = 161.2
There might have been an easier way to accomplish what we did in this
program, but it illustrates how subscripted variables work. Line 10 asks
for how many numbers will be entered. This variable, X, acts as the
counter for the loop within which values are entered and assigned to the
subscripted variable, B.
Each time through the INPUT loop, A is increased by 1 and so the next
value entered is assigned to the next element in the array A. For
example, the first time through the loop A = 1, so the first value
entered is assigned to B(1). The next time through, A = 2; the next value
is assigned to B(2), and so on until all the values have been entered.
But now a big difference comes into play. Once all the values have been
entered, they are stored in the array, ready to be put to work in a
variety of ways. Before, you kept a running total each time through the
INPUT or READ loop, but never could get back the individual pieces of
data without re-reading the information.
In line 50 through 80, another loop has been designed to add up the
various elements of the array and then display the average. This separate
part of the program shows that all of the values are stored and can be
accessed as needed.
To prove that all of the individual values are actually stored
separately in an array, type the following immediately after running the
previous program:
The display will show your actual values as the contents of the array
are PRINTed.
8.4. Dimension
If you tried to enter more than 10 numbers in the previous example, you
got a BAD SUBSCRIPT ERROR. Arrays of up to eleven elements (subscripts 0
to 10 for a one-dimensional array) may used where needed, just as simple
variables can be used anywhere within a program. Arrays of more than
eleven elements need to be "declared" in the dimension statement.
Add this line to the program:
5 DIM B(100)
This lets the computer know that you will have a maximum of 100
elements in the array.
The dimension statement may also be used with a variable, so the
following line could replace line 5 (don't forget to eliminate line 5):
15 DIM B(X)
This would dimension the array with the exact number of values that
will be entered.
Be careful, though. Once dimensioned, an array cannot be redimensioned
in another part of the program. You can, however, have multiple arrays
within the program and dimension them all on the same line, like this:
The array F, for FACE, will be used to keep track of how many times a
particular face turns up. For example, every time a 2 is thrown, F(2) is
increased by one. By using the same element of the array to hold the
actual number on the face that is thrown, we've eliminated the need for
five other variables (one for each face) and numerous statements to check
and see what number is thrown.
Line 10 asks for how many rolls you want to simulate.
Line 20 establishes the loop to perform the random roll and increment
the proper element of the array by one for each toss.
After all of the required tosses are completed, line 60 PRINTs the
heading and line 70 PRINTs the number of times each face shows up.
A sample run might look like this:
A(4,6)
^ ^ ^
| | |
| Subscripts
|
Array Name
0 1 2 3 4 5 6
+-------+-------+-------+-------+-------+-------+-------+
0 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
1 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
2 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
3 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
4 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
A(3,4) = 255
^ ^
| |___ Column
|
Row
0 1 2 3 4 5 6
+-------+-------+-------+-------+-------+-------+-------+
0 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
1 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
2 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
3 | | | | | 255 | | |
+-------+-------+-------+-------+-------+-------+-------+
4 | | | | | | | |
+-------+-------+-------+-------+-------+-------+-------+
CLUB QUESTIONNAIRE
The array table for this problem could be represented like this:
RESPONSES
YES NO UNDECIDED
+----------------+----------------+----------------+
QUESTION 1 | | | |
+----------------+----------------+----------------+
QUESTION 2 | | | |
+----------------+----------------+----------------+
QUESTION 3 | | | |
+----------------+----------------+----------------+
QUESTION 4 | | | |
+----------------+----------------+----------------+
20 PRINT "{CLR/HOME}"
30 FOR R = 1 TO 4
40 PRINT "QUESTION # :"; R
50 PRINT "1-YES 2-NO 3-UNDECIDED"
60 PRINT "WHAT WAS THE RESPONSE : ";
61 GET C : IF C<1 OR C>3 THEN 61
65 PRINT C: PRINT
70 A(R,C) = A(R,C) + 1 : REM UPDATE ELEMENT
80 NEXT R
85 PRINT
90 PRINT "DO YOU WANT TO ENTER ANOTHER" : PRINT "RESPONSE (Y/N) ?";
100 GET A$ : IF A$ = "" THEN 100
110 IF A$ = "Y" THEN 20
120 IF A$ <> "N" THEN 100
130 PRINT "{CLR/HOME}" ; "THE TOTAL RESPONSES WERE:" : PRINT
140 PRINT SPC(18); "RESPONSE"
141 PRINT "QUESTION", "YES", "NO", "UNDECIDED"
142 PRINT "-------- -----------------------------"
150 FOR R = 1 TO 4
160 PRINT R, A(R,1), A(R,2), A(R,3)
170 NEXT R
RUN
QUESTION # : 1
1-YES 2-NO 3-UNDECIDED
WHAT WAS THE RESPONSE : 1
QUESTION # : 2
1-YES 2-NO 3-UNDECIDED
WHAT WAS THE RESPONSE : 1
And so on...
RESPONSE
QUESTION YES NO UNDECIDED
-------- -----------------------------
1 6 1 0
2 5 2 0
3 7 0 0
4 2 4 1
This program makes use of many of the programming techniques that have
been presented so far. Even if you don't have any need for the actual
program right now, see if you can follow how the program works.
The heart of this program is a 4 by 3 two-dimensional array, A(4,3).
The total responses for each possible answer to each question are held in
the appropriate element of the array. For the sake of simplicity, we
don't use the first rows and column (A(0,0) to A(0,4)). Remember, though,
that those elements are always present in any array you design.
In practice, if question one is answered YES, then A(1,1) is
incremented by one -- row 1 for question 1 and column 1 for a YES
response. The rest of the questions and answers follow the same pattern.
A NO response for question three would add one to element A(3,2), and so
on.
APPENDICES
INTRODUCTION
Now that you've become more intimately involved with your Commodore 64,
we want you to know that our customer support does not stop here. You may
not know it, but Commodore has been in business for over 23 years. In the
1970's we introduced the first self-contained personal computer (the
PET). We have since become the leading computer company in many countries
of the world. Our ability to design and manufacture our own computer
chips allows us to bring you new and better personal computers at prices
way below what you'd expect for this level of technical excellence.
Commodore is committed to supporting not only you, the end user, but
also the dealer you bought your computer from, magazines which publish
how-to articles showing you new applications or techniques, and ...
importantly ... software developers who produce programs on cartridge,
disk ond tape for use with your computer. We encourage you to establish
or join a Commodore "user club" where you can learn new techniques,
exchange ideas and share discoveries. We publish two separate magazines
which contain programming tips, information on new products and ideas for
computer applications. (See Appendix N).
In North America, Commodore provides a "Commodore Information Network"
on the CompuServe Information Service ... to access this network, all you
need is your Commodore 64 computer and our low cost VICMODEM telephone
interface cartridge (or other compatible modem).
The following APPENDICES contain charts, tables, and other information
which help you program your Commodore 64 faster and more efficiently.
They also include important information on the wide variety of Commodore
products you may be interested in, and a bibliography listing of over 20
books and magazines which can help you develop your programming skills
and keep you current on the latest information concerning your computer
and peripherals.
APPENDIX A
ACCESSORIES
o Datassette Recorder -- This low cost tape unit enables programs and
data to be stored on cassette tape, and played back at a later time.
The datassette can also be used to play pre-written programs.
SOFTWARE
Business Aids
Entertainment
o Your Commodore 64 allows you all the fun and excitement available on
MAX games because these two machines have completely compatible
cartridges.
Education
10 PRINT "WRITE-TO-TAPE-PROGRAM"
20 OPEN 1,1,1, "DATA FILE"
30 PRINT "TYPE DATA TO BE STORED OR TYPE STOP"
40 PRINT
50 INPUT "DATA"; A$
60 PRINT#1, A$
70 IF A$ <> "STOP" THEN 40
80 PRINT
90 PRINT "CLOSING FILE"
100 CLOSE 1
The first thing that you must do is OPEN a file (in this case DATA
FILE). Line 10 handles that.
The program prompts for the data you want to save on tape in line 50.
Line 60 writes what you typed -- held in A$ -- onto the tape. And the
process continues.
If you type STOP, line 100 CLOSEs the file.
To retrieve the information, rewind the tape, and try this:
10 PRINT "READ-TAPE-PROGRAM"
20 OPEN 1,1,0, "DATA FILE"
30 PRINT "FILE OPEN"
40 PRINT
50 INPUT#1, A$
60 PRINT A$
70 IF A$ <> "STOP" THEN 40
80 PRINT
90 PRINT "CLOSING FILE"
100 CLOSE 1
Again, this file "DATA FILE" first must be OPENed. In line 50 the
program INPUTs A$ from tape and also PRINTs A$ on the screen. Then the
whole process is repeated until "STOP" is found, which ENDs the
program.
A variation of GET-GET# can also be used to read the data back from
tape. Replace lines 50-70 in the program above with:
50 GET#1, A$
60 IF A$ <> "" THEN 50
70 PRINT A$, ASC(A$)
APPENDIX C
COMMODORE 64 BASIC
VARIABLES
The Commodore 64 uses three types of variables in BASIC. These are real
numeric, integer numeric, and string (alphanumeric) variables.
Variable names may consist of a single letter, a letter followed by a
number, or two letters.
An integer variable is specified by using the percent (%) sign after
the variable name. String variable have the dollar sign ($) after their
name.
Examples
Arrays are lists of variables with the same name, using extra numbers
to specify the element of the array. Arrays are defined using the DIM
statement, and may contain floating point, integer, or string variables.
The array variable name is followed by a set of parentheses ( ) enclosing
the number of variables in the list.
NOTE: There are three variable names which are reserved for use by the
Commodore 64, and may not be defined by you. These variables are: ST, TI
and TI$. ST is a status variable which relates to input/output
operations. The value of ST will change if there is a problem loading a
program from disk or tape.
TI and TI$ are variables which relate to the real-time clock built into
the Commodore 64. The variable TI is updated every 1/60th of a second. It
starts at 0 when the computer is turned on, and is reset only by changing
the value of TI$.
TI$ is a string which is constantly updated by the system. The first
two characters contain the number of hours , the 3rd and 4th characters
the number of minutes, and the 5th and 6th characters are the number of
seconds. This variable can be given any numeric value, and will be
updated from that point.
This clock is erased when the computer is turned off, and starts at
zero when the system is turned back on.
OPERATORS
+ Addition
- Subtraction
* Multiplication
/ Division
^ Raising to a power (exponentiation)
= Equal To
< Less Than
> Greater Than
<= Less Than or Equal To
>= Greater Than or Equal To
<> Not Equal To
AND
OR
NOT
COMMANDS
CONT (Continue)
LIST
LOAD
NEW
This command erases the entire program in memory, and also clears
out any variables that may have been used. Unless the program was
SAVEd, it is lost. BE CAREFUL WHEN YOU USE THIS COMMAND.
The NEW command can also be used as a BASIC program statement. When the
program reaches this line, the program is erased. This is useful if you
want to leave everything neat when the program is done.
RUN
SAVE
VERIFY
STATEMENTS
CLOSE
This command completes and closes any files used by OPEN statements.
The number following CLOSE is the file number to be closed.
CLR
This command will erase any variables in memory, but leaves the program
itself intact. This command is automatically executed when a RUN command
is given.
CMD
CMD sends the output which normally would go to the screen (i.e., PRINT
statements, LISTs, but not POKEs onto the screen) to another device
instead. This could be a printer, or a data file on tape or disk. This
device or file must be OPENed first. The CMD command must be followed by
a number or numeric variable referring to the file.
To send output back to the screen, CLOSE the file with CLOSE 1.
DATA
DEF FN
DIM
When you use more than 11 elements of an array, you must execute a DIM
statement for the array. Keep in mind that the whole array takes up room
in memory, so don't create an array much larger than you'll need.
To figure the number of variables created with DIM, multiply the total
number of elements in each dimension of the array.
END
This statement works with the NEXT statement to repeat a section of the
program a set number of times. The format is:
10 FOR L = 1 to 10 STEP .1
20 PRINT L
30 NEXT L
The end of the loop value may be followed by the word STEP and another
number or variable. In this case, the value following STEP is added each
time instead of 1. This allows you to count backwards, or by fractions.
GET
The GET statement allows you to get data from the keyboard, one
character at a time. When GET is executed, the character that is typed is
assigned to the variable. If no character is typed, then a null (empty)
character is assigned.
GET is followed by a variable name, usually a string variable. If a
numeric variable was used and a nonnumeric key depressed, the program
would halt with an error message. The GET statement may be placed into a
loop, checking for any result. This loop will continue until a key is
hit.
GET#
GET #1,A$
GOSUB
20 GOSUB 800
GOTO or GO TO
When a statement with the GOTO command is reached, the next line to be
executed will be the one with the line number following the word GOTO.
IF ... THEN
IF ... THEN lets the computer analyze a situation and take two possible
courses of action, depending on the outcome. If the expression is true,
the statement following THEN is executed. This may be any BASIC
statement.
If the expression is false, the program goes directly to the next line.
The expression being evaluated may be a variable or formula, in which
case it is considered true if nonzero, and false if zero. In most cases,
there is an expression involving relational operators (=, <, >, <=, >=,
<>, AND, OR, NOT).
INPUT
The INPUT statement allows the program to get data from the user,
assigning that data to a variable. The program will stop, print a
question mark (?) on the screen, and wait for the user to type in the
answer and hit RETURN.
INPUT is followed by a variable name, or a list of variable names,
separated by commas. A message may be placed within quote marks, before
the list of variable names to be INPUT. If more than one variable is to
be INPUT, they must be separated by commas when typed.
INPUT#
10 INPUT#1, A
LET
10 LET A = 5
20 LET D$ = "HELLO"
NEXT
NEXT is always used in conjunction with the FOR statement. When the
program reaches a NEXT statement, it checks the FOR statement to see if
the limit of the loop has been reached. If the loop is not finished, the
loop variable is increased by the specified STEP value. If the loop is
finished, execution proceeds with the statement following NEXT.
NEXT may be followed by a variable name, or list of variable names,
separated by commas. If there are no names listed, the last loop started
is the one being completed. If variables are given, they are completed in
order from left to right.
ON
This command turns the GOTO and GOSUB commands into special versions of
the IF statement. ON is followed by a formula, which is evaluated. If the
result of the calculation is one, the first line on the list is executed;
if the result is 2, the second line is executed, and so on. If the result
is 0, negative, or larger than the list of numbers, the next line
executed will be the statement following the ON statement.
10 INPUT X
20 ON X GOTO 10,20,30,40,50
OPEN
0 Screen
1 Cassette
4 Printer
8 Disk
Also see: CLOSE, CMD, GET#, INPUT#, and PRINT#, system variable ST, and
Appendix B.
POKE
10 POKE 53281,0
20 S = 4096 * 13
30 POKE S + 29, 8
The PRINT statement is the first one most people learn to use, but
there are a number of variations to be aware of. PRINT can be followed
by:
Punctuation marks are used to help format the data on the screen. The
comma divides the screen into four columns, while the semicolon
suppresses all spacing. Either mark can be last symbol on a line. This
results in the next thing PRINTed acting as if it were a continuation of
the same PRINT statement.
10 PRINT "HELLO"
20 PRINT "HELLO", A$
30 PRINT A + B
40 PRINT J;
50 PRINT A, B, C, D
PRINT#
There are a few differences between this statement and PRINT. PRINT# is
followed by a number, which refers to the device or data file previously
OPENed. This number is followed by a comma and a list to be printed. The
comma and semicolon have the same effect as they do in PRINT. Please note
that some devices may not work with TAB and SPC.
READ
REM (Remark)
RESTORE
When executed in a program, the pointer to which an item in a DATA
statement will be READ next is reset to the first item in the list. This
gives you ability to re-READ the information. RESTORE stands by itself on
a line.
RETURN
STOP
This statement will halt program execution. The message, BREAK IN xxx
will be displayed, where xxx is the line number containing STOP. The
program may be restarted by using the CONT command. STOP is normally used
in debugging a program.
SYS
WAIT
WAIT X,Y,Z
The contents of the memory location are first exclusive-ORed with the
third number, if present, and then logically ANDed with the second
number. If the result is zero, the program goes back to that memory
location and checks again. When the result is nonzero, the program
continues with the next statement.
NUMERIC FUNCTIONS
ABS returns the absolute value of the number, without its sign (+ or
-). The answer is always positive.
ATN(X) (arctangent)
COS(X) (cosine)
FN xx(X)
INT(X)
Returns the truncated value of X, that is, with all the decimal places
to the right of the decimal point removed. The result will always be less
than, or equal to, X. Thus, any negative numbers with decimal places will
become the integer less than their current value.
LOG(X) (logarithm)
Will return the natural log of X. The natural log to the base e (see
EXP(X)). To convert to log base 10, simply divide by LOG(10).
PEEK(X)
RND(X) returns a random number in the range 0-1. The first random
number should be generated by the formula RND(-TI) to start things off
differently every time. After this, X should be a 1 or any positive
number. If X is zero, the result will be the same random number as the
last one.
A negative value for X will reseed the generator. The use of the
same negative number for X will result in the same sequence of
"random" numbers.
The formula for generating a number between X and Y is:
N = RND(1) * (Y-X) + X
where,
Y is the upper limit,
X is the lower range of numbers desired.
SGN(X) (sign)
SIN(X) (sine)
SIN(X) is the trigonometric sine function. The result will be the sine
of X, where X is an angle in radians.
TAN(X) (tangent)
USR(X)
STRING FUNCTIONS
ASC(X$)
This function will return the ASCII code of the first character of X$.
CHR$(X)
This is the opposite of ASC, and returns a string character whose ASCII
code is X.
LEFT$(X$,X)
LEN(X$)
MID$(X$,S,X)
This will return a string containing X characters starting from the Sth
character in X$.
RIGHT$(X$,X)
STR$(X)
VAL(X$)
10 X = VAL("123.456") X = 123.456
10 X = VAL("12A13B") X = 12
10 X = VAL("RIU017") X = 0
10 X = VAL("-1.23.45.67") X = -1.23
OTHER FUNCTIONS
FRE(X)
POS(X)
This function returns the number of the column (0-39) at which the next
PRINT statement will begin on the screen. X may have any value and is not
used.
SPC(X)
TAB(X)
TAB is also used in a PRINT statement; the next item to be PRINTed will
be in column X.
APPENDIX D
APPENDIX E
The following chart lists all of the characters built into the
Commodore 64 character sets. It shows which numbers should be POKED
into screen memory (locations 1024-2023) to get a desired character.
Also shown is which character corresponds to a number PEEKed from the
screen.
Two character sets are available, but only one set at a time. This
means that you cannot have characters from one set on the screen at
the same time you have characters from the other set displayed. The
sets are switched by holding down the <SHIFT> and <C=> keys
simultaneously.
From BASIC, POKE 53272,21 will switch to upper case mode and POKE
53272,23 switches to lower case.
Any number on the chart may also be displayed in REVERSE. The
reverse character code may be obtained by adding 128 to the values
shown.
If you want to display a solid circle at location 1504, POKE the
code for the circle (81) into location 1504: POKE 1504,81.
There is a corresponding memory location to control the color of
each character displayed on the screen (locations 55296-56295). To
change the color of the circle to yellow (color code 7) you would POKE
the corresponding memory location (55776) with the character color:
POKE 55776,7.
Refer to Appendix G for the complete screen and color memory maps,
along with color codes.
SCREEN CODES
APPENDIX F
ASCII AND CHR$ CODES
This appendix shows you what characters will appear if you PRINT
CHR$(X), for all possible values of X. It will also show the values
obtained by typing PRINT ASC("x"), where x is any character you can type.
This is useful in evaluating the character received in a GET statement,
converting upper/lower case, and printing character based commands (like
switch to upper/lower case) that could not be enclosed in quotes.
+-----------------+-----------------+-----------------+-----------------+
| PRINTS CHR$ | PRINTS CHR$ | PRINTS CHR$ | PRINTS CHR$ |
+-----------------+-----------------+-----------------+-----------------+
| 0 | 0 48 | 96 | {black} 144 |
| 1 | 1 49 | 97 | {up} 145 |
| 2 | 2 50 | 98 | {rvs off} 146 |
| 3 | 3 51 | 99 | {clear} 147 |
| 4 | 4 52 | 100 | {inst} 148 |
| {white} 5 | 5 53 | 101 | {brown} 149 |
| 6 | 6 54 | 102 | {lt. red} 150 |
| 7 | 7 55 | 103 | {grey 1} 151 |
| disSHIFT+C= 8 | 8 56 | 104 | {grey 2} 152 |
| enaSHIFT+C= 9 | 9 57 | 105 | {lt.green}153 |
| 10 | : 58 | 106 | {lt.blue} 154 |
| 11 | ; 59 | 107 | {grey 3} 155 |
| 12 | < 60 | 108 | {purple} 156 |
| return 13 | = 61 | 109 | {left} 157 |
| lower case 14 | > 62 | 110 | {yellow} 158 |
| 15 | ? 63 | 111 | {cyan} 159 |
| 16 | @ 64 | 112 | SPACE 160 |
| {down} 17 | A 65 | 113 | 161 |
| {rvs on} 18 | B 66 | 114 | 162 |
| {home} 19 | C 67 | 115 | 163 |
| {del} 20 | D 68 | 116 | 164 |
| 21 | E 69 | 117 | 165 |
| 22 | F 70 | 118 | 166 |
| 23 | G 71 | 119 | 167 |
| 24 | H 72 | 120 | 168 |
| 25 | I 73 | 121 | 169 |
| 26 | J 74 | 122 | 170 |
| 27 | K 75 | 123 | 171 |
| {red} 28 | L 76 | 124 | 172 |
| {right} 29 | M 77 | 125 | 173 |
| {green} 30 | N 78 | 126 | 174 |
| {blue} 31 | O 79 | 127 | 175 |
| SPACE 32 | P 80 | 128 | 176 |
| ! 33 | Q 81 | {orange} 129 | 177 |
| " 34 | R 82 | 130 | 178 |
| # 35 | S 83 | 131 | 179 |
| $ 36 | T 84 | 132 | 180 |
| % 37 | U 85 | f1 133 | 181 |
| & 38 | V 86 | f3 134 | 182 |
| ' 39 | W 87 | f5 135 | 183 |
| ( 40 | X 88 | f7 136 | 184 |
| ) 41 | Y 89 | f2 137 | 185 |
| * 42 | Z 90 | f4 138 | 186 |
| + 43 | [ 91 | f6 139 | 187 |
| , 44 | pound 92 | f8 140 | 188 |
| - 45 | ] 93 |shift+ret. 141 | 189 |
| . 46 | ^ 94 |upper case 142 | 190 |
| / 47 |{arrow left}95 | 143 | 191 |
+-----------------+-----------------+-----------------+-----------------+
APPENDIX D
COLUMN 1063
0 10 20 30 39 /
+------------------------------------------------------------/
1024 | | 0
1064 | |
1104 | |
1144 | |
1184 | |
1224 | |
1264 | |
1304 | |
1344 | |
1384 | |
1424 | | 10
1464 | |
1504 | | ROW
1544 | |
1584 | |
1624 | |
1664 | |
1704 | |
1744 | |
1784 | |
1824 | | 20
1864 | |
1904 | |
1944 | |
1984 | | 24
+------------------------------------------------------------\
\
2023
0 BLACK 8 ORANGE
1 WHITE 9 BROWN
2 RED 10 Light RED
3 CYAN 11 GRAY 1
4 PURPLE 12 GRAY 2
5 GREEN 13 Light GREEN
6 BLUE 14 Light BLUE
7 YELLOW 15 GRAY 3
COLUMN 55335
0 10 20 30 39 /
+------------------------------------------------------------/
55296| | 0
55336| |
55376| |
55416| |
55456| |
55496| |
55536| |
55576| |
55616| |
55656| |
55696| | 10
55736| |
55776| | ROW
55816| |
55856| |
55896| |
55936| |
55976| |
56016| |
56056| |
56096| | 20
56136| |
56176| |
56216| |
56256| | 24
+------------------------------------------------------------\
56295
APPENDIX H
+-------------------------------+---------------------------------------+
| FUNCTION | BASIC EQUIVALENT |
+-------------------------------+---------------------------------------+
| SECANT | SEC(X)=1/COS(X) |
| COSECANT | CSC(X)=1/SIN(X) |
| COTANGENT | COT(X)=1/TAN(X) |
| INVERSE SINE | ARCSIN(X)=ATN(X/SQR(-X*X+1)) |
| INVERSE COSINE | ARCCOS(X)=-ATN(X/SQR(-X*X+1))+{pi}/2 |
| INVERSE SECANT | ARCSEC(X)=ATN(X/SQR(X*X-1)) |
| INVERSE COSECANT | ARCCSC(X)=ATN(X/SQR(X*X-1)) |
| | +(SGN(X)-1*{pi}/2 |
| INVERSE COTANGENT | ARCOT(X)=ATN(X)+{pi}/2 |
| HYPERBOLIC SINE | SINH(X)=(EXP(X)-EXP(-X))/2 |
| HYPERBOLIC COSINE | COSH(X)=(EXP(X)+EXP(-X))/2 |
| HYPERBOLIC TANGENT | TANH(X)=EXP(-X)/(EXP(X)+EXP(-X))*2+1 |
| HYPERBOLIC SECANT | SECH(X)=2/(EXP(X)+EXP(-X)) |
| HYPERBOLIC COSECANT | CSCH(X)=2/(EXP(X)-EXP(-X)) |
| HYPERBOLIC COTANGENT | COTH(X)=EXP(-X)/(EXP(X)-EXP(-X))*2+1 |
| INVERSE HYPERBOLIC SINE | ARCSINH(X)=LOG(X+SQR(X*X+1)) |
| INVERSE HYPERBOLIC COSINE | ARCCOSH(X)=LOG(X+SQR(X*X-1)) |
| INVERSE HYPERBOLIC TANGENT | ARCTANH(X)=LOG((1+X)/(1-X))/2 |
| INVERSE HYPERBOLIC SECANT | ARCSECH(X)=LOG((SQR(-X*X+1)+1/X) |
| INVERSE HYPERBOLIC COSECANT | ARCCSCH(X)=LOG((SGN(X)*SQR(X*X+1/X) |
| INVERSE HYPERBOLIC COTANGENT | ARCCOTH(X)=LOG((X+1)/(X-1))/2 |
+------------------------------+----------------------------------------+
APPENDIX I
Control Port 1
+-----+-------------+-----------+ /---------------------\
| Pin | Type | Note | | 1 2 3 4 5 |
+-----+-------------+-----------+ | O O O O O |
| 1 | JOYA0 | | | |
| 2 | JOYA1 | | | O O O O |
| 3 | JOYA2 | | | 6 7 8 9 |
| 4 | JOYA3 | | \_______________/
| 5 | POT AY | |
| 6 | BUTTON A/LP | |
| 7 | +5V | MAX. 50mA |
| 8 | GND | |
| 9 | POT AX | |
+-----+-------------+-----------+
Control Port 2
+-----+-------------+-----------+
| Pin | Type | Note |
+-----+-------------+-----------+
| 1 | JOYB0 | |
| 2 | JOYB1 | |
| 3 | JOYB2 | |
| 4 | JOYB3 | |
| 5 | POT BY | |
| 6 | BUTTON B | |
| 7 | +5V | MAX. 50mA |
| 8 | GND | |
| 9 | POT BX | |
+-----+-------------+-----------+
+--------+-----------+ +--------+--------------+
| Pin | Type | | Pin | Type |
+--------+-----------+ +--------+--------------+
| N | A9 | | A | GND |
| P | A8 | | B | /ROMH |
| R | A7 | | C | /RESET |
| S | A6 | | D | /NMI |
| T | A5 | | E | 02 |
| U | A4 | | F | A15 |
| V | A3 | | H | A14 |
| W | A2 | | J | A13 |
| X | A1 | | K | A12 |
| Y | A0 | | L | A11 |
| Z | GND | | M | A10 |
+--------+-----------+ +--------+--------------+
2 2 2 1 1 1 1 1 1 1 1 1 1
2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1
+---@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@---+
| |
+---@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@-@---+
Z Y X W V U T S R P N M L K J H F E D C B A
Audio/Video ++ ++
+--------------------------+------------------+ / +-+ \
| Pin | Type | Note | / \
+--------+-----------------+------------------+ + +
| 1 | LUMINANCE | | |3O O1|
| 2 | GND | | | |
| 3 | AUDIO OUT | | + O O +
| 4 | VIDEO OUT | | \5 O 4/
| 5 | AUDIO IN | | \ 2 /
+--------+-----------------+------------------+ +---+
Serial I/O ++ ++
+---------------------------------------------+ / +-+ \
| Pin | Type | /5 1\
+--------+------------------------------------+ + O O +
| 1 | SERIAL /SRQIN | | 6 |
| 2 | GND | | O |
| 3 | SERIAL ATN OUT | | |
| 4 | SERIAL CLK IN/OUT | + O O +
| 5 | SERIAL DATA IN/OUT | \4 O 2/
| 6 | /RESET | \ 3 /
+--------+------------------------------------+ +---+
Cassette
+-------+-------------------------------------+
| Pin | Type |
+-------+-------------------------------------+
| A-1 | GND | 1 2 3 4 5 6
| B-2 | +5V | +---@-@-@-@-@-@---+
| C-3 | CASSETTE MOTOR | | |
| D-4 | CASSETTE READ | +---@-@-@-@-@-@---+
| E-5 | CASSETTE WRITE | A B C D E F
| F-6 | CASSETTE SENSE |
+-------+-------------------------------------+
User I/O
+------+------------------+-------------------+
| Pin | Type | Note |
+------+------------------+-------------------+
| 1 | GND | |
| 2 | +5V | MAX. 100 mA |
| 3 | /RESET | |
| 4 | CNT1 | |
| 5 | SP1 | |
| 6 | CNT2 | |
| 7 | SP2 | |
| 8 | /PC2 | |
| 9 | SER. ATN OUT | |
| 10 | 9 VAC | MAX. 100 mA |
| 11 | 9 VAC | MAX. 100 mA |
| 12 | GND | |
+------+------------------+-------------------+
+------+------------------+-------------------+
| Pin | Type | Note |
+------+------------------+-------------------+
| A | GND | |
| B | /FLAG2 | |
| C | PB0 | |
| D | PB1 | |
| E | PB2 | |
| F | PB3 | |
| H | PB4 | |
| I | PB5 | |
| K | PB6 | |
| L | PB7 | |
| M | PA2 | |
| N | GND | |
+------+------------------+-------------------+
1 1 1
1 2 3 4 5 6 7 8 9 0 1 2
+--@-@-@-@-@-@-@-@-@-@-@-@--+
| |
+--@-@-@-@-@-@-@-@-@-@-@-@--+
A B C D E F H J K L M N
APPENDIX J
PROGRAMS TO TRY
We've included a number of useful programs for you to try with your
Commodore 64. These programs will prove both entertaining and useful.
APPENDIX K
CONVERTING STANDARD
BASIC PROGRAMS TO
COMMODORE 64 BASIC
String Dimensions
A$(I)=X$ A$=LEFT$(A$,I-1)+X$+MID$(A$,I+1)
A$(I,J)=X$ A$=LEFT$(A$,I-1)+X$+MID$(A$,J+1)
Multiple Assignments
To set B and C equal to zero, some BASICs allow statements of the form:
10 LET B=C=0
10 C=0:B=0
Multiple Statements
MAT Functions
APPENDIX L
ERROR MESSAGES
BAD DATA String data was received from an open file, but the
program was expecting numeric data.
BAD SUBSCRIPT The program was trying to reference an element of
an array whose number is outside of the range
specified in the DIM statement.
BREAK Program execution was stopped because you hit the
<STOP> key.
CAN'T CONTINUE The CONT command will not work, either because the
program was never RUN, there has been an error, or
a line has been edited.
DEVICE NOT PRESENT The required I/O device was not available for an
OPEN, CLOSE, CMD, PRINT#, INPUT#, or GET#.
DIVISION BY ZERO Division by zero is a mathematical oddity and not
allowed.
EXTRA IGNORED Too many items of data were typed in response to an
INPUT statement. Only the first few items were
accepted.
FILE NOT FOUND If you were looking for a file on tape, and END-OF-
TAPE marker was found. If you were looking on disk,
no file with that name exists.
FILE NOT OPEN The file specified in a CLOSE, CMD, PRINT#, INPUT#,
or GET#, must first be OPENed.
FILE OPEN An attempt was made to open a file using the number
of an already open file.
FORMULA TOO COMPLEX The string expression being evaluated should be
split into at least two parts for the system to
work with, or a formula has too many parentheses.
ILLEGAL DIRECT The INPUT statement can only be used within a
program, and not in direct mode.
ILLEGAL QUANTITY A number used as the argument of a function or
statement is out of the allowable range.
LOAD There is a problem with the program on tape.
NEXT WITHOUT FOR This is caused by either incorrectly nesting loops
or having a variable name in a NEXT statement that
doesn't correspond with one in a FOR statement.
NOT INPUT FILE An attempt was made to INPUT or GET data from a
file which was specified to be for output only.
NOT OUTPUT FILE An attempt was mode to PRINT data to a file which
was specified as input only.
OUT OF DATA A READ statement was executed but there is no data
left unREAD in a DATA statement.
OUT OF MEMORY There is no more RAM available for program or
variables. This may also occur when too many FOR
loops have been nested, or when there are too many
GOSUBs in effect.
OVERFLOW The result of a computation is larger than the
largest number allowed, which is 1.70141884E+38.
REDIM'D ARRAY An array may only be DIMensioned once. If an array
variable is used before that array is DIM'd, an
automatic DIM operation is performed on that array
setting the number of elements to ten, and any
subsequent DIMs will cause this error.
REDO FROM START Character data was typed in during an INPUT
statement when numeric data was expected. Just re-
type the entry so that it is correct, and the
program will continue by itself.
RETURN WITHOUT GOSUB A RETURN statement was encountered, and no GOSUB
command has been issued.
STRING TOO LONG A string can contain up to 255 characters.
SYNTAX ERROR A statement is unrecognizable by the Commodore 64.
A missing or extra parenthesis, misspelled
keywords, etc.
TYPE MISMATCH This error occurs when a number is used in place of
a string, or vice-versa.
UNDEF'D FUNCTION A user defined function was referenced, but it has
never been defined using the DEF FN statement.
UNDEF'D STATEMENT An attempt was made to GOTO or GOSUB or RUN a line
number that doesn't exist.
VERIFY The program on tape or disk does not match the
program currently in memory.
VERIFY The program on tape or disk does not match the
program currently in memory.
APPENDIX M
+-----------------------------+-----------------------------------------+
| MUSICAL NOTE | OSCILLATOR FREQ |
+-------------+---------------+-------------+-------------+-------------+
| NOTE | OCTAVE | DECIMAL | HI | LOW |
+-------------+---------------+-------------+-------------+-------------+
| 0 | C-0 | 268 | 1 | 12 |
| 1 | C#-0 | 284 | 1 | 28 |
| 2 | D-0 | 301 | 1 | 45 |
| 3 | D#-0 | 318 | 1 | 62 |
| 4 | E-0 | 337 | 1 | 81 |
| 5 | F-0 | 358 | 1 | 102 |
| 6 | F#-0 | 379 | 1 | 123 |
| 7 | G-0 | 401 | 1 | 145 |
| 8 | G#-0 | 425 | 1 | 169 |
| 9 | A-0 | 451 | 1 | 195 |
| 10 | A#-0 | 477 | 1 | 221 |
| 11 | B-0 | 506 | 1 | 250 |
| 16 | C-1 | 536 | 2 | 24 |
| 17 | C#-1 | 568 | 2 | 56 |
| 18 | D-1 | 602 | 2 | 90 |
| 19 | D#-1 | 637 | 2 | 125 |
| 20 | E-1 | 675 | 2 | 163 |
| 21 | F-1 | 716 | 2 | 204 |
| 22 | F#-1 | 758 | 2 | 246 |
| 23 | G-1 | 803 | 3 | 35 |
| 24 | G#-1 | 851 | 3 | 83 |
| 25 | A-1 | 902 | 3 | 134 |
| 26 | A#-1 | 955 | 3 | 187 |
| 27 | B-1 | 1012 | 3 | 244 |
| 32 | C-2 | 1072 | 4 | 48 |
| 33 | C#-2 | 1136 | 4 | 112 |
| 34 | D-2 | 1204 | 4 | 180 |
| 35 | D#-2 | 1275 | 4 | 251 |
| 36 | E-2 | 1351 | 5 | 71 |
| 37 | F-2 | 1432 | 5 | 152 |
| 38 | F#-2 | 1517 | 5 | 237 |
| 39 | G-2 | 1607 | 6 | 71 |
| 40 | G#-2 | 1703 | 6 | 167 |
| 41 | A-2 | 1804 | 7 | 12 |
| 42 | A#-2 | 1911 | 7 | 119 |
| 43 | B-2 | 2025 | 7 | 233 |
| 48 | C-3 | 2145 | 8 | 97 |
| 49 | C#-3 | 2273 | 8 | 225 |
| 50 | D-3 | 2408 | 9 | 104 |
| 51 | D#-3 | 2551 | 9 | 247 |
| 52 | E-3 | 2703 | 10 | 143 |
| 53 | F-3 | 2864 | 11 | 48 |
| 54 | F#-3 | 3034 | 11 | 218 |
| 55 | G-3 | 3215 | 12 | 143 |
| 56 | G#-3 | 3406 | 13 | 78 |
| 57 | A-3 | 3608 | 14 | 24 |
| 58 | A#-3 | 3823 | 14 | 239 |
| 59 | B-3 | 4050 | 15 | 210 |
| 64 | C-4 | 4291 | 16 | 195 |
| 65 | C#-4 | 4547 | 17 | 195 |
| 66 | D-4 | 4817 | 18 | 209 |
| 67 | D#-4 | 5103 | 19 | 239 |
| 68 | E-4 | 5407 | 21 | 31 |
| 69 | F-4 | 5728 | 22 | 96 |
| 70 | F#-4 | 6069 | 23 | 181 |
| 71 | G-4 | 6430 | 25 | 30 |
| 72 | G#-4 | 6812 | 26 | 156 |
| 73 | A-4 | 7217 | 28 | 49 |
| 74 | A#-4 | 7647 | 29 | 223 |
| 75 | B-4 | 8101 | 31 | 165 |
| 80 | C-5 | 8583 | 33 | 135 |
| 81 | C#-5 | 9094 | 35 | 134 |
| 82 | D-5 | 9634 | 37 | 162 |
| 83 | D#-5 | 10207 | 39 | 223 |
| 84 | E-5 | 10814 | 42 | 62 |
| 85 | F-5 | 11457 | 44 | 193 |
| 86 | F#-5 | 12139 | 47 | 107 |
| 87 | G-5 | 12860 | 50 | 60 |
| 88 | G#-5 | 13625 | 53 | 57 |
| 89 | A-5 | 14435 | 56 | 99 |
| 90 | A#-5 | 15294 | 59 | 190 |
| 91 | B-5 | 16203 | 63 | 75 |
| 96 | C-6 | 17167 | 67 | 15 |
| 97 | C#-6 | 18188 | 71 | 12 |
| 98 | D-6 | 19269 | 75 | 69 |
| 99 | D#-6 | 20415 | 79 | 191 |
| 100 | E-6 | 21629 | 84 | 125 |
| 101 | F-6 | 22915 | 89 | 131 |
| 102 | F#-6 | 24278 | 94 | 214 |
| 103 | G-6 | 25721 | 100 | 121 |
| 104 | G#-6 | 27251 | 106 | 115 |
| 105 | A-6 | 28871 | 112 | 199 |
| 106 | A#-6 | 30588 | 119 | 124 |
| 107 | B-6 | 32407 | 126 | 151 |
| 112 | C-7 | 34334 | 134 | 30 |
| 113 | C#-7 | 36376 | 142 | 24 |
| 114 | D-7 | 38539 | 150 | 139 |
| 115 | D#-7 | 40830 | 159 | 126 |
| 116 | E-7 | 43258 | 168 | 250 |
| 117 | F-7 | 45830 | 179 | 6 |
| 118 | F#-7 | 48556 | 189 | 172 |
| 119 | G-7 | 51443 | 200 | 243 |
| 120 | G#-7 | 54502 | 212 | 230 |
| 121 | A-7 | 57743 | 225 | 143 |
| 122 | A#-7 | 61176 | 238 | 248 |
| 123 | B-7 | 64814 | 253 | 46 |
+-------------+---------------+-------------+-------------+-------------+
FILTER SETTINGS
+------------+--------------------------------+
| Location | Contents |
+------------+--------------------------------+
| 54293 | Low cutoff frequency (0-7) |
| 54294 | High cutoff frequency (0-255) |
| 54295 | Resonance (bits 4-7) |
| | Filter voice 3 (bit 2) |
| | Filter voice 2 (bit 1) |
| | Filter voice 1 (bit 0) |
| 54296 | High pass (bit 6) |
| | Bandpass (bit 5) |
| | Low pass (bit 4) |
| | Volume (bits 0-3) |
+------------+--------------------------------+
APPENDIX N
BIBLIOGRAPHY
Cowbay Computing "Feed Me, I'm Your PET Computer", Carol Alexander
Hoyden Book Co. "BASIC From the Ground Up", David E. Simon
Reston Publishing Co. "PET and the IEEE 488 Bus (GPIB)", Eugene
Fisher and C. W. Jensen
APPENDIX O
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
|Register#| | | | | | | | | |
| Dec Hex | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 0 0 |S0X7 | | | | | | |S0X0 |SPRITE 0 X |
| | | | | | | | | |Component |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 1 1 |S0Y7 | | | | | | |S0Y0 |SPRITE 0 Y |
| | | | | | | | | |Component |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 2 2 |S1X7 | | | | | | |S1X0 |SPRITE 1 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 3 3 |S1Y7 | | | | | | |S1Y0 |SPRITE 1 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 4 4 |S2X7 | | | | | | |S2X0 |SPRITE 2 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 5 5 |S2Y7 | | | | | | |S2Y0 |SPRITE 2 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 6 6 |S3X7 | | | | | | |S3X0 |SPRITE 3 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 7 7 |S3Y7 | | | | | | |S3Y0 |SPRITE 3 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 8 8 |S4X7 | | | | | | |S4X0 |SPRITE 4 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 9 9 |S4Y7 | | | | | | |S4Y0 |SPRITE 4 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 10 A |S5X7 | | | | | | |S5X0 |SPRITE 5 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 11 B |S5Y7 | | | | | | |S5Y0 |SPRITE 5 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 12 C |S6X7 | | | | | | |S6X0 |SPRITE 6 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 13 D |S6Y7 | | | | | | |S6Y0 |SPRITE 6 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 14 E |S7X7 | | | | | | |S7X0 |SPRITE 7 X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 15 F |S7Y7 | | | | | | |S7Y0 |SPRITE 7 Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 16 10 |S7X8 |S6X8 |S5X8 |S4X8 |S3X8 |S2X8 |S1X8 |S0X8 |MSB of X |
| | | | | | | | | |COORD. |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 17 11 | RC8 | ECM | BMM |BLNK |RSEL |YSCL2|YSCL1|YSCL0|Y SCROLL |
| | | | | | | | | |Mode |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 18 12 | RC7 | RC6 | RC5 | RC4 | RC3 | RC2 | RC1 | RC0 |RASTER |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 19 13 |LPX7 | | | | | | |LPX0 |LIGHT PEN X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 20 14 |LPY7 | | | | | | |LPY0 |LIGHT PEN Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 21 15 | SE7 | | | | | | | SE0 |SPRITE |
| | | | | | | | | |ENABLE |
| | | | | | | | | |(ON/OFF) |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 22 16 |N.C. |N.C. | RST | MCM |CSEL |XSCL2|XSCL1|XSCL0|X SCROLL |
| | | | | | | | | |MODE |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 23 17 |SEX7 | | | | | | |SEX0 |SPRITE |
| | | | | | | | | |EXPAND Y |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 24 18 |VS13 |VS12 |VS11 |VS10 |CB13 |CB12 |CB11 |N.C. |SCREEN |
| | | | | | | | | |Character |
| | | | | | | | | |Memory |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 25 19 |IRQ |N.C. |N.C. |N.C. |LPIRQ|ISSC |ISBC |RIRIQ|Interrupt |
| | | | | | | | | |Request's |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 26 1A |N.C. |N.C. |N.C. |N.C. |MLPI |MISSC|MISBC|MRIRQ|Interrupt |
| | | | | | | | | |Request |
| | | | | | | | | |MASKS |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 27 1B |BSP7 | | | | | | |BSP0 |Background |
| | | | | | | | | |Sprite |
| | | | | | | | | |PRIORITY |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 28 1C |SCM7 | | | | | | |SCM0 |MULTICOLOR |
| | | | | | | | | |SPRITE |
| | | | | | | | | |SELECT |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 29 1D |SEXX7| | | | | | |SEXX0|SPRITE |
| | | | | | | | | |EXPAND X |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 30 1E |SSC7 | | | | | | |SSC0 |Sprite-Sprite|
| | | | | | | | | |COLLISION |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
| 31 1F |SBC7 | | | | | | |SBC0 |Sprite- |
| | | | | | | | | |Background |
| | | | | | | | | |COLLISION |
+---------+-----+-----+-----+-----+-----+-----+-----+-----+-------------+
COLOR CODES
DEC HEX COLOR
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 32 20 | 0 0 BLACK |EXT 1| | | |EXTERIOR COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 33 21 | 1 1 WHITE |BKGD0| | | |BACKGROUND 0 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 34 22 | 2 2 RED |BKGD1| | | |BACKGROUND 1 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 35 23 | 3 3 CYAN |BKGD2| | | |BACKGROUND 2 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 36 24 | 4 4 PURPLE |BKGD3| | | |BACKGROUND 3 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 37 25 | 5 5 GREEN |SMC 0| | | | SPRITE |
| | | | | | |MULTICOLOR 0 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 38 26 | 6 6 BLUE |SMC 1| | | | SPRITE |
| | | | | | |MULTICOLOR 1 |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 39 27 | 7 7 YELLOW |S0COL| | | |SPRITE 0 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 40 28 | 8 8 ORANGE |S1COL| | | |SPRITE 1 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 41 29 | 9 9 BROWN |S2COL| | | |SPRITE 2 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 42 2A | 10 A LT RED |S3COL| | | |SPRITE 3 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 43 2B | 11 B GRAY 1 |S4COL| | | |SPRITE 4 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 44 2C | 12 C GRAY 2 |S5COL| | | |SPRITE 5 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 45 2D | 13 D LT GREEN |S6COL| | | |SPRITE 6 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| 46 2E | 14 E LT BLUE |S7COL| | | |SPRITE 7 COL |
+---------+-----------------------+-----+-----+-----+-----+-------------+
| | 15 F GRAY 3 | | | | | |
+---------+-----------------------+-----+-----+-----+-----+-------------+
LEGEND:
ONLY COLORS 0-7 MAY BE USED IN MULTICOLOR CHARACTER MODE.
APPENDIX P
This handy table gives you the key numbers you need to use in your
sound programs, according to which of the Commodore 64's 3 voices you
want to use. To set or adjust a sound control in your BASIC program, just
POKE the number from the second column, followed by a comma (,) and a
number from the chart ... like this: POKE 54276,17 (Selects a Triangle
Waveform for VOICE 1).
Remember that you must set the VOLUME before you can generate sound.
POKE 54296 followed by a number from 0 to 15 sets the volume for all 3
voices.
It takes 2 separate POKEs to generate each musical note ... for example
POKE 54273,34: POKE 54272,75 designates low C in the sample scale bellow.
Also ... you aren't limited to the numbers shown in the tables. If 34
doesn't sound "right" for a low C, try 35. To provide a higher SUSTAIN or
ATTACK rate than those shown, add two or more SUSTAIN numbers together.
(Examples: POKE 54277,96 combines two attack rates (32 and 64) for a
combined higher attack rate ... but ... POKE 54277,20 provides a low
attack rate (16) and a medium decay rate (4).
+----------------------------------------------------------------------------+
|SETTING VOLUME -- SAME FOR ALL 3 VOICES |
+--------------+---------+---------------------------------------------------+
|VOLUME CONTROL|POKE54296| Settings from 0 (off) to 15 (loudest) |
+--------------+---------+---------------------------------------------------+
VOICE NUMBER 1
+--------------+---------+---------------------------------------------------+
|TO CONTROL |POKE THIS| FOLLOWED BY ONE OF THESE NUMBERS |
|THIS SETTING: |NUMBER: | (0 to 15 ... or ... 0 to 255 depending on range) |
+--------------+---------+---------------------------------------------------+
|TO PLAY A NOTE| C | C#| D | D#| E | F | F#| G | G#| A | A#| B | C | C#|
|HIGH FREQUENCY|54273 34 | 36| 38| 40| 43| 45| 48| 51| 54| 57| 61| 64| 68| 72|
|LOW FREQUENCY |54272 75 | 85|126|200| 52|198|127| 97|111|172|126|188|149|169|
+--------------+---------+------------+------------+------------+------------+
|WAVEFORM | POKE | TRIANGLE | SAWTOOTH | PULSE | NOISE |
| | 54276 | 17 | 33 | 65 | 129 |
+--------------+---------+------------+------------+------------+------------+
|PULSE RATE (Pulse Waveform) |
|HI POLSE | 54275 | A value of 0 to 15 (for Pulse waveform only) |
|LO POLSE | 54274 | A value of 0 to 255 (for Pulse waveform only) |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|ATTACK/ | POKE | ATK4 | ATK3 | ATK2 | ATK1 | DEC4| DEC3| DEC2| DEC1|
| DECAY | 54277 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|SUSTAIN/ | POKE | SUS4 | SUS3 | SUS2 | SUS1 | REL4| REL3| REL2| REL1|
| RELEASE| 54278 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
VOICE NUMBER 2
+--------------+---------+---------------------------------------------------+
|TO CONTROL |POKE THIS| FOLLOWED BY ONE OF THESE NUMBERS |
|THIS SETTING: |NUMBER: | (0 to 15 ... or ... 0 to 255 depending on range) |
+--------------+---------+---------------------------------------------------+
|TO PLAY A NOTE| C | C#| D | D#| E | F | F#| G | G#| A | A#| B | C | C#|
|HIGH FREQUENCY|54280 34 | 36| 38| 40| 43| 45| 48| 51| 54| 57| 61| 64| 68| 72|
|LOW FREQUENCY |54279 75 | 85|126|200| 52|198|127| 97|111|172|126|188|149|169|
+--------------+---------+------------+------------+------------+------------+
|WAVEFORM | POKE | TRIANGLE | SAWTOOTH | PULSE | NOISE |
| | 54283 | 17 | 33 | 65 | 129 |
+--------------+---------+------------+------------+------------+------------+
|PULSE RATE (Pulse Waveform) |
|HI POLSE | 54282 | A value of 0 to 15 (for Pulse waveform only) |
|LO POLSE | 54281 | A value of 0 to 255 (for Pulse waveform only) |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|ATTACK/ | POKE | ATK4 | ATK3 | ATK2 | ATK1 | DEC4| DEC3| DEC2| DEC1|
| DECAY | 54284 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|SUSTAIN/ | POKE | SUS4 | SUS3 | SUS2 | SUS1 | REL4| REL3| REL2| REL1|
| RELEASE| 54285 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
VOICE NUMBER 3
+--------------+---------+---------------------------------------------------+
|TO CONTROL |POKE THIS| FOLLOWED BY ONE OF THESE NUMBERS |
|THIS SETTING: |NUMBER: | (0 to 15 ... or ... 0 to 255 depending on range) |
+--------------+---------+---------------------------------------------------+
|TO PLAY A NOTE| C | C#| D | D#| E | F | F#| G | G#| A | A#| B | C | C#|
|HIGH FREQUENCY|54287 34 | 36| 38| 40| 43| 45| 48| 51| 54| 57| 61| 64| 68| 72|
|LOW FREQUENCY |54286 75 | 85|126|200| 52|198|127| 97|111|172|126|188|149|169|
+--------------+---------+------------+------------+------------+------------+
|WAVEFORM | POKE | TRIANGLE | SAWTOOTH | PULSE | NOISE |
| | 54290 | 17 | 33 | 65 | 129 |
+--------------+---------+------------+------------+------------+------------+
|PULSE RATE (Pulse Waveform) |
|HI POLSE | 54289 | A value of 0 to 15 (for Pulse waveform only) |
|LO POLSE | 54288 | A value of 0 to 255 (for Pulse waveform only) |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|ATTACK/ | POKE | ATK4 | ATK3 | ATK2 | ATK1 | DEC4| DEC3| DEC2| DEC1|
| DECAY | 54291 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
|SUSTAIN/ | POKE | SUS4 | SUS3 | SUS2 | SUS1 | REL4| REL3| REL2| REL1|
| RELEASE| 54292 | 128 | 64 | 32 | 16 | 8 | 4 | 2 | 1 |
+--------------+---------+------+------+------+------+-----+-----+-----+-----+
+------------+----------+--------------+---------------+----------------+
| Instrument | Waveform | Attack/Decay |Sustain/Release| Pulse Rate |
+------------+----------+--------------+---------------+----------------+
| Piano | Pulse | 9 | 0 | Hi-0, Lo-255 |
| Flute | Triangle | 96 | 0 | Not applicable |
| Harpsichord| Sawtooth | 9 | 0 | Not applicable |
| Xylophone | Triangle | 9 | 0 | Not applicable |
| Organ | Triangle | 0 | 240 | Not applicable |
| Colliape | Triangle | 0 | 240 | Not applicable |
| Accordian | Triangle | 102 | 0 | Not applicable |
| Trumpet | Sawtooth | 96 | 0 | Not applicable |
+------------+----------+--------------+---------------+----------------+
ADSR -- Attack/Decay/Sustain/Release
Attack -- Rate sound rises to peak volume
Decay -- Rate sound falls from peak volume to Sustain level
Sustain -- Prolong note at certain volume
Release -- Rate at which volume falls from Sustain level
Waveform -- "Shape" of sound wave
Pulse -- Tone quality of Pulse Waveform
INDEX
A
Abbreviations, BASIC commands, D
Accesories, INTRODUCTION, A
Addition, 2.4-2.5, C
AND operator, 5.4, C
Animation, 4.1, 5.6, 6.2, E, G
Arithmetic, Operators, 2.4-2.5, C
Arithmetic, Formulas, 2.4-2.5, C, H
Arrays, 8.3-8.6
ASC function, 4.8, C, F
ASCII character codes, F
B
BASIC
abbreviations, D
commands, C
numeric functions, C
operators, 2.4, C
other functions, C
statements, C
string functions, C
variables, 3.3, C
Bibliography, N
Binary arithmetic, 6.3-6.4
Bit, 6.3-6.4
Business aids, A
Byte, 6.4
C
Calculations, 2.4-2.6
Cassette tape recorder (audio), 1.1, 2.3
Cassette tape recorder (video), 1.3
Cassette port, 1.1
CHR$ function, 3.3, 4.3, 4.8, 5.3, C, F, K
CLR statement, C
CLR/HOME key, 2.1, 3.1, 4.2
Clock, C
CLOSE statement, B, C
Color
adjustment, 1.5
CHR$ codes, 5.3
keys, 5.1-5.2
memory map, 5.5, G
PEEKS and POKES, 5.4
screen and border, 5.4-5.5, G
Commands, BASIC, C
Commodore key, (see graphic keys)
Connections
optional, 1.3
rear, 1.1
side panel, 1.1
TV/Monitor, 1.2
CONT command, C
ConTRoL key, 1.5, 2.1
COSine function, C
CuRSoR keys, 1.4, 2.1, 3.2
Correcting errors, 3.2
Cursor, 1.4
D
DATASSETTE recorder, (see cassette tape recorder, audio)
Data, loading and saving (disk), 2.3, C
Data, loading and saving (tape), 2.3, C
DATA statement, 6.2, 6.3, 7.4, 7.6, 8.1, C
DEFine statement, C
Delay loop, 5.4, 5.8
DELete key, 2.1
DIMension statement, 8.4, C
Division, 2.4-2.5, C
Duration, (see FOR ... NEXT)
E
Editing program, 2.1, 3.2
END statement, 3.4, C
Equal, not-equal-to, signs, 2.4-2.5, 3.4, C
Equations, 3.4, C
Error messages, 2.4, L
Expansion port, I
EXPonent function, C
Exponentiation, 2.4-2.5, C
F
Files, (tape), 2.3, B, C
Files, (disk), 2.3, C
FOR statement, 3.5, C
FRE function, C
Functions, C
G
Game controls and ports, 1.1, I
GET statement, 4.4, C
GET# statement, C
Getting started, 2.1-2.6
GOSUB statement, C
GOTO (GO TO) statement, 3.1, C
Graphic keys, 2.1, 5.1-5.2, 5.4, E
Graphic symbols, (see graphic keys)
Greater than, 3.4, C
H
Hyperbolic functions, H
I
IEEE-488 Interface, A
IF ... THEN statement, 3.4, C
INPUT statement, 4.3, C
INPUT# statement, C
INSerT key, 2.1, 3.2
INTeger function, 4.5, C
I/O pinouts, I
I/O ports, 1.1-1.3
J
Joysticks, 1.1, I
K
Keyboard, 2.1-2.2
L
LEFT$ function, C
LENgth function, 6.4, C
Less than, 3.4, C
LET statement, C
LIST command, 3.1-3.2, C
LOAD command, 2.3, C
LOADing programs from tape, 2.3, C
LOADing programs from disk, 2.3, C
LOGarithm, C
Loops, 3.5, 4.2-4.3
Lower Case characters, 2.1
M
Mathematics
formulas, 2.4-2.5
function table, H
symbols, 2.4-2.5, 3.4
Memory maps, 5.5, G, O, P
MID$ function, 6.4, C
Modulator, RF, 1.2-1.3
Multiplication, 2.4-2.5, C
Music, 7.1-7.8
N
Names
program, 2.3, C
variable, 3.3, C
NEW command, 3.1, C
NEXT statement, 3.5, C
NOT operator, C
Numeric variables, 3.3
O
ON statement, C
OPEN statement, C
Operators
arithmetic, 2.4, C
logical, C
relational, 3.4, C
P
Parentheses, 2.5
PEEK function, 5.4, 5.6
Peripherals, 1.1-1.3
POKE statement, 5.4
Ports, I/O, 1.1, I
POS function, C
PRINT statement, 2.4, C
PRINT# statement, C
Precedence, 2.5
Programs
editing, 2.1, 3.2
line numbering, 3.1
loading/saving (tape), 2.3, C
loading/saving (disk), 2.3, C
Prompt, 4.3
Q
Quotation marks, 2.4
R
RaNDom function, 4.5-4.8, C
Random numbers, 4.5-4.8
READ statement, 8.1-8.2, C
Reading from tape, B
REMark statement, 4.2, C
Reserved words, (see Commands, BASIC)
RESTORE key, 2.1-2.2
RESTORE statement, 8.1, C
RETURN key, 2.1-2.2
RETURN statement, C
RIGHT$ function, C
RUN command, C
RUN/STOP key, 2.1, 3.1
S
SAVE command, 2.3, C
Saving programs (tape), 2.3, C
Saving programs (disk), 2.3, C
Screen memory maps, 5.5, G
SGN function, C
SHIFT key, 2.1-2.2
SINe function, C
Sound effects, 7.7-7.8
SPC function, 8.6, C
SPRITE EDITOR, INTRODUCTION
SPRITE graphics, 6.1-6.3
SQuaRe function, C
STOP command, C
STOP key, 2.1
String variables, 3.3
STR$ function, C
Subscripted variables, 8.3
Subtraction, 2.4-2.5, C
SYNTAX ERROR, 2.4
SYS statement, C
T
TAB function, C
TAN function, C
TI variable, C
TI$ variable, C
Time clock, C
TV connections, 1.2-1.3
U
Upper/Lower Case mode, 2.1, E
USR function, C
User defined function, (see DEF)
V
VALue function, 6.4, C
Variables
array, 8.3-8.6, C
dimensions, 8.4-8.6, C
floating point, 3.3, C
integer, 3.3, C
numeric, 3.3, 4.3, C
string ($), 3.3, 4.3, C
VERIFY command, C
Voice, 7.1-7.8, P
W
WAIT command, C
Writing to tape, B
Z,
Z-80, INTRODUCTION, A
SIMPLE VARIABLES
ARRAY VARIABLES
TYPE NAME
Single Dimension XY(5)
Two-Dimension XY(5,5)
Three-Dimension XY(5,5,5)
ALGEBRAIC OPERATIONS
= Equal
<> Not Equal
< Less Than
> Greater Than
<= Less Than or Equal To
>= Greater Than or Equal To
NOT Logical "Not"
AND Logical "And"
OR Logical "Or"
SYSTEM COMMANDS
INPUT/OUTPUT COMMANDS
PROGRAM FLOW
_____
/ ___|___
| / |__/ c o m m o d o r e
| \___|__\ C O M P U T E R
\_____|
DISTRIBUTED BY
Howard W. Sams & Co., Inc.
4300 W. 62nd Street, Indianapolis, Indiana 46268 USA
$12.95/22010
ISBN:0-672-22010-5
*********
*********