Title of Invention

METHOD AND APPARATUS FOR DETERMINING THE RATE OF RECEIVED DATA IN A VARIABLE RATE COMMUNICATION SYSTEM

Abstract The apparatus and method are employed in a communications system has a transmitter and a receiver, where the receiver determines at which of several rates individual frames in a signal have been transmitted by the transmitter. For example, if the transmitter employs four transmission rates, the receiver decodes each frame of the received signal based on the four rates to produce four cyclic redundancy check (CRC) bits, four symbol error rate (SER) values and one or more Yamamoto check values. If only two of the CRC bits check, then the receiver compares to each other the SER values for those two rates to determine at which of the two rates a current frame was transmitted. If only one of the CRC bits check for a given rate, then the SER value for that rate is compared with a maximum SER threshold for that rate. Additionally, SER values for the other rates can be compared to minimum SER thresholds. Furthermore, the Yamamoto check values can be analyzed to determined whether looser or tighter minimum and maximum SER thresholds should be employed if the Yamamoto values check for the current rate, or do not check, respectively.
Full Text METHOD AND APPARATUS FOR DETERMINING THE RATE OF RECEIVED DATA IN A VARIABLE RATE COMMUNICATION
SYSTEM
BACKGROUND OF THE INVENTION
1 Field of the Invention
The present invention relates to communications. More particularly, the present invention relates to a method and apparatus for determining transmission rate in a variable rate transmission system.
H. Description of the Related Art
The use of code division multiple access (CDMA) modulation techniques is one of several techniques for facilitating communications in which a large number of system users are present. Although other techniques such as time division multiple access (TDMA), frequency division multiple access (FDMA), and AM modulation schemes such as amplitude companded single sideband (ACSSB) are known, CDMA has significant advantages over these other techniques. The use of CDMA techniques in a multiple access communication system is disclosed in U.S. Patent No. 4,901,307, entitled "SPREAD SPECTRUM MULTIPLE ACCESS COMMUNICATION SYSTEM USING SATELLITE OR TERRESTRIAL REPEATERS," and assigned to the assignee of the present invention and incorporated by reference herein. The use of CDMA techniques in a multiple access communication system is further disclosed in U.S. Patent No- 5,103,459, entitled "SYSTEM AND METHOD FOR GENERATING SIGNAL WAVEFORMS IN A CDMA CELLULAR TELEPHONE SYSTEM", assigned to the assignee of the present invention and incorporated by reference herein.
CDMA by its inherent nature of being a wideband signal offers a form of frequency diversity by spreading the signal energy over a wide bandwidth. Therefore, frequency selective fading affects only a small part of the CDMA signal bandwidth. Space or path diversity is obtained by providing multiple signal paths through simultaneous links from a mobile user through two or more cell-sites. Furthermore, path diversity may be obtained by exploiting the multipath environment through spread spectrum processing by allowing a signal arriving with different propagation delays to be received and processed separately. Examples of path diversity are illustrated in U.S.

Patent No. 5,101,501 entitled "METHOD AND SYSTEM FOR PROVIDING A SOFT HANDOFF IN COMMUNICATIONS IN A CDMA CELLULAR TELEPHONE SYSTEM", and U.S. Patent No. 5,109,390 entitled "DIVERSITY RECEIVER IN A CDMA CELLULAR TELEPHONE SYSTEM", both assigned to the assignee of the present invention, and incorporated by reference herein.
CDMA systems often employ a variable rate vocoder to encode data so that the data rate can be varied from one data frame to another. An exemplary embodiment of a variable rate vocoder is described in US. Pat. No. 5,414,796, entitled "VARIABLE RATE VOCODER," assigned to the assignee of the present invention and incorporated by reference herein. The use of a variable rate communications channel reduces mutual interference by eliminating unnecessary transmissions when there is no useful speech to be transmitted. Algorithms are utilized within the vocoder for generating a varying number of information bits in each frame in accordance with variations in speech activity. For example, a vocoder with a rate set of four may produce 20 millisecond data frames containing 20, 40, 80, or 160 bits, depending on the activity of the speaker. It is desired to transmit each data frame in a fixed amount of time by varying the transmission rate of communications. Additional details on the formatting of the vocoder data into data frames are described in U.S. Pat. No. 5,511,073, entitled "METHOD AND APPARATUS FOR THE FORMATTING OF DATA FOR TRANSMISSION," assigned to the assignee of the present invention, and incorporated by reference herein.
One technique for the receiver to determine the rate of a received data frame is described in copending U.S. patent application Serial No-08/233,570, entitled "METHOD AND APPARATUS FOR DETERMINING DATA RATE OF TRANSMITTED VARIABLE RATE DATA IN A COMMUNICATIONS RECEIVER," filed April 26, 1994, assigned to the assignee of the present invention and incorporated by reference herein. Another technique is described in copending U.S. Patent Application Serial No. 08/126,477, entitled "MULTIRATE SERIAL VITERBI DECODER FOR CODE DIVISION MULTIPLE ACCESS SYSTEM APPLICATIONS," filed Sept. 24, 1993, assigned to the assignee of the present invention, and incorporated by reference herein. According to these techniques, each received data frame is decoded at each of the possible rates. Error metrics, which describe the quality of the decoded symbols for each frame decoded at each rate, are provided to a processor. The error metrics may include Cyclic Redundancy Check (CRC) results, Yamamoto Quality Metrics, and Symbol

