Changes

PSG

575 bytes added, 14 April
/* Input Clock Speed */
The Programmable Sound Generator (PSG) is able to output three separate sound channels (named Channel A, B and C). Each channel can be used to output tones and/or white noise.
 
== Clock Frequency ==
 
The PSG is driven by an external clock at 1MHz provided by the [[Gate Array]]. The AY chip has an internal clock divider by 8 which means that it works internally at 125KHz, outputting 125,000 samples per second for each channel.
== PSG Registers ==
===05h - Channel C Tone Frequency High (4bit)===
The tone (square wave) frequency in Hertz is calculated as follows:
F = 4MHz 1MHz / 64 16 / nn ;with nn in range 1..4095 (nn=0 acts as nn=1)
Possible frequencies are in range from 62500Hz (nn=1) down to approx. 15.26Hz (nn=4095).
The noise frequency in Hertz is calculated as follows:
F = 4MHz 1MHz / 64 16 / nn ;with nn in range 1..31 (nn=0 acts as nn=1)
Noise can be output on all 3 channels, but there is only one noise generator (so all channels share the same noise frequency). The noise generator consists of 17bit shift register, and a 1bit noise level (0=LOW or 1=HIGH). These are updated at the selected frequency as follows:
Envelope step frequency (tone or noise) calculated as follows:
F = 4MHz 1MHz / 64 16 / nn ;with nn in range 1..65535 (nn=0 acts as nn=1)
Depending on the envelope shape, the volume is incremented from 0 to 15, or decremented from 15 to 0. In either case it takes 16 steps to complete, the completion time for 16 steps is therefore:
T = nn*1024 256 / 4MHz 1MHz ;with nn in range 1..65535 (256us .. 16.7 seconds)
=== 0Dh - Volume Envelope Shape (4bit) ===
== Mono and Stereo Output ==
When using the CPC's external stereo jack, channel A is output to the right, channel C is output left, and channel B is output to both left and right, in that case channel B is output through a bigger resistor to prevent that this channel appears loader louder than the others.
Otherwise (when using the built-in speaker), all three channels are mixed at the same intensity. This signal appears to be also sent to the Tape output line also, so a connected Data Recorder could be used to record CPC music also.
2 steps down = half values down.
1Thus, the theoretical formula is f(x) = 2 ^ ((x - 15) / 2) with x between 0and 15.707 , 0 This is the volume table used by BSC:[[File:PSG DAC volume table.5 jpg]] ETO once started testing the output levels (to be fair, 0.303 , 0.25 , 0.1515 , 0.125 ..with a multimeter only) and it was very close to the theoretical value based on the data sheet and how the CPC mixes the channels.
Thus, the theoretical formula is f(x) = 2 ^ ((x See [https://www.cpcwiki.eu/forum/technical- 15) support/ 2) with x between 0 and 15amstrad-cpc-volume-decibel-table/ Discussion on the forum]
== Block Diagram ==
4,605
edits