Extracting classifying data in music from an audio bitstream

Information

  • Patent Application
  • 20030040904
  • Publication Number
    20030040904
  • Date Filed
    August 27, 2001
    23 years ago
  • Date Published
    February 27, 2003
    21 years ago
Abstract
The method of the present invention utilizes machine-learning techniques, particularly Support Vector Machines in combination with a neural network, to process a unique machine-learning enabled representation of the audio bitstream. Using this method, a classifying machine is able to autonomously detect characteristics of a piece of music, such as the artist or genre, and classify it accordingly. The method includes transforming digital time-domain representation of music into a frequency-domain representation, then dividing that frequency data into time slices, and compressing it into frequency bands to form multiple learning representations of each song. The learning representations that result are processed by a group of Support Vector Machines, then by a neural network, both previously trained to distinguish among a given set of characteristics, to determine the classification.
Description


BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention


[0002] The invention relates generally to the fields of computer science, machine learning, artificial intelligence, and digital signal processing, and more specifically, to a combination of machine learning and digital signal processing that allows a computer to learn an audio bitstream, also known as “machine listening”. The machine listening technique allows the computer to extract artist and/or genre information from a piece of music with which it may not have previously experienced, but whose characteristics it has gleaned by exposure to other pieces of the same artist and/or genre.


[0003] 2. Description of the Prior Art


[0004] Song recognition systems can be a boon to copyright holders who need to check if their work is being distributed criminally or via unauthorized means. The present downside of such systems is that they must include a representation of each song owned, which for large record labels and song collections can be all but impossible. Queries made within this search space could feasibly take too much processing time. Further, new songs would have to be added manually.


[0005] A system that could identify the artist of an unknown piece of music, instead of identifying a particular song, solves these problems since the copyright holder need only provide a few representative samples of each artist. The system will ‘infer’ the set of features that makes this artist unique and classifiable. Future classifications happen on completely unknown music and match very quickly to a previously-learned feature space.


[0006] There is a recent spate of interest in music retrieval from both the frequency (e.g., recorded or digital audio) and score (e.g., notes, transcriptions) domains. Most music retrieval research efforts deal with classification of instrument type, and in some cases genre.


[0007] Foote gives an overview of audio information retrieval from the starting point of speech recognition and retrieval, referring to the music domain as “a large and extremely variable audio class.” See, “An Overview of Audio Information Retrieval,” ACM-Springer Multimedia Systems, 1998.


[0008] As well, Herrera et al. overviews the various classification techniques used on digital audio. See, “Towards Instrument Segmentation for Music Content Description: a Critical Review of Instrument Classification Techniques,” Proceedings of ISMIR 2000, Plymouth, Mass. Herrera, et al., discusses such methods as K-nearest neighbor (K-NN), naïve Bayesian classifiers, discriminant analysis, neural networks and support vector machines (SVM).


[0009] Tzanetakis, et al., discuss their audio retrieval system MARSYAS, which operates on various representations of audio to predict genre and classify music from speech. See, “Audio Information Retrieval (AIR) Tools,” Proceedings of ISMIR 2000, Plymouth, Mass. The classification techniques used include Gaussian Mixture Models and K-nearest neighbor algorithms.


[0010] Martin, et al., also use K-NN for instrument identification, with an overall identification success rate of 70%. See, “Musical Instrument Identification: A Pattern-Recognition Approach,” Presented at the 136th Meeting of the Acoustical Society of America, 1998.


[0011] Foote discusses using dynamic programming to retrieve orchestral music by similarity, starting with an energy representation composed of the peak RMS value of each one-second slice of music. See, “ARTHUR: Retrieving Orchestral Music by Long-Term Structure,” Proceedings of ISMIR 2000, Plymouth, Mass. He then moves onto a purely spectral feature space. The dynamic programming methods used to retrieve similar music (different performances of the same piece, for example) proved adequate for the small corpus used. Music data as lexemes for search and classification is also discussed at the score level in Pickens. See, “A Comparison of Language modeling and Probabilistic Text Information Retrieval Approaches to Monophonic Music Retrieval,” Proceedings of ISMIR 2000, Plymouth, Mass.


[0012] Logan describes the use of MFCCs for the task of music modeling. See, “Mel Frequency Cepstral Coefficients for Music Modeling,” Proceedings of ISMIR 2000, Plymouth, Mass. The MFCC is presented as a smarter Fast Fourier Transform (FFT), in that it is scaled to a more psycho-acoustically sound frequency growth, and also has a built-in discrete cosine transform (DCT) step to approximate principal component analysis for de-correlation. Her experiments in music/not music separation show promise for the MFCC in high-level music retrieval.