Error Rates. These error metrics are well-known in communications systems. The processor analyzes the error metrics and determines the most probable rate at which the incoming symbols were transmitted.
SUMMARY OF THE INVENTION
The present invention provides a novel and improved apparatus and method for decoding data. The apparatus and method are employed in a communications system having a transmitter and a receiver, where the receiver determines at which of several rates individual frames in a signal has been transmitted by the transmitter. For example, if the transmitter employs four transmission rates, the receiver decodes each frame of the received signal based on the four rates to produce four cyclic redundancy check (CRQJrifs, four symbol error rate (SER) values and one or more ^Talnamoto check values. If the CRC checks for only two rates, then the receiver compares to each other the SER values for those two rates to determine at which of the two rates a current frame was transmitted. If the CRC checks for only one rate, then the SER value for that rate is compared with a maximum SER threshold for that rate. Additionally, SER values for the other rates can be compared to minimum SER thresholds. Furthermore, the Yamamoto check values can be analyzed to determined whether looser or tighter minimum and maximum SER thresholds should be employed if the Yamamoto values check for the current rate, or do not check, respectively.
Broadly stated, the present invention embodies a method for use in a communication system having a transmitter and a receiver. The transmitter transmits a signal at a current rate, wherein the current rate corresponds to one of a plurality of rates. The receiver generates a plurality of check error values and error rate codes,, and at least one decoding code, each based on whether the signal has one of the plurality of rates. The method determines the current rate of the signal and includes the steps of: (a) determining if only a first check value of a selected rate favorably checks, wherein the selected rate is one of the plurality of rates; (b) determining if the selected rate corresponds to a predetermined rate; (c) if the selected rate corresponds to the predetermined rate, comparing a selected decoding code to a selected value; (d) if the selected rate does not correspond to the predetermined rate, comparing a selected error rate code to a first value based on a predetermined operational relationship, wherein the selected rate code corresponds to the selected rate; (e)if the selected decoding code

corresponds to the selected value, comparing the selected error rate code to a second value based on the predetermined operational relationship; (f) if the selected decoding code does not correspond to the selected value, comparing the selected error rate code to a third value based on the predetermined operational relationship; and (g) determining that the current rate of the signal is the selected rate if the selected error rate code has the/ predetermined operational relationship to the first, second or third values.
Broadly stated, the present invention also embodies a method far determining the current rate of the signal having the steps o(f; (a) determining that only first and second error check values of first and second rates favorably check, wherein the first and second rates are from the plurality of rates; (b) comparing a first error rate code to a second error rate code plus a first value based on a predetermined operational relationship, wherein the first and second error rate codes correspond to the first and second rates; and (c) determining that the current rate of the signal is the second rate if the first error rate code has the predetermined operational relationship to the second error rate code plus a first value, and otherwise determining that the current rate is the first rate.
BRIEF DESCRIPTION OF THE DRAWINGS
The features, objects, and advantages of the present invention will become more apparent from the detailed description set forth below when taken in conjunction with the drawings in which like reference characters identify correspondingly throughout and wherein:
FIG. 1 is a block diagram of the communication system of the present invention;
FIG. 2 is a flowchart illustrating a method for selecting the decoded frame when the CRC checks for two different rates;
FIG. 3 is a flowchart illustrating an alternative method for selecting ■he decoded frame when the CRC checks for two different rates;
FIG. 4 is a flowchart illustrating a method for selecting the decoded iraine when the CRC checks for one rate;
FIG. 5 is a flowchart illustrating an alternative method for selecting die decoded frame when the CRC checks for one rate; and
FIG. 6 is a plot of rate decision regions for symbol error rates i and j where the CRC checks for both rates i and j.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
Referring to FIG. 1, a remote transmission system 2 transmits data to a remote receiving system 4. In an exemplary embodiment, the present invention is implemented in a wireless communication system which communicates using spread spectrum modulation signals. Communication using spread spectrum communication systems is described in detail in the aforementioned US. Patents 4,901,307 and 5,103,459.
A variable rate data source 6 provides variable rate data frames for transmission to a Cyclic Redundancy Check (CRC) and Tail Bit Generator 8. In the exemplary embodiment, the data source 6 is a variable rate vocoder for encoding speech information at four variable rates as described in detail in the aforementioned U.S Patent No. 5,414,796. When used, for example, in a cellular telephone environment, the signal is transmitted at the full rate to transmit speech (i.e., when a user is talking) and is transmitted at the eighth rate to transmit silence {i.e., when the user is not talking). The eighth rate saves on the number of bits transmitted, and thereby saves on power. In general, 90% of the signals transmitted by the transmitter 2 to the receiver 4 are either at the full or one-eighth rate. The one-half and one-quarter rates represent transitional rates between the full and eighth rates.
The generator 8 generates a set of CRC bits to provide for error detection at the receiver as is well known in the art. In addition, the generator 8 appends a sequence of tail bits to the frame. In the exemplary embodiment, the generator 8 generates the set of CRC and tail bits in accordance with the Telecommunications Industry Association"s TIA/EIA/IS-95-A Mobile Stations-Base Station Compatibility Standard for Dual-Mode Wideband Spread Spectrum Cellular System.
The data frame is provided by the generator 8 to an encoder 10 which encodes the data as symbols for error correction and detection at the receiver. In the exemplary embodiment, the encoder 10 is a rate 1/2 convolutional encoder. The encoded symbols are provided to an interleaver 12, which reorders the encoded symbols in accordance with a predetermined interleaving format. In the exemplary embodiment, the interleaver 12 is a slock interleaver, the design and implementation of which is well known in ihe art.
The reordered frame is then provided to a modulator 14 which nodulates the frame for transmission. In the exemplary embodiment, the nodulator 14 is a CDMA modulator, the implementation of which is

described in detail in the aforementioned U.S. Patents 4,901,307 an\__ 5,103,459. The modulated data frame is provided to a transmitter (TMTR) 16. The transmitter 16 upconverts and amplifies the signal for transmission through an antenna 18.
The transmitted signal is received by an antenna 20 of a remote station 4, such as a cellular phone, and provided to a receiver (RCVR) 22 which down converts and amplifies the received signal. The received signal is then provided to a demodulator (DEMOD) 24 which demodulates the signal. In the exemplary embodiment, the demodulator 24 is a CDMA demodulator 24, the implementation of which is described in detail in the aforementioned U.S. Patents 4,901,307 and 5,103,459.
The demodulated signal is then provided to a diversity combiner 26. The diversity combiner 26 combines the demodulated signal from the demodulator 24 with demodulated signals from other demodulators (not shown) which demodulate the same signal except provided on a different propagation path. The design and implementation of the diversity combiner 26 is described in detail in the aforementioned U.S. Patent No. 5,109390. The diversity combined signal is provided to a de-interleaver 28 which re-orders the symbols in the frame in accordance with a predetermined re-ordering format as is well known in the art
The re-ordered frame is then provided to a multi-rate decoder 30, which provides error correction on the frame of symbols. The decoder 30 decodes the data based on a predetermined set of rate hypotheses. In the exemplary embodiment, the decoder 30 is a multi-rate Viterbi decoder as is described in detail in the aforementioned copending U.S. Patent Application Serial No. 08/126,477.
In the exemplary embodiment, the decoder 30 decodes the symbols for each of the four possible rates to provide four separately decoded frames of data, each of which is provided to a CRC check detector 32. The CRC check detector 32 determines under conventional techniques whether the cyclic redundancy check bits for each frame are correct for the decoded data. The CRC check detector 32 performs a CRC check for the CRC bits in the four decoded frames to help determine whether the currently received frame was transmitted at the full, half, quarter or eighth rates. As a result, the CRC check detector 32 provides four check bits, Q, C2, Q and Cs/ where a binary value of "1" for a given CRC check bit can indicate that the CRC check matched or checked, while a binary value of "0" can indicate that the CRC bits did not check. As used generally herein, the subscript or indication "1"

corresponds to the full rate, "2" corresponds to the half rate, "4" corresponds to the quarter rate and "8" corresponds to the eighth rate.
In addition, the decoder 30 provides the decoded data to a symbol error rate (SER) check detector 34. The SER detector 34 receives the decoded bits and an estimate of the received symbol data from the decoder 30. As is known, the SER detector 34 re-encodes the decoded bits, and compares them to the estimate of the received symbol data from the decoder 30. The SER is a count of the number of discrepancies between the re-encoded symbol data and the received symbol data. Therefore, the SER detector 34 generates four SER values: SERi, SER2, SER4 and SERg. For processing efficiency, the SER detector 34 provides SER values having a maximum value of 255. In addition to the CRC bits, the SER values help provide a determination of the rate of the current frame transmitted by the transmitter 2, and whether the frame has errors.
Furthermore, the decoder 30 provides information to a Yamamoto check detector 36 which provides a confidence metric based on the difference between the selected path through a trellis and the next closest path through the trellis. While the CRC check is dependent on the bits in each of the four decoded frames, the Yamamoto check is dependent on the decoding process of the receiver 4. The Yamamoto detector 36, as with the detectors 32 and 34, provides four Yamamoto values for each of the four possible rates: Yi, Y2, Y4 and Yg. Although the detectors 32,34 and 36 are shown as separate elements, the detectors can be incorporated within the hardware of the decoder 30.
A control processor 38 receives the CRC check bits, SER values and Yamamoto values from the detectors 32, 34 and 36, respectively. The processor 38 then determines at which of the four rates the currently received frame was sent. The decoder 30 provides four decoded frames for storage in a decoded frame buffer 40, where each of the four frames is decoded under one of the four rates. Based on the rate determined by the processor 38, the control processor provides a signal to the decoded frame buffer 40/ which in response thereto, outputs the stored frame decoded at the determined rate or outputs no frame if an erasure is declared. In an alternative embodiment, decoder frame buffer 40 outputs a signal indicative of a frame erasure if an erasure is declared.
Under the communication system of FIG. 1, the signal transmitted by the transmitter 2 to the receiver 4 can rapidly change between the four rates. As a result, the transmitter 2 does not include within the transmitted signal an actual indication as to the rate at which the signal is currently being transmitted. To do so would require unnecessary bandwidth. Therefore, the

transmitter 2 transmits a frame at a current rate (selected from one of the four rates), and a control processor 38 and the decoder 30 of the receiver 4, under routines described below, determine at which of the four rates the currently received frame was sent or whether an erasure should be declared (i.e., whether the current frame was sent at the full, half, quarter or eighth rate). The decoder 30 then decodes the one of the four decoded frames which has the determined rate and outputs a decoded signal. The appropriately decoded signal can then be input to, for example, a vocoder, amplifier and speaker (not shown) to output a voice signal to be heard by a user of the receiver 4.
The control processor 38, coupled to at least the decoder 30, operates in conjunction with the methods illustrated in the flow diagrams of FIGS. 2-5 to select the appropriate decoded frame to be output or provided to the user, or to declare the current frame an erasure condition. While the control processor 38 and decoder 30 are shown as separate elements, the control processor and decoder can be incorporated together to form a single decoder.
Referring to FIG. 2, an exemplary routine 100 performed by the processor 38 first determines in step 102 whether the CRC checks for two of the four rates. For example, if the processor 38 determines that the CRC for the full and eighth rates check (i.e., bits Q = C8 = 1), but the CRCs do not check for the half and quarter rates (i.e., bits C2 = Q =0), then the processor 38 determines that step 102 is satisfied. If the CRCs for exactly two rates check in step 102, then the current frame can have three possible interpretations: it could be erased, it could have been transmitted at a first rate i corresponding to the first rate that checked its CRC, or it could have been transmitted at a second rate j corresponding to the second rate that checked its CRC.
However, if the CRCs for less than two or greater than two of the rates check, then in step 104, the processor 38 determines whether the CRC for exactly one rate checks. If so, then in step 108, the processor 38 performs a one CRC check routine as described below. However, if the CRCs for none of the rates check, or if the CRCs for three or four rates check, then in step 106, the processor 38 declares the currently received frame an erasure. In general, if the CRCs for none of the rates check, then the current frame is erased. Alternatively, if the CRCs for three or four of the rates check, then, while the processor 38 could still determine the current rate of the currently received frame, such a determination is computationally difficult, can have a higher probability of error, and generally requires too much processing overhead to rapidly and accurately determine the rate for the current frame.

Therefore, it is simply easier for the processor 38 to declare the current frame an erasure.
If the CRCs for two rates check in step 102, then in step 110, the processor 38 compares the SER values for the two rates that checked in step 102. For example, if the CRCs for the full and eighth rates check in step 102, then the processor 38 in step 110 determines whether the SER value for the full rate (SER:) is greater than or equal to the SER value for the eighth rate (SER8) plus a weighting value W determined based on the full and eighth rates (Wy). In general, the processor 38 under step 110 compares the SERs based on the following equation:
SERi^SERj + Wi,), (1)
where i and j refer to the two rates corresponding to the two rates that decked under step 102.
The weighting or scaling value W can have one of six possible values, _iince i and j can have one of four possible values based on the four rates (i.e., W1(2y WM, W1(8/ W2/4, W2,8, and W4,s)- Additionally, the weighting value W can have a value ranging from -255 to +255 since the SER values have a maximum value of 255. The weighting value W is generally necessary because, fof the different probability densities of the SERs for the possible rates, and the differences in the chances of the CRC checking given the different actual frame rates from the transmitter. The weighting value W is preferably established based on empirical data provided through experimentation. By establishing a target acceptable error rate, and testing the response of the communication system of FIG. 1 under the four rates, empirical data resulting therefrom is used to determine a weighting value W for each of the six combination of rates.
In general, the weighting value W provides an increased level of confidence as to which of the two rates the currently received frame was transmitted. Simply determining that the current rate is equal to the rate having the lower SER can result in incorrectly determining the rate of the current frame. Therefore, the SERj value must be less than the SERj value plus a weighting factor for the processor 38 to determine that the rate of the currently received frame is equal to the rate I.
Sometimes, it is less desirable to decode a current frame at an incorrect rate than to declare a current frame an erasure. This is accomodated in the present invention. If a current frame is decoded at the wrong rate, the decoder 30 will output a noisy signal that can be amplified and broadcast to a user"s ear. Such a noisy signal can be perceptually undesirable to a user. As a result, the present invention sacrifices a little

higher frame erasure rate, in exchange for not decoding a current frame at the wrong rate. Nevertheless, the receiver 4 preferably attempts to maintain a frame erasure rate of less than 1%. Preferably, the probability of the wrong rate being determined under the routines described herein are less than or equal to 10"5.
If the SERi value is greater than or equal to the SERj value plus the weighting value Wy, then in step 112, the processor 38 determines that the rate of the current frame received from the transmitter 2 is at the rate i. Alternatively, if the SERj value is less than the SERj value plus Wy, then in step 114, the processor 38 determines that the rate of the current frame received from the transmitter 2 is equal to the rate j. In the above example, where i and j correspond to the full and eighth rates, respectively, if the SERi value is greater than or equal to the SERg value plus the weighting value Wi,g, then the rate of the currently received frame is equal to the full rate under step 112, otherwise, the rate is equal to the one-eighth rate under step 114. After determining the rate of the current frame, the processor 38 provides an appropriate signal to the buffer 40, which in response thereto, outputs the frame decoded corresponding to the determined rate or no frame if an erasure is declared.
An alternative embodiment according to the present invention for determining the received signal rate where two of the four rates check is shown in FIG. 3 as a routine 120. This and other alternative embodiments described below are similar to their corresponding previously described embodiment, and common steps are identified by the same reference numerals. Only the significant differences in operation are described in detail.
Referring to FIG. 3, the routine 120 performs the same steps 102,104, 106 and 108 as described above with respect to the routine 100. In step 124, if the CRCs for two of the rates check under step 102, then the processor 38 employs a more accurate comparison between the SER values for the two rates identified under step 102 to further ensure that the current frame is decoded under the appropriate rate. Specifically, the processor 38 in step 124 employs a multiplicative factor ky in equation (1) above, to provide the
following comparative function:
SER; >ky* SERj+ WM. (2)
As with the weighting value W, the multiplicative factor ky is preferably determined through experimentation based on empirical data for the four transmission rates. Therefore, six possible multiplicative factors are possible based on the four transmission rates {i.e„ ki^, ki,4, kw, k2|4, k2,s, and k^). The

multiplicative factor k can simply be a normalization factor so that, for example, if i is equal to full and j is equal to half, then ki^ would be equal to two to normalize the half rate SER2 value with respect to the SERi value. Alternatively, the multiplicative factor k can include not only a normalization factor, but compensate for differences between the different transmission rates, as described below.
Referring to FIG. 6, a simplified diagram is shown of rate decision regions for SER values SERi and SERj, where CRCs for rates i and j check. In general, a line SERi = ky * SERj + Wy separates an SERj region 140 from an SER, region 142. As a result, the multiplicative factor ki,j determines the slope of the line, while the weighting value Wy determines its offset from the origin (its Y-axis intercept). In general, the multiplicative factor k and weighting value W vary the decision range for areas 140 and 142. If, for example, the SERS value for the current frame is less than the SERj value, this frame provides a point above the line SERi = ky * SERj + Wi,j and in the SERj region 142. Under such an example, the rate of the received frame is then likely equal to j.
One can build probability density curves based on the empirical data collected through experimentation and define a target acceptable error rate. Thereafter, one can integrate under a portion of the probability density curves, below the target acceptable error rate, to determine minimum and maximum SER threshold values (discussed below), for each rate. The empirical data can be input to spreadsheets and known numerical analysis techniques can be employed under the spreadsheets to provide optimized values below the target acceptable error rate. In sum, one can determine through experimentation the probabilities that the current rate is i based on given SER values, where these probabilities are then plotted based on the SERj value and the SER values for the other rates (e.g., SERj).
In general, the routine 120 and the other routines described herein employ functions based on two rates and two SERs, SERj, SERj (i.e. f(i, j* SERj, SERj). Under the exemplary embodiment, the present invention employs linear equations such as equation (2) above, and as represented in FIG. 6. The weighting value W, the multiplicative factor k, and the maximum and minimum SER thresholds (discussed below) are preferably stored in memory as a look-up table (not shown) to be accessed by the processor 38.
In step 124, the processor 38 essentially determines on which side of the line in FIG. 6 a point defined by the two SER values (SERi, SERj) exists, to thereby determine the most likely rate for the currenUy received frame. If the SERj value is less than kM times the SER, value plus W^ then in step 126,

the processor 38 determines whether the SERi is greater than a maximum acceptable SER threshold for rate i {i.e., MaxSER;). In general, there is a maximum SER threshold value for the given rate beyond which the probability of error (of decoding at the incorrect rate) is unacceptable. As noted above, the maximum SER thresholds, shown in FIG. 6, are determined based on empirical data derived through experimentation with the four rates. If the SERi value is less than the maximum SERi threshold, then the processor 38 in step 128 determines that the rate of the currently received frame is equal to i. If, however, the SERi value is greater than or equal to the maximum SERj threshold, then in step 130 the processor 38 determines that the current frame is an erasure.
If, under step 124, the processor 38 determines that the SER; value is greater than or equal to ky times the SERj value plus Wi(j, then in step 132, the processor 38 determines whether the SERj value is greater than or equal to a maximum SER threshold for rate j {i.e-, MaxSERj). If so, the processor 38 in step 130 determines that the current frame is erased. However, if the SERj value is less than the maximum SERj threshold, then in step 134 the processor 38 determines that the current frame was transmitted at the rate j.
Referring to FIG. 4, a routine 200 is performed by the processor 38 if the CRC for only one rate checks. As with step 104 (FIG. 2), the processor 38 in step 202 first determines whether the CRC for exactly one rate checks. If not, then in step 203, the processor 38 declares the current frame to be an erasure, or performs the two CRC check routine 100 or 120, as discussed above. If the CRC checks for only one rate under step 202, the processor 38 under the routine 200 employs additional steps to confirm that the rate which checked under step 202 is in fact the correct rate for the current frame. Therefore, in step 204, the processor 38 determines whether the rate which checked under step 202 corresponds to the eighth rate (i.e., i = 8). If not, then in step 206, the processor 38 determines whether the SER value for the determined rate is greater than or equal to a maximum SER threshold for that rate {i.e., SERj £ MaxSERj). If it is less than the maximum, then in step 208, the processor 38 determines that the rate of the currently received frame is equal to i; otherwise, in step 210, the processor declares an erasure.
If in step 204 the processor 38 determines that the indicated rate is equal to the eighth rate, then in step 212, the processor examines the Yamamoto value for the eighth rate (Y8). As is known, a frame at the eighth rate has fewer CRC bits than frames at the other rates, and as a result, the CRC more often. Therefore, the routine 200 employs additional checks to confirm that the current frame was transmitted at the eighth rate.

minimum thresholds under steps 230 or 232, then the processor 38 declares a current frame an erasure under step 227. However, if such SER values are greater than the minimum, then in step 234 the processor 38 determines that the current frame was transmitted at rate i.
As under the routine 200, if the rate which checked under step 202 is determined to be the eighth rate in step 204, then the processor 38 checks the Yamamoto values for the eighth rate under step 212 as discussed above. Therefore, if the Yamamoto value for the eighth rate checks, then in step 238 the processor 38 not only employs a looser maximum SER threshold for the determined rate (the eighth rate), but also employs looser minimum SER thresholds for the determined and nondetermined rates (i.e., looser Min. SERjj, SERi,k and SERy). Similarly,, under step 240, if the Yamamoto value does not check under step 212, then in step 240 the processor 38 not only employs a tighter maximum SERi threshold, but tighter minimum SER thresholds for the other rates (i.e., tighter Min. SERy, SERU and SERy). Therefore, for the eighth rate, the threshold lookup table employed by the processor 38 includes two maximum threshold values for the eighth rate, and two sets of three minimum threshold values to be employed under steps 238 and 240.
Various alternatives to the various routines are available. For example, rather than simply comparing the determined and other SER values under steps 206,228,230 and 232 of the routine 220, the processor 38 can compare the particular SER value to a linear function by multiplying the minimum or maximum SER threshold by the multiplicative factor k, and adding an appropriate weighting value W. For example, under step 206, the processor 38 can compare the SER value SERi to the function k^MaxSERi + Wj, while under step 228, the processor can compare the SERj value to the function ki,j * MinSER^ + Wj,j. Moreover, a nonlinear function can be employed under steps 206-232. However, any improvement provided by a nonlinear function will likely, at best, provide only a small incremental benefit to the routine 220 and will lead to processing complexity and thus increased processing time.
While the Yamamoto values are checked only for the eighth rate, the routine 220 can be modified so that the Yamamoto values for the other rates are also checked. As a result, corresponding tighter or looser maximum and minimum SER thresholds would be employed for each of the other rates. A larger lookup table would therefore be required under such an alternative embodiment by the processor 38. Additionally, the routines 100,120,200 can

limited by the disclosure, but instead its scope is to be determined entirely by the following claims.



WE CLAIM :
1. A method for determining current rate of a current frame at the receiver in a communication system having a transmitter that transmits to said receiver, said transmitter transmitting each of a plurality of frames at a current rate, wherein said current rate corresponds to one of a plurality of rates; the method comprising the steps of:
generating a plurality of error check values each based on whether said current frame has one of said plurality of rates, wherein only a first check value of a selected rate favorably checks, and wherein said selected rate is one of said plurality of rates;
generating a plurality of error rate codes each based on whether said current frame has one of said plurality of rates, wherein a selected error rate code corresponds to said selected rate;
generating a plurality of decoding codes each based on whether said current frame has one of said plurality of rates, wherein a selected decoding code corresponds to said selected rate;
determining if said selected rate of said selected error rate code corresponds to a predetermined rate;
if said selected rate corresponds to said predetermined rate, comparing said selected decoding code to a selected value;
if said selected rate does not correspond to said predetermined rate, comparing said selected error rate code to a first value based on a predetermined operational relationship;
if said selected decoding code corresponds to said selected value, comparing said selected error rate code to a second value based on said predetermined operational relationship;
if said selected decoding code does not correspond to said selected value, comparing said selected error rate code to a third value based on said predetermined operational relationship; and

determining that said current rate of said current frame is said selected rate if said selected error rate code has said predetermined operational relationship to said first, second or third value.
2. The method as claimed in claiml wherein the step of generating a plurality of error check values generates a plurality of cyclic redundancy check values, wherein the step of generating a plurality of error rate codes generates a plurality of symbol error rates, and wherein the step of generating a plurality of decoding codes generates a plurality of Yamamoto check codes.
3. The method as claimed in claiml wherein said plurality of rates comprises full, half, quarter and eighth rates, and wherein the step of determining if said selected rate of said selected error rate code corresponds to a predetermined rate determines if said selected rate corresponds to said eighth rate.
4. The method as claimed in claiml wherein the step of generating a plurality of decoding codes generates a plurality of Yamamoto check codes, and wherein the step of comparing said selected decoding code to a selected value comprises the step of determining if said selected Yamamoto code checks acceptably.
5. The method as claimed in claiml wherein said first, second and third values are error rate code threshold values, wherein the steps of comparing said selected error rate code to said first, second and third values determines whether said selected error rate code is less than said first, second and third threshold values, respectively, and wherein said second threshold value is greater than said third threshold value.
6. The method as claimed in claiml wherein the step of determining that said current rate of said current frame is said selected rate comprises the step of determining that said current frame is erased if said selected error rate code does not have said predetermined operational relationship to said first, second or third value.

7. The method as claimed in claim 1, comprising the steps of:
comparing at least another of said error rate codes to a minimum threshold error rate code based on a selected operational relationship; and
determining that said current frame is erased if said another of said error rate codes has said selected operational relationship to said minimum threshold.
8. A method for determining current rate of a transmitter signal in a
communication system having a transmitter and a receiver, said transmitter
transmitting the signal at said current rate, wherein said current rate corresponds to
one of a plurality of rates, and wherein said receiver generates a plurality of error
check values and error rate codes and at least one decoding code each based on
whether said signal has one of said plurality of rates; the method comprising the steps
of:
determining if only a first check value of a selected rate favorably checks, wherein said selected rate is one of said plurality of rates;
determining if said selected rate corresponds to a predetermined rate;
if said selected rate corresponds to said predetermined rate, comparing a
selected decoding code to a selected value;
if said selected rate does not correspond to said predetermined rate, comparing a selected error rate code to a first value based on a predetermined operational relationship, wherein said selected rate code corresponds to said selected rate;
if said selected decoding code corresponds to said selected value, comparing said selected error rate code to a second value based on said predetermined operational relationship;
if said selected decoding code does not correspond to said selected value, comparing said selected error rate code to a third value based on said predetermined operational relationship; and
determining that said current rate of said signal is said selected rate if said selected error rate code has said predetermined operational relationship to said first, second or third value.

9. The method as claimed in claim8 wherein said plurality of rates comprises full, half, quarter and eighth rates, and wherein the step of determining if said selected rate corresponds to a predetermined rate determines if said selected rate corresponds to said eighth rate.
10. The method as claimed in claim8 wherein said selected decoding code is a Yamamoto check code, and wherein the step of comparing a selected decoding code to a selected value comprises the step of determining if said selected Yamamoto code checks acceptably.
11. The method as claimed in claimS wherein said first, second and third values are error rate code threshold values, wherein the steps of comparing said selected error rate code to said first, second and third values determines whether said selected error rate code is less than said first, second and third threshold values, respectively, and wherein said second threshold value is greater than said third threshold value.
12. The method as claimed in claim8 wherein said signal comprises a plurality of
frames including a current frame, and wherein the step of determining that said current
rate of said signal is said selected rate comprises the step of determining that said
current frame is erased if said selected error rate code does not have said
predetermined operational relationship to said first, second or third value.
13. The method as claimed in claim8, comprising the steps of:
comparing at least another of said error rate codes to a minimum threshold error rate code based on a selected operational relationship; and
determining that said signal is erroneous if said another of said error rate codes has said selected operational relationship to said minimum threshold.

14. The method as claimed in claim8 wherein the steps of comparing comprises the step of comparing said selected error rate code to first, second and third weighting values plus said first, second and third values, respectively.
15. The method as claimed in claimS wherein the steps of comparing comprises the step of comparing said selected error rate code to first, second and third multiplicative factor times said first, second and third values, respectively.
16. The method as claimed in claim8 wherein said first value is an error rate code threshold value, and wherein the method comprises the steps of:
comparing said selected rate to a previous rate;
decreasing said first threshold value if said selected rate and said previous rate are approximately equal; and
increasing said first threshold rate if said selected rate and said previous rate are not equal.
17. In a communication system having a transmitter that transmits a signal at a
current rate, and wherein said current rate corresponds to one of a plurality of rates, a
receiver comprising:
an error check value generator configured to generate a plurality of error check values each based on whether said signal has one of said plurality of rates, wherein only a first check value of a selected rate favorably checks, and wherein said selected rate is one of said plurality of rates;
an error rate code generator configured to generate a plurality of error rate codes each based on whether said signal has one of said plurality of rates, wherein a selected error rate code corresponds to said selected rate;

a decoding code generator configured to generate at least a selected decoding code, based on whether said signal has said selected rate; and
a decoder coupled to said error check value generator, error rate code generator and decoding code generator and configured to (a) determine if said selected rate of said selected error rate code corresponds to a predetermined rate, (b) compare said selected decoding code to a selected value if said selected rate corresponds to said predetermined rate, (c) compare said selected error rate code to a first value based on a predetermined operational relationship if said selected rate does not correspond to said predetermined rate, (d) compare said selected error rate code to a second value based on said predetermined operational relationship if said selected decoding code corresponds to said selected value, (e) compare said selected error rate code to a third value based on said predetermined operational relationship if said selected decoding code does not correspond to said selected value, (f) determine that said current rate of said signal is said selected rate if said selected error rate code has said predetermined operational relationship to said first, second or third value, and (g) decode said signal based on said selected rate.
18. The receiver as claimed in claim 17 wherein said error check value generator generates a plurality of cyclic redundancy check values, wherein said error rate code generator generates a plurality of symbol error rates, and wherein said decoding code generator generates a plurality of Yamamoto check codes.
19. The receiver as claimed in claiml7 wherein said plurality of rates comprises full, half, quarter and eighth rates, and wherein said decoder determines if said selected rate corresponds to said eighth rate.
20. The receiver as claimed in claiml7 wherein said decoding code generator generates a plurality of Yamamoto check codes, and wherein said decoder determines if said selected Yamamoto code checks acceptably.

21. The receiver as claimed in claiml7 wherem said first, second and third values are error rate code threshold values, wherein said decoder determines whether said selected error rate code is less than said first, second and third values, respectively, and wherein said second threshold value is greater than said third threshold value.
22. The receiver as claimed in claiml7 wherem said signal comprises a plurality of frames, including a current frame, and wherein said decoder determines that said current frame is erased if said selected error rate code does not have said predetermined operational relationship to said first, second or third value.
23. The receiver as claimed in claiml7 wherein said decoder compares at least another of said error rate co des to a minimum threshold based on a selected operational relationship, and determines that said signal is erroneous if said another of said error rate codes has said selected operational relationship to said minimum threshold.
24. The receiver as claimed in claiml7 wherein said decoder compares said selected error rate code to first, second and third weighting values plus said first, second and third values, respectively.
25. The receiver as claimed in claim 17 wherein said decoder compares said selected error rate code to first, second and third multiplicative factors times said first, second and third values, respectively.
26. The receiver as claimed in claiml7 wherein said decoder compares said selected rate to a previous rate and decreases said first value if said selected rate and said previous rate are approximately equal.

27. A communication system comprising:
a transmitter configured to transmit a signal at a current rate, wherein said current rate corresponds to one of a plurality of rates; and
a receiver configured to receive said signal, said receiver comprising :
an error check value generator configured to generate a plurality of error check values each based on whether said signal has one of said plurality of rates, wherein only a first check value of a selected rate favorably checks, and wherein said selected rate is one of said plurality of rates;
an error rate code generator configured to generate a plurality of error rate codes each based on whether said signal has one of said plurality of rates, wherein a selected error rate code corresponds to said selected rate;
a decoding code generator configured to generate a plurality of decoding codes each based on whether said signal has one of said plurality of rates, wherein a selected decoding code corresponds to said selected rate; and
a decoder coupled to said error check value generator, error rate code generator and decoding code generator and configured to (a) determine if said s elected rate of said selected error rate code corresponds to a predetermined rate, (b) compare said selected decoding code to a selected value if said selected rate corresponds to said predetermined rate, (c) compare said selected error rate code to a first value based on a predetermined operational relationship if said selected rate does not correspond to said predetermined rate, (d) compare said selected error rate code to a second value based on said predetermined operational relationship if said selected decoding code corresponds to said selected value, (e) compare said selected error rate code to a third value based on said predetermined operational relationship if said selected decoding code does not correspond to said selected value, (f) determine that said current rate of said signal is said selected rate if said selected error rate code has said predetermined operational relationship to said first, second or third value, and (g) decode said signal based on said selected rate.
28. A method for determining said current rate of a current frame at a receiver in a

communication system having a transmitter that transmits to said receiver, said
transmitter transmitting each of a plurality of frames at a current rate, wherein said
current rate corresponds t o one of a plurality of rates; the method comprising the
steps of:
generating a plurality of error check values each based on whether said current frame has one of said plurality of rates, wherein only first and second error check values of first and second rates favorably check, and wherein said first and second rates are from said plurality of rates;
generating a plurality of error rate codes each based on whether said current frame has one of said plurality of rates, wherein first and second error rate codes correspond to said first and second rates;
comparing said first error rate code to said second error rate code plus a first value based on a predetermined operational relationship; and
determining that said current rate of said current frame is said second rate if said first error rate code has said predetermined operational relationship to said second error rate code plus a first value, and otherwise deter mining that said current rate is said first rate.
29. The method as claimed in claim28 wherein the step of generating a plurality of
error check values generates a plurality of cyclic redundancy check values, and
wherein the step of generating a plurality of error rate codes generates a plurality of
symbol error rates.
30. The method as claimed in claim28, comprising the steps of:
comparing said first error rate code to a threshold value based on a selected
operational relationship if said first error rate code does not have said predetermined operational relationship to said second error rate code plus a first value; and determining that said current frame is erased if said first error rate code has said selected operational relationship to said threshold value.

31. The method as claimed in claim28 where in the step of comparing compares said first error rate code to s aid second error rate codes times a multiplicative factor.
32. A method for determining current rate of a transmitted signal in a communication system having a transmitter and a receiver, said transmitter transmitting the signal at a current rate, wherein said current rate corresponds to one of a plurality of rates, and wherein said receiver generates a plurality of error check values and error rate codes each based on whether said signal has one of said plurality of rates; the method comprising the steps of:
determining that only first and second error check values of first and second rates favorably check, wherein said first and second rates are from said plurality of rates;
comparing a first error rate code to a second error rate code plus a first value based on a predetermined operational relationship, wherein said first and second error rate codes correspond to said first and second rates; and
determining that said current rate of said signal is said first rate if said second error rate code has said predetermined operational relationship to said second error rate code plus a first value, and otherwise determining that said current rate is said first rate.
33. The method as claimed in claim32 wherein said first and second error check values are first and second cyclic redundancy check values, and wherein said first and second error rate codes are first and second symbol error rates.
34. The method as claimed in claim32, comprising the steps of: comparing said first error rate code to a n error rate code threshold value based on a selected operational relationship if said first error rate code does not have said predetermined operational relationship to said second error rate code plus a first value; and
determining that said signal is erroneous if said first error rate code has said selected operational relationship to said threshold value.

35. The method as claimed in claim 32 wherein the step of comparing compares said first error rate code to said second error rate codes times a multiplicative factor .
36. The method as claimed in ckim32, comprising the steps of:
generating at least a selected decoding code based on said first rate; determining if said first rate corresponds to a predetermined rate;
if said first rate corresponds to said predetermined rate, comparing said selected decoding code to a selected value; and
if said selected decoding code corresponds to said selected value, altering said first value.
37. In a communication system having a transmitter that transmits each of a signal
at a current rate, wherein said current rate corresponds to one of a plurality of rates, a
receiver comprising:
an error check value generator configured to generate a plurality of error check values each based on whether said current frame has one of said plurality of rates, wherein only first and second check values of first and second rates favorably check, and wherein said first and second rates are from said plurality of rates;
an error rate code generator configured to generate a plurality of error rate codes each based on whether said current frame has one of said plurality of rates, wherein first and second error rate codes correspond to said first and second rates; and
a decoder coupled to said error check value generator and error rate code generator and configured to compare said first error rate code to said second error rate code plus a first value based on a predetermined operational relationship, determine that said current rate of said current frame is said second rate if said first error rate code has said predetermined operational relationship to said second error rate code plus a first value, and otherwise determine that said current rate is said first rate.

38. The receiver as claimed in claim 37 wherein said error check value generator generates a plurality of cyclic redundancy check values, and wherein said error rate code generator generates a plurality of symbol error rates.
39. The receiver as claimed in claim 37 wherein said decoder compares said first error rate code to a threshold value based on a selected operational relationship if said first error rate code has said predetermined operational relationship to said second error rate code plus a first value determines that said current frame is erased if said first error rate code has said selected operational relationship to said threshold value.
40. The receiver as claimed in claim 37 wherein said decoder compares said first error rate code to a multiplicative factor times said second error rate code.
41. A communication system comprising;
a transmitter configured to transmit a signal at a current rate, wherein said current rate corresponds to one of a plurality of rates; and
a receiver configured to receive said signal, said receiver comprising :
an error check value generator configured to generate a plurality of error check values each based on whether said current frame has one of said plurality of rates, wherein only first and second check values of first and second rates favorably check, and wherein said first and second rates are from said plurality of rates;
an error rate code generator configured to generate a plurality of error rate codes each based on whether said current frame has one of said plurality of rates, wherein first and second error rate codes correspond to said first and second rates; and
a decoder coupled to said error check value generator and error rate code generator and configured to compare said first error rate code to said second error rate code plus a first value based on a predetermined operational relationship, determine that said current rate of said current frame is said second rate if said first error rate

code has said predetermined operational relationship to said second error rate code plus a first value, and otherwise determine that said current rate is said first rate.
Dated this 17th day Of October 1997

Documents:

2337-mas-1997 abstract duplicate.pdf

2337-mas-1997 abstract.pdf

2337-mas-1997 assignment.pdf

2337-mas-1997 claims duplicate.pdf

2337-mas-1997 claims.pdf

2337-mas-1997 correspondence-others.pdf

2337-mas-1997 correspondence-po.pdf

2337-mas-1997 description (complete) duplicate.pdf

2337-mas-1997 description (complete).pdf

2337-mas-1997 drawings duplicate.pdf

2337-mas-1997 drawings.pdf

2337-mas-1997 form-19.pdf

2337-mas-1997 form-2.pdf

2337-mas-1997 form-26.pdf

2337-mas-1997 form-4.pdf

2337-mas-1997 form-6.pdf

2337-mas-1997 others.pdf

2337-mas-1997 petition.pdf


Patent Number 202136
Indian Patent Application Number 2337/MAS/1997
PG Journal Number 05/2007
Publication Date 02-Feb-2007
Grant Date 12-Sep-2006
Date of Filing 17-Oct-1997
Name of Patentee M/S. QUALCOMM INCORPORATED
Applicant Address 6455 LUSK BOULEVARD, SAN DIEGO, CALIFORNIA 92121
Inventors:
# Inventor's Name Inventor's Address
1 TAO CHEN 8826 LA CARTERA STREET, SAN DIEGO, CALIFORNIA 92129-3309
PCT International Classification Number H 0 4L 25/02
PCT International Application Number N/A
PCT International Filing date
PCT Conventions:
# PCT Application Number Date of Convention Priority Country
1 08/730,863 1996-10-18 U.S.A.