EP0989541A1 - Système de synthèse sonore permettant d'obtenir en sortie une suite d'échantillons électriques - Google Patents
Système de synthèse sonore permettant d'obtenir en sortie une suite d'échantillons électriques Download PDFInfo
- Publication number
- EP0989541A1 EP0989541A1 EP99402316A EP99402316A EP0989541A1 EP 0989541 A1 EP0989541 A1 EP 0989541A1 EP 99402316 A EP99402316 A EP 99402316A EP 99402316 A EP99402316 A EP 99402316A EP 0989541 A1 EP0989541 A1 EP 0989541A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- value
- cell
- memory
- during
- cellule
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Withdrawn
Links
Images
Classifications
-
- G—PHYSICS
- G10—MUSICAL INSTRUMENTS; ACOUSTICS
- G10H—ELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
- G10H7/00—Instruments in which the tones are synthesised from a data store, e.g. computer organs
- G10H7/08—Instruments in which the tones are synthesised from a data store, e.g. computer organs by calculating functions or polynomial approximations to evaluate amplitudes at successive sample points of a tone waveform
- G10H7/12—Instruments in which the tones are synthesised from a data store, e.g. computer organs by calculating functions or polynomial approximations to evaluate amplitudes at successive sample points of a tone waveform by means of a recursive algorithm using one or more sets of parameters stored in a memory and the calculated amplitudes of one or more preceding sample points
Definitions
- the present invention relates to a sound synthesis system allowing obtain a series of electrical signals as output, which after conversion digital / analog can be applied to one or more transducers to give result in the production of an audible spectrum.
- the invention relates to a system sound synthesis of the type indicated above, which can be implemented using a plug-in card so that it can be inserted into a personal computer giving a very wide and varied capacity for sound production.
- the most common units currently used for sound synthesis are designated by the English word “Wave Table” or "FM”.
- the unit “Wave Table” denotes a unit in which sound synthesis is carried out using groups sound samples rigidly pre-recorded in a memory which can be present on any known recording medium, internal or external to the device.
- an "FM" unit uses two oscillations, one of which is a carrier frequency modulated by the other oscillation. This principle allows to generate more complex oscillations from a limited number of oscillations.
- the signal obtained depends on the frequency ratios and the amplitude of the modulants.
- the harmonics are the side bands of frequency modulation. Those are products with an equidistant frequency ratio proportional to the ratio between the frequency of the modulant and that of the carrier.
- the amplitude of the modulant determines the many of these harmonics.
- the amplitudes of the harmonics produced cannot be freely determined and they follow a shape akin to a curve interference.
- Wave Table and FM units have the disadvantage offer very little flexibility as regards the composition of the final sound spectrum, the parameters characterizing the successive samples (amplitude, frequency and phase, in particular) being mostly predefined without the possibility of modifications.
- the object of the invention is to provide a sound synthesis system devoid of disadvantages of the earlier units briefly described above.
- said first, second, third, fourth, fifth and sixth means are used in sharing of time in successive work cycles to determine relative values to said cells in said parameter, designation value and accumulation.
- FIG. 22 illustrates an example of detailed implementation of the synthesis unit according to the invention.
- FIG. 1 is a symbolic diagram illustrating, in the form of blocks functional, the main circuits of the sound synthesis device according to the invention.
- this includes three basic units which are a management computer called below CPU.
- This unit can be a personal computer running on a program sound synthesis management previously recorded, on a floppy disk for example, and working with any type of usual exploration program like 'Windows' TM, for example.
- the management unit can be formed by any other device allowing to execute a program dedicated to the management of the device according to the invention.
- the CPU is connected to a functional interface I which on the one hand ensures the exchange of messages between the CPU and a synthesis unit (called SYNT by the continued) and secondly the timing of all sound synthesis operations, intended to be implemented in this SYNT unit. This delivers the sound signal desired on an output S.
- a functional interface I which on the one hand ensures the exchange of messages between the CPU and a synthesis unit (called SYNT by the continued) and secondly the timing of all sound synthesis operations, intended to be implemented in this SYNT unit. This delivers the sound signal desired on an output S.
- the SYNT synthesis unit comprises a number of hardware functional blocks which will be described later in detail with reference to the figures, the figures concerned by the blocks being indicated in each of them.
- the SYNT unit comprises two main functional units EF1 and EF2, surrounded by mixed and charged lines basically establish parameters defining the characteristics of the samples sound to produce, and the other to implement these parameters by applying them to so-called zero level samples to generate the level samples superiors .
- each block contains a word or key expression intended to indicate its global function.
- FIGS. 3 and 4 show a symbolic diagram of the interface I of the sound synthesis according to the invention, the CPU being here symbolized by the rectangle 1.
- the signals generated in this interface I are represented in FIGS. 3 and 4, the scale of Figure 3 being smaller than that of Figure 4.
- Interface I includes a crystal oscillator 2 which provides a clock signal of CLK base (see for forms of signals and their temporal relationships Figures 3 and 4) to a three-bit binary counter 3.
- the three outputs Q0, Q1 and Q2 of this counter 3 constitute a CCAL signal described later and they are also applied to a binary decoder 4 decoding the three-bit signal applied to it on eight outputs C0 to C7.
- the outputs C0 to C3 of this decoder 4 clock four sub-periods P2_AMP, P2_FRE, P2_PHA and P2-FLT of a period P1 which is clocked via a gate AND 5.
- the outputs C4 and C5 of the decoder 4 respectively clock the sub-periods P3 and P4, while outputs C6 and C7 are applied to an AND gate 6 by through which the PCPU subperiod is clocked.
- the period P1 and the sub-periods P3, P4 and P2_AMP, P2_FRE, P2_PHA and P2-FLT have actually all the same duration, but as the time intervals during which they determine an activity in the SYNT unit, are fixed by the duration of their low level in each period. We will therefore designate these low level durations by the term "active pulse" in what follows, the active pulses being phase shifted compared to others in the various sub-periods.
- the output C0 of the decoder 4 is also applied to the RESET input of a flip-flop S-R 7 to the SET input from which a CS_CPU signal from the CPU and representing the access requests of the latter.
- This toggle provides periodically a signal ATTENTE_CPU on a terminal 8 to put the CPU in wait during a request expressed by a signal CS_CPU, during the cumulative duration active pulses of the P2_AMP, P2_FRE, P2_PHA, P2_FLT, P3 and P4.
- the CPU is authorized to transmit addresses, data and read / write commands to the synthesis unit SYNT. It can also receive data during the active pulses of the sub-periods PCPU.
- N 192 has been chosen, another number of cells being possible.
- the counter 9 is controlled by the signal C7 of the decoder 4 which advances it by one unit at the end of each period P1 and it is synchronized with the signal CLK of the base clock 2. Its output Q n delivers a cell base address ADR_BASE to a cell address selection block 10 for determining the succession of cell base addresses (0 to 191 in the example).
- the CPU can communicate via the interface with the SYNT unit.
- the PCPU output of AND gate 6 and the signal access request CS_CPU are applied to an OR gate 11 whose output can activate a SEL selection signal from block 10.
- the logic state of this signal selectively determines whether it is the output of counter 9 which constitutes the address of the active cell at an instant considered, or if it is the management program running in the CPU which provides this address.
- the output of counter 9 is passed from input ADR_BASE from block 10 to the shared AC output (instant cell address) of this block.
- the signal SEL activates two interface blocks 13 and 14.
- the cells of the SYNT unit are in fact materialized fleetingly during successive PCAL sequences (composed of signals P1, P3 and P4; Figure 4) preparation of so-called "first level" samples.
- PCAL sequences PCAL together make up a P cycle during which the successive first level sample calculations for all cells.
- cycle P therefore presents 192 PCAL sequences.
- successive, cycle P being executed at the sound synthesis sampling frequency which is for example 44,100 Hz. This is the frequency of the ACT signal also shown in Figure 4.
- the materialization of cells is carried out by fleetingly and cyclically storing calculated cell data, at memory locations of a plurality of memories assigned to calculation and / or control functions and provided materially in the SYNT unit.
- Each of these memories contains as many of locations there are cells in the SYNT unit.
- information in the form of addresses or data can also selectively be written to memory locations regarding cells respective from the CPU during the PCPU subperiod following each sequence PCAL.
- the memories in question can receive information the regarding to store this information at their storage location having address 0, or deliver this data when it leaves so that this data can be processed later. Then, during the next PCAL sequence the same operations or other similar operations may be carried out with regard to cell 1 at the locations having address 1 in the memories, and so on until cell # 191 has been processed, after which the process begins again with cell # 0.
- Memories can be loaded (write), read and unloaded from different ways including the CPU 1.
- the SYNT unit materializes the 192 cells by the contents of the 192 memory locations dedicated to this task, each cell being "composed" of the locations with the same address of these memories.
- the content of each cell may or may not vary from one cycle to another, depending on the characteristics first level samples to be produced.
- the audio samples to be produced can be compounds from several sources which can in particular be mixed with great flexibility.
- Blocks 13 and 14 allow to transfer to the SYNT unit respectively addresses, data and read / write commands, provided these blocks are activated by the SEL selection signal from gate 11 and that the output signal WAITING_CPU of flip-flop 7 is deactivated.
- This signal being active during the pulse active from the PCPU subperiod, the management program executed in the CPU can act on the SYNT unit, naturally as far as this program prescribes such action during the PCAL sequence considered.
- Block 12 can receive from the CPU on an input 12a addresses ADR_CPU, on an input 12b a read command signal RD_CPU, on an input 12c a write command signal WR_CPU and on an input 12d the selection signal CS_CPU.
- the output 12e of block 12 makes it possible to transfer address values to several destinations, namely block 10, block 14 for reading / writing selection of memories and other elements of the SYNT unit, which will be described later.
- Block 13 has an input 13a for receiving data from the CPU, 13b read command input, 13c write command input and an output 13e for transferring data to various elements of the SYNT unit such as described below. Data transfer can be bidirectional.
- Block 14 includes an input 14a for receiving read / write addresses from block 12, a read control input 14b receiving the signal RD_CPU, a write control input 14c receiving the signal WR_CPU and a selection input 14d connected to the output of door 11.
- This block includes also outputs 14e and 14f connected respectively to a control bus of read 15a and to a write control bus 15b, these two buses carrying selectively read / write command signals to all SYNT unit memories. The identifications of these signals are given in full in FIG. 2 and are found in the corresponding places of the other figures still at to describe.
- the output of door 5 is logically combined with the output of the block of address selection 10 in a NAND gate 16 providing the ACT output signal which is the sampling frequency of the SYNT unit.
- FIG. 5 represents a circuit for developing parameter values designated globally by reference 20. This circuit is part of the SYNT unit.
- the SYNT unit comprises a plurality of memories, some of which appear in FIG. 5.
- each memory is symbolized by a square with associated data inputs and / or outputs and a smaller rectangle associated with an address entry, an entry for write command and / or a read command input.
- each square we indicated the number of locations in the memory in question in the example considered.
- FIG. 5 represents the hardware of a circuit 20 development of a parameter that is repeated four times in the SYNT unit ( Figure 6).
- each circuit 20 (incorporated respectively in blocks 20A to 20D) forms one of four AMPLITUDE, FREQUENCY, PHASE or FILTER parameters that can be assigned to the calculation of first level samples.
- the corresponding parameter value VAL (which are respectively designated by AMP, FRE, PHA and FLT) obtained after the pulse activates the respective P2_AMP, P2_FRE, P2_PHA, P2-FLT sub-periods appears on an output terminal 21 of circuits 20A to 20D.
- each circuit 20A to 20D for developing parameters includes a memory M1 in which the basic value of the AMPLITUDE, FREQUENCY, PHASE or FILTER parameter of cells. These values are received from the CPU via output 13e (figure 2) during the pulses active in the PCPU subperiod during which the CPU is authorized to access SYNT unit.
- a memory M2 is intended to store increment values of the parameter in case it has to undergo a change for the elaboration of a sample given with respect to the same parameter of a previously developed sample.
- the increment value is also supplied by the CPU via output 13e of the interface block 13.
- the outputs of memories M1 and M2 are applied to a calculation unit 22 intended to implement the following calculation function: in which PAR P not is the current parameter value of the cell considered during the current PCAL sequence or the initial parameter value, PAR P n-1 is the parameter value developed during the previous PCAL sequence for this cell and INC P not is the increment brought to the current value of the parameter compared to the previous value. It should be noted that this calculation makes it possible to introduce an automatic interpolation between different successive parameter values to attenuate value jumps, if necessary.
- the output of memory M2 is applied to a first arithmetic unit U1 responsible for performing on variables A and B which are applied to it the operation B ⁇ A, the variable B being supplied by an arithmetic unit U2 which performs on its variables input A and B operation A-B.
- the variable A of this arithmetic unit U2 is each times the output of the difference between the new value stored in the memory M1 of the parameter and its current value stored in a memory or accumulator M3.
- the result of the calculation performed in the arithmetic unit U1 is applied, as variable A, to another arithmetic unit U3 which performs the operation A + B on its input variables.
- the input variable B of this arithmetic unit U3 comes from the memory M3 which is intended to temporarily store and for each cell the parameter value PAR P n-1 , i.e. the parameter value calculated during the previous PCALP sequence.
- the memory M3 is therefore connected by its data input to the output 21 and by its data output to the variable input B of the calculation unit U2. Writing the PAR P value n-1 in the memory M3 occurred during the active pulse of the sub-period P4 of the previous PCAL sequence.
- This part includes a memory M4 controlled in read / write by the R3 and W3 signals with regard to amplitude, frequency, phase or filtering.
- This memory stores, if necessary, a modification of the parameter value for one or more of the 192 cells depending on the AC address signal. Its output is connected to an address buffer 23 whose input values can pass to the output under the command of the respective active pulse of the P2_AMP sub-periods, P2_FRE, P2_PHA or P2_FLT.
- the values thus transmitted through buffer 23 are applied to a distributor 25 responsible for selecting one of a plurality of sources of values of parameter intended for the elaboration of the first level samples by the cells.
- This distributor 25 will be described later with reference to FIG. 12.
- the signals corresponding to these parameter values are sent in a flip-flop 24 activated in writing on the active pulse of the P2 sub-period concerned, depending on the nature of the parameter to be modified.
- the output of flip-flop 24 is connected to input A an arithmetic unit U4 which allows to perform selectively a combinatorial calculation such as a sum calculation or a product calculation on the values applied to its starters.
- Input B of this arithmetic unit U4 is connected to a flip-flop 26 whose input is connected to the output of the arithmetic unit U3 and which is activated at during the active pulse of the P3 subperiod.
- the part of the circuit of FIG. 5 which has just been described allows for example to apply a vibrato to a synthesized sound by varying the value of frequency of the samples from which this sound is formed.
- Figure 6 a diagram illustrating the sets of input signals and output which are applied, respectively produced, by the four circuits 20A to 20D each of which is identical to the circuit 20 for developing a parameter in FIG. 5.
- block 20A is assigned to the AMPLITUDE parameter, blocks 20B, 20C and 20D being respectively assigned to the FREQUENCY, PHASE and FILTER parameters.
- the write and read signals R1 / W1, R2 / W2 and R3 / W3 are applied to memories M1, M2 and M4 of FIG. 5; they come respectively from the buses of command 15a and 15b in FIG. 2.
- Each block is selectively timed for each PCAL sequence at the moment when the active pulse of the subperiod corresponding is produced.
- Each block also receives input data on the DCPU bus and the AC signal of cell number or address (see Figure 2).
- the exits AMP, FRE, PHA and FLT of each block are dealt with in other parts of the unit SYNT as described below; the same is true of the signals passing over the terminals of blocks 20A to 20D.
- Each corresponding first level sample during a sequence PCAL to one of the cells, must be formed from a zero level sample which must be specifically identified and taken from one of the zero level sample sources. But, this zero level sample must also be assigned a time value so that he can contribute to the elaboration of the first level sample to which he goes to belong.
- the system thus comprises means, represented in FIG. 7, which is intended to generate a binary value, called "zero level sample designation value” or more briefly "value
- This designation value symbol POS-X
- This first binary value represents a time interval expressing the ratio between the frequency of any cell in relation to a basic frequency of which it is a multiplying factor.
- the increment must be double to address the same table of 1024 points per cycle or 20.43345.
- the ACT signal corresponds to the sampling rate, in the occurrence of a frequency of 44 100 Hz. It will therefore be noted that the value POS_X inherently represents a time value of sample positioning on the time axis, while at the same time it designates these samples by evolving constantly since it is at the same time a memory address containing the level zero samples.
- the designation value POS_X is calculated in a calculation circuit 30 of selection values shown in Figure 7.
- the divider 31 adds in the unit U5 a value 1 to the integer value 10 at the rate of 21678 times per hundred thousand pulses of the ACT signal.
- the value added to the output of the unit U5 will be equal to 11, 21678 times over one hundred hundred thousand pulses of this ACT signal.
- the output of the arithmetic unit U5 is applied to one of the SEL B inputs of a multiplexer 32 which, under the control of a signal SC_ETR, makes it possible to select, from one PCAL sequence to another, the type of growth of the POS_X value as a function of several use cases of zero level sample sources, as we will see below. In one of these cases, the growth of the POS_X value is constant (0001 for example) and applied to connection 33.
- the output of block 32 is connected to a block of determination of sign 34 which under the control of a signal SGN affects a signal positive or negative at the value extracted from memory M5. Note that if the negative signal is selected, the synthesized sound sequence can be played backwards in the time, because the value POS_X will then be decremented from one period P1 to another, from the quantity determined in the calculation circuit 30 instead of being incremented.
- An M5 accumulation memory loaded by the active pulse of the subperiod P4 stores for all cells the previous POS_X value.
- the output of the sign determination block 34 is applied to the input B of a arithmetic unit U6 whose input A is connected to the output of memory M5.
- This unit U6 adds up its two input variables.
- the result is sent to a multiplexer 35 which allows, under the control of a CD_INIT signal, to address its output, either the output of the arithmetic unit U6, or an initialization value lNlT_X still to be described from which the POS_X value will be incremented.
- the value lNlT_X can be zero in some cases.
- the output of multiplexer 35 is connected to a bistable synchronization flip-flop 36 in which the value is written by the active pulse of the P3 subperiod.
- the output of this flip-flop 36 is connected on the one hand to the data input of memory M5 and on the other hand as variable B, at one of the inputs of a unit U7 arithmetic which receives on its other input the PHA value coming from the circuit for developing parameters 20 (block 20C of FIG. 6).
- the result of the calculation in the arithmetic unit U7 (sum of its input variables A and B) is the value POS_X.
- the SYNT unit materializes in time sharing a number n of cells in which prime sample values are developed level from zero level sample values assigned parameters of predetermined amplitude, frequency, phase and filtering.
- the SYNT unit also has means to materialize in time sharing a number m of sets of cells which, like these are represented by values stored at locations of memory of a plurality of memories.
- m 64 so that there are 64 sets, the locations of each of the memories assigned to this task therefore also being 64 in number.
- the sets are intended to bring together or more precisely to combine first level sample values developed in a predetermined number of cells at the end of each P sampling cycle to produce so-called samples second level.
- FIG. 8 represents a circuit 40 for allocating first level samples allowing to assign predetermined cells to a predetermined set of the plurality of sets of the SYNT synthesis unit.
- the forms of the appearing signals in this allocation circuit 40 are shown in FIGS. 9 and 10.
- the second level sample value of a set selected for this time is represented by the signal ACC_ENS which is found at the top right in Figure 8 and which constitutes the output of the allocation circuit 40.
- This value is fleetingly found at the address corresponding to this set of an M6 accumulator memory (at 64 locations in the example) sent by the signal AACC_ENS and whose input from data is connected to the output of an arithmetic unit U9 responsible for performing the multiplication of its inputs A and B.
- Writing to memory M6 is controlled by through the active pulse of the P4 subperiod. It reaches him through an AND gate 41 also receiving a signal C_ENS designating the last cell whose the first level sample which has just been calculated must, for a given allocation, be incorporated into the second level sample value to be provided by this together.
- the arithmetic unit U9 receives on its input A the stored output data in a flip-flop 42 (see FIG. 9) which receives this input data from an arithmetic unit U10. It performs the sum of its values applied to its inputs A and B.
- the writing of the data in the flip-flop 42 takes done during the active pulse of the P3 subperiod.
- the output of this flip-flop 42 is also connected to an intermediate accumulation memory M7 (64 locations) in which data can be written during the pulse active of the P4 subperiod. On output, this data is applied to input B of the arithmetic unit U10.
- This AND gate makes it possible to add the sample value of the cell current, if bit C_CSEL is '1'. Otherwise, the value is not added overall.
- the input A of the arithmetic unit U9 receives a value constituted by the sum of all ACC_CEL accumulated values of cells assigned to a given set, sum which appears at the exit of rocker 42, as represented in figure 9.
- the arithmetic unit U9 receives on its input B an amplitude value coming from an M8 memory (64 locations) in which values are stored amplitude which can be entered by the management unit CPU under the command of the write signal W_ENS_AMP ( Figures 2 and 8).
- the amplitude value can be read in the memory M8 under the control of the signal R_ENS_AMPL to adjust the value calculated amplitude of the current set considered.
- the data input of an M9 memory (192 locations) is connected to the block 13 (figure 2) to receive from the CPU address values specifying for each cells to which set this cell will belong to participate in the production a second level sample. Writing these address values into this memory M9 is done at the addresses corresponding to the cells respectively concerned.
- FIG. 9 illustrates by a simple example this writing in the memory M8 for the first five cells with the numbers 0 to 4 of a P cycle.
- the cells 0, 1 and 2 will belong to set 0 and cells 3 and 4 to set 1.
- the writing and reading of the memory M9 are carried out under the control of the signals W_ENS_CEL and R_ENS_CEL.
- the same value determines the address of the M7 memory which accumulates this data under the control of the active pulse of the subperiod P4.
- Each address value written in memory M9 is accompanied by a bit which, in the example, is the most significant bit (MSB). In this case, it is at 1 when during the following period P1, the calculation for the current set must continue to be done for this set. On the other hand, when this bit is at one, this means that the calculation of the current set is finished.
- the corresponding signal is designated by C_ENS which, as shown in Figure 9, is for example one for the cells 0, 1 and 3, and zero for cells 2 and 4.
- the signal C_ENS is used to command the writing in memory M6 of the cumulative value a second level sample belonging to a current set.
- the writing of the amplitude data of the sets in the memory M8 can be do to addresses which can come either from memory M9 (A_ENS), or directly of block 10 ( Figure 2).
- the address is selected using a multiplexer 43.
- the address AC passes through this multiplexer 43, when one or other of the W_ENS_AMP or R_ENS_AMP signals is zero. Otherwise it is the address A_ENS which past.
- the allocation circuit 40 also includes a part for phasing the cells and sets.
- This phasing and the triggering of a selected set are non-synchronously controlled by a W_DEC signal from block 14 (figure 2).
- the signal W_DEC commands the writing of the address of the assembly to be put in phase in a flip-flop 44, receiving this address from the CPU.
- the signal W_DEC is synchronized with the ACT sampling signal via a lock 45, three flip-flops 46, 47 and 48 and a NAND gate 49.
- the signals appearing in this part of the circuit are represented on figure 10 which allows you to understand how it works.
- the Q bar output of flip-flop 46 provides an ACT_lNlT signal which activates a comparator 50 intended to compare two address values, namely that coming from of the memory M9 and that which is delivered by the rocker 44. In the event of equality of the two address values a cell initialization signal C_INIT is issued. This signal is used in particular in the circuit 30 for calculating time increments of FIG. 7 for the multiplexer 35.
- the allocation circuit 40 of FIG. 8 also makes it possible to supply the signal ENS_FRE also used in the computation circuit of figure 7.
- a multiplexer 51 makes it possible to selectively send to a memory M10, the A_ENS address values or AC address values depending on signal status write / read W_ENS_FRE and R_ENS_FRE provided by block 14 of figure 2 for write in this memory the value ENS_FRE coming from the CPU to the address of the current set having to work with this interval value.
- FIG. 11 represents a circuit 60 for allocating second level samples allowing to selectively group the second level samples on outputs 0 to q to generate third level samples which, in the example described, are SYNT unit output samples. There are 16 outputs in the example.
- An M11 memory (64 addresses, one per set on the six weight bits weak signal AC) is intended to contain sample distribution values of second level ACC_ENS. These distribution values are provided by the CPU under the command of a W_SORTIE signal and they can be read under the command of a signal R_SORTIE to be transferred to a distribution control bus 61. The bits of these values are applied respectively to logic gates 62-0 to 62-q which also receive the signal C_ENS and the active pulse of the sub-period P4.
- the values of the second level samples ACC_ENS are applied respectively to arithmetic units U11-0 to U11-q in which values previous second level samples can be added to values common such samples.
- the sums calculated in these arithmetic units are temporarily stored in flip-flops 63-0 to 63-q in which the results of arithmetic unit calculations can be written under the command of outputs of the respective doors 62-0 to 62-q.
- the contents of the flip-flops can be deleted either by the sampling signal ACT which also provides the synchronization signal EXT_SYNC for an external device (converter digital / analog, processor, etc.) to read outputs 63-0 to 63-q.
- each first level sample can be calculated by acting on the cell considered from different sources.
- Source selection values stored for cells respectively in this memory M4 are transferred to an output of a flip-flop 23 activated on the active pulse of sub-period P2, output at which appear ADR_CTR source selection command values when they need to respectively be available to operate the selection of a change in value of parameter for the current cell.
- Figure 12 gives more details of the block of selection 25 which is common to blocks 20A to 20D of FIG. 6 and which is controlled by the selection values ADR_CTR.
- a source for modifying parameter values can be made up selectively either by another cell, or by a set, or again by an external input to the SYNT unit as appropriate (detection signal of parameter), the term "input” here designating a group of blocks intended to adapt the external signals for operation in the SYNT unit.
- the source or input selection block 25 thus comprises a first selection logic 25a whose control signal is formed by bits 1 to 5 of greatest weight of the values ADR_CTR memorized in the memory M4 (figure 5). These most significant bits are used to transmit from the input to the output of the selection logic, selectively for each cell, one of four values of modification of sample which are respectively the signals ACC_CEL, ACC_ENS and ACC_DET and lN_CEL generated from first level samples (cell) or second level (set), of a detector on signal input (amplitude, frequency or band) and a signal input (see for more details later).
- the output signal thus selected is called DATA_CTR which can be used as a parameter value change value during the subsequent calculation of a first level sample of any cell.
- ADR_CTR value bits are also applied to one second selection logic 25b which distributes the sources of modification values in four cases.
- the first of these cases concerns the accumulation for cells in a accumulation memory M13 using an AACC-CEL address (figure 13), in from a multiplexer 25-1.
- the address is normally set to AC or during sub-cycle P1, it has the value of the most significant bits of the value ADR_CTR, when it determines a value between 0 and 191.
- the DATA_CTR data is then activated by a buffer BX1 of logic 25a.
- the second case concerns the memory for accumulating sets M6 in FIG. 8 which receives the address AACC_ENS by the multiplexer 25-2 of the logic 25b.
- This address is normally the value A_ENS, but during the sub-cycle P1, it has the value ADR_CTR, when the most significant bits of the value ADR_CTR are located between 192 and 207.
- the DATA_CTR data are then activated by a BX6 buffer.
- the third case concerns the selection of what are known as detectors, by the value AACC_lN supplied by a multiplexer 25-3 of the logic 25b of figure 12.
- the value AACC_lN is determined by a memory M14 (figure 16) of selection of inputs.
- the address is normally AIN and during the P1 sub-cycle, it is ADR_CTR if the most significant bits of this signal determine a value between 208 and 223.
- the DATA_CTR data are then activated by a BX2 buffer of the logic 25a.
- the fourth case concerns the choice of detectors shown in Figure 18 (described in detail below). This choice concerns either a block 144 of amplitude, or a block 147 of frequency, again a block 146 of bands. Values beyond 224 of ADR_CTR can be used to define these detectors.
- the data DATA_CTR are then activated by buffers BX3 to BX5 as appropriate.
- FIG. 13 represents a diagram of a circuit 70 for controlling the selection of mode and input blocks. Indeed, the calculation of the first level samples in the cells can be performed in a number of modes of operation and also based on output signals set by any of a certain number of input blocks. These in turn can set their exit signals to from actual sources which may be internal and / or external to the unit SYNT.
- the three least significant bits MOD_SC0 to MOD_SC2 are applied to a selection logic 71 which, according to the values of these bits, can activate eight modes of operation implemented respectively in four input blocks 72 to 74 which form so-called zero level samples.
- the input block 72 makes it possible to implement an operating mode in which the SYNT unit uses waveform generators which it comprises itself. This block will be described with reference to FIG. 14 (activation signals SC_SIN, SC_CAR, SC_TR, SC_RMP, and SC_RMN).
- the input block 73 makes it possible to implement an operating mode in which the SYNT unit uses its own noise generator. This block will be described at About Figure 15.
- the input block 74 makes it possible to implement an operating mode by which the SYNT unit uses previously generated and stored samples (signal SC_ECH) or samples used in real time which may come from outside the SYNT unit (signal SC_ETR). These two modes will be examined in reference to Figures 16 and 17.
- the samples generated respectively in blocks 72, 73 and 74 appear on a bus 75 depending on the operating mode selected, the signal transiting on this bus being called CCYC.
- This signal is applied to a filter block 76 whose structure appears in Figure 19.
- This block provides affected samples of predetermined filtering characteristics, its output signal being designated by CFLT.
- Each sample of this signal is applied to input A of an arithmetic unit of multiplication U12 in which its value is multiplied by the parameter value current amplitude AMP applied to input B of this arithmetic unit.
- the result of the multiplication is written in an accumulation memory M13, at 192 locations, at the address determined by the address value AACC_CEL provided by the selection logic 25b (figure 12), under the control of the active pulse of the subperiod P4.
- Memory M13 is write only, writing to a given address chasing the previous written value to the output.
- the corresponding signal is representative of successive first level samples and called ACC_CEL, as that out of the cells.
- the four intermediate weight bits of the values read from the M12 memory are intended to determine the method of calculation on the amplitude parameters, of frequency, phase and filtering, performed in the arithmetic unit U4, respectively of each of the circuits 20A to 20D of figure 6. Their binary value places this unit U4 arithmetic in addition or multiplication mode.
- the three most significant bits from memory M12 selectively determine the continuous, repeat and "round trip" operating modes of the generation of first level samples from cells. These bits are called MOD_CCY, MOD_DCY and MOD_ALT respectively. These signals will be described in reference to Figures 20 and 21.
- This input block includes four function generators 81 to 84 intended to produce samples of level zero and to which the time value POS_X is applied calculated in the calculation circuit 30 of FIG. 7. It therefore recalls here that according to a important characteristic of the invention, the value POS_X is in fact a value most of the time.
- the first function generator is a sine table 81 in which a predetermined number of sine values are stored, this number being equal to 2 A , A being equal to 10 in the example considered.
- the address value formed by the current POS_X value is applied to the table by line 85. Access to table 81 is validated by the signal SC_SIN coming from the selection logic 71 of FIG. 13.
- the designation value POS_X can comprise a number of bits much greater than the number A, 32 for example, the same set of addresses from table 81 can therefore be traversed successively a very large number of times during the incrementation of the POS_X value up to its maximum value during operation of the SYNT unit.
- the generator 82 is capable of generating a square waveform in determining the instants of change of polarity of the first level samples at beget.
- the generator 82 is activated on the signal SC_CAR coming from the logic of selection 71 of figure 13.
- the change is made according to the sign of the most bit significant of the A bits of the current value of POS_X which is applied by the driver 86. In this case, POS_X does not therefore constitute a memory address proper.
- the generator 83 makes it possible to generate functions of triangular shape. It is an arithmetic function calculating a triangular oscillation based on the address on A least significant bits of the POS_X signal as location addresses. These address values are applied to it by the driver 87. The addresses and the resulting functions are summarized inside the block representing the generator 83. The latter is activated under the command of the signal SC_TRI coming from logic 71 of Figure 13.
- the generator 84 is also an arithmetic function calculating a positive or negative ramp oscillation based on address on A least bits significant of the POS_X value.
- a series of values thus stored can be browsed positive or negative under the control of a pair of signals SC_RMP and SC_RMN respectively, coming from logic 71 and applied to an AND gate 88.
- the output of this door validates the activation of this generator 84, the signal level SC_RMP determining the direction of the sequence of calculated values.
- the generated function by the addresses is also indicated inside the block representing this generator 84.
- FIG 15 shows the detail of the input block 73 of Figure 13.
- This block serves to generate first level samples in the event that these must present random amplitude values.
- This input block 73 includes a generator random numbers 90 working continuously. At the appearance of an impulse sampling ACT, the number generated at the corresponding time has passed to a flip-flop 91 in which it is written at the appearance of the pulse P1 corresponding. If flip-flop 91 is simultaneously activated by the validation signal SC_BRT, the corresponding data will be output from flip-flop 91 and the value of the current sample will be based on this data.
- each input is connected upstream to a converter analog / digital in turn connected to an analog signal source (not shown).
- Signal sources can come from musical instruments equipped with transducers, musical instruments associated with a microphone, record player, microphones picking up the sound spectrum of an orchestra, player compact discs etc., a very large number of such sources can be imagined.
- the signals present on inputs 0 to e are called lN_0 to lN_e.
- the input block 100 includes a memory M14 to 192 slots in which the CPU can write input assignment values to addresses provided by the AC signal under the control of the W_ETR_N signal from the block 14 of interface I (FIG. 2). Reading takes place under signal control R_ETR_N also coming from this block 14.
- the data recorded in the M14 memory by the CPU represent an input allocation code which is applied to to the multiplexer 25-3 (FIG. 12) whose output is connected to a decoder 101 having e outputs that can activate buffers 102-0 to 102-e whose inputs receive respectively the input signals lN_0 to lN_e.
- an external input for a given cell is applied to a bus 103 common to all the buffers 102-0 to 102nd.
- the signal passing through this bus is called lN_CEL and therefore it forms so-called zero level samples.
- the signal lN_CEL can be used as selected parameter values as long as they are allowed to pass to the output of logic 25a of figure 12 under the control of the signal ADR_CTR.
- the value of lN_CEL is routed as a DATA_CTR signal to be able to be multiplicatively combined or additive with the current value of a parameter under the signal control MODE_FCT.
- FIG. 17 represents the diagram of a circuit for memorizing samples of level zero and selecting the time use of these samples for the development of first level samples in the cells of the SYNT unit.
- This circuit includes a large capacity sample memory M15 in which a large quantity of zero level samples can be stored.
- this memory can have 2 32 locations. Note however that the memory M15 can have a greater or lesser capacity depending on the length of a recording of successive samples that one wishes to make. It will also be noted that this memory is the only one of the device according to the invention having a large capacity.
- the addresses of this memory M15 come from a multiplexer 121, at 32 bits for example, having an input A to which the address signal ACPU is applied ( Figure 2) from interface I. These addresses are therefore determined by the CPU. Through elsewhere, the data input from memory M15 of zero level samples is connected to block 13 of interface I so that the CPU can write data to this memory to addresses that he himself will have fixed.
- This storage mode in the M15 memory allows to use as zero level samples for example signals graphically selected by a user on the CPU screen, the application program of this management unit being naturally designed especially for this task, as is well known in the art.
- the ACPU address is activated by the signals W_ECH_CYC and R_ECH_CYC which respectively control writing and reading by a CPU.
- the other input B of the multiplexer 121 is connected to the output of the calculation circuit 30 of FIG. 7 from which it thus receives the current value of POS_X used here also in as an address, but this time for memory M15 (current value of POS_X).
- This output B is selected when the signals W_ECH_CYC and R_ECH_CYC are active. Indeed, these signals from block 14 of interface I are both applied to an OR gate 122 whose output is connected to the activation input of the multiplexer 121. If either of these two signals is active, input A of the multiplexer 121 is activated.
- the read / write command in the sample memory M15 can selectively be carried out by these same signals R_ECH_CYC and W_ECH_CYC.
- the signal R_ECH_CYC is applied directly to the command input of reading from memory M15, while the signal W_ECH_CYC is applied to a door AND 123 whose output is connected to the write command input of this same memory.
- the other input of the AND gate 123 is connected to the output of an OR gate 124. This receives on its first input the signal corresponding to the active pulse of the period P1 and on its other input the signal SC_ETR which can be activated when the data in memory M12 (figure 13) designates the operating mode corresponding to the output of decoder 71.
- OR gate 124 is applied to the activation input of a buffer 125. This receives on its input the signal IN_CEL which constitutes the output of the circuit input allocation of Figure 16.
- the output of buffer 125 is connected to the input of M15 sample memory data.
- OR gate 124 is also connected to one of the inputs of the AND gate 123 to enable activation of the write input of memory M15.
- writing level zero samples can be performed at addresses which depend either on the CPU by the ACPU signal on activation by the W_ECH_CPU signal for writing a sample into memory M15, i.e. by incrementing 0001 by the current POS_X value.
- This selection is made according to the state of the selection SC_ETR allowing to place the multiplexer 32 in one or the other of its configurations.
- the address where the data is written to memory M15 depends on the address specified by the CPU or the incrementation by '1' of the value POS_X under the control of the signal SC_ETR. This last way of incrementing actually corresponding to a real-time reproduction of the level samples zero (hence the acronym ETR: Real Time Entries). It should be noted that when the memory M15 is in real-time operating mode, the entered data comes out memory simultaneously. In the other mode of operation, says data (ECH), data may remain in memory for a period of predetermined time, the memory then functioning in a way as a tape recorder.
- the memory M15 When the signal SC_ETR is active, the memory M15 is used alternately in writing (P1) and in reading to obtain the zero level sample.
- the signal SC_ECH (see figure 13) is active, memory M15 is only used for writing enter a new sample.
- the memory is normally used for reading, the sample being read in the same way as for the sine table of block 81 of the figure 14, except that in the case of memory M15 the sample can be modified in any point by point time and that the dimension of the sample table contained in the memory M15 can be predetermined or chosen at will when this is not the case case for the sine table of block 81.
- the signals leaving the M15 sample memory form the CCYC signal which are first level samples not yet submitted filtering in the filtering circuit 160.
- FIG. 18 represents a circuit for analyzing the input signals applied to the inputs lN_0 to lN_e of the SYNT synthesis unit.
- Parameter detection circuit 140 since it is intended to detect in the input signals properties of amplitude, frequency and amplitude distribution as a function of frequency (bands), these properties, being converted to digital signals, allowing adjustment of parameter values with which cells will work to form the first level samples in the synthesis unit.
- the inputs of the detection circuit 140 are connected in parallel to the inputs lN_0 to lN_e of the synthesis unit together forming the signal E of FIG. 1. By Consequently, the inputs of the allocation circuits of FIG. 16 and of detection of the Figure 18 are connected respectively in parallel.
- the detection circuit 140 comprises a first group of detectors 141_0 to 141_e for determining the absolute value of the amplitudes of the samples digital sound which are applied by analog / digital converters (not shown) on the respective inputs lN_0 to lN_e. They are also designed to establish the average value over a number of successive samples and to provide a numerical value corresponding to their output.
- the detection circuit 140 comprises a second group of detectors 142_0 to 142_m used to determine an average amplitude value in each of a plurality of p frequency bands of the sequences of samples applied respectively on the inputs lN_0 to lN_e. These mean amplitude values appear, in the form of a digital code and for each of the p bands, on a determined output 0 to p of each detector.
- the detection circuit 140 comprises a third group of detectors 143_0 to 143_e responsible for determining temporal properties of the sequences of input samples and in particular the instants of passage through zero, the average of their frequency and a count value. These data are presented in the form of digital codes on each of the detector outputs 143_0 to 143_e.
- All the numerical values coming from the detectors of circuit 140 can selectively be placed in an M16 accumulation memory at 192 locations under the control of the active pulse of the sub-period P4. Addresses these values are written in this memory are formed by the least significant bits of the ADR_CTR signal applied to block 25 shown in Figures 5 and 12. The weight bits strong of this signal respectively determine the position of several selectors to which the detector output values are applied. So the outputs of the detectors 141_0 to 141_e are applied to 'e' inputs of a selector 144 according to a series of amplitude bits of the ADR_CTR signal.
- this can contain for each of the cells of the SYNT unit a numerical value whose stored data represent the values of amplitude and frequency parameters of the applied digital samples of outside the SYNT unit.
- the parameter values thus noted on the input signal can be used to intervene in the calculation of the values of parameters (VAL value) provided that at the instant considered the signal ACC_DET is authorized to pass to the output of block 25a of figure 12 under the control of the signal ADR_CTR coming from the CPU as represented on figure 2.
- the DATA_CTR signal can be combined additively or multiplicatively with the value current of a parameter under the command of the MODE_FCT signal which is applied to the arithmetic unit U4 of FIG. 5, this signal MODE_FCT being itself selected via the content of the M12 memory (figure 13) loaded by the CPU.
- FIG. 19 represents the filtering circuit 160 making it possible to apply a filtering suitable for the CCYC signal as shown by block 76 in Figure 13.
- This circuit includes a sequencer 161 of the filtering functions which receives the CCAL signal from interface 1 (figure 2) to run a sequence counter and the signal FLT of the circuit of FIG. 5 as a parameter determining the filtering in ultimately selecting filter coefficients in an M18 memory.
- This signal actually determines an address of a table in which is contained a curve of predetermined filter coefficients.
- the sequencer thus determines a code filtering operation appearing on its output 161a.
- the sequencer is also capable of generating two types of address values appearing on its outputs 161c and 161b respectively
- the address value of output 161b is applied to a memory M17 of filtering calculations.
- This memory M17 has a predetermined number locations, for example 16384.
- Address output 161c is applied to input B of a multiplexer 162 whose input A can directly receive address values from the block 12 of interface I. These values are entered by the CPU to characterize these filters (coefficients) in an M18 memory. The filtering process allows you to read these data for calculation.
- the selection of the input B of the multiplexer 162 is carried out under the command of the output of an AND 163 door which opens on condition that one of three signals is present, namely the read signal R_FLT_COEF, the write signal W_FLT_COEF or a coefficient read command signal constituting an output 164a of a block 164 for determining the IIR filtering function.
- the output of the multiplexer 162 is applied to the memory M18 of coefficients of filtering.
- This memory receives its data directly from the CPU. These data are registered at the appropriate addresses under the control of a write signal from of an AND gate 165.
- a first input of this AND gate is connected to block 14 of interface I (read signal R_FLT_COEF), its other input being connected to the output 164a of block 164 for determining filtering functions.
- Data output from the filter coefficient memory M18 is applied to an input 164b of block 164.
- the input and output of data from memory M17 of filtering calculations are respectively connected to the output 164c and at input 164d of block 164.
- the latter receives the operation code of the block 161 on its 164th entry. Reading in memory M17 is controlled by a signal from the 164f output, while the write command comes from the 164g output of block 164.
- this block 164 has an input 164h to which the signal is applied CCYC selectively derived from blocks 72, 73 and 74 of Figure 13, while the Completed "filtered" samples appear at output 164i of block 164.
- the memory 17 makes it possible to temporarily store the intermediate data for calculating filtering, this data producing the filtered signal on output 164i, i.e. the CFLT signal which is the signal used in figure 13 to determine the level 1 sample.
- the code allows to control the transitions of the signals between the inputs and the outputs of block 164.
- FIGS. 20 and 21 describe the circuit 180 of determination of the time limits of certain production processes of samples. These production processes are the sample mode, when the unit SYNT works with samples from memory M15 in figure 17 and the real-time sample mode.
- the validation of the determination circuit 180 is therefore provided at the appropriate time by one or other of the signals SC_ECH or SC_ETR applied to an AND gate 181 shown at the top of figure 20.
- the determination circuit 180 comprises a memory M19 in which values of start times can be stored (i.e. values representing a predetermined instant on the time axis by accumulation of a number determined of values analogous to values POS_X) of a series of samples determined representing for example a note to play.
- This M19 memory contains 192 slots and can therefore be loaded with a start time value for each of the cells.
- the address value is formed by the AC signal and the data is written / read into the memory from the management unit CPU under the command of W_ECH_DEB / R_ECH_DEB signals.
- Another M20 memory also at 192 locations, allows you to store analogously the instants of the end of a series of samples.
- the data is written / read in this memory by the signals W_ECH_FIN / R_ECH_FIN.
- the circuit of determination also includes two memories M21 and M22, at 192 locations in which "loop" values can be stored, more precisely time values representing a loop start time and an end time loop, the term loop to be understood here as a cyclic repetition of the same series of samples by one or more cells.
- Memories M21 and M22 can be written and read under the respective signal control W_ECH_B1 / R_ECH_B1 and W_ECH_B2 / R_ECH_B2. The data comes each times of the CPU.
- Each memory M19 to M21 is associated with a comparator, respectively 182 to 185, each time input A is connected to the data output of the memory associated and whose entry B receives the current value of POS_X.
- Comparators 182 and 184 provide a validation signal when their input B is less than or equal to their input A and comparators 183 and 185 provide such a signal when input B is greater than or equal to entry A.
- comparators 182 to 185 are respectively connected to activation logic 186 to 190 each receiving several signals which are combined therein logically to ensure the activation of output buffers 192 to 195 if necessary whose outputs can selectively supply the value lNlT_X which is a value particular initialization from which POS_X is then incremented by the designation values calculated in the calculation circuit 30.
- the activation logic 186 to 191 also receive the mode signals MOD_CCY, MOD_DCY and MOD_ALT which are contained in the output data of the memory M12 of FIG. 13.
- Another output buffer 196 makes it possible to set the value lNlT_X to zero when to each other, the signals SC_ECH or SC_ETR are inactive, through an inverter 197.
- the terminal determination circuit 180 also includes a memory of sign M23 at 192 places in which the sign determining the direction of progression of the POS_X value.
- This memory M23 is addressed by the signal AC and receives the sign bit to memorize for the cells of a multiplexer 198.
- the latter receives as selection signal the signal C_lNlT from the comparator 50 of FIG. 8.
- This signal passes the appropriate sign to the output of the multiplexer when the signal C_lNlT is active. Otherwise the sign signal comes from a logic gate 199 which logically combines the output of memory M23 with the mode signal MOD_ALT. When the latter is active (0 '), the sign changes with each write to memory M23.
- Another multiplexer 200 is controlled by this same mode signal MOD_ALT to selectively establish the SGN signal used in block 34 of the calculation 30 of FIG. 7.
- the input A of this multiplexer receives a signal T_DIR and the input B the MOD_DCY mode signal.
- buffers 194 and 195 are made active by through respective AND gates 201 and 202 and that writing to memory M23 is controlled via logic 203.
- the value of T_DIR will be set to 0 by gate 203, when fixing terminal E_B1 to set the progression in decrement.
- the terminals are fixed by the lNlT_X signal sent to the multiplexer 35 of FIG. 7, which reinitializes the value POS_X by the command CD_lNlT from the door 208.
- the signal lNlT_X can also be produced selectively by the output of two buffers 204 and 205 which respectively receive the E_DEB and E_FIN signals from memories M19 and M20. These buffers are activated by the appropriate logical combination of C_lNlT signals (phasing), the mode signal MOD_DCY and the output signal from OR gate 181, this logical combination being provided by OR doors 206 and 207.
- the buffer 204 fixes the initial value (or position) of POS_X on the activation of C_lNlT and mode signals SC_ECH / SC_ETR.
- MOD_DCY 1 (increasing)
- the start point E_DEB constitutes the initialization value transmitted to lNlT_X
- MOD_DCY 0 (decreasing)
- the end point E_FIN constitutes the initial value transmitted to lNlT_X.
- This last signal is then selected on the multiplexer 35 of FIG. 7 for initialize the POS_X value.
- the value POS_X When a cell is phased, at the start of a new note to be played by example, the value POS_X must be set to its initial value via the multiplexer 35 of the calculation circuit 30 of FIG. 7.
- the initial value lNlT_X of POS_X is equal to zero. This value goes through buffer 196 which is activated in the absence of either of the signals SC_ECH or SC_ETR.
- the lNlT_X value is determined by a starting instant of a given cell on the axis of time.
- a series of first level samples can be delimited in time by time limits between which the value POS_X can evolve, either by incrementing, or by decreasing, or even by making a "loop", which means repeating the same series of samples a number of times.
- Such a loop repetition can also be done in several ways: “forward”, “in backward “or alternately” forward “and” backward “.
- the POS_X values thus delimited each time constitute a address for the memory M15 of FIG. 17 which stores sample values at reproduce either in real time (ETR mode) or from samples that have been there previously stored (ECH Mode).
- the memory M15 of samples is addressed with the value E_DEB. Then the address increases gradually with the increment of the value POS_X calculated in the circuit of calculation 30 as a function of the frequency values FRE and ENS_FRE which are imposed on this calculation circuit, and in a similar way to that already described with regard to waveform generators in Figure 14.
- Buffer 193 is activated by the state of logic block 187 and transmits E_END to the bus which transmits lNlT_X to the calculation circuit 30.
- CD_lNlT activates initialization by state of door 208, the output of which is at '0' via the output of logic block 187.
- the memory M15 is addressed by the value E_END.
- the memories M20 and M19 respectively contain the values E_END and E_DEB.
- Comparator 182 compares E_DEB with the current value of POS_X, the logic block 186 commands the initialization of POS_X and the buffer 192 transmits the value E_DEB to the bus transmitting lNlT_X to the calculation circuit 30.
- the memory M15 is addressed by the value of E_DEB which increments gradually as in case 1, but this time when the value POS_X reaches or exceeds the value E_B2 stored in the memory M22, it will be set at the value E_B1, the value POS_X increases again until the value E_B2, and so on.
- MOD_CCY 0 (Cyclic)
- MOD_DCY 1 (incrementation)
- MOD_ALT 1 (not alternative, the loop is traversed always in the Same direction).
- the memories M19 to M22 respectively contain the values E_DEB, E_END, E_B1 and E_B2.
- Comparator 185 compares the value E_B2 with the current value of POS_X.
- the logic block and the AND gate 201 control the initialization of POS_X and the buffer 194 transmits the value E_B1 on the bus which transmits INIT_X to the calculation 30.
- POS_X> E_B2
- POS_X will be set to the value E_B1 under the command INIT_X and CD_lNlT signals.
- Exit from gate 201 is at '0', if the outputs of block 188 or the output of block 191 are at '0'.
- the buffer 194 is then activated by the state of the AND gate 201 and transmits the value E_B1 on the bus on which lNlT_X passes.
- Initialization is activated by the door status 208 whose output will be at '0' by the state of gate 201.
- POS_X is again initialized to the value E_B1, which fulfills the condition POS_X ⁇ E_B2 and the cycle start again.
- E_END ends the memory M15 and this value gradually decreases as a function of frequency (signals FRE and ENS_FRE).
- the memories M19, M20, M21 and M22 respectively contain the values E_DEB, E_FIN, E_B1 and E_B2.
- Comparator 184 compares E_B1 with the current value of POS_X; the logic block 189, as well as the AND gate 202, command the initialization of POS_X and buffer 195 transmits the value E_B2 on the bus on which INIT_X passes to the calculation circuit 30.
- POS_X When POS_X> E_B1, POS_X decreases progressively as a function of the frequency and there is no control ensured by the signals INIT_X and CD_lNlT.
- the buffer 195 is then activated by the state of the AND gate 202 and the value E_B2 is transmitted to the calculation circuit 30 via the transfer bus of lNlT_X.
- CD_lNlT activates the AND gate 208 whose output will be at '0' by the output of AND gate 202.
- POS_X is initialized to E_B2 which restores the condition POS_X> E_Bi.
- the memories M19 to M22 respectively contain the values E_DEB, E_END, E_B1 and E_B2.
- Comparators 184 and 185 compare the values E_B1 and E_B2 with the current value of POS_X.
- Logic block 203 and multiplexer 198 control the direction increment / decrement via the T_DIR signal.
- the buffer 194 passes the value E_B1 on the transfer bus lNlT_X thanks to initialization command (end of increments) and buffer 195 transmits the value E_B2 on this same bus for the initialization of the end of decrementation.
- POS_X will be updated the value E_B2 by command of lNlT_X and CD_lNlT.
- the output of ET gate 202 is at '0', if the logic block 189 output or logic block 190 is at '0'.
- Buffer 195 is activated by the output at '0' of the AND gate 202 and thus transmits the value E_B2 on the transfer bus from lNlT_X to the calculation circuit 30.
- the signal C_lNlT will activate the initialization by the state of the AND gate 208.
- the output of this one (C_lNlT) is therefore at '0' by the output of the AND gate 202.
- the output of gate ET 201 is at '0', if the logic block 188 or logic block 191 output is '0'. Buffer 194 is activated by the output at '0' of the AND gate 201 and thus transmits the value E_B1 on the transfer bus from lNlT_X to the calculation circuit 30.
- the signal C_lNlT will activate the initialization by the state of the AND gate 208.
- the output of this one (CD_lNlT) is therefore at '0' by the output of the AND gate 201.
- the synthesis device must generate a sound of sinusoidal shape at a frequency of 440 Hz with an amplitude value that will be set arbitrarily at 100 (value giving after the output S a given sound volume).
- the sinusoidal curve in table 81 (figure 15) is defined with 1024 samples.
- the base clock 2 in Figure 2 is at 67.737 MHz and the sampling frequency is 44 100 Hz (ACT signal), i.e. 67 737/8 (counter 3 Figure 2) / 192.
- the SYNT unit is initialized by the CPU unit via the interface I. At this Indeed, the CPU writes in several memories data suitable for the example considered.
- the CPU will determine the parameters that will be in effect during the sound production as follows.
- the amplitude values are all set to zero.
- the value '0' is registered at addresses 0 to 191 of the memory M1 of circuit 20A (FIGS. 5 and 6) by the write signal W_AMP_BAS.
- the value 'maximum' is written in the M2 memory of this same circuit 20A by the write signal W_AMP_INC in order to suppress the interpolation on the amplitude values (modality chosen here by way of example).
- the value 'maximum' is written to memory M4 by the write signal W_AMP_CTR, because in the example no amplitude control from other sources is performed.
- 'Maximum' is the maximum possible value; on 16 bits for example, it is 65535 (or in hexadecimal ⁇ FFFF).
- the basic frequency value is arbitrarily set to '1000' (in integers base 10) for all cells; this value '1000' is therefore entered in every memory locations M1 of block 20B in Figure 6, using the write signal W_FRE_BAS.
- the 'maximum' value is written to all 192 locations in M2 memory of this block 20B to deactivate the interpolation, using the write signal W_INC_FRE.
- the value 'maximum' is written by the signal W_FRE_CTR in the memory M4 at all locations, no additional frequency control being provided in this example.
- the 'maximum' value here is the maximum possible value, on 24 bits for example, it is 16,777,215 (or in hexadecimal ⁇ FFFFFF)
- the basic value of the phase is fixed at '0'; '0' is therefore entered in all locations 0 to 191 of the memory M1 of block 20C of FIG. 6, using the signal W_PHA_BAS.
- the value 'maximum' is written to all the locations of the M2 memory of this same block 20C in order to deactivate the interpolation on the phase values, using the write signal W_PHA_INC.
- the value 'maximum' is written to all locations in the M4 memory of this same block 20C, using the write signal V_PHA_CTR to deactivate any additional command on the PHASE parameter.
- the 'maximum' value here is the maximum possible value, on 9 bits for example, it is 511 (or in hexadecimal 1FF).
- 'maximum' is also entered in all the locations of the memory M4 using the write signal W_FLT_CTR to deactivate any command additional on the FILTERING parameter.
- 'Maximum' here is the maximum value possible, on 8 bits for example, it is 255 (or in hexadecimal OFF).
- the SYNT unit To generate this sinusoidal sound, the SYNT unit must be programmed so that the sine table 81 of figure 14 is activated.
- this table contains 1024 zero level samples whose values of successive points reproduce together a sine waveform.
- This activation is programmed by the CPU unit which, as regards the cell '0', entered in location '0' of memory M12 (figure 13) and using the signal write W_MOD, a value whose three least significant bits have the value '000'. he as a result that the decoder 71 activates the signal SC_SIN which frees access to the table 81 of the circuit 72 first level sample generator of FIG. 14. Cell 0 is thus placed in the appropriate mode.
- Table 81 should be read at a rate that corresponds to 440 Hz sound at the output from SYNT unit. As already indicated above, under these conditions, it is advisable to use a multiplication factor of 10.21678 in the arithmetic unit U4 of the circuit computation 30 of FIG. 7. This value is entered at address '0' of the memory M10 of Figure 8 using the write signal W_ENS_FRE. Then, at address '0' from memory M1 of block 20B, the value '1' is entered as the basic relative value FRE of the frequency. The effective frequency will be calculated by the multiplying unit U4 in the figure 7.
- the cells of set 0 must be put in phase, which in the example described, is only necessary for cell '0'.
- the value '0' corresponding to the set 0 is entered in the rocker 44 of the first level allocation circuit 40 in FIG. 8 under the control of the signal W_DEC.
- the amplitude is fixed at the value '100'.
- the volume of set 0 which will include cell '0' presents the maximum value by writing "maximum" at address '0' of memory M8 under the command of the write signal W_ENS_AMP, for example the value 1023 on 10 bits.
- the value '100' is written in the memory M1 of block 20A at address '0' corresponding to cell '0' as the base value of the AMPLITUDE parameter, under the control of the write signal W_AMP_BAS.
- the SYNT unit is then initialized to produce the desired sound.
- the signals corresponding to the sub-periods P2_AMP, P2_FRE, P2_PHA and P2_FLT are not used, because no parameter modification is only provided in the example described.
- the synthesis device sound already carries out the first passages on the cells starting with the cell 0.
- a positive sign is assigned to the direction of the time axis; this means that the value of POS_X is increasing.
- the corresponding sign bit has been recorded beforehand in the memory M23, the MOD_DCY and MOD_ALT signals having been fixed at their suitable binary value by via the memory M12 in FIG. 13. The sign bit is applied to the circuit 34 of the calculation circuit 30.
- the parameters of the cell 0 are fixed at their previously stored value, the designation value POS_X is accumulated in accumulator memory M5 (unspecified value), the amplitude of cell 0 is calculated (zero value), cell '0' is assigned to set 0 with the zero amplitude value for this set as a second level value (memory M7 of figure 8) and the zero value is also placed in rocker 63-0 in Figure 11 as a third level value.
- the active pulse of the PCPU subperiod ends this period P1 for allow the CPU to enter other values in the SYNT unit if necessary.
- a first cycle P is then completed.
- the four parameter values of cell 0 are initialized in accordance with the data entered by the CPU.
- the value of the sample of first current level is added to that of the previous P1 period (it is always equal to zero).
- the four parameters of the cell 0 are conformed to their current value.
- the "cumulative" value (still zero) of POS_X is stored in memory M5.
- the cell amplitude value is established on the one hand by looking for the sine value at address 0 of table 81, this address being formed by the least significant bits of the POS_X signal, and on the other hand by multiplying this sine value by the amplitude value (100) previously entered in the arithmetic unit U12 of figure 13.
- the point value from table 81 was the CCYC signal and passed the filter circuit 160 of Figure 19 which is inactive in the example studied here.
- the signal ACC_CEL which is the first sample level thus formed for cell 0, is assigned to set 0 by storage in the first level allocation circuit memory M7 40. Since the value 100 was previously entered, the amplitude value of this first level sample will be therefore equal to 100 also.
- the arithmetic unit U10 (figure 8) adds the values of the cells of the same together and it is reset at the start of each pass (after processing for last cell of a given set). Since only one cell is used in example, the corresponding first level sample value is equal to the value second level sample (output from flip-flop 42 to unit U9), i.e. the amplitude of the set previously set to the maximum and calculated in this unit 9.
- the value of the set itself is made up (there is only one cell concerned), to form the second level sample which is then allocated in as a third level sample at the desired output ( Figure 11). Then the period P1 considered ends with data entry by the CPU during the pulse active of the PCPU subperiod.
- the sign of progression of the POS_X value is again set to positive via circuit 34 of the calculation circuit 30.
- the four parameters of cell 0 are kept at their value according to the data previously entered by the CPU.
- the calculation circuit 30 again recognizes the phase ordered during period P1, the value POS_X is set to zero in location '0' of memory M5.
- Cell 0 is assigned to set 0 as during the first pass and the sum of cell values for set 0 (cell 0 only) is calculated in the arithmetic unit U10 and placed in the scale 42.
- This multiplied value (signal ACC_CEL) is also stored at the location '0' of accumulation memory M7 as current value of the sample of second level after addition with the value B (zero in this case) in the unit U10 arithmetic.
- the amplitude value of the set 0 is then established in the unit arithmetic U9, by multiplying the fixed amplitude value stored in the memory M8, the multiplied value being loaded into the memory M6.
- the current P1 period ends again if necessary by registering data by the CPU during the active pulse of the PCPU subperiod.
- the value POS_X continues to increment by 10 or 11 for cell '0' and the other cells will remain inactive until the CPU has ordered an operation change of the SYNT unit.
- Level samples zero can then come from three different sources namely the generators of waveforms of Figure 14 or 15, the input circuits of Figure 16 and 18 by through M15 memory and the cells themselves using the samples from first level which are present in the accumulation memory M13.
- the CPU initializes the system.
- the data is stored in the memories corresponding.
- the value hex_200 maximum) is reserved to indicate that the command is inactive on the corresponding parameter of a cell.
- each sub-period P includes a sub-period PCPU at the end of the calculation relating to each cell. This will not be expressly recalled in what follows.
Abstract
Description
- des premiers moyens pour déterminer une succession de cycles de travail rythmés en fonction d'une fréquence d'échantillonnage;
- au moins une source d'échantillons dits de niveau zéro représentant au moins un signal sonore et apte à fournir au cours de chaque cycle de travail en cours x au moins un échantillon de niveau zéro,
- des seconds moyens pour déterminer, pour chacun desdits échantillons de niveau zéro à sélectionner au cours d'un cycle de travail suivant x+1, une première valeur propre à cet échantillon d'un paramètre de fréquence,
- des troisièmes moyens pour déterminer, pour chacun desdits échantillons de niveau zéro à traiter au cours d'un cycle de travail suivant x+1, au moins une seconde valeur, également propre à cet échantillon, d'au moins un autre paramètre,
- au moins deux mémoires de paramètres pour, au cours du cycle de travail x en cours, mémoriser respectivement lesdites première et seconde valeurs de paramètre, dans n emplacements de mémoire respectifs, afin de pouvoir utiliser ces valeurs au cours du cycle de travail suivant x+1,
- des quatrièmes moyens pour, pendant chaque cycle de travail en cours x déterminer, en fonction de chacune des n valeurs de paramètre de fréquence mémorisées pendant le cycle de travail précédent x-1, une valeur de désignation pour désigner parmi lesdits échantillons de niveau zéro, le ou les échantillons de niveau zéro qui, au cours du cycle de travail suivant x+1, vont contribuer à l'élaboration de n échantillons de premier niveau respectifs,
- une mémoire de valeurs de désignation pour mémoriser lesdits n valeurs de désignation déterminées pendant le cycle de travail en cours x, afin de pouvoir les utiliser pendant le cycle de travail suivant x+1,
- des cinquièmes moyens pour, pendant le cycle de travail x en cours, appliquer à chacun des échantillons de niveau zéro désignés pendant le cycle de travail précédent x-1, la valeur correspondante dudit autre paramètre mémorisée pendant le cycle de travail précédent, pour former n échantillons actuels de premier niveau et les mémoriser respectivement dans n emplacements d'une mémoire d'accumulation, et
- des sixièmes moyens pour au cours du cycle de travail en cours x, transférer vers ladite sortie les n échantillons de premier niveau mémorisés au cours du cycle de travail précédent x-1,
- le système comprend également une unité de gestion connectée auxdits seconds, troisième, quatrième, cinquièmes et sixièmes moyens, pour en gérer des valeurs de fonctionnement selon un logiciel exécuté par cette unité de gestion;
- lesdites valeurs de fonctionnement sont des valeurs initiales desdits paramètres et/ou des valeurs d'incrément de ces paramètres, lesdites valeurs initiales et d'incrément étant déterminées par ledit logiciel;
- lesdits premiers moyens sont agencés pour déterminer successivement, au cours de chacun desdits cycles, n sous-cycles de signaux de commande affectés respectivement auxdites n cellules, les signaux de commande de chacun de ces sous-cycles étant destinés, d'une part à activer, pendant le cycle de travail x en cours, des opérations de calcul pour la détermination desdites première et seconde valeurs de paramètre de la cellule correspondante et d'autre part, pour ce qui concerne chacune desdites mémoires, à permettre la lecture/écriture dans lesdits n emplacements de mémoire, de données résultant de la détermination de ces valeurs, ces données formant les contenus respectifs desdites n cellules utilisés pendant le cycle de travail suivant x+1;
- chacun desdites sous-cycles de signaux de commande comprend également un signal de commande pour autoriser ladite unité de gestion à communiquer avec lesdits premiers, seconds, troisièmes, quatrièmes, cinquièmes et sixièmes moyens;
- lesdits seconds moyens (20B, 25) exécutent une fonction de calcul de la
forme
dans laquelle PARP
n est la valeur de paramètre de fréquence courante de la cellule considérée pendant ledit sous-cycle en cours ou la valeur initiale de paramètre de fréquence, PARPn-1 est la valeur de paramètre de fréquence élaborée au cours du sous-cycle précédent pour cette cellule et INCPn est l'incrément apporté à la valeur courante de paramètre de fréquence vis-à-vis de la valeur précédente; - lesdits troisièmes moyens exécutent une fonction de calcul de la forme
dans laquelle PARP
n est la valeur courante de l'un desdits autres paramètres de la cellule considérée pendant ledit sous-cycle en cours ou la valeur initiale de cet autre paramètre, PARPn-1 est la valeur dudit autre paramètre élaborée au cours du sous-cycle précédent pour cette cellule et INCPn est l'incrément apporté à la valeur courante dudit autre paramètre vis-à-vis de la valeur précédente; - lesdits seconds et/ou troisièmes moyens comprennent une mémoire de valeur initiale destinée à contenir, pour chacune desdites cellules, ladite valeur initiale de paramètre et une mémoire d'incrément, destinée à contenir, pour chacune desdites cellules, ladite valeur d'incrément de paramètre;
- lesdits troisièmes moyens comprennent un circuit pour le calcul d'au moins l'un desdits autres paramètres, identique au circuit desdits seconds moyens pour le calcul dudit paramètre de fréquence;
- lesdits quatrièmes moyens comprennent une première unité de calcul pour combiner algébriquement ladite valeur de paramètre de fréquence du cycle de travail en cours avec une valeur représentant la fréquence fondamentale du son à synthétiser auquel contribue l'échantillon de premier niveau calculé pendant ce cycle en cours, une seconde unité de calcul pour combiner algébriquement le résultat fourni par ladite première unité de calcul avec le contenu actuel de l'emplacement de ladite mémoire de valeurs de désignation correspondant à la cellule traitée au cours du cycle de travail en cours et des septièmes moyens pour remplacer dans cet emplacement la valeur de désignation calculée au cours du cycle de travail précédent par le résultat du calcul effectué au cours d cycle de travail en cours par ladite seconde unité de calcul;
- lesdits quatrièmes moyens comprennent également un multiplexeur dont la sortie est connectée à ladite seconde unité, dont rune des entrées reçoit le résultat du calcul de ladite première unité de calcul, et dont l'autre entrée reçoit un signal de progression de valeur fixe, notamment '0001', de ladite valeur de désignation permettant, sous la commande d'un signal de mode, de faire progresser cette valeur de désignation de ladite valeur fixe d'un cycle de travail à l'autre;
- lesdits quatrièmes moyens comprennent également une troisième unité de calcul pour combiner algébriquement le résultat du calcul de ladite seconde unité de calcul avec la valeur en cours de l'un desdits autres paramètres représentant la phase à appliquer à l'échantillon de premier niveau engendré au cours du cycle de travail suivant x+1;
- lesdits quatrièmes moyens comprennent également des huitièmes moyens pour affecter le signe positif ou négatif au résultat du calcul obtenu dans ladite première unité de calcul;
- au moins certaines desdites sources comprennent une mémoire d'échantillons de niveau zéro et ladite valeur de désignation est utilisée comme adresse de ladite mémoire d'échantillons de niveau zéro;
- une première mémoire parmi lesdites mémoires d'échantillons de niveau zéro est une table de sinus;
- une seconde mémoire parmi lesdites mémoires d'échantillons de niveau zéro est agencée pour stocker au moins une séquence sonore échantillonnée dont les échantillons successifs constituent lesdits échantillons de niveau zéro;
- ladite seconde mémoire d'échantillons de niveau zéro est connectée pour être chargée par ladite unité de gestion, éventuellement par l'intermédiaire dudit logiciel;
- au moins certaines desdites sources comprennent un générateur de fonction et ladite valeur de désignation est utilisée comme valeur de désignation ou comme adresse pour identifier les équations de ladite fonction à utiliser;
- ledit générateur de fonction est choisi parmi le groupe comprenant un générateur de fonction carrée, un générateur de fonction triangulaire, et/ou un générateur de rampe positive et/ou négative;
- le système comprend en tant que source d'échantillons de niveau zéro un générateur de bruit aléatoire fournissant des échantillons au rythme de ladite fréquence d'échantillonnage;
- ladite seconde mémoire d'échantillons de niveau zéro est connectée pour stocker, en tant qu'échantillons de niveau zéro, des échantillons de premier niveau calculés et stockés dans au moins une cellule au cours d'au moins un cycle de travail antérieur;
- le système comprend également des neuvièmes moyens pour préparer des échantillons de niveau zéro à partir d'au moins une entrée du système de synthèse à laquelle est appliquée un spectre sonore provenant d'une source externe, et en ce que lesdits neuvièmes moyens sont connectés à ladite seconde mémoire d'échantillons pour permettre le stockage desdits échantillons de niveau zéro provenant desdites entrées;
- le système comprend également des dixièmes moyens connectés à ladite au moins une entrée pour analyser le spectre sonore de ladite source externe et en tirer des valeurs de paramètre pouvant être utilisées pour modifier le ou les paramètres déterminés par lesdits seconds et troisièmes moyens;
- le système comprend également des dixièmes moyens pour déterminer laquelle desdites sources d'échantillons de niveau zéro va servir pour générer, au cours de chacun desdits cycles de travail, l'échantillon de premier niveau de chacune desdites cellules;
- lesdits sixièmes moyens comprennent également des onzièmes moyens pour au cours d'un cycle de travail en cours répartir les échantillons de premier niveau desdites cellules engendrés au cours d'un cycle de travail précédent, sur m emplacements de mémoire d'une seconde mémoire d'accumulation, les emplacement de cette seconde mémoire d'accumulation matérialisent m ensembles dont le contenu peut varier d'un cycle de travail à l'autre, le contenu de chacun desdits m emplacements étant sélectivement transféré à ladite sortie en tant qu'échantillon dit de second niveau pendant le cycle de travail en cours;
- ladite sortie comprend une pluralité de sorties distinctes et il est prévu en outre des douzièmes moyens pour répartir sélectivement le contenu des emplacements de mémoire de ladite seconde mémoire d'accumulation sur lesdites sorties distinctes, en tant qu'échantillons dits de troisième niveau;
- le système comprend également des treizièmes moyens pour déterminer pour ladite valeur de désignation des bornes entre lesquelles cette valeur peut évoluer au cours d'une série déterminée de cycles de travail successifs;
- lesdits treizièmes moyens sont agencés pour faire évaluer ladite valeur de désignation cycliquement entre lesdites bornes, à savoir de la première borne à la seconde borne, cycliquement de la seconde borne à la première borne et/ou cycliquement en boucle de la première borne à la seconde borne et puis inversement de ladite seconde borne à ladite première borne;
- lesdites valeurs de fonctionnement sont stockées sélectivement dans une pluralité de mémoires comprenant n emplacements par ladite unité de gestion appartenant respectivement aux, seconds, troisièmes, quatrièmes, cinquièmes et sixièmes moyens, en fonction dudit logiciel;
- lesdits troisièmes moyens comportent des quatorzièmes moyens pour appliquer au cours d'au moins certains desdits cycles de travail, au moins une coefficient de filtrage à au moins certains des échantillons de premier niveau engendrés.
- la figure 1 est un schéma fonctionnel global du dispositif de synthèse sonore selon l'invention;
- la figure 2 est un schéma de l'interface destinée à l'échange de messages entre une unité de gestion et une unité de synthèse sonore et au cadencement des opérations effectuées dans cette unité de synthèse;
- les figures 3 et 4 représentent un diagramme temporel des signaux apparaissant dans l'interface de la figure 2, l'échelle des temps de la figure 3 étant plus petite que celle de la figure 4;
- la figure 5 représente un schéma d'un circuit d'élaboration d'un paramètre déterminant l'une des propriété des échantillons sonores à engendrer et appartenant à l'unité de synthèse selon l'invention;
- la figure 6 est un schéma illustrant comment quatre circuits d'élaboration d'un paramètre selon la figure 5 peuvent être utilisés pour déterminer quatre paramètres fixant les propriétés des échantillons à engendrer;
- la figure 7 est un schéma d'un circuit générateur de valeurs temporelles permettant de désigner des échantillons dits de niveau zéro devant être utilisés pour préparer des échantillons dits de premier niveau;
- la figure 8 est un circuit assurant l'attribution d'échantillons sonores de premier niveau à des circuits de l'unité de synthèse situés en aval;
- les figures 9 et 10 illustrent par un diagramme temporel les signaux apparaissant dans le circuit d'attribution de la figure 8;
- la figure 11 est un schéma d'un circuit d'attribution d'échantillons dits de second niveau à un circuit qui est monté juste en amont de la sortie de l'unité de synthèse;
- la figure 12 illustre par un schéma simplifié comment les paramètres élaborés dans les circuits des figures 5 et 6 peuvent être utilisés pour influencer la production des échantillons en fonction de plusieurs sources de signaux sonores, soit internes soit externes au dispositif suivant l'invention;
- la figure 13 est un schéma d'un circuit de sélection de modes de fonctionnement du dispositif selon l'invention;
- la figure 14 est un schéma d'un circuit générateur d'échantillons de premier niveau à partir d'échantillons de niveau zéro présents à l'intérieur même de l'unité de synthèse et pouvant donner lieu à la formation de plusieurs formes d'onde de signaux sonores;
- la figure 15 est un schéma d'un autre circuit générateur d'échantillons de premier niveau à partir d'échantillons de niveau zéro également produits à l'intérieur même de l'unité de synthèse, mais pouvant dans ce cas donner lieu à la formation de bruit aléatoire;
- la figure 16 est un schéma d'un circuit destiné à attribuer sélectivement un groupe d'entrées externes au dispositif de synthèse sonore, afin d'utiliser ces entrées en tant que sources de formation d'échantillons de premier niveau;
- la figure 17 est un schéma d'un circuit pour permettre le stockage de certains échantillons de niveau zéro;
- la figure 18 représente un schéma d'un circuit d'analyse de signaux d'entrée afin de déterminer des paramètres caractérisant des échantillons de premier niveau élaborés à partir d'échantillons de niveau zéro ayant pour origine des signaux sonores venant de l'extérieur;
- la figure 19 est un schéma d'un circuit permettant en phase finale d'élaboration des échantillons de premier niveau de tenir compte de certains coefficients de filtrage;
- les figures 20 et 21 illustrent schématiquement un circuit de production de bornes temporelles utilisées au cours de l'élaboration des échantillons sonores des premier et second niveaux; et
- Ensemble 0; les contenus des cellules 0 à 191 sont acheminés sur l'ensemble 0. Pour cela, la valeur '0' est inscrite par le signal AC aux adresses 0 à 191 de la mémoire M9 (figure 8) sous la commande du signal d'écriture W_ENS_CEL. A noter que les cellules 1 à 191 seront inactives mais restent associées à l'ensemble 0.
- Volume ensembles; tous les ensembles sont mis sur la valeur d'amplitude '0'. Pour cela, la valeur '0' est inscrite aux adresses 0 à 16 de la mémoire M8 (figure 8) à l'aide du signal d'écriture W_ENS_AMP.
- Sortie 0; le contenu de l'ensemble 0 doit être acheminé sur la sortie 0. Pour cela, la mémoire 11 (figure 11) reçoit une valeur binaire '1' à l'adresse '0' sous la commande du signal d'écriture W_SORTIE, de sorte que la bascule 63-0 sera activée par la valeur '1' du bit 0 appliquée à la porte 62-0 et ce, pendant l'impulsion active de la sous-période P4.
- nombre de cellules utilisées : 4 sur 192,
- nombre de signaux de cellules additionnés à la sortie : 3 sur 4,
- nombre d'ensembles utilisés : 1 parmi 16,
- nombre de sorties utilisées : 1 parmi 16,
- nombre d'entrées utilisées : 1 parmi 16,
- échantillonnage :comme dans le premier exemple.
- La cellule 0 utilise un signal externe (exemple: guitare) appliqué à l'entrée 0 (mode SC_ETR), son amplitude est fixée à '100'.
- la cellule 1 est utilisée en oscillation RAMPE (mode SC_RMN) s'additionnant au signal. Son amplitude est fixée à '100' et modulée en amplitude par la cellule 0 de manière multiplicative. Sa fréquence est fixée à 440 Hz (base = 440 Hz, rapport de fréquence = 1; 5.U4)
- la cellule 2 contient en mémoire l'échantillon d'une trompette (mode SC_ECH). Cette cellule comporte un vibrato et sa fréquence sera modulée de manière additive par la cellule 3. Son amplitude est fixée à '100'. Sa fréquence est de 440 Hz (base = 440 Hz, rapport de fréquence = '1').
- la cellule 3 est utilisée en oscillation sinus (mode SC_SIN) d'amplitude '250', de fréquence 0,5 Hz (base = 440 Hz, rapport de fréquence '0,001136'). Cette dernière cellule ne sera pas additionnée au signal de sortie mais ne servira que comme modulante de la fréquence de la cellule 2.
- les quatre cellules sont incorporées dans un même ensemble, soit l'ensemble 0. Seul le contenu des cellules 0 à 2 est acheminé sur la sortie 0. Les paramètres phase et filtrage de toutes les cellules sont à '0'.
- Ensemble 0 : les cellules 0 à 191 sont acheminées sur l'ensemble 0.
La valeur '0' est écrite aux adresses W_ENS_CEL+0 à W_ENS_CEL+191 (8.M9).
Les cellules 4 à 191 sont inactives mais laissées sur l'ensemble 0. Pour que le circuit
d'attribution 40 complète l'addition des cellules sur l'ensemble 0 (soit les cellules 0 à
3 qui sont actives, et les cellules 0 à 2 additionnées), les valeurs suivantes doivent
être inscrites :
- cellule 0: valeur hexadécimale '30' sur W_ENS_CEL+0 (8.M9), alloue l'accumulation de la cellule 0 sur l'additionneur U10 (bit 4 C_SCEL actif='1', bit 5 C_ENS inactif='1');
- cellule 1: valeur hexadécimale '30' sur W_ENS_CEL+1 (8.M9), alloue l'accumulation de la cellule 1 sur l'additionneur U10 (bit 4 C_SCEL actif='1', bit 5 C_ENS inactif='1');
- cellule 2: valeur hexadécimale '30' sur W_ENS_CEL+2 (8.M9), alloue l'accumulation de la cellule 2 sur l'additionneur U10 (bit 4 C_SCEL actif='1', bit 5 C_ENS inactif='1');
- cellule 3: valeur hexadécimale '00' sur W_ENS_CEL+3 (8.M9), la cellule 3 n'est pas additionnée (bit 4 C_SCEL inactif='0'). Elle est la dernière cellule dans l'ensemble (bit 5 C_ENS actif='0'). Cela fixe le contenu de la cellule 3 comme dernière valeur à additionner dans l'ensemble (bit C_ENS, soit le bit 5 de la valeur);
- Amplitude ensembles : les ensembles sont d'abord mis à amplitude nulle. La valeur '0' est écrite aux adresses W_ENS_AMP+0 à W_ENS_AMP+15 (8.M8) correspondant aux ensembles 0 à 15;
- Fréquence ensembles : le CPU programme le SYNT sur une base fréquencielle de 440 Hz. Le programme doit tenir compte de la fréquence d'échantillonnage (44 100 Hz) et du nombre de points par cycle des générateurs (1024 points) pour calculer le code de fréquence. Dans le présent exemple, on utilise donc une valeur de fréquence pour l'ensemble 0 identique à celle discutée précédemment à propos de la figure 6. Cette valeur de fréquence de l'ensemble 0 est inscrite à l'adresse W_ENS_FRE+0 (8.M10) correspondant à l'adresse de la fréquence de l'ensemble 0;
- Sortie 0: l'ensemble 0 est acheminé vers la sortie 0. Ecrire la valeur '1' (bit 0 à 1) sur W_SORTIE (11.M11) correspondant aux destinations de sortie de l'ensemble 0.
- Valeurs des amplitudes : toutes les amplitudes à '0' qui est écrit aux adresses W_AMP_BAS+0 à W_AMP_BAS+191 (6.20A[5.M2]).
- Valeurs des incréments d'amplitude : la valeur "maximum" est écrite aux adresses W_AMP_INC+0 à W_AMP_INC+191 (6.20A[5.M1]). Cela a pour effet de conférer une valeur sans interpolation aux amplitudes.
- Valeurs de modification des amplitudes: la valeur "maximum" (hex_200) est inscrite aux adresses W_AMP_CTR+0 à W_AMP_CTR+191 (6.20A[5.M4]). Cela a pour effet de désactiver la modification des amplitudes.
- Valeurs de fréquence: toutes les fréquences sont à la valeur '1000' (arbitraire) qui est écrite aux adresses W_FRE_BAS+0 à W_FRE_BAS+191 (6.208[5.M2]).
- Valeurs d'incréments de fréquence: la valeur "maximum" est écrite aux adresses W_FRE_INC+0 à W_FRE_INC+191 (6.20B[5.M1]). Cela a pour effet de conférer une valeur sans interpolation aux fréquences.
- Valeurs de modification de fréquence: la valeur "maximum" est inscrite aux adresses W_FRE_CTR+0 à W_FRE_CTR+191 (6.20B[5.M4]. Cela a pour effet de désactiver la modification des fréquences.
- Valeurs phases: toutes les phases sont à '0' qui est inscrit aux adresses W_PHA_BAS+0 à W_PHA_BAS+191 (6.20C[5.M2]).
- Valeurs d'incrément de phases: la valeur 'maximum' est écrite aux adresses W_PHA_INC+0 à W_PHA_INC+191 (6.20C[5.M1]). Cela confère une valeur sans interpolation aux phases.
- Valeurs de modification de phase: la valeur 'maximum' est inscrite aux adresses W_PHA_CTR+0 à W_PHA_CTR+191 (6.20C[5.M4]). Cela a pour effet de désactiver la modification sur les phases.
- Valeurs de filtre: tous les filtres sont rendus inactifs: la valeur 'maximum' est inscrite aux adresses W_FLT_BAS+0 à W_FLT_BAS+191 (6.20D[5.M2]).
- Valeurs d'incrément des filtres: la valeur 'maximum' est inscrite aux adresses W_FLT_INC+0 à W_FLT_INC+191 (6.20D[5.M1]). Cela confère une valeur sans interpolation aux filtres.
- Valeurs de modification de filtre: la valeur 'maximum' est inscrite aux adresses W_FLT_CTR à W_FLT_CTR+191 (6.20D[5.M4]). Cela a pour effet de désactiver la modification sur les filtres.
- Mode cellule 0 : la cellule 0 sera reliée à l'entrée en temps réel 0. On écrit la valeur '0' à l'adresse W_ETR_N+0 (16.M14). Le mode SC_ETR correspond au code '007' sur W_MOD (13.M12). Le mode d'accès à la mémoire M15 (1024 adresses) est cyclique (MOD_CCY=0), croissant (MOD_DCY=1), non-alternatif (MOD_ALT=1), le code hexadécimal '300' s'ajoute sur W_MOD. Le code hexadécimal '307'('007'+'000'+'300') est inscrit à l'adresse W_MOD+0 (13.M12) correspondant à l'adresse du mode de la cellule 0. Cela active le bit de commande SC_ETR qui met en fonction le mode d'échantillonnage de la cellule.
- Adresses de l'échantillon de la cellule 0 : les adresses de début d'échantillon et de début de bouclage ont la valeur '0' qui est inscrite aux adresses W_ECH_DEB+0 (20.M19) et W_ECH_B1+0 (20.M21). Les adresses de fin d'échantillon et de fin de bouclage ont la valeur '1023' qui est inscrite aux adresses W_ECH_FIN+0 (20.M20) et W_ECH_B2+0 (20.M22). Comme l'accès est cyclique, la mémoire M15 sera utilisée comme tampon circulaire dans la zone assignée à la cellule 0.
- Fréquence de la cellule 0 : celle-ci n'a pas à être fixée, car l'échantillonnage est basé sur l'horloge (2.2) qui, une fois divisée, donne 44 100 Hz pour l'échantillonnage. Dans ce mode (SC_ETR), le pas d'incrémentation est fixe et égal à '1'.
- Amplitude de la cellule 0 : dans le présent exemple, l'amplitude est arbitrairement fixée à '100', valeur qui est donc inscrite à l'adresse W_AMP_BAS+0 (6.20A[5.M2]).
- Mode de la cellule 1 : une rampe négative correspond au code '4' sur W_MOD (13.M12). La modulation d'amplitude est additive (MOD_FCT_AMP=0), le code '0' est ajouté à W_MOD. On inscrit donc la valeur '4' à l'adresse W_MOD+1 (13.M12) correspondant à l'adresse du mode de la cellule 1. Cela active le bit de commande SC_RMN qui met en fonction le mode d'oscillation en rampe négative (14.88,84).
- Fréquence de la cellule 1: le facteur fréquenciel inscrit sur l'ensemble 0 correspond à la base de 440 Hz. On inscrit donc la valeur '1' (fréquence de l'ensemble multipliée par 1) à l'adresse W_FRE_BAS+1 (6.20B[5.M2]).
- Amplitude de la cellule 1: '100' est inscrit à l'adresse W_AMP_BAS+1 (6.20A[5.M2]).
- Commande amplitude cellule 1 : dans le présent exemple, la cellule 1 utilise la sortie de la cellule 0 pour moduler son amplitude. La valeur '0' est inscrite sur W_AMP_CTR+1 (6.20A[5.M4]). Cette valeur confère à la cellule 0 le rôle de source de modulation.
- Mode cellule 2 : la cellule 2 est programmée pour générer le signal d'échantillonnage de la trompette. Cela correspond au code '006' sur W_MOD. La modulation sur la fréquence est additive de sorte que le code '000' s'ajoute sur W_MOD. Le mode d'échantillonnage est non-cyclique (MOD_CCY=1), croissant (MOD_DCY=1), non-alternatif (MOD_ALT=1), le code hexadécimal '380' s'ajoute donc sur W_MOD. Le code hexadécimal '386'(006+000+380) est inscrit à l'adresse W_MOD+2 (13.M12). Cela active le bit de commande SC_ECH qui met en fonction le mode d'échantillonnage de la cellule.
- Adresses des échantillons de la cellule 2: l'adresse de début d'échantillon a la valeur '1024' qui est inscrite à l'adresse W_ECH_DEB+2 (20.M19). L'adresse de fin d'échantillon est fixée à 89224 qui est inscrite à l'adresse W_ECH_FIN+2 (20.M20).
- Inscription de l'échantillon de la cellule 2: l'échantillon de 88200 points est transféré du CPU à la mémoire d'échantillonnage M15 aux adresses W_ECH_CYC+'1024' à W_ECH_CYC+'89224' (17.121 et M15).
- Fréquence de la cellule 2 : le facteur fréquenciel inscrit sur l'ensemble 0 correspond à la base de 440Hz. On inscrit donc la valeur '1' (fréquence de l'ensemble multipliée par 1) à l'adresse W_FRE_BAS+2 (6.20B[5.M2]).
- Amplitude de la cellule 2: on fixe arbitrairement l'amplitude à la valeur '100' qui est donc inscrite à l'adresse W_AMP_BAS+2 (6.20A[5.M2]).
- Commande de fréquence de la cellule 2 : dans l'exemple, la cellule 2 utilise la sortie de la cellule 3 pour moduler sa fréquence. La valeur '3' est inscrite sur W_FRE_CTR+2 (6.20B[5.M4]) pour déterminer que la cellule 3 est utilisée comme source de modulation.
- Mode de la cellule 3: elle doit préalablement être mise dans le mode d'oscillation sinusoïdale. On écrit donc la valeur '0' à l'adresse W_MOD+3 (13.M12). Cela active le bit de commande SC_SIN qui met en fonction le générateur de fonction 81 contenant la table de sinus.
- Fréquence de la cellule 3: la fréquence de l'oscillation étant de 0,5 Hz, le facteur sur la fréquence de base doit être '0,00136' (0,5 Hz='440'*'0,00136'). La valeur '0,00136' (fréquence de l'ensemble multiplié par 1) est donc inscrite à l'adresse W_FRE_BAS+3 (6.20B[5.M2]).
- Amplitude de la cellule 3 : dans le présent exemple l'amplitude est arbitrairement fixée à la valeur '250' qui est inscrite à l'adresse W_AMP_BAS+3 (6.20A[5.M2]).
- Mise en phase des cellules 0 à 3: les cellules programmées pour l'ensemble 0 sont mises en phase. Le numéro '0' correspondant à l'ensemble 0 est écrit à l'adresse W_DEC (8.44).
- Amplitude de l'ensemble: on met le volume de l'ensemble 0 au maximum, en inscrivant la valeur 'maximum' à l'adresse W_ENS_AMP+0 (8.M8).
- Un instrument tel qu'une guitare est branché sur l'entrée en temps réel 0.
- Premier passage (durant l'éxécution des opérations d'initailisation décrites dans les
paragraphes 1.1.1. à 1.2.4):
- Cellule 0
- P1 :
-
- direction Axe-x des temps: positive
- lecture de l'entrée lN_0 (exemple: valeur'0,28'). Cette valeur est acheminée sur lN_CEL (16.103), et inscrite en mémoire (17.M15) à une adresse non définie (POS_X) mais à l'intérieur des limites d'adresse établies à l'initialisation de la cellule soit entre E_DEB(0) et E_FIN(1023).
- la cellule 0 n'étant pas assujettie à une commande externe d'amplitude, de fréquence, de phase ou de filtrage, les signaux P2_AMP, P2_FRE, P2_PHA et P2_FLT sont inopérants.
- P3:
-
- les paramètres de la cellule 0 sont initialisés suivant les données inscrites par le CPU aux valeurs résultant de l'initialisation.
- sélection de l'ensemble 0 sur la cellule 0.
- inscription de la valeur de la cellule 0 par le bit actif C_SCEL sur (8.M9) sur l'ensemble (8.U10,42). Cette valeur est nulle comme la valeur précédente. La cellule est initialisée à l'amplitude nulle pendant les passages précédents.
- P4:
-
- les paramètres de la cellule 0 sont fixés à leur valeur.
- accumulation de POS_X sur l'axe-x de la cellule 0 (5.M3; 6.20B).
- valeur nulle accumulée pendant le sous-cycle P3 (8.42) inscrite sur l'accumulateur d'ensemble (8.M7).
- calcul de l'amplitude (13.U12) de la cellule 0 = '100'. Valeur de l'échantillon de la cellule 0 = '28' (amplitude '100'* Valeur lN_0 = '0,28'). Mémorisation de cette valeur (13.M13).
- calcul de l'amplitude de l'ensemble 0= '0', valeur acheminée sur la mémoire M6 (non mémorisée).
- accumulateur de l'ensemble : aucune valeur n'est inscrite dans la mémoire M6 (bit C_ENS inactif sur 8.M9). La valeur précédente est nulle. L'ensemble initialisé a l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie : la valeur de l'ensemble 0 est nulle.
- Cellule 1
- P1 :
-
- direction Axe-x: positive
- P2_AMP
-
- La cellule 1 est assujettie à une commande externe d'amplitude par la cellule 0. La valeur calculée dans le cycle précédent de l'oscillation de la cellule 0 (13.M13) est captée sur la bascule 24 (fig.5). La modulation est active à la valeur '28'.
La cellule 1 n'étant pas assujettie à une commande externe de fréquence, de phase et de filtrage, les signaux P2_FRE, P2_PHA et P2_FLT sont inopérants. - P3:
-
- les paramètres de la cellule 1 sont initialisés suivant les données inscrites par le CPU à des valeurs acquises durant l'initialisation.
- affectation de la cellule 0 sur l'ensemble 0.
- addition de la valeur de la cellule 1 par le bit actif C_SCEL (8.M9) sur l'ensemble 0 (8.U10,42). Cette valeur est nulle comme la précédente. La cellule a été initialisée à l'amplitude '0' pendant les passages précédents.
- P4:
-
- les paramètres de la cellule 1 sont fixés (amplitude + modulation) à la valeur '28'.
- POS_X est accumulé sur l'axe-x de la cellule 1. La valeur est indéterminée.
- la valeur nulle accumulée au sous-cycle P3 sur la bascule 42 est inscrite dans l'accumulateur d'ensemble M7 (figure 8).
- calcul de l'amplitude (13.U12) de la cellule 1 à la valeur '128' ('100' AMP+'28' (Val.cellule 0)). La valeur de l'échantillon est indéterminée ('128'* la rampe sur une adresse indéterminée). Mémorisation dans la mémoire M13.
- l'amplitude de l'ensemble à la valeur '0' est acheminée vers la mémoire M6 (non mémorisée).
- accumulateur de l'ensemble : la valeur n'est pas inscrite dans la mémoire M6, le bit C_ENS étant inactif (8.M9). La valeur précédente est nulle, l'ensemble ayant été initialisé à l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie : la valeur de l'ensemble 0 est nulle.
- Cellule 2
- P1 :
-
- direction Axe-x: positive
- P2_FRE
-
- la cellule 2 n'est assujettie qu'à une commande externe de fréquence par la cellule 3. La valeur de l'oscillation de la cellule 3 au passage précédent est nulle et captée sur la bascule 24. La modulation est nulle.
- P3:
-
- les paramètres de la cellule 2 sont initialisés suivant les données inscrites par le CPU aux valeurs acquises durant l'initialisation.
- affectation de la cellule 2 sur l'ensemble 0.
- addition de la valeur de la cellule 2, le bit C_SCEL étant actif (8.M9), sur l'ensemble (8.U10,42). La valeur est nulle, car la valeur précédente est nulle et la cellule a été initialisée à l'amplitude '0' pendant les passages précédents.
- P4:
-
- les paramètres de la cellule 2 sont fixés à leur valeur.
- POS_X est accumulé sur l'axe-x. La valeur est indéterminée et comprise entre E_DEB (1024) et E_FIN (89224).
- la valeur nulle accumulée au sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur de l'ensemble (8.M7).
- calcul de l'amplitude (13.U12; valeur '100'). La valeur de l'échantillon est indéterminée ('100'*échantillon à adresse indéterminée). La valeur est mémorisée dans la mémoire M13.
- l'amplitude calculée pour l'ensemble 0 est acheminée vers la mémoire M6, mais pas mémorisée.
- accumulateur de l'ensemble : aucune valeur n'est inscrite dans la mémoire M6 car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle et l'ensemble est initialisé à l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie : la valeur de l'ensemble 0 est nulle.
- Cellule 3
- P1 :
-
- direction Axe-x: positive
- la cellule 3 n'est assujettie à aucune commande externe d'amplitude, de fréquence, de phase ou de filtrage.
- P3:
-
- les paramètres sont initialisés suivant les données initialisées par le CPU;
- affectation de la cellule 3 sur l'ensemble 0;
- la valeur de la cellule 3 n'est pas additionnée sur l'ensemble 0 (8.U10,42) car le bit C_SCEL est inactif (8.M9).
- P4:
-
- les paramètres sont fixés à leur valeur.
- POS_X est accumulé sur l'axe-x à une valeur indéterminée.
- la valeur nulle accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur d'ensemble (8.M7).
- l'amplitude (13.U12) est calculée (valeur '250'). La valeur d'échantillon de la cellule 3 est indéterminée ('250'*sinus avec adresse indéterminée). Mémorisation dans la mémoire M13.
- l'amplitude de l'ensemble est calculée (valeur '0') et acheminée vers la mémoire M6.
- accumulateur de l'ensemble: la valeur est inscrite dans la mémoire M6, car le bit C_ENS est actif (8.M9). La valeur précédente est nulle. L'ensemble a été initialisé à l'amplitude '0' pendant les passages précédents. La bascule 42 est mise à zéro pour initialiser l'ensemble pour le prochain passage.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle. Le passage 0 implique ensuite le traitement des cellules 4 à 191 pendant les cycles P1 à PCPU. Il n'y a pas de signal.
- Deuxième passage
II se déroule pendant la mise en phase et l'inscription des paramètres
d'ensemble (paragraphes 1.2.5., 1er échantillon):
- Cellule 0
- P1
-
- la mise en phase s'effectue par l'écriture de la valeur '0' (numéro de l'ensemble 0 à mettre en phase, toutes les cellules en faisant partie) sur la bascule 44 (figure 8). Comme les valeurs de phase sont '0', le terme POS_X de l'axe-x est initialisé sur le circuit de la figure 7 durant le sous-cycle P3 suivant. Le signal d'initialisation C_lNlT est généré par le bloc 50 et acheminé vers la porte 208 qui produit le signal CD_lNlT. POS_X de la cellule 0 est initialisé à E_DEB(cellule 0)='0'.
- lecture de l'entrée lN_0 (ex:'0,35') et transmission vers IN_CEL. La valeur est inscrite dans la mémoire M15 (POS_X=?).
- La cellule 0 n'est assujettie à aucune commande externe.
- P3:
-
- les paramètres de la cellule 0 sont inchangés depuis le passage précédent.
- le circuit de la figure 7 (bloc 35 signal CD_lNlT) reconnait la mise en phase ordonnée durant le cycle P1. POS_X est mis à '0' sur la cellule 0.
- affectation de la cellule 0 à l'ensemble 0.
- inscription de la valeur de la cellule 0 par le bit actif C_SCEL (8.M9) sur l'ensemble (8.U10,42); la valeur d'amplitude était '100'.
- P4:
-
- les paramètres de la cellule 0 sont fixés à leur valeur.
- accumulation de POS_X sur l'axe-x de la cellule 0 = '0' (phase '0').
- valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite dans l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) de la cellule 0 à la valeur '100'. La valeur d'échantillon de la cellule 0 = '35' ('100'* lN_0='0,35'). Mémorisation sur la mémoire M13.
- calcul de l'amplitude de l'ensemble à la valeur '0'. Elle est acheminée sur la mémoire M6 mais non mémorisée.
- accumulateur de l'ensemble: la valeur n'est pas inscrite sur la mémoire M6 car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle, l'ensemble a été initialisé à l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle.
- Cellule 1
- P1 :
-
- mise en phase sur l'ensemble 0 de la cellule, exécutée pendant le sous-cycle P3; E_DEB = '0'.
- P2_AMP
-
- la cellule 1 n'est assujettie qu'à une commande externe d'amplitude par la cellule 0. La valeur calculée pendant le cycle précédent de l'oscillation de la cellule 0 et stockée dans la mémoire M13 est captée sur la bascule 24. La modulation est active à la valeur '35'.
- P3:
-
- les paramètres de la cellule 1 sont inchangés depuis le passage précédent.
- le circuit de la figure 7 (bloc 35 signal CD_lNlT) reconnaít la mise en phase ordonnée durant le cycle P1. POS_X est mis à '0' sur la cellule 1 (E_DEB).
- affectation de la cellule 1 sur l'ensemble 0.
- addition de la valeur de la cellule 1, le bit C_SCEL étant actif (8.M9), sur l'ensemble (8.U10,42). Les valeurs précédentes sont cellule 0('28') + cellule 1(?). La valeur est donc indéterminée.
- P4:
-
- les paramètres de la cellule 1 sont fixés à leur valeur à l'amplitude est ajoutée la valeur de la cellule 0 (5.U4,M3; 6.20A) qui la module. L'amplitude totale de la cellule = '135'.
- accumulation de POS_X sur l'axe-x de la cellule 1 ='0' (phase '0').
- valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) de la cellule 1 = '135', soit'100'Ampl + '35' (valeur cellule 0). La valeur de l'échantillon de la cellule 1 = '134' ('135'*rampe début'0,99'). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble à la valeur '0' qui est acheminée sur la mémoire M6 mais non mémorisée.
- accumulateur de l'ensemble. La valeur n'est pas inscrite dans la mémoire M6, car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle. L'ensemble initialisé a l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle.
- Cellule 2
- P1 :
-
- mise en phase sur l'ensemble 0 de la cellule, exécutée pendant le sous-cycle P3. POS_X sur la cellule 2 est initialisé à E_DEB = '1024'.
- P2_FRE
-
- la cellule 2 n'est assujettie qu'à une commande externe de fréquence par la cellule 3. La valeur calculée pendant le passage précédent de l'oscillation de la cellule 3 (13.M13) est captée sur la bascule 24. La modulation est active à une valeur indéterminée.
- P3:
-
- les paramètres sont inchangés depuis le passage précédent.
- le circuit de la figure 7 (bloc 35 signal CD_INIT) reconnaít la mise en phase ordonnée durant le cycle P1. POS_X est mis à '1024' (E_DEB).
- affectation de la cellule 2 à l'ensemble 0.
- addition de la valeur de la cellule 2 par le bit actif C_SCEL (8.M9) sur l'ensemble 0 (8.U10,42) aux valeurs précédentes : cellule 0('28') + cellule 1(?)+ cellule 2(?). La valeur est donc indéterminée.
- P4:
-
- les paramètres sont fixés à leur valeur. La fréquence est additionnée à la valeur de la cellule 1 (5.U4, M3; 6.20B) qui la module en fonction de la valeur accumulée au premier passage (ex: valeur accumulée=indéterminée). Comme la mise en phase est en cours, la valeur de fréquence n'a pas de rôle.
- accumulation de POS_X sur l'axe-x de la cellule 2 = '1024' (phase '0').
- valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) à la valeur '100'. La valeur de l'échantillon de la cellule 2 = '11' ('100'* premier point trompette par exemple '0,11' sur adresse 1024). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble à la valeur '0' qui est acheminée sur la mémoire M6 mais pas mémorisée.
- accumulateur de l'ensemble: la valeur n'est pas inscrite dans la mémoire M6 car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle. L'ensemble initialisé a l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle.
- Cellule 3
- P1 :
-
- mise en phase sur l'ensemble 0 de la cellule, exécutée dans le sous-cycle P3.
- aucun assujettissement à une commande externe pendant les sous-cycles P2_AMP, P2_FRE, P2_PHA et P2_FLT.
- P3:
-
- les paramètres sont inchangés depuis le passage précédent.
- le circuit de la figure 7 (bloc 35 signal CD_INIT) reconnaít la mise en phase ordonnée durant le cycle P1. POS_X est mis à 0.
- affectation de la cellule 3 à l'ensemble 0.
- la valeur de la cellule 3 n'est pas additionnée, le bit C_SCEL étant inactif (8.M9), sur l'ensemble (8.U10,42).
- P4:
-
- les paramètres sont fixés à leur valeur.
- accumulation de POS_X sur l'axe-x = '0' (phase '0').
- valeur accumulée pendant le sous-cycle sur la bascule 42 est inscrite sur l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) à la valeur '250'. La valeur de l'échantillon = '0' ('250'* le premier point de la table sinus ='0'). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble 0 à la valeur '0' qui est mémorisée et acheminée dans la mémoire M6.
- accumulateur de l'ensemble: la valeur inscrite sur la mémoire M6 (bit C_ENS actif sur 8.M9) valeur addition cellules, ensemble initialisé à l'amplitude='0' (mise au maximum au passage suivant seulement). Mise à 0 de la bascule 8.42, initialisant l'ensemble pour le prochain passage.
- accumulateur de sortie: la valeur de l'ensemble 0 = '0' (amplitude ='0'* la somme des échantillons des cellules 0 à 2), la cellule 3 n'étant pas additionné par choix. Le bit C_CEL est inactivé par le CPU.
- Deuxième passage des cellules 4 à 191 sur les cycles P1 à PCPU (pas de signal).
- Troisième passage (après la mise en phase, élaboration du deuxième échantillon):
- Cellule 0
- P1 :
-
- Direction Axe-x: positive.
- lecture de l'entrée lN_0 (ex: '0,33') et acheminement sur IN_CEL. La valeur '0,33' est inscrite dans la mémoire M15 = (POS_X ='0').
- aucun assujettissement à une commande externe pendant les sous-cycles P2_AMP, P2_FRE, P2_PHA et P2_FLT.
- P3:
-
- les paramètres sont inchangés depuis le passage précédent.
- incrémentation de l'adresse POS_X à la valeur '1' ('0' + '1'). Dans le mode SC_ETR, l'incrément de POS_X est constant et égal à '1' (7.32).
- affectation de la cellule 0 à l'ensemble 0.
- inscription de la valeur '35' par le bit inactif C_SCEL (8.M9) sur l'ensemble (8.U10,42), la valeur précédente était'35'.
- P4:
-
- les paramètres sont fixés à leur valeur.
- accumulation de POS_X sur l'axe-x = '1'.
- valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) de la cellule 0 à la valeur '100'. La valeur de l'échantillon de la cellule 0 = '33' (ampli '100'*valeur lN_0 = '0,33'). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble à la valeur 'maximum', qui est acheminée vers la mémoire M6 mais non mémorisée.
- accumulateur d'ensemble : la valeur n'est pas inscrite dans la mémoire M6, car le bit C_ENS est inactif (8.M9). La valeur précédente est maintenue jusqu'à la demière cellule de l'ensemble 0.
- accumulateur de sortie: la valeur de l'ensemble 0 = nulle.
- Cellule 1
- P1 :
-
- Direction Axe-x: positive.
- P2_AMP
-
- la cellule 1 n'est assujettie qu'à une commande externe d'amplitude par la cellule 0. La valeur calculée dans le cycle précédent de l'oscillation de la cellule 0 (13.M13) est captée sur la bascule 24. La modulation est active, soit la valeur '33'.
- P3:
-
- les paramètres de la cellule 1 sont inchangés depuis le passage précédent.
- incrémentation de l'adresse POS_X de la cellule 1 = '10'('0' + '10'). A noter que l'incrément est égal à '10', 79 fois sur 100 et égal à '11', 21 fois sur 100 à 440 Hz.
- affectation de la cellule 1 sur l'ensemble 0.
- addition de la valeur de la cellule 1, par le bit actif C_SCEL (8.M9), sur l'ensemble (8.U10,42). Les valeurs précédentes sont: cellule 0('35')+ cellule 1('134')= '169'.
- P4:
-
- les paramètres sont fixés à leur valeur. L'amplitude est additionnée à la valeur de la cellule 0 (5.U4, M3 de 6.20A) qui la module par la valeur '33'. L'amplitude totale de la cellule 1 est donc '100'+'33' = '133'.
- accumulation de POS_X sur l'axe-x de la cellule 1 = '10'.
- valeur accumulée au sous-cycle P3 dans la bascule 42 est inscrite sur l'accumulateur d'ensemble (8.M7).
- calcul de l'amplitude (13.U12) de la cellule 1 à '133' {'100'ampl + '33' (valeur cellule 0)}. - valeur d'échantillon de la cellule 1 = '129'('133'* '0,97'). La valeur '0,97' est la valeur de la rampe à l'adresse 10. Cette valeur est mémorisée (13.M13).
- calcul de l'amplitude de l'ensemble à 'maximum'. Cette valeur est acheminée vers la mémoire M6, mais pas mémorisée.
- accumulateur d'ensemble : la valeur n'est pas inscrite dans la mémoire M6, car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle. L'ensemble a été initialisé à l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle.
- Cellule 2
- P1 :
-
- Direction Axe-x: positive.
- P2_FRE
-
- la cellule 2 n'est assujettie qu'à une commande externe de fréquence par la cellule 3. La valeur calculée pendant le passage précédent de l'oscillation de la cellule 3 (13.M13) est captée sur la bascule 24. La modulation est active à la valeur '0'.
- P3:
-
- les paramètres de la cellule 2 sont inchangés depuis le passage précédent.
- incrémentation de l'adresse POS_X de la cellule 2 = '1034' ('1024' + '10'). Ici aussi, l'incrément est égal à '10', 79 fois sur 100 et égal à '11', 21 fois sur 100 à 440 Hz).
- attribution de la cellule 2 sur l'ensemble 0.
- addition de la valeur de la cellule 2 par le bit actif C_SCEL (8.M9) sur l'ensemble (U8.U10,42). Les valeurs précédentes sont: cellule 0 ('35')+ cellule 1('134')+ cellule 2('11') = '180'.
- P4:
-
- les paramètres de la cellule 2 sont fixés à leur valeur. La fréquence est additionnée à la valeur de la cellule 3 (5.U4, M3 de 6.20B) qui la module, ici à la valeur '0'. La fréquence de la cellule est donc '10.21' ('10.21'+'0').
- accumulation de POS_X sur l'axe-x = '1034'.
- la valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite sur l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) de la cellule 2 à la valeur '100' (amplitude = '100'). La valeur de l'échantillon de la cellule 1 = '-8', par exemple ('100'*échantillon de l'adresse 1034 qui est ici supposé égal à '-0,08'). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble 0 à la valeur 'maximum' acheminée vers la mémoire M6, mais pas mémorisée.
- accumulateur d'ensemble : la valeur n'est pas inscrite dans la mémoire M6, car le bit C_ENS est inactif (8.M9). La valeur précédente est nulle. L'ensemble est initialisé à l'amplitude '0' pendant les passages précédents.
- accumulateur de sortie: la valeur de l'ensemble 0 est nulle.
- Cellule 3
- P1 :
-
- Direction Axe-x: positive.
- pas d'assujettisement de la cellule 3 à une commande externe d'amplitude, de fréquence, de phase et de filtrage.
- P3:
-
- les paramètres sont inchangés depuis le passage précédent.
- incrémentation de l'adresse POS X = '0'('0' + '0'), l'incrément étant égal à '0.001136', soit '0', 9989 fois sur 10000 et '1', 11 fois sur 10000 à 0.5 Hz).
- affectation de la cellule 3 sur l'ensemble 0.
- la valeur de la cellule 3 n'est pas additionnée sur l'ensemble 0 (U8.U10,42), car le bit C_SCEL est inactif (8.M9).
- P4:
-
- les paramètres sont fixés à leur valeur.
- l'accumulation de POS_X sur l'axe-x = '0'.
- la valeur accumulée pendant le sous-cycle P3 sur la bascule 42 est inscrite dans l'accumulateur d'ensemble M7.
- calcul de l'amplitude (13.U12) à '250'. La valeur de l'échantillon = '0'('250'* le premier point de la table sinus, soit '0'). La valeur est mémorisée dans la mémoire M13.
- calcul de l'amplitude de l'ensemble à la valeur 'maximum' qui est acheminée vers la mémoire M6.
- accumulateur d'ensemble : la valeur est inscrite dans la mémoire M6, car le bit C_ENS est actif (8.M9). La valeur d'addition des cellules = '180', (amplitude max '0,9999'* somme des cellules 0 à 2 = '180'. Il est à noter que la cellule 3 n'est pas additionnée intentionellement, le bit C_CEL étant inactivé par le CPU). L'ensemble est initialisé à l'amplitude 'maximum'. La bascule 42, est mise à '0' initialisant l'ensemble pour le prochain passage.
- accumulateur de sortie: la valeur de l'ensemble 0 = 180.
- Troisième passage des cellules 4 à 191 sur les cycles P1 à PCPU (pas de signal).
- Quatrième passage (Sommaire)
- Cellule 0
- P1 :
-
- lecture de l'entrée lN_0 (ex : '0,04') acheminée sur IN_CEL. La valeur inscrite dans la mémoire M15 à '0,04' (POS_X='0').
- P3:
-
- POS_X (cellule 0)= '2'('1'+'1')
- ensemble 0 : valeur précédente de la cellule 0 = '33'.
- P4:
-
- valeur de l'échantillon de la cellule 0='4' (ampli '100'* valeur IN_0='0,04').
- Cellule 1
- P2_AMP
-
- la cellule 1 subit la commande externe d'amplitude par la cellule 0. La valeur du passage précédent de la cellule 0 est captée sur la bascule 24. La modulation est active, soit à la valeur '33'.
- P3:
-
- POS_X = '21'('10'+'11'). (Incrément= '10', 79 fois sur 100; '11':21 fois sur 100 à 440 Hz).
- ensemble 0: addition des valeurs précédentes : cellule 0('33') + cellule 1('129') = '162'.
- P4:
-
- amplitude additionnée avec la valeur cellule 0='8'. L'amplitude totale = '104' ('100'+'4').
- valeur de l'échantillon de la cellule 1 = '101' ('104'*rampe adr.21 = '0,95').
- Cellule 2
- P2_FRE
-
- la cellule 2 subit la commande externe de fréquence par la cellule 3. La valeur du passage précédent de la cellule 3 est captée sur la bascule 24. La modulation est active, soit la valeur '0'.
- P3:
-
- POS_X = '1045' ('1034+11'). (Incrément= '10': 79 fois sur 100; '11': 21 fois sur 100 à 440 Hz).
- ensemble :addition des valeurs précédentes : cellule 0('33')+ cellule 1('129')+cellule 2('-8')= '154'.
- P4:
-
- fréquence additionnée à la valeur précédente '0' de la cellule 3, fréquence de la cellule= '10.21'('10.21'+'0').
- valeur de l'échantillon de la cellule 2 = '-18' ('100'*échantillon adr. 1045 = exemple -'0,18').
- Cellule 3
- P3:
-
- POS_X ='0'('0'+'0'). Incrément = '0,001136' soit '0', 9989 fois sur 10 000 et '1', 11 fois sur 10 000 à 0,5 Hz).
- la valeur de la cellule 3 n'est pas additionnée, le bit C_SCEL étant inactif (8.M9), sur l'ensemble (U8.U10,42).
- P4:
-
- la valeur de l'échantillon de la cellule 3 = 0('250'*1er point table sinus = '0').
- ensemble: le bit C_ENS est actif sur la mémoire M9. Le total d'addition des cellules = '154' (somme des cellules 0 à 2)* '0,9999' (ensemble ampl.max.). La cellule 3 n'est pas additionnée, car C_CEL est inactivé par le CPU.
- accumulateur de sortie : la valeur de l'ensemble 0 = '154'.
- Quatrième passage des cellules_4 à 191 sur les cycles P1 à PCPU (pas de
signal).
O-O-O-O-O-O-O-O- Un signal sera ainsi généré par la séquence des passages sur les cellules 0 à 2. La cellule 3 étant à basse fréquence (0,5 Hz), l'effet de sa modulation sur la fréquence de la cellule 2 sera également lent, l'oscillation sinus de cette cellule n'avancera d'adresse qu'une fois tous les 998,9 passages (ou 11 fois sur 10 000, comme indiqué plus haut. Pour en voir l'effet, on passe tout de suite du 999 passage au 1001ième passage. - 999ième passage (sommaire)
- Cellule 0
- P1:
-
- lecture entrée lN_0 (ex : '-0.69') acheminée sur IN_CEL. La valeur est inscrite dans la mémoire M15 = '-0,69' (POS_X='0').
- P3:
-
- POS_X = '995' ('994'+'1'). A noter que cette valeur incrémentera jusqu'à E_B2 ('1023'), puis sera tronquée pour prendre la valeur de E_B1('0'), le fonctionnement étant cyclique.
- ensemble 0: valeur précédente cellule 0 (exemple= '-72')= '-72'.
- P4:
-
- la valeur de l'échantillon de la cellule 0='-69' (ampli '100'* valeur IN_0='-0,69').
- Cellule 1
- P2_AMP
-
- la cellule 1 subit la commande externe d'amplitude par la cellule 0. La valeur au cycle précédent de la cellule 0 est captée sur la bascule 24. La modulation est active, soit à la valeur '-69'.
- P3:
-
- POS_X = '942'('932'+'10'). (Incrément= '10': 79 fois sur 100; '11':21 fois sur 100 à 440 Hz). A noter que cette valeur incrémente sur 10 bits ('0' à '1023').
- ensemble 0: addition des valeurs précédentes : cellule 0('-72') + cellule 1{'-23': rampe('-0,81')*('100'-'72')}='-95'.
- P4:
-
- l'ampitude est additionnée à la valeur de la cellule 0='69'. L'ampitude totale = '311'('100'-'69').
- valeur de l'échantillon de la cellule 1 = '-25' ('31'*rampe adr.942 = '-0,82').
- Cellule 2
- P2_FRE
-
- la cellule 2 subit la commande externe de fréquence par la cellule 3. La valeur du passage précédent de la cellule 3 est captée sur la bascule 24. La modulation est active, soit à la valeur '0'.
- P3:
-
- POS_X = '10159' ('10149'+'10'). (Incrément= '10': 79 fois sur 100; '11': 21 fois sur 100 à 440 Hz). A noter que cette valeur incrémentera jusqu'à E_FIN ('89224') puis s'arrête de s'incrémenter, le fonctionnement étant ici non cyclique.
- ensemble 0 addition des valeurs précédentes : cellule 0('-72')+ cellule 1('-23')+cellule 2(ex:'32')='-63'.
- P4:
-
- la fréquence est additionnée à la valeur '0' précédente de la cellule 3. La fréquence de la cellule= '10,21'('10,21'+'0')
- la valeur de l'échantillon de la celulle 2 = '30' ('*100'*échantillon adr. 10159 = exemple '-0,30).
- Cellule 3
- P3:
-
- POS_X = '1'('0'+'1').(incrément = '0,001136': '0':9989 fois sur 10 000 et '1':11 fois sur 10 000 à 0,5 Hz).
- la valeur cellule 3 n'est pas additionnée, le bit C_SCEL étant inactif (8.M9) sur l'ensemble (U8.U10,42).
- P4:
-
- la valeur de l'échantillon = '1'('250'*2ième point de la table de sinus nulle='0,006').
- ensemble: le bit C_ENS est actif sur la mémoire M9). Le total d'addition des cellules = '-63' (somme des cellules 0 à 2)* '0,9999' (ensemble ampl. max.). La cellule 3 n'est pas additionnée, car C_CEL est inactivé par le CPU.
- accumulateur de sortie : la valeur de l'ensemble 0 = '-63'.
- 999ième passages des cellules 4 à 191 sur les cycles P1 à PCPU (pas de signal).
- 1000ième passage (sommaire)
- Cellule 0
- P1:
-
- lecture de l'entrée lN_0 (ex : '-0,64') acheminée sur IN_CEL. La valeur est inscrite dans la mémoire M15 = '-0,64' (POS_X='0').
- P3:
-
- POS_X = '996' ('995'+'1').
- ensemble 0: cellule 0 à la valeur précédente = '-69'.
- P4:
-
- la valeur d' l'échantillon de la cellule 0='-64' (ampli '100'* valeur IN_0='-0,64').
- Cellule 1
- P2_AMP
-
- cellule 1 subit la commande externe d'amplitude par la cellule 0. La valeur pendant le passage précédent de la cellule 0 est captée sur la bascule 24. La modulation est active, soit à la valeur '-69'.
- P3:
-
- POS_X = '953'('942'+'11').
- ensemble 0: addition des valeurs précédentes : cellule 0('-69') + cellule 1{'-25': rampe('-0,82')*('100'-'69')}='-95'.
- P4:
-
- l'amplitude est additionnée avec la valeur de la cellule 0='-64'. L'amplitude totale = '36' ('100'-'64').
- la valeur de l'échantillon de la cellule 1 = '-30' ('36'*rampe adr.953 = '-0,83').
- Cellule 2
- P2_FRE
-
- la cellule 2 subit la commande externe de fréquence par la cellule 3. La valeur du passage précédent de la cellule 3 est captée sur la bascule 24. La modulation est active, soit à la valeur '1' qui s'additionne à l'incrément de fréquence, soit '11' ('10,21' ou'10', 79 fois sur 100 et '11', 21 fois sur 100)+'1' = '12', qui sera la valeur lors du prochain passage. L'incrément courant est de '11'.
- P3:
-
- POS_X = '10170' ('10159'+'11'). (Incrément= '10': 79 fois sur 100; '11': 21 fois sur 100 à 440 Hz).
- ensemble 0 addition des valeurs précédentes : cellule 0('-69')+ cellule 1('-25')+cellule 2('30')='-64'.
- P4:
-
- la fréquence est additionnée à la valeur '1' précédente de la cellule 3. La fréquence de la cellule= '11,21'('10,21'+'1').
- valeur de l'échantillon de la cellule 2 = '24' ('100'*échantillon adr. 10 170 = exemple '0,24').
- Cellule 3
- P3:
-
- POS_X= '1'('1'+'0').(incrément = '0,001136': '0':9989 fois sur 10 000 et '1':11 fois sur 10 000 à 0,5 Hz).
- la valeur de la cellule 3 n'est pas additionnée, le bit C_SCEL étant inactif (8.M9), sur l'ensemble (U8.U10,42).
- P4:
-
- valeur de l'échantillon de la cellule 3 = '1'('250'*2ième point table sinus nulle='0.006').
- ensemble: le bit C_ENS est actif sur la mémoire M9. Le total de l'addition des cellules = '-64' (somme cellules 0 à 2)* '0,9999' (ensemble ampl. max.).
- accumulateur de sortie: valeur ensemble 0 = '-64'.
- 1000ième passages des cellules 4 à 191 sur les cycles P1 à PCPU (pas de signal).
- 1001ième passage (sommaire)
- Cellule 0
- P1:
-
- lecture de l'entrée lN_0 (ex : -'0,59') acheminée sur IN_CEL. La valeur est inscrite dans la mémoire M15 = '-0,59' (POS_X='0').
- P3:
-
- POS_X = '997' ('996'+'1').
- ensemble 0: cellule 0 à la valeur précédente: = '-64'.
- P4:
-
- valeur de l'échantillon de la cellule 0='-59' (ampli '100'* valeur lN_0='-0,59').
- Cellule 1
- P2_AMP
-
- la cellule 1 subit la commande externe d'amplitude par la cellule 0. La valeur au cycle précédent de la cellule 0 est captée sur la bascule 24, la modulation est active, soit à la valeur '-64'.
- P3:
-
- POS_X ='963'('953'+'10'). (Incrément= '10': 79 fois sur 100; '11':21 fois sur 100 à 440 Hz).
- ensemble 0: addition des valeurs précédentes : cellule 0('-64') + cellule 1('-30': rampe{-'0.83')*('100'-'64')}='-94'.
- P4:
-
- l'amplitude est additionnée à la valeur de la cellule 0='-59'. L'amplitude totale = '41' ('100'-'59').
- la valeur de l'échantillon de la cellule 1 = '-34' ('41'*rampe adr.963 = '-0,84').
- Cellule 2
- P2_FRE
-
- la cellule 2 subit la commande externe de fréquence par la cellule 3. La valeur du passage précédent de la cellule 3 est captée sur la bascule 24. La modulation est active, soit à la valeur '1'. Cette valeur s'additionne à l'incrément de fréquence, soit '10' ('10,21 '11', 21 fois sur 100)+'1' = '11', valeur sur prochain passage. L'incrément courant est de '11'.
- P3:
-
- POS_X = '10181' ('10170'+'11'). (Incrément= '10': 79 fois sur 100; '11': 21 fois sur 100 à 440 Hz).
- ensemble 0 addition des valeurs précédentes : cellule 0('-64')+ cellule 1('-29')+cellule 2('24')='-71'.
- P4:
-
- la fréquence est additionnée à la valeur '1' précédente de la cellule 3. La fréquence de la cellule= '11,21'('10,21'+'1').
- valeur de l'échantillon de la cellule 2 = '21' ('100'*échantillon adr. 10181 = exemple '-0,21').
- Cellule 3
- P3:
-
- POS_X = '1'('1'+'0').(incrément = '0,001136': '0':9989 fois sur 10 000 et '1':11 fois sur 10 000 à 0,5 Hz).
- la valeur de la cellule 3 n'est pas additionnée, le bit C_SCEL étant inactif sur M9, sur l'ensemble (U8.U10,42).
- P4:
-
- la valeur de l'échantillon de la cellule 3 = '1'('250'*2ième point table sinus nulle='0,006').
- ensemble 0 : le bit C_ENS est actif sur M9. Le total d'addition des cellules = '-63' (somme des cellules 0 à 2)* '0,9999' (ensemble ampl. max).
- accumulateur de sortie : valeur de l'ensemble 0 = '-71'.
- 1001ième passages des cellules_4 à 191 sur les cycles P1 à PCPU (pas de signal). Le signal sera ainsi généré par la séquence des passages, sur les cellules 0 à 2. La cellule 3 étant à basse fréquence (0.5 Hz) l'effet de sa modulation sur la fréquence de la cellule 2 se fait sentir plus lentement, l'incrément de la cellule 2 (base '10,21') suit l'évolution lente du sinus de la cellule 3 ('10,21'+'1' aux passages 1001 à 1998, '10,21'+'3' aux passages 1999 à 2996, '10,21'+'4' aux passages 2997 à 3994, '10,21'+'6' aux passages 3995 à 4991, etc).
Claims (31)
- Système de synthèse d'une suite d'échantillons électroniques destinés à la production d'un spectre sonore apparaissant sur une sortie (S), caractérisé en ce qu'il comprend:des premiers moyens (I) pour déterminer une succession de cycles de travail (P) rythmés en fonction d'une fréquence d'échantillonnage (ACT);au moins une source (72, 73, 74, CPU) d'échantillons dits de niveau zéro représentant au moins un signal sonore et apte à fournir au cours de chaque cycle de travail en cours x au moins un échantillon de niveau zéro,des seconds moyens (20B, 23 à 25) pour déterminer, pour chacun desdits échantillons de niveau zéro à sélectionner au cours d'un cycle de travail suivant x+1, une première valeur propre à cet échantillon d'un paramètre de fréquence (FRE),des troisièmes moyens (20A, 20C, 20D, 25) pour déterminer, pour chacun desdits échantillons de niveau zéro à traiter au cours d'un cycle de travail suivant x+1, au moins une seconde valeur, également propre à cet échantillon, d'au moins un autre paramètre (AMP, FLT; PHA),au moins deux mémoires de paramètres (M3) pour, au cours du cycle de travail x en cours, mémoriser respectivement lesdites première et seconde valeurs de paramètre, dans n emplacements de mémoire respectifs, afin de pouvoir utiliser ces valeurs au cours du cycle de travail suivant x+1,des quatrièmes moyens (30) pour, pendant chaque cycle de travail en cours x déterminer, en fonction de chacune des n valeurs de paramètre de fréquence (FRE) mémorisées pendant le cycle de travail précédent x-1, une valeur de désignation (POS_X) pour désigner parmi lesdits échantillons de niveau zéro, le ou les échantillons de niveau zéro qui, au cours du cycle de travail suivant x+1, vont contribuer à l'élaboration de n échantillons de premier niveau respectifs,une mémoire de valeurs de désignation (M5, 20B) pour mémoriser lesdits n valeurs de désignation (POS_X) déterminées pendant le cycle de travail en cours x, afin de pouvoir les utiliser pendant le cycle de travail suivant x+1,des cinquièmes moyens (U12, 30, 76) pour, pendant le cycle de travail x en cours, appliquer à chacun des échantillons de niveau zéro désignés pendant le cycle de travail précédent x-1, la valeur correspondante dudit autre paramètre (AMP, PHA, FLT) mémorisée pendant le cycle de travail précédent, pour former n échantillons actuels de premier niveau et les mémoriser respectivement dans n emplacements d'une mémoire d'accumulation (M13), etdes sixièmes moyens (40, 60) pour au cours du cycle de travail en cours x, transférer vers ladite sortie (S) les n échantillons de premier niveau mémorisés au cours du cycle de travail précédent x-1,
- Système de synthèse suivant la revendication 1, caractérisé en ce que lesdits premiers (I), seconds (20, 25), troisièmes (20, 25), quatrièmes (30), cinquièmes (U12, 30, 76) et sixièmes moyens (40, 60) sont utilisés en partage de temps au cours des cycles de travail successifs pour déterminer les valeurs relatives auxdites cellules dans lesdites mémoires de paramètre, de valeurs de désignation et d'accumulation
- Système de synthèse suivant l'une quelconque des revendications 1 et 2, caractérisé en ce qu'il comprend également une unité de gestion (CPU) connectée auxdits seconds, troisième, quatrième, cinquièmes et sixièmes moyens, pour en gérer des valeurs de fonctionnement selon un logiciel exécuté par cette unité de gestion.
- Système de synthèse suivant la revendication 3, caractérisé en ce que lesdites valeurs de fonctionnement sont des valeurs initiales desdits paramètres et/ou des valeurs d'incrément de ces paramètres (FRE, AMP, PHA, FRT), lesdites valeurs initiales et d'incrément étant déterminées par ledit logiciel.
- Système de synthèse suivant l'une quelconque des revendications 1 à 4, caractérisé en ce que lesdits premiers moyens (I) sont agencés pour déterminer successivement, au cours de chacun desdits cycles (P), n sous-cycles (P1) de signaux de commande affectés respectivement auxdites n cellules, les signaux de commande (P2_AMP, P2_FRE, P2_PHA, P2_FLT, P3, P4) de chacun de ces sous-cycles (P1) étant destinés, d'une part à activer, pendant le cycle de travail x en cours, des opérations de calcul pour la détermination desdites première et seconde valeurs de paramètre de la cellule correspondante et d'autre part, pour ce qui concerne chacune desdites mémoires, à permettre la lecture/écriture dans lesdits n emplacements de mémoire, de données résultant de la détermination de ces valeurs, ces données formant les contenus respectifs desdites n cellules utilisés pendant le cycle de travail suivant x+1.
- Système de synthèse suivant la revendication 5, lorsqu'elle dépend de l'une quelconque des revendications 3 et 4, caractérisé en ce que chacun desdites sous-cycles de signaux de commande (P1) comprend également un signal de commande (PCPU) pour autoriser ladite unité de gestion (CPU) à communiquer avec lesdits premiers, seconds, troisièmes, quatrièmes, cinquièmes et sixièmes moyens (I; 20B,25; 20A, 20C, 20D, 25; U12, 30, 76; 40, 60).
- Système de synthèse suivant l'une quelconque des revendications 5 et 6, caractérisé en ce que lesdits seconds moyens (20B, 25) exécutent une fonction de calcul de la forme dans laquelle PARP
n est la valeur de paramètre de fréquence courante de la cellule considérée pendant ledit sous-cycle (P1) en cours ou la valeur initiale de paramètre de fréquence, PARPn-1 est la valeur de paramètre de fréquence élaborée au cours du sous-cycle (P1) précédent pour cette cellule et INCPn est l'incrément apporté à la valeur courante de paramètre de fréquence vis-à-vis de la valeur précédente. - Système de synthèse suivant l'une quelconque des revendications 5 à 7, caractérisé en ce que lesdits troisièmes moyens (20A, 20C, 20D, 25) exécutent une fonction de calcul de la forme dans laquelle PARP
n est la valeur courante de l'un desdits autres paramètres (AMP, FLT, PHA) de la cellule considérée pendant ledit sous-cycle (P1) en cours ou la valeur initiale de cet autre paramètre, PARPn-1 est la valeur dudit autre paramètre élaborée au cours du sous-cycle (P1) précédent pour cette cellule et INCPn est l'incrément apporté à la valeur courante dudit autre paramètre vis-à-vis de la valeur précédente. - Système de synthèse suivant l'une quelconque des revendications 7 et 8, caractérisé en ce que lesdits seconds et/ou troisièmes moyens comprennent une mémoire de valeur initiale (M1) destinée à contenir, pour chacune desdites cellules, ladite valeur initiale de paramètre et une mémoire d'incrément (M3), destinée à contenir, pour chacune desdites cellules, ladite valeur d'incrément de paramètre.
- Système de synthèse suivant l'une quelconque des revendications 7 à 9, caractérisé en ce que lesdits troisièmes moyens (20A, 20C, 20D, 25) comprennent un circuit pour le calcul d'au moins l'un desdits autres paramètres (AMP, FLT, PHA), identique au circuit desdits seconds moyens (20b, 25) pour le calcul dudit paramètre de fréquence (FRE).
- Système de synthèse suivant l'une quelconque des revendications 1 à 10, caractérisé en ce que lesdits quatrièmes moyens (30) comprennent une première unité de calcul (U4) pour combiner algébriquement ladite valeur de paramètre de fréquence du cycle de travail en cours avec une valeur (ENS_FRE) représentant la fréquence fondamentale du son à synthétiser auquel contribue l'échantillon de premier niveau calculé pendant ce cycle en cours, une seconde unité de calcul (U6) pour combiner algébriquement le résultat fourni par ladite première unité de calcul avec le contenu actuel de l'emplacement de ladite mémoire de valeurs de désignation (M5) correspondant à la cellule traitée au cours du cycle de travail en cours et des septièmes moyens (35, 36) pour remplacer dans cet emplacement la valeur de désignation (POS_X) calculée au cours du cycle de travail précédent par le résultat du calcul effectué au cours d cycle de travail en cours par ladite seconde unité de calcul (U6).
- Système de synthèse suivant la revendication 11, caractérisé en ce que lesdits quatrièmes moyens (30) comprennent également un multiplexeur (33) dont la sortie est connectée à ladite seconde unité (U6), dont l'une des entrées reçoit le résultat du calcul de ladite première unité de calcul (U5), et dont l'autre entrée reçoit un signal de progression de valeur fixe, notamment '0001', de ladite valeur de désignation permettant, sous la commande d'un signal de mode (SC_ETR), de faire progresser cette valeur de désignation de ladite valeur fixe d'un cycle de travail à l'autre.
- Système de synthèse suivant l'une quelconque des revendications 11 et 12, caractérisé en ce que lesdits quatrièmes moyens (30) comprennent également une troisième unité de calcul (U7) pour combiner algébriquement le résultat du calcul de ladite seconde unité de calcul (U6) avec la valeur en cours de l'un desdits autres paramètres représentant la phase (PHA) à appliquer à l'échantillon de premier niveau engendré au cours du cycle de travail suivant x+1.
- Système de synthèse suivant l'une quelconque des revendications 11 à 13, caractérisé en ce que lesdits quatrièmes moyens comprennent également des huitièmes moyens (34) pour affecter le signe positif ou négatif au résultat du calcul obtenu dans ladite première unité de calcul (U4).
- Système de synthèse suivant l'une quelconque des revendications 1 à 14, caractérisé en ce qu'au moins certaines desdites sources comprennent une mémoire d'échantillons de niveau zéro (81, M15) et en ce que ladite valeur de désignation (POS_X) est utilisée comme adresse de ladite mémoire d'échantillons de niveau zéro (81, M15).
- Système de synthèse suivant la revendication 15, caractérisé en ce qu'une première mémoire parmi lesdites mémoires d'échantillons de niveau zéro est une table de sinus (81).
- Système de synthèse suivant l'une quelconque des revendications 15 et 16, caractérisé en ce qu'une seconde mémoire (M15) parmi lesdites mémoires d'échantillons de niveau zéro est agencée pour stocker au moins une séquence sonore échantillonnée dont les échantillons successifs constituent lesdits échantillons de niveau zéro.
- Système de synthèse suivant la revendication 17, lorsqu'elle dépend de la revendication 3, caractérisé en ce que ladite seconde mémoire d'échantillons de niveau zéro (M15) est connectée pour être chargée par ladite unité de gestion (CPU), éventuellement par l'intermédiaire dudit logiciel.
- Système de synthèse suivant l'une quelconque des revendications 1 à 18, caractérisé en ce qu'au moins certaines desdites sources comprennent un générateur de fonction (82, 83, 84) et en ce que ladite valeur de désignation (POS_X) est utilisée comme valeur de désignation ou comme adresse pour identifier les équations de ladite fonction à utiliser.
- Système de synthèse suivant la revendication 19, caractérisé en ce que ledit générateur de fonction (82, 83, 84) est choisi parmi le groupe comprenant un générateur de fonction carrée, un générateur de fonction triangulaire, et/ou un générateur de rampe positive et/ou négative.
- Système de synthèse suivant l'une quelconque des revendications 1 à 20, caractérisé en ce qu'il comprend en tant que source d'échantillons de niveau zéro un générateur de bruit aléatoire (91) fournissant des échantillons au rythme de ladite fréquence d'échantillonnage (ACT).
- Système de synthèse suivant l'une quelconque des revendications 17 à 21, caractérisé en ce que ladite seconde mémoire d'échantillons de niveau zéro (M15) est connectée pour stocker, en tant qu'échantillons de niveau zéro, des échantillons de premier niveau calculés et stockés dans au moins une cellule au cours d'au moins un cycle de travail antérieur.
- Système de synthèse suivant la revendication 22, caractérisé en ce qu'il comprend également des neuvièmes moyens (100) pour préparer des échantillons de niveau zéro à partir d'au moins une entrée (lN_0 à lN_e) du système de synthèse à laquelle est appliquée un spectre sonore provenant d'une source externe, et en ce que lesdits neuvièmes moyens (100) sont connectés à ladite seconde mémoire d'échantillons (M15) pour permettre le stockage desdits échantillons de niveau zéro provenant desdites entrées (In_0 à In_e).
- Système de synthèse suivant la revendications 23, caractérisé en ce qu'il comprend également des dixièmes moyens (140) connectés à ladite au moins une entrée (In_0 à In_e) pour analyser le spectre sonore de ladite source externe et en tirer des valeurs de paramètre pouvant être utilisées pour modifier le ou les paramètres (FRE, AMP, FLT, PHA) déterminés par lesdits seconds et troisièmes moyens (20B, 23 à 25; 20A, 20C, 20D, 25).
- Système de synthèse suivant l'une quelconque des revendications 1 à 24, caractérisé en ce qu'il comprend également des dixièmes moyens (M12, 71) pour déterminer laquelle desdites sources d'échantillons de niveau zéro va servir pour générer, au cours de chacun desdits cycles de travail, l'échantillon de premier niveau de chacune desdites cellules.
- Système de synthèse suivant l'une quelconque des revendications 1 à 25, caractérisé en ce que lesdits sixièmes moyens comprennent également des onzièmes moyens (40) pour au cours d'un cycle de travail en cours répartir les échantillons de premier niveau desdites cellules engendrés au cours d'un cycle de travail précédent, sur m emplacements de mémoire d'une seconde mémoire d'accumulation (M6), les emplacement de cette seconde mémoire d'accumulation matérialisent m ensembles dont le contenu peut varier d'un cycle de travail à l'autre, et en ce que le contenu de chacun desdits m emplacements est sélectivement transféré à ladite sortie en tant qu'échantillon dit de second niveau pendant le cycle de travail en cours.
- Système de synthèse suivant la revendication 26, caractérisé en ce que ladite sortie (S) comprend une pluralité de sorties distinctes (0 à q) et en ce qu'il comprend en outre des douzièmes moyens (60) pour répartir sélectivement le contenu des emplacements de mémoire de ladite seconde mémoire d'accumulation (M6) sur lesdites sorties distinctes, en tant qu'échantillons dits de troisième niveau.
- Système de synthèse suivant l'une quelconque des revendications 11 à 27, caractérisé en ce qu'il comprend également des treizièmes moyens (180 à 208; M19 à M23) pour déterminer pour ladite valeur de désignation (POS_X) des bornes entre lesquelles cette valeur peut évoluer au cours d'une série déterminée de cycles de travail successifs.
- Système de synthèse suivant la revendication 28, caractérisé en ce que lesdits treizièmes moyens (180 à 208; M19 à M23) sont agencés pour faire évaluer ladite valeur de désignation (POS_X) cycliquement entre lesdites bornes, à savoir de la première borne à la seconde borne, cycliquement de la seconde borne à la première borne et/ou cycliquement en boucle de la première borne à la seconde borne et puis inversement de ladite seconde borne à ladite première borne.
- Système de synthèse suivant l'une quelconque des revendications 3 à 29, caractérisé en ce que lesdites valeurs de fonctionnement sont stockées sélectivement dans une pluralité de mémoires comprenant n emplacements par ladite unité de gestion (M1, M2, M3, M4, M9, M16; M17, M18) appartenant respectivement aux, seconds, troisièmes, quatrièmes, cinquièmes et sixièmes moyens, en fonction dudit logiciel.
- Système de synthèse suivant l'une quelconque des revendications 1 à 30, caractérisé en ce que lesdits troisièmes moyens comportent des quatorzièmes moyens (160) pour appliquer au cours d'au moins certains desdits cycles de travail, au moins une coefficient de filtrage à au moins certains des échantillons de premier niveau engendrés.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
FR9811871A FR2783630B1 (fr) | 1998-09-23 | 1998-09-23 | Systeme de synthese sonore permettant d'obtenir en sortie une suite d'echantillons electriques |
FR9811871 | 1998-09-23 |
Publications (1)
Publication Number | Publication Date |
---|---|
EP0989541A1 true EP0989541A1 (fr) | 2000-03-29 |
Family
ID=9530745
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP99402316A Withdrawn EP0989541A1 (fr) | 1998-09-23 | 1999-09-22 | Système de synthèse sonore permettant d'obtenir en sortie une suite d'échantillons électriques |
Country Status (5)
Country | Link |
---|---|
US (1) | US6137044A (fr) |
EP (1) | EP0989541A1 (fr) |
JP (1) | JP2000148151A (fr) |
CA (1) | CA2282916A1 (fr) |
FR (1) | FR2783630B1 (fr) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1806840A1 (fr) | 2006-01-05 | 2007-07-11 | Siemens Schweiz AG | Gain adaptatif pour l'ajustement du volume de la voix |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040064622A1 (en) * | 2002-09-30 | 2004-04-01 | Smith Winthrop W. | Signal processing resource with sample-by-sample selective characteristics |
US8180063B2 (en) * | 2007-03-30 | 2012-05-15 | Audiofile Engineering Llc | Audio signal processing system for live music performance |
US20110011242A1 (en) * | 2009-07-14 | 2011-01-20 | Michael Coyote | Apparatus and method for processing music data streams |
JP5528987B2 (ja) * | 2010-11-11 | 2014-06-25 | ピーエスフォー ルクスコ エスエイアールエル | 半導体装置 |
US9779625B2 (en) * | 2012-07-04 | 2017-10-03 | Panasonic Intellectual Property Management Co., Ltd. | Proximity alarm device, proximity alarm system, mobile device, and method for diagnosing failure of proximity alarm system |
US9860638B2 (en) | 2013-09-20 | 2018-01-02 | Panasonic Intellectual Property Management Co., Ltd. | Acoustic device, acoustic system, moving body device, and malfunction diagnosis method for acoustic system |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4133241A (en) * | 1975-05-27 | 1979-01-09 | Nippon Gakki Seizo Kabushiki Kaisha | Electronic musical instrument utilizing recursive algorithm |
EP0235538A2 (fr) * | 1986-01-31 | 1987-09-09 | Casio Computer Company Limited | Générateur de forme d'onde pour instrument de musique électronique |
US5553011A (en) * | 1989-11-30 | 1996-09-03 | Yamaha Corporation | Waveform generating apparatus for musical instrument |
US5792970A (en) * | 1994-06-02 | 1998-08-11 | Matsushita Electric Industrial Co., Ltd. | Data sample series access apparatus using interpolation to avoid problems due to data sample access delay |
-
1998
- 1998-09-23 FR FR9811871A patent/FR2783630B1/fr not_active Expired - Fee Related
-
1999
- 1999-09-22 CA CA002282916A patent/CA2282916A1/fr not_active Abandoned
- 1999-09-22 EP EP99402316A patent/EP0989541A1/fr not_active Withdrawn
- 1999-09-23 US US09/404,679 patent/US6137044A/en not_active Expired - Lifetime
- 1999-09-24 JP JP11270276A patent/JP2000148151A/ja active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4133241A (en) * | 1975-05-27 | 1979-01-09 | Nippon Gakki Seizo Kabushiki Kaisha | Electronic musical instrument utilizing recursive algorithm |
EP0235538A2 (fr) * | 1986-01-31 | 1987-09-09 | Casio Computer Company Limited | Générateur de forme d'onde pour instrument de musique électronique |
US5553011A (en) * | 1989-11-30 | 1996-09-03 | Yamaha Corporation | Waveform generating apparatus for musical instrument |
US5792970A (en) * | 1994-06-02 | 1998-08-11 | Matsushita Electric Industrial Co., Ltd. | Data sample series access apparatus using interpolation to avoid problems due to data sample access delay |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1806840A1 (fr) | 2006-01-05 | 2007-07-11 | Siemens Schweiz AG | Gain adaptatif pour l'ajustement du volume de la voix |
Also Published As
Publication number | Publication date |
---|---|
CA2282916A1 (fr) | 2000-03-23 |
JP2000148151A (ja) | 2000-05-26 |
US6137044A (en) | 2000-10-24 |
FR2783630A1 (fr) | 2000-03-24 |
FR2783630B1 (fr) | 2000-12-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
FR2639458A1 (fr) | Appareil permettant de produire, d'enregistrer ou de reproduire des donnees de source sonore et procede associe de codage de compression de donnees de source sonore | |
FR2522157A1 (fr) | Circuit de calcul rapide de la transformee de fourier discrete d'un signal, destine notamment a un appareil de controle par courants de foucault | |
FR2638883A1 (fr) | Appareil de generation de signal audio numerique | |
FR3004876A1 (fr) | Correction de perte de trame par injection de bruit pondere. | |
EP0071506B1 (fr) | Procédé et dispositif numérique de correction d'erreur de phase d'un signal échantillonné et son application à la correction de signaux de télévision | |
EP0989541A1 (fr) | Système de synthèse sonore permettant d'obtenir en sortie une suite d'échantillons électriques | |
FR2679689A1 (fr) | Procede de synthese de sons. | |
FR2476888A1 (fr) | Synthetiseur numerique de signaux sonores et applications aux instruments de musique electronique | |
JPH0548648B2 (fr) | ||
FR2551279A1 (fr) | Generateur d'onde sinusoidale, dont la frequence est asservie a un signal binaire, notamment pour modem | |
EP0425352A1 (fr) | Dispositif d'amortissement actif de vibrations | |
GB2103005A (en) | Modulation effect device | |
FR2513462A1 (fr) | Procede pour reduire l'encombrement d'une memoire d'un transmetteur et ce transmetteur | |
EP0978116B1 (fr) | Procede et dispositif pour l'enregistrement en boucles cycliques de plusieurs sequences phoniques | |
EP0021964B1 (fr) | Synthétiseur numérique polyphonique de signaux périodiques | |
FR2747528A1 (fr) | Structure de dispositif de banc de filtres numeriques et son procede de fonctionnement | |
FR2548490A1 (fr) | Circuit programmable de transformation serie-parallele d'un signal numerique, et son application a un recepteur de signaux video numeriques | |
EP0011576B1 (fr) | Synthétiseur polyphonique de signaux périodiques utilisant les techniques numériques | |
FR2717294A1 (fr) | Procédé et dispositif de synthèse dynamique sonore musicale et vocale par distorsion non linéaire et modulation d'amplitude. | |
WO2002084510A2 (fr) | Systeme de processeur modulaire | |
FR2466826A1 (fr) | Synthetiseur de sons | |
EP0104290B1 (fr) | Processeur numérique de signal en temps réel | |
EP2304510A1 (fr) | Estimation de la réponse impulsionnelle d'un système à partir d'observations binaires | |
FR2596873A1 (fr) | Perfectionnements aux radars a impulsions coherents | |
FR2486680A1 (fr) | Procede et dispositif de permutation des elements d'un ensemble |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
AX | Request for extension of the european patent |
Free format text: AL;LT;LV;MK;RO;SI |
|
17P | Request for examination filed |
Effective date: 20000904 |
|
AKX | Designation fees paid |
Free format text: AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN |
|
18D | Application deemed to be withdrawn |
Effective date: 20040401 |
|
REG | Reference to a national code |
Ref country code: HK Ref legal event code: WD Ref document number: 1026501 Country of ref document: HK |