Import From Cassette
Back in the early days of the Apple II, the most popular way to distribute commercial software was on audio cassettes. Cassette tapes are slow, transferring data at an average of 1350 bits per second (better than a 1200 baud modem, but about a thousand times slower than a 1x CD-ROM). If stored properly, however, they can last a long time.
Technical Background
The basic layout of Apple II data on a cassette looks like this:
(1) Ten seconds of 770Hz tone.
(2) Short pulse indicating start of data.
(3) Data (one cycle at 1000Hz for a '1', one cycle at 2000Hz for a '0').
The last byte of data is a checksum that can be used to verify that the previous data read correctly. The data length is not stored, and there is no explicit "end" marker, so it's necessary to either know the length ahead of time or guess the position of the end based on the absence of data. Because of the way the code works, you're limited to 64K of data, though in practice you'd be limited to less than 48K on a real Apple II unless you were using custom read routines.
Applesoft and Integer BASIC programs write two consecutive blocks of data. The first block contains the length of the second block. CiderPress doesn't really need the first block, because the end of the recording is usually pretty obvious, but the existence of the first block makes it easier to guess what the second block contains.
Most cassettes include more than one copy of a program. In some cases (such as Adventure International's "Asteroid") they are slightly different implementations, while in others it's the same program repeated. Sometimes the program is repeated on the back side of the tape. Magnetic tapes wear out if you play them too much, so redundancy was common.
Getting the Audio Data
You will need to capture the audio from the cassette tape on your computer. This requires connecting a tape player to your PC while running audio capture software. Using a sound editor is recommended. Some examples:
Adobe Audition (www.adobe.com; expensive)
GoldWave (www.goldwave.com; shareware)
Audacity (audacity.sourceforge.net; freeware)
It isn't necessary to record each section of data from the cassette into its own WAV file. CiderPress will try to find every chunk of data in a WAV file.
If you have a "line out" on your tape player and a "line in" on your PC sound card, use those. If not, you can use the "microphone" input and the "headphone" out, though you will have to set the volume levels correctly. In the "speaker" or "multimedia" control panel, set the microphone input gain to 50%. Start up your sound editor. If you have an input level meter (e.g. hit F10 in Adobe Audition), turn that on. Play the cassette tape out loud until you hear a tone, then plug it into the computer and watch the input level. You want to set the volume so that the input is as high as you can get it without exceeding the limit (this causes "clipping", which is a lot like a square wave but probably isn't going to help us here). In Adobe Audition, make sure it stays above -3dB.
Once you have the volume level figured out, back the tape up to the start of the tone. Hit "record" in your software and "play" on your tape player. Record at 22.05KHz with 8-bit samples. (Recording at CD quality -- 44.1KHz with 16-bit samples -- doesn't help and requires 4x the space.) If your software shows an input meter while recording, continue to record until the volume level drops and stays low for at least 10 seconds. If you can't monitor the input, you will either need to time the cassette, or just record for a long time and perhaps trim the excess off in the sound editor. Make sure you get all of the data from the tape. When you think you're done, pull the audio plug out of the tape player and keep listening for a little bit.
Tip: CiderPress only needs to see about a second of the lead-in, so it's okay to fiddle with the volume while the initial tone is playing.
Tip: in some cases, setting the volume a little too high can be beneficial. It's better to clip some samples than have too little signal. If at first you don't succeed, crank up the volume a notch and try again.
Save the WAV file, launch CiderPress, and open a ShrinkIt archive or disk image. Files extracted from WAV files are added to the currently open archive. Select the "import file from WAV" option in the Actions menu, and open the WAV file you created.
Decoding the Data
The display shows the name of an algorithm, and a box with six columns:
Index: relative position of the program on the tape.
Format: best guess at the nature of the data (Applesoft, Integer BASIC, etc).
Length: decoded length, in bytes, not including the checksum.
Checksum: the checksum, with "Good" if the checksum matched, "BAD" if it didn't.
Start sample: sample number (not byte offset) where the data began. Useful when examining the data in a sound editor.
End sample: last good sample in the data. If the data is bad, this is probably where things went wrong.
The text in the "format" column is a guess at the contents, based on the length of the current and previous segment. For BASIC headers, the contents (e.g. length of program that follows) are shown in hexadecimal. Applesoft also has an "auto-run" flag, set to either $55 or $D5.
The output of the Apple II is a blocky "square wave" rather than a smooth "sine wave". Because of limitations in how quickly voltage levels can change, the output isn't perfectly square. Because of the physical properties of and variations in magnetic media, the not-quite-square wave is rather rounded and wiggly. After being stored in less-than-perfect conditions for 25-30 years, what you read back from an Apple II tape is pretty crazy. Deciphering it can be tricky.
CiderPress provides different algorithms that you can apply:
"Zero Crossing" works very much like the Apple II does, and measures the distance between points where the signal changes from positive to negative. This is usually a good place to start.
"Peak to Peak Width (Sharp)" measure the distance between peaks, which works a little better when the input has been affected by a DC bias (i.e. the entire signal has been shifted up or down, in some cases so far that it no longer crosses zero).
"Peak to Peak Width (Round)" is the same as "Sharp" but with different parameters.
"Peak to Peak Width (Shallow)" is another peak-width variant with different parameters.
Usually one will work better than the others. In some cases, different algorithms may pull out different copies of a program from the same tape. You can use the "start offset" column in the display to see which copy has been found. (Note the start offset may vary by a couple of samples for different algorithms.)
Most cassettes can be recovered, even those that will no longer play on an Apple II. If you find one that can't, you may want to keep the WAV recording anyway, on the off chance that in the future an improved algorithm can be developed that will decode it.
When CiderPress encounters data that it can't interpret, it stops trying to read from that section of the WAV file. For this reason, damaged entries will usually be shorter than undamaged ones. If a file appears to have the correct length but the checksum still doesn't match, it means the signal was sufficiently distorted to make a '0' bit look like a '1' bit, which is actually pretty hard to do. In most cases the decoder will either make an accurate determination or will conclude that the signal is too distorted to process. So far only one case has been found where the checksum was deliberately altered, as part of a copy protection scheme (Sargon II).
If the tape has more than one program on it, you can usually tell if it's multiple copies of the same thing by comparing lengths and checksums. If the checkums say "good" but have different values, you probably have two different programs, or two slightly different versions of the same program.
Saving the Data
The best way to save cassette programs is to a DOS 3.3 disk image, because it's difficult to run Integer BASIC programs under ProDOS. If you're only extracting Applesoft or binary programs, the choice of disk format doesn't really matter.
Click on the file to save and then click "import". This brings up the import options screen. You can change the file name, file type, and for binary files you can alter the start address. The file name you enter will be altered as needed for compatibility with the currently open archive or disk image. If it's the same as an existing file, numbers will be appended to the end of the name.
For binary files, a range of addresses should be shown on the cassette tape or on instructions included with it. It should say something like "800.1A6FR", which is the Apple II system monitor command to read data from the tape and store it in memory (for this example, in locations $0800 through $1A6F, inclusive). CiderPress is able to determine the length accurately, so when you supply the start address CiderPress fills out the end address for you.
You can import files with bad checksums. They will almost certainly be damaged or, more likely, incomplete.
Once the file has been imported, you will be able to view it as you would any other file. Because loading machine language subroutines from disk wasn't an option, many BASIC programs included embedded routines. It's not uncommon for Integer BASIC programs to appear to have only one or two lines of POKEs and HIMEM: statements until they're run for the first time. In some cases, the entire program was written in assembly language and then wrapped in BASIC so that the tape could be loaded with "LOAD" instead of from the monitor. Such programs may not be all that interesting to look at when listed with the BASIC file viewer.
There are three cases where CiderPress currently guesses the file type incorrectly:
A quick examination of the file with the CiderPress file viewer should reveal whether or not it is not a BASIC program. Anything that isn't should be saved as a binary file. Actually making use of them is left as an exercise for the reader -- start with the Applesoft BASIC reference manual, or find an Apple II emulator that emulates the cassette I/O port.
Other Notes
You may be tempted to store copies of the WAV file in MP3 format. This is not recommended. CiderPress cannot decode MP3s, and the decoded MP3 file is less likely to work than the original. However, experiments with converting the sound files in and out of MP3 format suggest that "healthy" files are unharmed at reasonable compression ratios.
You don't need fancy equipment. Connecting the headphone jack of a 15-year-old "boom box" to the microphone jack of a low-cost PC with on-motherboard audio works just fine.