## DIGITAL SOUND GENERATOR

 MAX EXTERNAL ADDRESSING MEMORY OF 256K

SGS-THOMSON MICROELECTRONICS

- 16 INDEPENDENT CHANNELS
- 12 BIT EQUIVALENT D/A CONVERTER RESOLUTION (DELTA CODING)
- SOUND GENERATED BY READING TABLES CODED IN DELTA CODING OR IN ABSOLUTE VALUES, SITUATED IN AN EXTERNAL MEMORY
- 8 DIFFERENT TABLE LENGHTS AND 8 READING MODES GIVING A TOTAL OF 58 DISTINCT COMBINATIONS
- 16 DIFFERENT MIXABLE LAYERS BE-TWEEN TWO SEPARATE TABLES
- MULTIPLE READING PERMITS INTERPO-LATION BETWEEN TWO ADJOINING SAMPLES ON THE SAME TABLE
- 4 SELECTABLE ANALOG OUTPUTS
- 10 BIT INTERNAL ATTENUATOR WITH GRADUAL AMPLITUDE VARIATION
- ROM ENABLE OUTPUT TO MINIMISE EXTERNAL MEMORY POWER CONSUMP-TION
- POSSIBILITY OF SYNCHRONOUS AND ASYNCHRONOUS FREQUENCY-TABLE CHANGE AT THE END OF THE READ-ING TABLE

The M114A is a 16 channels digital polyphonic, politimbric sound generator.

The M114A must be driven by a microprocessor and needs an external memory.

With this device it is possible to synthesize a large range of sound by simply transcribing the most significant periods of the sound to be reproduced into an external memory and programming a suitable reading sequence for these periods with the use of a microprocessor.

The M114A is realized on a single monolithic silicon chip using low threshold N-channel silicon gate MOS technology and is assembled in plastic DIP.48.



CONNECTION DIAGRAM

