The present invention relates generally to apparatus and methods for producing waveforms of musical tones, voices or other sounds on the basis of waveform data supplied from memory or the like, and more particularly to an improved waveform producing apparatus and method capable of producing waveforms that faithfully represent tone color variations effected by a player using various styles of rendition (i.e., performing techniques) or various sorts of articulation unique to a natural musical instrument. It should be appreciated that the basic principles of the present invention can be applied extensively to every type of equipment, apparatus and methods having the function of generating musical tones, voices or any other sounds, such as automatic performance devices, computers, electronic game devices and multimedia-related devices, not to mention electronic musical instruments. Also, let it be assumed that the terms “tone waveform” in this specification are not necessarily limited to a waveform of a musical tone alone and are used in a much broader sense that may embrace a waveform of a voice or any other type of sound.
The so-called “waveform memory readout” technique has already been well known, which prestores waveform data (i.e., waveform sample data) coded in a given coding scheme, such as the PCM (Pulse Code Modulation), DPCM (Differential Pulse Code Modulation) or ADPCM (Adaptive Differential Pulse Code Modulation), and then reads out the thus-prestored waveform data at a rate corresponding to a desired tone pitch to thereby produce a tone waveform. So far, various types of “waveform memory readout” technique have been proposed and known in the art, most of which are directed to producing a waveform covering from the start to end of a tone. As one specific example of the waveform memory readout technique, there has been known a scheme of prestoring waveform data of a complete waveform of a tone covering from the start to end thereof. As another example of the waveform memory readout technique, there has been known a scheme of prestoring waveform data of a complete waveform only for a particular portion, such as an attach portion, of a tone presenting relatively complex variations and prestoring a predetermined loop waveform for a sustain portion and the like presenting less variations. In this patent specification, the terms “loop waveform” are used to refer to a waveform to be read out repeatedly, i.e., in a looped fashion.
With the conventional waveform memory readout scheme of prestoring waveform data of a complete waveform of a tone covering from the start to end thereof or prestoring waveform data of a complete waveform only for a particular portion, such as an attach portion, of a tone, however, it has been necessary to prestore a great number of various waveform data corresponding to a variety of styles of rendition (or various sorts of articulation), which would undesirably require a large storage capacity.
Further, although the above-mentioned scheme of prestoring waveform data of a complete waveform of a tone can faithfully express tone color variations effected using various styles of rendition (or various sorts of articulation) unique to a natural musical instrument, it can only reproduce the tone in just the same way as the prestored waveform data and thus would afford very poor controllability and editability. For instance, with this waveform memory readout scheme, it has been extremely difficult to control time-axial and other characteristics of the waveform data, corresponding to a desired style of rendition (or sort of articulation), in accordance with performance data.
It is therefore an object of the present invention to provide a waveform producing technique which can produce high-quality waveform data corresponding to a variety of styles of rendition (or various sorts of articulation) in a simplified manner with greatly increased facility and controllability. Particularly, the present invention seeks to provide a method and apparatus for waveform recording, reproduction or production which can effectively save a storage capacity necessary for storing waveform data and achieve precise waveform reproducibility with enhanced controllability by storing, rather than complete or full waveform data corresponding to a desired high-quality waveform (i.e., waveform representing a desired style of rendition or articulation), only partial waveform data selectively extracted from the complete waveform data in such a way as to be still able to express a characteristic waveform shape variation and then producing a waveform using the thus-stored partial waveform data.
In order to accomplish the above-mentioned object, the present invention provides a waveform recording method which comprises the steps of: supplying waveform data; extracting, from the supplied waveform data, partial waveform data representative of a waveform shape variation; and storing, into a memory, the extracted partial waveform data along with information indicative of their respective time positions. By thus extracting and storing only partial waveform data representative of a waveform shape variation, waveform data necessary for expressing the waveform shape variation can be stored in compressed form, which can effectively save a waveform data storage capacity or minimize the quantity of waveform data to be stored. Further, by storing the extracted partial waveform data along with the information indicative of their respective time positions, the present invention achieves precise waveform reproducibility.
The present invention also provides a method of reproducing a waveform using data stored in a memory, the memory storing, in pairs, partial waveform data representative of a waveform shape variation and information indicative of time positions thereof, which method comprises the steps of: giving a waveform reproduction instruction; reading out, from the memory, the partial waveform data representative of a waveform shape variation along with the information indicative of time positions thereof, in response to the waveform reproduction instruction; arranging the partial waveform data on a time axis in accordance with the information indicative of time positions read out from the memory; and synthesizing, on the basis of the partial waveform data arranged on the time axis, complete waveform data including waveform data to be interposed between adjoining ones of the partial waveform data. Because the partial waveform data representative of a waveform shape variation are arranged at appropriate time positions in accordance with the time position information read out in association therewith, they can be reproduced at appropriate time positions in relation to important segments of a tone waveform, i.e. waveform segments representative of the waveform shape variation, thereby achieving precise waveform reproducibility.
The present invention also provides a waveform producing method which comprises the steps of: sequentially receiving a plurality of sets of sample identification information and time position information; obtaining sample data by referring to a database in accordance with the received sample identification information; and arranging, on a time axis, the obtained sample data in accordance with the received time position information, so that a waveform is produced on the basis of the sample data arranged on the time axis. In this case, what are paired with the time position information are not sample data themselves but sample identification (ID) information (i.e., data designating the sample data). The sample data are obtained from the database on the basis of the sample identification information, and then arranged at appropriate time positions in accordance with the time position information. Thus, in this case too, it is possible to effectively save the waveform data storage capacity and achieve precise waveform reproducibility.
The above-mentioned sample data are sample data pertaining to any of waveform factors including a waveform shape, amplitude, pitch and time axial control. In preferred embodiments to be described later, such sample data pertaining to any of the waveform factors are also referred to as vector data; that is, “vectors” correspond to various fundamental waveform factors for producing a waveform. Examples of the fundamental waveform factors include a waveform shape (that determines a tone color or timbre), pitch variation over time and amplitude variation over time, and the vector data of these waveform factors are called a waveform shape vector, pitch vector and amplitude vector, respectively. Time vector for performing stretch/compression control on a time-axial progression of the waveform may also be used. The respective time axes of the waveform shape vector, pitch vector, amplitude vector, etc. can be controlled in accordance with the time vector.
The waveform producing method of the invention may further comprise a step of receiving adjustment information and the sample data to be used for producing a waveform may be modified or adjusted in accordance with the received adjustment information. Thus, in a situation where sample data just as designated by the sample identification information is not previously provided (prestored), the desired sample data can be acquired by first obtaining, from the database, sample data approximate to the one designated by the sample identification information and then adjusting the approximate sample data in accordance with the received adjustment information. This arrangement can significantly simplify the construction for prestoring the sample data and hence save the storage capacity. Further, even where sample data just as designated by the sample identification information is prestored, the sample data can be modified freely by the adjustment information, thereby assuming enhanced controllability.
The present invention also provides a waveform producing method which comprises the steps of: receiving performance data; obtaining sets of sample identification information and time position information by referring to a predetermined table on the basis of the received performance data; adjusting the obtained time position information in accordance with the performance data; obtaining sample data by referring to a database on the basis of the received sample identification information; arranging, on a time axis, the obtained data in accordance with the adjusted time position information; producing a waveform on the basis of the sample data arranged on the time axis. In this case, sets of sample identification information and time position information are obtained from the table on the basis of the received performance data. There may be a situation where a set of sample identification information and time position information, optimum to a performance tone intended by the performance data, is not among a number of previously provided (e.g., prestored) sets of sample identification information and time position information. However, even in such a situation, the present invention can obtain the time position information just as intended by the performance data, by first selecting one of the prestored sets of sample identification information and time position information which is approximate to the one intended by the performance data and then adjusting the thus-obtained time position information in accordance with the performance data. If the performance data contains a variable control factor such as touch or velocity, then the obtained time position information can be variably controlled in accordance with the performance data. This arrangement can significantly simplify the construction for previously providing (prestoring) the time position information and hence save the storage capacity. Further, because the time position of the sample data characterizing the waveform can be variably controlled, the present invention achieves enhanced controllability.
In the later-described embodiments, the performance data are supplied in a form containing style-of-rendition identification (ID) information. For example, the style-of-rendition identification (ID) information may be supplied, according to the characteristics of styles of rendition of the performance tone, in correspondence with a partial tone segment such as an attack, body or release portion, or in correspondence with a link or joint segment between adjoining tones such as a slur, or in correspondence with a specially performed tone segment such as a vibrato, or in correspondence with a plurality of notes constituting a phrase. Namely, given style-of-rendition identification (ID) information is supplied in accordance with a performance to be reproduced.
The present invention may be constructed and implemented not only as the method invention as discussed above but also as an apparatus invention. Also, the present invention may be arranged and implemented as a software program for execution by a processor such as a computer or DSP, as well as a storage medium storing such a program. Furthermore, the processor used in the present invention may comprise a dedicated processor based on predetermined fixed hardware circuitry, rather than a general-purpose type processor capable of running software.
For better understanding of the object and other features of the present invention, its preferred embodiments will be described in greater detail hereinbelow with reference to the accompanying drawings, in which:
In
The ROM 102 stores therein various programs and data to be executed or referred to by the CPU 101. The RAM 103 is used as a working memory for temporarily storing various performance-related information and various data generated as the CPU 101 executes the programs, or as a memory for storing a currently-executed program and data related to the program. Predetermined address regions of the RAM 103 are allocated to various functions and used as various registers, flags, tables, memories, etc. The switch panel 104 includes various operators for instructing tone sampling, editing the sampled waveform data, entering various pieces of information, etc. The switch panel 104 may be, for example, in the form of a ten-button keypad for inputting numerical value data, keyboard for inputting character data or panel switches. The switch panel 104 may also include other operators for selecting, setting and controlling a pitch, color, effect, etc. of each tone to be generated. The panel display unit 105 displays various information inputted by the switch panel, the sampled waveform data, etc. and comprises, for example, a liquid crystal display (LCD), CRT (Cathode Ray Tube) and/or the like.
The waveform input section 107 contains an A/D converter for converting an analog tone signal, introduced via an external waveform input device such as a microphone, into digital data (waveform data sampling), and inputs the thus-sampled digital waveform data into the RAM 103 or hard disk 109 as original waveform data from which to produce desired waveform data. In the “waveform database creation” process carried out by the CPU 101, a waveform database of the present invention is created on the basis of the above-mentioned original waveform data. Also, in the “database-based tone synthesis” process carried out by the CPU 101, waveform data of each tone signal corresponding to performance information are produced using the above-mentioned waveform database. Of course, in the instant embodiment, a plurality of tone signals can be generated simultaneously. The thus-produced waveform data of each tone signal are given via the bus BL to the waveform output section 108 and then stored into a buffer thereof as necessary. The waveform output section 108 reads out the buffered waveform data at a predetermined output sampling frequency and then sends the waveform data to a sound system 108A after D/A-converting the data. In this way, each tone signal output from the waveform output section 108 is sounded or audibly reproduced via the sound system 108A. Here, the hard disk 109 is provided for storing data (various data of a later-described style-of-rendition table, code book, etc.) for synthesizing a desired waveform corresponding to waveform data and style of rendition, a plurality of sorts of performance-related data such as tone color data composed of various tone color parameters, and control-related data such as those of various programs to be executed by the CPU 101. The drive 106 functions to drive a removable disk (external storage medium 106A) for storing data (various data of the later-described style-of-rendition table, code book, etc.) for synthesizing a desired waveform corresponding to waveform data and style of rendition, a plurality of sorts of performance-related data such as tone color data composed of various tone color parameters and control-related data such as those of various programs to be executed by the CPU 101. The external storage medium 106A to be driven by the drive 106 may be any one of various known removable-type media, such as a floppy disk (FD), compact disk (CD-ROM or CD-RAM), magneto-optical (MO) disk or digital versatile disk (DVD). Stored contents (control program) of the external storage medium 106A set in the drive 106 may be loaded directly into the RAM 103, without being first loaded into the hard disk 109. The approach of supplying a desired program via the external storage medium 106A or via a communication network is very advantageous in that it can greatly facilitate version upgrade of the control program, addition of a new control program, etc.
Further, the communication interface 111 is connected to a communication network, such as a LAN (Local Area Network), the Internet or telephone lines, via which it may be connected to a desired sever computer or the like (not shown) so as to input a control program and various data or performance information to the waveform producing apparatus. Namely, in a situation where the control program and various data are not contained in the ROM 102 or hard disk 109 of the waveform producing apparatus, these control program and data can be downloaded from the server computer via the communication interface 111 to the apparatus. In such a case, the waveform producing apparatus of the invention, which is a “client”, sends a command to request the server computer to download the control program and various data by way of the communication interface 111 and communication network. In response to the command from the client, the server computer delivers the requested control program and data to the waveform producing apparatus via the communication network. The waveform producing apparatus receives the control program and data from the server computer via the communication network and communication interface 111 and accumulatively stores them into the hard disk 109. In this way, the necessary downloading of the control program and various data is completed. It should be obvious that the waveform producing apparatus may further includes a MIDI interface so as to receive MIDI performance information. It should also be obvious that a music-performing keyboard and music operating equipment may be connected to the bus BL so that performance information can be supplied to the waveform producing apparatus by an actual real-time performance. Of course, the external storage medium containing performance information of a desired music piece may be used to supply the performance information of the desired music piece.
First, at step S1, a database storage medium, such as the hard disk 109, is provided for storing data of the later-described style-of-rendition table and code book. Then, at step S2, waveform data are acquired which correspond to tones performed on various natural musical instruments with various styles of rendition. Namely, at this step S2, various performance tones actually produced on various natural musical instruments are acquired via an external waveform input device, such as a microphone, through the waveform input section 107, and waveform data of these performance tones (i.e., original waveform data) are stored into predetermined areas of the hard disk 109. At this time, the waveform data of either the entire performance or only part of the performance, such as a particular phrase, one particular tone or characteristic portions like attack and release portions of a particular tone, may be acquired and stored. At following step S3, the thus-acquired waveform data of each of the performance tones corresponding to the various performance styles unique to the natural musical instruments are segmented every characteristic portion, then subjected to a tuning operation and then given file names. Namely, the acquired original waveform data of each of the performance tones are segmented into partial waveforms (waveform segmentation), each representing a characteristic waveform shape variation, such as an attack-portion waveform, body-portion waveform, release-portion waveform and joint-portion waveform, the tuning operation is performed to determine the respective pitches of the individual segmented waveform data or partial waveforms covering one or two or more cycles of the tone in question, and then unique file names are imparted to the segmented waveform data. Note that in the case where only the waveform data of part of the performance, such as attack and release portions, are acquired, the above-mentioned waveform segmentation can be dispensed with.
Then, at step S4, the waveform data having been processed at step S3 are divided into waveform components through frequency analysis. Namely, each of the segmented partial waveforms is subjected to Fast Fourier Transform (FFT) for division into a plurality of waveform components (in the instant embodiment, harmonic and nonharmonic components). In addition, characteristics of various waveform factors, such as a waveform shape, pitch and amplitude, are extracted from each of the waveform components (harmonic and nonharmonic components); however, in the case where the each of the segmented partial waveforms is divided into the harmonic and nonharmonic components, the pitch extraction from the nonharmonic component may be omitted because the nonharmonic component has no pitch. For example, the “waveform shape” (timbre) factor represents extracted characteristics of a waveform shape normalized in pitch and amplitude, the “pitch” factor represents extracted characteristics of a pitch variation from a predetermined reference pitch, and the “amplitude” factor represents extracted characteristics of an amplitude envelope.
At next step S5, vector data are created. Namely, for each of the waveform shape (timbre), pitch and amplitude factors of the divided waveform components (e.g., harmonic and nonharmonic components), a plurality of sample values of succussive sample points are extracted dispersedly or, if necessary, successively, and each extracted sample value group of succussive sample points thus obtained is given a different or unique vector ID (identification information) and stored into the code book along with data indicative of a time position thereof. Hereinafter, such sample data are referred to as “vector data”. The instant embodiment creates vector data of the waveform shape (timbre) factor, pitch factor and amplitude factor of each of the harmonic components, and vector data of the waveform shape (timbre) factor and amplitude factor of each of the nonharmonic components. The vector data of each of the waveform factors is data variable in accordance with the passage of time along the time axis. Then, as will be later described later, data of style-of-rendition modules are created to store the style-of-rendition modules into the style-of-rendition table. The thus-created style-of-rendition modules and vector data are written into the style-of-rendition table and code book in the database for data accumulation into the database, at step S6. As noted above, the vector data differ from the original waveform data as initially introduced into the waveform producing apparatus of the invention; these are the data obtained by dividing the introduced original waveform for each of the waveform factors. Each of the vector data is data that ultimately becomes a minimum constituent unit of a style-of-rendition module. Thus, in the code book, the extracted partial waveform data representing respective variations in the waveform shape are stored in compressed form. In the style-of-rendition table, on the other hand, data of various style-of-rendition modules are stored, such as various data necessary for converting the vector data, stored in compressed form, back to the waveform data of the original waveform shape and ID data for designating a desired one of the vector data stored in the code book, as will be later described in detail.
During the extraction of the characteristics of the various waveform factors at step S4, characteristics of a time factor are also extracted in addition to those of the above-mentioned amplitude, pitch and waveform shape factors. Hereinafter, thus-extracted vector data of the time factor will be referred to as “time vector data”. The time length of part of the original waveform data, corresponding to the time section of the extracted partial waveform data, is used directly as the time factor. Thus, if the original time length (variable value) of the time section in question is represented by a ratio “1”, then there is no need to analyze and measure the time length in this waveform database creation process. Because, in this case, the data of the time factor, i.e. time vector data, has the same value “1” in each of the time sections, the time length need not necessarily be stored in the code book. However, the present invention is, of course, not so limited and may be modified to analyze and measure the actual time length and store the thus-measured time length into the code book as the time vector data.
Then, at step S7 of
It should be appreciated here that the above-described waveform database creation process may be arranged to add/delete any desired style-of-rendition module or edit the data of a desired style-of-rendition module.
Now, the following paragraphs describe the style-of-rendition module data in greater detail.
Each of the style-of-rendition modules is stored in the style-of-rendition table arranged as a database in the hard disk 109 and can be designated by a combination of “style-of-rendition ID” and “style-of-rendition parameters”. The style-of-rendition ID contains musical instrument type information and module part name and can be defined, for example, as follows. Assuming that each style-of-rendition ID consists of 32 bits (0th-31st bits), six bits of the 32 bits are use for the musical instrument type information. In the instant embodiment, for example, if the six-bit train constituting the musical instrument type information is “000000”, it is indicative of “AltoSax” (an alto saxhorn), and if the six-bit train constituting the musical instrument type information is “001000”, it is indicative of “Violin” (a violin); note that the upper three bits of the six-bit train may be used to represent a major class of the musical instrument while the lower three bits may be used to represent a minor class of the musical instrument. Further, other six bits of the 32 bits are used for the module part name. If the six-bit train constituting the module part name is “000000”, it is indicative of a module part name “NormalAttack”, if the six-bit train is “000001”, it is indicative of “BendAttack”, if the six-bit train is “000010”, it is indicative of “GraceNoteAttack”, if the six-bit train is “001000”, it is indicative of “NormalShortBody”, if the six-bit train is “001001”, it is indicative of “VibBody”, if the six-bit train is “001010”, it is indicative of “NormalLongBody”, if the six-bit train is “010000”, it is indicative of “NormalRelease”, if the six-bit train is “011000”, it is indicative of “NormalJoint” and if the six-bit train is “011001”, it is indicative of “GraceNoteJoint”. Of course, the present invention is not limited to the above-noted arrangements.
As stated above, each individual style-of-rendition module is specified by a combination of the “style-of-rendition ID” and “style-of-rendition parameters”; that is, a predetermined style-of-rendition module can be specified in accordance with the style-of-rendition ID and its contents can be variably controlled in accordance with the style-of-rendition parameters. The style-of-rendition parameters are parameters for characterizing or controlling the waveform data corresponding to the style-of-rendition module, and predetermined sorts of style-of-rendition parameters are provided for each style-of-rendition module. For example, for the “AltoSax[NormalAttack]” module, there may be provided style-of-rendition parameters pertaining to an absolute tone pitch and tone volume immediately following the attack, etc. For the “AltoSax[BendUpAttack]” module, there may be provided style-of-rendition parameters pertaining to an absolute tone pitch at the end of the bendup attack, initial value of a bend depth at the time of the bendup attack, time length from the start (note-on timing) to end of the bendup attack, tone volume immediately following the attack, timewise stretch/contraction of a default curve during the bendup attack, etc. For the “AltoSax[NormalShortBody]” module, there may be provided style-of-rendition parameters pertaining to an absolute tone pitch of the style-of-rendition module, end and start times of the normal short body, dynamics at the start and end of the normal short body, etc. Note that the style-of-rendition module does not necessarily include data (later-described waveform factor data) corresponding to all the values which the style-of-rendition parameters can take; the style-of-rendition module may include data corresponding to only some discrete (non-successive) values of the style-of-rendition parameters. That is, for the “AltoSax[NormalAttack]” module, for example, there may be stored data corresponding to only some, not all, of the values representative of the absolute tone pitch and tone volume immediately following the attack.
By thus allowing each style-of-rendition module to be specified by a combination of the style-of-rendition ID and style-of-rendition parameters, it is possible to designate data corresponding to a desired set of style-of-rendition parameters from among a plurality of data (waveform factor data) indicative of the normal attack portion of an alto saxophone tone, for example, in the case of the “AltoSax[NormalAttack]” module. In the case of the “Violin[BendAttack]” module, it is possible to designate data corresponding to a desired set of style-of-rendition parameters from among a plurality of data (waveform factor data) indicative of the bend attack portion of a violin tone.
In the style-of-rendition table, there are stored, for each individual style-of-rendition module, data necessary for producing a waveform corresponding to the style-of-rendition module, such as vector IDs designating the vector data of the individual waveform factors (e.g., the waveform shape factor, pitch factor (pitch envelope) and amplitude factor (amplitude envelope)), train of values at representative points (i.e., data indicative of representative sample points to be modified in a train of a plurality of samples), and respective starting and ending time positions of the vector data of the individual waveform factors (e.g., the waveform shape factor, pitch factor (pitch envelope) and amplitude factor (amplitude envelope)). Namely, in the style-of-rendition table, there are stored various data necessary for reproducing a waveform of a normal shape from a waveform stored in the database in the form of compressed vector data; hereinafter, such data will also be called “waveform factor data”. The following explain details of one of the data groups stored in the style-of-rendition table in association with various style-of-rendition modules, and more particularly is explanatory of the data group stored for the AloSax[NormalAttack] module:
Data 1: Sampled length of the style-of-rendition module;
Data 2: Position of note-on timing;
Data 3: Vector ID of the amplitude factor of the harmonic component and train of the representative point values;
Data 4: Vector ID of the pitch factor of the harmonic component and train of the representative point values;
Data 5: Vector ID of the waveform shape (timbre) factor of the harmonic component;
Data 6: Vector ID of the amplitude factor of the nonharmonic component and train of the representative point values;
Data 7: Vector ID of the waveform shape (timbre) factor of the nonharmonic component;
Data 8: Start position of a waveform block of the waveform shape (timbre) factor of the harmonic component;
Data 9: End position of a waveform block of the waveform shape (timbre) factor of the harmonic component (i.e., start position of a loop portion of the waveform shape (timbre) factor of the harmonic component);
Data 10: Start position of a waveform block of the waveform shape (timbre) factor of the nonharmonic component;
Data 11: End position of a waveform block of the waveform shape (timbre) factor of the nonharmonic component; (i.e., start position of a loop portion of the waveform shape (timbre) factor of the nonharmonic component); and
Data 12: End position of a loop portion of the waveform shape (timbre) factor of the nonharmonic component.
Data 1-Data 12 mentioned above will be described below in greater detail with reference to FIG. 3.
More specifically, numerical value 1 represents the sampled length of the waveform section (length of the waveform section) corresponding to the style-of-rendition module, which corresponds, for example, to the total time length of the original waveform data from which the style-of-rendition module is derived. Numerical value 2 represents the position of the note-on timing, which can be variably set at any time position of the style-of-rendition module. Although, in principle, sounding of the performance tone based on the waveform is initiated at the position of the note-on timing, the rise start point of the waveform component may precede the note-on timing in the case of a particular style of rendition such as a bend attack. Numerical value 3 represents the vector ID designating the vector data of the amplitude factor of the harmonic component and train of the representative point values stored in the code book; in the figure, two square marks filled in with black indicate these representative points. Numerical value 4 represents the vector ID designating the vector data of the pitch factor of the harmonic component and train of the representative point values. Numerical value 6 represents the vector ID designating the vector data of the amplitude factor of the nonharmonic component and train of the representative point values. The representative point values are data to be used for changing/controlling the vector data, made up of a train of a plurality of samples, designated by the vector ID, and designates some of the representative sample points. As the respective time positions (plotted on the horizontal axis of the figure) and levels (plotted on the vertical axis of the figure) of the designated representative sample points are changed or controlled, the other sample points are also changed so that the overall shape of the vector can be changed. For example, the representative point values represent discrete samples fewer than the total number of the samples; however, the representative point values may be values at intermediate points between the samples or values at a plurality of successive samples over a predetermined range. Alternatively, the representative point values may be such values indicative of differences between the sample values, multipliers to be applied to the sample values or the like, rather than the sample values themselves. The shape of each vector data, i.e. shape of the envelope waveform, can be changed by moving the representative points along the horizontal axis (time axis) and/or vertical axis (level axis). Numerical value 5 represents the vector ID designating the vector data of the waveform shape (timbre) factor of the harmonic component.
Further, in
Whereas the preceding paragraphs have described the case where each of the style-of-rendition modules includes all of the fundamental waveform factors (waveform shape, pitch and amplitude factors) of the harmonic component and the fundamental waveform factors (waveform shape and amplitude factors) of the nonharmonic component, the present invention is not so limited, and each or some of the style-of-rendition modules may, of course, include only one of the waveform factors (waveform shape, pitch and amplitude) of the harmonic component and the waveform factors (waveform shape and amplitude) of the nonharmonic component. For example, each or some of the style-of-rendition modules may include a selected one or more of the waveform shape, pitch and amplitude factors of the harmonic component and waveform shape and amplitude factors of the nonharmonic component. In this way, the style-of-rendition modules can be used freely in any desired combination depending on the waveform factor desired, which is very preferable.
With the above-described arrangement that only waveform data of partial waveforms necessary for waveform shape variations (such as partial waveforms of attack, body, release, joint portions), rather than all waveform data, of tones performed on various natural musical instruments with various performance styles are extracted and stored into the hard disk 109 in a form compressed with the data compression scheme using a hierarchy of the waveform components, waveform factors and representative points, the instant embodiment can effectively reduce a necessary storage capacity of the hard disk 109 for storing the waveform data.
In the waveform producing apparatus shown in
Music-piece-data reproduction section 101A of
Further, in
It should be appreciated here that the music piece data (performance information) may be constructed to include, in advance, data indicative of interpreted results of the musical score. Of course, if such music piece data including the data indicative of interpreted results have been input to the apparatus, the above-described musical score interpretation process need not be performed. Further, the musical score interpretation process may be performed by the interpretation section 101B in a fully automatic fashion or with intervention of some user's manual input operations as appropriate.
By referring to the style-of-rendition table on the basis of the converted style-of-rendition designating information (style-of-rendition IDs and parameters) from the interpretation section 101B, the style-of-rendition synthesis section (articulator) 101C creates a packet stream (also called a vector stream) corresponding to the style-of-rendition designating information and vector parameters for the packet stream corresponding to the style-of-rendition parameters, and supplies the thus-created packet stream and vector parameters to a waveform synthesis section 101D (step S13). The data supplied as the packet stream to the waveform synthesis section 101D include time information, vector IDs, representative point values, etc. of the packets in the case of the pitch and amplitude factors, and vector IDs, time information, etc. in the case of the waveform shape (timbre) factor, as will be later described in detail.
Then, the waveform synthesis section 101D retrieves the vector data from the code book in accordance with the supplied packet stream, changes or modifies the retrieved vector data in accordance with the vector parameters, and synthesizes a waveform on the basis of the thus-changed vector data (step S14). After that, the waveform synthesis section 101D carries out a waveform production process for another performance part (step S15). Here, the “other performance part” means any one of a plurality of performance parts which is not subjected to the style-of-rendition synthesis process but is subjected to a normal tone waveform synthesis process. For the other performance part, the tone generation is performed using the conventional waveform-memory-based tone generator scheme. The waveform production process for the other performance part may be performed by a dedicated hardware tone generator, such as an external tone generator unit or tone generator card detachably attachable to a computer. For simplicity of description, however, it is assumed here that the instant embodiment performs the tone generation corresponding to styles of rendition or articulation only for one performance part, although the style-of-rendition reproduction may of course be performed for a plurality of performance parts.
The style-of-rendition synthesis section 101C creates various packet streams to be supplied to the waveform synthesis section 101D, on the basis of the style-of-rendition designating information (including the style-of-rendition IDs and style-of-rendition parameters) and time information given from the musical score interpretation section 101B. The style-of-rendition modules employed in the style-of-rendition synthesis section 101C for the individual tone colors are not necessarily fixed; rather, the user can add any new style-of-rendition module to the currently-stored modules and stop using any of the currently-stored modules. Also, the style-of-rendition synthesis section 101C performs a process for creating information to compensate for a difference or discrepancy between selected waveform factor data and values of the style-of-rendition parameters, as well as a process for smoothing a connection between waveform characteristics of successive style-of-rendition modules, as will be later described in detail.
Whereas, in principle, the data are given from the musical score interpretation section 101B to the style-of-rendition synthesis section 101C, the present invention is not so limited. Namely, there may be prepared music piece data with style-of-rendition designating data already interpreted by the interpretation section 101B as noted earlier, or music piece data with style-of-rendition designating data having style-of-rendition IDs and style-of-rendition parameters imparted thereto as a result of musical score interpretation by a human operator. Then, the data obtained by reproducing the thus-prepared music piece data may be supplied to the style-of-rendition synthesis section 101C.
The style-of-rendition synthesis section 101C selects one of the style-of-rendition modules stored in the style-of-rendition table in accordance with the style-of-rendition ID and style-of-rendition parameters, at step S21; that is, one of the style-of-rendition modules is selected in accordance with the style-of-rendition ID (musical instrument type information plus module part name) and style-of-rendition parameters sent from the musical score interpretation section 101B. At this time, the musical score interpretation section 101B, before proceeding to the interpretation of the musical score, checks the database to see what sorts of module parts are currently stored in the style-of-rendition table in correspondence with the tone color represented by the musical instrument type information and designates the style-of-rendition ID within the bounds of the currently-stored module parts. In case a module part not currently stored in the style-of-rendition table has been designated, then another module part having similar characteristics to the designated module part may be selected from the style-of-rendition table. After that, a plurality of waveform factor data are selected in accordance with the designated style-of-rendition ID and style-of-rendition parameters at step S22. Namely, a particular style-of-rendition module is specified by referring to the style-of-rendition table on the basis of the designated style-of-rendition ID and style-of-rendition parameters, and a plurality of waveform factor data corresponding to the style-of-rendition parameters are selected from the style-of-rendition module. In the event that the style-of-rendition module does not include waveform factor data fully matching the style-of-rendition parameters, other waveform factor data sufficiently close to the values of the style-of-rendition parameters are selected.
Then, at step S23, time values of selected positions in the waveform factor data are calculated in accordance with the time information; that is, the individual waveform factor data are arranged at their respective absolute time positions on the basis of the time information. More specifically, corresponding absolute times of the individual waveform factor data presenting respective relative time positions are calculated on the basis of the time information. This way, respective timing of the waveform factor data is determined (see FIG. 3). Then, at step S24, values of the individual waveform factor data are adjusted in accordance with the style-of-rendition parameters; that is, differences between the selected waveform factor data and the values of the style-of-rendition parameters are compensated for at this step. For example, if the tone volume (style-of-rendition parameter) immediately following the attack portion of the AltoSax[NormalAttack] module, received from the musical score interpretation section 101B, is at a level “95” while the tone volume immediately following the attack portion of the AltoSax[NormalAttack] module stored in the style-of-rendition is at a level “100”, then the style-of-rendition synthesis section 101C selects the waveform factor data of the latter AltoSax[NormalAttack] module whose tone volume level immediately following the attack portion is “100”. However, because the tone volume level immediately following the attack portion is still “100”, adjustments are made to the representative points of the selected waveform factor data so as to modify the tone volume level immediately following the attack portion to “95”. This way, the values of the selected waveform factor data are adjusted to approach the values of the received style-of-rendition parameters. Further, at this step, there is made an adjustment according to a currently-set microtuning value for tuning of the musical instrument, as well as a tone volume adjustment according to tone volume variation characteristics of the musical instrument. These adjustments are performed by changing, sometimes greatly, the representative point values of the individual waveform factor data. Namely, the representative point values are necessary and sufficient data for the adjustments, and various adjustments are made by controlling the representative point values in the waveform factor data.
Note that at step S23 above, the time positions indicated by the time information may be adjusted by adjustment information such as the above-mentioned style-of-rendition parameters. For example, in a situation where a time position based on the performance data and a time position indicated by the time information do not coincide with each other, other time information indicative of another time position close to the time position based on the performance data may be selected and the time position indicated by the thus-selected time information may be adjusted in accordance with the performance data so that the time position information intended by the performance data can be obtained. Further, in a situation where the performance data includes variable control factors such as a touch and velocity, time position information based on the performance data can be variably controlled by changing the time position information in accordance with the variable control factors. The above-mentioned adjustment information include information for effecting such a time position adjustment.
Further, at next step S25, a waveform linking process is performed for smoothing respective connecting portions of adjoining style-of-rendition modules by adjusting the individual waveform factor data. Namely, the representative points of the respective connecting portions of the adjoining style-of-rendition modules are brought closer and linked with each other, so as to smooth the waveform characteristics of the adjoining style-of-rendition modules. Such a connection or waveform linking process is carried out for each of the waveform factors, such as the waveform shape (timbre), amplitude and pitch of the harmonic component, or for each of the waveform factors, such as the waveform (Timbre) and amplitude of the nonharmonic component.
At that time, adjustments are made over a range from a link starting point of the preceding style-of-rendition module to a linking end point of the succeeding style-of-rendition module. More specifically, the representative points within the range from the link starting point to the linking end point are adjusted on the basis of a “mutual approaching rate”. Here, the “mutual approaching rate” is a parameter for performing control to determine a point displaced from each of the preceding and succeeding style-of-rendition modules toward the other where the adjoining style-of-rendition modules are to be interlinked, and this parameter is set in accordance with a combination of the adjoining style-of-rendition modules. In case the adjoining style-of-rendition modules have not been interlinked successfully, the connection is smoothed by thinning out the vector IDs of the waveform characteristics of one of the adjoining style-of-rendition modules. For the thinning-out of the vector IDs, there are provided, in the instant embodiment, a “style-of-rendition module combination table”, “thinning-out parameter range table” to be referred to from the style-of-rendition module combination table, and a “thinning-out time table” to be referred to from the thinning-out parameter range table.
The waveform characteristics can also be interlinked smoothly through a waveform linking process performed by the musical score interpretation section 101B as follows, in place of or in addition to the above-described waveform linking process performed by the style-of-rendition synthesis section 101C. For example, discrete regions of the style-of-rendition parameters (values of the dynamics, pitch parameter, etc.) are linked together smoothly without regard to the style-of-rendition modules. In shifting from a vibrato to a release portion, for example, the waveform characteristics may be linked smoothly by decreasing the vibrato effect earlier.
Now, the above-described waveform linking process, i.e. adjustments of the individual waveform factor data for smoothing respective connecting portions of adjoining style-of-rendition modules (see step S25), will be described in more details. First, with reference to
When there is produced a great value difference at a waveform-interconnecting point between the adjoining style-of-rendition modules due to discreteness between the representative point values in the respective connecting portions of the two style-of-rendition modules, a “mutual approaching rate” is first determined as an index indicating to which one of the values of the preceding and succeeding style-of-rendition modules the target value of the dynamics connecting point or pitch connecting point should be brought closer. Let it be assumed here that in the instant embodiment, such a mutual approaching rate is given by a table as illustrated in FIG. 7. For example, if the vector ID of the preceding style-of-rendition module is “3” and the vector ID of the succeeding style-of-rendition module is “7”, then a mutual approaching rate of “30” is determined via the table. Then, the envelope shapes of the style-of-rendition modules are modified progressively from the link starting point of the preceding style-of-rendition module up to the linking end point of the succeeding style-of-rendition module, so as to approach the respective target values. Also, the envelope shapes of the style-of-rendition modules are modified progressively in the reverse direction, i.e. from the linking end point of the succeeding style-of-rendition module to the link starting point of the preceding style-of-rendition module. More specifically, if the mutual approaching rate has been set as “30”, then the target value for the preceding style-of-rendition module is “30” so that the preceding style-of-rendition module is adjusted to be closer to the succeeding style-of-rendition module by 30%; in the instant embodiment, the last one of the representative points in the preceding style-of-rendition module is brought downward by 30%. At the same time, the succeeding style-of-rendition module is adjusted to be closer to the preceding style-of-rendition module by 70 (i.e., 100-30)%; in the instant embodiment, the leading one of the representative points in the succeeding style-of-rendition module is brought upward by 70%. Also, in accordance with the above-mentioned adjustments of the leading and last representative points, a plurality of other representative points of the adjoining style-of-rendition modules intervening between the link starting and ending points are adjusted upward and downward to approach the respective target values. As set out above, the mutual approaching is effected at a plurality of representative points of the preceding and succeeding style-of-rendition modules. Note that although the above-mentioned link starting and ending points may be set as desired, it is desirable to set these link starting and ending points to coincide exactly with desired ones of the representative points in that undesirable bends of the envelope shape occurring at the link starting and ending points as illustrated in the figure can be avoided. It should also be obvious that even where the link starting and ending points are not set to coincide with the desired representative points, the mutual approaching may be performed in such a manner as to avoid the undesirable bends of the envelope shape.
It should also be appreciated that the mutual approaching rate may be determined in any other manner than the above-mentioned. For example, the mutual approaching rate may be determined on the basis of the style-of-rendition parameters designated before and after the waveform-interconnecting point, or performance data before being converted into the style-of-rendition ID and parameters, or a combination of these data. Further, whereas the instant embodiment has been described above in relation to the case where only one representative point is adjusted in accordance with the mutual approaching rate and other representative points are adjusted by appropriate amounts in response to the adjustment of the one representative point, the embodiment may be modified such that a separate mutual approaching rate is determined for each of the plurality of representative points so that each of the representative points is adjusted by an amount as specified by the separate approaching rate.
Next, a description is made about the waveform linking process in relation to a case where the style-of-rendition modules each corresponds to the waveform (timbre) factor, with reference to
There are a variety of schemes to adjust the waveform factor data (namely, schemes to perform the waveform linking process). As one example, the assignee of the present patent application proposes a scheme which permits a smooth connection, for example, between a style-of-rendition module of an attack or joint portion and a style-of-rendition module of a body portion (or between a style-of-rendition module of a body portion and a style-of-rendition module of a release or joint portion), by partially thinning out the waveforms. It is well known to use cross-fade synthesis in interconnecting waveforms. However, where there is only a short time t between the waveform-interconnecting point and the start point of the first loop waveform segment L1 as in the illustrated example of
Note that the joint portion as referred to herein is a waveform section for interconnecting adjoining tones (or tone segments) through a desired style of rendition.
Further, the instant embodiment permits a smooth connection between a style-of-rendition module of an attack portion and a style-of-rendition module of a release or joint portion.
In this case, waveform thinning-out of the style-of-rendition module of the attack portion, release portion or the like is sometimes possible but sometimes impossible. Examples of the attack portion whose style-of-rendition module can be subjected to the waveform thinning-out operation include a bendup attack portion that has several loop waveform segments in its latter half. Release-portion having several loop waveform segments in its former half can also be subjected to the waveform thinning-out operation. Thus, the instant embodiment thins out only the waveform of such a style-of-rendition module that can be subjected to the waveform thinning-out operation. For example, when the bend attack portion and release portion are interconnected, one or more of the loop waveform segments of the bend attack portion are thinned out (in the illustrated example of
It should be appreciated here that the loop waveform segment to be thinned out in the instant embodiment need not necessarily be the one closest to the waveform-interconnecting point (such as the leading or last loop waveform segment) and such a loop waveform segment to be thinned out may be designated from among a plurality of loop waveform segments in accordance with predetermined priority order.
As described above, the instant embodiment is constructed to perform the waveform thinning-out operation when adjoining style-of-rendition modules can not be properly interconnected within the bounds of certain style-of-rendition parameters. For this purpose, there are provided, in the instant embodiment, a “style-of-rendition module combination table”, “thinning-out parameter range table” to be referred to from the style-of-rendition module combination table, and a “thinning-out time table” to be further referred to from the thinning-out parameter range table. The style-of-rendition module combination table is a table to be used for determining predetermined parameters in accordance with a combination of adjoining style-of-rendition modules to be interconnected. The thinning-out parameter range table is a table to be used for determining a time range within which the waveform thinning-out operation is to be effected for each of the parameters. Further, the thinning-out time table is a table to be used for determining a time length of the waveform thinning-out. If a time difference between the waveform-interconnecting point and the leading or last loop waveform segment L1 (or L6′) (i.e., the time t shown in
Further, the following paragraphs describe the waveform linking process performed in a situation where the sampled length of a style-of-rendition module is so short that it would end before another style-of-rendition module following the same starts, with reference to FIG. 9. Here, the description is made in relation to a waveform shape (timbre) factor packet stream that is made, in the left-to-right direction (in a time-serial fashion), of four style-of-rendition modules: A.Sax[BendupAttack]; A.Sax[NormalShortBody]; A.Sax[VibratoBody]; and A.Sax[NormalRelease]. Sampled lengths of the individual ones of the four style-of-rendition modules (waveform section lengths) are each denoted by “length” in the figure. “note-on” and “note-off” on the top row of
The A.Sax[BendupAttack] module is caused to start at time point t0. Time point t1 represents note-on timing within the style-of-rendition module and is made to coincide with instructed note-on timing. The contents of the module in the packet stream are controlled on the basis of the style-of-rendition parameters such as those of the note, dynamics and depth. The A.Sax[NormalShortBody] module is caused to start at time point t2. Time point t3 represents timing when a vibrato rendition starts at a halfway point in the waveform-interconnecting region, and this timing is determined, for example, on the basis of start timing of a vibrato mark imparted to the music piece data. Time point t5 represents note-off timing in the A.Sax[NormalRelease] module and is made to coincide with instructed note-off timing. Starting time point t4 of the A.Sax[NormalRelease] module is determined in accordance with the note-off timing of the A.Sax[NormalRelease] module. Namely, because the note-on timing occurs at time point t1 and the corresponding note-off timing occurs at time point t5, actual generation of a tone in accordance with a waveform produced from the packet stream takes place over a time period from time point t1 to time point t5. In the case of this packet stream, the time length from time point t2 to time point t4 and the total of the respective sampled lengths of the A.Sax[NormalRelease] and A.Sax[VibratoBody] modules intervening between time point t2 and time point t4 often do not match each other, which must be properly dealt with. For this purpose, in the instant embodiment, the total of the respective sampled lengths of the A.Sax[NormalRelease] and A.Sax[VibratoBody] modules is made to coincide with the time length from time point t2 to time point t4 by repeating one of the modules, changing the sampled length of the module(s) or using an appropriate combination of parts of the two modules. Namely, the instant embodiment of the present invention is arranged to perform the waveform linking process with appropriate adjustments between the modules as necessary. Specifically, in the illustrated example, the waveform interlinking operation is performed between the A.Sax[NormalShortBody] and A.Sax[VibratoBody] modules with the preceding A.Sax[NormalShortBody] module repeated, and similarly, the waveform interlinking operation is performed between the A.Sax[VibratoBody] and A.Sax[NormalRelease] modules with the preceding A.Sax[VibratoBody] module repeated.
In the case where the waveform interlinking operation is performed between adjoining style-of-rendition modules by repeating one of the modules as described above, the time length of the repeated module is variably controlled. The variable control of the module time length, in the illustrated example, is effected by moving the representative points of the A.Sax[NormalShortBody] or A.Sax[VibratoBody] module; that is, the module time length is controlled in an appropriate manner, such as by changing a time length of cross-fade connection between a plurality of loop waveform segments constituting the module. In the case of the loop waveform segment, the time length of the entire loop reproduction can be variably controlled relatively easily by varying the number of loops or loop-lasting time. In the case of the nonloop waveform segment, however, its length along the time axis can not be variably controlled so easily. Thus, a scheme of variably controlling the sounding time length of the entire waveform of a tone comprising nonloop and loop waveform segments is very preferable in that it greatly facilitates time stretch/compression control. For this purpose, it will be advantageous to employ the “time stretch/compression control” (abbreviated “TSC”) proposed earlier by the assignee of the present patent application in Japanese Patent Laid-open Publication No. HEI-10-307586; the proposed stretch/compression control can be advantageously applied to variably control the time-axial length of a nonloop waveform corresponding to a particular style of rendition.
In the above-mentioned manner, the style-of-rendition synthesis section 101C creates a packet stream for each of the waveform components (i.e., harmonic and nonharmonic components). Each of these packet streams comprises a plurality of packets each including a vector ID and time information of the packet. In addition, each of the amplitude and pitch factors of the harmonic component and amplitude factor of the nonharmonic component includes definite values of the individual representative values. Of course, the present invention is not so limited, and each of the packets may include any other information in addition to the vector ID and time information of the packet. Thus, a packet stream is constructed, for each of the waveform factors, in accordance with the contents of the individual packets.
It should be appreciated that the number of the packet streams may differ depending on the type of the musical instrument or the like.
The waveform synthesis section 101D synthesizes a waveform on the basis of the packet streams (i.e., streams of packets each including a vector ID, time information, adjustment information, etc.) for each of the waveform factors which are supplied from the style-of-rendition synthesis section 10C.
Packet streams, created for the individual waveform factors of the harmonic and nonharmonic components by the style-of-rendition synthesis section (articulator) 101C, are sequentially input, on a packet-by-packet basis, to predetermined packet queue buffers 21-25 that are provided in the waveform synthesis section 101D in corresponding relation to the waveform factors of the harmonic and nonharmonic components. After being accumulated in the respective packet queue buffers 21-25, the packets are sent to the vector loader 20 in predetermined order, and the vector loader 20 refers to the vector ID of each of the packets to read out, from the code book 26, the original vector data corresponding to the vector ID (original vector data loading). The read-out vector data are then delivered to the vector decoders 31-35 provided in corresponding relation to the waveform factors of the harmonic and nonharmonic components, via which waveforms for the individual waveform factors are produced in predetermined synchronized relation to each other. The thus-produced waveforms for the individual waveform factors are then passed to a mixer 38. In addition to inputting the packets to the packet queue buffers 21-25, the style-of-rendition synthesis section (articulator) 101C performs various control for the waveform synthesis section 101D, such as packet stream management (i.e., management pertaining to production or deletion of the individual vector data or interconnection between the vector data) and reproduction control (i.e., control pertaining to production of a desired waveform or reproduction/stop of the produced desired waveform).
As noted above, the packets constituting the packet streams, having been accumulated in the packet queue buffer 21, are sequentially sent to the vector loader 20, and the vector loader 20 reads out, from the code book 26, the original vector data corresponding to the vector ID of each of the packets and delivers the read-out vector data to the vector decoder 21 (see FIG. 12). Some of the read-out vector data may include adjustment information (e.g., adjustment information pertaining to the representative points). In such a case, the vector loader 20 modifies the read-out original vector data in accordance with the adjustment information and then outputs the packets having the modified vector data (which will hereinafter be called “vector information data” to differentiate from the “original vector data”) to the vector decoders 31-35. Namely, the vector loader 20 reads out, from the code book 26, the original vector data on the basis of the vector IDs of the packets input from the style-of-rendition synthesis section (articulator) 101C, modifies the vector data in accordance with the adjustment information as necessary, and then passes the vector packets to the respective vector decoders 31-35 (see FIG. 13). Examples of the adjustment information pertaining to the representative points of the above-mentioned vector data include various information, such as one for changing the time information, for example, on the basis of a random number.
Further, as shown in
Further, in the instant embodiment of the invention, the time-serial waveform production for the individual waveform factors of the harmonic and nonharmonic components is performed while keeping waveform synchronization between the vector decoders 31-35. If vector packets of the waveform shape (timbre) and amplitude factors have been input, an amplitude waveform based on the vector packet of the amplitude factor is produced in synchronism with a waveform producing time based on the waveform shape (timbre) factor vector packet. The amplitude of the waveform produced on the basis of the waveform shape (timbre) factor vector packet is controlled by the thus-produced amplitude waveform. Further, if vector packets of the waveform shape (timbre) and pitch factors have been input, a pitch waveform based on the pitch factor vector packet is synthesized in synchronism with a waveform producing time based on the waveform shape (timbre) factor vector packet, and the pitch of the waveform produced on the basis of the waveform shape (timbre) factor vector packet is controlled by the thus-synthesized pitch waveform. Further, if a vector packet of the waveform shape (timbre) of the harmonic component and a vector packet of the waveform shape (timbre) of the nonharmonic component have been input, a nonharmonic component based on the waveform shape (timbre) vector packet of the nonharmonic component is synthesized in synchronism with a harmonic component synthesizing time based on the waveform shape (timbre) factor vector packet of the harmonic component. Then, a desired tone waveform is produced by mixing the synthesized waveforms of the harmonic and nonharmonic components.
Note that the instant embodiment may be arranged to permit a selection as to whether or not the harmonic and nonharmonic components should be synchronized. In this case, only when the synchronization between the harmonic and nonharmonic components has been selected, a nonharmonic component based on the waveform shape (timbre) vector packet of the nonharmonic component may be synthesized in synchronism with the harmonic component synthesizing time based on the waveform shape (timbre) factor vector packet of the harmonic component.
As noted previously, each of the packet streams consists of a plurality of packets. In the case of the packet stream of vector packets, for example, each of the vector packets include vector data; namely, the packet stream comprises a time series of the vector data. Although different in the data organization and meaning, the vector data of the amplitude factor, pitch factor and waveform shape factor appear to be fundamentally the same, in principle, as viewed from the vector operators 36 and 37.
Finally,
Note that in the case where the above-described waveform producing apparatus is applied to an electronic musical instrument, the electronic musical instrument may be of any type other than the keyboard-based instrument, such as a stringed, wind or percussion instrument. In such a case, the present invention is of course applicable not only to such an electronic musical instrument where all of the music-piece-data reproduction section 101A, musical score interpretation section 101B, style-of-rendition synthesis section 10C, waveform synthesis section 101D and the like are incorporated together as a unit, but also to another type of electronic musical instrument where the above-mentioned sections are provided separately and interconnected via communication facilities such as a MIDI interface, various networks and the like. Further, the waveform producing apparatus of the present invention may comprise a combination of a personal computer and application software, in which case various processing programs may be supplied to the waveform producing apparatus from a storage media such as a magnetic disk, optical disk or semiconductor memory or via a communication network. Furthermore, the waveform producing apparatus of the present invention may be applied to automatic performance apparatus such as a player piano.
In summary, the present invention having been described so far is characterized by extracting and storing only partial waveform data representative of a waveform shape variation. Thus, waveform data necessary for expressing the waveform shape variation can be stored in compressed form, so that the present invention can effectively save the waveform data storage capacity or minimize the quantity of waveform data to be stored. Further, by storing the extracted partial waveform data along with the information indicative of their respective time positions, the present invention achieves precise waveform reproducibility. Further, because the partial waveform data representative of a waveform shape variation are arranged at appropriate time positions in accordance with the time position information read out in association therewith, they can be reproduced at appropriate time positions in relation to important segments of a tone waveform, i.e. waveform segments representative of the waveform shape variation, thereby achieving precise waveform reproducibility. Furthermore, with the arrangement that sets of sample identification information and time position information are received and sample data are arranged at appropriate time positions in accordance with the received time position information, it is possible to effectively save the waveform data storage capacity and achieve precise waveform reproducibility. Moreover, with the arrangement that sets of sample identification information and time position information are obtained on the basis of performance data and the thus-obtained time position information is adjusted in accordance with the performance data, the present invention can provide time position information just as intended by the performance data. Also, because the obtained time position information can be variably controlled in accordance with the performance data, the present invention can effectively save the storage capacity and achieves waveform production with enhanced controllability. As a result, the present invention can advantageously produce high-quality waveforms, taking styles of rendition or articulation into account, in a simplified manner with significantly increased controllability.
Number | Date | Country | Kind |
---|---|---|---|
11-273176 | Sep 1999 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
3890602 | Tomisawa et al. | Jun 1975 | A |
4271486 | Dagostino et al. | Jun 1981 | A |
4280196 | Hornak et al. | Jul 1981 | A |
5300724 | Medovich | Apr 1994 | A |
5792971 | Timis et al. | Aug 1998 | A |
6201175 | Kikumoto et al. | Mar 2001 | B1 |
6365817 | Suzuki et al. | Apr 2002 | B1 |
Number | Date | Country |
---|---|---|
0847 039 | Jun 1998 | EP |
0856 830 | Aug 1998 | EP |
0 907 160 | Apr 1999 | EP |
00 12 0846 | Dec 2000 | EP |
1 087 368 | Mar 2001 | EP |
59-096513 | Jun 1984 | JP |
06-110455 | Apr 1994 | JP |
10-214083 | Aug 1998 | JP |
10-307587 | Nov 1998 | JP |
11-167382 | Jun 1999 | JP |