[0013] There are a few commercially oriented music recommending and copyright protection systems that operate on the spectral features of music. Such examples are Moodlogic (at www.Moodlogic.com), whose information is limited to select features of music, and the song-recognition components used by Relatable Technologies (www.relatable.com), cannot infer artist information from its feature space.



BRIEF SUMMARY OF THE INVENTION

[0014] The system of the present invention uses a combination of machine learning techniques, such as neural networks and support vector machines, with a music-specific representation generator to classify audio data.


[0015] Specifically, the present invention begins with an audio signal converted into a Pulse Code Modulated bitstream capable of being machine processed. This bitstream is then transformed into a perceptual representation of the constituent frequencies that make up the audio signal.


[0016] To facilitate processing by machine-learning techniques, the perceptual representation is divided into time slices. The frequency data of the perceptual representation is then compressed into a smaller number of frequency bands. The result is a learning representation for each time slice of the audio signal. The slice representation of audio adequately describes the piece of music and its performers and production for search and retrieval tasks.


[0017] This learning representation is then processed in a multi-stage classifier by a number of support vector machines, each trained to identify a particular characteristic. The results of each support vector machine are collected into a metalearner vector, which is input into a neural network, also trained to discriminate among a set of characteristics. The neural network, using the metalearner vector as input, makes the classification.


[0018] This system could be used by copyright holders to quickly search large music databases for instances of an artist's work. Conversely, it could be used by end-users who wish to find music by a particular artist. It can also be used in converting large sets of music data to the digital domain; instead of manually entering artist information, the system could automatically make the classification. The representation generated by the system of the present invention can also be used as a recommendation agent for content-based music retrieval.







BRIEF DESCRIPTION OF THE DRAWINGS

[0019] These and other features, aspects, and benefits of the present invention will become better understood with regard to the following description, appended claims, and accompanying drawings, where like reference numerals refer to like components across the several views:


[0020]
FIG. 1 shows the flow path of a Music Classifier according to the present invention.


[0021]
FIG. 2 shows the flow path of the Learning Representation Generator according to the present invention.


[0022]
FIG. 3 shows the flow path of the multi-stage classifier according to the present invention.







DETAILED DESCRIPTION OF THE INVENTION

[0023] Referring to FIG. 1, the system 100 begins by receiving an audio signal from some source 102. The source 102 generates a signal 103 which contains audio content, which can be a recording from CD or other media, a received broadcast, a file that stores the music data, or even input from a live performance. The signal 103 is either re-sampled or directly copied by a Pulse Code Modulation (PCM) encoding circuit 104, which outputs a digital representation of audio signal 103, which is audio bitstream 105.


[0024] Next, the audio bitstream 105 is transformed by a perceptual representation (PR) generator 106 into PR 107. From this PR, a learning representation (LR) generator 108 transforms the PR into LRs 109. The LRs 109 output from the LR generator 108 are input into a multi-stage classifier 110, which after proper training will be capable of distinguishing between a variety of artists to which it has been exposed. An output 112 will be the classification of source 102 into one of a number of categories, for example by artist.


[0025] Referring to FIG. 2, the complete formation of LRs 109 from the bitstream 105 is shown schematically. The bitstream 105 is a representation of the audio signal 103, sampled and measured at fixed time intervals. However, a system that attempts to hear as a person must be able to interpret the encoding that enables ears to vibrate, namely, the frequency domain.


[0026] A preferred method of transforming bitstream 105 into a PR 107 is the Fast Fourier Transform (FFT). PR generator 106 performs the FFT, in accordance with the criterion described below, resulting in the PR 107. In the case of the FFT, the output is the coefficients of the sine and cosine components of frequency vectors given an n-sampled time series. The choice of n can vary depending on performance requirements. Larger windows get more done at once, but introduce latency into ‘real-time’ analyses. A 1,024-sample time window was found suitable.