| GND(digital)[<br>EA1<br>ROM ADDR 0<br>1<br>1 | 48<br>47<br>8 46 | TESTING EA 0 EA 0 |
|----------------------------------------------|------------------|-------------------|
| EA 1 E 2<br>ROM ADDR 0 I 3<br>J 1 I 4        | 2 47<br>3 46     | EA 0              |
| ROM ADDR 0                                   | 46               |                   |
| 1 1 2 4                                      |                  | BUS STROBE        |
|                                              | 45               | BUS 0             |
| 2                                            | 5 44             | ]   1             |
| 3 ( 6                                        | 43               | 1 2               |
| 40 7                                         | 42               | ] ] 3             |
| ROM ADDR 5[ 8                                | 41               | 1 4               |
| EA 3 E 9                                     | 40               | ) BUS 5           |
| EA 2                                         | 39               | ROM DATA 7        |
| ROM ADDR 6 [                                 | 38               | 6                 |
| 7[12                                         | 37               | ] [5              |
| 8 [ 1;                                       | 3 36             | 1 4               |
| 1 36                                         | 4 35             | 1 1 3             |
| 10[                                          | 5 34             | 1 2               |
| 1 11[ 11                                     | 6 33             | 1.1               |
| ROM ADDR 12[                                 | 7 32             | ROM DATA 0        |
| VDD (digital) [] i                           | 8 31             | ROM ENABLE        |
| CLOCK [1                                     | 9 30             | ANALOG OUT 3      |
| RESET [2                                     | 29               | ANALOG OUT 2      |
| GND(analog) [ 2                              | 28               | ANALOGOUT 1       |
| VDD(analog) [ 2                              | 2 27             | COMMON NODE       |
| VRFF I 2                                     | 3 26             | ANALOG OUT 0      |
| TAB1/TAB2                                    | 4 25             | +12V OUT          |
| 4                                            | 5-9678/1         |                   |

### M114A

| Symbol           | Parameter                       | Value                   | Unit |
|------------------|---------------------------------|-------------------------|------|
| VDD              | Supply voltage                  | -0.3 to 7               | V    |
| VI               | Input voltage                   | -0.3 to $V_{\text{DD}}$ | V    |
| Vo               | Output voltage                  | -0.3 to V <sub>DD</sub> | V    |
| Ptot             | Total package power dissipation | 800                     | mW   |
| T <sub>stg</sub> | Storage temperature             | -65 to 150              | °C   |
| Top              | Operating temperature           | 0 to 70                 | °C   |

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.



### Fig. 1 - Block Diagram



### Fig. 2 - System Configuration



# **STATIC ELECTRICAL CHARACTERISTICS** ( $V_{DD} = 5V \pm 5\%$ , $V_{SS} = 0$ , $T_{amb} = 0/70^{\circ}$ C, $V_{DD}$ DIG = $V_{DD}$ Analog)

|                 |                                            | <b>T</b>                      |         |        |           |          |
|-----------------|--------------------------------------------|-------------------------------|---------|--------|-----------|----------|
| Symbol          | Parameter                                  | lest Conditions               | Min.    | Тур.   | Max.      | Unit     |
| INPUTS: RE      | SET (pin 20), CLOCK (p<br>ATA ST. (pin 46) | oin 19), ROM DATA (pins 3     | 32-39), | DATA E | BUS (pin: | \$ 40-45 |
| VIL             | Low Input Level                            |                               |         |        | 0.8       | V        |
| VIH             | High Input Level                           |                               | 2.2     |        |           | V        |
| 1               | Input Leakage Current                      | VI = VDD to VSS               |         |        | ± 1       | μA       |
| V <sub>OL</sub> | Low Output Level                           | I <sub>OL</sub> = 1 mA        |         |        | 0.4       | V        |
| VOL             | Low Output Level                           | I <sub>OL</sub> = 1 mA        |         |        | 0.4       | V        |
| Vон             | High Output Level                          | ΤΟΗ = 100 μΑ                  | 2.4     |        |           | V        |
| ANALOG OL       | JTPUTS: (pins 26, 28,29, 30                | )), V <sub>REF</sub> (pin 23) |         |        |           |          |
| VREF            | Voltage Reference Output                   | 1 <sub>0</sub> = ± 1 mA       |         | 2.5    |           | V        |
| 0               | Output Current                             | Zero attenuation              | -       | ± 1    |           | mA       |
|                 | (current generator)                        | Max input code to the DAC     |         |        |           |          |
| OWER DIS        | SIPATION                                   |                               |         |        |           |          |
|                 | Supply Current                             | Vpp = 5.25V                   |         |        | 120       | mA       |

\* High impedance means that, when the addresses are off, the digital output is connected with an internal resistive pull-up.



### DYNAMIC ELECTRICAL CHARACTERISTICS

| Symbol                          | Parameter Test Conditions |            | Min. | Typ.  | Max. | Unit |
|---------------------------------|---------------------------|------------|------|-------|------|------|
| CLOCK                           |                           |            | -    |       |      |      |
| tck                             | Input Clock Frequency     |            |      | 4.000 |      | KHz  |
| t <sub>r</sub> , t <sub>f</sub> | Rise and Fall Time        | 10% to 90% |      |       | 20   | ns   |
| twH, twL                        | High and Low Pulse Width  |            | 80   |       |      | ns   |

#### RESET

| tw             | Pulse Width | Clock = 4 MHz | 10 |    | μs |
|----------------|-------------|---------------|----|----|----|
| t <sub>f</sub> | Fall Time   | 10% to 90%    |    | 20 | ns |

### DATA BUS

| tw                  | Pulse Width                | 750 | ns |
|---------------------|----------------------------|-----|----|
| t <sub>set-up</sub> | Set-up Time to DATA Strobe | 0   | ns |
| thold               | Hold time from DATA Strobe | 750 | ns |

#### DATA STROBE

| tw                              | Pulse width                               | 1.5 | 128 | μs |
|---------------------------------|-------------------------------------------|-----|-----|----|
| twr                             | Pulse Width for Internal Reset generation | 128 |     | μs |
| t <sub>f</sub> , t <sub>r</sub> | Pulse and Fall Times                      |     | 100 | ns |

### ROM ENABLE

| tLOW                    |                    |    | 600 | ns |
|-------------------------|--------------------|----|-----|----|
| thigh                   |                    |    | 350 | ns |
| t <sub>set-up</sub> (*) | Set-up Time ROM-EN | 70 |     | ns |

(\*) t<sub>set-up</sub> time means that the data coming from ext. ROM must be stable at least 70 nsec before the rising edge of ROM-EN.

### **PIN FUNCTIONS**

Pin 1 – GND (digital) Digital ground is linked to this pin.

### Pin 21 – GND (analog)

Analog ground is linked to this pin.

### Pin 3-8 and 11-17 - ROM-ADD

13 PUSH PULL type output pins for external memory address. When the output is off (doesn't exist an address) the output is connected to a internal resistive pull-up of about  $10K\Omega$ .

### Pins 2, 9, 10, 47 - EA

These four pins give in output the channel number that is reading the external memory.

When the output is off (doesn't exist an address) the output is connected to a internal pull-up. With these 4 pins the memory is expanded up to 128 Kbyte (8 Kbyte/channel).

### Pin 24 - TAB1/TAB2

It shows which one of the two tables (TAB1 or TAB2) is read.

Pin 24 permits to double the memory so reading 256 Kbyte addressing memory (top configuration).

### Pin 19 – CLOCK (4 MHz)

For correct functioning the generator must be external to the chip and the duty cycle must be very close to 50%.

### Pin 20 - RESET

All channel are reset by reading this pin and the 13 external ROM address outputs toghether with the 4 sound outputs are placed in a high impedence state.

### Pin 22 – Analog power supply

The power supply for all analog parts, i.e. DAC attenuator, etc..., are linked to this pin. It is therefore important that this power supply should be very stable and well smoothed.

The internal power supply chip separation allows a great improvement of signal/noise ratio.



### PIN FUNCTIONS (continued)

#### Pin 23 — Voltage reference (VREF)

VREF is the average value of the DAC output. With  $V_{supply} = 5V$ ,  $V_{REF}$  is nominally 2.5 but could vary by chip to chip ( $\sim 10 \text{mV}$ ).

It's only necessary to filter the VREE output with an external capacitor of some tens of  $\mu F$ (Fig. 3a). To get a voltage suitable to act as VPEE towards external integrator which reconstruct the output signal. Since such a voltage is quite the same than DAC output for a null input code, it automatically conforms itself, following possible differencies between various device instances. It is possible to modify slightly, from the external environment, the obtained VREE value with suitable resistive networks so that the operational integrator offset can be compensated. (Fig. 3b) To improve the VREF it's possible to use a filter as in Fig. 3c.







### Pins 26, 28, 29, 30 - Analog out

These outputs are under current with an output impedance of approximatly 1 K $\Omega$  and the filter or external integrator must have a low input impedance. This means that the voltage between output and V<sub>REE</sub> must be negligeable so as to obtain a good signal linearity.

An integrator together with a low pass filter are necessary if the tables have been DELTA coded. If on the other hand they have been coded in absolute values then only a low pass filter is needed. If the channels do not have to be separated for stereofonic effects or otherwise, a single output may be used routing, by  $\mu P$  programming, all channels to this pin.

### Pin 31 - ROM ENABLE (Low active)

This is a PUSH-PULL-TYPE-OUTPUT and is used to set the external memory is stand-by so as to reduce consumption whenever is not read.

### Pin 32-39 - ROM-DATA

8 input pins for data from external memory.

#### Pin 40-45 - DATA-BUS

6 input pins for data from the microprocessor. 8 of these data groups make up a complete piece of information.

### Pin 46 - BUS-STROBE

A signal from the microprocessor must arrive at this input in order to memorize the present code onto the DATA-BUS

Memorization occurs on both edges.

#### Pin 27 - COMMON NODE

This pin permit the access to the common point placed before the four output switches.

### Pin 18 – Digital Power Supply

The power supply for all digital parts, i.e. counters, memories, etc...., are linked to this pin.

#### Pin 48 – Testing

This pin is utilized only for testing and must be left unconnected by the user.

#### Pin 25 (+12V out)

This pin is the output of an internal 5V/14V -DC-DC converter and it needs an external filtering capacitance (min 100 nF). The performances of DAC and attenuator are very improved with an external zener that clamps the voltage elevator output (see Fig. 4).

Fig. 4

SGS-THOMSON

171.



### M114A

### GENERAL DESCRIPTION

The M114A is a device that allows digital sound synthesis.

The essential system needed consists of a microprocessor, an M114A and an external memory with a maximum of 256 Kbytes.

Sound generation is based on cyclic reading of a table corresponding to a waveform of the timbre to be reproduced.

As the waveform and therefore also the spectrum frequently change, a series of tables of form and frequency appropriate to the sound are cyclically scanned during sound reproduction.

The effect caused by the sudden passage from one table to the next would be unpleasant unless there is such a large number of tables to allow a smooth unnoticeable change from one table to the following.

A favourable compromise between number of tables and quality of sound, that has been implemented in the M114A is the following: A limited number of tables which may even diverge from one another are chosen during an initial phase of analysis after which, during the reproduction phase, two adjoining tables are read simultaneously by extracting a percentage of one and the remaining percentage of the other.

Therefore by starting with 100% of one and zero of the other and successively increasing the second while decreasing the first, so that the sum of the percentages is always equal to 100, there will come a point at which there is a 100% of the second and zero of the first thus having achieved a smooth passage from one table to the next. In the M114A this passage is made up of a maximum of 16 steps.

The tables are stored in an external memory and may be of eight different lengths ranging from 16 to 2048 bytes. The M114A can handle up to a maximum of 256 Kbytes. adjoining samples, that is, in a incremental manner (Delta Coding).

The typical resolution in Delta Coding is 12 bit with a sinusoidal wave coded in a 16-byte table.

A low pass filter at the output is sufficient in the first case to reconstruct the original signal but very long tables would be necessary for low frequency sounds causing a waste of memory.

With the use of an integrator at the output in the second case, the waveforms are coded thus allowing easy interpolation. By simply reading the same data n time and dividing the amplitude of each reading by n, a ramp of n small steps is obtained instead of a large single step.

The value of n may be 1, 2 or 4.

When a waveform is coded in this way (Delta-Coding or incrementally), one must check that the sum or the samples in an entire period is always equal to zero or there would be a continuity which could even saturate the external integrator.

Always the M114A completes the reading of a table before the starting of another. This too avoids saturation of the external integrator.

Whenever it is necessary to suddenly move from one table to another before the read cycle has been completed the FTT forced table termination code must be forwarded to the 8 frequency bits.

It is possible to drive the M114A in such a way that the programmed frequency becomes active immediately, without waiting for the running table to end (asynchronous mode); or that this change of frequency occurs only at the end of the running table (synchrounous-mode).

### ASYNCHRONOUS MODE (SET UP AT RESET)

### MEMORY EXPANSION

With the 13 pins ROM-ADD is possible to address 8 Kbyte of memory.

The 4 pins named EA permit an expansion to 128 Kbyte, while with the pin TAB1/TAB2 we have 256 Kbyte for the top configuration.

The tables may be coded using waveform's absolute value or by the difference between

The frequency-information in a command causes the immediate change of the frequency, while the table and all the other parameters are changed only when the running table has been completely scanned. This type of operation is useful for producing vibrato effects on long tables or vibrato effects on low frequency sounds.

In fact in these cases it is useful to be able to vary continuously the scanning frequency of the same table without being bound to execute the variation of frequency at the end of the table.



### **GENERAL DESCRIPTION** (continued)

### SYNCHRONOUS MODE

The frequency-information in a command causes the synchronous change of table and frequency; this is obtained by delaying the frequency change until the running table has been completely scanned.

This command is very useful in some special effects (glide) because it avoids the reading of the table in part with the old frequency and in part with the new one, thus causing an audible click.

This way-to-operate is useful in the reproduction of deep vibrato on notes placed at the octave boundary, for glide effects and in any case when it is necessary to go beyond the octave boundary without discontinuity.

In fact in these causes it is necessary to schedule in the M114A a length of table and a table frequency scanning completely different from the previous programming.

To avoid clicks it is indispensable to finish the old table with the old frequency before starting the new one with new frequency.

The feature is obtained by acting in global synchronous mode.

The commands for synchronization are:

- SSG Set Global Sync. (F9 Hex Code). Activates the global synchronous mode i.e. sinchronize, also the frequency change with the table end.
- **RSG** Reset Sync. Global (FB Hex Code). This command disables global synchronous mode.
- RSS Reverse Sync. Status (FA Hex Code). This command inverts the synchronism state only for the next programming sequence.

Everyone of these three commands is accomplished by sending a complete programming sequence with F9/FB/FA frequency codes, respectively.

They affect the whole working mode of the device (all its channels).

All the remaining bits are ignored.

Note that the **RSS** command can be obtained by sending eight times the 6-bit data 111110.

As shown in Tab. 3, there are six bit among the control bits that are dedicated to the choice of table pair length and n number of repeated readings of each table.

The frequency of sample readings is synchronous.

This means that the frequency is a whole multiple of the table length. In this way any problem caused by intermodula tion is eliminated but a noise due to "collision" is produced. As there is a single output circuit for all channels, that is interpolator, D/A converter, attenuator, ecc., each time more than one channel requires access to this circuit one or more other channels must wait.

The amount of time necessary for the output circuit to process each table, that is the period of time for which each channel uses the circuit during each sample reading cycle, is of  $2\mu$ s. The delay will therefore be proportional to the number of channels operating simultaneously and to the frequency that they are generating. As these parameters casually vary, so will the delay thus producing a casual alteration of the original waveform.

Simulation has proved that under worst possible conditions the signal/noise ratio due to this problem is around 60dB.

In conclusion let us mention the envelope that has to be controlled by the microprocessor which, at suitable intervals, must forward the desired attenuation coefficient.

There are 64 possible attenuations each with steps of approximately 0.75dB;

These passage from one level to another may be immediate or to gradual increments of 1/256 of the maximum amplitude at a frequency proportional to external table reading frequency.

### OPERATION

The M144A receives from the  $\mu$ P a single programming sequence at a time. This programming sequence is made up of 48 bits.

The  $\mu$ P must send a 48 bit set for every M114A active channel.

Each M114A channel continuously generates the same signal, that is it reads the same table, with the same mixing coefficient, with the same amplitude, ecc., until the microprocessor forwards a different programming sequence (variation of one or more parameters characterising the sound to be generated within a single channel.

Timbre amplitude evolution and any other slight frequency changes must be handled in real-time by the microprocessor.

Often the microprocessor is unable to update the amplitude with sufficient speed. For this reason the M114A carries out a gradual change from one amplitude to another at steps of 1/256 of maximum sample frequency amplitude if the change in level is greater than 128 steps, of 1/2 of this frequency if greater than 64, of 1/4 if greater than 32 and of 1/8 if smaller than or equal to 32 steps.



### GENERAL DESCRIPTION (continued)

Each channel reads two samples at the sampling frequency by taking one from each table, sums them according to the mixing coefficient and forwards the result to the DAC whose suitably attenuated output goes to the previously selected output pin (Fig. 5)

This operation requires  $2\mu s$  and as there is a single output circuit for all channels it is certain that one or more channels will simultaneously request the use of the circuit. Thus a priority order has been assigned to each channel. This order is fixed, channel zero being that of greatest priority followed in order by the others.





When more than one channel is simultaneously active at the output pin there will be an overlap of impulse sequence of each channel.

The example of Fig. 6 shows an output signal with 2 active channels, CH1 has greater priority then CH2:



The signal will change from impulsive to continuous by passing through:

- a low pass filter if the table have been coded using absolute values.
- an integrator if in delta coding

### PROGRAMMING

48 bits subdivided into 8 groups of 6 bits each must be forwarded in order to programme a channel.

A group of 6 bits is memorised on every Data Strobe switch front. As the data bus is read approximately 250ns after transition from the Data Strobe, the 6 data bits may simultaneously arrive with the Data Strobe switch.

### DATA PROGRAMMING ORDER

| N. PIN<br>BYTE | 34              | 35            | 36          | 37        | 38        | 39     |  |  |  |
|----------------|-----------------|---------------|-------------|-----------|-----------|--------|--|--|--|
| 12.0           |                 |               | ATTEN       | UATION    |           |        |  |  |  |
|                | A5              | A4            | A3          | A2        | A1        | AO     |  |  |  |
| bho            | 4 OU1           | TPUTS         | TABLE 1     | ADDRESS   | TABLE 2 A | DDRESS |  |  |  |
| 2.15           | 1               | 0             | 7           | 6         | 7         | 6      |  |  |  |
| bre            |                 |               | TABLE 2     | ADDRESS   |           |        |  |  |  |
| 3.0            | 5               | 4             | 3           | 2         | 1 1       | 0      |  |  |  |
| .th            | TABLE 1 ADDRESS |               |             |           |           |        |  |  |  |
| 4              | 5               | 4             | 3           | 2         | 1 1       | 0      |  |  |  |
| eth            |                 | REA           | DING METHOD | & TABLE L | ENGTH     |        |  |  |  |
| 5              | L2              | L1            | LO          | M2        | M1        | MO     |  |  |  |
| oth            |                 | INTERPOLATION |             |           | IMMEDIATE | OCTAVE |  |  |  |
| 6              | 3               | 2             | 1           | 0         | 0         | 0      |  |  |  |
| ath            |                 | CHANNE        | L NUMBER    |           | FREQU     | ENCY   |  |  |  |
| 7              | 3               | 2             | 1           | 0         | 1         | 0      |  |  |  |
| oth            |                 |               | FREQU       | UENCY     |           |        |  |  |  |
| 8              | 7               | 6             | 5           | 4         | 3         | 2      |  |  |  |



### GENERAL DESCRIPTION (continued)

The following graph shows the time lapse that must be assigned to these signal for correct functioning.

No more than  $128\mu s$  must pass between one Data Strobe transition and the next during transmission of the 8 groups of data or else synchronisation is lost due to the internal auto-

matic reset generated after  $128\mu s$  from the last Data Strobe transition, causing the data to be misinterpreted.

One should wait for at least  $9\mu$ s after the forcedzero-cross command has been given between the last group of data of one instruction and the first group of the next.



The degree of priority of the channel and the number of channels in use at that moment must be taken into account in order to shorten this wait, If there is maximum priority the wait will be a minimum wait of approximately  $2\mu$ s. The same holds if the priority is not maximum but there are no other channels in use. There will however be a maximum wait of  $2\mu$ s for each active channel with greater priority than the channel in question.

If another instruction were to be transmitted without a sufficient wait, there would be the risk of losing the previous instruction of forced trable termination.

The wait is unnecessary after normal commands.

Every data group must be remain present for at least  $1\mu$ s after Data Strobe transition. The 48 bit functions are the following:

- A) 8 address bits for the 1<sup>st</sup> table (ext. ROM)
- B) 8 address bits for the  $2^{nd}$  table (ext ROM) C) 8 frequency bits (4-note and 4-twelfths of note and  $\pm 1$  or 2/1000)
- D) 6 attenuation or amplitude address bits
- E) 4 interpolation bits
- F) 4 channel address bits
- G) 6 reading mode and table length bits (ext. ROM)
- H) 2 bits for choice between four outputs
- 1 bit for a frequency octave change
- J) 1 bit for disable of gradual envelope

While waiting for the present 1<sup>st</sup> table reading to terminate, the above data (not immediately operational) is memorized into the internal RAM1).

The new data is transfered to RAM2 and becomes operational when the addressed channel ends the current table scanning.

An exception is made by the 8 frequency bits and the one varying the frequency octave as they operate immediately (See synchronization).

All data may be made operational by giving the forced-table-termination command.

# 48 PROGRAMMING BIT FOR CHANNEL SELECTION

### 8 Address Bits 1st Table (ext. ROM)

These determine the most significant part of the 13 external memory address bits but according to the table length chosen by the 6 mode bits, some of the least significant of these 8 bits are suitably substituted by the M114A.

In the case of a maximum table length, 2048 bytes, there will only be 2 significant bits to address the table while the remaining 11 will address each single table word.

By already knowing the table length, the programmer will be able to programme the most significant bits needed for table address only and ignore the others.

As the maximum memory that can be handled is of 8Kbytes, if the table has a length of 1Kbyte it is sufficient to program the 3 MSB bits and ignore the other five.



### 48 PROGRAMMING BIT FOR CHANNEL SELECTION (continued)

#### 8 Address Bits 2<sup>nd</sup> Table (ext. ROM)) As above but refering to the second table.

One must consider that the forced table termination refers to the first table and that during table mixing the second table may assume a percentage value of zero while the first table can only assume a minimum percentage value of 1/16 of the maximum value.

### 8 Frequency Bits

The 4 most significant bits characterize one of the 15 available notes with HEX. Codes from 0 to E.

Eleven movements in twelfths of a semitone may be obtained with the remaining 4 bits as well as four  $\pm$  1/1000 and  $\pm$  2/1000 note frequency variations.

These permit the production of: Vibrato, Glissando, Chorus effect etc....

The FF codes correspond to the forced-tabletermination command while FC maintains the previous frequency. F9, FA, FB are synchronisation commands. The F8 code = ROMID is a ROM identification command.

It just sets the programmable counters of the M114A to a very short counting modulo (8 + 0) useless for misical purposes.

The remaining codes are used for testing and therefore must not be used by the operator.

Table 1 shows the 240 frequencies obtainable by setting the external clock to 4MHz and the table length to 16 bytes, with single reading and without inserting an octave divisor. These are the highest octave frequencies obtainable with the M114A.

In practice double, quadruple, etc . . . frequencies may be obtained by writing 2, 4, etc. complete waveform periods in the table.

### **6** Attenuation Bits

These are the addresses for the internal attenuation table.

The contents of this table follow a logarithmic pattern so as to produce a decrease of 0.75dB for each address unit increment. See table 2. The word length is of 10 bits.

After processing by a suitable circuit in order to obtain a gradual amplitude variation the ten outputs of this table are linked to the 10 bit attenuator.

The gradual movement from the present level to that just programmed takes place by increasing or decreasing the 8 most significant bits of the attenuation table contents, with the same frequency with which the external memory tables are being scanned if the difference in level is greater than 128 steps, or with 1/2 of this frequency if greater than 64 steps or 1/4 if greater than 32, or 1/8 if smaller than or equal to 32. In conclusion, the output signal amplitude increases of decreases at each variation by 1/256 of the maximum value.

By setting the bit that deals with the gradual envelope there is an immediate passage from the present level to that programmed.

#### **4 Interpolation Bits**

These define the mixing coefficient between the two waveform tables.

It is possible in this way to sum the  $1^{st}$  waveform percentage with the remaining  $2^{nd}$  waveform percentage thus obtaining a third signal which will be forward to the output.

In greater detail, the operation carried out is the following:

D = (D1 \* (K + 1)/16) + (D2 \* (15 - K)/16)

where :

- D is the data at the input of the DAC (8 bits in complement with 2)
- D1 is the data read from the 1<sup>st</sup> table (8 bits in complement with 2)
- D2 is the data read from the 2<sup>nd</sup> table (8 bits in complement with 2)
- K is a 4 bit interpolation coefficient (from 0 to 15)

Obviously only the first waveform will be output if K = 15.

### **4 Channel Address Bits**

These indicate to which of the 16 M114A channel the remaining 44 bits will be forwarded.

### 6 Mode Bits

These indicate the table couple reading mode (ext. ROM).

For each table there are 58 distinct combinations that include, both table lengths and the number of repeated readings from the same address. (ext ROM). See table n. 3.

The three most significant bits characterize the table lengths while the other three characterise the length ratio between tables and the number of repeated readings.

### 2 Output Address Bits

These indicate to which of the 4 output pins the corresponding channel signal must be forwarded.

This is necessary in order to obtain stereophonic effect or to separate channels used for accompanyment from those of "SOLO", etc. . .

### **1 Octave Divisor Bit**

This is used to pass from one octave to another without changing the table length. If octave divisor bit is set to 1 the programming frequency is divided by two.

### 1 Instant ENVELOPE Change Bit

This orders instant passage from the present amplitude to that programmed.



### TABLE 1 - FREQUENCIES

| NOTE | DEVIATION | -6/12   | -5/12   | -4/12   | -3/12   | -2/12   | -1/12   | -2/1000 | -1/1000 |
|------|-----------|---------|---------|---------|---------|---------|---------|---------|---------|
|      | (Hex)     | 0       | 1       | 2       | 3       | 4       | 5       | 6       | 7       |
| С    | 0         | 1016.78 | 1021.45 | 1026.69 | 1031.46 | 1036.27 | 1041.67 | 1044.39 | 1045.48 |
| C #  | 1         | 1077.01 | 1082.25 | 1087.55 | 1092.90 | 1098.30 | 1103.14 | 1106.81 | 1107.42 |
| D    | 2         | 1140.90 | 1146.79 | 1152.07 | 1158.08 | 1163.47 | 1168.91 | 1172.33 | 1173.71 |
| D #  | 3         | 1209.19 | 1215.07 | 1221.00 | 1226.99 | 1232.29 | 1238.39 | 1242.24 | 1243.78 |
| E    | 4         | 1281.23 | 1287.00 | 1293.66 | 1299.55 | 1305.48 | 1312.34 | 1315.79 | 1317.52 |
| F    | 5         | 1356.85 | 1363,33 | 1369.86 | 1376.46 | 1383.13 | 1389.85 | 1393.73 | 1395.67 |
| F #  | 6         | 1437.81 | 1445.09 | 1451.38 | 1458.79 | 1466.28 | 1472.75 | 1478.20 | 1479.29 |
| G    | 7         | 1523.23 | 1530.22 | 1538,46 | 1545.60 | 1552.80 | 1560.06 | 1564.95 | 1566,17 |
| G#   | 8         | 1614.21 | 1622.06 | 1629.99 | 1638.00 | 1644.74 | 1652.89 | 1658.37 | 1659,75 |
| A    | 9         | 1709.40 | 1718.21 | 1727.12 | 1734.61 | 1743.68 | 1751.31 | 1757.47 | 1759.01 |
| A #  | A         | 1811.59 | 1819.84 | 1829.83 | 1838.24 | 1846.72 | 1855.29 | 1860.47 | 1862.20 |
| В    | В         | 1919.39 | 1928.64 | 1937.98 | 1947,42 | 1956.95 | 1966.57 | 1972.39 | 1974.33 |
| 2C   | С         | 2032.52 | 2042.90 | 2053.39 | 2063.98 | 2072.54 | 2083.33 | 2087.68 | 2089.86 |
| 2C # | D         | 2155.17 | 2164.50 | 2176.28 | 2185.79 | 2195.39 | 2207.51 | 2212.39 | 2214.84 |
| 2D   | E         | 2283.11 | 2293.58 | 2304.15 | 2314.81 | 2325.58 | 2339.18 | 2344.67 | 2347.42 |
|      | F         | For     |
|      |           | Testing |

| NOTE | DEVIATION | 0       | +1/1000 | +2/1000 | +1/12   | +2/12                               | +3/12          | +4/12          | +5/12                        |
|------|-----------|---------|---------|---------|---------|-------------------------------------|----------------|----------------|------------------------------|
|      | (Hex)     | 8       | 9       | А       | В       | С                                   | D              | E              | F                            |
| С    | 0         | 1046.57 | 1047.67 | 1048.77 | 1051.52 | 1056.52                             | 1061.57        | 1066.67        | 1071.81                      |
| C #  | 1         | 1108.65 | 1109.88 | 1111.11 | 1114.21 | 1119.19                             | 1124.86        | 1130.58        | 1135,72                      |
| D    | 2         | 1174.40 | 1175.78 | 1177.16 | 1180.64 | 1186.24                             | 1191.90        | 1197.60        | 1203.37                      |
| D #  | 3         | 1244.56 | 1245.33 | 1246.88 | 1250.78 | 1256.28                             | 1262.63        | 1269.04        | 1274.70                      |
| E    | 4         | 1318.39 | 1319.26 | 1321.00 | 1324.50 | 1331.56                             | 1337.79        | 1344.09        | 1350.44                      |
| F    | 5         | 1396.65 | 1397.62 | 1398.60 | 1403.51 | 1410.44                             | 1417.43        | 1424.50        | 1430.62                      |
| F #  | 6         | 1480.38 | 1481.48 | 1482.58 | 1486.99 | 1494.77                             | 1501.50        | 1508.30        | 1516.30                      |
| G    | 7         | 1567.40 | 1568.63 | 1569.86 | 1576.04 | 1583.53                             | 1591.09        | 1598.72        | 1606.43                      |
| G #  | 8         | 1661.13 | 1662.51 | 1663.89 | 1669.45 | 1677.85                             | 1684.92        | 1693.48        | 1702.13                      |
| А    | 9         | 1760.56 | 1762.11 | 1763.89 | 1768,35 | 1777.78                             | 1785.71        | 1793.72        | 1803.43                      |
| A #  | A         | 1863.93 | 1865.67 | 1867.41 | 1874.41 | 1883.24                             | 1892.15        | 1901.14        | 1910.22                      |
| В    | В         | 1976.28 | 1978.24 | 1980.20 | 1984.13 | 1994.02                             | 2004.01        | 2014.10        | 2024.29                      |
| 2C   | С         | 2092.05 | 2094.24 | 2096.44 | 2103,05 | 2114.16                             | 2123.14        | 2134.47        | 2143.62                      |
| 2C # | D         | 2217.29 | 2219.76 | 2222.22 | 2227.17 | 2239.64                             | 2249.72        | 2259.89        | 2272.73                      |
| 2D   | E         | 2350.18 | 2352.94 | 2355.71 | 2361.28 | 2372.48                             | 2383.79        | 2395.21        | 2406.74                      |
|      | F         | ROMID   | SSG     | RSS     | RSG     | Previously<br>Selected<br>Frequency | For<br>Testing | For<br>Testing | Forced<br>Table<br>Terminat. |

### M114A

### TABLE 2 - ATTENUATION

- N = six bit attenuation code decimal value (0 : 63)
- V = internally decoded linear ten bit value (0 : 1023)

A = theoretical attenuation value in decibels =  $20 \cdot \text{Log} ((V + 1)/1024)$ 

|    | T    |       |    |    |         |    |
|----|------|-------|----|----|---------|----|
| N  | v    | A     | N  | v  | A       |    |
| 0  | 1023 | 0.00  | 32 | 64 | 23.95   |    |
| 1  | 939  | 0.74  | 33 | 58 | 24.79   |    |
| 2  | 863  | 1.48  | 34 | 53 | 25.56   |    |
| 3  | 791  | 2.23  | 35 | 49 | 26.23   |    |
| 4  | 727  | 2.96  | 36 | 45 | 26.95   |    |
| 5  | 667  | 3.71  | 37 | 41 | 27.74   |    |
| 6  | 611  | 4.47  | 38 | 37 | 28.61   |    |
| 7  | 559  | 5.24  | 39 | 34 | 29.32   |    |
| 8  | 515  | 5.95  | 40 | 31 | 30.10   |    |
| 9  | 471  | 6.73  | 41 | 28 | 30.96   |    |
| 10 | 431  | 7.50  | 42 | 26 | 31.58   |    |
| 11 | 395  | 8.25  | 43 | 24 | 32.25   |    |
| 12 | 363  | 8.98  | 44 | 22 | 32.97   |    |
| 13 | 335  | 9.68  | 45 | 20 | 33.76   |    |
| 14 | 307  | 10.43 | 46 | 18 | 34.63   |    |
| 15 | 283  | 11.14 | 47 | 16 | 35.60   |    |
| 16 | 259  | 11.91 | 48 | 14 | 36.68   |    |
| 17 | 235  | 12.75 | 49 | 13 | 37.28   |    |
| 18 | 215  | 13.52 | 50 | 12 | 37.93   |    |
| 19 | 199  | 14 19 | 51 | 11 | 38.62   |    |
| 20 | 183  | 14.91 | 52 | 10 | 39.38   |    |
| 21 | 166  | 15.75 | 53 | 9  | 40.21   |    |
| 22 | 152  | 16.51 | 54 | 8  | 41.12   |    |
| 23 | 140  | 17.22 | 55 | 7  | 42.14   |    |
| 24 | 128  | 17.99 | 56 | 6  | 43.30   |    |
| 25 | 117  | 18.77 | 57 | 5  | 44.64   |    |
| 26 | 107  | 19.54 | 58 | 4  | 46.23   |    |
| 27 | 98   | 20.29 | 59 | 3  | 48.16   |    |
| 28 | 90   | 21.03 | 60 | 2  | 50.66   |    |
| 29 | 83   | 21.72 | 61 | 1  | 54.19   |    |
| 30 | 76   | 22.48 | 62 | 0  | 60.21   |    |
| 31 | 69   | 23.30 | 63 | 0  | 60.21 + | ST |

### TABLE 3 - READING MODES

| MODE |     | LEN   | IGTH | READ N. |    |
|------|-----|-------|------|---------|----|
| М    | L   | T1    | Т2   | T1      | Т2 |
| 000  | 000 | 16    | 16   | 2       | 2  |
| 000  | 001 | 32    | 32   | 2       | 2  |
| 000  | 010 | 64    | 64   | 2       | 2  |
| 000  | 011 | 128   | 128  | 2       | 2  |
| 000  | 100 | 256   | 256  | 2       | 2  |
| 000  | 101 | 512   | 512  | 2       | 2  |
| 000  | 110 | 1024  | 1024 | 2       | 2  |
| 000  | 111 | 2048  | 1048 | 2       | 2  |
| 001  | 000 | 16    | 16   | 1       | 1  |
| 001  | 001 | 32    | 32   | 1       | 1  |
| 001  | 010 | 64    | 64   | 1       | 1  |
| 001  | 011 | 128   | 128  | 1       | 1  |
| 001  | 100 | 256   | 256  | 1       | 1  |
| 001  | 101 | 512   | 512  | 1       | 1  |
| 001  | 110 | 1024  | 1024 | 1       | 1  |
| 001  | 111 | 2048  | 2048 | 1       | 1  |
| 010  | 000 | 16    | 16   | 4       | 4  |
| 010  | 001 | 32    | 32   | 4       | 4  |
| 010  | 010 | 64    | 64   | 4       | 4  |
| 010  | 011 | 128   | 128  | 4       | 4  |
| 010  | 100 | 256   | 256  | 4       | 4  |
| 010  | 101 | 512   | 512  | 4       | 4  |
| 010  | 110 | 1024  | 1024 | 4       | 4  |
| 010  | 111 | 1024* | 1024 | 4       | 4  |
| 011  | 000 | 16    | 16\$ | 1       | 1  |
| 011  | 001 | 32    | 16   | 1       | 1  |
| 011  | 010 | 64    | 32   | 1       | 1  |
| 011  | 011 | 128   | 64   | 1       | 1  |
| 011  | 100 | 256   | 128  | 1       | 1  |
| 011  | 101 | 512   | 256  | 1       | 1  |
| 011  | 110 | 1024  | 512  | 1       | 1  |
| 011  | 111 | 2048  | 1024 | 1       | 1  |
|      |     |       |      |         |    |

| МС  | DE  | LENGTH |      | READ N. |    |
|-----|-----|--------|------|---------|----|
| Μ   | L   | T1     | Т2   | Т1      | Т2 |
| 100 | 000 | 16     | 8    | 1       | 2  |
| 100 | 001 | 32     | 16   | 1       | 2  |
| 100 | 010 | 64     | 32   | 1       | 2  |
| 100 | 011 | 128    | 64   | 1 .     | 2  |
| 100 | 100 | 256    | 128  | 1       | 2  |
| 100 | 101 | 512    | 256  | 1       | 2  |
| 100 | 110 | 1024   | 512  | 1       | 2  |
| 100 | 111 | 2048   | 1024 | 1       | 2  |
| 101 | 000 | 16     | 16S  | 1       | 1  |
| 101 | 001 | 32     | 165  | 1       | 1  |
| 101 | 010 | 64     | 16   | 1       | 1  |
| 101 | 011 | 128    | 32   | 1       | 1  |
| 101 | 100 | 256    | 64   | 1       | 1  |
| 101 | 101 | 512    | 128  | 1       | 1  |
| 101 | 110 | 1024   | 256  | 1       | 1  |
| 101 | 111 | 2048   | 512  | 1       | 1  |
| 110 | 000 | 16     | 4    | 1       | 4  |
| 110 | 001 | 32     | 8    | 1       | 4  |
| 110 | 010 | 64     | 16   | 1       | 4  |
| 110 | 011 | 128    | 32   | 1       | 4  |
| 110 | 100 | 256    | 64   | 1       | 4  |
| 110 | 101 | 512    | 128  | 1       | 4  |
| 110 | 110 | 1024   | 256  | 1       | 4  |
| 110 | 111 | 2048   | 512  | 1       | 4  |
| 111 | 000 | 16     | 16\$ | 1       | 1  |
| 111 | 001 | 32     | 16\$ | 1       | 1  |
| 111 | 010 | 64     | 16\$ | 1       | 1  |
| 111 | 011 | 128    | 16   | 1       | 1  |
| 111 | 100 | 256    | 32   | 1       | 1  |
| 111 | 101 | 512    | 64   | 1       | 1  |
| 111 | 110 | 1024   | 128  | 1       | 1  |
| 111 | 111 | 2048   | 256  | 1       | 1  |

Repetitions

\$ Exceptions