EP0280293B1 - Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals - Google Patents

Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals Download PDF

Info

Publication number
EP0280293B1
EP0280293B1 EP19880102806 EP88102806A EP0280293B1 EP 0280293 B1 EP0280293 B1 EP 0280293B1 EP 19880102806 EP19880102806 EP 19880102806 EP 88102806 A EP88102806 A EP 88102806A EP 0280293 B1 EP0280293 B1 EP 0280293B1
Authority
EP
European Patent Office
Prior art keywords
envelope
function
value
order
global
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.)
Expired - Lifetime
Application number
EP19880102806
Other languages
German (de)
French (fr)
Other versions
EP0280293A3 (en
EP0280293A2 (en
Inventor
Kenichi Pat.Dept.Dev.Div. Hamura R&D Ctr Tsutsumi
Jun Pat. Dept. Dev. Div. Hamura R&D Ctr. Yoshino
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Casio Computer Co Ltd
Original Assignee
Casio Computer Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Priority claimed from JP62040455A external-priority patent/JP2621862B2/en
Priority claimed from JP1987025501U external-priority patent/JP2521652Y2/en
Application filed by Casio Computer Co Ltd filed Critical Casio Computer Co Ltd
Publication of EP0280293A2 publication Critical patent/EP0280293A2/en
Publication of EP0280293A3 publication Critical patent/EP0280293A3/en
Application granted granted Critical
Publication of EP0280293B1 publication Critical patent/EP0280293B1/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC 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/00Instruments in which the tones are synthesised from a data store, e.g. computer organs
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC 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
    • G10H1/00Details of electrophonic musical instruments
    • G10H1/02Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos
    • G10H1/04Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos by additional modulation
    • G10H1/053Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos by additional modulation during execution only
    • G10H1/057Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos by additional modulation during execution only by envelope-forming circuits
    • G10H1/0575Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos by additional modulation during execution only by envelope-forming circuits using a data store from which the envelope is synthesized
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC 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
    • G10H1/00Details of electrophonic musical instruments
    • G10H1/02Means for controlling the tone frequencies, e.g. attack or decay; Means for producing special musical effects, e.g. vibratos or glissandos
    • G10H1/06Circuits for establishing the harmonic content of tones, or other arrangements for changing the tone colour
    • G10H1/08Circuits for establishing the harmonic content of tones, or other arrangements for changing the tone colour by combining tones

Definitions

  • the present invention relates to a musical tone generating apparatus as claimed in the preamble of claim 1.
  • envelopes respectively corresponding to a plurality of sine waves as frequency components of the musical tone are independently controlled to change tone colors as a function of time.
  • a musical tone generating apparatus of this type is described in e.g., US-A-4 083 285.
  • an object of the present invention to provide a musical tone generating apparatus capable of producing envelope functions independently of respective component wave signals in response to simple input operations.
  • the user need not produce individual envelope functions for the component wave signals of a plurality of orders in order to obtain musical tones.
  • a data input device such as a keyboard
  • the user selects only one envelope function to obtain a variety of tone colors because a plurality of envelope functions are generated on the basis of one envelope function (i.e., a common or global envelope function) generated by an envelope modifying means.
  • An envelope function for controlling an envelope of a component wave signal of a given order is obtained by modifying the common envelope function in accordance with a value of a corresponding order of the component wave signal.
  • the envelope modifying means performs modification represented by the following function: G(x,w)
  • the value of function G(x,w) is determined by parameter x and parameter w .
  • the modified value of function G(x,w) is a value for the xth order envelope function. That is, it is a value of the envelope function for controlling the envelope of the xth order component wave signal.
  • function G(x,w) provides a modification characteristic for modifying the common envelope function into the envelope functions of the respective orders.
  • function G(x,w) can be calculated in accordance with arithmetical and logical operations.
  • the envelope modifying means can be basically realized by a means for executing appropriate logical and/or arithmetical algorithms.
  • modification characteristic function G(x,w) is solely determined if order value x and the value w of the common envelope function are given.
  • this function cannot be solved by arithmetic and logical operations or cannot be calculated for at least a given combination of x and w .
  • the envelope modifying means can be constituted by using a modification table (e.g., a memory such as a ROM) in the range where calculations cannot be performed.
  • the modification table can also be used in the first example.
  • a suitable construction can be determined in consideration of a processing speed, an operation volume, and a required memory capacity.
  • logical operations e.g., comparison, AND, and OR
  • modification is characteristic function G(x,w) is defined as a function in which the characteristics are changed in ranges of values of parameter u if parameter u is calculated by arithmetical operations using parameter x of the order and parameter w of the envelope function.
  • An appropriate function is selected in accordance with the value of parameter u . For example, if u > 0, then monotonous function G 1 (u) serves as a modification characteristic function. If u ⁇ 0, another monotonous function G 2 (u) serves as a modification characteristic function.
  • the envelope modifying means produces envelopes of respective orders from the common envelope function.
  • the user is free from production of respective envelope functions for the corresponding component waves and can easily produce musical tones.
  • the common envelope function input to the envelope modifying means can be expressed in various forms.
  • an envelope function can be given as a waveform data format (i.e., a sequence of digital data representing the instantaneous values of the envelope levels).
  • the envelope functions can be represented by compressed data (control information).
  • an envelope function of a polygonal type is expressed as a set of position data of polygonal points (e.g., this function is expressed by several step rate data and several step level data).
  • this function is expressed by several step rate data and several step level data.
  • A/D-converted data (data prior to data compression) is expressed in the form of waveform data.
  • the form of the input device for inputting the common envelope function is not important to the present invention.
  • the form of modification processing varies in the envelope modifying means in accordance with the form of expression of the input common envelope function.
  • the envelope modifying means modifies the common envelope function given in the form of digital waveform data into envelope functions of the respective orders represented in the same form as the common envelope-function. That is, each digital value of the common envelope function is modified into the corresponding digital value of an envelope function of each order.
  • the modified envelope functions of the respective orders which are expressed in the form of waveform data can be directly inparted to a component wave signal in the form of waveform data.
  • the above envelope functions of the respective orders may be decoded into the envelope function in the form of waveform data upon generation of a musical tone signal after the envelope functions of the respective orders are compressed in the form of control information.
  • the envelope modifying means modifies the common envelope function given in the form of control information into the envelope functions of the respective orders in the same form as the common envelope function.
  • the values of the control information e.g., values of rate data and level data for each step, or coordinates of each polygonal point
  • G(x,w) modification characteristic function
  • the modification characteristic function is also applied to points on a polygonal line (these points can be easily calculated by arithmetical operations because the common envelope function is defined by control information) in addition to polygonal points, thereby obtaining points defining the envelope functions of the respective orders.
  • the envelope function of each order modified by the envelope modifying means is finally used to control the envelope of the component wave signal of the order corresponding to the envelope function.
  • This envelope control can be performed by a digital multiplier, an analog multiplier, or a device for performing other functionally or equivalently performing a multiplication.
  • the component wave signal is not limited to the sine wave signal but can be extended to any waveform signal having a frequency or a frequency spectrum corresponding to the order.
  • a rectangular wave e.g., a rectangular wave obtained by the Walsh function
  • a component wave signal can be used as a component wave signal.
  • independent envelopes can be given in units of groups of component waves, and musical tones with a variety of tone colors can be obtained.
  • a means for establishing an independent relationship between an envelope function for a component wave belonging to a given group (e.g., the first group) and that belonging to another group (e.g., the second group) can be arranged in several specific forms.
  • a global envelope setting means provides different global envelope functions in units of groups.
  • the user produces different envelopes in units of component wave groups.
  • the envelope modifying means for the first group generates envelope functions of the respective orders on the basis of the first global envelope function.
  • the envelope modifying means for the second group produces envelope functions of the respective orders on the basis of the second global envelope function.
  • the modification logical algorithm used in the first and second envelope modifying means is the same and is given as Fx(W) where x is the order and W is the global envelope function.
  • Fx(W) is the xth-order envelope function.
  • the envelope modifying means modifies the global envelope function in accordance with its orders.
  • Condition Fx(W) ⁇ Fy(W) is established between envelope functions Fx(W) and Fy(W) having different orders x and y .
  • Fx(W) Fx(W).
  • functions Fx(W) and Fy(W) depend on the orders (if identical global envelope functions are assumed).
  • the first global envelope function W1(t) and the second envelope function W2(t) are independently determined by the user and are independent functions. Functions obtained by modifying independent functions on the basis of the same modification logical algorithm are independent. If the first envelope modifying means produces xth-order envelope function Fx(W1(t)) and the second envelope modifying means produces xth-order envelope function Fx(W2(t)), condition Fx(W1(t)) Fx(W2(t)) is established.
  • envelope function group ⁇ Fx(W1(t)). ⁇ for controlling the component waves of the first group and envelope function group ⁇ Fx(W2(t)) ⁇ for controlling the component waves of the second group are independent.
  • modification logical algorithm Fx(W) of the first envelope modifying means and modification logical algorithm Gx(W) of the second envelope modifying means are independent or different.
  • either envelope modifying means can receive the same global envelope function.
  • the global envelope setting means can provide only one global envelope function.
  • envelope function group ⁇ Fx(W) ⁇ generated by the first envelope modifying means to control the component waves of the first group and envelope function group ⁇ Gx(W) ⁇ generated by the second envelope modifying means to control the component waves of the second group are independent of each other.
  • a means can be used to modify a single global envelope function set by the user into global envelope functions which are independent between the groups.
  • the global envelope function of each group is supplied to the corresponding envelope modifying means.
  • global envelope function G(W) for the first group is supplied to the first envelope modifying means and global envelope function H(W) for the second group is supplied to the second envelope modifying means.
  • envelope modifying means i.e., a means for modifying the global envelope group into envelope functions of the respective orders
  • Fig. 1 shows the overall circuit arrangement of a sine wave synthesis type musical tone generating apparatus.
  • n envelope-controlled sine wave generators 15-1 to 15-n are connected to keyboard 1 serving as a performance input device, data input device 2 for inputting various data, and global envelope memory (common envelope memory) 3.
  • Envelope-controlled sine wave generators 15-1 to 15-n are arranged to generate sine waves having independent frequencies on the basis of harmonic data set by a user at data input device 2.
  • Global envelope memory 3 comprises a RAM and stores global envelope function data set at data input device 2.
  • the global envelope is modified by the circuit constructed in the sine wave generators 15-1 to 15-n into envelope function data depending on their assigned frequencies (i.e., orders).
  • the sine waves generated in generators 15-1 to 15-n are envelope-controlled by the modified envelope data.
  • n independent envelope functions can be obtained for the preset global envelope function.
  • the user need not set n envelopes for the respective sine waves, thereby reducing envelope producing labor.
  • Envelope-controlled sine wave data from envelope-controlled sine wave generators 15-1 to 15-n are added by adder 16, and a sum signal (musical tone signal) is converted into an analog signal by D/A converter 17.
  • the analog signal is produced as a tone through amplifier 18 and loudspeaker 19.
  • each envelope-controlled sine wave generator is shown in Fig. 2.
  • the arrangement surrounded by the dotted line and denoted by reference numeral 15 represents one of envelope-controlled sine wave generators 15-1 to 15-n.
  • key code generator 4 generates a key code corresponding to the depressed key at keyboard 1.
  • Key code converter 5 converts the generated key code in accordance with a value in harmonic data memory 10.
  • Memory 10 can store harmonic data (harmonic orders) of 0 to 31 which can be set by the user at data input device 2.
  • Key code converter 5 converts the key code using the stored harmonic data in accordance with a method shown in Fig. 3.
  • Phase angle generator 6 comprises a frequency data ROM and an accumulator and causes the frequency data ROM to convert the key code from key code converter 5 into frequency data, and the accumulator to accumulate the frequency data so as to generate a phase angle corresponding to the key code, thereby reading out sine wave data from sine wave ROM 7.
  • An output from sine wave ROM 7 is a sine wave signal having a frequency corresponding to the order of a harmonic set in harmonic data memory 10.
  • the key code is converted in accordance with the harmonic data.
  • frequency data may be converted into frequency data corresponding to the harmonic in accordance with bit shifting or the like.
  • the value of the phase angle output from phase angle generator 6 may be converted to obtain a phase angle representing the corresponding order. In this manner, various circuit modifications may be proposed.
  • Fixed amplitude memory 11 comprises a RAM for storing data for controlling (scaling) the amplitude of the sine wave signal from sine wave ROM 7 regardless of time changes. Scaling data can be input by the user at data input device 2. Scaling data stored in fixed amplitude memory 11 represent independent values for envelope-controlled sine wave generators 15-1 to 15-n. Therefore, when the sine wave data from sine wave ROM 7 is multiplied by each multiplier 8 with the data read out from fixed amplitude memory 11, relative amplitudes of n sine wave signals can be independently controlled.
  • the amplitude-controlled sine wave signal from multiplier 8 is multiplied with an envelope signal output from envelope modification device 14 (to be described in detail later). Therefore, amplitude control as a function of time can be performed, and the product is output from envelope sine wave generator 15.
  • global envelope memory 3 stores common global envelope function data for n envelope-controlled sine wave generators 15-1 to 15-n.
  • the global envelope function in global envelope memory 3 can be expressed by 4-step rate data and 4-step level data (Fig. 4).
  • the global envelope function in this form is modified into the form of waveform data by envelope generator 12 (Fig. 5). More specifically, envelope generator 12 comprises an accumulator and a comparator and receives step-1 rate data of step-1 level data from global envelope memory 3. The rate data is repetitively accumulated. If the accumulation result reaches the level data, envelope generator 12 receives step-2 rate data and step-2 level data from global envelope memory 3. The above operations are repeated to obtain waveform data of the global envelope.
  • Envelope modification device 14 modifies the waveform data of the common global envelope function generated by envelope generator 12 into waveform data of envelope functions of the respective orders in accordance with harmonic data (order) from harmonic data memory 10. For example, if the harmonic data from harmonic data memory 10 in envelope-controlled sine wave generator 15 is 1 (i.e., this value represents a second harmonic), the first-order envelope waveform data is generated by envelope modification device 14. The first-order envelope waveform data is multiplied with a sine wave signal having a frequency of the second harmonic, thereby controlling the envelope.
  • envelope modification device 14 The arbitrary modification characteristic of envelope modification device 14 can be provided in principle. In practice, the modification characteristic for a resonance effect will be described first.
  • x is the order, i.e., the value of the harmonic data from harmonic data memory 10
  • w(t) is the global envelope function, i.e., the output from envelope generator 12, and that R is the depth of resonance.
  • Xth-order envelope function Fx(t) modified by envelope generator 12 satisfies the following conditions:
  • Xth-order envelope function Fx(t) is expressed as a function of time t .
  • function F(u) is derived.
  • the value of function F(u) is changed in accordance with order x relative to value W(t) of global envelope function at arbitrary time t . Therefore, function F(u) determines the modification characteristic for modifying the global envelope function into envelope functions of the respective orders.
  • modification characteristic function F(u) is shown in Fig. 6(A).
  • a difference obtained by subtracting the value of global envelope function W(t) from order x is plotted along abscissa u . As shown in Fig.
  • the resonance effect can be dynamically given. More specifically, the value of global envelope function W(t) is changed as a function of time t . When specific order x 0 is given, a value obtained by subtracting W(t) from order x 0 is also changed as a function of time along the u-axis in Fig. 6(A). The value of each F(u), i.e., value Fx 0 (t i ) of the x 0 th-order envelope function at time t i is also changed. According to Fig.
  • the value of Fx 0 (t i ) is one (1) and is not thus attenuated if order x is sufficiently smaller (lower) than value W(t i ) of the global envelope function at time t i . However, if order x is sufficiently larger (higher) than value W(t i ) of the global envelope function at time t i , the value of FX 0 (t i ) is zero and is thus perfectly attenuated. If order x is very close to value W(t i ) of the global envelope function at time ti, the value of Fx 0 (t i ) can be amplified to a value of one or more.
  • the order of an envelope function having an amplified value at a given time is close to the value of the global envelope function at the given time. Therefore, the order of the emphasized component wave is changed as a function of time, thereby obtaining the resonance effect which is dynamically changed as a function of time.
  • envelope modification device 14 shown in Fig. 2 produces x 0 th-order envelope function Fx 0 (t) shown in Fig. 6(C) in accordance with modification characteristic F(u) shown in Fig. 6(A).
  • x 0 th-order envelope function Fx 0 (t) which correspond to several values of global envelope function W(t) shown in Fig. 6(B) are written in Fig. 6(A).
  • the values of x 0 th-order envelope function Fx 0 (t) at other times can be obtained in the same manner as described above.
  • envelope modification device 14 shown in Fig. 2 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12.
  • Envelope modification device 14 can be arranged in various ways.
  • device 14 can comprise a subtracter for calculating a difference between the instantaneous value of global envelope function W(t) from envelope generator 12 and the value of order x from harmonic data memory 10, and a memory addressed in response to output data from the subtracter and adapted to store modified envelope function waveform data values.
  • modification characteristic function F(u) or f(x-W(t)) is a function to be calculated
  • f(x-W(t)) is calculated and is added to resonance value R, thereby obtaining f(x-W(t)) + R. Whether difference u is negative is determined or whether f(x-W(t)) + R is 1 or less is determined. If both these conditions are established (corresponding to x ⁇ W(t) and f(x-W(t)) + R ⁇ 1), constant 1 is used as the modified envelope function value. If neither conditions are established (corresponding to x ⁇ W(t) or f(x-W(t) + R ⁇ 1), whether f(x-W(t)) + R is negative is determined. If value f(x-W(t)) + R is not negative, this value serves as the modified envelope function value. If value f(x-W(t)) + R is negative, constant 0 serves as the modified envelope function value.
  • Modification characteristic F(u) of the global envelope function/envelope functions of the respective orders is not limited to ones shown in Fig. 6(A) or in modification conditions (a) to (e).
  • cx W(t) (where c is a constant or cx is an increment function of x ) may be the central position of the resonance.
  • (x-K) can be evaluated as the value of order x .
  • cx can be evaluated as the value of order x .
  • Modification characteristic F(u) may be selected to obtain a high-pass filter type resonance effect in place of the low-pass filter type resonance effect.
  • Modification characteristic F(u) may be selected to obtain a band-pass filter type resonance effect, as shown in Fig. 7(B).
  • Resonance value R need not be a constant but a variable which can be changed by the user.
  • the resonance value can be preferably changed in real time during musical performance in the following manner.
  • changing resonance value R is used in the process for producing envelope functions Fx(t) of the respective orders in the form of waveform data from global envelope function W(t) in the form of waveform data.
  • envelope modification device 14 in Fig. 2 The operation of envelope modification device 14 in Fig. 2 will be described when waveform data of envelopes of the respective orders for obtaining a low-pass filter effect is to be generated.
  • envelope modification device 14 performs the following modifications to produce envelopes of the respective orders:
  • Fig. 8(A) shows the characteristic of function Fx(t) when order x is plotted along the abscissa.
  • function W(t) is a function of the global envelope function, its value is changed as a function of time t . If specific order x 0 is given, the value of x 0 th-order envelope function Fx 0 (t) is changed in accordance with the value at each time of global envelope function W(t).
  • x 0 th-order envelope function Fx 0 (t) is not attenuated.
  • the function is greatly attenuated when a difference between x 0 and W(t) is larger.
  • x 0 th-order envelope modification device 14 generates x 0 th-order envelope function Fx 0 (t) shown in Fig. 9(B) in accordance with the modification characteristic shown in Fig. 8(A).
  • value Fx 0 (b) of the modified envelope function is not attenuated and is 1, as shown in Fig. 8(C).
  • Value W(d) of the global envelope function at time d is slightly smaller than the value of order x 0 .
  • order x 0 is located in the region of the attenuation curve of f(x-W(t)) shown in Fig. 8(A).
  • the modified envelope function value is value Fx 0 (d) between 0 and 1 in accordance with the characteristic of attenuation curve f(x-W(t)), as shown in Fig. 8(E).
  • envelope modification device 14 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12. As a result, envelope function Fx 0 (t) in the form of waveform data shown in Fig. 9(B) is calculated.
  • Envelope functions of higher orders than order x 0 are attenuated as compared with the x 0 th-order envelope function. As a result, an effect similar to a low-pass filter can be obtained.
  • Envelope modification device 14 can be arranged in various ways.
  • envelope modification device 14 comprises a subtracter for calculating a difference between the instantaneous value of the global envelope function output from envelope generator 12 and the value of the order from harmonic data memory 10, and a memory addressed in response to output data from the subtracter to store waveform data of the modified envelope function.
  • a calculation program is executed. For example, the value of order x and the instantaneous value of global envelope function W(t) are compared. If the value of order x is smaller than the instantaneous value of the envelope function, the modified envelope function value serves as a constant.
  • instantaneous value W(t) is used to calculate f(x-W(t)).
  • the sign of f(x-W(t)) is determined. If value f(x-W(t)) is positive, the result serves as the modified envelope function value. Otherwise, zero serves as the modified envelope function value.
  • a modification characteristic for the global envelope function/envelope functions of the respective orders is not limited to the one shown in Fig. 8(A).
  • envelope modification device 14 shown in Fig. 2 An operation of envelope modification device 14 shown in Fig. 2 will be described when waveform data for envelopes of the respective orders for obtaining an effect similar to the high-pass filter is generated.
  • envelope modification device 14 performs the following modifications to generate envelopes of the respective orders:
  • function f(u) is set to be 1. However, if the value of order x is smaller than the value of global envelope function W(t), the gradient of function F(u) is positive.
  • Fig. 10(A) Difference u is plotted along the abscissa and obtained by subtracting the value of global envelope function W(t) from the value of order x .
  • global envelope function W(t) is changed as a function of time t .
  • envelope modification device 14 generates x 0 th-order envelope function Fx 0 (t) shown in Fig. 10(C) in accordance with the modification characteristic shown in Fig. 10(A).
  • envelope modification device 14 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12.
  • envelope function Fx 0 (t) in the form of waveform data shown in Fig. 10(C) is calculated for the x 0 th order.
  • Envelope modification device 14 can be arranged in various ways.
  • envelope modification device 14 comprises a subtracter for calculating a difference between the instantaneous value of the global envelope function output from envelope generator 12 and the value of the order from harmonic data memory 10, and a memory addressed in response to output data from the subtracter to store waveform data of the modified envelope function.
  • f(x-W(t)) in condition (k) can be calculated, a calculation program is executed. For example, the value of order x and the instantaneous value of global envelope function W(t) are compared. If the value of order x is larger than the instantaneous value of the envelope function, the modified envelope function value serves as a constant.
  • instantaneous value W(t) is used to calculate f(x-W(t)).
  • the sign of f(x-W(t)) is determined. If value f(x-W(t)) is positive, the result serves as the modified envelope function value. Otherwise, zero serves as the modified envelope function value.
  • a modification characteristic for the global envelope function/envelope functions of the respective orders is not limited to the one shown in Fig. 10(A).
  • Envelope modification device 14 described above generates envelope functions in the form of waveform data by using the global envelope functions in the form of waveform data and the order data. At the same time, all values of the waveform data of the global envelope are modified.
  • an arrangement shown in Fig. 11 modifies a global envelope function expressed by a set of rate data and level data shown in Fig. 4 into envelope functions of the respective orders.
  • several points of global envelope function W(t) are modified in accordance with modification characteristic F(u). These points include peak or break points (i.e., points corresponding to W(a), W(b), W(c), W(d), and W(e) in Fig. 12) on global envelope function W(t) and points (i.e., points corresponding to W(t 1 ) and W(t 2 )) in which the values of function W(t) coincide with the values of order x .
  • Envelope modification device 14A in Fig. 11 executes the following algorithm to obtain a set of rate data and level data which express the x 0 th-order envelope function in accordance with the set of rate and level data which define the global envelope data.
  • l (i) and r(i) are level and rate data of the ith step of the global envelope function
  • L(j) and R(j) represent level and rate data of the jth step of the x 0 th-order envelope function to be stored in envelope memory 14B for respective orders.
  • l(old) represents the previous level of the point on the global envelope function. The initial value of level l(old) is zero, and L(0) is also zero. Both initial values of i and j are 1.
  • Envelope generator 14C has an arrangement similar to that of envelope generator 12 shown in Fig. 2.
  • rate and level data are read out from the first step from envelope memory 14B for the respective orders.
  • the envelope functions of the respective orders which are expressed by rate and level data are sequentially changed into waveform data.
  • the amplitudes of sine wave data of the corresponding orders which are output from multiplier 8 are controlled by multiplier 9 in accordance with the waveform data sequentially generated by envelope generator 14C.
  • Fig. 13 shows a modification obtained by partially modifying the circuit arrangement in Fig. 11.
  • Envelope modification device 14A cooperates with global envelope generator 14D to modify the global envelope function from global envelope memory 3 into envelope functions of the respective orders expressed in the same form as that of the global envelope function.
  • Global envelope generator 14D calculates an instantaneous value of the global envelope function and basically comprises an accumulator. After the rate data is set by envelope modification device 14A, envelope generator 14D adds rate data to the accumulated value every time a clock is supplied from envelope modification device 14A. An accumulation result is output to envelope modification device 14A.
  • Envelope modification device 14A comprises a level coincidence detector for detecting a coincidence between the accumulation result front global envelope generator 14D and global envelope predetermined level data, and an order coincidence detector for detecting a coincidence between the accumulation result and the order data. If the coincidence is established, the accumulation result is modified in accordance with modification characteristic F(u) to obtain level data of envelopes of the respective orders (The arrangement required for modification itself is substantially the same as the corresponding section in envelope modification device 14 shown in Fig. 2). If a coincidence signal is output from the level coincidence detector, global envelope generator 14D is reset in accordance with the rate data of the next envelope step.
  • envelope modification device 14A comprises a counter for counting an operation count of each envelope step in global envelope generator 14D and a circuit for calculating rate data of the envelopes of the respective orders in accordance with a difference between the level data and time data as the contents of the counter.
  • envelope modification device 14A reads out the rate and level data of step 1 for global envelope function W(t) shown in Fig. 12(B) (corresponding to the interval between time a and time b in Fig. 12(B)) from global envelope memory 3.
  • the level data is set in the internal level coincidence detector, and the rate data is set in global envelope generator 14D.
  • Envelope modification device 14A supplies a clock signal to generator 14D to allow an accumulation operation and increments the count of the internal counter by one.
  • the internal order coincidence detector detects a coincidence between the global envelope function value (output from global envelope generator 14D) and the value of order x 0 .
  • envelope modification device 14A modifies the function value in accordance with modification characteristic F(u) shown in Fig.
  • the modified result is assured as the level data of the first step of the x 0 th-order envelope function.
  • a difference between this level data and the immediately preceding step level data (in this case, no preceding step is present, and the previous level data represents zero) is calculated.
  • the difference is divided by the count of the counter, i.e., the value representing the time of the first step of x 0 th-order envelope function Fx 0 (t).
  • the quotient is assured as the rate data of the first step of the x 0 th-order envelope function.
  • the counter is initialized for the second step of the x 0 th-order envelope function.
  • the operation of global envelope generator 14D is started again.
  • the count of the internal counter is incremented by one every time the accumulation cycle is completed.
  • the level coincidence circuit detects that the global envelope function value as the accumulation result has reached the predetermined level.
  • envelope modification device 14A calculates the level and rate data of the second step of the x 0 th-order envelope function. Thereafter, the rate and level data of the next step are read out from global envelope memory 3 and the above operations are repeated.
  • envelope control information i.e., set of rate and level data
  • the control information is temporarily stored in envelope memory 14B for the respective orders.
  • Envelope generator 14C has the same arrangement as that of envelope generator 12C of Fig. 11.
  • rate and level data are read out from the first step from envelope memory 14B for respective orders.
  • the envelope functions of the respective orders expressed by the rate and level data are sequentially changed into waveform data.
  • the envelopes of the respective orders expressed by the rate and level data can be derived from the global envelope expressed by the rate and level data in Fig. 13.
  • the above arrangement may be changed to obtain a high-pass filter type resonance effect or a band-pass filter type resonance effect in place of the low-pass filter type resonance effect.
  • the circuit can be properly designed with reference to Fig. 7, and Fig. 11, 12 or 13 to set the rate and level data which represent the x 0 th-order envelope function.
  • the resonance value R need not be a constant but be a variable which can be set by the user. If the resonance value can be changed in real time, a performance effect can be further improved.
  • An arrangement for performing real time resonance value changes can be obtained by adding to the arrangement of Fig. 11 or 13 a multiplier, arranged between envelope generator 14C and multiplier 9, for multiplying resonance depth coefficient R/R0 (where R0 is the reference resonance depth which is reflected in the data stored in the envelope memory 14B for the respective orders, and R is the resonance value designated by the user) with the output from envelope generator 14C, a selector (its selection output is input to multiplier 9) for selecting an output from the additional multiplier or a direct output from envelope generator 14C, and a comparator for controlling selection of the selector.
  • envelope modification device 14A shown in Fig. 11 An operation of envelope modification device 14A shown in Fig. 11 will be described when a low-pass filter type resonance effect is to be realized.
  • the filter characteristic is obtained by using as a parameter difference u between the value of order x and global envelope function value W(t).
  • the present invention can be easily modified to perform modifications for performing a filter effect having several pass or stop bands.
  • F(x,LEVEL) 100[1 - ⁇ 1 - (LEVEL/100) ⁇ x]
  • level F(x.LEVEL) 100
  • the 0th-order envelope function is given as shown in Fig. 14(B).
  • the modified 0th-order envelope function is used to control the envelopes of the 0th-order sine wave, i.e., the sine wave having the fundamental frequency.
  • F(1,LEVEL) LEVEL is given. That is, each level of the given global envelope function is always equal to that of the first-order envelope function.
  • the first-order envelope function is the same as the global envelope function (Fig. 14(C)).
  • the waveform data of the first-order envelope function is used to control the envelope of the first-order sine wave signal, i.e., the envelope of the sine wave signal having a frequency of a second harmonic.
  • (C) Second Order (x 2)
  • the level of each step of the global envelope function is doubled, and 100 is subtracted from the doubled value.
  • the resultant difference serves as the corresponding level of the second-order envelope function (Fig. 14(D)).
  • the second-order envelope function is applied to a sine wave having a frequency of a second order, i.e., third harmonic.
  • Envelope functions of higher orders can be produced in the same manner as described above. If the modification function given in equation (1) is used, the envelope function is attenuated and its amplitude change is small when the order is increased.
  • Function 100[1 - ⁇ 1 - (LEVEL/100 ⁇ x] is an example.
  • An arbitrary function may be selected, such as a function having an amplitude which is greatly changed when the order is increased.
  • envelope modification device 14D shown in Fig. 11.
  • the following algorithm can be used:
  • the rate modification in addition to the level modification can be performed as follows: LEVEL ⁇ F(x,LEVEL) Rate ⁇ G(x,LEVEL)
  • G(x,RATE) is a rate value corresponding to the xth-order envelope function obtained by modifying value RATE of the global envelope function in accordance with the value of order x .
  • a plurality (n) of envelope-controlled sine wave generators 15-1 to 15-n are used.
  • hardware of a sine generator is not limited if it functionally provides a plurality of sine waves.
  • envelope-controlled sine wave generators 15-1 to 15-n can be realized by TDM (time-division multiplexing).
  • the envelope-controlled sine wave generator section is divided into two groups: envelope-controlled sine wave generators 15-1 to 15-n as the first group and envelope-controlled sine wave generators 15 ⁇ -1 to 15 ⁇ -m as the second group.
  • Envelope-controlled sine wave generators 15-1 to 15-n and 15 ⁇ -1 to 15 ⁇ -m are connected to keyboard 1 as a performance input device and data input device 2 for inputting various data.
  • the user can specify independent harmonic data to the respective groups of envelope-controlled sine wave generators.
  • Sine wave generators 15-1 to 15-n and 15 ⁇ -1 to 15 ⁇ -m can generate different sine waves having independent frequencies on the basis of prestored harmonic data upon key depression at keyboard 1.
  • the feature of this embodiment lies in that the first and second groups constituted by the corresponding envelope-controlled sine wave generators are coupled to the corresponding global envelope memories. More specifically, envelope-controlled sine wave generators 15-1 to 15-n of the first group are coupled to first global envelope memory 3-1, and envelope-controlled sine wave generators 15 ⁇ -1 to 15 ⁇ -m of the second group are coupled to second global envelope memory 3-2.
  • First and second global envelope memories 3-1 and 3-2 respectively store first and second global envelope functions W1(t) and W2(t) which are independently set at data input device 2.
  • First global envelope function W1(t) is converted to n envelope functions of n orders determined by the assigned harmonic data (order) in envelope-controlled sine wave generators 15-1 to 15-n belonging to the first group.
  • Second global envelope function W2(t) is modified into m envelope functions determined by the assigned harmonic data in envelope-controlled sine wave generators 15 ⁇ -1 to 15 ⁇ -m belonging to the second group.
  • the modified envelope functions of the respective orders are used to control the envelopes of the sine wave signals of the corresponding orders in envelope-controlled sine wave generators 15-1 to 15-n.
  • one envelope i.e. the global envelope function
  • a plurality of envelope functions i.e., envelope functions of sine wave signals belonging to this group can be obtained based on the given function.
  • the load imposed on the user who produces the envelopes can be greatly reduced.
  • independent global envelope functions are set in units of groups, musical tones with a variety of tone colors can be obtained as compared with the arrangement in which a common global envelope is given for all sine waves without dividing a set of sine waves into a plurality of groups.
  • envelope-controlled sine wave data from envelope-controlled sine wave generators 15-1 to 15-n and 15 ⁇ -1 to 15 ⁇ -m are added by adders 16-1 and 16-2, respectively.
  • the sum signals (musical tone signals) are converted into analog signals by D/A converter 17.
  • the analog signals are produced outside through amplifier 18 and loudspeaker 19.
  • adders 16-1 and 16-2 are represented as separate units, only one adder can be used to add output data from envelope-controlled sine wave generators 15-1 to 15-n and 15 ⁇ -1 to 15 ⁇ -m.
  • each envelopecontrolled sine wave generator is the same as that in Fig. 2, 11 or 13.
  • the independent first and second global envelope functions can be arbitrarily set by the user. Independency and flexibility between the global envelope functions are reflected in envelope functions (i.e., the envelope functions for the sine waves of the first group and the envelope functions for the sine waves of the second group) converted by envelope modification device 14 or 14A. Therefore, a variety of finally produced musical tone signals can be achieved.
  • envelope functions i.e., the envelope functions for the sine waves of the first group and the envelope functions for the sine waves of the second group
  • the global envelope functions can be input and set by the user in units of groups.
  • the envelope functions of the first group applied to the sine waves of the first group are independent of the envelope functions of the second group applied to the sine waves of the second group.
  • envelope functions of orders e.g., 0th, 1st, and 2nd orders
  • envelope-controlled sine wave generators 15-1 to 15-n of the first group and envelope-controlled sine wave generators 15 ⁇ -1 to 15 ⁇ -m of the second group are fixedly illustrated. However the user can arbitrarily determine which generators belong to the first or second group. Some generators may be added or omitted easily within the scope of the present invention.
  • the envelope-controlled sine wave generators are divided into two groups but may be divided into three or more groups. In an extreme case, a given group may use one sine wave.
  • the frequency of the generated sine wave is a fundamental frequency or its harmonic due to the relationship with harmonic data.
  • the arrangement is not limited to this.
  • a sine wave having a frequency obtained by detuning the sine wave frequency of the first group may be used as the sine wave of the second group.
  • a technique for generating a sine wave having a detuned frequency is known to those skilled in the art.
  • the repetitive accumulation value of the accumulator is offset by a predetermined number of sent.
  • the plurality of envelope-controlled sine wave generators 15-1 to 15-n and 15 ⁇ -1 to 15 ⁇ -m are used.
  • hardware is not limited if a plurality of sine waves can be functionally generated.
  • a sine wave generator may be arranged in accordance with a time division multiplexing.
  • a common envelope function is provided for the component wave signals of a plurality of orders.
  • the common envelope function is modified by the envelope modifying means into envelope functions of the respective orders.
  • the envelopes of the component wave signals are controlled in accordance with modified envelope functions. Therefore, the user need not prepare all envelopes for the component wave signals. Much labor can be advantageously reduced to produce musical tones.
  • the global envelope setting means is arranged to give at least one global envelope function.
  • the plurality of component waves to be produced by the component wave generating means are divided into at least the first and second groups.
  • the envelope functions for controlling the component waves of the respective orders belonging to the first group are obtained by modifying the global envelope function by the first envelope modifying means, and the envelope functions for controlling the component waves of the respective orders belonging to the second group are obtained by modifying another global envelope function by the second envelope modifying means. Therefore, the user need set only a limited number of envelopes, thus improving operability for producing musical tones.
  • the envelope functions for controlling the component waves of the first group can be independent of the envelope functions for controlling the component waves of the second group, musical tone with high-quality musical tones can be produced.

Description

  • The present invention relates to a musical tone generating apparatus as claimed in the preamble of claim 1.
  • In a known conventional musical tone generating apparatus, envelopes respectively corresponding to a plurality of sine waves as frequency components of the musical tone are independently controlled to change tone colors as a function of time.
  • A musical tone generating apparatus of this type is described in e.g., US-A-4 083 285.
  • In a conventional musical tone generating apparatus of this type, if a user can arbitrarily manipulate envelopes of sine waves, musical performance effects can be naturally improved.
  • However, with the above application, the user must spend long time setting envelopes in proportion to an increase in envelope flexibility or versatility. Overloading on the user can be easily expected.
  • It is, therefore, an object of the present invention to provide a musical tone generating apparatus capable of producing envelope functions independently of respective component wave signals in response to simple input operations.
  • In order to achieve the above object of the present invention, there is provided a musical tone generating apparatus as claimed in claim 1.
  • According to the present invention, the user need not produce individual envelope functions for the component wave signals of a plurality of orders in order to obtain musical tones. For example, at a data input device such as a keyboard, the user selects only one envelope function to obtain a variety of tone colors because a plurality of envelope functions are generated on the basis of one envelope function (i.e., a common or global envelope function) generated by an envelope modifying means. An envelope function for controlling an envelope of a component wave signal of a given order is obtained by modifying the common envelope function in accordance with a value of a corresponding order of the component wave signal.
  • If a value of the common envelope function is given as w and a value of the order is given as x, the envelope modifying means performs modification represented by the following function: G(x,w)
    Figure imgb0001
    The value of function G(x,w) is determined by parameter x and parameter w. The modified value of function G(x,w) is a value for the xth order envelope function. That is, it is a value of the envelope function for controlling the envelope of the xth order component wave signal. In other words, function G(x,w) provides a modification characteristic for modifying the common envelope function into the envelope functions of the respective orders.
  • In one example, if order value x and value w of the common envelope function are given, function G(x,w) can be calculated in accordance with arithmetical and logical operations. In this case, the envelope modifying means can be basically realized by a means for executing appropriate logical and/or arithmetical algorithms.
  • In another example, modification characteristic function G(x,w) is solely determined if order value x and the value w of the common envelope function are given. However, this function cannot be solved by arithmetic and logical operations or cannot be calculated for at least a given combination of x and w. In this case, the envelope modifying means can be constituted by using a modification table (e.g., a memory such as a ROM) in the range where calculations cannot be performed. The modification table can also be used in the first example. A suitable construction can be determined in consideration of a processing speed, an operation volume, and a required memory capacity.
  • In a simple example, a monotonous function (e.g., monotonous for x - w = u, x/w = u, x.w = u, and x + w = u, or monotonous for all parameters u as a combination of the above arithmetic operations) can be used as modification characteristic function G(x,w). In this case, logical operations (e.g., comparison, AND, and OR) need not be performed. Only the arithmetical calculations can be performed.
  • In a more complicated example, modification is characteristic function G(x,w) is defined as a function in which the characteristics are changed in ranges of values of parameter u if parameter u is calculated by arithmetical operations using parameter x of the order and parameter w of the envelope function. An appropriate function is selected in accordance with the value of parameter u. For example, if u > 0, then monotonous function G1(u) serves as a modification characteristic function. If u ≦ 0, another monotonous function G2(u) serves as a modification characteristic function.
  • The envelope modifying means produces envelopes of respective orders from the common envelope function. As a result, the user is free from production of respective envelope functions for the corresponding component waves and can easily produce musical tones.
  • The common envelope function input to the envelope modifying means can be expressed in various forms. In a simplest example in digital techniques, an envelope function can be given as a waveform data format (i.e., a sequence of digital data representing the instantaneous values of the envelope levels). In many examples, the envelope functions can be represented by compressed data (control information). For example, an envelope function of a polygonal type is expressed as a set of position data of polygonal points (e.g., this function is expressed by several step rate data and several step level data). Not many envelope input devices are available to input envelope functions in the form of waveform data. For example, when an envelope waveform is drawn on an input device such as a tablet, A/D-converted data (data prior to data compression) is expressed in the form of waveform data. The form of the input device for inputting the common envelope function is not important to the present invention.
  • The form of modification processing varies in the envelope modifying means in accordance with the form of expression of the input common envelope function. For example, in a given arrangement, the envelope modifying means modifies the common envelope function given in the form of digital waveform data into envelope functions of the respective orders represented in the same form as the common envelope-function. That is, each digital value of the common envelope function is modified into the corresponding digital value of an envelope function of each order. The modified envelope functions of the respective orders which are expressed in the form of waveform data can be directly inparted to a component wave signal in the form of waveform data. Alternatively, the above envelope functions of the respective orders may be decoded into the envelope function in the form of waveform data upon generation of a musical tone signal after the envelope functions of the respective orders are compressed in the form of control information. In another arrangement, the envelope modifying means modifies the common envelope function given in the form of control information into the envelope functions of the respective orders in the same form as the common envelope function. In this case, in a simple example, the values of the control information (e.g., values of rate data and level data for each step, or coordinates of each polygonal point) are converted in accordance with modification characteristic function G(x,w), thereby obtaining the envelope functions of the respective orders. In a more complicated example, the modification characteristic function is also applied to points on a polygonal line (these points can be easily calculated by arithmetical operations because the common envelope function is defined by control information) in addition to polygonal points, thereby obtaining points defining the envelope functions of the respective orders.
  • The envelope function of each order modified by the envelope modifying means is finally used to control the envelope of the component wave signal of the order corresponding to the envelope function. This envelope control can be performed by a digital multiplier, an analog multiplier, or a device for performing other functionally or equivalently performing a multiplication.
  • According to the present invention, the component wave signal is not limited to the sine wave signal but can be extended to any waveform signal having a frequency or a frequency spectrum corresponding to the order. For example, a rectangular wave (e.g., a rectangular wave obtained by the Walsh function) can be used as a component wave signal.
  • According to the specific form of the present invention, independent envelopes can be given in units of groups of component waves, and musical tones with a variety of tone colors can be obtained.
  • A means for establishing an independent relationship between an envelope function for a component wave belonging to a given group (e.g., the first group) and that belonging to another group (e.g., the second group) can be arranged in several specific forms. In a given example, a global envelope setting means provides different global envelope functions in units of groups. In this case, the user produces different envelopes in units of component wave groups. The envelope modifying means for the first group generates envelope functions of the respective orders on the basis of the first global envelope function. The envelope modifying means for the second group produces envelope functions of the respective orders on the basis of the second global envelope function. With the above arrangement, independency of the envelopes of the different groups can be established due to the following reason.
  • Assume the modification logical algorithm used in the first and second envelope modifying means is the same and is given as Fx(W) where x is the order and W is the global envelope function. In other words, Fx(W) is the xth-order envelope function. The envelope modifying means modifies the global envelope function in accordance with its orders. Condition Fx(W) ≠ Fy(W) is established between envelope functions Fx(W) and Fy(W) having different orders x and y. However, if envelope functions have the same order, Fx(W) = Fx(W). In other words, functions Fx(W) and Fy(W) depend on the orders (if identical global envelope functions are assumed).
  • In the above case, the first global envelope function W1(t) and the second envelope function W2(t) are independently determined by the user and are independent functions. Functions obtained by modifying independent functions on the basis of the same modification logical algorithm are independent. If the first envelope modifying means produces xth-order envelope function Fx(W1(t)) and the second envelope modifying means produces xth-order envelope function Fx(W2(t)), condition Fx(W1(t))
    Figure imgb0002
    Fx(W2(t)) is established. Since functions W1(t) and W2(t) are independent, envelope function group {Fx(W1(t)).} for controlling the component waves of the first group and envelope function group {Fx(W2(t))} for controlling the component waves of the second group are independent.
  • In another arrangement, assume that modification logical algorithm Fx(W) of the first envelope modifying means and modification logical algorithm Gx(W) of the second envelope modifying means are independent or different. In this case, either envelope modifying means can receive the same global envelope function. In other words, the global envelope setting means can provide only one global envelope function.
  • In the same manner as described above, the envelope function group {Fx(W)} generated by the first envelope modifying means to control the component waves of the first group and envelope function group {Gx(W)} generated by the second envelope modifying means to control the component waves of the second group are independent of each other.
  • In still another arrangement, a means can be used to modify a single global envelope function set by the user into global envelope functions which are independent between the groups. The global envelope function of each group is supplied to the corresponding envelope modifying means. For example, global envelope function G(W) for the first group is supplied to the first envelope modifying means and global envelope function H(W) for the second group is supplied to the second envelope modifying means. With this arrangement, either envelope modifying means (i.e., a means for modifying the global envelope group into envelope functions of the respective orders) can employ the same modification logical algorithm.
  • This invention can be more fully understood from the following detailed description when taken in conjunction with the accompanying drawings, in which:
    • Fig. 1 is a block diagram showing the overall circuit arrangement according to an embodiment of the present invention;
    • Fig. 2 is a block diagram showing a detailed circuit arrangement of an envelope-controlled sine wave generator in the circuit shown in Fig. 1;
    • Fig. 3 is a table showing a key code conversion logic algorithm in a key code converter in Fig. 2;
    • Fig. 4 is a map showing a format of envelope data stored in a global envelope memory shown in Figs. 1 and 2;
    • Fig. 5 is a waveform chart showing an envelope generated by an envelope generator in accordance with envelope data shown in Fig. 4;
    • Figs. 6(A) to 6(C) are waveform charts showing envelope modifications for obtaining a low-pass filter type resonance effect in the envelope modification device in Fig. 2;
    • Figs. 7(A) and 7(B) are waveform charts showing other envelope modifications for obtaining a high-pass filter type and band-pass filter type resonance effects in the envelope modification device in Fig. 2;
    • Figs. 8(A) to 8(E) and Figs. 9(A) and 9(B) are waveform charts showing still other envelope modifications for obtaining a low-pass filter effect in the envelope modification device in Fig. 2;
    • Figs. 10(A) to 10(C) are waveform charts showing still other envelope modifications for realizing a high-pass filter effect in the envelope modification device in Fig. 2;
    • Fig. 11 is a block diagram showing a partial modification of the circuit in Fig. 2;
    • Figs. 12(A) to 12(C) are waveform charts for explaining the operation of the envelope modification device shown in Fig. 11;
    • Fig. 13 is a circuit diagram of a device arranged by further modifying part of the envelope modification device in Fig. 2;
    • Figs. 14(A) to 14(D) are waveform charts showing still other envelope modifications for obtaining characteristics for modifying the envelope by only levels in the device shown in Fig. 11; and
    • Fig. 15 is a block diagram showing an overall circuit arrangement according to another embodiment of the present invention.
  • A few preferred embodiments of the present invention will be described in detail hereinafter. These embodiments exemplify sine wave synthesis type musical tone generating apparatuses.
  • The first embodiment will be described below. Fig. 1 shows the overall circuit arrangement of a sine wave synthesis type musical tone generating apparatus. Referring to Fig. 1, n envelope-controlled sine wave generators 15-1 to 15-n are connected to keyboard 1 serving as a performance input device, data input device 2 for inputting various data, and global envelope memory (common envelope memory) 3. Envelope-controlled sine wave generators 15-1 to 15-n are arranged to generate sine waves having independent frequencies on the basis of harmonic data set by a user at data input device 2. Global envelope memory 3 comprises a RAM and stores global envelope function data set at data input device 2. The global envelope is modified by the circuit constructed in the sine wave generators 15-1 to 15-n into envelope function data depending on their assigned frequencies (i.e., orders). The sine waves generated in generators 15-1 to 15-n are envelope-controlled by the modified envelope data.
  • In this embodiment, when the user sets one global envelope function, n independent envelope functions can be obtained for the preset global envelope function. The user need not set n envelopes for the respective sine waves, thereby reducing envelope producing labor.
  • Envelope-controlled sine wave data from envelope-controlled sine wave generators 15-1 to 15-n are added by adder 16, and a sum signal (musical tone signal) is converted into an analog signal by D/A converter 17. The analog signal is produced as a tone through amplifier 18 and loudspeaker 19.
  • The detailed arrangement of each envelope-controlled sine wave generator is shown in Fig. 2. The arrangement surrounded by the dotted line and denoted by reference numeral 15 represents one of envelope-controlled sine wave generators 15-1 to 15-n. Referring to Fig. 2, key code generator 4 generates a key code corresponding to the depressed key at keyboard 1. Key code converter 5 converts the generated key code in accordance with a value in harmonic data memory 10. Memory 10 can store harmonic data (harmonic orders) of 0 to 31 which can be set by the user at data input device 2. Key code converter 5 converts the key code using the stored harmonic data in accordance with a method shown in Fig. 3. For example, if harmonic data represents 1, the key code is converted into another key code representing a second harmonic which represents a tone higher by one octave than the original tone. Phase angle generator 6 comprises a frequency data ROM and an accumulator and causes the frequency data ROM to convert the key code from key code converter 5 into frequency data, and the accumulator to accumulate the frequency data so as to generate a phase angle corresponding to the key code, thereby reading out sine wave data from sine wave ROM 7. An output from sine wave ROM 7 is a sine wave signal having a frequency corresponding to the order of a harmonic set in harmonic data memory 10. In this embodiment, the key code is converted in accordance with the harmonic data. However, frequency data may be converted into frequency data corresponding to the harmonic in accordance with bit shifting or the like. Alternatively, the value of the phase angle output from phase angle generator 6 may be converted to obtain a phase angle representing the corresponding order. In this manner, various circuit modifications may be proposed.
  • Fixed amplitude memory 11 comprises a RAM for storing data for controlling (scaling) the amplitude of the sine wave signal from sine wave ROM 7 regardless of time changes. Scaling data can be input by the user at data input device 2. Scaling data stored in fixed amplitude memory 11 represent independent values for envelope-controlled sine wave generators 15-1 to 15-n. Therefore, when the sine wave data from sine wave ROM 7 is multiplied by each multiplier 8 with the data read out from fixed amplitude memory 11, relative amplitudes of n sine wave signals can be independently controlled.
  • The amplitude-controlled sine wave signal from multiplier 8 is multiplied with an envelope signal output from envelope modification device 14 (to be described in detail later). Therefore, amplitude control as a function of time can be performed, and the product is output from envelope sine wave generator 15.
  • As described above, global envelope memory 3 stores common global envelope function data for n envelope-controlled sine wave generators 15-1 to 15-n. The global envelope function in global envelope memory 3 can be expressed by 4-step rate data and 4-step level data (Fig. 4). The global envelope function in this form is modified into the form of waveform data by envelope generator 12 (Fig. 5). More specifically, envelope generator 12 comprises an accumulator and a comparator and receives step-1 rate data of step-1 level data from global envelope memory 3. The rate data is repetitively accumulated. If the accumulation result reaches the level data, envelope generator 12 receives step-2 rate data and step-2 level data from global envelope memory 3. The above operations are repeated to obtain waveform data of the global envelope.
  • Envelope modification device 14 modifies the waveform data of the common global envelope function generated by envelope generator 12 into waveform data of envelope functions of the respective orders in accordance with harmonic data (order) from harmonic data memory 10. For example, if the harmonic data from harmonic data memory 10 in envelope-controlled sine wave generator 15 is 1 (i.e., this value represents a second harmonic), the first-order envelope waveform data is generated by envelope modification device 14. The first-order envelope waveform data is multiplied with a sine wave signal having a frequency of the second harmonic, thereby controlling the envelope.
  • The arbitrary modification characteristic of envelope modification device 14 can be provided in principle. In practice, the modification characteristic for a resonance effect will be described first.
  • Assume that x is the order, i.e., the value of the harmonic data from harmonic data memory 10, that w(t) is the global envelope function, i.e., the output from envelope generator 12, and that R is the depth of resonance. Xth-order envelope function Fx(t) modified by envelope generator 12 satisfies the following conditions:
    • (a) If x < w(t) and f(x-w(t)) + R < 1, then Fx(t) = 1
    • (b) If x ≧ w(t) or f(x-w(t)) + R ≧ 1, then Fx(t) = f(x-w(t)) + R (if f(x-w(t)) + R < 0, then Fx(t) = 0)
  • A substitution of u for x-w(t) yields the following conditions for f(u):
    • (c) If u < 0, then f'(u) > 0
    • (d) If u = 0, then f(u) = 1
    • (e) If u > 0, then f'(u) < 0
    Therefore, if u = 0, i.e., if the order value x is equal to value W(t) of the global envelope function, f(u) takes the maximum value. The value of f(u) is decreased when the absolute value of difference u is increased.
  • Xth-order envelope function Fx(t) is expressed as a function of time t. When xth-order envelope function Fx(t) is expressed as a function of difference u, function F(u) is derived. The value of function F(u) is changed in accordance with order x relative to value W(t) of global envelope function at arbitrary time t. Therefore, function F(u) determines the modification characteristic for modifying the global envelope function into envelope functions of the respective orders. An example of modification characteristic function F(u) is shown in Fig. 6(A). A difference obtained by subtracting the value of global envelope function W(t) from order x is plotted along abscissa u. As shown in Fig. 6(A), near u = 0, i.e, in the range of order x closer to the value of global envelope function W(x), F(u) is amplified. However, if u << 0, then F(u) = 1. If u >> 0, then F(u) = 0. Therefore, modification characteristic function F(u) provides a resonance effect for emphasizing the component closer to the cutoff frequency of the low-pass filter.
  • The resonance effect can be dynamically given. More specifically, the value of global envelope function W(t) is changed as a function of time t. When specific order x0 is given, a value obtained by subtracting W(t) from order x0 is also changed as a function of time along the u-axis in Fig. 6(A). The value of each F(u), i.e., value Fx0(ti) of the x0th-order envelope function at time ti is also changed. According to Fig. 6(A), the value of Fx0(ti) is one (1) and is not thus attenuated if order x is sufficiently smaller (lower) than value W(ti) of the global envelope function at time ti. However, if order x is sufficiently larger (higher) than value W(ti) of the global envelope function at time ti, the value of FX0(ti) is zero and is thus perfectly attenuated. If order x is very close to value W(ti) of the global envelope function at time ti, the value of Fx0(ti) can be amplified to a value of one or more.
  • In other words, the order of an envelope function having an amplified value at a given time is close to the value of the global envelope function at the given time. Therefore, the order of the emphasized component wave is changed as a function of time, thereby obtaining the resonance effect which is dynamically changed as a function of time.
  • Modification into envelope functions of the respective orders will be described in detail. Assume that global envelope function W(t) shown in Fig. 6(B) is supplied from global envelope memory 3 through envelope generator 12. Specific order x0 has a dotted level. In this case, envelope modification device 14 shown in Fig. 2 produces x0th-order envelope function Fx0(t) shown in Fig. 6(C) in accordance with modification characteristic F(u) shown in Fig. 6(A).
  • In order to readily understand modification, the values of x0th-order envelope function Fx0(t) which correspond to several values of global envelope function W(t) shown in Fig. 6(B) are written in Fig. 6(A). For example, as shown in Fig. 6(B), values W(t1) and W(t2) of the global envelope function are equal to the value of order x0 at times t1 and t2. Therefore, u = 0 is established. The value of F(u) at position for u = 0 in Fig. 6(A) are values Fx0(t1) and Fx0(t2) of the x0-th order envelope function at times t1 and t2. The values of x0th-order envelope function Fx0(t) at other times can be obtained in the same manner as described above.
  • In practice, envelope modification device 14 shown in Fig. 2 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12.
  • Envelope modification device 14 can be arranged in various ways. For example, device 14 can comprise a subtracter for calculating a difference between the instantaneous value of global envelope function W(t) from envelope generator 12 and the value of order x from harmonic data memory 10, and a memory addressed in response to output data from the subtracter and adapted to store modified envelope function waveform data values. Alternatively, if modification characteristic function F(u) or f(x-W(t)) is a function to be calculated, envelope modification device 14 can be achieved by a proper algorithm. For example, a difference between the order value x and the value of the global envelope function is calculated such that u = x - W(t). By utilizing difference u, f(x-W(t)) is calculated and is added to resonance value R, thereby obtaining f(x-W(t)) + R. Whether difference u is negative is determined or whether f(x-W(t)) + R is 1 or less is determined. If both these conditions are established (corresponding to x < W(t) and f(x-W(t)) + R < 1), constant 1 is used as the modified envelope function value. If neither conditions are established (corresponding to x ≧ W(t) or f(x-W(t) + R ≧ 1), whether f(x-W(t)) + R is negative is determined. If value f(x-W(t)) + R is not negative, this value serves as the modified envelope function value. If value f(x-W(t)) + R is negative, constant 0 serves as the modified envelope function value.
  • Modification characteristic F(u) of the global envelope function/envelope functions of the respective orders is not limited to ones shown in Fig. 6(A) or in modification conditions (a) to (e). The illustrated modification characteristic is an example for obtaining a low-pass filter type resonance effect. For example, within the range of u << 0, the characteristic is perfectly flat since F(u) = 1. However, the characteristic may be almost flat. The position for u = 0, i.e., x = W(t) is the center of resonance. However, x = W(t) + K (where K is a constant) may be the central position of the resonance. Alternatively, cx = W(t) (where c is a constant or cx is an increment function of x) may be the central position of the resonance. In the former case, (x-K) can be evaluated as the value of order x. In the latter case, cx can be evaluated as the value of order x.
  • Modification characteristic F(u) may be selected to obtain a high-pass filter type resonance effect in place of the low-pass filter type resonance effect.
  • A modification characteristic for the high-pass filter type resonance effect is shown in Fig. 7(A). This modification characteristic is obtained by changing conditions (a) and (b) of conditions (a) to (e) and using the following condition in place of condition (a): If x > W(t) and f(x-W(t)) + R < 1, then Fx(t) = 1
    Figure imgb0003
    and the following condition in place of condition (b): If x ≦ W(t) or f(x-W(t)) + R ≧ 1, then Fx(t) = f(x-W(t)) + R
    Figure imgb0004
    (if f(x-W(t)) + R < 0, then Fx(t) = 0)
    Figure imgb0005
  • Modification characteristic F(u) may be selected to obtain a band-pass filter type resonance effect, as shown in Fig. 7(B).
  • The modification characteristic for the band-pass filter type resonance effect is obtained by using conditions (c), (d), and (e) of conditions (a) to (e) without changes and the following condition in place of conditions (a) and (b): Fx(t) = f(x-W(t)) + R
    Figure imgb0006
    (if f(x-W(t)) + R < 0, then Fx(t) = 0)
    Figure imgb0007
  • Resonance value R need not be a constant but a variable which can be changed by the user. In this case, the resonance value can be preferably changed in real time during musical performance in the following manner. When envelope modification device 14 shown in Fig. 2 is used, changing resonance value R is used in the process for producing envelope functions Fx(t) of the respective orders in the form of waveform data from global envelope function W(t) in the form of waveform data.
  • The operation of envelope modification device 14 in Fig. 2 will be described when waveform data of envelopes of the respective orders for obtaining a low-pass filter effect is to be generated.
  • In this case, envelope modification device 14 performs the following modifications to produce envelopes of the respective orders:
    • (f) If x ≦ W(t), then Fx(t) = 1
    • (g) If x > W(t), then Fx(t) = f(x-W(t))
       (if f(x-W(t)) < 0, then Fx(t) = 0) where x is the order (corresponding harmonic data), W(t) is the global envelope function (output from envelope generator 12), and Fx(t) is the modified envelope function (output from envelope modification device 14). Let x-W(t) be u, then f(u) satisfies the following conditions:
    • (h) If u = 0, then f(u) = 1
    • (i) If u > 0, then fʹ(u) < 0
  • When order x is smaller than the value of global envelope function W(t), Fx(t) is 1. However, when order x is larger than the value of global envelope function W(t), the gradient of Fx(t) is negative. An example of this function is shown in Fig. 8(A). Fig. 8(A) shows the characteristic of function Fx(t) when order x is plotted along the abscissa. Although function W(t) is a function of the global envelope function, its value is changed as a function of time t. If specific order x0 is given, the value of x0th-order envelope function Fx0(t) is changed in accordance with the value at each time of global envelope function W(t). In the range of x0 ≦ W(t), x0th-order envelope function Fx0(t) is not attenuated. However, in the range of x0 > W(t), the function is greatly attenuated when a difference between x0 and W(t) is larger.
  • Assume that global envelope function W(t) shown in Fig. 9(A) is supplied from global envelope memory 3 through envelope generator 12. Specific order x0 has the dotted level. In this case, x0th-order envelope modification device 14 generates x0th-order envelope function Fx0(t) shown in Fig. 9(B) in accordance with the modification characteristic shown in Fig. 8(A).
  • The value of global envelope function W(t) shown in Fig. 9(A) at time a is W(a) = 0 and is sufficiently smaller than the value of order x0 of interest. As shown in Fig. 8(B), value Fx0(a) of x0th-order envelope function Fx0(t) at time a is completely attenuated and is zero. Similarly, since value W(c) of the global envelope function time c is sufficiently smaller than the value of order x0, value Fx0(c) of the modified envelope function is also zero, as shown in Fig. 8(D). Even at time b when global envelope function W(t) has a maximum value, its value W(b) is larger than the value of order x0. Therefore, value Fx0(b) of the modified envelope function is not attenuated and is 1, as shown in Fig. 8(C). Value W(d) of the global envelope function at time d is slightly smaller than the value of order x0. For this reason, order x0 is located in the region of the attenuation curve of f(x-W(t)) shown in Fig. 8(A). The modified envelope function value is value Fx0(d) between 0 and 1 in accordance with the characteristic of attenuation curve f(x-W(t)), as shown in Fig. 8(E).
  • In practice, envelope modification device 14 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12. As a result, envelope function Fx0(t) in the form of waveform data shown in Fig. 9(B) is calculated.
  • Envelope functions of higher orders than order x0 are attenuated as compared with the x0th-order envelope function. As a result, an effect similar to a low-pass filter can be obtained.
  • Envelope modification device 14 can be arranged in various ways. For example, envelope modification device 14 comprises a subtracter for calculating a difference between the instantaneous value of the global envelope function output from envelope generator 12 and the value of the order from harmonic data memory 10, and a memory addressed in response to output data from the subtracter to store waveform data of the modified envelope function. Alternatively, if f(x-W(t)) in Fig. 8(A) can be calculated, a calculation program is executed. For example, the value of order x and the instantaneous value of global envelope function W(t) are compared. If the value of order x is smaller than the instantaneous value of the envelope function, the modified envelope function value serves as a constant. However, if the value of order x is larger than the instantaneous value, instantaneous value W(t) is used to calculate f(x-W(t)). The sign of f(x-W(t)) is determined. If value f(x-W(t)) is positive, the result serves as the modified envelope function value. Otherwise, zero serves as the modified envelope function value.
  • A modification characteristic for the global envelope function/envelope functions of the respective orders is not limited to the one shown in Fig. 8(A).
  • For example, in the range of x ≦ W(t) in Fig. 8(A), function Fx(t) is perfectly flat but may be almost flat. The position of x = W(t) is the attenuation start point associated with the cutoff point. However, x = W(t) + K (where K is a constant) may be the attenuation start point. Alternatively, cx = W(t) (where c is a constant) may be the attenuation start point. In the former case, (x-K) can be regarded as the value of the order. In the latter case, cx can be regarded as the value of the order.
  • An operation of envelope modification device 14 shown in Fig. 2 will be described when waveform data for envelopes of the respective orders for obtaining an effect similar to the high-pass filter is generated.
  • In this case, envelope modification device 14 performs the following modifications to generate envelopes of the respective orders:
    • (j) If x > W(t), then Fx(t) = 1
    • (k) If x ≦ W(t), then Fx(t) = f(x-W(t))
       (if f(x-W(t)) < 0, then Fx(t) = 0) where x is the order (corresponding harmonic data), W(t) is the global envelope function (output from envelope generator 12), and Fx(t) is the converted envelope function (output from envelope modification device 14). A substitution of x - W(t) into u yields the following conditions for f(u):
    • (ℓ) If u = 0, then f(u) = 1
    • (m) If u < 0, then fʹ(u) > 0
    In addition, if f(u) = 1 is established for u > 0, the result coincides with Fx(t) = 1 for x > W(t). This f(u) determines the modification characteristic with the envelope function of a given order derived from the global envelope function.
  • If the value of order x is larger than the value of global envelope function W(t), function f(u) is set to be 1. However, if the value of order x is smaller than the value of global envelope function W(t), the gradient of function F(u) is positive. An example of such a modification characteristic is shown in Fig. 10(A). Difference u is plotted along the abscissa and obtained by subtracting the value of global envelope function W(t) from the value of order x. In general, global envelope function W(t) is changed as a function of time t. Therefore, if specific order x0 is given, a value obtained by subtracting the value W(t) from order x0 is also changed as a function of time and is moved along the u-axis in Fig. 10(A). The value of each f(u), i.e., value Fx0(ti) of the x0th-order envelope function at each time ti is also changed. The value of Fx0(ti) is not attenuated in the range of x0 ≧ W(t). However, the value of Fx0(ti) is greatly attenuated in the range of x0 < W(t) when the difference between x0 and W(t) is increased.
  • Assume that global envelope function W(t) shown in Fig. 10(B) is supplied from global envelope memory 3 through envelope generator 12. Specific order x0 has a dotted level. In this case, envelope modification device 14 generates x0th-order envelope function Fx0(t) shown in Fig. 10(C) in accordance with the modification characteristic shown in Fig. 10(A).
  • In order to readily understand the modification values of the x0th-order envelope function which correspond to several values of global envelope function W(t) shown in Fig. 10(B) are written. For example, Fx0(d) is the value of the x0th-order envelope function at time d. As is apparent from Fig. 10(B), W(d) is slightly larger than x0 at time d. In other words, the value of u is negative. The point on f(u) at the position of u in Fig. 10(A) is calculated. The obtained point represents Fx0(d). Other points can be obtained in the same manner as described above.
  • In practice, envelope modification device 14 performs modifications for all data values of global envelope function W(t) in the form of waveform data supplied from envelope generator 12. As a result, envelope function Fx0(t) in the form of waveform data shown in Fig. 10(C) is calculated for the x0th order.
  • It is apparent from the above description that envelope functions having orders smaller than the x0th order are attenuated as compared with the x0th-order envelope function. As a result, an effect similar to a high-pass filter can be obtained.
  • Envelope modification device 14 can be arranged in various ways. For example, envelope modification device 14 comprises a subtracter for calculating a difference between the instantaneous value of the global envelope function output from envelope generator 12 and the value of the order from harmonic data memory 10, and a memory addressed in response to output data from the subtracter to store waveform data of the modified envelope function. Alternatively, if f(x-W(t)) in condition (k) can be calculated, a calculation program is executed. For example, the value of order x and the instantaneous value of global envelope function W(t) are compared. If the value of order x is larger than the instantaneous value of the envelope function, the modified envelope function value serves as a constant. However, if the value of order x is smaller than the instantaneous value, instantaneous value W(t) is used to calculate f(x-W(t)). The sign of f(x-W(t)) is determined. If value f(x-W(t)) is positive, the result serves as the modified envelope function value. Otherwise, zero serves as the modified envelope function value.
  • A modification characteristic for the global envelope function/envelope functions of the respective orders is not limited to the one shown in Fig. 10(A).
  • For example, in the range of u > 0, i.e., x > W(t) in Fig. 10(A), function Fx(t) is perfectly flat but may be almost flat. The position of u = 0, i.e., x = W(t) is the attenuation start point associated with the cutoff point. However, x = W(t) + K (where K is a constant) may be the attenuation start point. Alternatively, cx = W(t) (where c is a constant or cx is an increment function) may be the attenuation start point. In the former case, (x-K) can be regarded as the value of the order. In the latter case, cx can be regarded as the value of the order.
  • Envelope modification device 14 described above generates envelope functions in the form of waveform data by using the global envelope functions in the form of waveform data and the order data. At the same time, all values of the waveform data of the global envelope are modified.
  • To the contrary, an arrangement shown in Fig. 11 modifies a global envelope function expressed by a set of rate data and level data shown in Fig. 4 into envelope functions of the respective orders. In other words, several points of global envelope function W(t) are modified in accordance with modification characteristic F(u). These points include peak or break points (i.e., points corresponding to W(a), W(b), W(c), W(d), and W(e) in Fig. 12) on global envelope function W(t) and points (i.e., points corresponding to W(t1) and W(t2)) in which the values of function W(t) coincide with the values of order x.
  • Envelope modification device 14A in Fig. 11 executes the following algorithm to obtain a set of rate data and level data which express the x0th-order envelope function in accordance with the set of rate and level data which define the global envelope data.
  • ℓ (i) and r(i) are level and rate data of the ith step of the global envelope function, and L(j) and R(j) represent level and rate data of the jth step of the x0th-order envelope function to be stored in envelope memory 14B for respective orders. In addition, ℓ(old) represents the previous level of the point on the global envelope function. The initial value of level ℓ(old) is zero, and L(0) is also zero. Both initial values of i and j are 1.
    • (1) Level ℓ (i) and rate r(i) of the current step are read out from global envelope memory 3.
    • (2) Whether condition ℓ(old) < x0 < ℓ(i) or ℓ(old) > x0 > ℓ(i) is established is determined (that is, whether the value of order x0 is present between the previous and current values of the global envelope functions is determined). If this determination is established, the flow advances to (3). Otherwise, the flow advances to (7).
    • (3) Let (1+R) be level L(j) of the x0th-order envelope function (that is, the jth level of the x0th-order envelope function is obtained).
    • (4) A division (x0-ℓ(old))/r(i) is calculated, and the quotient is given as t (e.g., time t1 between point W(a) and the next point W(t1) in Fig. 12(B) is calculated).
    • (5) A division (L(j) - L(j-1))/t is calculated, and the quotient is given as rate R(j) (that is, the jth rate of the x0th-order envelope function is calculated).
    • (6) The value of order x0 is set in ℓ(old), and the count of j is incremented by one.
    • (7) A difference F(x0 - ℓ(i)) is calculated, and let the difference be level L(j) (that is, the jth level of the x0th-order envelope function is obtained in accordance with modification characteristic F(u) for obtaining a low-pass filter type resonance effect).
    • (8) A division (ℓ(i) - ℓ(old))/r(i) is calculated and the quotient is given as t (e.g., time between point W(t1) in Fig. 12(B) and the next point W(b) is calculated; see step (4)).
    • (9) A division (L(j) - L(j-1))/t is calculated and the quotient is defined as the jth rate R(j) of the X0th-order envelope function.
    • (10) Set the value of ℓ(i) in ℓ(old), and both the values of i and j are incremented by one. If i < 5, the flow returns to step (1). However if i = 5 then the flow is ended.
  • By performing the above processing, sets of rate and level data {(L(1),R(1)), (L(2),R(2)),...} which define the x0th-order envelope function (Fig. 12(C)) are stored in envelope memory 14B for the respective orders. The above algorithm is an example, and similar envelope functions can be obtained by using other algorithms.
  • Envelope generator 14C has an arrangement similar to that of envelope generator 12 shown in Fig. 2. In response to key depression on keyboard 1 (Fig. 1), rate and level data are read out from the first step from envelope memory 14B for the respective orders. The envelope functions of the respective orders which are expressed by rate and level data are sequentially changed into waveform data. The amplitudes of sine wave data of the corresponding orders which are output from multiplier 8 are controlled by multiplier 9 in accordance with the waveform data sequentially generated by envelope generator 14C.
  • The above description has been made to clarify a low-pass filter type resonance effect of modification characteristic F(u) executed in envelope modification device 14A shown in Fig. 11.
  • Fig. 13 shows a modification obtained by partially modifying the circuit arrangement in Fig. 11. Envelope modification device 14A cooperates with global envelope generator 14D to modify the global envelope function from global envelope memory 3 into envelope functions of the respective orders expressed in the same form as that of the global envelope function. Global envelope generator 14D calculates an instantaneous value of the global envelope function and basically comprises an accumulator. After the rate data is set by envelope modification device 14A, envelope generator 14D adds rate data to the accumulated value every time a clock is supplied from envelope modification device 14A. An accumulation result is output to envelope modification device 14A. Envelope modification device 14A comprises a level coincidence detector for detecting a coincidence between the accumulation result front global envelope generator 14D and global envelope predetermined level data, and an order coincidence detector for detecting a coincidence between the accumulation result and the order data. If the coincidence is established, the accumulation result is modified in accordance with modification characteristic F(u) to obtain level data of envelopes of the respective orders (The arrangement required for modification itself is substantially the same as the corresponding section in envelope modification device 14 shown in Fig. 2). If a coincidence signal is output from the level coincidence detector, global envelope generator 14D is reset in accordance with the rate data of the next envelope step. In addition, in order to obtain time information, envelope modification device 14A comprises a counter for counting an operation count of each envelope step in global envelope generator 14D and a circuit for calculating rate data of the envelopes of the respective orders in accordance with a difference between the level data and time data as the contents of the counter.
  • For example, envelope modification device 14A reads out the rate and level data of step 1 for global envelope function W(t) shown in Fig. 12(B) (corresponding to the interval between time a and time b in Fig. 12(B)) from global envelope memory 3. The level data is set in the internal level coincidence detector, and the rate data is set in global envelope generator 14D. Envelope modification device 14A supplies a clock signal to generator 14D to allow an accumulation operation and increments the count of the internal counter by one. At time t1 the internal order coincidence detector detects a coincidence between the global envelope function value (output from global envelope generator 14D) and the value of order x0. In this case, envelope modification device 14A modifies the function value in accordance with modification characteristic F(u) shown in Fig. 12(A). The modified result is assured as the level data of the first step of the x0th-order envelope function. A difference between this level data and the immediately preceding step level data (in this case, no preceding step is present, and the previous level data represents zero) is calculated. The difference is divided by the count of the counter, i.e., the value representing the time of the first step of x0th-order envelope function Fx0(t). The quotient is assured as the rate data of the first step of the x0th-order envelope function. The counter is initialized for the second step of the x0th-order envelope function.
  • The operation of global envelope generator 14D is started again. The count of the internal counter is incremented by one every time the accumulation cycle is completed. When the count of the counter reaches a predetermined value (corresponding to time b in Fig. 12(B)), the level coincidence circuit detects that the global envelope function value as the accumulation result has reached the predetermined level. In the same manner as described above, envelope modification device 14A calculates the level and rate data of the second step of the x0th-order envelope function. Thereafter, the rate and level data of the next step are read out from global envelope memory 3 and the above operations are repeated.
  • As a result, envelope control information (i.e., set of rate and level data) for describing the x0th-order envelope function shown in Fig. 12(C) are obtained. The control information is temporarily stored in envelope memory 14B for the respective orders.
  • Envelope generator 14C has the same arrangement as that of envelope generator 12C of Fig. 11. In response to key depression on keyboard 1 (Fig. 1), rate and level data are read out from the first step from envelope memory 14B for respective orders. The envelope functions of the respective orders expressed by the rate and level data are sequentially changed into waveform data.
  • In this manner, the envelopes of the respective orders expressed by the rate and level data can be derived from the global envelope expressed by the rate and level data in Fig. 13.
  • The above arrangement may be changed to obtain a high-pass filter type resonance effect or a band-pass filter type resonance effect in place of the low-pass filter type resonance effect. In this case, the circuit can be properly designed with reference to Fig. 7, and Fig. 11, 12 or 13 to set the rate and level data which represent the x0th-order envelope function.
  • The resonance value R need not be a constant but be a variable which can be set by the user. If the resonance value can be changed in real time, a performance effect can be further improved.
  • An arrangement for performing real time resonance value changes can be obtained by adding to the arrangement of Fig. 11 or 13 a multiplier, arranged between envelope generator 14C and multiplier 9, for multiplying resonance depth coefficient R/R0 (where R0 is the reference resonance depth which is reflected in the data stored in the envelope memory 14B for the respective orders, and R is the resonance value designated by the user) with the output from envelope generator 14C, a selector (its selection output is input to multiplier 9) for selecting an output from the additional multiplier or a direct output from envelope generator 14C, and a comparator for controlling selection of the selector. This comparator compares the output from envelope generator 14C with data of a level (e.g., level corresponding to F(u) = 1 in Fig. 12(A)) for switching the output from envelope generator 14C. An output from this comparator is supplied to the selection control input of the selector.
  • An operation of envelope modification device 14A shown in Fig. 11 will be described when a low-pass filter type resonance effect is to be realized.
  • If low-pass filter type modification characteristic F(u) satisfying conditions (f) to (i) is provided to envelope modification device 14A shown in Fig. 11, the following algorithm is executed to obtain the x0th-order envelope function expressed by the sets of level and rate data.
    • (1) Level ℓ(i) and rate r(i) of the current step i are read out from global envelope memory 3.
    • (2) A function F(x0 - ℓ(i)) is calculated, and the result is set as level L(i) of step i of the x0th-order envelope function.
    • (3) A division (ℓ(i) - ℓ(i-1))/r(i) is calculated, and the quotient is set as time t of step i.
    • (4) A division (L(i) - L(i-1))/t is calculated, and the quotient is set as rate R(i) of step i of the x0th-order envelope function.
    • (5) Step number i is incremented by one. If i < 5, then the flow returns to step (1). However if i = 5, then the flow is ended.
  • Similarly, an arrangement for obtaining a high-pass filter type resonance effect by using envelope modification device 14A in Fig. 11 will be described below.
  • In order to assign high-pass filter type modification characteristic F(u) satisfying conditions (j) to (m) to envelope modification device 14A in Fig. 11, the same algorithm as the algorithm consisting of steps (1) to (5) described with reference to the low-pass filter type resonance effect is performed to obtain the x0th-order envelope function expressed by sets of rate and level data (however, the algorithm in this case is different from the that of steps (1) to (5) in that F(x-ℓ(i)) is calculated to obtain level L(i) of each step of the x0th-order envelope function).
  • In each arrangement described above, the filter characteristic is obtained by using as a parameter difference u between the value of order x and global envelope function value W(t). The present invention can be easily modified to perform modifications for performing a filter effect having several pass or stop bands.
  • A very simple modification characteristic will be described below.
  • In this arrangement, only level data of the global envelope function expressed by sets of rate and level data are modified. That is, when level data of each step of the global envelope function is represented by LEVEL, the following modification is performed: LEVEL → F(X,LEVEL)
    Figure imgb0008
    The right-hand side F(x,LEVEL) represents the level of the step corresponding to the xth-order envelope function.
  • For example, F(x,LEVEL) is given as follows: F(x,LEVEL) = 100[1 - {1 - (LEVEL/100)}x]
    Figure imgb0009
    In this case, modified level F(x,LEVEL) is changed in accordance with the values of order x as follows:
       (A) 0th Order (x = 0)
  • In this case, level F(x.LEVEL) is given as follows regardless of the level of the global envelope function:
       F(0, LEVEL) = 100
  • For example, if the global envelope function is given as shown in Fig. 14(A), the 0th-order envelope function is given as shown in Fig. 14(B). The modified 0th-order envelope function is used to control the envelopes of the 0th-order sine wave, i.e., the sine wave having the fundamental frequency.
       (B) First Order (x = 1)
  • F(1,LEVEL) = LEVEL is given. That is, each level of the given global envelope function is always equal to that of the first-order envelope function. The first-order envelope function is the same as the global envelope function (Fig. 14(C)). The waveform data of the first-order envelope function is used to control the envelope of the first-order sine wave signal, i.e., the envelope of the sine wave signal having a frequency of a second harmonic.
       (C) Second Order (x = 2)
  • F(2,LEVEL) = 2LEVEL - 100 is given. The level of each step of the global envelope function is doubled, and 100 is subtracted from the doubled value. The resultant difference serves as the corresponding level of the second-order envelope function (Fig. 14(D)). The second-order envelope function is applied to a sine wave having a frequency of a second order, i.e., third harmonic.
  • Envelope functions of higher orders can be produced in the same manner as described above. If the modification function given in equation (1) is used, the envelope function is attenuated and its amplitude change is small when the order is increased.
  • Function 100[1 - {1 - (LEVEL/100}x] is an example. An arbitrary function may be selected, such as a function having an amplitude which is greatly changed when the order is increased.
  • The modification of only levels can be easily realized by envelope modification device 14D shown in Fig. 11. For example, the following algorithm can be used:
    • (1) Rate r(i) of step i from global envelope memory 3 is transferred to envelope memory 14B as rate R(i) of step i of the xth-order envelope function.
    • (2) Level ℓ(i) of step i is read out from global envelope memory 3.
    • (3) Function F(x,ℓ(i)) is calculated, and the result is transferred to envelope memory 14b as level L(i) of step i of the xth-order envelope function.
    • (4) Step number i is incremented by one. If i < 5, then the flow returns to step (1). However, if i = 5, the algorithm is ended.
  • The above level modification can be easily performed by envelope modification device 14 shown in Fig. 2. F(x,W(t)) for each W(t) from envelope generator 12 is calculated.
  • In the arrangement of Fig. 11, the rate modification in addition to the level modification can be performed as follows: LEVEL → F(x,LEVEL)
    Figure imgb0010
    Rate → G(x,LEVEL)
    Figure imgb0011
  • G(x,RATE) is a rate value corresponding to the xth-order envelope function obtained by modifying value RATE of the global envelope function in accordance with the value of order x.
  • Several arrangements have been described in detail above. The present invention is not limited to these. Various changes, modifications, and improvements may be made. In the above embodiment, a plurality (n) of envelope-controlled sine wave generators 15-1 to 15-n are used. However, hardware of a sine generator is not limited if it functionally provides a plurality of sine waves.
  • For example, at least some of envelope-controlled sine wave generators 15-1 to 15-n can be realized by TDM (time-division multiplexing).
  • Another embodiment of the present invention will be described with reference to Fig. 15.
  • Referring to Fig. 15, the envelope-controlled sine wave generator section is divided into two groups: envelope-controlled sine wave generators 15-1 to 15-n as the first group and envelope-controlled sine wave generators 15ʹ-1 to 15ʹ-m as the second group. Envelope-controlled sine wave generators 15-1 to 15-n and 15ʹ-1 to 15ʹ-m are connected to keyboard 1 as a performance input device and data input device 2 for inputting various data. At data input device 2, the user can specify independent harmonic data to the respective groups of envelope-controlled sine wave generators. Sine wave generators 15-1 to 15-n and 15ʹ-1 to 15ʹ-m can generate different sine waves having independent frequencies on the basis of prestored harmonic data upon key depression at keyboard 1. The feature of this embodiment lies in that the first and second groups constituted by the corresponding envelope-controlled sine wave generators are coupled to the corresponding global envelope memories. More specifically, envelope-controlled sine wave generators 15-1 to 15-n of the first group are coupled to first global envelope memory 3-1, and envelope-controlled sine wave generators 15ʹ-1 to 15ʹ-m of the second group are coupled to second global envelope memory 3-2. First and second global envelope memories 3-1 and 3-2 respectively store first and second global envelope functions W1(t) and W2(t) which are independently set at data input device 2. First global envelope function W1(t) is converted to n envelope functions of n orders determined by the assigned harmonic data (order) in envelope-controlled sine wave generators 15-1 to 15-n belonging to the first group. Second global envelope function W2(t) is modified into m envelope functions determined by the assigned harmonic data in envelope-controlled sine wave generators 15ʹ-1 to 15ʹ-m belonging to the second group. The modified envelope functions of the respective orders are used to control the envelopes of the sine wave signals of the corresponding orders in envelope-controlled sine wave generators 15-1 to 15-n.
  • In this embodiment, if one envelope (i.e. the global envelope function) is given for sine wave signals of one group, a plurality of envelope functions, i.e., envelope functions of sine wave signals belonging to this group can be obtained based on the given function. The load imposed on the user who produces the envelopes can be greatly reduced. In addition, according to this embodiment, since independent global envelope functions are set in units of groups, musical tones with a variety of tone colors can be obtained as compared with the arrangement in which a common global envelope is given for all sine waves without dividing a set of sine waves into a plurality of groups.
  • Referring back to the arrangement of Fig. 15, envelope-controlled sine wave data from envelope-controlled sine wave generators 15-1 to 15-n and 15ʹ-1 to 15ʹ-m are added by adders 16-1 and 16-2, respectively. The sum signals (musical tone signals) are converted into analog signals by D/A converter 17. The analog signals are produced outside through amplifier 18 and loudspeaker 19. Although adders 16-1 and 16-2 are represented as separate units, only one adder can be used to add output data from envelope-controlled sine wave generators 15-1 to 15-n and 15ʹ-1 to 15ʹ-m.
  • The detailed arrangement of each envelopecontrolled sine wave generator is the same as that in Fig. 2, 11 or 13.
  • The independent first and second global envelope functions can be arbitrarily set by the user. Independency and flexibility between the global envelope functions are reflected in envelope functions (i.e., the envelope functions for the sine waves of the first group and the envelope functions for the sine waves of the second group) converted by envelope modification device 14 or 14A. Therefore, a variety of finally produced musical tone signals can be achieved.
  • In the above embodiment, the global envelope functions can be input and set by the user in units of groups. The envelope functions of the first group applied to the sine waves of the first group are independent of the envelope functions of the second group applied to the sine waves of the second group. For example, if the global envelope function shown in Fig. 14(A) is a global envelope function of the first group and a global envelope function entirely different therefrom is a global envelope function of the second group, envelope functions of orders (e.g., 0th, 1st, and 2nd orders) obtained on the basis of the global envelope function of the second group are obviously different from those shown in Figs. 14(B), 14(C), and 14(D).
  • Independency between the envelope function groups can be obtained by other means, as has been described above. As compared with other means, the arrangement of this embodiment is more advantageous due to the following reason. In this embodiment, a total number of combinations of the global envelope functions of the first and second groups is greatly increased upon selection by the user. In order to obtain the same effect by other means, e.g., a means for producing different global envelope functions from a given one global envelope function, a large number of modification algorithms and large hardware are required.
  • In the arrangement of Fig. 15, envelope-controlled sine wave generators 15-1 to 15-n of the first group and envelope-controlled sine wave generators 15ʹ-1 to 15ʹ-m of the second group are fixedly illustrated. However the user can arbitrarily determine which generators belong to the first or second group. Some generators may be added or omitted easily within the scope of the present invention.
  • In the above embodiment, the envelope-controlled sine wave generators are divided into two groups but may be divided into three or more groups. In an extreme case, a given group may use one sine wave.
  • In the above embodiment, the frequency of the generated sine wave is a fundamental frequency or its harmonic due to the relationship with harmonic data. However, the arrangement is not limited to this. For example, a sine wave having a frequency obtained by detuning the sine wave frequency of the first group may be used as the sine wave of the second group. A technique for generating a sine wave having a detuned frequency is known to those skilled in the art. For example, in phase angle generator 6 in Fig. 2, the repetitive accumulation value of the accumulator is offset by a predetermined number of sent.
  • In the above embodiment, the plurality of envelope-controlled sine wave generators 15-1 to 15-n and 15ʹ-1 to 15ʹ-m are used. However, hardware is not limited if a plurality of sine waves can be functionally generated. A sine wave generator may be arranged in accordance with a time division multiplexing.
  • According to the present invention as described above in detail, a common envelope function is provided for the component wave signals of a plurality of orders. The common envelope function is modified by the envelope modifying means into envelope functions of the respective orders. The envelopes of the component wave signals are controlled in accordance with modified envelope functions. Therefore, the user need not prepare all envelopes for the component wave signals. Much labor can be advantageously reduced to produce musical tones.
  • Furthermore, the global envelope setting means is arranged to give at least one global envelope function. The plurality of component waves to be produced by the component wave generating means are divided into at least the first and second groups. The envelope functions for controlling the component waves of the respective orders belonging to the first group are obtained by modifying the global envelope function by the first envelope modifying means, and the envelope functions for controlling the component waves of the respective orders belonging to the second group are obtained by modifying another global envelope function by the second envelope modifying means. Therefore, the user need set only a limited number of envelopes, thus improving operability for producing musical tones. In addition, since the envelope functions for controlling the component waves of the first group can be independent of the envelope functions for controlling the component waves of the second group, musical tone with high-quality musical tones can be produced.
  • The present invention is exemplified by the particular embodiment described above in detail. However, the present invention is not limited to these embodiments, and various changes and modifications may be made within the scope of the invention.

Claims (4)

  1. A musical tone generating apparatus for synthesizing a musical tone signal by the combination of a plurality of component wave signals, wherein each of said component wave signals forms a component of one order of said synthesized signal and is generated by a respective component generating means (15) which is controlled in accordance with an envelope function, said envelope function being supplied by a common envelope setting means (3),
    characterized in that
    each of said component generating means (15) comprises an envelope modifying means (14, 14A) which modifies said envelope function supplied by said common envelope setting means (3) into a specific envelope function which is adapted to control the envelope of the respective order of the corresponding component wave signal, wherein the value of the specific envelope function changes according to values W and x when the difference between W and x is in a predetermined range and wherein the value of the specific envelope function is a first predetermined constant value when the difference between W and x is smaller than the predetermined range and wherein the value of the specific envelope function is a second constant value when the difference between W and x is larger than the predetermined range, where W is the value of said common envelope function and x is the value of the respective order.
  2. An apparatus according to claim 1, characterized in that said envelope modifying means (14, 14A)
    outputs a value which is amplified in accordance with the difference between W and x as a value of the specific envelope function when the difference between W and x is in a first portion of said predetermined range, and
    outputs a value attenuated in accordance with the difference between W and x as a value of the specific envelope function when the difference between W and x is in a second portion of said predetermined range. (Fig.6A)
  3. An apparatus according to claim 1, characterized in that said envelope modifying means (14, 14A) outputs said specific envelope function with a value that is attenuated in accordance with the difference between W and x in said predetermined range where W is smaller than W. (Fig.8A)
  4. An apparatus according to claim 1, characterized in that said envelope modifying means (14, 14A) outputs said specific envelope function with a value that is attenuated in accordance with the difference between W and x in said predetermined range where W is larger than x. (Fig.10A)
EP19880102806 1987-02-25 1988-02-25 Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals Expired - Lifetime EP0280293B1 (en)

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
JP25501/87U 1987-02-25
JP40455/87 1987-02-25
JP62040455A JP2621862B2 (en) 1987-02-25 1987-02-25 Tone generator
JP1987025501U JP2521652Y2 (en) 1987-02-25 1987-02-25 Musical sound generator

Publications (3)

Publication Number Publication Date
EP0280293A2 EP0280293A2 (en) 1988-08-31
EP0280293A3 EP0280293A3 (en) 1990-06-06
EP0280293B1 true EP0280293B1 (en) 1996-08-14

Family

ID=26363123

Family Applications (1)

Application Number Title Priority Date Filing Date
EP19880102806 Expired - Lifetime EP0280293B1 (en) 1987-02-25 1988-02-25 Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals

Country Status (2)

Country Link
EP (1) EP0280293B1 (en)
DE (1) DE3855465T2 (en)

Family Cites Families (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
FR2344907A1 (en) * 1976-03-16 1977-10-14 Deforeit Christian POLYPHONIC ELECTRONIC MUSICAL INSTRUMENT
US4215617A (en) * 1976-11-22 1980-08-05 The Board Of Trustees Of Leland Stanford Junior University Musical instrument and method for generating musical sound
JPS5858595A (en) * 1981-10-01 1983-04-07 ヤマハ株式会社 Electronic musical instrument

Also Published As

Publication number Publication date
DE3855465T2 (en) 1997-03-27
EP0280293A3 (en) 1990-06-06
EP0280293A2 (en) 1988-08-31
DE3855465D1 (en) 1996-09-19

Similar Documents

Publication Publication Date Title
US4175464A (en) Musical tone generator with time variant overtones
US4829463A (en) Programmed time-changing coefficient digital filter
KR0150223B1 (en) Tone signal generating device
JPS6325359B2 (en)
US4961364A (en) Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals
JPS5858595A (en) Electronic musical instrument
US4267761A (en) Musical tone generator utilizing digital sliding formant filter
US4644839A (en) Method of synthesizing musical tones
US4281574A (en) Signal delay tone synthesizer
US4402243A (en) Synthesizer circuit for electronic musical instrument
US4375777A (en) Electronic musical instrument
EP0280293B1 (en) Musical tone generating apparatus for synthesizing musical tone signal by combining component wave signals
US4215614A (en) Electronic musical instruments of harmonic wave synthesizing type
US5173567A (en) Musical tone generating apparatus with parameter controller for changing characteristics of musical tone signal
US5223656A (en) Musical tone waveform signal forming apparatus with pitch and tone color modulation
US5241129A (en) Electronic musical instrument having physical model tone generator
US4108040A (en) Electronic musical instrument
JPS6120875B2 (en)
US5597970A (en) Waveform processing apparatus and an electronic musical instrument using the output waveform thereof
JPS58100191A (en) Electronic musical instrument
JPH0679224B2 (en) Waveform synthesizer
JP2521652Y2 (en) Musical sound generator
JPH0131638B2 (en)
JPS6049320B2 (en) electronic musical instruments
JP3646854B2 (en) Music synthesizer

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: A2

Designated state(s): DE FR GB IT

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): DE FR GB IT

17P Request for examination filed

Effective date: 19900621

17Q First examination report despatched

Effective date: 19920403

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

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): DE FR GB IT

ITF It: translation for a ep patent filed

Owner name: BUGNION S.P.A.

REF Corresponds to:

Ref document number: 3855465

Country of ref document: DE

Date of ref document: 19960919

ET Fr: translation filed
PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 19970211

Year of fee payment: 10

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: DE

Payment date: 19970228

Year of fee payment: 10

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed
PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: FR

Free format text: THE PATENT HAS BEEN ANNULLED BY A DECISION OF A NATIONAL AUTHORITY

Effective date: 19980228

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 19981103

REG Reference to a national code

Ref country code: FR

Ref legal event code: ST

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20000223

Year of fee payment: 13

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20010225

GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 20010225

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IT

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES;WARNING: LAPSES OF ITALIAN PATENTS WITH EFFECTIVE DATE BEFORE 2007 MAY HAVE OCCURRED AT ANY TIME BEFORE 2007. THE CORRECT EFFECTIVE DATE MAY BE DIFFERENT FROM THE ONE RECORDED.

Effective date: 20050225