[0027] The nature of PCM sampling is such that the sampling rate must be twice that of the highest frequency of the signal being sampled, known as the Nyquist Criterion. In the case of CD audio, that sampling rate is 44 kHz. Further, the nature of the FFT is such that it will compute the component magnitudes of n frequency vectors as high as the sampling rate. It is known, however, from the Nyquist Criterion, that there can be no frequencies greater than ½ the sampling rate accurately represented in the PCM data. Further, it has been shown that the magnitudes are a mirror image, along the frequency domain. Moreover, frequencies above 22 kHz are too high to be relevant to the audio signal being transformed. Therefore, to avoid the effects of this mirroring, frequency components above 22 kHz are discarded.


[0028] This leaves the sine and cosine component magnitude weights of 512 frequency vectors between 0 Hz and 22 kHz. The magnitude of each frequency vector is calculated, using the Pythagorean theorem, from these sine and cosine component magnitudes. The result is, for each 1,024-sample time window, a value of the magnitude of the each of the 512 constituent frequency vectors that make up the audio at that time.


[0029] Therefore, the PR generator 106 performs the above FFT calculations, and the resulting data is then represented conveniently in a three dimensional matrix 201 having dimensions of time (t), frequency (f), and magnitude (M). This matrix 201 of frequency magnitudes is the perceptual representation 107 of the audio bitstream 105.


[0030] Within LR generator 108, this matrix 201 is then divided along the time domain into n sequentially indexed discrete time slices 203, for example 1.2 seconds long. In the exemplary embodiment, a time slice 203 was comprised of 12 time-sample windows. The frequency magnitudes were averaged across the time-sample windows which make up a given time slice 203. Therefore, each time slice 203 will have only one average magnitude at each frequency.


[0031] For effective machine learning, 512 dimensions are still far too many given the limited number of examples for training and classification. To alleviate this, each time slice 203 is then subdivided into j sequentially indexed frequency bands 205. In testing, best results were achieved where j=20.


[0032] Further, the size of each frequency band should be chosen to reflect where the most salient information typically lies. Most information in music happens across the lower-end of the spectrum, below 11 kHz. Moreover, octave sizes grow logarithmically according to the golden ratio (A4=440 hz, A5=880 hz, A6=1760 hz, etc.). The size of each frequency band should grow according to this golden ratio in order to best capture the frequency information closely grouped at the lower frequencies.


[0033] The magnitudes of each frequency component vector within a given band are averaged into a scalar dimension Mi. The LRs 109 output from the LR generator 108 are in the form of LR Vectors 207. There are j number of dimensions Mi comprising each LR Vector 207, i being the index of each dimension's corresponding frequency band 205. Each LR Vector 207 represents one time slice of a song.


[0034] Referring now to FIG. 3, the multi-stage classifier 110 of the present invention is illustrated schematically. A first stage 301 comprises y number of SVMs 302, each trained to recognize the LRs of a particular artist. An unknown LR Vector 207 is then presented to each SVM 302. Each SVM 302 will output a value O 306, between 1 and −1, depending on how well or poorly, respectively, the characteristics of that particular LR vector 207 conform to the characteristics each SVM 302 has been trained to recognize.


[0035] Training an SVM 302 entails presenting a number of LR vectors 207 of a given characteristic, e.g. artist, to an SVM 302, while instructing it to hold its output value O 306 to a value near 1. Training further entails presenting a number of LR Vectors 207 of differing characteristics, i.e., belonging to different artists, while instructing the SVM 302 to hold its output value O 306 to a value near −1. Over several representative LR Vectors, the SVM will infer the particular frequency magnitudes and relationships therebetween that are unique to a given artist.


[0036] At this first stage, if all one wished was a yes/no indication on one particular characteristic, e.g., artist, genre, etc., then a single SVM 302 would suffice. However, for discrimination among multiple artists, it would not be possible for even a human viewing the multiple SVM 302 outputs to intuit the correct artist. To accomplish this, a “Metalearner” machine is required. The final stage 304 of the multi-stage classifier 110 is a metalearner. In the present invention, final stage 304 is a neural network 303.


[0037] The output value O 306 of each SVM 302 based on each LR Vector 207 is arranged into a Metalearner vector 305. This Metalearner vector 305 is then presented to the neural network 303 to make the final classification.


[0038] Neural network 303 has y input nodes 307, one for each output of each SVM 302, and also y output nodes 309. Neural network 303 also has a hidden layer 311, comprised of hidden nodes, not pictured. In the exemplary embodiment, the neural network 303 has a set of double-precision floating point values as each input node. As is typical of such systems, neural network 303 will assign an output value between 0 and 1 to each output node in response to an input.


