US 6473876 B1 Abstract The present invention includes a system and method for encoding data by altering data of a rotation block by a rotation factor dependent on data of a key block. In one embodiment, the data includes compression parameters that are descriptive of compressed data. In one embodiment, data of the second or rotation block is altered by calculating a rotation factor from data of a first or key block and altering data of second block in accordance with the rotation factor. In another embodiment, the present invention includes a method for recovering data when there are data losses by determining candidate rotation values for full decoding data of the second block and selecting a rotation value from the candidate rotation values corresponding to the first block data.
Claims(54) 1. A method for encoding data comprising:
calculating a rotation factor from a selected data of a first block; and
altering a selected data of a second block in accordance with the rotation factor such that if the selected data of the first block is lost the rotation factor may be used to estimate the selected data of the first block.
2. The method of
3. The method of
4. The method of
5. The method of
calculating a rotation factor from the selected data of the first block, wherein the rotation factor is determined as:
N _{Q} ·MF ^{key} +Qbit^{key} −Q _{MIN}, where MF
^{key }is the motion flag value of the first block, Qbit^{key }is the Qbit value of the first block, N_{Q }is the number of allowable Qbit values, and Q_{MIN }is the minimum allowable Qbit value; and altering the selected data of the second block in accordance with the rotation factor.
6. The method of
7. The method of
VAL ^{Rot})_{trans}=(VAL ^{Rot}+(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents the unaltered value of the selected data of the second block, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents a range of values for the rotation factor.8. A method for recovering lost/damaged data of a first block comprising:
receiving an altered data of a second block;
determining candidate values of recovered unaltered data corresponding to selected altered data of the second block, the altered data created by altering a selected data of the second block in accordance with a rotation factor calculated from a selected data of the first block such that the lost/damaged data of the first block may be estimated;
selecting a recovered unaltered value from the candidate values; and
determining recovered lost/damaged data of first block from the selected recovered unaltered value.
9. The method of
VAL ^{Rot}=((VAL ^{Rot})_{trans}−(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents recovered unaltered data, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents one of a set of possible rotation factors and is varied for determination of each candidate value. 10. The method of
determining a rotation factor from the selected recovered unaltered value;
determining at least one of the compression parameters of a first block associated with the second block using the rotation factor.
11. The method of
12. The method of
13. The method of
14. The method of
15. A method of encoding a stream of data points comprising:
encoding a stream of data points to form a plurality of blocks of encoded data; and
altering at least one block parameter of a second block by using a factor that is dependent on a bitstream parameter of a first block, said block parameter representative of the encoding of data points of the block and said bitstream parameter representative of how bits are utilized to encode the first block such that if the bitstream parameter of the first block is lost the factor may be used to estimate the bitstream parameter of the first block.
16. The method of
two-dimensional static images, hologram images, three-dimensional static images, video, two-dimensional moving images, three dimensional moving images, monaural sound, and N-channel sound.
17. The method of
complementary blocks, shifted blocks, randomized blocks, and shuffled blocks.
18. A computer readable medium containing executable instructions, which, when executed in a processing system, causes the system to perform the steps for encoding data, comprising:
calculating a rotation factor from a selected data of a first block; and
altering a selected data of a second block in accordance with the rotation factor such that if the selected data of the first block is lost the rotation factor may be used to estimate the selected date of the first block.
19. The computer readable medium of
20. The computer readable medium of
21. The computer readable medium of
22. The computer readable medium of
calculating a rotation factor from the selected data of the first block wherein the rotation factor is determined as:
N _{Q} ·MF ^{key} +Qbit^{key} −Q _{MIN}, where MF
^{key }is the motion flag value of the first block, Qbit^{key }is the Qbit value of the first block, N_{Q }is the number of allowable Qbit values, and Q_{MIN }is the minimum allowable Qbit value; and altering the selected data of the second block in accordance with the rotation factor.
23. The computer readable medium of
24. The computer readable medium of
VAL ^{Rot})_{trans}=(VAL ^{Rot}+(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents the selected data of the second block, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents a range of values for the rotation factor.25. A computer readable medium containing executable instructions, which, when executed in a processing system, causes the system to perform the steps for recovering lost/damaged data of a first block comprising:
receiving an altered data of a second block, the altered data created by altering a selected data of the second block in accordance with a rotation factor calculated from a selected data of the first block such that the lost/damaged data of the first block may be estimated;
determining candidate values of recovered unaltered data corresponding to selected altered data of the second block;
selecting a recovered unaltered value from the candidate values; and
determining recovered lost/damaged data of first block from the selected recovered unaltered value.
26. The computer readable medium of
VAL ^{Rot}=((VAL ^{Rot})_{trans}−(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents recovered unaltered data, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents one of a set of possible rotation factors and is varied for determination of each candidate value. 27. The computer readable medium of
determining a rotation factor from the recovered unaltered value; and
determining at least one of the compression parameters of a first block associated with the second block using the rotation factor.
28. The computer readable medium of claims
25, wherein the recovered unaltered data comprises block parameters.29. The computer readable medium of claims
25, wherein the lost/damaged data comprises bitstream parameters.30. The computer readable medium of
31. The computer readable medium of
32. A computer readable medium containing executable instructions, which, when executed in a processing system, causes the system to perform the steps of encoding a stream of data points comprising:
encoding a stream of data points to form a plurality of blocks of encoded data; and
altering at least one block parameter of a second block by using a factor that is dependent on a bitstream parameter of a first block, said block parameter representative of the encoding of data points of the block and said bitstream parameter representative of how bits are utilized to encode the first block such that if the bitstream parameter of the first block is lost the factor may be used to estimate the bitstream parameter of the first block.
33. The computer readable medium of
34. The computer readable medium of
35. A system for encoding data comprising:
calculating a rotation factor from a selected data of a first block; and
altering a selected data of a second block in accordance with the rotation factor such that if the selected date of the first block is lost the rotation factor may be used to estimate the selected date of the first block.
36. The system of
37. The system of
38. The system of
39. The system of
calculation logic configure to calculate a rotation factor from selected data of the first block wherein the rotation factor is determined as:
N _{Q} ·MF ^{key} +Qbit^{key} −Q _{MIN}, where MF
^{key }is the motion flag value of the first block, Qbit^{key }is the Qbit value of the first block, N_{Q }is the number of allowable Qbit values, and Q_{MIN }is the minimum allowable Qbit value; and wherein the altering logic is configured to alter the selected data of the second block in accordance with the rotation factor.
40. The system of
41. The system of
VAL ^{Rot})_{trans}=(VAL ^{Rot}+(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents the unaltered value of the selected data of the second block, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents a range of values for the rotation factor. 42. The system of
43. A system for recovering lost/damaged data of a first block comprising:
an input configured to receive an altered data of a second block, the altered data created by altering a selected data of the second block in accordance with a rotation factor calculated from a selected data of the first block such that the lost/damaged data of the first block may be estimated;
candidate value logic configured to determine candidate values of recovered unaltered data corresponding to selected altered data of the second block;
selecting logic configured to select a recovered unaltered value from the candidate values; and
determining logic configured to determine lost/damaged data of first block from the selected recovered unaltered value.
44. The system of
VAL ^{Rot}=((VAL ^{Rot})_{trans}−(256/N)·rotation factor)mod 256, where VAL
^{Rot }represents recovered unaltered data, (VAL^{Rot})_{trans }represents the altered value of the selected data of the second block, and N represents one of a set of possible rotation factors and is varied for determination of each candidate value. 45. The system of
determining logic configured to determine a rotation factor from the selected recovered unaltered value;
determining logic configured to determine at least one of the compression parameters of a first block associated with the second block using the rotation factor.
46. The system of
47. The system of
48. The system of
49. The system of
50. The system of
51.A system of encoding a stream of data points comprising:an input configured to encode a stream of data points to form a plurality of blocks of encoded data; and
altering logic configured to alter at least one block parameter of a second block by using a factor that is dependent on a bitstream parameter of a first block, said block parameter representative of the encoding of data points of the block and said bitstream parameter representative of how bits are utilized to encode the first block such that if the bitstream parameter of the first block is lost the factor may be used to estimate the bitstream parameter of the first block.
52. The system of
two-dimensional static images, hologram images, three-dimensional static images, video, two-dimensional moving images, three dimensional moving images, monaural sound, and N-channel sound.
53. The system of
complementary blocks, shifted blocks, randomized blocks, and shuffled blocks.
54. An apparatus for encoding data, comprising:
means for calculating a rotation factor from a selected data of a first block; and
means for altering a selected data of a second block in accordance with the rotation factor such that if the selected data of the first block is lost the rotation factor may be used to estimate the selected data of the first block.
55. An apparatus for recovering lost/damaged data of a first block comprising:
means for receiving an altered data of a second block, the altered data created by altering a selected data of the second block in accordance with a rotation factor calculated from a selected data of the first block such that the lost/damaged data of the first block may be estimated;
means for determining candidate values of recovered unaltered data corresponding to selected altered data of the second block;
means for selecting a recovered unaltered value from the candidate values; and
means for determining recovered lost/damaged data of first block from the selected recovered unaltered value.
Description 1. Field of the Invention The present invention relates to encoding of data to provide for robust error recovery due to data losses typically incurred during transmission of signals. 2. Art Background A number of techniques exist for reconstructing lost data due to random errors that may occur during signal transmission or storage. However, these techniques cannot handle the loss of consecutive packets of data. Consecutive loss of packets of data is described in the art as burst error. Burst errors may result in a reconstructed signal with such a degraded quality that it is easily apparent to the end user. Additionally, compression methodologies used to facilitate high speed communications compound the signal degradation caused by burst errors, thus adding to the degradation of the reconstructed signal. Examples of burst error loss affecting transmitted and/or stored signals is seen in high definition television (“HDTV”) signals, mobile telecommunication applications, as well as video storage technologies including video disk and video cassette recorders (VCRs). In one application, the advent of HDTV has led to television systems with a much higher resolution than the current standards proposed by the National Television Systems Committee (“NTSC”). Proposed HDTV signals are predominantly digital. Accordingly, when a color television signal is converted for digital use it is common that the luminance and chrominance signals are digitized using eight bits. Digital transmission of NTSC color television requires a nominal bit rate of about two hundred and sixteen megabits per second. The transmission rate is greater for HDTV which would nominally require about 1200 megabits per second. Such high transmission rates are well beyond the bandwidths supported by current wireless standards. Accordingly, an efficient compression methodology is required. Compression methodologies also play an important role in mobile telecommunication applications. Typically, packets of data are communicated between remote terminals in mobile telecommunication applications. The limited number of transmission channels in mobile communications requires an effective compression methodology prior to the transmission of packets. A number of compression techniques are available to facilitate high transmission rates. Adaptive Dynamic Range Coding (“ADRC”) and Discrete Cosine Transform (“DCT”) Coding provide image compression techniques known in the art. Both techniques take advantage of the local correlation within an image to achieve a high compression ratio. However, an efficient compression algorithm can result in compounded error propagation because errors in an encoded signal are more prominent when subsequently decoded. This error multiplication can result in a degraded video image that is readily apparent to the user. The present invention includes a system and method for encoding data by altering data of a rotation block by a rotation factor dependent on data of a key block. In one embodiment, the data includes compression parameters that are descriptive of compressed data. In one embodiment, data of the second block is altered by calculating a rotation factor from data of a first block and altering data of the second block in accordance with the rotation factor. In another embodiment, the present invention includes a method for recovering data when there are data losses by determining candidate rotation values for full decoding data of the second block and selecting a rotation value from the candidate rotation values corresponding to the first block data. The objects, features and advantages of the present invention will be apparent from the following detailed description in which: FIG. 1A shows an embodiment of the signal encoding, transmission, and subsequent decoding processes. FIGS. 1B and 1C show embodiments of the present invention implemented as software executed by a processor. FIGS. 1D and 1E show embodiments of the present invention implemented as hardware logic. FIG. 2A shows an embodiment of the method of the present invention for encoding data. FIG. 2B shows an embodiment of the method of the present invention for recovering lost or damaged data. FIG. 3 shows an image laid out into an exemplary pattern of rectangular blocks. FIG. 4A shows rectangular regions of an image decomposed into one embodiment of even and odd subsample blocks. FIG. 4B shows one embodiment of even and odd block definitions shifted relative to one another to increase robustness. FIG. 5 shows one embodiment of rotation blocks associated with key blocks. FIG. 6 shows one embodiment of how the rotation method can be used in Adaptive Dynamic Range Coding method. The present invention provides a method for coding and arranging a signal stream to provide for a robust error recovery and methods for performing error recovery. In the following description, for purposes of explanation, numerous details are set forth, in order to provide a thorough understanding of the present invention. However, it will be apparent to one skilled in the art that these specific details are not required in order to practice the present invention. In other instances, well known electrical structures and circuits are shown in block diagram form in order not to obscure the present invention unnecessarily. The following is described in the context of Adaptive Dynamic Range Coding (ADRC) encoded images, and more particularly to the recovery of lost or damaged (lost/damaged) compression parameters such as dynamic range (DR) and minimum value (MIN). However, it is contemplated that the present invention is not limited to ADRC encoding and the particular compression parameters generated; rather it will be apparent that the present invention is applicable to different compression technologies, different types of correlated data, including, but not limited to, sound data and the like, and different compression parameters including, but not limited to, the maximum value (MAX) and central value (CEN) which may be used in ADRC processes. In addition, the present invention is applicable to different types of ADRC processes including edge-matching and non edge-matching ADRC. For further information regarding ADRC, see “Adaptive Dynamic Range Coding Scheme for Future HDTV Digital VTR”, Kondo, Fujimori, Nakaya, Fourth International Workshop on HDTV and Beyond, Sep. 4-6, 1991, Turin, Italy. ADRC has been established as a feasible real-time technique for coding and compressing images in preparation for constant bit-rate transmission. The discrete data points that make up a digital image are known as pixels. Typically, each pixel is represented independently using 8 bits, but other representations can also be used for the purposes of compression or analysis. Many representations begin by dividing this raw data into disjoint sets. For historical reasons, these sets, which may be composed of one or more pieces of data or pixels, are referred to as “blocks”, even though they may not have a traditional block shape. The data may then be characterized by compression parameters. In one embodiment, these compression parameters include block parameters and bitstream parameters. A block parameter includes data that describes how an image looks. The block parameter therefore may be used to define one or more attributes of a block. For example, in ADRC, block-wide information can include the minimum pixel value (MIN), the maximum pixel value (MAX), the central pixel value (CEN), and/or the dynamic range of the pixel values (DR). A bitstream parameter may include data that describes how an image is encoded. In one embodiment, a bitstream parameter may indicate the number of bits used to encode data. For example, in ADRC, the bitstream parameters may include Qbit and motion flag (MF) values. In this embodiment, the bitstream parameter therefore can indicate how the data is encoded that represents where the pixel value lies within the range specified by the global information. If a bitstream parameter is lost, the compressed image may be lost because the decoder will not know where the compressed block of data begins or ends. Therefore, an advantage of the present invention is providing for the recovery of data that describes how an image is encoded. In one example in which ADRC encoding is used, the block data is comprised of the MIN, DR and Qbit number (defined below), and the pixel data is comprised of Qcodes. DR may be defined as MAX−MIN or MAX−MIN+1. CEN may be defined as a value set between MIN and MAX. For example, CEN may be equal to MIN+DR/2. A Qcode is an integer in the range [0,2 Temporal compression is feasible for a sequence of like images spanning more than one instance in time. An image frame is defined as the 2-dimensional collection of pixels arising within a given time period. It is well known that data from corresponding locations of temporally close image frames is likely to contain similar values. When this is true, compression is improved by encoding each of these like values only once. In a second example, multiple image frames are encoded by adding a motion flag (MF) to the block information of the first example. This MF indicates whether or not data from each frame is encoded using separate Qcodes. If no motion is indicated, the same Qcodes are used to represent each frame of data. If motion is indicated, then separate Qcodes are used to encode each frame. Two methods of ADRC coding typically can be used: non-edge-matching ADRC, and edge matching ADRC. These methods differ in the precise formula used to generate the quantization code (Qcode) values. On the other hand, the methods have much in common. Both methods begin by segmenting the image into blocks, and then determining the maximum (MAX) and minimum (MIN) pixel value for each block. In 2D ADRC, one quantization code (Qcode) value is determined for each pixel. In 3D ADRC, a motion flag (MF) value (1 if motion, 0 otherwise) is determined for each block. When the motion flag is 1, a unique Qcode can be determined for each block. When the motion flag is 0, then corresponding pixel values can be averaged for each block, the MAX and MIN values are updated accordingly, and a single Qcode can be determined that will represent the corresponding pixels from each frame. Non-edge-matching ADRC can define the DR value as
and a quantization code as where Q is the number of quantization bits, and x where MAX represents the maximum level of a block, MIN represents the minimum level of a block, Q represents the number of quantization bits, q Edge-matching ADRC can define the DR value as
and a quantization code as where Q is the number of quantization bits, and x where MAX represents the maximum level of a block, MIN represents the minimum level of a block, Q represents the number of quantization bits, q In Central Value ADRC, the central value (CEN) can be transmitted in place of the MIN value. In one embodiment, the CEN value may be defined as
To minimize rounding errors the CEN value might actually be computed as CEN=MIN+└(DR+1)/2┘ in a practical system. In this embodiment, the reconstruction formulas for x′ and in the case of edge-matching ADRC In the error-free case, the performance of Central Value ADRC using CEN is similar to ADRC using a MIN value. However, in the presence of DR loss, Central Value ADRC may provide better lost/damaged data recovery performance compared with the MIN value ADRC. Variable length image compression schemes, such as ADRC, are designed to distribute most compression bits to the highly active parts of an image. Naturally, this distribution is data dependent, and so the decoder needs special knowledge to decipher the bitstream. Qbit and MF values are examples of bitstream parameters which describe the distribution of bits, thus enabling the decoder to decipher the bitstream. When a bitstream parameter is lost, the decoder is in danger of losing all of the data that remains to be decompressed. Therefore, accurate recovery methods are advantageous. The rotation method of the present invention supports the recovery of data, including compression parameters such as the bitstream parameters or block parameters discussed above. In one embodiment, data from a second or rotation block is modified by a rotation factor that is dependent on data of a first or key block. When selected data of the first block is subsequently destroyed during transmission, it may be recovered by using the rotation factor used to modify the second block. The signal encoding, transmission, and subsequent decoding processes are generally illustrated in FIG. Encoder Embodiment of the circuits for encoding and recovering lost/damaged compression parameters are shown in FIGS. 1B and 1C. The methods described herein can be implemented on a specially configured or general purpose processor system An alternate embodiment of the circuits for encoding compression parameters and recovering lost/damaged compression parameters are shown in FIGS. 1D and 1E. The methods described herein may be implemented in specially configured logic, such as Application Specific Integrated Circuits (ASIC), large scale integration (LSI) logic, a programmable gate array, or one or more processors. In FIG. 1D, calculation logic One embodiment of a process for encoding using rotation is illustrated by the flow diagram of FIG. At step At step FIG. 2B generally describes one embodiment of a process for recovering lost/damaged data. In this embodiment, the selected data of the first block (used to generate the rotation factor of the second block as described with reference to FIG. 2A) have been lost or damaged and the rotated data of the second block is used to estimate selected data of the first block. Referring to FIG. 2B, at step At step Examples of the processes of encoding data and recovering lost/damaged data will now be discussed. First, pixels of an image are grouped to form equal sized rectangular blocks, where each block has an even number of pixels. For simplicity, assume that the image is a multiple of 3 blocks high. The blocks are cyclically labeled Each block may be separated into two subsample blocks, as shown in FIG. Each block acts as a key block for another block called a rotation block, as shown in FIG. For example, suppose all segment
The rotation factor associated with each combination of the Qbit and MF values is an integer between 0 and N−1. This provides a unique rotation factor for every possible Qbit and MF value. Therefore, the Qbit and MF values can be easily determined from the rotation factor. For this example, where there are 6 different combinations of Qbit and MF values (since there are N
A value of the rotation block (VAL
where VAL is a compression value of the rotation block that is altered. This value can be CEN, MIN, MAX, DR, or any other compression value. In this example, the central value is rotated. Therefore, the CEN value is altered as follows:
where (CEN Now suppose the key block's Qbit and MF values are 3 and 1, respectively, and the rotation block's CEN value is 147. Then the rotation factor is computed as 3·1+3−2=4, and (CEN When there is no transmission loss, the central value CEN
Finally, the block level parameter (CEN
However, there may be a loss during transmission. Now suppose the bitstream suffers 1/6 damage such that all blocks in segment To illustrate the recovery process when there is a transmission error, assume that the key block's Qbit and MF values were both lost during transmission, but the rotation key block's transmitted central value (CEN For example, when a rotation factor of 1 is used in equation (14), the value CEN
The decoder may use a variety of techniques to estimate the value of CEN. For example, several techniques for estimating MIN are known, as discussed below. These methods can also be used to estimate CEN, because CEN=MIN+[DR/2]. Thus, replacing MIN with CEN−[DR/2] in the expressions below, and solving for CEN, will provide an estimate of CEN. MIN may be estimated as the value that minimizes an average difference between decoded values from the block and corresponding decoded values from at least one neighboring block. The average function can be a weighted average of neighboring values, for example, the values may be weighted relative to the location of the neighboring block with respect to the block of interest. In one embodiment, MIN may be estimated using a least squares estimation. For example, MIN may be determined as follows: Non edge-matching ADRC Edge-matching ADRC where N represents a number of neighboring encoded data to use, MIN′ represents the MIN value of the neighboring block, DR and DR′ respectively represents the DR value of the block and the neighboring block, Q represents a number of quantization bits used to encode the block, Q′ represents a number of quantization bits used to encode the neighboring block, e The DR value may be used in place of the CEN or MIN value. Therefore, if the DR value is lost/damaged, the MIN value and Qcodes of the block and the DR, MIN and Qcodes of the neighboring block are used to estimate DR. In one embodiment, DR may be estimated using a least squares estimation. For example: An Integer Formula for Non Edge-matching ADRC An Integer Formula for Edge-matching ADRC where N represents a number of neighboring encoded data to use, MIN and MIN′ respectively represent the MIN value of the block and the neighboring block, Q represents a number of quantization bits used to encode, Q′ represents a number of quantization bits used to encode the neighboring block, e In another embodiment, an alternate recovery formula may be used. DR may be estimated as the value that makes the sum of decoded values of the block equal to the sum of the decoded values of the neighboring block. For example, DR is determined according to the following equation: Non Edge-matching ADRC Edge-matching ADRC where N represents a number of neighboring encoded data to use, MIN and MIN′ respectively represent the MIN value of the block and the neighboring block, Q represents a number of quantization bits used to encode, Q′ represents a number of quantization bits used to encode the neighboring block, e Other embodiments are also contemplated. For example, if MIN and MAX are used as compression parameters, and one of them is damaged, DR is estimated and the compression parameter is computed from the estimated DR. Furthermore, if MAX and DR are used, processing similar to MIN and DR described herein is used. Furthermore, other parameters not specifically identified herein may be used. It is contemplated that other parameters may function similar to MIN and appropriate equations would be derived therefrom. Therefore, the value of the compression parameter in the present example, CEN can be estimated. Suppose, for instance, the estimate is
The decoder determines that the closest candidate value to the estimate of 150 is 147, using the table computed earlier, which corresponds to a rotation factor of 4. Thus, the decoder determines that the proper CEN value of the rotation block is 147 and that the lost Qbit and MF values of the key block are 3 and 1, respectively. Note the minimum distance between the possible values of CEN Variations on the above description involve changing the number of segments or the rotation quantities. For example, the DR values, the complementary CEN values, the MIN value, frequency component, or any other appropriate value of the rotation block may be rotated. Other variations involve using multiple key blocks together to transform the block level parameters of multiple rotation blocks. The rotation factor can also be changed. For example, the rotation factor equation could include the LSB's of the DR for the key block, or the CEN value of the key block, or any other appropriate value of the key block. Auxiliary information that narrows the range of allowable DR values can also be added to the rotation factor equation. Another variation involves using the key block's Qbit and MF values to shuffle Qcode values. Using this variation, other recovery methods, which rely on Qcode correlations, such as those known in the art, may be combined with the currently proposed methods. FIG. 6 gives an example of how the rotation method may be used within the context of an ADRC image transmission system. In one embodiment, the data block may consist of CEN, DR, and MF values, and possibly an ADRC table threshold indices. The Qbit values may be derived from the DR values, for example, using a threshold table of DR values which specify possible corresponding Qbit values. The proposed system has many strengths. One strength is that the same circuit that is used to estimate lost block parameters may also be used to determine the rotation factors. This dual-use reduces system complexity and cost. Another strength is that, in a system in which Qcodes are not shuffled, parallel candidate evaluation is not required, since the decoder simply selects the closest match from an easily determined list. A third strength is that only the most trivial types of shuffling are demanded while providing error recovery robustness. At step Although the present invention is discussed with respect to three dimensional image (e.g., video) data, the present invention may be used with any form of correlated data, including without limitation photographs or other two-dimensional static images, holograms, or other three-dimensional static images, video or other two-dimensional moving images, three-dimensional moving images, a monaural sound stream, or sound separated into a number of spatially related streams, such as stereo. The invention has been described in conjunction with the preferred embodiment. It is evident that numerous alternatives, modifications, variations and uses will be apparent to those skilled in the art in light of the foregoing description. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |