An arrangement for processing a speech message which uses arbitrary value codes to form time frame excitation signals. The arbitrary value codes, e.g., random numbers, are stored as well as signals indexing the codes and transform domain signals corresponding to the arbitrary codes are generated. The speech message is partitioned into time frame interval speech patterns and a first signal representative of the transform domain speech pattern of each successive time frame interval is formed responsive to the partitioned speech message. A plurality of second signals representative of time frame interval patterns corresponding to the transform code signals are generated responsive to said set of transform signals. One of the arbitrary code signals is selected jointly responsive to the first and second signals of each successive time interval to represent the time frame speech signal excitation, and the index signal corresponding to said selected arbitrary code signal is output. A replica of the speech message is formed from the arbitrary codes by concatenating a sequence of said arbitrary codes identified by the output index signals.
|
15. A method for producing a speech message comprising
receiving a sequence of speech message signals for the successive time intervals of the speech message, each time interval speech message signal including a set of transform-domain-coded signals representative of the time interval portion of the speech message, at least a portion of which are index signals corresponding to a known set of random codes; storing said known set of random codes in one-for-one association with the corresponding index signals; generating said codes sequentially for each of the set of index signals; and controlling speech wave generation for said time interval in response to said sequentially generated random codes.
13. Apparatus for providing a speech message comprising
means for receiving a sequence of speech message signals for the successive time intervals of the speech message, each time interval speech message signal including a set of transform-domain-coded signals representative of the time interval portion of the speech message, at least a portion of which are index signals corresponding to a known set of random codes means for storing said known set of random codes in one-for-one association with the corresponding index signals means for generating said random codes for each of the set of index signals, and means for controlling speech wave generation for said time interval in response to said generated random codes.
7. A method for encoding speech comprising the steps of
storing a set of signals each representative of a random code and a set of index signals each identifying one of the random codes; partitioning the speech into successive time frame interval portions; forming a time-domain signal representative of the portion of speech in each successive time frame interval; generating at least one transform domain signal from each such time-domain signal; generating a transform domain code signal responsive to each random code signal, via the same type of transformation as in the aforesaid steps of generating a transform domain signal; cross-correlating transform domain signals for each time frame interval with each of said transform domain code signals to select one of the transform domain code signals as yielding minimum error or maximum similarly as a representative of the speech portion in the time-frame interval; and outputting the index signal corresponding to the random code signal corresponding to the selected transform domain code signal.
12. A method for encoding speech comprising
storing a set of signals each representative of a random code and a set of index signals each identifying one of the random codes; partitioning the speech into successive time frame interval portions; forming a time-domain signal representative of the portion of speech in each successive time frame interval; generating at least one transform domain signal from each such time-domain signal; generating a transform domain code signal responsive to each random code signal via the same type of transformation as in the aforesaid step of generating a transform domain signal; responding in a comparative fashion to transform domain signals for each time frame interval and, for each such signal, to each of said transform domain code signals to select one of the transform domain code signals as yielding minimum error or maximum similarity as a representative of the speech portion in the time frame interval; and outputting the index signal corresponding to the random code signal corresponding to the selected transform.
1. Apparatus for encoding speech comprising
means (330) for storing a set of signals each representative of a random code and a set of index signals each identifying one of the random codes; means (203 through 247 except 225 and 245) for partitioning the speech into successive time frame interval portions and for forming a time-domain signal representative of the portion of speech in each successive time frame interval; means (225, 245, 250) for generating at least one transform domain signal from each such time-domain signal; means (305) responsive to each random code signal for generating a transform domain code signal corresponding thereto, via the same type of transformation as in the aforesaid means for generating a transform domain signal; means (315 and 320, or 501 through 520 and 320) for cross-correlating transform domain signals for each time frame interval with each of said transform domain code signals to select one of the transform domain code signals as yielding minimum error or maximum similarity as a representative of the speech portion in the time-frame interval; and means (325) for outputting the index signal corresponding to the random code signal corresponding to the selected transform domain code signal.
6. Apparatus for encoding speech comprising
means (330) for storing a set of signals each representative of a random code and set of index signals each identifying one of the random codes; means (203 through 247 except 225 and 245) for partitioning the speech into successive time frame interval portions and for forming a time-domain signal representative of the portion of speech in each successive time frame interval; means (225, 245, 250) for generating at least one transform domain signal from each such time-domain signal; means (305) responsive to each random code signal for generating a transform domain code signal corresponding thereto, via the same type of transformation as in the aforesaid means for generating a transform domain signal; means (315 and 320 or 501 through 520 and 320) for responding in a comparative fashion to transform domain signals for each time frame interval and, for each such signal, to each of said transform domain code signals to select one of the transform domain code signals as yielding minimum error or maximum similarity as a representative of the speech portion in the time frame interval; and means (325) for outputting the index signal corresponding to the random code signal corresponding to the selected transform domain code signal.
2. Apparatus for encoding speech of the type claimed in
the means for generating at least one trnsform domain signal comprises means for generating a transform domain signal representative of the predictive parameters from said time domain signal representative of the predictive parameters; and the means for generating at least one transform domain signal further comprises means (225, 245) for generating a transform domain signal representative of predictive characteristics for said portion of speech; the means for cross-correlating includes means responsive to the predictive characteristics representative signal for forming a signal (γ) representative of the relative scaling of the transform domain code signal with respect to a transform domain signal representative of the predictive parameters for each time frame interval; and the outputting means comprises means for outputting the relative scaling signal and the signal representative of the predictive parameters.
3. Apparatus for encoding speech of the type claimed in
the means for forming a time domain signal as representative of the portion of speech in each successive time frame interval comprises means (209, 213, 215) for generating a set of signals representative of the predictive parameters of the speech in each successive time frame interval; means (207, 211) for forming a signal representative of the predictive residual for the speech in each successive time frame interval; and means (217, 227, 222, 235, 240, 247) responsive to the predictive residual generating means and to the predictive parameter signal generating means for removing the contribution attributable to speech from the previous time frame.
4. Apparatus for encoding speech of the type claimed in
means (220, 230), responsive to the predictive residual generating means, for producing pitch predictive parameters including contributions of previous frames; and the combining means of the outputting means is responsive to said means for producing pitch predictive parameters.
5. Apparatus for encoding speech of the type claimed in either of
means (501) for cross-correlating all three of said predictive-parameter-representative transform domain signal, said transform domain signal representative of the relative scaling for the portion of speech, and said transform domain code signal; means (505, 510, 515, 520) responsive to the output of the means for cross-correlating specifically and to one or more of the three signals for producing the relative scaling signal (γ) and for producing a cross-correlation error signal (E(k)).
8. A method for encoding speech of the type claimed in
the step of generating at least one transform domain signal comprises generating a transform domain signal representative of the predictive parameter from said time domain signal representative of the predictive parameters; and the step of generating at least one transform domain signal further comprises step of generating a transform domain signal representative of predictive characteristics for said portion of speech; the step of cross-correlating includes the step of forming a signal (γ) representative of the relative scaling of the transform domain code signal with respect to a transform domain signal representative of the predictive parameters for each time frame interval in response to the representative signal representative of the energy predictive characteristics; and the outputting means comprises means for outputting the relative scaling signal and the signal representative of the predictive parameters.
9. A method for encoding speech of the type claimed in
the step of forming a time domain signal as representative of the pattern of the portion of speech in each successive time frame interval comprises generating a set of signals representative of the predictive parameters of the speech in each successive time frame interval; forming a signal representative of the predictive residual for the speech in each successive time frame interval; and removing the contribution attributable to speech from the previous time frame in response to the predictive residual generating means and to the predictive parameter signal generating means. 10. Apparatus for encoding speech of the type claimed in
producing pitch predictive parameters including contributions of previous frames in response to the predictive residual representative signal; and the combining step also combines said pitch predictive parameters.
11. A method for encoding speech of the type claimed in either of
specifically cross-correlating all three of said predictive-parameter-representative transform domain signal, said transform domain signal representative of the relative scaling for the portion of speech, and said transform domain code signal; applying the output of the specifically cross-correlating step and one or more of the three signals to produce the relative scaling signal (γ) and a cross-correlation error signal (E(k)).
14. Apparatus of the type claimed in
in which the storing means comprises means for storing the random codes sequentially so that a first portion of each succeeding one is derived from the latter portion of the preceding one. 16. Apparatus for processing input speech signals occurring over one or more successive time frame intervals comprising
means (e.g., 203, 205) for forming first signals representative of said speech signals for each of said time frame intervals, means (e.g., 305) for providing a set of transform domain representations of a corresponding set of codes each of said codes being representative of possible speech signals over a time frame interval, and for providing a set of index signals, each identifying one of said codes, means (e.g., 315) for generating a set of similarity signals corresponding to the similarity of said first signals to each of said set of transform domain representations, means (e.g., 320) for generating index signals corresponding to codes having transform domain representations giving rise to similarity signals meeting a predetermined criterion. 17. Apparatus according to forming first signals representative of said speech signals for each of said time frame intervals, providing a set of transform domain representations of a corresponding set of codes each of said codes being representative of possible speech signals over a time frame interval, and for providing a set of index signals, each identifying one of said codes, generating a set of similarity signals corresponding to the similarity of said first signals to each of said set of transform domain representations, generating index signals corresponding to codes having transform domain representations giving rise to similarity signals meeting a predetermined
criterion. 21. The method according to claim 20, wherein said step of forming first signals comprises forming a perceptually weighted representation of said input speech signals. 22. The method according to claim 20, wherein said step of providing a set of transform domain representations comprises accessing a set of stored transform domain signals. 23. The method according to claim 20, wherein said forming first signals comprises reducing for each time frame interval any contribution to said first signal arising from speech signals occurring during another time frame interval. |
The Government has rights in this invention pursuant to Contract No. MDA904-84-C-6010 awarded by Maryland Procurement Office.
Our invention relates to speech processing and more particularly to digital speech coding arrangements.
Digital speech communication systems including voice storage and voice response facilities utilize signal compression to reduce the bit rate needed for storage and/or transmission. As is well known in the art, a speech pattern contains redundancies that are not essential to its apparent quality. Removal of redundant components of the speech pattern significantly lowers the number of digital codes required to construct a replica of the speech. The subjective quality of the speech replica, however, is dependent on the compression and coding techniques.
One well known digital speech coding system such as disclosed in U.S. Pat. No. 3,624,302 issued Nov. 30, 1971 includes linear prediction analysis of an input speech signal. The speech signal is partitioned into successive intervals of 5 to 20 milliseconds duration and a set of parameters representative of the interval speech is generated. The parameter set includes linear prediction coefficient signals representative of the spectral envelope of the speech in the interval, and pitch and voicing signals corresponding to the speech excitation. These parameter signals may be encoded at a much lower bit rate than the speech signal waveform itself. A replica of the input speech signal is formed from the parameter signal codes by synthesis. The synthesizer arrangement generally comprises a model of the vocal tract in which the excitation pulses of each successive interval are modified by the interval spectral envelope representative prediction coefficients in an all pole predictive filter.
The foregoing pitch excited linear predictive coding is very efficient and reduces the coded bit rate, e.g., from 64 kb/s to 2.4 kb/s. The produced speech replica, however, exhibits a synthetic quality that makes speech difficult to understand. In general, the low speech quality results from the lack of correspondence between the speech pattern and the linear prediction model used. Errors in the pitch code or errors in determining whether a speech intervals is voiced or unvoiced cause the speech replica to sound disturbed or unnatural. Similar problems are also evident in formant coding of speech. Alternative coding arrangements in which the speech excitation is obtained from the residual after prediction, e.g., APC, provide a marked improvement because the excitation is not dependent upon an inexact model. The excitation bit rate of these systems, however, is at least an order of magnitude higher than the linear predictive model. Attempts to lower the excitation bit rate in the residual type systems have generally resulted in a substantial loss in quality.
The article "Stochastic Coding of Speech Signals at Very Low Bit Rates" by Bishnu S. Atal and Manfred Schroeder appearing in the Proceedings of the International Conference on Communications-ICC '84, May 1984, pp. 1610-1613, discloses a stochastic model for generating speech excitation signals in which a speech waveform is represented as a zero mean Gaussian stochastic process with slowly-varying power spectrum. The optimum Gaussian innovation sequence is obtained by comparing a speech waveform segment, typically 5 ms. in duration, to synthetic speech waveforms derived from a plurality of random Gaussian innovation sequences. The innovation sequence that minimizes a perceptual error criterion is selected to represent the segment speech waveform. While the stochastic model described in this article results in low bit rate coding of the speech waveform excitation signal, a large number of innovation sequences are needed to provide an adequate selection. The signal processing required to select the best innovation sequence involves exhaustive search procedures to encode the innovation signals, but such search arrangements for code bit rates corresponding to 4.8 Kbit/sec code generation are very time consuming even when processed onlarge, high speed scientific computers. It is an object of the invention to provide improved speech coding and synthesis of high quality at lower bit rates utilizing arbitrary codes.
The foregoing object is realized by replacing the exhaustive search of innovation sequence stochastic or other arbitrary codes of a speech analyzer with an arrangement that converts the stochastic codes into transform domain code signals and generates a set of transform domain patterns from the transform codes for each time frame interval. The transform domain code patterns are compared to the transfer of the time interval speech pattern obtained from the input speech to select the best matching stochastic code and an index signal corresponding to the best matching stochastic code is output to represent the time frame interval speech. Transform domain processing reduces the complexity and the time required for code selection.
The index signal is applied to a decoder in which it is used to select a stochastic code stored therein. In a predictive speech synthesizer, the stochatic codes may represent the time frame speech pattern excitation signal whereby the code bit rate is reduced to that required for the index signals and the prediction parameters of the time frame. The stochastic codes may be predetermined overlapping segments of a string of stochastic numbers to reduce storage requirements.
The invention is directed to an arrangement for processing a speech message in which a set of arbitrary value code signals such as random numbers together with index signals indentifying the arbitrary value code signals and signals representative of transforms of the arbitrary valued codes are formed. The speech message is partitioned into time frame interval speech patterns and a first signal representative of the speech pattern of each successive time frame interval is formed responsive to the partitioned speech. A plurality of second signals representative of time frame interval patterns formed from the transform domain code signals are generated. One of said artirary code signals is selected for each time frame interval jointly responsive to the first signal and the second signals of the time frame interval and the index signal corresponding to said selected transform signal is output.
According to one aspect of the invention, forming of the first signal includes generating a third signal that is a transform domain signal corresponding to the current time frame interval speech pattern and the generation of each second signal includes producing a fourth signal that is a transform domain signal corresponding to a time frame interval pattern responsive to said transform domain code signals. Arbitrary code selection comprises generating a signal representative of the similarities between said third and fourth signals and determining the index signal corresponding to the fourth signal having the maximum similarities signal.
According to another aspect of the invention, the transform domain code signals are frequency domain transform codes derived from the arbitrary codes.
According to yet another aspect of the invention, the transform domain code signals are Fourier transforms of the arbitrary codes.
According to yet another aspect of the invention, a speech message is formed from the arbitrary codes by receiving a sequence of said outputted index signals, each identifying a predetermined arbitrary code. Each index signal corresponds to a time frame interval speech pattern. The arbitrary codes are concatenated responsive to the sequence of said received index signals and the speech message is formed responsive to the concatenated codes.
According to yet another aspect of the invention, a speech message is formed using a string of arbitrary value coded signals having predetermined segments thereof identified by index signals. A sequence of signals identifying predetermined segments of said string are received. Each of said signals of the sequence corresponds to speech patterns of successive time frame intervals. The predetermined segments of said arbitrary value code string are selected responsive to the sequence of received identifying signals and the selected arbitrary codes are concatenated to generate a replica of the speech message.
According to yet another aspect of the invention, the arbitrary value signal sequences of the string are overlapping sequences.
FIG. 1 depicts a speech encoder utilizing a prior art stochastic coding arrangement;
FIGS. 2 and 3 depict a general block diagram of a digital speech encoder usin arbitrary codes and transform domain processing that is illustrative of the invention;
FIG. 4 depicts a detailed block diagram of digital speech encoding signal processing arrangement that performs the functions of the circuit shown in FIGS. 2 and 3;
FIG. 5 shows a block diagram of an error and scale factor generating circuit useful in the arrangement of FIG. 3;
FIGS. 6-11 show flow chart diagrams that illustrate the operation of the circuit of FIG. 4; and
FIG. 12 shows a block diagram of a speech decoder circuit illustrative of the invention in which a string of random number codes form an overlapping sequence of stochastic codes.
FIG. 1 shows a prior art digital speech coder arranged to use stochastic codes for excitaion signals. Referring to FIG. 1, a speech pattern applied to microphone 101 is converted therein to a speech signal which is band pass filtered and sampled in filter and sampler 105 as is well known in the art. The resulting samples are converted into digital codes by analog-to-digital converter 110 to produce digitally coded speech signal s(n). Signal s(n) is processed in LPC and pitch predictive analyzer 115. The processing includes dividing the coded samples into successive speech frame intervals and producing a set of parameter signals corresponding to the signal s(n) in each successive frame. Parameter signals a(1), a(2), . . . a(p) represent the short delay correlation or spectral related features of the interval speech pattern, and parameter signals β(1), β(2), β(3), and m represent long delay correlation or pitch related features of the speech pattern. In this type of coder, the speech signal is partitioned in frames or blocks, e.g., 5 msec or 40 samples in duration. For such blocks, stochastic code store 120 may contain 1024 random white Gaussian codeword sequences, each sequence comprising a series of 40 random numbers. Each codeword is scaled in scaler 125, prior to filtering, by a factor γ that is constant for the 5 msec block. The speech adaptation is done in recursive filters 135 and 145.
Filter 135 uses a predictor with large memory (2 to 15 msec) to introduce voice periodicity and filter 145 uses a predictor with short memory (less than 2 msec) to introduce the spectral envelope in the synthetic speech signal. Such filters are described in the article "Predictive coding of speech at low bit rates" by B. S. Atal appearing in the IEEE Transactions on Communications, Vol. COM-30, pp. 600-614, April 1982. The error representing the difference between the original speech signal s(n) applied to differencer 150 and synthetic speech signal s(n) applied from filter 145 is further processed by linear filter 155 to attenuate those frequency components where the error is perceptually less important and amplify those frequency components where the error is perceptually more important. The stochastic code sequence from store 120 which produces the minimum mean-squared subjective error signal E(k) and the corresponding optimum scale factor γ are selected by peak picker 170 only after processing of all 1024 code word sequences in store 120.
For purposes of analyzing the codeword processing of the circuit of FIG. 1, synthesis filters 135 and 145 and perceptual weighting filter 155 can be combined into one linear filter. The impulse response of this equivalent filter may be represented by the sequence f(n). Only a part of the equivalent filter output is determined by its input in the current 5 msec frame since, as is well known in the art, a portion of the filter output corresponds to signals carried over from preceding frames. The filter memory from the previous frames plays no role in the search for the optimum innovation sequence in the present frame. The contributions of the previous memory to the filter output in the present frame can thus be subtracted from the speech signal in determining the optimum code word from stochastic code stoe 120. The residual after subtracting the contributions of the filter memory carried over from the previous frames may be represented by the signal x(n). The filter output contributed by the kth codeword from store 120 in the present frame is ##EQU1## where c(k) (i) is the ith sample of the kth codeword. One can rewrite equation 1 in matrix notations as
t(k)=γ(k)Fc(k),
where F is a N×N matrix with the term in the nth row and the ith column given by f(n-i). The total squared error E(k), representing the difference between x(n) and x(k) (n), is given by
E(k)=∥x-γ(k)Fc(k)∥2, (3)
where the vector x represents the signal x(n) in vector notations, and ∥ ∥2 indicates the sum of the squares of the vector components. The optimum scale factor γ(k) that minimizes the error E(k) can easily be determined by setting ∂E(k)/∂γ(k)=0 and this leads to ##EQU2## The optimum codeword is obtained by finding the minimum of E(k) or the maximum of the second term on the right side in equation 5.
While the signal processing described with respect to FIG. 1 is relatively straight forward, the generation of the 1024 error signals E(k) of equation 5 is a time consuming operation that cannot be accomplished in real time in currently known high speed, large scale computers. The complexity of the search processing in FIG. 1 is due to the presence of the convolution operation represented by the matrix F in the error. The complexity is substantially reduced if the matrix F is replaced by a diagonal matrix. This is accomplished by representing the matrix F in the orthogonal form using singular-value decomposition as described in "Introduction to Matrix Computations" by G. W. Stewart, Academic Press, pp. 317-320, 1973. Assume that
F=UDVt, (6)
where U and V are orthogonal matrices, D is a diagonal matrix with positive elements and Vt indicates the transpose of V. Because of the orthogonality of U, equation 3 can be written as
E(k)=∥Ut (x-γ(k)Fc(k)∥2. (7)
If we now replace F by its orthogonal form as expressed in equation 6, we obtain
E(k)=∥Ut x-γ(k)DVt c(k)∥2. (8)
On substituting
z=Ut x
and
b(k)=Vt c(k), (9)
in equation 8, we obtain ##EQU3## As before, the optimum γ(k) that minimizes E(k) can be determined by setting ∂E(k)/∂γ(k)=0 and equation 10 simplifies to ##EQU4## The error signal expressed in equation 11 can be processed much faster than the expression in equation 5. If Fc(k) is processed in a recursive filter of order p (typically 20), processing according to equation 11 can be substantially reduce the processing time requirements for stochastic coding.
Alternatively, the reduced processing time may also be obtained by extending the operations of equation 5 from the time domain to a transform domain such as the frequency domain. If the combined impulse response of the synthesis filter with the long-delay prediction excluded and the perceptual weighting filter is represented by the sequence h(n), the filter output contributed by the kth codeword in the present frame can be expressed as a convolution between its input γ(k)c(k) (n) and the impulse response h(n). The filter output is given by
x(k) (n)=γ(k)h(n)*c(k) (n) (12)
The filter output can be expressed in the frequency domain as
X(k) (i)=γ(k)H(i)C(k) (i), (13)
where X(k) (i), H(i) and C(k) (i) are discrete Fourier transforms (DFTs) of x(k) (n),h(n) and c(k) (n), respectively. In practice, the duration of the filter output can be considered to be limited to a 10 msec time interval and zero outside. Thus a DFT with 80 points is sufficiently accurate for expressing equation 13. The total squared error E(k) is expressed in frequency-domain notations as ##EQU5## where X(i) is the DFT of x(n). If we express now
H(i)=d(i)ejφi, (15)
and
ξi =X(i)e-jφi, (16)
equation 14 is then transformed to ##EQU6## Again, the scale factor γ(k) can be eliminated from equation 17 and the total error can be expressed as ##EQU7## where ξ(i)* is complex conjugate ξ(i). The frequency-domain search has the advantage that the singular-value decomposition of the matrix F is replaced by discrete fast Fourier transforms whereby the overall processing complexity is significantly reduced. In the transform domain using either the singular value decomposition or the discrete Fourier transform processing, further savings in the computational load can be achieved by restricting the search to a subset of frequencies (or eigenvectors) corresponding to large values of d(i) (or b(i)). According to the invention, the processing is substantially reduced whereby real time operation with microprocessor integrated circuits is realizable. This is accomplished by replacing the time domain processing involved in the generation of the error between the synthetic speech signal formed responsive to the innovation code and the input speech signal of FIG. 1 with transform domain processing as described hereinbefore.
A transform domain digital speech encoder using arbitrary codes for excitation for excitation signals illustrative of the invention is shown in FIGS. 2 and 3. The arbitrary codes may take the form of random number sequences or may, for example, be varied sequences of +1 and -1 in any order. Any arrangement of varied sequences may be used with the broad restriction that the overall average of the sequences is small. Referring to FIG. 2, a speech pattern such as a spoken message received by microphone transducer 201 is bandlimited and converted into a sequence of pulse samples in filter and sampler circuit 203 and supplied to linear prediction coefficient (LPC) analyzer 209 via analog-to-digital converter 205. The filtering may be arranged to remove frequency components of the speech signal above 4.0 KHz, and the sampling may be at an 8.0 KHz rate as is well known in the art. Each sample from circuit 203 is transformed into an amplitude representative digital code in the analog-to-digital converter. The sequence of digitally coded speech samples is supplied to LPC analyzer 209 which is operative, as is well known in the art, to partition the speech signals into 5 to 20 ms time frame intervals and to generate a set of linear prediction coefficient signals a(k), k=1, 2, . . . , p representative of the predicted short time spectrum of the speech samples of each frame. The analyzer also forms a set of perceptually weighted linear predictive coefficient signals
b(k)=ka(k),
k=1, 2, . . . p, (19)
where p is the number of the prediction coefficients.
The speech samples from A/D converter 205 are delayed in delay 207 to allow time for the formation of speech parameter signals a(k) and the delayed samples are supplied to the input of prediction residual generator 211. The prediction residual generator, as is well known in the art, is responsive to the delayed speech samples s(n) and the prediction parameters a(k) to form a signal ∂(n) corresponding to the differences between speech samples and their predicted values. The formation of the predictive parameters and the prediction residual signal for each frame in predictive analyzer 209 may be performed according to the arrangement disclosed in U.S. Pat. No. 3,740,476 issued to B. S. Atal, June 19, 1973, and assigned to the same assignee, or in other arrangements well known in the art.
Prediction residual signal generator 211 is operative to subtract the predictable portion of the frame signal from the sample signals s(n) to form signal ∂(n) in accordance with ##EQU8## where p, the number of the predictive coefficients, may be 12, N the number of samples in a speech frame, may be 40, and a(k) are the predictive coefficients of the frame. Predictive residual signal ∂(n) corresponds to the speech signal of the frame with the short term redundancies removed. Longer term redundancy of the order of several speech frames in the predictive residual signal remains and predictive parameters β(1), β(2), β(3) and m corresponding to such longer term redundancy are generated in predictive pitch analyzer 220 such that m is an integer that maximizes ##EQU9## as described in U.S. Pat. No. 4,354,057 issued to B. S. Atal et al on Jan. 9, 1979. As is well known, digital speech encoders may be formed by encoding the predictive parameters of each successive frame, and the frame predictive residual for transmission to decoder appratus or for storage for later retrieval. While the bit rate for encoding the predictive parameters is relatively low, the non-redundant nature of the residual requires a very high bit rate. According to the invention, an optimum arbitrary code ##EQU10## is selected to represent the frame excitation, and a signal K* that indexes the selected arbitrary excitation code is transmitted. In this way, the speech code bit rate is minimized without adversely affecting intelligibility. The arbitrary code is selected in the transform domain to reduce the selection processing so that it can be performed in real time with microprocessor components.
Selection of the arbitrary code for excitation includes combining the predictive residual with the perceptually weighted linear predictive parameters of the frame to generate a signal y(n). Speech pattern signal y(n) corresponding to the perceptually weighted speech signal contains a component y(n) due to the preceding frames. This preceding frame component y(n) is removed prior to the selection processing so that the stored arbitrary codes are in effect compared to only the current frame excitation. Signal y(n) is formed in predictive filter 217 responsive to the perceptually weighted predictive parameter and the predictive residual signals of the frame as per the relation ##EQU11## and are stored in y(n) store 227.
The preceding frame speech contribution signal y(n) is generated in preceding frame contribution signal generator 222 from the perceptually weighted predictive parameter signal b(k) of the current frame, the pitch predictive parameters β(1), β(2), β(3) and m obtained from store 230 and the selected ##EQU12## where d(1), 1≦0 and y(1), 1≦0 represent the past frame components. Generator 222 may comprise well known processor arrangements adapted to form the signals of equations 24. The past frame speech contribution signal y(n) of store 240 is subtracted from the perceptually weighted signal of store 227 in subtractor circut 247 to form the current frame speech pattern signal with past frame components removed. ##EQU13## The difference signal x(n) from subtractor 247 is then transformed into a frequency domain signal set by discrete Fourier transform (DFT) generator 250 as follows. ##EQU14## where Nf is the number of DFT points, e.g., 80. The DFT transformation generator may operate as described in the U.S. Pat. No. 3,588,460 issued to Richard A. Smith, June 28, 1971, and assigned to the same assignee, or may comprise any of the well known discrete Fourier transform circuits.
In order to select one of a plurality of arbitrary excitation codes for the current speech frame, it is necessary to take into account the effects of a perceptually weighted LPC filter on the excitation codes. This is done by forming a signal in accordance with ##EQU15## that represents the impulse response of the filter and converting the impulse response to a frequency domain signal by a discrete Fourier transformation as per ##EQU16## The perceptually weighted impulse response signal h(n) is formed in impulse response generator 225, and the transformation into the frequency domain signal H(i) is performed in DFT generator 245.
The frequency domain impulse response signal H(i) and the frequency domain perceptually weighted speech signal with preceding frame contributions removed X(i) are applied to transform parameter signal converter 301 in FIG. 3 wherein the signals d(i) and ξ(i) are formed according to ##EQU17## The arbitrary codes, to which the current speech frame excitation signals represented by d(i) and ξ(i) are compared, are stored in stochastic code store 330. Each code comprises a sequence of N, e.g., 40, digital coded signals c(k) (1), c(k) (2), . . . , c(k) (40). These signals may be a set of arbitrary selected numbers within the broad restriction that the grand average is relatively small, or may be randomly selected digitally coded signals but may also be in the form of other codes well known in the art consistent with this restriction. The set of signals ##EQU18## may comprise individual codes that are overlapped to minimize storage requirements without affecting the encoding arrangements of FIGS. 2 and 3. Transform domain code store 305 contains the Fourier transformed frequency domain versions of the codes in store 330 obtained by the relation ##EQU19## While the transform code signals are stored, it is to be understood that other arrangements well known in the art which generate the transform signals from stored arbitrary codes may be used. Since the frequency domain codes have real and imaginary component signals, there are twice as many elements in the frequency domain code C(k) (i) as there are in the corresponding time domain code ##EQU20##
Each code output C(k) (i) of transform domain code store 305 is applied to one of the K error and scale factor generators 315-1 through 315-K wherein the transformed arbitrary code is compared to the time frame speech signal represented by signals d(i) and ξ(i) for the time frame obtained from parameter signal converter 301. FIG. 5 shows a block diagram arrangement that may be used to produce the error and scale factor signals for error and scale factor generator 315-K. Referring to FIG. 5, arbitrary code sequence C(k) (1), C(k) (2), . . . , C(k) (i), . . . , C(k) N is applied to speech pattern cross correlator 501 and speech pattern energy coefficient generator 505 which serves as a normalizer. Signal d(i) from transform parameter signal converter 301 is supplied to cross correlator 501 and normalizer 505, while ξ(i) from converter 301 is supplied to cross correlator 501. Cross correlator 501 is operative to generate the signal ##EQU21## which represents the correlation of the speech frame signal with past frame components removed ξ(i) and he frame speech signal derived from the transformed arbitrary code d(i) Ck (i) while squarer circuit 510 produces the signal ##EQU22## The error using code sequence ##EQU23## is formed in divider circuit 515 responsive to the outputs of cross correlator 501 and normalizer 505 over the current speech time frame according to ##EQU24## and the scale factor is produced in divider 520 responsive to the outputs of cross correlator circuit 510 and normalizer 505 as per ##EQU25## The cross correlator, normalizer and divide circuits of FIG. 5 may comprise well known logic circuit components or may be combined into a digital signal processor as described hereinafter. The arbitrary code that best matches the characteristics of the current frame speech pattern is selected in code selector 320 of FIG. 3, and the index of the selected code K* as well as the scale factor for the code γ(K*) are supplied to multiplexer 325. The multiplexer is adapted to combine the excitation code signals K* and γ(K*) with the current speech time frame LPC parameter signals a(k) and pitch parameter signals β(1), β(2), β(3) and m into a form suitable for transmission or storage. Index signal K* is also applied to selector 326 so that the time domain code for the index is selected from store 330. The selected time domain code ##EQU26## is fed to preceding frame contribution generator 222 in FIG. 2 where it is used in the formation of the signal y(n) for the next speech time frme processing. ##EQU27##
FIG. 4 depicts a speech encoding arrangement according to the invention wherein the operations described with respect to FIGS. 2 and 3 are performed in a series of digital signal processors 405, 410, 415, and 420-1 through 420-K under control of control processor 435. Processor 405 is adapted to perform the predictive coefficient signal processing associated with LPC analyzer 209, LPC and weighted LPC signal stores 213 and 215, prediction residual signal generator 217, and pitch predictive analyzer 220 of FIG. 2. Predictive residual signal processor 410 performs the functions described with respect to predictive filter 217, preceding frame contribution signal generator 222, subtractor 247 and impulse response generator 225. Transform signal processor 415 carries out the operations of DFT generators 245 and 250 of FIG. 2 and transform parameter signal converter 301 of FIG. 3. Processors 420-1 and through 420-K produce the error and scale factor signals as would be obtained from error and scale factor generators 315-1 through 315-K of FIG. 3.
Each of the digital signal processors may be the WE®DSP32 Digital Signal Processor described in the article "A 32 Bit VLSI Digital Signal Processor", by P. Hays et al, appearing in the IEEE Journal of Solid State Circuits, Vol. SC20, No. 5, pp. 998, October 1985, and the control processor may be the Motorola type 68000 microprocessor and associated circuits described in the publication "MC68000 16 Bit Microprocessor User's Manual", Second Edition, Motorola Inc., 1980. Each of the digital signal processors has associated therewith a memory for storing data for its operation, e.g., data memory 408 connected to prediction coefficient signal processor 405. Common data memory 450 stores signals from one digital signal processor that are needed for the operation of another signal processor. Common program store 430 has therein a sequence of permanently stored instruction signals used by control processor 435 and the digital signal processors to time and carry out the encoding functions of FIG. 4. Stochastic code store 440 is a read only memory that includes random codes Ck (n) as described with respect to FIG. 3 and transform code signal store 445 is another read only memory that holds the Fourier transformed frequency domain code signals corresponding to the codes in store 440.
The encoder of FIG. 4 may form a part of a communication system in which speech applied to microphone 401 is encoded to a low bit rate digital signal, e.g., 4.8 kb/s, and transmitted via a communication link to a receiver adapted to decode the arbitrary code indices and frame parameter signals. Alternatively, the output of the encoder of FIG. 4 may be stored for later decoding in a store and forward system or stored in read only memory for use in speech synthesizers of the type that will be described. As shown in the flow chart of FIG. 6, control processor 435 is conditioned by a manual signal ST from a switch or other device (not shown) to enable the operation of the encoder. All of the operations of the digital signal processors of FIG. 4 to generate the predictive parameter signals and the excitation code signals K* and γ* for a time frame interval occur within the time frame interval. When the on switch has been set (step 601), signal ST is produced to enable predictive coefficients processor 405 and the instructions in common program store 430 are accessed to control the operation of processor 405. Speech applied to microphone 401 is filtered and sampled in filter and sampler 403 and converted to a sequence of digital signals in A/D converter 404. Processor 405 receives the digitally coded sample signals from converter 404, partitions the samples into time frame segments as they are received and stores the successive frame samples in data memory 408 as indicated in step 705 of FIG. 7. Short delay coefficient signals a(k) and perceptually weighted short delay signals b(k) are produced in accordance with aforementioned U.S. Pat. No. 4,133,476 and equation 19 for the current time frame as per step 71. The current frame predictive residual signal ∂(n) are generated in accordance with equation 20 from the current frame speech samples s(n) and the LPC coefficient signals a(k) in step 715. When the operations of step 715 are completed, an end of short delay analysis signal is sent to control processor 435 (step 720). The STELPC signal is used to start the operations of processor 410 as per step 615 of FIG. 6. Long delay coefficient signals β(1), β(2), β(3) and m ae then formed according to equations 21 and 22 as per step 725, and an end of the predictive coefficient analysis signal STEPCA is generated (step 730). Processor 405 may be adapted to form the predictive coefficient signals as described in the aforementioned patent 4,133,976 The signals a(k), b(k), β(n), and β(n) and m of the current speech frame are transferred to common data memory 450 for use in residual signal processing.
When the current frame LPC coefficient signals have been generated in processor 405, control processor 435 is responsive to the STELPC signal to activate prediction residual signal processor 410 by means of step 801 in FIG. 8. The operations of processor 410 are done under control of common program store 430 as illustrated in the flow chart of FIG. 8. Referring to FIG. 8, the formation and storage of the current frame perceptually weighted signal y(n) is accomplished in step 805 according to equation 23. Long delay predictor contribution signals ∂(n) are generated as per equation 24 in step 810. Short delay predictor contributions signal y(n) is produced in step 815 as per equation 24. The current frame speech pattern signal with preceding frame components removed (x(n)), is produced by subtracting signal y(n) from signal y(n) in step 820 and impulse response signal h(n) is formed from the LPC coefficient signals a(k) as described in aforementioned U.S. Pat. No. 4,133,476 (step 825). Signals x(n) and h(n) transferred to and stored in common data memory 450 for use in transform signal processor 415.
Upon completion of the generation of signals x(n), h(n) for the current time frame, control processor 435 receives signal STEPSP from processor 410. When both signals STEPSP and SEPTCA are received by control processor 435 (step 621 of FIG. 6), the operation of transform signal processor 415 is started by transmitting the STEPSP signal to processor 415 as per step 625 in FIG. 6. Processor 415 is operative to generate the frequency domain speech frame representative signals x(i) and H(i) by performing a discrete Fourier transform operation on signals x(n) and h(n). Referring to FIG. 9, upon detecting signal STEPSP (step 901), the x(n) and h(n) signals are read from common data memory 450 (step 905). Signals X(i) are generated from the x(n) signals (step 910) and signals H(i) are generated from the h(n) signals (step 915) by Fourier transform operations well known in the art. The DFT may be implemented in accordance with the principles described in aforementioned U.S. Pat. No. 3,588,460. The conversion of signals X(i) and H(i) into the speech frame representative signals d(i) and ξ(i) implemented in processor 415 is done in step 920 as per equation 29 and signals d(i) and ξ(i) are stored in common data memory 450. At the end of the current frame transform prediction processing, signals STETPS is sent to control processor 435 (step 925). Responsive to signal STETPS in step 630, the control processor enables the error and scale factor signal processors 420-1 through 420-R (step 635).
Once the transform domain time frame speech representative signals for the current frame have been formed in processor 415 and stored in common data memory 450, the search operations for the stochastic code ##EQU28## that best matches the current frame speech pattern is performed in error and scale factor signal processors 420-1 through 420-K. Each processor generates error and scale factor signals corresponding to one or more (e.g., 100) transform domain codes in store 445. The error and scale factor signal formation is illustrated in the flow chart of FIG. 10. In FIG. 10, the presence of control signal STETPS (step 1001) permits the initial setting of parameters k identifying the stochastic code being processing, K* identifying the selected stochastic code for the current frame, P(r)* identifying the cross correlation coefficient signal of the selected code for the current frame, and Q(r)* identifying the energy coefficient signal of the selected code for the current frame.
The currently considered transform domain arbitrary code C(k) (i) is read from transform code signal store 445 (step 1005) and the current frame transform domain speech pattern signal obtained from the transform domain arbitrary code Ck (i) is formed (step 1015) from the d(i) and Ck (i) signals. The signal d(i)C(k) (i) represents the speech pattern of the frame produced by the arbitrary code ##EQU29## In effect, code signal C(k) (i) corresponds to the frame excitation and signal d(i) corresponds to the predictive filter representative of the human vocal apparatus. Signal ξ(i) stored in common data store 450 is representative of the current frame speech pattern obtained from microphone 401.
The two transform domain speech pattern representative signals, d(i)C(k) (i) and ξ(i), are cross correlated to formed signal P(k) in step 1020 and an energy coefficient signal Q(k) is formed in step 1022 for normalization purposes. The current deviation of the stochastic code frame speech pattern from the actual speech pattern of the frame is evaluated in step 1025. If the error between the code pattern and the actual pattern is less than the best obtained for preceding codes in the evaluation, index signal K(r)*, cross correlation signal P(r)* and energy coefficient signal Q(r)* are set to k, P(k), and Q(k) in step 1030. Step 1035 is then entered to determine if all codes have been evaluated. Otherwise, signals K(r)*, P(r)*, and Q(r)* remain unaltered and step 1035 is entered directly from step 1025. Until K>Kmax in tep 1035, code index signal k is incremented (step 1040) and step 1010 is reentered. When k>Kmax, signal K(r)* is stored and scale factor signal γ* is generated in step 1045. The index signal K(r)* and scale factor signal γ(r)* for the codes processed in the error and scale factor signal processor are stored in common data store 450. Step 1050 is then entered and the STEER control signal is sent to control processor 435 to signal the completion of the transform code selection in the error and scale factor signal processor (step 640 in FIG. 6). The control processor is then operative to enable the minimum error and multiplex processor 455 as per step 645.
The signals P(r)*, Q(r)*, and K(r)* resulting from the evaluation in processors 420-1 through 420-R are stored in common data memory 450 and are sent to minimum error and multiplex processor 455. Processor 455 is operative according to the flow chart of FIG. 11 to select the best matching stochastic code in store 440 having index K*. This index is selected from the best arbitrary codes indexed by signals K*(1) through K*(R) for processors 420-1 to 420-R. This index K* corresponds to the stochastic code that results in the minimum error signal. As per step 1101 of FIG. 11, processor 455 is enabled when a signal is received from control processor 435 indicating that processors 420-1 through 420-R have sent STEER signals. Signals r, K*, P*, and Q* are each set to an initial value of one, and signals P(r)*, Q(r)*, K(r)* and γ(r)* are read from common data memory 450 (step 1110). If the current signals P(r)* and Q(r)* result in a better matching stochastic code signal as determined in step 1115, these values are stored as K*, P*, Q*, and γ* for the current frame (step 1120) and decision step 1125 is entered. Until the Rth set of signals K(R)*, P(R)*, Q(R)* are processed, step 1110 is reentered via incrementing step 1130 so that all possible candidates for the best stochastic code are considered. After the Rth set of signals are processed, signal K*, the selected index of the current frame and signal γ*, the corresponding scale factor signal are stored in common data memory 450.
At this point, all signals to form the current time frame speech code are available in common data memory 450. The contribution of the current frame excitation code ##EQU30## must be generated for use in signal processor 440 in the succeeding time frame interval to remove the preceding frame component of the current time frame for forming signal x(n) as aforementioned. This is done in step 1135 where signals d(n) and y(n) are updated.
The predictive parameter signals for the current frame and signals K* and γ* are then read from memory 450 (step 1140), and the signals are converted into a frame transmission code set as is well known in the art (step 1145). The current frame end transmission signal FET is then generated and sent to control processor 435 to signal the beginning of the succeeding frame processing (step 650 in FIG. 6).
When use in a communication system, the coded speech signal of the time frame comprises a set of LPC coefficient a(k), a set of pitch predictive coefficients β(1), β(2), β(3), and m, and the stochastic code index and scale factor signals K* and γ*. As is well known in the art, a predictive decoder circuit is operative to pass the excitation signal of each speech time frame through one or more filters that are representative of a model of the human vocal apparatus. In accordance with an aspect of the invention, the excitation signal is an arbitrary code stored therein which is indexed as described with respect to the speech encoder of the circuits of FIGS. 2 and 3 or FIG. 4. The stochastic codes may be a set of 1024 codes each comprising a set of 40 random numbers obtained from a string of the 1024 random number codes g(1), g(2), . . . ,g(1063) stored in a register. The 40 element stochastic codes are arranged in overlapping fashion as illustrated in Table 1.
TABLE I |
______________________________________ |
Stochastic Code |
Index K Stochastic Code |
______________________________________ |
1 g(1), g(2), . . . , g(40) |
2 g(2), g(3), . . . , g(41) |
3 g(3), g(4), . . . , g(42) |
4 g(4), g(5), . . . , g(43) |
4 g(4), g(5), . . . , g(43) |
4 g(4), g(5), . . . , g(43) |
1024 g(1024), g(1025, . . . , g(1063) |
______________________________________ |
Referring to Table 1, each code is a sequence of 40 random numbers that are overlapped so that each successive code begins at the second number position of the preceding code. The first entry in Table 1 includes this indes k=1 and the first 40 random numbers of the single string g(1), g(2), . . . . g(40). The second code with index k=2, corresponds to the set of random numbers g(2), g(3), . . . , g(41). Thus, 39 positions of successive codes are overlapped without affecting their random character to minimize storage requirements. The degree of overlap may be varied without affecting the operation of the circuit. The overall average of the string signals g(1) through g(1063) must be relatively small. The arbitrary codes need not be random numbers and the codes need not be arranged in overlapped fashion. Thus, arbitrary sequences of +1, -1 that define a set of unique codes may be used.
In the decoder or synthesizer circuit of FIG. 12, LPC coefficient signals a(k), pitch predictive coefficient signals β(1), β(2), β(3), and m, and the stochastic code index and scale factor signals K* and γ* are separated in demultiplexer 1201. The pitch predictive parameter signals β(k) and m are applied to pitch predictive filter 1220, and the LPC coefficient signals are supplied to LPC predictive filter 1225. Filters 1220 and 1225 operate as is well known in the art and as described in the aforementioned U.S. Pat. No. 4,133,976 to modify the excitation signal from scaler 1215 in accordance with vocal apparatus features. Index signal K* is applied to selector 1205 which addresses stochastic string register 1210. Responsive to index signal K*, the stochastic code best representative of the speech time frame excitation is applied to scaler 1215. The stochastic codes correspond to time frame speech patterns without regard to the intensity of the actual speech. The scaler modifies the stochastic code in accordance with the intensity of the excitation of the speech frame. The formation of the excitation signal in this manner minimizes the excitation bit rate required for transmission, and the overlapped code storage operates to reduce the circuit requirements of the decoder and permits a wide selection of encryption techniques. After the stochastic code excitation signal from scaler 1215 is modified in predictive filters 1220 and 1225, the resulting digital coded speech is applied to digital-to-analog converter 1230 wherein successive analog samples are formed. These samples are filtered in low pass filter 1235 to produce a replica of the time frame speech signal s(n) applied to the encoder of the circuit of FIGS. 2 and 3 of FIG. 4.
The invention may be utilized in speech synthesis wherein speech patterns are encoded using stochastic coding as shown in the circuits of FIGS. 2 and 3 or FIG. 4. The speech synthesizer comprises the circuit of FIG. 12 in which index signals K* are successively applied from well known data processing apparatus together with predictive parameter signals in accordance with the speech pattern to be produced. The overlapping code arrangement minimizes the storage requirements so a wide variety of speech sounds may be produced and the stochastic codes are accessed with index signals in a highly efficient manner. Similarly, storage of speech messages according to the invention for later reproduction only requires the storage of the predictive parameters and the excitation index signals of the successive frames so that speech compression is enhanced without reducing the intelligibility of the reproduced message.
While the invention has been described with respect to particular embodiments thereof, it is to be understood that various changes and modifications may be made by those skilled in the art without departing from the spirit or scope of the invention.
Atal, Bishnu S., Martins Trancoso, Isabel M.
Patent | Priority | Assignee | Title |
5649051, | Jun 01 1995 | Lockheed Martin Corporation | Constant data rate speech encoder for limited bandwidth path |
5668925, | Jun 01 1995 | RETRO REFLECTIVE OPTICS | Low data rate speech encoder with mixed excitation |
5822721, | Dec 22 1995 | HEWLETT-PACKARD DEVELOPMENT COMPANY, L P | Method and apparatus for fractal-excited linear predictive coding of digital signals |
Patent | Priority | Assignee | Title |
3588460, | |||
3624302, | |||
3740476, | |||
3982070, | Jun 05 1974 | Bell Telephone Laboratories, Incorporated | Phase vocoder speech synthesis system |
4022974, | Jun 03 1976 | Bell Telephone Laboratories, Incorporated | Adaptive linear prediction speech synthesizer |
4092493, | Nov 30 1976 | Bell Telephone Laboratories, Incorporated | Speech recognition system |
4133976, | Apr 07 1978 | Bell Telephone Laboratories, Incorporated | Predictive speech signal coding with reduced noise effects |
4184049, | Aug 25 1978 | Bell Telephone Laboratories, Incorporated | Transform speech signal coding with pitch controlled adaptive quantizing |
4354057, | Apr 08 1980 | Bell Telephone Laboratories, Incorporated | Predictive signal coding with partitioned quantization |
4472832, | Dec 01 1981 | AT&T Bell Laboratories | Digital speech coder |
4701954, | Mar 16 1984 | THE CHASE MANHATTAN BANK, AS COLLATERAL AGENT | Multipulse LPC speech processing arrangement |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 02 1991 | AT&T Bell Laboratories | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Sep 30 1996 | M184: Payment of Maintenance Fee, 8th Year, Large Entity. |
Oct 09 1996 | ASPN: Payor Number Assigned. |
Nov 05 1998 | ASPN: Payor Number Assigned. |
Nov 05 1998 | RMPN: Payer Number De-assigned. |
Sep 28 2000 | M185: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
May 11 1996 | 4 years fee payment window open |
Nov 11 1996 | 6 months grace period start (w surcharge) |
May 11 1997 | patent expiry (for year 4) |
May 11 1999 | 2 years to revive unintentionally abandoned end. (for year 4) |
May 11 2000 | 8 years fee payment window open |
Nov 11 2000 | 6 months grace period start (w surcharge) |
May 11 2001 | patent expiry (for year 8) |
May 11 2003 | 2 years to revive unintentionally abandoned end. (for year 8) |
May 11 2004 | 12 years fee payment window open |
Nov 11 2004 | 6 months grace period start (w surcharge) |
May 11 2005 | patent expiry (for year 12) |
May 11 2007 | 2 years to revive unintentionally abandoned end. (for year 12) |