[0039] To train neural network 303, the Metalearner vectors 305 corresponding to known artists were input, while the output node corresponding to the correct artist was set to 0.9, and all other output nodes were set to 0.1. It is known to avoid the extremes of the output range when teaching a system of this type.


[0040] When the neural network 303 completes training, it writes a binary representation of the network to disk. The activation function of the neural network 303, number of hidden nodes in the hidden layer 311, and learning algorithm could all be altered at run time. For example, a Gaussian activation function performed best over the mostly-noisy audio data, and having at least as many hidden nodes as input nodes supported high testing accuracies.


[0041] One feature of the classification process is its confidence evaluation. Using the learning representation vectors 207 of the time slices 203, a number of examples within a set are close enough to each other that the neural network 303 could become confused and assign low scores to each output unit, essentially failing to make any classification. However, since there are a large number of slices per song, one could easily “throw away” many of the neural net's weaker decisions if it was known that they weren't as strong as others.


[0042] To account for this, the present system includes a confidence metric, which defines confidence as the maximum value among classification output nodes 309 of neural net 303, subtracted by the second-highest value among output nodes 309, multiplied by the maximum again. Only determinations that have a confidence above 0.1 are included.


[0043] During the classifying process, the artist corresponding to the output node 309 that had the most of these over-threshold determinations was assigned to the song.


[0044] Each song s is divided into n parts. Eventually only 1 out of every k parts is used to make the classification. Each part out of song s is defined as j frequency bands distributed along the audio spectrum. An LR vector 207 then becomes an “example” for a training system, with each s containing n/k LRs.


[0045] The length of a given slice n, in seconds, has been tested between 0.09 seconds to 2.0 seconds. Best results were found around the “two-beat long” length of about 0.8-1.2 second, which is approximately 2 beats at the most common tempo of 120 beats per second. It would take someone 2 beats to identify the changes that define music, and this follows over to the digital domain as well.


[0046] Frequency banding determines the count j in the slice representation. Each slice is a group of bands along the frequency vector. At j=10, for example, we split the frequency vector into 10 divisions and use the magnitude of each range. Unfortunately, a 10-band arrangement doesn't work very well. Much better results were found with a number in the range of 20-40, preferably 20.


[0047] Lastly, there is the skip parameter, k. If every single slice in the audio were used, there would simply be too much data. For example, a 3:05 song will produce over 150 slices of 1.2 s each, more than are necessary for either learning or recognition given the limited dimensions of the LR vector 207. It speeds both the learning and recognition processes, without impacting accuracy, to consider only a fraction of the slices available. Only every kth slice, in testing k=2, contribute to the total representation processed.


[0048] It should be noted that Support Vector Machine is used as a term of art, where the word ‘machine’ is itself a colloquialism. What is referred to is a learning process, several of which may be performed on one or more machines. Similarly with respect to the neural network, the reference is to the process, not specifically the apparatus. However, this should not be misunderstood to imply that the present invention is limited to the processes disclosed. An embodiment of the invention may comprise a computer apparatus to perform the data extraction and classification according to the present invention, and/or computer readable media storing therein a program of instructions instructing a computer to carry out the data extraction and classification of the present invention.


[0049] The overall system 100 can be viewed as composed of a series of interconnected modules with swappable ‘glue’ layers. This design allows the system to perform various music retrieval related tasks in permuted configurations. The glue layer between each module can be a link over networks, for example via a TCP/IP layer, or on disk or memory, e.g., through an XML data storage mechanism.


[0050] Some modules contemplated include those that transfer a CD source into PRs. Another takes an MP3 file and likewise transfers it into PRs. Still a third can take buffered live input data, for example in the Steinberg VST format, and transfer this into PRs.


[0051] A module sequentially later in the classification process could take the PRs and convert them into LRs according to our inventive process. Still later in the process is a module that can take the LRs and perform a learning operation, or selected combination of learning operations.


[0052] The exemplary embodiment of the invention has been described with respect to a system for classifying the artist of a piece of music. However, the invention is not limited to that use, as it would be equally applicable to discriminate among genres, or other characteristics.


[0053] Certain other alterations and modifications may be apparent to those skilled in the art, without departing from the scope of the invention. The exemplary embodiment is not meant to be limiting on the scope of the invention, which is defined by the appended claims.


