The present disclosure relates to audible signal processing, and in particular, to accurately recognizing phonemes in noisy audible signal data using neural network systems.
The ability to recognize speech of a particular speaker is a basic human auditory system function. However, this function is notoriously difficult to reproduce using previously known machine-listening technologies because spoken communication often occurs in adverse acoustic environments. The problem is also complicated because how a person speaks the same words often varies between different utterances. Nevertheless, the unimpaired human auditory system is able to recognize speech effectively and perceptually instantaneously.
As a previously known machine-listening process, speech recognition (and subsequent re-synthesis) often includes recognizing phonemes using statistical formalisms such as neural networks. Phonemes are a basic representation of information bearing vocalizations. However, the previously known neural network approaches have a number of drawbacks. First, for example, in order to improve performance, previously known neural network approaches are heavily dependent on language-specific models, which make such approaches language-dependent. Second, many of the previously known neural network approaches recognize phonemes too slowly for real-time and/or low-latency applications because they are reliant on look-ahead information in order to provide context. Third, previously known neural network approaches are becoming increasingly computationally complex, use ever-larger memory allocations, and yet remain functionally limited and highly inaccurate—especially for problematic phonemes that are difficult to detect and are frequently misidentified as other similar sounding phonemes.
Due to increasing computational complexity and memory demands, previously known phoneme recognition neural network approaches are characterized by long delays and high power consumption. As such, these approaches are undesirable for low-power, real-time and/or low-latency devices, such as hearing aids and mobile devices (e.g., smartphones, wearables, etc.).
Various implementations of systems, methods and devices within the scope of the appended claims each have several aspects, no single one of which is solely responsible for the attributes described herein. After considering this disclosure those of ordinary skill in the art will understand how the aspects of various implementations are used to enable expert-assisted phoneme recognition neural network systems configured to recognize phonemes within continuous large vocabulary speech sequences without using language specific models (“left-context”), look-ahead (“right-context”) information, or multi-pass sequence processing, and while operating within the resource constraints of low-power and real-time devices.
In accordance with various implementations, a method of training an expert-assisted phoneme recognition neural network system, the method comprising: at an expert-assisted phoneme recognition neural network system configured to generate one or more phoneme candidates as recognized within audible signal data, the expert-assisted phoneme recognition neural network system including an ensemble phoneme recognition neural network and a phoneme-specific experts system: selecting a target problematic phoneme; synthesizing a targeted training data set including an overemphasis of examples of the target problematic phoneme; synthesizing respective problematic phoneme-specific weight values for problematic phoneme-specific expert neural network (PPENN) included in the phoneme-specific experts system by providing the synthesized target training data set to the PPENN in accordance with a determination that the respective problematic phoneme-specific weight values satisfy an error convergence threshold.
So that the present disclosure can be understood in greater detail, a more particular description may be had by reference to the features of various implementations, some of which are illustrated in the appended drawings. The appended drawings, however, merely illustrate the more pertinent features of the present disclosure and are therefore not to be considered limiting, for the description may admit to other effective features.
In accordance with common practice various features shown in the drawings may not be drawn to scale, as the dimensions of various features may be arbitrarily expanded or reduced for clarity. Moreover, the drawings may not depict all of the aspects and/or variants of a given system, method or apparatus admitted by the specification. Finally, like reference numerals are used to denote like features throughout the drawings.
Numerous details are described herein in order to provide a thorough understanding of the example implementations illustrated in the accompanying drawings. However, the invention may be practiced without many of the specific details. Those of ordinary skill in the art will appreciate from the present disclosure that well-known methods, components, systems and circuits have not been described in exhaustive detail so as not to unnecessarily obscure more pertinent aspects of the implementations described herein.
As noted above, accurate speech recognition is a notoriously difficult hearing task to reproduce using previously known machine-listening technologies. The challenge is complicated because spoken communication often occurs in adverse acoustic environments, which often include ambient noise, interfering sounds, and background chatter. The problem is also complicated because how a person speaks the same words often varies between different utterances of the words. However, it is well established that speech recognition accuracy is highly dependent on phoneme recognition and discrimination accuracy, which varies greatly depending on the specific phonemes. For example, distinguishing the spoken word “first” from the spoken word “third” depends upon being able to distinguish an sound from a ‘th’ sound, and a ‘t’ sound from a ‘d’ sound. But making such distinctions reliably using previously available machine-listening technologies is very difficult to accomplish.
As an example provided to illustrate the spectral challenges involved in distinguishing similar sounding phonemes,
The spectrogram 100 includes the portion of the frequency spectrum associated with human vocalizations, the human voice spectrum 101. The human voice spectrum typically ranges from approximately 300 Hz to 3400 Hz. However, the bandwidth associated with a typical voice channel is approximately 4000 Hz (4 kHz) for telephone applications and 8000 Hz (8 kHz) for hearing aid applications.
Formants are distinguishing frequency components of voiced sounds that make up phonemes. A phoneme, of any language, includes a combination of formants in the human voice spectrum 101. In addition to characteristics such as pitch and amplitude (i.e., loudness), formants and how formants vary in time characterize how words are perceived to sound. Formants do not vary significantly in response to changes in pitch. However, formants do vary substantially in response to different vowel sounds. An example of the variation can be seen with reference to the formant sets 110, 120 for the words “ball” and “buy.” The first formant set 110 for the word “ball” includes three dominant formants 111, 112 and 113. Similarly, the second formant set 120 for the word “buy” also includes three dominant formants 121, 122 and 123. The three dominant formants 111, 112 and 113 associated with the word “ball” are spaced differently and vary differently in time as compared to the three dominant formants 121, 122 and 123 associated with the word “buy.” Also, if the formant sets 110 and 120 are attributable to different speakers, the formants sets would not be synchronized to the same fundamental frequency defining the pitch of one of the speakers.
As a previously known machine-listening process, speech recognition (and subsequent re-synthesis) typically includes phoneme recognition using neural networks, as phonemes are a constituent component of information bearing vocalizations that are perceived as spoken words. However, previously known neural network approaches have a number of drawbacks that make them undesirable for low-power, real-time and/or low-latency devices, such as hearing aids and mobile devices (e.g., smartphones, wearables, etc.).
First, previously known neural network approaches are heavily dependent on language specific models. Language specific models include distributions of conditional probability values characterizing the likelihoods of which phonemes follow other phonemes on a phoneme-by-phoneme basis. In other words, these models provide sequence information (or “left-context”) to assist in the recognition of a phoneme at a given instance based on a decision recognizing a previous phoneme in sequence. While beneficial for improving recognition accuracy, relying on sequence information makes such approaches language-dependent. In turn, a speech recognition system relying on sequence information is limited to the number of language models that can be supported by the computational and memory resources of a given system. Generally, this is undesirable for devices, such as hearing aids and mobile devices, which are tightly resource constrained.
Second, many of the previously known neural network approaches process audible sequences far too slowly for real-time and/or low-latency applications because they are also reliant look-ahead information and multi-pass sequence processing. Look-ahead systems, or “right-context” information systems, delay the recognition of a phoneme until the system is able to evaluate which of one or more phonemes follow in sequence. Delaying phoneme recognition in this manner precludes real-time and/or low-latency operation because phoneme recognition depends on future phonemes.
Third, in order to improve recognition accuracy, previously known neural network approaches are becoming increasingly computationally complex, are demanding ever larger memory allocations, and yet remain functionally limited and highly inaccurate—especially for problematic phonemes that are difficult to detect and are frequently misidentified as other similar sounding phonemes. For example, some previously known neural network approaches employ a structured neural network architecture that is configured toward recognizing different individual phonemes. What these approaches have in common is that they merely rely on low-level linguistic information present in an audio signal as inputs, and force the structured neural network to learn to recognize the higher order attributes of speech (e.g., auditory filters that emulate the response of the basilar membrane in the human ear) that focus on identifying sound energies in different frequency bands, combinations of different auditory filter energies, the evolution of filter responses over time, combining these features to track “high energy” plosive sounds versus “harmonic” vowel sounds a-posteriori. Relying on a neural network to learn to recognize higher order attributes of speech from audible signal data significantly increases the size and complexity of the neural network required. For example, a previously available recurrent neural network (RNN) with the capacity to learn to recognize higher order attributes of speech typically includes nine to ten hidden layers in addition to the input and output layers that define the RNN. A RNN of that size typically includes inputs sizes of the order of 103, a number of neurons (neural network logic units) of the order of 104, interconnects (between the logic units) of the order of 106, and noisy speech training data of the order of 104 hours. As noted above, despite this immense computational complexity and demand for memory, these approaches remain functionally limited especially for problematic phonemes.
By contrast, various implementations disclosed herein include an expert-assisted phoneme recognition neural network system configured to recognize phonemes within continuous large vocabulary speech sequences without using language specific models (“left-context”), look-ahead (“right-context”) information, or multi-pass sequence processing, and while operating within the resource constraints of low-power and real-time devices. To these ends, in various implementations, an expert-assisted phoneme recognition neural network system as described herein utilizes a-priori phonetic knowledge. Phonetics is concerned with the configuration of the human vocal tract while speaking and acoustic consequences on vocalizations. While similar sounding phonemes are difficult to detect and are frequently misidentified by previously known neural networks, phonetic knowledge gives insight into what aspects of sound acoustics contain the strongest contrast between similar sounding phonemes. For example, two vowels that are articulated with similar tongue height (e.g., ‘ih’ and ‘uh’) will have similar first formants, which make it difficult to distinguish between them. However, the same vowels are also articulated with differing degrees of tongue backness (tongue backness is a characterization of the position of the tongue during the articulation of a vowel relative to the back of the mouth), resulting in different second formants. Utilizing features that emphasize the respective second formants thus allows for more robust sound discrimination between these problematic phonemes. Since human vocal tracts are similar for human speakers of all languages, focus on features such as those above are beneficial for sound discrimination in all languages.
As a non-limiting example, in some implementations, the speech recognition and re-synthesis system 200 includes a microphone 201, a time series conversion module 203, a spectrum conversion module 204, a frame buffer 205, a spectral feature characterization module 210, the aforementioned expert-assisted phoneme recognition neural network system 300, a speech (or text) re-synthesis module 250, and a formant templates buffer 260.
The microphone 201 (e.g., one or more audio sensors) is provided to receive and convert sound into electronic signal data that can be stored in a non-transitory memory, and which is referred to as audible signal data hereinafter. In many situations, audible signal data is captured from within an adverse acoustic environment, and thus likely includes ambient noise, interfering sounds, and background chatter in addition to a target voice of interest.
In many applications, the microphone 201 provides the audible signal data as an ongoing or continuous time series of values. In turn, the times series conversion module 203 is configured to generate two or more temporal frames of audible signal data from a continuous stream of audible signal data. Each temporal frame of audible signal data includes a temporal portion of the audible signal received by the microphone 201. In some implementations, the times series conversion module 203 includes a windowing module 203a that is configured to mark and separate one or more temporal frames or portions of the audible signal data for times t1, t2, . . . , tn. In some implementations, each temporal frame of the audible signal data is conditioned by a pre-filter (not shown). For example, in some implementations, pre-filtering includes band-pass filtering to isolate and/or emphasize the portion of the frequency spectrum typically associated with human speech. In some implementations, pre-filtering includes pre-emphasizing portions of one or more temporal frames of the audible signal data in order to adjust the spectral composition of the one or more temporal frames of the audible signal data. Additionally and/or alternatively, in some implementations, the windowing module 203a is configured to retrieve the audible signal data from a non-transitory memory. Additionally and/or alternatively, in some implementations, pre-filtering includes filtering the received audible signal using a low-noise amplifier (LNA) in order to substantially set a noise floor for further processing. In some implementations, a pre-filtering LNA is arranged between the microphone 201 and the time series conversion module 203. Those of ordinary skill in the art will appreciate that numerous other pre-filtering techniques may be applied to the received audible signal, and those highlighted herein are merely examples of numerous pre-filtering options available.
The spectrum conversion module 204 operates to generate a corresponding frequency domain representation for each of the one or more temporal frames, so that one or more spectral characteristics of the audible signal data can be determined for each frame. In some implementations, the frequency domain representation of a temporal frame includes at least one of a plurality of sub-bands contiguously distributed throughout the frequency spectrum associated with voiced sounds. In some implementations, for example, the spectrum conversion module 204 includes a Fast Fourier Transform (FFT) sub-module 204a. In some implementations, a 32 point short-time FFT is used for conversion into the frequency domain. Those of ordinary skill in the art will appreciate that any number of FFT implementations are used in various implementations. In various implementations, the FFT module 204a may also be replaced with a Goertzel module. Additionally and/or alternatively, the FFT module 204a may also be replaced with any suitable implementation of a wavelet decomposition module, constant-Q transform and/or a set of redundant basis function modules configured to capture pertinent spectral characteristics of the input signal. In some implementations, an optional spectral filter module (not shown) is configured to receive and adjust the spectral composition of the frequency domain representations of the one or more frames. In some implementations, for example, the spectral filter module is configured to one of emphasize, deemphasize, and/or isolate one or more spectral components of a temporal frame of the audible signal in the frequency domain. The frequency domain representations of the one or more frames are stored in the frame buffer 205, which is accessible to the spectral feature characterization module 210.
The spectral feature characterization module 210 is configured to generate a plurality of feature streams from the frequency domain representations of the one or more frames of audible signal data. In various implementations, the plurality of feature streams generated by the spectral feature characterization module 210 includes a first feature stream (F1) that is suitable for an ensemble phoneme recognition neural network, which is included in the expert-assisted phoneme recognition neural network system 300. Additionally, in some implementations, the plurality of feature streams generated includes one or more targeted feature streams (F2 to Fn). As described below, each problematic phoneme feature stream is provided to a corresponding problematic phoneme-specific expert neural network that supports the operation of the ensemble phoneme recognition neural network.
In various implementations, the spectral feature characterization module 210 includes a characterization engine 220, a multiplexer (MUX) 211 (or selection module), and short-term spectral feature generation module 230. In various implementations, each of the plurality of feature streams (F1, F2 to Fn) includes any of a number and/or combination of signal processing features, such as mel-scaled cepstral coefficients, power normalized cepstral coefficients, linguistically informed spectral moments, frequency-domain linear prediction, group-delay function, a pitch estimation, a signal-to-noise ratio (SNR), a voice strength estimate, and a voice period variance estimate.
For example, in various implementations, the characterization engine 220 includes one or more sub-modules that are configured to analyze the frames in order to obtain feature characterization data. As shown in
In some implementations, the cepstrum analysis sub-module 221 is configured to determine the Inverse Fourier Transform (IFT) of the logarithm of a frequency domain representation of a temporal frame. In some implementations, the fundamental frequency (f0) estimation sub-module 222 is configured to provide a pitch estimate of voice activity in an audible signal. As known to those of ordinary skill in the art, pitch is generally an estimation of a dominant frequency characterizing a corresponding series of glottal pulses associated with voiced sounds. As such, the pitch estimation sub-module 222 is configured to identify the presence of regularly spaced transients generally corresponding to glottal pulses characteristic of voiced speech. In some implementations, relative amplitude and relative spacing identify the transients. In some implementations, the mel-frequency cepstrum coefficients (MFCCs) analysis sub-module 223 is configured to provide a representation of the short-term power spectrum of a frequency domain representation of a temporal frame. During MFCC processing, the logarithm is determined after passing the power spectrum through a mel-filter bank. The mel-filter bank includes a bank of triangular filters, the centers of which are at locations on the mel-scale (typically linear up to 1000 Hz and logarithmic thereafter). In some implementations, the power normalized cepstrum coefficients (PNCCs) analysis sub-module 224 is configured to provide another representation of the short-term power spectrum of a frequency domain representation of a temporal frame. The process for generating PNCCs is similar to that for generating MFCCs with a few modifications. First, a gammatone filter bank is used instead of triangular filter bank. Second, filter bank energies are filtered to remove noise and reverberation effects. Third, power law nonlinearity together with power normalization instead of a logarithm as is done in MFCC feature extraction is applied. In some implementations, linguistically informed spectral moments are calculated, providing a general description of the spectral shape of a time frame. In some implementations, Group-Delay functions are calculated using both the magnitude and phase spectra of a time frame. The two spectra are combined using multiples of themselves and an alpha and gamma parameter. In some implementations, the SNR estimation sub-module 225 is configured to estimate the signal-to-noise ratio in one or more of the frequency domain representations of the temporal frames. In some implementations, the voice strength estimation sub-module 226 is configured to provide an indicator of the relative strength of the target or dominant voice signal in a frame. In some implementations, the relative strength is measured by the number of detected glottal pulses, which are weighted by respective correlation coefficients. In some implementations, the relative strength indicator includes the highest detected amplitude of the smoothed inter-peak interval accumulation produced by an accumulator function. In some implementations, the voice period variance estimation sub-module 227 is configured to estimate the pitch variance in one or more of the frequency domain representations of the temporal frames. In other words, the voice period variance estimation sub-module 227 provides an indicator for each sub-band that indicates how far the period detected in a sub-band is from the dominant voice period P. In some implementations the variance indicator for a particular sub-band is determined by keeping track of a period estimate derived from the glottal pulses detected in that particular sub-band, and comparing the respective pitch estimate with the dominant voice period P.
In operation, the short-term spectral feature generation module 230 utilizes the MUX 211 in order to selectively activate the sub-modules of the characterization engine 220 for the generation of the plurality of feature streams (F1, F2 to Fn). In some implementations, the sub-modules that are selected are determined during the training of the network. This determination may be done using a multiple linear regression, which estimates the variance explained for a phoneme expert in a given generated feature stream. In other implementations, feature streams are selected based on a determination of linguistically relevant information for identifying a phoneme. The plurality of feature streams (F1, F2 to Fn) are provided to the expert-assisted phoneme recognition neural network system 300, which is described in greater detail with reference to
As a non-limiting example, as compared to the system 200, the system 290 additionally includes the training module 270 and a mode-selection MUX 265. In some implementations, the mode-selection MUX 265 is used to coordinate switching between training modes and detection modes, which are described below with reference to
As shown in
As a non-limiting example, the expert-assisted phoneme recognition neural network system 300, in various implementations, includes an ensemble phoneme recognition neural network 310, a phoneme-specific experts system 370, and an interface module 380. The ensemble phoneme recognition neural network 310 is configured to recognize or distinguish individual phonemes with respect to all other phonemes. For a majority of phonemes, the ensemble phoneme recognition neural network 310 performs with a relatively high level of accuracy without support from the phoneme-specific experts system 370. However, in various implementations, for problematic phonemes, the accuracy of the ensemble phoneme recognition neural network 310 is lower without the aid of the phoneme-specific experts system 370. Accordingly, the phoneme-specific experts system 370 is configured and provided to support the operation of the ensemble phoneme recognition neural network 310 in the process of recognizing problematic phonemes, which are difficult to detect and are frequently misidentified as other similar sounding phonemes.
In order to support the operation the expert-assisted phoneme recognition neural network system 300, the short-term spectral feature generation module 230 provides a plurality of feature streams (F1, F2 to Fn) for targeted uses. Each of the plurality of feature streams (F1, F2 to Fn) is generated from frequency domain representations of the one or more frames of audible signal data are stored in the frame buffer 205. In some implementations, each feature stream is provided on a frame-by-frame basis. In various implementations, the plurality of feature streams includes a first feature stream (F1) that is specifically generated (or synthesized) for the ensemble phoneme recognition neural network 310. Accordingly, in some implementations, the short-term spectral feature generation module 230 includes an ensemble feature characterization sub-module 231 that is configured to synthesize the first feature stream (F1) for use by the ensemble phoneme recognition neural network 310. The first feature stream (F1) is generated to include a sufficient number of spectral features in order to enable the ensemble phoneme recognition neural network 310 to recognize a majority of phonemes with relatively high accuracy. In some implementations, for example, the first feature stream (F1) includes approximately 35-65 spectral features. In one implementation, approximately 40 power normalized cepstral coefficients (PNCCs) are included in the first feature stream (F1).
Additionally, in various implementations, the plurality of feature streams generated by the short-term spectral feature generation module 230 includes one or more targeted problematic phoneme feature streams (F2 to Fn)—which are also referred to as target feature streams. Each of the targeted feature streams (F2 to Fn) is synthesized and provided to the phoneme-specific experts system 370 for use by a respective one of a number of constituent problematic phoneme-specific expert neural networks (PPENNs). Those of ordinary skill in the art will appreciate from the present disclosure that the targeted feature streams (F2 to Fn) are not necessarily wholly independent from one another or the first feature stream (F1). For example, PNCC coefficients in combination with other relevant features that target the second formant for “ih” versus “uh” detection may be included in two or more feature streams. In various implementations, in order to synthesize the targeted feature streams (F2 to Fn) the short-term spectral feature generation module 230 includes a respective number of problematic phoneme feature characterization (PPFC) sub-modules. Each PPFC sub-module is configured to synthesize and provide a corresponding one of the targeted feature streams (F2 to Fn) to a respective PPENN in the phoneme-specific experts system 370. As an example, the short-term spectral feature generation module 230 shown in
Each problematic phoneme feature stream (F2 to Fn) includes a respective set of targeted spectral features that characterize the a-priori phonetic and acoustic knowledge utilized to identify a particular problematic phoneme. Each respective set of targeted spectral features is beneficial to a respective PPENN for distinguishing a single target problematic phoneme as distinct from one or two other specific phonemes based linguistically supported attributes. The one or two other specific phonemes are selected because the target problematic phoneme is highly likely to be misclassified as one of these phonemes without focused attention to the spectral feature differences—that the ensemble phoneme recognition neural network 310 is not configured to provide based on the desire to tightly constrain the resources of the system 300. As an example, if the second feature stream (F2) is provided to help distinguish the phoneme “uh” from the phoneme “ih,” the first PPFC 232 is configured to generate spectral features including PNCCs and a Gammatone filtered spectrum around the 2nd and 3rd formants. Similarly, in another example, in order to distinguish “th” from “f,” a PPFC is configured to generate spectral features including PNCCs and linguistically informed spectral moments. In particular, the spectral slope is a significant source of contrast for distinguishing “th” from “f”. As another example, to distinguish “b” from “d”, a PPFC is configured to generate spectral features including PNCCs and group-delay features that isolate differences in the energy of respective plosive bursts for each sound.
For example, with reference to the feature characterization process flow 2000 of
With reference to
In some implementations, multiple variable regression is utilized to select a subset of a features, based on the extracted PNCC (2101), FDLP (2102), GD (2103) and SC (2104) features, as indicated by 2201, 2202, 2203, 2204 in
Training data is labeled such that each speech frame i has a corresponding ground-truth label yi, where yi=1 if the speech frame corresponds to that from a target phoneme, and 0 if it belongs to the competitor or any other phoneme. Applying multiple variable regression (2201, 2202, 2203, 2204) tries to fit a line using regression coefficients β, given the elements of a feature vector (e.g., Pi, Ai, Gi or Si) to predict the label yi. Here yi is used to denote the predicted label as a result of multiple variable linear regression. It assumed here that i is one of Ne examples selected for training expert network e. The regression coefficients are estimated using all examples Ne. For example, if the kth element of Pi is denoted by Pik then a linear regression using example i can be written as,
ŷi=1+β1Pi1+ . . . +βkPik+ . . . +βKPiK.
Here K is used to denote the total number of elements in the vector Pi. The goodness of a linear regression fit is usually determined by what is usually called the R2 metric which is defined:
R2=Σi=1N
Here
is used to denote the average value of all the ground-truth labels in the training set. Feature selection is carried out by setting the corresponding regression variable in the kth position, i.e., βk=0, and retaining those that contribute to increasing the R2 metric (e.g., in some implementations, the higher the value, the better). In some implementations, the R2 values and the featured indices are stored to disk (or the like) for each feature set.
In a second step for a given target vector size ranging from 1 to 110 (the total feature size of the concatenated feature vector Xi) a cumulative R2 value is calculated by looking up the records of all R2 values for all feature sizes across the four example feature types, namely—Pi, Ai, Gi and Si. Finally, the feature set combination that matches the particular target size specified by the user and has the highest cumulative R2 value is chosen (2402). The individual feature elements are chosen by looking up records of feature indices (2403) maintained for each feature type that contributed to this maximum cumulative R2 sum. If the resulting best index vector containing all of the indices is denoted by I, then elements of xi are populated by looking up elements of Xi with element indexes specified in I(2410). The output feature stream Fe (2415) corresponds to the outputs of 231,232,233 and 234 in
The ensemble phoneme recognition neural network 310 is configured to recognize individual phonemes with respect to all other phonemes in a sequence of audible signal data. The ensemble phoneme recognition neural network 310 uses the spectral features included in the first feature stream (F1) that was synthesized from the sequence of audible signal data obtained by the microphone 201. As noted above, for the majority of phonemes, the ensemble phoneme recognition neural network 310 performs with a relatively high level of accuracy without support from the phoneme-specific experts system 370. In various implementations, the ensemble phoneme recognition neural network 310 is able to recognize or distinguish a majority of phonemes with 75-80% accuracy (or above), and in some implementation within a tolerable error threshold ranging from 2-5%. However, in various implementations, for problematic phonemes, the accuracy of the ensemble phoneme recognition neural network 310 is lower without the aid of the phoneme-specific experts system 370. The problematic phonemes tend to occur rarely in nominal speech patterns for a particular language. For example, some problematic phonemes occur as low as 0.1% of the time in nominal speech patterns for a particular language, which is well below the typical lower boundary tolerable error threshold values. As a result, without the aid of the phoneme-specific experts system 370, the ensemble phoneme recognition neural network 310 is likely to misclassify a problematic phoneme as one or two other specific phonemes. In part, this is because the ensemble phoneme recognition neural network 310 is not configured to provide focused attention to the spectral feature differences. The ensemble phoneme recognition neural network 310 cannot provide that focused attention to the spectral feature differences without attendant exponential growth in computational complexity, memory demand, and inputs—which would make implementations unacceptable for low-power, real-time and/or low-latency devices, such as hearing aids and mobile devices. Accordingly, in various implementations, the ensemble phoneme recognition neural network 310 is tightly resource constrained, as compared to previously known neural network approaches.
Referring to
The input layer 320 is coupled to receive the first feature stream (F1) from the ensemble feature characterization sub-module 231. The input layer 320 includes a number of LSTM logic units 321, which are also referred to as neurons by those of ordinary skill in the art. In some such implementations, an input matrix from the features to the LSTM logic units include rectangular matrices. The size of this matrix is a function of the number of spectral features included in the first feature stream (F1). The first hidden layer 330 also includes a number of LSTM logic units 331. Similar to the input layer 320, the number of LSTM logic units 331 ranges between approximately 10-500. Those of ordinary skill in the art will appreciate that number of LSTM logic units per layer is orders of magnitude smaller than previously known approaches (being of the order of O(101)-O(102)), which allows such implementations to be embedded in highly resource-constrained devices.
In some implementations, the second hidden layer consists of as many logic units as in the input layer 320 or first hidden layer 330. In the example shown in
In various implementations, the classification layer 350 is also configured to include a number of outputs 353 that corresponds to a total number of possible unique phonemes that could be detected within continuous large vocabulary speech sequences. In some implementations, the superset of all phonemes present in any human language can be used as possible unique phoneme outputs. This superset may include more than 80 consonants, more than 30 vowels and a multitude of clicks. In other implementations, for efficiency, the set of unique phonemes will be a subset of the all-phoneme superset, tailored to a specific language (e.g., 39 phonemes for American English). The outputs 353 are coupled to a phoneme candidate selection module 360. In various implementations, the phoneme candidate selection module 360 is configured to select the top N phoneme candidates based on the corresponding values provided at the outputs 353. In some implementations, the top N phoneme candidates are the most likely phonemes present in a given frame. In some implementations, the phoneme candidate selection module 360 selects a single most likely phoneme for a frame based on the corresponding values provided at the outputs 353.
In operation, the ensemble phoneme recognition neural network 310 learns to make decisions from the combination of sub-optimal detection indicator values received from the phoneme-specific experts system 370. In particular, the ensemble phoneme recognition neural network 310 learns to balance sub-optimal detection indicator values associated with one or more conflicting problematic phonemes, as opposed to making hard decisions based on just one of the sub-optimal detection indicator values. Indicator values from the phoneme-specific experts system 370 are appended to activation values from a previous processing layer going into a subsequent layer of the ensemble phoneme recognition network 310. The indicator values are weighted appropriately when provided as higher-level features to the logic units of the subsequent layer. If the layer at which the indicator values are introduced contain recurrent logic units, the indicator values could also feedback into other logic units of the same layer through weighted recurrent connections. The weight values to logic units in the subsequent layer and current layer (recurrent connections) are learned from the data. The learning takes place in the context of a back-propagation method that works by looking misclassifications in the output layer and generating an error signal. A gradient is calculated for the weights in that layer so that the error is reduced. The error signal coming from the output layer is then propagated back to the layers below. Gradients are similarly calculated for all sets of weights in the hidden layers so that the misclassification in the output layer is reduced. The gradient updates are applied to each set of weights after looking at either an entire speech sequence or a set of speech sequences. In learning these weights by associating these indicator values to the phoneme labels during training, the network is able to learn when to use these indicator values and when to ignore them. During training, classification errors are propagated backward through the ensemble phoneme recognition network 310 in order to adjust and learn the weights so that misclassifications on subsequent examples are reduced. The errors that are propagated back to the point of entry of the indicator values are used only to update the weights connecting the outputs of the experts to logic units (of the ensemble phoneme recognition network 310) in the subsequent processing layer and the weights connecting to the logic units (of the ensemble phoneme recognition network 310) in the same layer.
In various implementations, the phoneme-specific experts system 370 includes a number of problematic phoneme-specific expert neural networks (PPENNs). As illustrated in
In various implementations, each of the three PPENNs 374, 375, 376 is included in a respective processing chain that is configured to distinguish a respective target problematic phoneme as distinct from one or two other specific phonemes. In various implementations, each processing chain is provided for at least one problematic phoneme that conflicts with at least one other problematic phoneme, in terms of being similar sounding and difficult to distinguish from one another. In other words, in some implementations, a processing chain provides a detection indicator value for at least one problematic phoneme that conflicts with at least one other problematic phoneme that is associated with another processing chain. For example, in various implementations, one or more PPENNs are provided in combination within the phoneme-specific experts system 370 as follows.
With reference to
Rather than detecting classes of phonemes like the structured neural networks of previous approaches, each of the first, second, and third PPENNs 374, 375, 376 is configured and trained to recognize, or estimate detection of, a single target problematic phoneme as distinct from one or two other specific phonemes. In some instances, but not always, the one or two other specific phonemes are within the same class of phonemes as the target problematic phoneme. The one or two other specific phonemes are selected because the target problematic phoneme is highly likely to be misclassified as one of these phonemes without focused attention to the spectral feature differences (e.g., the phonemes “uh” and “ih” are very difficult to distinguish using previously available machine-listening approaches). As noted above, the ensemble phoneme recognition neural network 310 cannot provide that focused attention to the spectral feature differences without attendant exponential growth in computational complexity, memory demand, and inputs from the short-term spectral feature generation module 230. As such, a respective output of each of the first, second, and third PPENNs 374, 375, 376 includes a corresponding detection indicator value provided to a hidden layer of the ensemble phoneme recognition neural network 310. As described above, in some implementations, the detection indicator values are provided to logic units in the second hidden layer 340. Additionally and/or alternatively, in some implementations, the detection indicator values are provided to logic units in the first hidden layer 330 and/or to another hidden layer (not shown) included between the second hidden layer 340 and the classification layer 350. In some implementations, the detection indicator value provides an indication characterizing when the PPENN has detected the target problematic phoneme in accordance with a detection threshold associated with the target problematic phoneme.
As noted above, the plurality of feature streams generated by the short-term spectral feature generation module 230 includes one or more targeted feature streams (F2 to Fn)—the corresponding second, third and fourth feature streams (F2, F3, F4) as illustrated in
The transformed feature streams (F2, F3, F4) are provided to the respective PPENNs 374, 375, 376. Each of the PPENNs 374, 375, 376 then operates to determine a corresponding detection indicator value. In some implementations, the detection indicator value provides an indication characterizing when a PPENN has detected the target problematic phoneme in accordance with a detection threshold. In some implementations, each of one or more problematic phonemes is associated with a particular corresponding detection threshold based on the targeted spectral features selected for use by a particular PPENN. In some implementations, the detection indicator value provides a confidence level (e.g., a probability value) characterizing the extent to which portions of an audible signal satisfy a detection threshold. In some implementations, the detection indicator value provides a flag indicating a binary detection result.
The detection indicator values are provided to the interface module 380. In various implementations, the interface module 380 includes a number of logic units configured to provide a gating function between the phoneme-specific experts system 370 and the ensemble phoneme recognition neural network 310. More specifically, with reference to
The interface module 380 helps to interface the output of the phoneme-specific experts system 370 with the ensemble phoneme recognition neural network 310. A phoneme-specific expert could have either one or two outputs. In some implementations, in the case of a single output (with an output sigmoidal unit), the value is ranges between 0 and 1. A high value indicates the presence of target phoneme, and a zero indicates otherwise. In some implementations, in the case of two outputs (with a soft-max layer), one of the outputs indicates the presence of the target phoneme and the other output indicates the presence of a competitor phoneme. In some implementations, in the soft-max layer both outputs are constrained to sum to 1, and the two outputs are complementary to each other.
Considering experts with two outputs per expert, the outputs from all experts can be collected into a vector:
pt=[p1 1−p1 p2 1−p2 . . . pE 1−pE].
In some implementations, the interface module 380 utilizes the vector pt within a function ƒ operating on the vector pt to produce a vector output qt=ƒ(pt). In various implementations, the function can range in complexity between an identity function to a more complex non-linear function like a typical neural network sigmoidal unit or a set of LSTM/GRU units. This output vector qt is then weighted by a matrix Wqx (x denotes the respective input/gate of the LSTM unit in the next layer) and appears as an additive term to all of the LSTM equations described below with reference to
ht=ot tan h(ct) (i)
ot=tan h(Wxoxt+Whoht−1+Wqoqt+bo) (ii)
ƒt=tan h(Wxƒxt+Whƒht−1+Wqƒqt+bƒ) (iii)
it=tan h(Wxixt+Whiht−1+Wqiqt+bi) (iv)
rt=tan h(Wxcxt+Whcht−1+Wqcqt+bc) (v)
As noted above with reference to
In addition to the three processing chains including the respective three PPENNs 374, 375, 376, the phoneme-specific experts system 470 also includes another processing chain including fourth and fifth PPENNs 473, 474, having outputs that are combined into a single detection indicator value. The fourth and fifth PPENNs 473, 474 are provided for two respective problematic phonemes that do not conflict with one another, in terms of being similar sounding and difficult to distinguish from one another. The fourth PPENN 473 is provided in series between a fourth feature transform module 471 and a combiner 475. Similarly, the fifth PPENN 474 is provided in series between a fifth feature transform module 472 and the combiner 475. The fourth feature transform module 471 is coupled to receive a fifth feature stream (F5) from a respective sub-module (not shown) in the short-term spectral feature generation module 230. Similar to the first feature transform module 371, the fourth feature transform module 471 is configured to emphasize differences in the spectral features between a fourth single target problematic phoneme and the one or two other specific phonemes. The fifth feature transform module 472 is coupled to receive a sixth feature stream (F6) from a respective sub-module (not shown) in the short-term spectral feature generation module 230. Also similar to the first feature transform module 371, the fifth feature transform module 472 is configured to emphasize differences in the spectral features between a fifth single target problematic phoneme and the one or two other specific phonemes. The combiner 475 is configured to combine respective detection indicator values provided by the fourth and fifth PPENNs 473, 474 into a single detection indicator value, which is provided to a fourth output gate 476.
Additionally, in various implementations, the interface module 380 of
In order to describe the operation of LSTM logic unit 500, vector and scalar mathematical variables are used. Vector quantities are described in bold, e.g., xt. Scalar quantities are indicated in regular font, e.g., ct−1. As shown in
ht=ot tan h(ct) (1)
In equation (1), ot is the output value of the output gate ot (533), which modulates the amount of memory content exposure. In some implementations, the output gate value is provided by equation (2) as follows:
ot=tan h(Wxoxt+Whoht−1+bo) (2)
In various implementations, the forget gate ƒt (531) is configured to modulate the extent to which the existing memory of the LSTM logic unit 500 is forgotten. In some implementations, the forget gate value is provided by equation (3) as follows:
ƒt=tan h(Wxƒxt+Whƒht−1+bƒ) (3)
Similarly, the input gate it (532) is configured to modulate the degree to which the new memory content is added to the memory cell content of the LSTM logic unit 500. In some implementations, the input gate value is provided by equation (4) as follows:
it=tan h(Wxixt+Whiht−1+bi) (4)
In order to calculate new cell content ct an intermediate quantity rt (534) is calculated by equation (5) as follows:
rt=tan h(Wxcxt+Whcht−1+bc) (5)
In turn, updated content for the new content memory cell ct (512) is determined by equation (6) as follows:
ct=ƒtct−1+itrt (6)
With reference to equations (1) to (6), the matrices Wx* are weights, and the vectors b* are biases. The values of the weight matrices Wx* are adjusted during a training mode of a LSTM based neural network until an error convergence threshold is satisfied. In some implementations, the weights are further adjusted during nominal operation, as the neural network learns from real-valued audible signal data.
ht=(1−zt)ht−1+zt{tilde over (h)}t (6)
The update gate zt (571) is configured to determine how much GRU logic unit 550 the updates the activation, or content, and is provided by equation (7) as follows:
zt=sigm(Wxzxt+Whzht−1+bz) (7)
The reset gate rt (572) value is similarly provided by equation (8) as follows:
rt=sigm(Wxrxt+Whrht−1+br) (8)
In turn, the candidate activation gate lit value is provided by equation (9), where ∘ denotes elementwise multiplication between the two vectors:
{tilde over (h)}t=tan h(Wxhxt+Whh(rt∘ht−1)+bh) (9)
As represented by block 6-1, the method 600 includes selecting a target problematic phoneme. A phoneme is considered problematic when it occurs rarely (e.g., below a frequency of occurrence threshold) in nominal speech patterns and/or is particularly difficult to distinguish from a similar sounding phoneme without focused attention to the spectral feature differences between the two. As represented by block 6-2, the method 600 includes identifying at least one conflicting phoneme associated with the target problematic phoneme. A conflicting phoneme is a phoneme that the target problematic phoneme is often misidentified as because the two phonemes sound similar and/or have difficult to distinguish spectral features. For example, with reference to
As represented by block 6-3, the method 600 includes synthesizing a targeted training data set including an overemphasis of examples of the target problematic phoneme. For example, with reference to
As represented by block 6-4, the method 600 includes determining phonetic properties (articulatory properties) that distinguish the target problematic phoneme and the at least one conflicting phoneme from one another. For example, with reference to
Returning to
As an example of targeted training data, consider a simplified sequence of targeted training data 700, shown in
The left-constrained portion 711 is included in the left-context 701 of the training data instance 715 of the phoneme “uh,” and the right-constrained portion 712 is included in the right-context 702. In various implementations, the left-constrained portion 711 provides a transition from “non-uh” training data to “uh” training data. Similarly, right-constrained portion 712 provides a transition from “uh” training data to “non-uh” training data. In various implementations, each of the left-constrained and the right-constrained portion 712 include approximately 5 to 25 frames of “non-uh” training data. The left-context 701 and the right-context 702 also both include randomized “non-uh” training frames, although not necessarily constrained. In various implementations, each of the left-context 701 and the right-context 702 include approximately 20 to 100 frames of “non-uh” training data. Moreover, in various implementations, the left and right contexts 701, 702 include limited portions (20-50 msec) of the preceding and succeeding phonemes, thus forcing a PPENN to learn to recognize the target problematic phoneme from within arbitrary preceding and succeeding phonemes, rather than as sequences of phonemes.
Returning to
As represented by block 6-8, the method 600 includes determining whether or not there are additional problematic phonemes for which an associated PPENN can be trained for a particular implementation. If there are additional problematic phonemes (“Yes” path from block 6-8), the method 600 circles back to the portion of the method represented by block 6-1. On the other hand, if there are no additional problematic phonemes left to consider (“No” path from block 6-8), as represented by block 6-9, the method 600 includes training an ensemble phoneme recognition neural network to work in concert with the associated trained PPENNs. For example, with reference to
As represented by block 8-1, the method 800 includes initializing each of constituent neural networks of an expert-assisted phoneme recognition neural network system with weights generated during a training mode. For example, with reference to
As represented by block 8-5, the method 800 includes selecting a frequency domain representation of a temporal frame of the audible signal data. As represented by block 8-6, the method 800 includes synthesizing a first feature stream (F1) for an ensemble phoneme recognition neural network. For example, with reference to
As represented by block 8-8, the method 800 includes determining a respective one or more detection indicator values from the one or more targeted feature streams (F2 to Fn) using a corresponding one or more PPENNs. For example, with reference to
As represented by block 8-9, the method 800 includes providing the one or more detection indicator values to the ensemble phoneme recognition neural network. For example, with reference to
As a non-limiting example, in some implementations the system 900 includes the microphone 201, the frame buffer 205, the formant templates buffer 260, one or more processing units (CPU's) 912, one or more local I/O (input/output) interfaces 913, an allocation of programmable logic and/or non-transitory memory (local storage) 901, and one or more communication buses 914 for interconnecting these and various other components not illustrated for the sake of brevity.
In some implementations, the communication buses 914 include circuitry that interconnects and controls communications between the various components of the system 900. In various implementations the programmable logic and/or non-transitory memory 901 includes a suitable combination of a programmable gate array (such as an FPGA or the like), high-speed random access memory, such as DRAM, SRAM, DDR RAM or other random access solid state memory devices; and may include non-volatile memory, such as one or more magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. The programmable logic and/or non-transitory memory 901 optionally includes one or more storage devices remotely located from the CPU(s) 912. The programmable logic and/or non-transitory memory 901 comprises a non-transitory computer readable storage medium. In some implementations, the programmable logic and/or non-transitory memory 901 includes the following programs, modules and data structures, or a subset thereof including a programmable logic controller (and/or an optional operating system) 911, time series conversion logic 903, frequency domain conversion logic 904, a feature characterization module 910, a phoneme recognition neural network 940, a speech (or text) re-synthesis module 980, and a training module 990.
The programmable logic controller 911 includes implementations of functions and procedures for handling various system services and for performing hardware dependent tasks. In some implementations, the programmable logic controller 911 includes some or all of an operating system executed by the CPU(s) 912.
In some implementations, the times series conversion module 903 is configured to generate two or more temporal frames of audible signal data from a continuous stream of audible signal data. Each temporal frame of audible signal data includes a temporal portion of the audible signal received by the microphone 201. In some implementations, the times series conversion module 903 includes a windowing module that is configured to mark and separate one or more temporal frames or portions of the audible signal data for times t2, . . . , tn. To that end, the times series conversion module 903 includes heuristics and metadata 903a.
In some implementations, the frequency domain conversion logic 904 is configured to generate a corresponding frequency domain representation for each of the one or more temporal frames, so that one or more spectral characteristics of the audible signal data can be determined for each frame. In some implementations, the frequency domain representation of a temporal frame includes at least one of a plurality of sub-bands contiguously distributed throughout the frequency spectrum associated with voiced sound. To that end, the frequency domain conversion logic 904 includes heuristics and metadata 904a. In some implementations, for example, the frequency domain conversion logic 904 includes a Fast Fourier Transform (FFT) sub-module. The frequency domain representations of the frames are stored in the frame buffer 205, which is accessible to the spectral feature characterization module 910.
In some implementations, the feature characterization module 910 is configured to generate a plurality of feature streams from frequency domain representations of the one or more frames of audible signal data. In various implementations, the plurality of feature streams generated by the feature characterization module 910 includes a first feature stream (F1) that is suitable for an ensemble phoneme recognition neural network. Additionally, in some implementations, the plurality of feature streams generated includes one or more targeted feature streams (F2 to Fn) that are suitable for corresponding PPENNs. As described above, each problematic phoneme feature stream is provided to a corresponding PPENN that supports the operation of the ensemble phoneme recognition neural network.
In various implementations, the feature characterization module 910 includes a short-term spectral feature generation module 930. In various implementations, the short-term spectral feature generation module 930 is configured to synthesize the plurality of feature streams (F1, F2 to Fn). Each of the plurality of feature streams (F1, F2 to Fn) includes any of a number and/or combination of signal processing features, such as spectra, cepstra, mel-scaled cepstra coefficients, power normalized cepstral coefficients, fundamental frequency (f0), a signal-to-noise ratio (SNR), a voice strength estimate, and a voice period variance estimate. For example, in some implementations, the short-term spectral feature generation module 930 includes a power normalized cepstral coefficients analysis sub-module 931, a mel-frequency cepstrum coefficients analysis sub-module 932, and a cepstrum analysis sub-module 933.
In some implementations, the phoneme recognition neural network 940 is configured to recognize individual phonemes with respect to all other phonemes within audible signal data. To that end, the phoneme recognition neural network 940 includes an ensemble phoneme recognition neural network 950, an interface module 960, and a number of problematic phoneme experts 970. The ensemble phoneme recognition neural network 950 is configured to recognize individual phonemes with respect to all other phonemes in a sequence of audible signal data. The ensemble phoneme recognition neural network 950 uses the spectral features included in the first feature stream (F1) that was synthesized from the sequence of audible signal data obtained by the microphone 201. As noted above, for the majority of phonemes, the ensemble phoneme recognition neural network 950 performs with a relatively high level of accuracy without support from the problematic phoneme experts system 970. In some implementations, the ensemble phoneme recognition neural network 950 includes a phoneme candidate selection module 951. In various implementations, the phoneme candidate selection module 951 is configured to select the top N phoneme candidates produced by the ensemble phoneme recognition neural network 950.
The interface module 960 includes a number of logic units configured to provide a gating function between the problematic phoneme experts 970 and the ensemble phoneme recognition neural network 950. As shown in
In some implementations, the speech (or text) re-synthesis module 980 is configured to use the output of the ensemble phoneme recognition neural network 950 in combination with formant templates (stored in buffer 260) in order to re-synthesize an audible speech signal (or a text translation) of the audible signal data received by the microphone 201.
In some implementations, the training module 990 is configured to train the various portions of the phoneme recognition neural network 940. As shown in
While various aspects of implementations within the scope of the appended claims are described above, it should be apparent that the various features of implementations described above may be embodied in a wide variety of forms and that any specific structure and/or function described above is merely illustrative. Based on the present disclosure one skilled in the art should appreciate that an aspect described herein may be implemented independently of any other aspects and that two or more of these aspects may be combined in various ways. For example, an apparatus may be implemented and/or a method may be practiced using any number of the aspects set forth herein. In addition, such an apparatus may be implemented and/or such a method may be practiced using other structure and/or functionality in addition to or other than one or more of the aspects set forth herein.
It will also be understood that, although the terms “first,” “second,” etc. may be used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first feature could be termed a second feature, and, similarly, a second feature could be termed a first feature, which changing the meaning of the description, so long as all occurrences of the “first feature” are renamed consistently and all occurrences of the “second feature” are renamed consistently. The first feature and the second feature are both features, but they are not the same feature.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the claims. As used in the description of the embodiments and the appended claims, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As used herein, the term “if” may be construed to mean “when” or “upon” or “in response to determining” or “in accordance with a determination” or “in response to detecting,” that a stated condition precedent is true, depending on the context. Similarly, the phrase “if it is determined [that a stated condition precedent is true]” or “if [a stated condition precedent is true]” or “when [a stated condition precedent is true]” may be construed to mean “upon determining” or “in response to determining” or “in accordance with a determination” or “upon detecting” or “in response to detecting” that the stated condition precedent is true, depending on the context.
Number | Name | Date | Kind |
---|---|---|---|
20100057452 | Mukerjee | Mar 2010 | A1 |
20100217589 | Gruhn | Aug 2010 | A1 |
20140365221 | Ben-Ezra | Dec 2014 | A1 |
Entry |
---|
Graves, et al., “Connectionist Temporal Classification: Labelling Unsegmented Sequence Data with Recurrent Neural Networks”, Proceedings of the 23 rd International Conference on Machine Learning, 2006, 8 pages. |
Chung, et al., “Gated Feedback Recurrent Neural Networks”, Jun. 17, 2015, 9 pages. |
Chung, et al., “Empirical Evaluation of Gated Recurrent Neural Networks on Sequence Modeling”, Dec. 11, 2014, 9 pages. |
Cho, et al., “Learning Phrase Representations using RNN Encoder-Decoder for Statistical Machine Translation”, Proceedings of the 2014 Conference on Empirical Methods in Natural Language Processing (EMNLP), pp. 1724-1734, Oct. 25-29, 2014. |
Jozefowicz, et al., “An Empirical Exploration of Recurrent Network Architectures”, Proceedings of the 32nd International Conference on Machine Learning, 2015, vol. 37, 9 pages. |
Graves, et al., “Framewise Phoneme Classification with Bidirectional LSTM and Other Neural Network Architectures”, IJCNN 2005 conference proceedings, 8 pages. |
Graves, “Generating Sequences With Recurrent Neural Networks”, Jun. 5, 2014, 43 pages. |
Number | Date | Country | |
---|---|---|---|
62322163 | Apr 2016 | US |