Claims
  • 1. A method of extracting classifying data from an audio signal, the method comprising the steps of: (a) processing said audio signal into a perceptual representation of its constituent frequencies; (b) processing said perceptual representation into at least one learning representation of said audio data stream; (c) inputting at least one said learning representation into a multi-stage classifier, whereby said multi-stage classifier extracts classifying data from said learning representations and outputs the classification of said audio signal.
  • 2. The method of extracting classifying data from an audio signal according to claim 1, wherein the step of processing the audio data into a perceptual representation of its constituent frequencies comprises calculating, for a time sample window of a digital representation of said audio signal, a Fast Fourier Transform function.
  • 3. The method of extracting classifying data from an audio signal according to claim 1, wherein the step of processing said perceptual representation into at least one learning representation further comprises dividing said perceptual representation into a plurality of time slices.
  • 4. The method of extracting classifying data from an audio signal according to claim 3, wherein each of said time slices is about 0.8 to about 1.2 seconds in length.
  • 5. The method of extracting classifying data from an audio signal according to claim 1, wherein the step of dividing the perceptual representation into learning representations further comprises dividing said perceptual representation into a plurality of frequency bands.
  • 6. The method of extracting classifying data from an audio signal according to claim 5, wherein said plurality of frequency bands comprises 20 frequency bands.
  • 7. The method of extracting classifying data from an audio signal according to claim 5, wherein the size of each of said frequency bands grows according to the golden ratio of frequency with respect to pitch.
  • 8. The method of extracting classifying data from an audio data stream according to claim 5, wherein no said frequency band includes any frequency greater than 11 kHz.
  • 9. The method of extracting classifying data from an audio signal according to claim 1, wherein a first stage of said multi-stage classifier comprises at least one Support Vector Machine.
  • 10. The method of extracting classifying data from an audio signal according to claim 10, wherein said first stage of said multi-stage classifier comprises at least one Support Vector Machine per category of classification.
  • 11. The method of extracting classifying data from an audio signal according to claim 1, wherein a final stage of said multi-stage classifier comprises a neural network.
  • 12. The method of extracting classifying data from an audio signal according to claim 11, wherein said neural network comprises at least one input node per category of classification, and further wherein said neural net comprises at least one output node per category of classification.
  • 13. The method of extracting classifying data from an audio signal according to claim 12, wherein said neural network comprises a hidden layer, wherein said hidden layer comprises at least as many nodes as the number of said input nodes.
  • 14. The method of extracting classifying data from an audio signal according to claim 11, wherein said neural network operates on a Gaussian activation function.
  • 15. The method of extracting classifying data from an audio signal according to claim 1, wherein said classifying data comprises at least one of artist and genre.
  • 16. The method of extracting classifying data from an audio signal according to claim 1, further comprising the step of converting said audio signal into a pulse code modulated digital bitstream.
  • 17. The method of extracting classifying data from an audio signal according to claim 1, further comprising the step of measuring the confidence of said classification by said multi-stage classifier.
  • 18. A computer readable storage medium, storing therein a program of instructions for causing a computer to execute process of extracting classifying data from an audio signal, said process comprising the steps of: (a) processing said audio signal into a perceptual representation of its constituent frequencies; (b) processing said perceptual representation into at least one learning representation; (c) inputting said learning representations of said audio data stream into a multi-stage classifier, whereby said multi-stage classifier extracts classifying data from said learning representations and outputs the classification of said audio signal.
  • 19. A method of representing an audio signal for machine learning comprising: (a) creating a perceptual representation of said audio signal by performing a frequency domain transform on at least one time-sampled window of a digital representation of said audio signal, said perceptual representation comprising component magnitudes of constituent frequency vectors that comprise said audio signal; (b) calculating a magnitude of each constituent frequency vector within said audio signal; (c) grouping each of said constituent frequency vectors into a number of frequency bands; (d) calculating an average magnitude of said constituent frequency vectors within each of said frequency bands; and (e) arranging said magnitudes into a learning representation.
  • 20. The method according to claim 19 wherein said frequency domain transform is a Fast Fourier Transform.
  • 21. The method according to claim 19 wherein an average magnitude of said constituent frequency vectors within each of said frequency bands further comprises an aggregate average magnitude over a plurality of said time-sampled windows.
  • 22. The method according to claim 21 where said plurality of time-sampled windows comprises 12 time-sampled windows.
  • 23. The method according to claim 19 wherein no said frequency band includes any frequency greater than 11 kHz.
  • 24. The method according to claim 19 wherein said frequency bands grow in size according to the golden ratio of frequency with respect to pitch.
  • 25. The method according to claim 19 further comprising the step of converting said audio signal into a pulse code modulated bitstream for processing by said frequency domain transform.
  • 26. A computer readable storage medium, storing therein a program of instructions for causing a computer to execute process of representing an audio signal for machine learning, said process comprising the steps of: (a) creating a perceptual representation of said audio signal by performing a frequency domain transform on at least one time-sampled window of a digital representation of said audio signal, said perceptual representation comprising component magnitudes of constituent frequency vectors that comprise said audio signal; (b) calculating a magnitude of each constituent frequency vector within said audio signal; (c) grouping each of said constituent frequency vectors into a number of frequency bands; (d) calculating an average magnitude of said constituent frequency vectors within each of said frequency bands; and (e) arranging said magnitudes into a learning representation.
  • 27. An apparatus for classifying an audio data stream comprising: (a) a means for covering an audio data stream into a perceptual representation of its constituent frequencies; (b) a means for dividing said perceptual representation into learning representations; and (c) a multi-stage classifying means trained to distinguish among classifying categories of said audio data stream, wherein said multi-stage classifying means outputs the classification of said audio signal.
  • 28. The apparatus according to claim 27, wherein the said means for covering an audio data stream into a perceptual representation of its constituent frequencies comprises means to perform a Fast Fourier Transform function on at least one time-sampled window digital representation of said audio stream.
  • 29. The apparatus according to claim 27, wherein a means for dividing said perceptual representation into learning representations further comprises means for dividing said perceptual representation into a plurality of time slices.
  • 30. The apparatus according to claim 29, wherein each of said time slices is about 0.8 to about 1.2 seconds in length.
  • 31. The apparatus according to claim 27, wherein said means for dividing said perceptual representation into learning representations further comprises means for dividing said perceptual representation into a plurality of frequency bands.
  • 32. The apparatus according to claim 31, wherein said plurality of frequency bands comprises 20 frequency bands.
  • 33. The apparatus according to claim 31, wherein the size of each of said frequency bands grows according to the golden ratio of frequency with respect to pitch.
  • 34. The apparatus according to claim 31, wherein no said frequency includes any frequency higher than 11 kHz.
  • 35. The apparatus according to claim 27, wherein a first stage of said multi-stage classifier comprises at least one Support Vector Machine.
  • 36. The apparatus according to claim 36, wherein said first stage of said multi-stage classifier comprises at least one Support Vector Machine per category of classification.
  • 37. The apparatus according to claim 27, wherein a final stage of said multi-stage classifier comprises a neural network.
  • 38. The apparatus according to claim 37, wherein said neural network comprises at least one input node per category of classification, and further wherein said neural net comprises at least one output node per category of classification.
  • 39. The apparatus according to claim 38, wherein said neural network comprises a hidden layer, wherein said hidden layer comprises at least as many nodes as the number of said input nodes.
  • 40. The apparatus according to claim 37, wherein said neural network operates on a Gaussian activation function.
  • 41. The apparatus according to claim 27, wherein said classifying categories comprise at least one of artist and genre.
  • 42. The apparatus according to claim 27, further comprising a means to convert said audio signal into a pulse code modulated digital bitstream.
  • 43. The apparatus according to claim 27, further comprising a means for measuring the confidence of said classification by said multi-stage classifier.
  • 44. An apparatus for representing an audio signal for machine learning comprising: (a) a means for performing a frequency domain transform on at least one time-sampled window of a digital representation of said audio signal, said perceptual representation comprising component magnitudes of constituent frequency vectors that comprise said audio signal; (b) a means for calculating a magnitude of each constituent frequency vector; (c) a means for grouping each of said constituent frequency vectors into a number of frequency bands; (d) a means for calculating an average magnitude of said constituent frequency vectors within each of said frequency bands; and (e) a means for arranging said magnitudes into a learning representation.
  • 45. The apparatus according to claim 44 wherein said means for performing a frequency domain transform comprises a means for performing a Fast Fourier Transform.
  • 46. The apparatus according to claim 44 wherein no said frequency band includes any frequency greater than 11 kHz.
  • 47. The apparatus according to claim 44 wherein said frequency bands grow in size according to the golden ratio of frequency with respect to pitch.
  • 48. The apparatus according to claim 44 further comprising a means for converting said audio signal into a pulse code modulated bitstream for processing by said frequency domain transform.