# Case 3:05-cv-01958-B-BLM Document 1 Filed 10/14/05 Page 1 of 55 USDC SCAN INDEX SHEET APB 10/17/05 11:03 3:05-CV-01958 QUALCOMM INC V. BROADCOM CORPORATION \*1\* \*CMP.\* Case 3:05-cv-01958-B-BLM Document 1 Filed 10/14/05 Page 2 of 55 David E. Kleinfeld (Bar No. 110734) 1 C3 CCT 14 PH 4: 012 Barry J. Tucker (Bar No. 164163 HELLER EHRMAN LLP 2 4350 La Jolla Village Drive, 7th Floor San Diego, CA 92122 3 Telephone: (585) 450-8400 4 Facsimile: (585) 450-8499 5 Robert T. Haslam (Bar No. 71134) Nitin Subhedar (Bar No. 171802) HELLER EHRMAN LLP 6 275 Middlefield Road Menlo Park, CA 94025 7 Telephone: (650) 324-7000 8 Facsimile: (650) 324-0638 9 James R. Batchelder (Bar No. 136347) DAY CASEBEER MADRID & BATCHELDER LLP 20300 Stevens Creek Blvd., Suite 400 10 Cupertino, CA 95014 Telephone: (408) 873-0110 11 Facsimile: (408) 873-0220 12 Louis M. Lupin (Bar No. 120846) Alexander H. Rogers (Bar No. 131879) 13 Roger Martin (Bar No. 195003) **QUALCOMM INCORPORATED** 14 5775 Morehouse Drive San Diego, CA 92121 15 (858) 658-1121 16 Attorneys for Plaintiff 17 QUALCOMM INCORPORATED 18 UNITED STATES DISTRICT COURT 19 SOUTHERN DISTRICT OF CALIFORNIA 20 (NL\$ CASE NO. 115 CV 1958 1EG QUALCOMM INCORPORATED, 21 Plaintiff, 22 COMPLAINT FOR PATENT INFRINGEMENT 23 ٧. DEMAND FOR JURY TRIAL **BROADCOM CORPORATION,** 24 25 Defendant. 26 27 28 COMPLAINT FOR PATENT INFRINGEMENT DEMAND FOR JURY TRIAL 8 13 11 14 16 15 17 19 18 20 21 22 23 24 25 26 27 28 Plaintiff QUALCOMM Incorporated ("QUALCOMM") for its complaint herein states: #### **PARTIES** - Plaintiff QUALCOMM is a corporation organized and existing under the laws of the 1. state of Delaware, with its principal place of business in San Diego, California. - Defendant Broadcom Corporation ("Broadcom") is a corporation organized and 2. existing under the laws of the state of California, with its principal place of business in Irvine, California. - 3. OUALCOMM is informed and believes and thereon alleges that Broadcom is doing business in California and in this district. #### JURISDICTION AND VENUE - 4. This is an action for patent infringement. The claims arise under the patent laws of the United States, Title 35 U.S.C. §§ 1 et seq. This Court has subject matter jurisdiction over these claims pursuant to 28 U.S.C. §§ 1331 and 1338(a). - Venue is proper in this district under 28 U.S.C. §§ 1391(b) and (c), and 1400(b), as 5. Broadcom resides and/or conducts substantial business in this district and has committed, and is continuing to commit, acts of infringement in this district. #### **GENERAL ALLEGATIONS** 6. This action arises out of Broadcom's infringement of two (2) patents assigned to QUALCOMM. #### **QUALCOMM's Patents** - 7. On September 17, 1995, United States Patent No. 5,452,104 (the "'104 Patent"), entitled "Adaptive Block Size Image Compression Method and System," was duly and legally issued to QUALCOMM as assignee of the inventor, Chong U. Lee. A true and correct copy of the '104 Patent is attached hereto as Exhibit 1. - 8. On November, 19, 1996. United States Patent No. 5,576,767 (the "'767 Patent"), entitled "Interframe Video Encoding and Decoding System," was duly and legally issued to QUALCOMM as assignee of the inventors, Chong U. Lee and Donald Pian. A true and correct copy of the '767 Patent is attached hereto as Exhibit 2. - 9. The patents described in paragraphs 7 through 8 above, copies of which are attached hereto as Exhibits I through 2, are referred to collectively herein as the "patents-in-suit." The patents-in-suit relate generally to the processing of digital video signals. - 10. On information and belief, Broadcom manufactures, sells and offers for sale in the United States products that comply with the H.264 standards and technical specifications adopted by the International Telecommunication Union ("ITU-T"), which standards are also known as ISO/IEC MPEG-4 Part 10, and/or manufactures, sells and offers for sale in the United States products intended to be used with or incorporated into products or systems that comply with said standards. - 11. QUALCOMM is informed and believes and thereon alleges that Broadcom has been and is infringing, literally and/or under the doctrine of equivalents, one or more claims of each of the patents-in-suit directly and/or indirectly pursuant to 35 U.S.C. § 271(a), (b), (c) and/or (f). # FIRST CAUSE OF ACTION Patent Infringement (35 U.S.C. §§ 271 et seq.) - 12. QUALCOMM refers to and incorporates paragraphs 1 through 11 inclusive, as though fully set forth herein. - 13. QUALCOMM is informed and believes and thereon alleges that Broadcom has been and is infringing, literally and/or under the doctrine of equivalents, one or more claims of each of the patents-in-suit directly and/or indirectly pursuant to 35 U.S.C. § 271(a), (b), (c) and/or (f). - 14. Broadcom threatens to continue to do the acts complained of herein, and unless restrained and enjoined will continue to do so, all to QUALCOMM's irreparable damage. - 15. By reason of Broadcom's acts alleged herein, QUALCOMM has suffered, is suffering, and unless such acts are enjoined by the Court will continue to suffer injury to its business and property rights, for which it is entitled to damages pursuant to 35 U.S.C. § 284 in an amount to be proved at trial. - 16. By reason of Broadcom's acts alleged herein, QUALCOMM has suffered, is suffering, and unless such acts are enjoined by the Court will continue to suffer irreparable harm for which there is no adequate remedy at law, and for which QUALCOMM is entitled to permanent injunctive relief pursuant to 35 U.S.C. § 283. suit; COMPLAINT FOR PATENT INFRINGEMENT DEMAND FOR JURY TRIAL #### **PRAYER** WHEREFORE, QUALCOMM prays for judgment against Broadcom as follows: - (a) For judgment that Broadcom has infringed, directly and/or indirectly, the patents-in- - (b) For a preliminary and permanent injunction prohibiting Broadcom, and all persons or entities acting in concert with Broadcom, from infringing, directly and/or indirectly, the patents insuit; - (c) For an award to QUALCOMM of all compensatory damages resulting from the direct and/or indirect infringement by Broadcom of the patents-in-suit, including pre-judgment and post-judgment interest; - (d) For judgment and an order directing Broadcom to pay QUALCOMM's reasonable attorneys' fees, expenses and costs due to this being an "exceptional" case within the meaning of 35 U.S.C. § 285; - (e) For judgment directing Broadcom to pay costs of suit; and - (f) For an award to QUALCOMM of such other and further relief as the court deems equitable, just and proper. Dated: October 14, 2005 DAY CASEBEER MADRID & BATCHELDER LLP James R. Batchelder Attorneys for Plaintiff QUALCOMM Incorporated **DEMAND FOR JURY TRIAL** Pursuant to Rule 38 of the Federal Rules of Civil Procedure, QUALCOMM demands a trial by jury on all issues triable of right by a jury. Dated: October 14, 2005 **DAY CASEBEER** MADRID & BATCHELDER LLP Attorneys for Plaintiff QUALCOMM Incorporated COMPLAINT FOR PATENT INFRINGEMENT 28663\_1.doc DEMAND FOR JURY TRIAL Case No. 05 cv 1392 B (BLM) US005452104A ## United States Patent [19] Lee [11] Patent Number: 5,452,104 [45] Date of Patent: Sep. 19, 1995 #### [54] ADAPTIVE BLOCK SIZE IMAGE COMPRESSION METHOD AND SYSTEM [75] Inventor: Cheng U. Lee, San Diego, Calif. [73] Assignee: Qualcomm Incorporated, San Diego, Calif [21] Appl. No.: 102,124 [22] Filed: Aug. 4, 1993 # Related U.S. Application Data [63] Continuation of Ser. No. 4,213, Jan. 13, 1993, abandoned, which is a continuation of Ser. No. 710,216, Jun. 4, 1991, abandoned, which is a continuation-ispart of Ser. No. 487,012, Feb. 27, 1990, Pat. No. 3,021,891. [51] Int. Cl.<sup>4</sup> H04N 1/415 [52] U.S. Cl. 358/433; 358/261.2; 348/404 [56] References Cited #### U.S. PATENT DOCUMENTS | 4,774,574 | 9/1988 | Daly et al | 358/133 | |-----------|---------|----------------|---------| | 4,776,030 | 10/1988 | Tzou | 358/432 | | 4,922,341 | 5/1990 | Strobach | 358/136 | | 4,924,309 | 5/1990 | Hartnack et al | 358/133 | | 4,984,076 | 1/1991 | Watanabe et al | 358/133 | | 5,021,891 | 6/1991 | Lœ | 358/432 | | 5.045,938 | 9/1991 | Sogiyama | 358/133 | | 5,073,820 | 12/1991 | Nakagawa et al | 358/209 | | 5,073,821 | 12/1991 | Juri . | | | 5,107,345 | 4/1992 | Lee | 358/136 | | 5,126,157 | 6/1992 | Watenabe et al | 358/432 | | 5,142,380 | 1/1992 | Sakagami et al | 358/432 | | 5,227,878 | 7/1993 | Puri et al | | | 5,272,528 | 12/1993 | Juri et al | | | 5,335,016 | 1/1994 | Nakagawa . | | | | | | | #### OTHER PUBLICATIONS "Discrete Cosine Transform" by N. Ahmed et al., IEEE Transactions on Computers, Jan. 1974, pp. 90-93. "Adaptive Coding of Monochrome and Color Images" by Wen-Hsiung Chen et al., IEEE Transactions on Communications, vol. Com-25 No. 11, Nov. 1977 pp. 1285-1292. "Interframe Cosine Transform Image Coding" by John A. Roese et al., IEEE Transactions on Communications, vol. Com-25, No. 11, Nov. 1977, pp. 1329-1339. "Distributions of the Two-Dimensional DCT Coefficients for Images" by Randall C. Raininger et al., IEEE Transactions on Communications, vol. Com-31, No. 6, Jun. 1983, pp. 835-839. "Scene Adaptive Coder": by Wen-Hsiung Chen et al., IEEE Transactions on Communications, vol. Com-32, No. 3, Mar. 1984, pp. 225-232. "Hamming Coding of DCT-Compressed Images over Noisy Chamaels" by David R. Comstock et al., IEEE Transactions on Communications, vol. Com-32, No. 7, Jul. 1984, pp. 856-861. "Variable Block-Size Transform Image Coder" by Its' Hak Dinstein et al., IEEE Transactions on Communications, vol. 38, No. 11, Nov. 1990, pp. 2073-2078. "Quadtree-Structured Recursive Plane Decomposition Coding of Images" by Peter Strobach, IEEE Transactions on Signal Processing, vol. 39, No. 6, Jun. 1991. Primary Examiner—Edward L. Coles, Sr. Assistant Examiner—Kim Yen Vu Attorney, Agent, or Firm—Russell B. Miller; Sean English #### [57] ABSTRACT In an adaptive block size image compression method and system for compressing image data, a respective method and system for further compressing the image data for transmission. Each block and corresponding sub-blocks of pixel data is subjected to a discrete cosine transform (DCT) operation. Varying levels of subblocks of resulting corresponding transform coefficients are selected for construction into a composite transform coefficient block corresponding to each input block of pixel data. The selection of transform coefficient block size for the composite block is determined by a comparison process between transform block and sub-block coding efficiency. The composite block is variable length coded to further reduce bit count in the compressed data. A discrete quadtree transform (DQT) operation is in supplement of the adaptive block size block selection with coefficient replacement to optimize image data compression. ### 61 Claims, 10 Drawing Sheets U.S. Patent 19, 1995 Sheet 1 of U.S. Patent Sep. 19, 1995 Sheet 3 of 10 5,452,104 FIG. 3A FIG. 3B FIG. 4A Ex. 1-4 5,452,104 Ex. 1-5 U.S. Patent Ş 19, 1995 Sheet 5 of 10 Ex. 1- U.S. Patent Scp. 19, 1995 Sheet 6 of 10 5,452,10 19, 1995 Short 7 of ಕ Sep. 19, 1995 U.S. Patent SHEET O OF TO 5,452,10 Ex. 1-9 U.S. Patent Sep. 19, 1995 Sheet 9 of 10 5,452,104 **FIG. 10** U.S. Patent Sep. 19, 1995 Sheet 10 of 10 5,452,104 FIG. 11 #### ADAPTIVE BLOCK SIZE IMAGE COMPRESSION METHOD AND SYSTEM This application is a continuation of application Ser. 5 No. 08/004,213, filed Jan. 13, 1993, abandoned, which is a continuation of application Ser. No. 07/710,216, filed Jun. 4, 1991, now abandoned, which is a continuationin-part application of U.S. patent application Ser. No. issued Jun. 4, 1991, and as such relates to image process- #### BACKGROUND OF THE INVENTION #### I. Field of the Invention More particularly, the present invention relates to a novel and improved method and system for data compression in an image signal compression scheme utilizing adaptively sized blocks and sub-blocks of encoded discrete cosine transform (DCT) coefficient data. II. Description of the Related Art In the field of transmission and reception of television signals, various improvements are being made to the NTSC (National Television Systems Committee) System. Developments in the field of television are com- 25 monly directed towards a high definition television (HDTV) System. In the development of HDTV, system developers have merely applied the Nyquist sampling theorem and low pass filtering design with varying degrees of success. Modulation in these systems 30 amounts to nothing more than a simple mapping of an analog quantity to a value of signal amplitude or fre- It has most recently been recognized that it is possible to achieve further improvements in HDTV systems by 35 using digital techniques. Many of the proposed HDTV transmission formats share common factors. These systems all involve digital processing of the video signal, which necessitates analog-to-digital (A/D) conversion of the video signal. An analog transmission format is 40 then used thereby necessitating conversion of the digitally processed picture back to analog form for trans- The receiver/processor must then reverse the process in order to provide image display. The received 45 analog signal is therefor digitized, stored, processed and reconstructed into a signal according to the interface format med between the receiver/processor and the HDTV display. Furthermore the signal is most likely is noted however that the proposed HDTV formats utilize digital transmission for transmission of control, audio and authorization signals. Many of the conversion operations mentioned above, however, may be avoided using a digital transmission 55 format which transmits the processed picture, along with control, audio and authorization signals, using digital modulation techniques. The receiver may then be configured as a digital modern with digital outputs to the video processor function. Of course, the modem 60 requires an A/D function as part of operation, but this implementation may only require a 4-bit resolution device rather than the 8-bit resolution device required by analog format receivers. Digital transmission is superior to analog transmission 65 in many ways. Digital transmissions provide efficient use of power which is particularly important to satellite transmission and in military applications. Digital trans- missions also provide a robustness of the communications link to impairments such as multipath and jamming. Furthermore digital transmission facilitates ease in signal encryption, necessary for military and many broadcast applications. Digital transmission formats have been avoided in previous HDTV system proposals primarily because of the incorrect belief that they inherently require excessive bandwidth. Therefore in order to realize the bene-487.012 filed Feb. 27, 1990, now U.S. Pat. No. 5,021,891 10 fits of digital transmission, it is necessary to substantially compress the HDTV signal, HDTV signal compression must therefor be achieved to a level that enables transmission at bandwidths comparable to that required by analog transmission formats. Such levels of signal compression coupled with digital transmission of the signal will enable a HDTV system to operate on less power with greater immunity to channel impairments. It is therefore an object of the present invention to provide a novel and improved method and system for 20 enhancing the compression of HDTV signals so as to enable digital transmission at bandwidths comparable to that of analog transmissions of conventional TV signals. #### SUMMARY OF THE INVENTION The present invention is a novel and improved method and system for further compressing image data for transmission and for reconstruction of the image data upon reception. The image compression system includes a subsystem for generating from a block of input pixel data a corresponding composite block of discrete cosine transform (DCT) data optimized for encoding for a minimized transmission data rate. An additional subsystem is utilized to replace certain DCT coefficients with Discrete Quadtree Transform (DQT) coefficients in order to further reduce the data rate. In the present invention a transform means receives an input block of pixel data and performs a discrete cosine transform (DCT) operation on the block of pixel data and on at least one predetermined level of constituent sub-blocks thereof. The transform means provides an output of corresponding block and sub-blocks of DC and AC DCT coefficient values. An additional transform means also receives the input block of pixel data and performs a discrete quadtree transform (DQT) operation thereupon so as to generate a block of DQT coefficient values. A block size assignment means receives, for the block and each sub-block, AC DCT coefficient values and a DQT value which in replacement of the DC DCT coefconverted back to analog form once more for display. It 50 ficient value. The block size assignment means determines, for the block and each corresponding group of constituent sub-blocks of DQT/DCT coefficient values, a bit count value corresponding to a number of bits required to respectively encode the block and each corresponding group of constituent sub-blocks of DQT/DCT coefficient values according to a predetermined coding format. The block assignment means further determines, from the bit count values, ones of the block and group of constituent sub-blocks of DQT/DCT coefficient values requiring a lesser number of bits to encode according to the predetermined coding format, and providing an output of a corresponding selection value. A DCT selection means receives the selection value and the block and sub-blocks of DCT coefficient values and selects the block of DCT coefficient values or ones of the DCT coefficient values sub-blocks in accordance with the selection value. The DCT selection means provides an output of a corresponding composite block of DCT coefficient values formed from the selected block or sub-blocks of DCT coefficient values. A DQT selection means also receives the selection value and the block of DQT coefficient values and selects ones of the 5 DQT coefficient values in accordance with the selection value. The each selected DQT coefficient values corresponds to a DC DCT coefficient values of the selected block or sub-block. A DCT ordering means receives and orders the composite block of DCT coefficient values according to a predetermined ordering format. The ordering means provides an output of the ordered DCT coefficient values to an encoder means that codes the ordered DCT coefficient values according to a predetermined coding 15 format. The encoder means provides an output of the coded ordered DCT coefficient values. A DQT ordering means receives selected DQT coefficient and orders the selected DQT coefficients in a format such that each maintains corresponds with a 20 respective one of the DC DCT coefficients in the coded ordered coefficient values. The DQT ordering means provides an output of the ordered DQT coefficient values. An assembler means receives the coded ordered 25 DCT coefficient values, the ordered DQT values and the selection value. The assembler means generates an coded image value by removing the DC coefficient values in the ordered coded DCT coefficient values while combining the selection value with the remaining 30 AC DCT coefficients in the ordered coded DCT coefficient values and the ordered DQT coefficient values. The coded image value is representative of the input block of pixel data and is of a reduced bit count with respect to a bit count of the input block of pixel data. 35 The assembler means provides an output of the coded image value for transmission. The present invention also provides for a novel and improved method for reconstructing from each received coded image value a corresponding block pixel 40 of pixel data. The present invention further envisions a novel and improved method for compressing an image signal as represented by a block of pixel data and for reconstructing the image signal from the compressed image signal. #### 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 50 with the drawings in which like reference characters identify correspondingly throughout and wherein: FIG. 1 is a block diagram illustrating the processing elements of the adaptive block size image compression system for providing DCT coefficient data and block 55 size determination: FIG. 2 is a block diagram illustrating the further processing elements for the adaptive block size image compression system for selecting block sizes of DCT coefficient data so as to generate a composite block of 60 DCT coefficient data and the encoding of the composite block for transmission; FIGS. 3a and 3b respectively illustrate exemplarily register block size assignment data and the block selection tree corresponding thereto; FIGS. 4s and 4b are graphs respectively illustrating in graphical form the selected block zig-zag scan serialization ordering sequence within the sub-blocks and between sub-blocks for an exemplary composite block of DCT coefficient data whose block size selection was made according to the block size assignment data of FIG. 3a; FIGS. 50-5d respectively illustrate in graphical form an alternate zig-zag scan serialization format; FIG. 6 is a block diagram illustrating the DQT coefficient processing elements of the DQT subsystem of the present invention used in accompaniment with the image compression system of FIGS. 1 and 2; FIG. 7 is a block diagram further illustrating the DQT coefficient block replacement processing elements of the DQT subsystem of the present invention used in accompaniment with the image compression system of FIGS. 1, 2 and 6 FIG. 8 is a block diagram illustrating a decoder for reconstructing an image from a received signal generated by the processing elements of FIGS. 1 and 2; FIG. 9 is block diagram illustrating the DQT subsystem of the present invention used in accompaniment with the decoder of FIG. 7; FIG. 10 is a flow chart illustrating the processing steps involved in compressing and coding image data as performed by the processing elements of FIGS. 1 and 2; and FIG. 11 is a flow chart illustrating the processing steps involved in decoding and decompressing the compressed signal so as to generate pixel data. # DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS In order to facilitate digital transmission of HDTV signals and enjoy the benefits thereof, it is necessary to employ some form of signal compression. In order to achieve such high definition in the resulting image, it is also important that high quality of the image also be maintained. The discrete cosine transform (DCT) techniques have been shown to achieve a very high compression. One such article which illustrates the compression factor is that entitled "Scene Adaptive Coder" by Wen-Hsiung Chen et al., IEEE Transactions on Communications, Vol. Com-32, No. 3, March, 1984. However, the quality of reconstructed pictures is marginal even for video conferencing applications. With respect to the DCT coding techniques, the image is composed of pixel data which is divided into an array of non-overlapping blocks, N×N in size. Strictly for black and white television images each pixel is represented by an 8-bit word whereas for color television each pixel may be represented by a word comprised of up to 24-bits. The blocks in which the image is divided up to is typically a 16×16 pixel block, i.e. N=16. A two-dimensional N×N DCT is performed in each block. Since DCT is a separable unitary transformation, a two-dimensional DCT is performed typically by two successive one-dimensional DCT operations which can result in computational savings. The one-dimensional DCT is defined by the following equation: $$I(k) = \frac{2C(k)}{N} \prod_{n=0}^{N-1} I(n) \cos \frac{\pi(2n+1)k}{2N}$$ (1) where $$C(0) = \frac{1}{\sqrt{2}}$$ (2) Ex. 1-13 5,452,104 5 -continued C(k) = 1 for k = 1,2,3,...N - 1. For television images, the pixel values are real so that 5 the computation does not involve complex arithmetic. Purthermore, pixel values are non-negative so that the DCT component X(0) is always positive and usually has the most energy. In fact, for typical images, most of the transform energy is concentrated around DC. This 10 energy compaction property makes the DCT such an attractive coding method. It has been shown in the literature that the DCT approaches the performance of the optimum Karhunen-Loeve Transform (KLT), as evidenced by the article 15 entitled "Discrete Cosine Transform" by N. Ahmed et al., IERE Transactions on Computers, Japanary 1974, pages 90-93. Basically, the DCT coding performs a spatial redundancy reduction on each block by discarding frequency components that have little energy, and 20 by assigning variable numbers of bits to the remaining DCT coefficients depending upon the energy content. A number of techniques exist that quantize and allocate bits to minimize some error criterion such as MSE over mapped into a one-dimensional string by ordering from low frequency to high frequency. The mapping is done according to diagonal zig-zag mapping over the block of DCT coefficients. The locations of the zero (or discoding technique. In order to optimally quantize the DCT coefficient. one needs to know the statistics of the transform coefficients. Optimum or sub-optimal quantizers can be designed based on the theoretical or measured statistics 35 that minimize the over-all quantization error. While there is not complete agreement on what the correct statistics are, various quantization schemes may be utilized, such as that disclosed in "Distribution of the Two-Dimensional DCT Coefficients for Images" by 40 Randall C. Reininger et al., IEEE Transactions on Communications, Vol. 31, No. 6, June 1983, Pages 835-839. However, even a simple linear quantizer has been uti- lized which has provided good results. Aside from deciding on a quantization scheme, there 45 are two other methods to consider in order to produce the desired bit rate. One method is to threshold the DCT coefficient so that the small values are discarded and set to zero. The other technique is to linearly scale (or normalize) the coefficients to reduce the dynamic 50 range of the coefficients after floating point to integer conversion for coding. Scaling is believed to be superior to thresholding in retaining both the subjective as well as objective signal to noise ratio quality. Therefore the main variable in the quantization process will be the 55 code the coefficient locations and Huffman code the coefficient scale factor which can be varied to obtain the desired bit rate. The quantized coefficients usually are coded by Hulfman codes designed from the theoretical statistics or from the measured histogram distribution. Most of the 60 coefficients are concentrated around the low values so that Huffman coding gives good results. It is believed that Huffman codes generated from a measured histogram performs very close to theoretical limits set by the entropy measure. The location of the zero coefficients 65 are coded by run-length codes. Because the coefficients are ordered from low to high frequencies, the runs tend to be long such that there is a small number of runs. 6 However, if the number of runs in terms of length were counted, the short runs dominate so that Huffman coding the run-lengths reduces the bit rate even more. An important issue that concerns all low bit-rate compression schemes is the effect of channel bit error on the reconstruction quality. For DCT coding, the lower frequency coefficients are more vulnerable especially the DC term. The effect of the bit error rate (BER) on the reconstruction quality at various compression rates has been presented in the literature. Such issues are discussed in the article entitled "Intraframe Cosine Transfer Image Coding" by John A. Rosse et al., IEEE Transactions on Communications, Vol. Com-25, No. 11, November 1977, Pages 1329-1339. The effect of BER becomes noticeable around 10-3 and it becomes significant at 10-2. A BER of 10-5 for the transmission subsystem would be very conservative. If necessary, a scheme can be devised to provide additional protection for lower frequency coefficients, such as illustrated in the article "Hamming Coding of DCT-Compressed Images over Noisy Channels" by David R. Comstock et al., IERE Transactions on Communications, Vol. Com-32, No. 7, July 1984, Pages 856-861. It has been observed that most natural images are the block. Typically the quantized DCT coefficients are 25 made up of blank or relatively slow varying areas, and busy areas such as object boundaries and high-contrast texture. Scene adaptive coding schemes take advantage of this factor by assigning more bits to the busy area and less bits to the blank area. For DCT coding this adaptacarded) coefficients are then coded by a run-length 30 tion can be made by measuring the busyness in each transform block and then adjusting the quantization and bit allocation from block to block. The article entitled "Adaptive Coding of Monochrome and Color images" by Wen-Haining Chen et al., IERR Transactions on Communications, Vol. Com-25, No. 11, November 1977, Pages 1285-1292, discloses a method where block energy is measured with each block classified into one of four classes. The bit allocation matrix is computed iteratively for each class by examining the variance of the transform samples. Each coefficient is scaled so the desired number of bits result after quantization. The overhead information that must be sent are the classification code, the normalization for each block, and four bit allocation matrices. Utilization of this method has produced acceptable results at I and 0.5 bits per pixel. Further bit rate reduction was achieved by Chen et al in the previously mentioned article "Scene Adaptive Coder" where a channel buffer is utilized to adaptively scale and quantize the coefficients. When the buffer becomes more than half full, a feedback parameter normalizes and quantizes the coefficients coarsely to reduce the bits entering the buffer. The converse happens when the buffer becomes less than half full. Instead of transmitting the bit allocation matrices, they run-length coefficients as well as the run-lengths. Such an implomentation has shown good color image reconstructions at 0.4 bits per pixel. Although these results look very good when printed, the simulation of the system shows many deficiencies. When images are viewed under normal to moderate magnification smoothing and blocking effects are visible. In the image compression method and system disclosed herein, intraframe coding (two-dimensional processing) is utilized over interframe coding (three-dimensional processing). One reason for the adoption of intraframe coding is the complexity of the receiver required to process interframe coding signals. Interframe coding inherently require multiple frame buffers in addition to more complex processing circuits. While in commercialized systems there may only be a small number of transmitters which contain very complicated hardware, the receivers must be kept as simple as possible for mass 5 production purposes. The second most important reason for using intraframe coding is that a situation, or program material, may exist that can make a three-dimensional coding scheme break down and perform poorly, or at least no better than the intraframe coding scheme. For example, 24 frame per second movies can easily fall into this category since the integration time, due to the mechanical abutter, is relatively short. This short integration time allows a higher degree of temporal aliasing than in TV cameras for rapid motion. The assumption of frame to frame correlation breaks down for rapid motion as it becomes jurky. Practical consideration of frame to frame registration error, which is already noticeable on home videos become worse at higher resolution. An additional reason for using intraframe coding is that a three-dimensional coding scheme is more difficult to standardize when both 50 Hz and 60 Hz power line frequencies are involved. The use of an intraframe scheme, being a digital approach, can adapt to both 50 25 Hz and 60 Hz operation, or even to 24 frame per second movies by trading off frame rate versus spatial resolution without inducing problems of standards conversion. Although the present invention is described primarily 30 with respect to black and white, the overhead for coding color information is surprisingly small, on the order of 10 to 15% of the bits needed for the huminance. Because of the low spatial sensitivity of the eye to color, most researchers have converted a color picture from 35 RGB space to YIQ space, sub-sample the I and Q components by a factor of four in horizontal and vertical direction. The resulting I and Q components are coded similarly as Y (luminance). This technique requires 6.25% overhead each for the I and Q components. In 40 practice, the coded Q component requires even less data than the I component. It is envisioned that no significant loss in color fidelity will result when utilizing this class of color coding techniques. In the implementation of DCT coding techniques, the 45 blocking effect is the single most important impairment to image quality. However, it has been realized that the blocking effect is reduced when a smaller sized DCT is used. The blocking effect becomes virtually invisible when a 2×2 DCT is used. However, when using the small-sized DCT, the bit per pixel performance suffers somewhat. However, a small-sized DCT helps the most around sharp edges that separate relatively blank areas. A sharp edge is equivalent to a step signal which has significant compo- 55 nents at all frequencies. When quantized, some of the low energy coefficients are truncated to zero. This quantization error spreads over the block. This effect is similar to a two-dimensional equivalent of the Gibbs phenomenon, i.e. the ringing present around a step pulse 60 signal when part of the high frequency components are removed in the reconstruction process. When adjacent blocks do not exhibit similar quantization error, the block with this form of error stands out and creates the blocking effect. Therefore by using smaller DCT block 65 picture. sizes the quantization error becomes confined to the area near the edge since the error cannot propagate outside the block. Thereby, by using the smaller DCT 8 block sizes in the busy areas, such as at edges, the error is confined to the area along the edge. Furthermore, the use of the small DCT block sizes is further enhanced with respect to subjective quality of the image due to the spatial masking phenomena in the eye that hides noise near busy areas. The adaptive block size DCT technique implemented in the present invention may be simply described as a compare-and-replace scheme. A b 16×16 pixel data array or block of the image is coded as in the fixed block size DCT techniques, however, block and sub-block sizes of $16 \times 16$ , $8 \times 8$ , $4 \times 4$ and $2 \times 2$ are used. For each 4×4 block, the number of bits to code the block by using four $2\times2$ sub-blocks inside the $4\times4$ block is examined. If the sum of the four 2×2 sub-blocks is smaller than the bits needed to code it as a $4\times4$ block, the $4\times4$ block is replaced by four 2×2 sub-blocks. Next, each of the $8 \times 8$ blocks are examined to determine if they can in turn be replaced by four 4×4 sub-blocks which were optimized in the previous stage. Similarly, the 16×16 block is examined to determine if it can be replaced by four 8×8 sub-blocks that were optimized in the previous stage. At each stage the optimum block/sub-block size is chosen so that the resulting block size assignment is optimized for the 16×16 block. Since 8-bits are used to code the DC coefficients regardless of the block size, utilization of small blocks results in a larger bit count. For this reason, 2×2 blocks are used only when their use can lower the bit count. The resulting sub-block structure can be conveniently represented by an inverted quadtree (as opposed to a binary tree), where the root corresponding to the 16×16 block in each node has four possible branches corresponding to four sub-blocks. An example of a possible inverted quadtree structure is illustrated in FIG. 3b. Each decision to replace a block with smaller subblocks requires one bit of information as overhead. This overhead ranges from one bit for a 16×16 block up to 21 bits (1+4+16) when 4×4 and 2×2 smb-blocks are used everywhere within in the 16×16 block. This overhead is also incorporated into the decision making process to ensure that the adaptive block size DCT scheme always uses the least number of bits to code each 16×16 block. Although block sizes discussed herein as being N×N in size, it is envisioned that various block sizes may be used. For example an N×M block size may be utilized where both N and M are integers with M being either greater than or lesser than N. Another important aspect is that the block is divisible into at least one level of sub-blocks, such as N/i×N/, N/i×N/j, N/i×M/j, and etc. where i and j are integers. Furthermore, the exemplary block size as discussed herein is a 16×16 pixel block with corresponding block and sub-blocks of DCT coefficients. It is further envisioned that various other integer such as both even or odd integer values may be used, e.g. 9×9. Due to the importance of these overhead bits for the quadtree, these bits need to be protected particularly well against channel errors. One can either provide an extra error correction coding for these important bits or provide and error recovery mechanism so that the effect of channel errors is confined to a small area of the picture. The adaptive block size DCT compression scheme of the present invention can be classified as an intraframe coding technique, where each frame of the image se- quence is encoded independently. Accordingly, a single frame still picture can be encoded just as easily without modification. The input image frame is divided into a number of 16×16 pixel data blocks with encoding performed for each block. The main distinction of the 5 compression scheme of the present invention resides in the fact that the 16×16 block is adaptively divided into sub-blocks with the resulting sub-blocks at different sizes also encoded using a DCT process. By properly choosing the block sizes based on the local image characteristics, much of the quantization error can be confined to small sub-blocks. Accordingly small sub-blocks naturally line up along the busy area of the image where the perceptual visibility of the noise is lower than in blank areas. In review, a conventional or fixed block size DCT coding assigns a fixed number of bits to each block such that any quantization noise is confined and distributed within the block. When the severity or the characteristics of the noise between adjacent blocks are different, 20 the boundary between the blocks become visible with the effect commonly known as a blocking artifact. Scene adaptive DCT coding assigns a variable number of bits to each block thereby shifting the noise between fixed sized blocks. However, the block size is still large 25 enough, usually 16×16, such that some blocks contain both blank and busy parts of the image. Hence the blocking artifact is still visible along image detail such as lines and edges. Using smaller block sizes such as 8×8 or 4×4 can greatly reduce the blocking artifact, 30 however, at the expense of a higher data rate. As a result, the coding efficiency of DCT drops as the block size gets smaller. In the embodiment is which the present invention is described an adaptive block size DCT trechnique is used 35 in which optimal block size is chosen such that smaller blocks are used only when they are needed. As a result, the blocking artifact is greatly reduced without increasing the data rate. Although a number of different methods can be devised that determine block size assignment, an exemplary illustration of an embodiment is provided which assigns block sizes such that the total number of bits produced for each block is minimized. Using the DQT transform of the present invention in combination with the adaptive block size technique a 45 further reduction in the data rate, on the order of 5% or greater, can be achieved. FIGS. 1 and 2 illustrate an exemplary implementation of the adaptive block size DCT transform image signal compression scheme for converting N×N pixel data 50 spective code length values. The number of bits required for purposes of illustration N=16. FIG. 1 illustrates the implementation of the DCT transform and block size determination elements. FIG. 2 illustrates the DCT coefficient data block selection according to the block 55 code lengths for the DC are size determination along with composite DCT coefficient data block bit coding. In FIG. 1, an image signal as represented by a 16×16 block of digitized pixel data is received from the frame buffer (not shown). The pixel data may be either 8 bit 60 black and white image data or 24 bit color image data. The 16×16 pixel block is input to a 16×16 two-dimensional discrete cosine transform (DCT) element 10a. The 16×16 pixel block is also input as four 8×8 pixel blocks to 8×8 DCT element 10b, as eight 4×4 pixel 65 blocks to 4×4 DCT element 10c, and as sixty-four 2×2 pixel blocks to 2×2 DCT element 10d. DCT elements 10a-10d may be constructed in integrated circuit form as is well known in the art. The 16×16 pixel block is also input is also provided in parallel to a DQT subsystem as discussed later herein with reference to FIG. 9. DCT elements 10a-10d perform two-dimensional DCT operations on each respectively sized input block of pixel data. For example, DCT element 10a performs a single 16×16 transform operation, DCT element 10b performs four 8×8 DCT operations, DCT element 10c performs sixteen 4×4 DCT operations, while DCT element 10d performs sixty-four 2×2 DCT operations. Transform coefficients are output from each DCT element 10a-10d to a respective quantizer look up table 12a-12d. Quantizer lookup tables 12a-12d may be implemented in conventional read only memory (ROM) form with memory locations containing quantization values. The value of each transform coefficient is used to address a corresponding memory location to provide an output data signal indicative of a corresponding quantized transform coefficient value. The output of quantizer lookup table 12a, indicated by the reference signal QC16, is a 16×16block of quantized DCT coefficient values. The output of quantizer lookup table 12h, indicated by the reference signal QCS, is comprised of a data block of four \$X8sub-blocks of quantized DCT coefficient values. The output of quantizer lookup table 12c, indicated by the reference signal QCA, is comprised of a data block of sixteen 4×4 sub-blocks of quantized DCT coefficient values. And finally, the output of quantizer lookup table 12d, indicated by the reference signal QC2, is comprised of a data block of sixty-four 2×2 sub-blocks of quantized DCT coefficient. Although not illustrated, the DC (lowest frequency) coefficients of each transform may be optionally treated separately rather than through the corresponding quantizer lookup table. The outputs of quantizer lookup tables 120-12d are respectively input to code length lookup tables 14a-14d. The quantized DCT coefficient values are each coded using variable length code, such as a Huffman code, in order to minimize the data rate. Code words and corresponding code lengths are found in the form of code length look up tables 14a-14d. Each of the quantized DCT coefficients QC2, QC4, QC8, and QC16 are used to look up in the code length tables the corresponding number of bits required to code each coefficient. Code length lookup tables 14a-14d may be implemented in read only memory form with the DCT coefficients addressing memory locations which contain respective code length values. The number of bits required to code each block or sub-block is then determined by summing the code lengths in each block and sub-block. In the basic implementation of the adaptive block size coding scheme the code lengths for the DC and AC coefficients of each block and sub-block is used in determining the number of bits to code the respective block or sub-block. However in the case where the DQT subsystem is utilized, the value corresponding to the DC DCT coefficients output from code length lookup tables 14a-14d is replaced with a similar value from the DQT subsystem. Multiplexers 15a-15d are used to permit the DQT coefficient code length values output from the DQT subsystem to be provided to the respective code length summer 160-16d. Multiplexers 150-15d also permit the AC DCT coefficient code length values output from code length lookup tables 14a-14d to be provided to the respective code length summer 160~16d. The 256 code length values from code length lookup table 14a, comprised of 1 DC coefficient code length values and 255 AC coefficient code length values, are provided to multiplexer 15a. A DQT coefficient code length value is also provided to multiplexer 15a from 5 the DQT subsystem. Multiplexer 15a is responsive to a control signal Ma so as to provide the DQT coefficient code length value from the DQT subsystem to code length summer 16s in place of the DC DCT coefficient code length value from code length lookup table 14a. 10 However, the 255 AC coefficient code length values are provided via multiplexer 15s to code length summer 16a. In code length summer 16a the number of bits required to code the 16×16block DQT/DCT coefficient block is determined by summing the code lengths 15 for the block. Therefore for the 16×16block, code length summer 16a sums the 255 AC coefficient code length values along with the 1 DQT coefficient code length value. The output from code length summer 16a is the signal CL16, a single value indicative of the num- 20 ber of bits required to code the 16×16 block of quantized DOT/DCT coefficients. The 256 code length values from code length lookup table 14b, comprised of a total of 4 DC coefficient code length values and 252 AC coefficient code length val- 25 ues, are provided to multiplexer 156. Each of the four 8x8 blocks is comprised of 1 DC coefficient code length value and 63 AC coefficient code length values. For each DC DCT coefficient code length value provided to multiplexer 15b, a corresponding DQT coeffi- 30 cient code length value is provided to multiplexer 156 from the DOT subsystem. Multiplexer 15b is responsive to a control signal Maso as to provide the DQT coefficient code length value from the DQT subsystem to code length summer 166 in place of each of the 4 DC coeffici- 35 ent code length values from code length lookup table 145. However, the 252 AC coefficient code length values from code length lookup table 146 are provided via multiplexer 150 to code length summer 166. For each of the four 8×8 blocks, code length summer 160 sums the 40 63 AC coefficient code length values along with the DQT coefficient code length value so as to determine the number of bits required to code each 8×8 DQT/DCT coefficient sub-block. The output of code length summer 16b is four values indicated by the refer- 45 ence signal CL8 with each value corresponding to the sum of the code lengths in each of the four \$x8 DQT/DCT blocks. Similarly, the 256 code length values from code length lookup table 14c, comprised of a total of 16 DC 50 coefficient code length values and 240 AC coefficient code length values, are provided to multiplexer 15c. Each of the sixteen 4×4 blocks is comprised of 1 DC coefficient code length value and 15 AC coefficient code length values. For each DC DCT coefficient code 55 leagth value provided to multiplexer 15c, a corresponding DQT coefficient code length value is provided to multiplexer 15c from the DQT subsystem. Multiplexer 15c is responsive to a control signal Meso as to provide the DC coefficient code length value from the DQT 60 subsystem to code length summer 16c in place of each of the 16 DC coefficient code length values from code length lookup table 14c. However, the 240 AC coefficient code length values from code length lookup table 14c are provided via multiplexer 15c to code length 65 summer 16b. For each of the sixteen 4×4 blocks, code length summer 16c sums the 15 AC coefficient code length values along with the DQT subsystem DC coef12 ficient code length value so as to determine the number of bits required to code each 4×4 DQT/DCT coefficient sub-block. The output of code length summer 16c is sixteen values indicated by the reference signal CLA with each value corresponding to the sum of the code lengths in each of the sixteen 4×4 DQT/DCT blocks. Finally, the 256 code length values from code length lookup table 14d, comprised of a total of 64 DC coefficient code length values and 192 AC coefficient code length values, are provided to multiplexer 15d. Each of the sixty-four 2×2 blocks is comprised of 1 DC coefficient code length value and 3 AC coefficient code length values. For each DC DCT coefficient code length value provided to multiplexer 15d, a corresponding DQT coefficient code length value is provided to multiplexer 15d from the DQT subsystem. Multiplexer 15d is responsive to a control signal Maso as to provide the DC coefficient code length value from the DQT subsystem to code length summer 16d in place of each of the 64 DC coefficient code length values from code length lookup table 14d. However, the 192 AC coefficient code length values from code length lookup table 14d are provided via multiplexer 15d to code length summer 16d. For each of the sixty-four 2×2 blocks, code length summer 16d sums the 3 AC coefficient code length values along with the DQT subsystem DC coefficient code length value so as to determine the number of bits required to code each 2×2 DQT/DCT coefficient subblock. The output of code length summer 16d is sixtyfour values indicated by the reference signal CL2 with each value being the sum of the code lengths in each of the sixty-four 2×2 DQT/DCT blocks. The values CL8, CLA, and CL2 are also identified with block position orientation indicia for discussion later herein. The position indicia is a simple x-y coordinate system with the position indicated by the subscript (x,y) associated with the values CL8, CLA, and CL2. The block size assignment (BSA) is determined by examining values of CL2, CLA, CLA and CL16. Four neighboring entries of CL2(x,s) are added and the sum is compared with the corresponding entry in CLA(LL) The output of CL2(x,) from code length summer 16d is input to adder 18 which adds the four neighboring entries and provides a sum value CLA'(12). For example, the values representative of blocks CL2(0,0), CL2(0,1), CL2(1,0), and CL2(1,1) are added to provide the value CLA (0.0). The value output from adder 18 is the value CLA'(x,) which is compared with the value CLA(x,) output from code length summer 16c. The value CLA'(x,y) is input to comparator 20 along with the value CLA(x,y). Comparator 20 compares the corresponding input values from adder 18 and code length summer 16c so as to provides a bit value, P, that is output to a P register (FIG. 2) and as a select input to multiplexer 22. In the example as illustrated in FIG. 1, the value CLA'(n,0) is compared with the value CLA(n,0). If the value CLA'(n,0) is greater than the summed values of CLA'(n,0) comparator 28 generates a logical one bit, "1", that is entered into the P register. The "1" bit indicates that a corresponding 4×4 block of DCT coefficients can be coded more efficiently using four 2×2 subblocks. If not, a logical zero bit, "0", is entered into the P register, indicating that the 4×4 block is coded more efficiently using the corresponding 4×4 block. The output of code length summer 16c and adder 18 are also provided as data inputs to multiplexer 22. In response to the "1" bit value output from comparator 20, multiplexer 22 enables the CLA'(x,y) value to be out- put therefrom to adder 24. However should the comparison result in a "0" bit value being generated by comparator 20, muliplexer 22 enables the output CLA(x,r) from code length summer 16c to be input to adder 24. Adder 24 is used to sum the data input therefrom, as selected from the comparisons of the values of CLA(xx) and CLA'(xx). The result of the sixteen comparisons of the CLA(x,y) and the CLA'(x,y) data is added in adder 24 to generate a corresponding CLA (x, ) seles. For CLA'(x,r) mbon the comparison result bit is sent to the P The next stage in the determination of block size assignment is similar to that discussed with respect to the generation and comparison of the values CLA and 15 CLA'. The output of CLB'(x,p) is provided as an input to comparator 26 along with the output CL8(x,r) from code length summer 166. If the corresponding entry in CLE(x,) is greater than the summed value CLE(x,) comparator 26 generates a "1" bit which is output to the 20 Q register (FIG. 2). The output of comparator 26 is also provided as a selected input to multiplexer 28 which also receives the values CLa(xx) and CLa(xx) respectively from code length summer 160 and adder 24. Should the value output from comparator 26b be a "1" 25 bit, the CLS (x,r) value is output from multiplexer 28 to adder 30. However, should the value CLE(xx) be greater than the value CLE(ap) comparator 26 generates a "O" bit that is sent to the Q register and also to the select input of multiplexer 28. Accordingly, the value 30 CLB(xx) is then input to adder 30 via multiplexer 28. Comparison results of comparator 26 are the Q values sent to the Q register. Again a "1" bit indicates that the corresponding 8×8 block of DCT coefficients may be more efficiently coded by smaller blocks such as all 35 4×4 blocks, all 2×2 blocks or a combination thereof as optimally determined by the smaller block comparisons. A "0" bit indicates that the corresponding 8×8block of DCT coefficients can be more efficiently coded than any combination of smaller blocks. The values input to adder 30 are summed and provided as an output value CL16' input to comparator 32. A second input is provided to comparator 32 as the value CL16 output from by code length summer 16a. Comparator 32 preforms a single comparison of the 45 value CL16 and CL16'. Should the value CL16 be greater than the value CL16' a "1" bit is extered into the R register (FIG. 3). A "1" bit input to the R register is indicative that the block may be coded more efficiently using sub-blocks rather than a single 16×16block. 50 However should the value CL16 be greater than the value CL16, comparator 32 outputs a "0" bit to the R register. The "O" bit in the R register is indicative that the block of DCT coefficients may be coded more efficiently as a 16×16 block. Comparator 32 is also provides the output R bit as a select input to multiplexer 34. Multiplexer 34 also has inputs for receiving the CL16 and CL16' values respectively provided from code length summer 16s and adder 30. The output from multiplexer 34 is the value 60 CL16 should the R output bit be a "O" while the value CL16' is output should the R output bit be a "1". The output of multiplexer 34 is a value indicative of the total bits to be transmitted. It should be noted that the overhead bits vary from 65 one bit to up to twenty-one bits (1+4+16) when $4\times4$ and $2\times2$ blocks are used everywhere within the $16\times16$ block. In FIG. 2, the P value output from comparator 20 (FIG. 1) is input serially to a sixteen-bit register, P register 40. Similarly, the output from comparator 26 is input serially to a four-bit register, Q register 42. Finally, the output from comparator 32 is input serially to a one-bit register, R register 44. The output from P register 40 is provided as a P output to the select input of multiplexer 46. Multiplexer 46 also has inputs as the QC2 and QC4 values respectively output from Quantizer lookup tables each of the sixteen comparisons of the CLA(x,t) and 10 12d and 12c. The output of multiplexer 46 is provided as an input to multiplexer 48, which also has as a second input for the QCS values as output from quantizer lookup table 12b. A select input to multiplexer 48 is provided from the output of Q register 42. The output of multiplexer 48 is coupled as one input to multiplexer 50. The other input of multiplexer 50 is coupled to the output of quantizer lookup table 12a for receiving the values QC16. The select input of multiplexer 50 is conpled to the output of R register 44 so as to receive the output bit R. As illustrated in FIG. 2, P register 40 includes a sequence of bit positions, 0-15, with corresponding bit values as determined by the comparison process as discussed with reference to FIG. 1. Similarly Q register 42 and R register 44 respectively have bit position 0-3 and 0 with corresponding data as determined with reference to PIG. 1. The data in the P, Q and R registers as illustrated in FIG. 2 is merely for the purpose of illustration. As illustrated in FIG. 2, the value of P register 40 bit is used to select via multiplexer 46, QC2 data (four 2×2 blocks of quantized transform coefficients) or the corresponding QC4 data (a 4×4 block of quantized transform coefficients). Multiplexer 48, in response to the value of the bit output from Q register 42 selects between the output of multiplexer 46 and the value QCS data. When the Q register bit value is a "1" bit, the output of multiplexer 46 as input to multiplexer 48 is selected for output of multiplexer 48. When the Q register bit value is a "0" bit, the output of multiplexer 48 is the QC\$ value. Therefore, the output bit value of O register 42 is used to select between four QC4 blocks or sub-blocks of QC2 values as output from multiplexer 46 or a corresponding single 8×8 block. As illustrated in FIG. 2, the four upper left hand blocks as output from multiplexer 46 include four 2×2 blocks with three neighboring 4×4 blocks. However with the bit of the Q register being a "0" bit, multiplexer 48 selects the \$x8 block as an output. This example illustrates the conditional replacement scheme. The output of multiplexer 48 is coupled as an input to multiplexer 50. The other input of multiplexer 50 is provided with the Q16 data, the $16 \times 16$ block of quantized DCT coefficients as provided from quantizer lookup table 12a. The select input to multiplexer 50 is the output bit of the R register. In the example illustrated in FIG. 2, the bit output from R register 44 is a "1" bit thus selecting data as output from multiplexer 50 that which was provided from multiplexer 48. Should the R register 44 output bit value be a "0" bit, multiplexer 50 would output the QC16 data. The multiplexing scheme as illustrated in FIG. 2 utilizes the block assignments to multiplex coefficient sub-blocks QC2, QC4, QC1, QC16 values into a composite block of DCT coefficients QC. In essence this step is accomplished by three stages. The first stage conditionally replaces a 4×4 block of QC4 with four 2×2 sub-blocks according to the content of the P register. The second stage conditionally replaces an \$x8 block of QC8 by four 4×4 sub-blocks as resulting from the previous stage according to the content of the Q register. The third stage conditionally replaces the 16×16 block of QC16 with the result of the previous stages if the R register contains a "1" bit. FIGS. 3a and 3b respectively illustrate the exemplary P, Q and R register data and corresponding and BSA bit pattern, and the corresponding inverted quadtree corresponding thereto. The level of hierarchy involved is that should the bit stored in the R register be a "1", a 10 condition exists which is indicative that the image block may be more efficiently coded using smaller blocks. Similarly, should the Q register contain any "1" bits it further indicates that the corresponding 8 x 8 block may be more efficiently coded by smaller blocks. Similarly, 15 should the P register contain any "1" bits it further indicates that the corresponding 4×4 block may be more efficiently coded using four 2×2 blocks. Should any of the registers contain a "O" bit, this indicates that the block or sub-block may be coded more efficiently 20 by using the size block related thereto. For example, the value of the bit in the P register bit 0 position, a "1" bit, indicates that this 4×4 block may be more efficiently coded using four 2×2 blocks, while the "O" bits in the P register bit positions indicate that 25 the three 4×4 are more efficiently coded using corresponding 2×2 blocks. However, the bit value "0" in the O register indicates that the four 4×4 blocks, comprised of one group of four 2×2 blocks and three 4×4 blocks. may be more efficiently coded by a single 8×8 block. 30 Therefore, the Q register data would override the P register data. Once the P register data was overridden by the Q register 0 position bit, data in the P register bit positions 0-3, need not be transmitted as part of the block size assignment (BSA) data. However, should a 35 bit position in a higher register be a "I" bit, such as bit position 1 of the Q register, the corresponding P register bits are provided as part of the BSA data. As illustrated in FIG. 3a, the Q register bit position 1 is a "1" bit and therefore the corresponding P register bits 4-7 are pro- 40 vided in the BSA data. On a higher level, since the R register bit is a "1" bit each of the Q register bits are provided in the BSA data. Returning to FIG. 2, the composite block QC conefficiently coded by run-length codes. The number of consecutive zeros or runs are sent instead of the code words for each zero. In order to maximize the efficiency of the run-length coding, the coefficients are ordered in a predetermined manner such that the occur- 50 reace of short runs is minimized. Minimization is done by encoding the coefficients which are likely to be non-zeros first, and then encoding the coefficients that are more likely to be zeros last, Because of the energy compaction property of DCT towards low frequency, 55 and because diagonal details occur less often than horizontal or vertical details, diagonal scan or zig-zag scan of the coefficients is preferred. However, because of the variable block sizes used, the zig-zag scan has to be modified to pick out the low frequency components 60 from each sub-block first, but at the same time follow the diagonal acanning for coefficients of similar frequency, technically when the sum of the two frequency indices are the same. Accordingly, the output composite block QC from 65 multiplexer 50 is input to zig-zag scan serializer 52 along with the BSA data (P, Q and R). FIG. 4c illustrates the zig-zag ordering of the block data within blocks and corresponding sub-blocks. FIG. 46 illustrates the ordering in the serialization between blocks and sub-blocks as determined by the BSA data. The output of zig-zag scan serializer 52, comprised of the ordered 256 quantized DCT coefficients of the composite block QC, is input to coefficient buffer 54 where they are stored for run-length coding. The serialized coefficients are output from coefficient buffer 54 to run-length coder 56 where run-length coding is preformed to separate out the zeros from the non-zero coefficients. Run-length as well as the non-zero coefficient values are separately provided to corresponding lookup tables. The run-length values are output from run-length coder 56 as an input of run-length code lookup table 58 where the values are Huffman coded. Similarly, the non-zero coefficient values are output from run-length coder 56 as an input to non-zero code lookup table 60 where the values are also Huffman coded. Although not illustrated it is further envisioned that run-length and non-zero code look up tables may be provided for each block size. The Huffman run-length coded values along with the Huffman non-zero coded values are respectively output from run-length lookup code table 58 and non-zero code lookup table 60 as inputs to bit field assembler 62. An additional input to bit field assembler 62 is the BSA data from the P, Q and R registers. Bit field assembler 62 disregards the unnecessary bits provided from the P, O and R registers. Bit field assembler 62 assembles the input data with BSA data followed by the combined RL codes and NZ codes. The combined data is output from bit field assembler 62 to a transmit buffer 64 which temporarily stores the data for transfer to the transmitter (not shown). When the DQT subsystem is employed the coded DC DCT coefficients are omitted from transfer to transmit buffer 64. Instead the DQT coefficients provided by the DQT subsystem, as an input to bit field assembler 62, are transmitted. The formatting of data in this embodiment is typically a data packet comprised in sequence of sync, BSA, DQT and DCT data bits. Furthermore, the packet may also include end of block code bits following the DCT bits. FIGS. 50-5d illustrates an alternate scan and serialtains many zero coefficient values which can be more 45 ization format for the zig-zag scan serializer 52. In FIGS. 50-5d, the quantized DCT coefficients are mapped into a one-dimensional string by ordering from low frequency to high frequency. However in the scheme illustrated in FIGS. 5a-5d the lower order frequencies are taken from each block prior to taking the next higher frequencies in the block. Should all coefficients in a block be ordered, during the previous scan, the block is skipped with priority given to the next block in the scan pattern. Block to block scanning, as was done with the scanning of FIGS. 4a-4c is a left-to-right, up to down scan priority. As previously mentioned the present invention implements a new and previously undisclosed transform identified herein as the differential quadtree transform (DQT). The basis for this transform is the recursive application of the 2×2 DCT on a quadtree representation of the sub-blocks. At the bottom of the inverted quadtree, for example the quadtree illustrated in FIG. 3b, the $2\times2$ DCT operation is performed and the node is assigned the DC value of the 2x2 DCT transform. The nearest nodes are gathered and another 2×2 DCT is performed. The process is repeated until a DC value is assigned to the root. Only the DC value at the root is signal N<sub>d</sub> for providing the DC DCT coefficient (DC<sub>4</sub>) and the AC coefficients (AC<sub>4</sub>) from DCT element 78. Multiplexer 80 creates a composite 8×8 block of DC and AC DCT coefficients, block 81. Block 81 is identical in arrangement with respect to the AC DCT coefficients (AC<sub>4</sub>) as output from DCT element 74 in block 75. However in block 81 the DC DCT coefficients (DC<sub>4</sub>) and AC DCT coefficients (AC<sub>4</sub>) replace the DC DCT coefficients (DC<sub>4</sub>) in block 75 as it was output from DCT element 74. As illustrated in FIG. 6, the circled DC DCT coefficients (DC<sub>4</sub>) and AC DCT coefficients (AC<sub>4</sub>) in block 81 replace a corresponding DC DCT coefficients (DC<sub>4</sub>) in the 8×8 block arrangement of block 75. In block 81 since there is only one DC coefficient for every fifteen AC coefficients, the com- coded at a fixed number of bits, typically 8-bits, while the rest are Huffman coded. Because each 2×2 DCT operation is nothing more than a sum and a difference of numbers, no multiplications are required, and all coefficients in the quadtree, except DC, represent the differences of two sums, hence the name DQT. Theoretically this type of transform cannot exceed the performance of 16×16 DCT coding. However the implementation of the DQT transform has the advantage of requiring seemingly simple hardware in addition to naturally 10 implementing the adaptive block size coding. Purthermore the quadtree structure allows the coding of the zero coefficients by simply indicating the absence of a subtree when all sub-blocks under the subtree contain only zeros. posite block is considered as four 4×4 blocks. The four 4×4 blocks of DCT coefficients output from Multiplexer \$0 is provided to selector \$2. Selector \$2 provides the AC DCT coefficients (AC<sub>4</sub>) and (AC<sub>4</sub>) from the input block of DCT coefficients as an input to multiplexer \$6 while providing the DC DCT coefficients (DC<sub>4</sub>) as 2×2 block of DC DCT coefficients (DC<sub>4</sub>), block \$3, to 2×2 DCT element \$4. FIG. 6 illustrates an exemplary implementation of a DQT subsystem. In FIG. 6, the same 16×16 block of pixel data is received as that of the subsystem of FIGS. 1 and 2 such that the DQT processing is accomplished in parallel to the adaptive block size data processing. 20 The input block of pixel data is provided to 2×2 DCT element 70 which performs sixty-four 2×2 two-dimensional DCT operations on data. The output of DCT element 70 is comprised of a 16×16 block of DCT coefficients, block 71. For each 2×2 block of pixel data 25 processed by DCT element 70, the corresponding output is comprised of one DC DCT coefficient (DC2) and three AC coefficients (AC2). DCT element \$4 performs a 2×2 two-dimensional DCT operations on the input block of DC DCT coefficients (DC<sub>4</sub>). The output of DCT element 78 is comprised of a 2×2 block of DCT coefficients, block \$5. For the 2×2 block of DC DCT coefficients (DC<sub>4</sub>) processed by DCT element \$4, the output is comprised of one DC DCT coefficient (DC<sub>16</sub>) and three AC DCT coefficients (AC<sub>16</sub>). The output DC DCT coefficient (DC<sub>16</sub>) and AC DCT coefficients (AC<sub>16</sub>) are provided as another input to multiplexer \$6. The 16×16 block of DCT coefficients output from DCT element 70 is provided to selector 72. Selector 72 30 removes the AC DCT coefficients from the input block of DCT coefficients and provides an output \$×8 block of comprised of DC DCT coefficients (DC<sub>2</sub>) only. The \$×8 block of DC DCT coefficients (DC<sub>2</sub>), block 73, is provided to 2×2 DCT element 74. Multiplexer 86 normally provides an output of the AC DCT coefficients (AC4) and (AC4) from multiplexer 80 (via separator \$2). Multiplexer 86 is responsive to a control signal Na for providing the DC DCT coefficient (DC16) and the AC coefficients (AC16) from DCT element \$4. Multiplexer \$6 creates a composite 8×8 block of DC and AC DCT coefficients, block 87. Block \$7 is identical in arrangement with respect to the AC DCT coefficients (AC4) and (AC4) as output from multiplexer 80 in block \$1. However in the block \$7 the DC DCT coefficient (DC14) and AC DCT coefficients (AC14) replace the DC DCT coefficients (DC4) in block 81 as output from multiplexer 80. As illustrated in FIG. 6, the circled DC DCT coefficient (DC14) and AC DCT coefficients (ACid) in block \$7 replace a corresponding DC DCT coefficients (DC<sub>2</sub>) in the \$x\$ block arrangement of block \$1. In block \$7 since there is only one DC coefficient for every fifteen AC coefficients, the composite block is considered as one 8×8 block. DCT element 74 performs sixteen 2×2 two-dimensional DCT operations on the input block of DC DCT coefficients (DC<sub>2</sub>). The output of DCT element 74 is comprised of an 8×8 block of DCT coefficients. For each 2×2 block of DC DCT coefficients (DC<sub>2</sub>) processed by DCT element 74, the corresponding output is comprised of one DC DCT coefficient (DC<sub>4</sub>) and three AC DCT coefficients (AC<sub>4</sub>). As illustrated in FIG. 6, the circled DC DCT coefficients (DC<sub>4</sub>) and AC DCT coefficients (AC<sub>4</sub>) in block 75 replace a corresponding 45 DC DCT coefficients (DC<sub>2</sub>) in the 8×8 block, block 73, arrangement as output from selector 72. C(4) as four 2×2 blocks of DC DCT coefficients C(4), block 77, to 2×2 DCT element 78. The 8×8 block, block 87, output from multiplexer 86 is comprised of what are considered Discrete Quadtree DCT element 78 performs four 2×2 two-dimensional CT operations on the input block of DC DCT coefficients CT operations on the input block of DC DCT coefficients CT operations on the input block of DC DCT coefficients CT operations on the input block of DC DCT coefficients CT operations on the input block of DC DCT coefficients are then quantized by providing the coefficient values to quantizer look table 88. The 8×8 block of DCT coefficients output from DCT element 74 is provided to selector 76. Selector 76 provides the AC DCT coefficients (AC4) from the 50 input block of DCT coefficients as an input to multiplexer 80 while providing the DC DCT coefficients (DC4) as four 2×2 blocks of DC DCT coefficients (DC4), block 77, to 2×2 DCT element 78. Quantizer lookup table 88 may also be implemented in conventional read only memory (ROM) form with 60 memory locations containing quantization values. The value of each transform coefficient is used to address a corresponding memory location to provide an output data signal indicative of a corresponding quantized transform coefficient value. The output of quantizer lookup table 88, indicated by the reference signal QC16, is an 8×8 block of quantized DQT coefficient values. Although not illustrated, again the DC coefficient (DC16) of the DQT transform operation may be option- DCT element 78 performs four 2×2 two-dimensional 55 DCT operations on the input block of DC DCT coefficients (DC4). The output of DCT element 78 is comprised of an 4×4 block of DCT coefficients, block 79. For each of the four 2×2 blocks of DC DCT coefficients (DC4) processed by DCT element 78, the corresponding output is comprised of one DC DCT coefficient (DC4) and three AC DCT coefficients (AC4). The output DC DCT coefficient (DC4) and AC DCT coefficients (AC4) are provided as another input to multiplexer 80. Multiplexer 80 normally provides an output of the AC DCT coefficients (AC4) from DCT element 74 (via separator 76). Multiplexer 80 is responsive to a control B ally treated separately rather than through the corresponding quantizer lookup table. The DOT coefficients are provided as an output of quantizer lookup table 88 to code length lookup table 90. The quantized DQT coefficient values are each 5 coded using variable length code, such as a Huffman code, in order to minimize the data rate. Code words and corresponding code lengths are found in the form of code length look up table 90. Each of the quantized DQT coefficients DC16, AC16, AC2 and AC4, are used 10 to look up in the code length table the corresponding number of bits required to code each coefficient. Code length lookup table 90 may also be implemented in read only memory form with the DQT coefficients address ing memory locations which contain respective code 15 length values. The DQT coefficient code length values are provided to multiplexers 150-15d of FIG. 1 for replacing the corresponding DC DCT coefficient code length value for each block and sub-block in the block FIGS. 1 and 2. In FIG. 7 the 64 quantized DQT coefficient values of block 91 are selected for replacement of the DC DCT coefficient values for the block sizes as determined by the block size determination made in accordance as 25 discussed with reference to FIGS. 1 and 2. The values stored in P, Q and R registers 40, 42 and 44 are used in selecting the DQT coefficient values for replacement in the block and sub-blocks of the DC DCT coefficient The DQT coefficient values are provided from quantizer lookup table 53 (FIG. 6) to one input to multiplexer 92. At the other input of multiplexer 92 a dummy value x is provided. Multiplexer 92 is responsive to the bits of P register 40 for providing an output of the DQT 35 coefficient values for the entire 2×2 sub-block when a "I" is in the P register 40 bit position. When the value in P register 40 bit position is a "0", only the DQT coefficient value which corresponds to the DC coefficient value of the sub-block is output with the remaining 40 values output being the dummy values x. The value x is used merely to maintain the arrangement within the sub-block with these values eventually discarded. Using the data in the sixteen bit position of P register 40 as provided in the example as given with reference to 45 FIGS. 1 and 2, composite block 93 is formed. The sub-blocks of DQT coefficients and dummy values x output from multiplexer 92 are provided as one input to multiplexer 94. At the other input of multiplexer 94 the dummy value x is again provided. Multi- 50 plexer 94 is responsive to the bits of Q register 42 for providing an output of the DQT coefficient values and dummy values x for an entire 4×4 sub-block as provided from multiplexer 92 when a "1" is in the Q register 42 bit position. When the value in Q register 42 bit 55 position is a "0", only the DQT coefficient value which corresponds to the DC coefficient value of the subblock is output with the remaining values output being the dummy values x. The value x is again used merely to maintain the arrangement within the sub-block with 60 these values eventually discarded. Using the data in the four bit positions of Q register 42 as provided in the example as given with reference to FIGS. 1 and 2, composite block 95 is formed. The sub-blocks of DQT coefficients and dummy valus x output from multiplexer 94 are provided as one input to multiplexer 96. At the other input of multiplexer 96 the dummy value x is again provided. Multi- plexer 96 is responsive to the bits of R register 44 for providing an output of the DQT coefficient values and dummy values x for an entire 16×16 block as provided from multiplexer 94 when a "1" is in the R register 44 single bit position 0. When the value in R register 42 bit position 0 is a "0", only the DQT coefficient value which corresponds to the DC coefficient value of the block is output with the remaining values output being the dummy values x. The value x is again used merely to maintain the arrangement within the block with these values eventually discarded. Using the data in single bit position of R register 44 as provided in the example as given with reference to FIGS. 1 and 2, composite block 97 is formed. ing memory locations which contain respective code is memory locations which contain respective code is length values. The DQT coefficient code length values are provided to multiplexers 150-15d of FIG. 1 for replacing the corresponding DC DCT coefficient code length value for each block and sub-block in the block size determination as was discussed with reference to 20 coded a single DQT coefficient value exists. Similarly for each 4x4 and 2x2 DCT coefficient block of QC to be encoded a single DQT coefficient value exists. Althoughin the example given the block was not encoded as a 16x16 block had this been the case a single DQT value would have been generated in the composite block. The DQT coefficient values are output from multiplexer 96 to zig-zag scan serializer which arranges the DQT coefficients and dummy values x in a manner that was discussed with reference to FIGS. 4a and 4b. The zig-zag scan serialized data is provided to value removal logic 99 which removes the dummy values x using information identifying the position of the dummy values x based upon the P, Q and R register data. It should be understood that the use of the dummy values x may be climinated using a more elaborate multiplexing acheme. The DQT coefficient values output from logic 99 is provided to code lookup table 66 the values are coded also preferably using a Huffman code. The coded DQT coefficient values are output from code lookup table 66 to bit field assembler 62 of FIG. 2. Bit field assembler 62 as previously discussed in arranging the data for transmission provides the coded DQT coefficients along with the coded AC DCT coefficients, while removing the coded DC DCT coefficients from the data output. FIG. 8 illustrates the implementation of a receiver for decoding the compressed image signal generated according to the parameters of FIGS. 1 and 2. In FIG. 8, the coded word is output from the receiver (not shown) to a receive buffer 100. Receive buffer 100 provides an output of the code word to separator 102. Received code words include by their nature the BSA data, the DQT coded coefficients, and the coded DCT coefficients in the form of the RL codes and NZ codes. All received code words obey the prefix conditions such that the length of each code word need not be known to separate and decode the code words. Separator 102 separates the BSA codes from the the DQT coded coefficients and the coded DCT coefficients since the BSA codes are transmitted and received first before this data. The first received bit is loaded into an internal R register (not shown) similar to that of DFIG. 2. An examination of the R register determines that if the bit is a "0", the BSA code is only one bit long. Separator 102 also includes Q and P registers that are initially filled with zeros. If the R register contains a "1" bit, four more bits are taken from the receive buffer and loaded into the Q register. Now for every "1" bit in the Q register, four more bits are taken from the receive buffer and loaded into the P register. For every "0" in the Q register, nothing is taken from the receive buffer but four "O" are loaded into the P register. Therefore, the possible lengths of the BSA code is 1, 5, 9, 13, 17 and 21 bits. The decoded BSA data is output from separator Separator 102 also separates the the DQT coded 5 coefficients from the coded DCT coefficients. Separator 102 outputs the DQT coded coefficients to the DQT decoder subsystem illustrated in further detail in FIG. 9. Separator 102 also outputs the coded DCT coefficients in the form of RL codes and NZ codes respectively 10 to RL decode lookup table 104 and NZ decode lookup table 106. Lookup tables 104 and 106 are essentially inverse lookup tables with respect to lookup tables 58 and 60 of FIG. 2. The output of lookup table 104 are values corresponding to ran-length and are input to 15 run-length decoder 108. Similarly the non-zero coefficient values output from lookup table 106 are also input to run-length decoder 108. Run-length decoder 108 inserts the zeros into the decoded coefficients and provides an output to coeffici- 20 ent buffer 110 which temporarily stores the coefficients. The stored coefficients are output to inverse zig-zag scan serializer 112 which orders the coefficients according to the scan scheme employed. Inverse zig-zag scan serializer 112 receives the BSA signal from separator 25 102 to assist in proper ordering of the block and subblock coefficients into a composite coefficient block. The block of coefficient data is output from inverse zig-zag scan serializer 112 and respectively applied to a corresponding inverse quantizer lookup table 30 1140-114d. In each of inverse quantizer lookup tables 1140-114d an inverse quantizer value is applied to each coefficient to undo the quantization. Inverse quantizer lookup tables 114a-114d may be employed as ROM devices 35 which contain the quantization factors from that of quantizer lookup tables 120-12d. The coefficients are output from each of inverse quantizer lookup tables 1146-114d to a corresponding input of multiplexers 1150-1154 The other input of each of multiplexers 115a-115d is coupled to the DQT decoder subsystem of FIG. 9. Multiplexers 1150-115d are each responsive to a respective control signal Y. Y. for providing an output of the AC DCT coefficient values provided from inverse 45 quantizer lookup tables 1140-114d and the DQT coefficients values, which replace the DC DCT coefficient values. The DQT/DCT coefficients are output respectively from multiplexers 1150-115d to inverse discrete cosine transform (IDCT) elements 1160-116d. IDCT element 116s forms from the 16×16 coefficient block, if present, a 16×16 pixel data block which is then output to sub-block combiner 118. Similarly, DCT 116b transforms respective 8×8 blocks of coefficients, IDCT element 1166 is provided to sub-block combiner 118. IDCT elements 116c and 116d respective transform the 4×4 and 2×2 coefficient blocks, if present, to corresponding pixel data blocks which are provided to sub-block combiner 118. Sub-block combiner 118 in 60 addition to receiving the outputs from IDCT elements 116a-116d also receives the BSA data from separator 102 so as to reconstruct the blocks of pixel data into a single 16×16 pixel block. The reconstructed 16×16 pixel block is output to a reconstruction buffer (not 65 shown) for ultimate transfer to the display system. FIG. 9 illustrated in further detail the structure of the DQT decoder subsystem wherein separator 102 pro- vides the coded DQT coefficients to decode lookup table 120. Lookup table 120 is essentially an inverse lookup table with respect to lookup table 66 of FIG. 7, and as such is a Huffman decoder lookup table. The output of lookup table 120 are values corresponding to the decoded DQT coefficients and are input to value insertion logic 122. Logic 122 also receives the BSA data which is in essence the values for the P, Q, and R registers. Logic 122 reconstructs the block/snb-blocks with the DQT data and dummy values x to produce a composite serialized block of DQT and dummy values corresponding to a zig-zag scan serialized version of block 97 of FIG. 7. The DQT coefficients and dummy values are output from logic 122 to inverse zig-zag scan serializer 124 which orders the coefficients according to the scan scheme employed. Inverse zig-zag scan serializer 124 also receives the BSA signal from separator 102 to assist in proper ordering of the block and sub-block coefficients into a composite coefficient block identical to that of block 97 of FIG. 7. The block of coefficient data is output from inverse zig-zag scan serializer 124 to inverse quantizer lookup table 126. In inverse quantizer lookup table 126 an inverse quantizer value is applied to each coefficient to undo the quantization. Inverse quantizer lookup table 126 may also be employed as a ROM device which contain the quantization factors from that of quantizer lookup table 88. The coefficients are output from each of inverse quantizer lookup tables 126 to separator 128. Separator 128 provides the DC DQT coefficient (DC14), along with the AC DQT coefficients (AC16), to multiplexer 115a. IDCT element 116a therefore receives the DC DQT coefficient (DC16) via multiplexer 115e. It should be noted that although these values are sent to multiplexer 115a, the AC coefficients (AC16) are not output from the multiplexer. With respect to the DC coefficient (DC14) this value is output from the multiplexer but may ultimately be disregarded should it belong to a block size which is not selected according to the block size assignment. In an alternate embodiment the ultimate unused value may not be sent to multiplexer 115a or inhibited thereat using the BSA data. In FIG. 7 this value is not graphically illustrated as an input to subblock combiner 118. Separator 128 also provides the DC and AC DQT coefficients (DC16) and (AC16) to 2×2 inverse discrete cosine transform (IDCI) element 130 while providing 50 All of the other values of the \$x 8 composite block as an input to multiplexer 132. Illustrated in block 129 are the relevant values provided to IDCT element 130. IDCT element 130 performs one 2×2 inverse discrete cosine transform on the 2×2 block comprised of if present, to 8×8 blocks of pixel data. The output of 55 one DC and three AC DQT coefficients, (DC16) and (AC1s's), so as to produce four resultant DC DQT coefficients (DC<sub>4</sub>) which are provided as an input to multiplexer 132. The DC DQT coefficients (DCs) are also provided to multiplexer 115b. In the example provided, two of the DC DQT coefficients (DC4), circled in block 135, are used in the final block data in place of the DC DCT coefficient that was not sent. As was discussed with reference to the values provided to multiplexer 115a, in the present example the other two of these values are also unused in the final block assignment data. In FIG. 7 these unused computation values are not graphically illustrated as an input to sub-block combiner 118 Multiplexer 132 provides all of the values from separator 128 as an output to separator 134. Multiplexer 132 also receives the DC DQT coefficient values (DCa) from IDCT element 130 and in response to a control signal Z1 the DC DQT coefficients (DC4) are output to 5 acparator 134 at the corresponding place in the composite block for the DC and AC DQT coefficients, (DC16) and (AC16). Separator 134 provides the DC and AC DQT coefficients (DCa) and (ACa) to 2×2 inverse discrete cosine 10 size image compression scheme as disclosed herein. The transform (IDCT) element 136 while providing all of the other values of the 8×8 composite block as an input to multiplexer 138. Illustrated in block 135 are the relevant values provided to IDCT element 136. IDCT element 136 performs four 2×2 inverse dis- 15 crete cosine transform on each of the four 2X2 blocks of comprised of one DC and three AC DQT coefficients, (DCg) and (ACg's) so as to produce sixteen resultant DC DQT coefficients (DC4) which are provided as an input to multiplexers 138 and 115c. In the provided 20 example the IDCT computation is performed in each of the two left hand side sub-blocks of block 135 using the DC DQT coefficient (DC<sub>4</sub>) and three dummy values for the three AC DQT coefficients (AC4). Since the result of the IDCT computations using dummy values is 25 not an actual DC DQT coefficient these values may be transmitted to multiplexer 115c but will remain unused. The DC DQT coefficients (DC4) are as output from IDCT element 136 provided to multiplexer 115c. Again for the example provided, six of the eight DC DQT 30 coefficients (DC4), circled in block 139, are used in the final block data in place of the DC DCT coefficient that was not sent. As was discussed with reference to the values provided to multiplexers 115s and 115b, in the present example, the other two of these values are also 35 unused in the final block assignment data. In FIG. 7 these unused values along with the dummy value computation results are not graphically illustrated as an input to sub-block combiner 118. Multiplexer 138 provides the values output from sep- 40 arator 134 as an input to 2×2inverse discrete cosine transform (IDCT) element 140. Multiplexer 138 also receives the DC DQT coefficient values (DC4) from IDCT element 136 and in response to a control signal Z<sub>2</sub> the DC DQT coefficients (DC<sub>4</sub>) are output to IDCT 45 element 140 at the corresponding place in the composite block for the DC and AC DQT coefficients, (DCs) and (AC4). Illustrated in block portion 141 are the relevant values provided to IDCT element 140. IDCT element 140 performs sixteen 2×2 inverse 50 discrete cosine transform on the 2×2 blocks each comprised of one DC and three AC DQT coefficients, (DC4) and (AC4's), so as to produce sixty-four resultant DC DQT coefficients (DC2) which are provided as an input to multiplexer 115d. In the provided example the 55 IDCT computation is performed in each coefficient sub-block in block 139 including those without AC DQT coefficients (AC4) by using three dummy values for the three AC DQT coefficients (ACs). Since the result of the IDCT computations using dummy values is 60 not an actual DC DQT coefficient these values may be transmitted to multiplexer 115d but will remain unused. Again for the example provided, eight of the sixtyfour DC DQT coefficients (DC2), circled in block 141. are used in the final block data in place of the DC DCT 65 coefficient that was not sent. As was discussed with reference to the values provided to multiplexer 115a and 115b, in the present example, the other two of these values are also unused in the final block assignment data. In FIG. 7 these unused values along with the dummy value computation results are not graphically illustrated as an input to sub-block combiner 118. As was discussed with reference to FIG. 8, the DQT coefficients which were transmitted as replacements for the omitted DC DCT coefficients are used as the DC coefficient for each relevant block size. The DOT implementation is readily adaptable to the adaptive block DQT subsystem reduces the data rate by providing a reduction in bits that need to be sent. Furthermore, a DQT subsystem implementation has no effect on the number of overhead bits in the adaptive block size image compression scheme. In fact the use of the DQT processing scheme results in a reduction in the number of bits that need be transmitted for those cases in where the number of smaller blocks is great. FIG. 10 illustrates in block diagram form a flow chart for signal compression of the present invention. FIG. 19 briefly illustrates the steps involved in the processing as discussed with reference to FIGS. 1, 2, 6 and 7. Similarly, PIG. 11 illustrates the decompression process of transmitted compressed image data to result in the output pixel data. The steps illustrated in FIG. 11 are previously discussed with reference to FIG. 9 and 10. The use of DQT processing techniques furthers the improved image quality provided by the adaptive block size processing scheme without making any sacrifice in the bit per pixel ratio. It is also believed that a bit per pixel ratio of about "I" and even substantially less than this level would provide substantial improvement in image quality sufficient for HDTV applications when using the techniques disclosed herein. It is envisioned that many variations to the invention may be readily made upon review of the present disclosure. The previous description of the preferred embodiments is provided to enable any person skilled in the art to make or use the present invention. The various modifications to these embodiments will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other embodiments without the use of the inventive faculty. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and novel features disclosed herein. I claim: 1. In an adaptive block size image compression system for compressing a block of input pixel data for transmission by performing a discrete cosine transform (DCT) operation on the block of pixel data and on at least one predetermined level of constituent sub-blocks thereof so as to produce corresponding image block and sub-blocks of DC and AC DCT coefficient values determining for each image block and each corresponding group of image sub-blocks of DCT coefficient values a bit count corresponding to the number of bits required to respectively encode the image block and each corresponding group of image sub-blocks of DCT coefficient values according to a predetermined coding format; determining from the bit count ones of the image block and corresponding group of image sub-blocks of DCT coefficient values requiring a lesser number of bits to encode according to the coding format; selecting ones of the image block and image sub-blocks of DCT coefficients values requiring a lesser number of bits to encode according to the coding format so as to form a composite image block; ordering the DCT coefficient values of the composite image block according to a predetermined ordering format; encoding the ordered DCT coefficient values of the composite image block according to the encoding format; and assembling the encoded 5 ordered DCT coefficient values of the composite image block along with information identifying the selected ones of the image block and image sub-blocks of DCT coefficient values of the composite image block, a subsystem for providing further compression of the block 10 of pixel data comprising: discrete quadtree transform means for, receiving said input block of pixel data, performing a first discrete cosine transform (DCT) operation on said block of pixel data so as to produce a corresponding first 15 block of DC and AC DCT coefficient values, performing a series of additional DCT operations with a first additional DCT operation performed on said DC DCT coefficients of said first block of DC and AC DCT coefficient values with each subsequent 20 additional DCT operation performed on resultant DC coefficients values of a proceeding additional DCT operation with a last additional DCT operation producing a corresponding last block of DC and AC DCT coefficient values, and providing an out-25 put of said last block of DC and AC DCT coefficient values, and providing an out-25 put of said last block of DC and AC DCT coefficient values; code length determination means for, receiving each of said last block of DC and AC DCT coefficient values, generating a corresponding code length 30 value corresponding to a length of each of said last block DC and AC DCT coefficient value as encoded according to said predetermined coding format, inserting each code length value in place of a DC DCT coefficient for each corresponding 35 image block and image sub-block in said bit count determination, wherein said ones of said image block and image sub-blocks are selected for said composite image block using said corresponding code length values; and replacement means for receiving each of said last block of DC and AC DCT coefficient values and replacing each DC DCT coefficient of said selected ones of said image block and image subblocks of said composite image block with a corresponding one of said last block DC and AC DCT coefficient values. 2. The subsystem of claim 1 wherein said replacement means further comprises: ordering means for ordering said last block DC and 50 AC DCT coefficient values according to said predetermined ordering format; and encoder means for encoding each of said last block DC and AC DCT coefficient values according to said predetermined encoding format. 3. In an adaptive block size compression system wherein a block of pixel data is transformed to AC and DC discrete cosine transform (DCT) coefficient data for a block and constituent sub-blocks of pixel data, and wherein the AC and DC DCT coefficient values of a 60 composite block of selected ones of said block and constituent sub-blocks of pixel data are provided for transmission, an apparatus for compressing said DC DCT coefficient values comprising: discrete quadtree means for receiving at least one 65 block of data representing said block of pixel data, performing a plurality of DCT operations to provide AC and DC DQT coefficient values, with a first DCT operation performed on said at least one block of data to provide first sub-blocks of AC and DC DQT coefficient values, performing at least one additional DCT operation wherein each of said at least one additional DCT operation is performed on resultant DC DQT coefficient data of a preceding DCT operation, and selecting ones of AC and DC DQT coefficient values to provide a DQT composite block of AC and DC coefficient values; and encoding means for receiving said DQT composite block, selecting values from said DQT composite block and encoding said selected values of said DQT composite block to provide a signal indicative of compressed DC DCT coefficient values. 4. The apparatus of claim 3 wherein said discrete quadtree means comprises: at least one DCT means for receiving said at least one block of data and performing a series of DCT operations to provide AC and DC DQT coefficient values with a first DCT operation performed on said at least one block of data and with additional DCT operations performed on sub-blocks of selected DC DQT coefficient values; and selector means for receiving said AC and DC DQT coefficient values selecting ones of said AC and DC DQT, coefficient values to provide said subblocks of selected DC DQT coefficient values in accordance with a predetermined selection format. - 5. The apparatus of claim 4 wherein said at least one DCT means comprises a plurality of single DCT means wherein each of said single DCT means is for performing a corresponding one of said series of DCT operations. - 6. The apparatus of claim 5 wherein said selector means further comprises: - at least one multiplexer means for receiving AC and DC DQT coefficient values from a corresponding one of said at least one single DCT means and selecting ones of said AC and DC DQT coefficient values to provide intermediate DQT composite blocks of AC and DC DQT coefficient values; and - at least one single selector means for receiving said intermediate DQT composite blocks, selecting values from said intermediate DQT composite blocks to provide said sub-blocks of selected DC DQT coefficient values. - 7. The apparatus of claim 3 wherein said at least one block of data comprises pixel data. - The apparatus of claim 3 wherein said at least one block of data comprises said sub-blocks of AC and DC DCT coefficient values. - The apparatus of claim 6 wherein said encoding means is responsive to a selection signal. - 10. The apparatus of claim 9 wherein said encoding means comprises a replacement means for receiving said DQT composite block of AC and DC DQT coefficient values and said selection signal and replacing selected values of said composite block of AC and DC DQT coefficient values with a predetermined dummy value in accordance with said selection signal to provide a value replaced composite block. - 11. The apparatus of claim 10 wherein said encoding means further comprises: - zig-zag scan serializer means for receiving said value replaced composite block and reordering the members of said value replaced composite block to provide a reordered composite block; and value removal logic means for removing selected values from said reordered composite block in accordance with a predetermined removal format to provide a compressed composite block. 12. The apparatus of claim 11 further comprising 5 quantization means for receiving said compressed composite block and quantizing values of said compressed composite block in accordance with a predetermined quantization format. 13. In an adaptive block size compression system 10 wherein a block of pixel data is transformed to AC and DC discrete cosine transform (DCT) coefficient data for a block and at least one constituent level of subblocks of pixel data, and wherein the AC and DC DCT coefficient values of a composite block of selected ones 15 of said block and constituent sub-blocks of pixel data are provided for transmission, a method for compressing said DC DCT coefficient values comprising: receiving at least one block of data; performing a series of discrete cosine transformation 20 (DCI) operations to provide AC and DC DQT coefficient values with a first DCT operation performed on said at least one block of data to provide first sub-blocks of AC and DC DQT coefficient values and at least one additional DCT operations 25 is performed on sub-blocks of selected DC DQT coefficient values resultant from a preceding DCT operation of said series of DCT operations; and selecting ones of AC and DC DQT coefficient values resultant from said first DCT operation and said at 30 least one additional DCT operation to provide a DQT composite block of AC and DC DQT coefficient values. 14. The method of claim 13 further comprising the steps of: receiving a selection signal; replacing values of said DQT composite block of selected values with a predetermined dummy element in accordance with said selection signal to provide a value replaced composite block. 15. The method of claim 14 further comprising the steps of: reordering the elements of said value replaced composite block in accordance with a predetermined rig zag format to provide a reordered composite 45 block; and removing selected elements of said reordered composite block in accordance with said selection signal to provide a value removed composite block. 16. The method of claim 15 further comprising the 50 step of quantizing the values of said value removed composite block to provide quantized values. 17. The method of claim 16 further comprising the step of encoding said quantized values in accordance with a predetermined coding format. 18. An image compression apparatus for compressing data representative of a block of pixel data comprising: transform means for receiving an input block of pixel data and performing a discrete cosine transform (DCT) operation on said block of pixel data and on 60 at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding AC and DC DCT coefficient values for said block and constituent sub-blocks and selecting ones of said AC and DC DCT coefficient values to 65 provide a composite block of AC and DC DCT coefficient values representing said input block of pixel data; DC DCT compression means for compressing the DC DCT values of said composite block of AC and DC DCT coefficient values by performing a series of DCT operations to provide AC and DC DQT coefficient values, with a first DCT operation performed on sub-blocks of said DC DQT values of said constituent sub-blocks of pixel data and additional DCT operations performed on sub-blocks of DC DQT values from preceding DCT operations of Said series of DCT operations and encoding ones of said AC and DC DQT coefficient values to provide compressed DC DCT coefficient values; and combination means for receiving said composite block of AC and DC DCT and said compressed DC DCT coefficient values and combining said composite block of AC and DC DCT and said compressed DC DCT coefficient values to provide a composite block of AC and compressed DC DCT coefficient values. 19. The apparatus of claim 18 wherein said DC DCT compression means comprises: discrete quadtree means for performing said series of DCT operations on said sub-blocks of DC DQT coefficient values to provide said AC and DC DQT coefficient values, with said first DCT operation performed on said sub-blocks of DC DQT coefficient values of said constituent sub-blocks of pixel data and said additional DCT operations performed on said sub-blocks of DC DQT values from preceding said DCT operations of said series of DCT operations, and selecting ones of said AC and DC DQT coefficient values to provide said DQT composite block; and encoding means for receiving said DQT composite block, selecting values from said DQT composite block and encoding said selected values of said DQT composite block to provide said compressed DC DCT coefficient values. 20. The apparatus of claim 19 wherein said discrete quadtree means comprises: at least one DCT means for performing said series of DCT operations on said sub-blocks of DC DQT coefficient values to provide said AC and DC DQT coefficient values, with said first DCT operation performed on said sub-blocks of DC DQT coefficient values of said constituent sub-blocks of pixel data and said additional DCT operations performed on said sub-blocks of DC DQT values from said preceding DCT operations of said series of DCT operations, and selecting ones of said AC and DC DQT coefficient values to provide said DQT composite block; and selector means for receiving said AC and DC DQT coefficient values selecting said ones of said AC and DC DQT coefficient values to provide said sub-blocks of DC DQT values. data and performing a discrete cosine transform (DCT) operation on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding AC and DC DCT coefficient values for special states. 22. The apparatus of claim 21 wherein said selector means further comprises: at least one multiplexer means for receiving AC and DC DQT coefficient values from a corresponding one of said at least one single DCT means and selecting ones of said AC and DC DQT coefficient values to provide intermediate DQT composite blocks of AC and DC coefficient values; and at least one single selector means for receiving said intermediate DQT composite blocks, selecting values from said intermediate DQT composite blocks 5 to provide said sub-blocks of selected DC DQT coefficient values. 23. The apparatus of claim 22 further comprising: DC code length means for receiving said compressed DC DCT coefficient values and providing a DC 10 code length indicative of the number of bits to encode said DC DCT coefficient data of said blocks and sub-blocks of pixel data; AC code length means for receiving said blocks and sub-blocks of AC and DC DCT coefficient values 15 and providing an AC code length indicative of the number of bits to encode said AC DCT coefficient data of said blocks and sub-blocks of pixel data; and block selection means for receiving said DC code length and said AC code length and providing a 20 selection signal indicative of said selected ones of said block and sub-blocks of AC and compressed DC DCT coefficient values of said composite block of AC and compressed DC DCT coefficient values in accordance with a weighted sum of said 25 encoding is responsive to said selection signal. AC code length and said DC code length. 24. The apparatus of claim 23 wherein said encoding mems is responsive to said selection signal. 25. The apparatus of claim 24 wherein said encoding means comprises replacement means for receiving said 30 DQT composite block and said selection signal and replacing selected values of said DQT composite block with a predetermined dummy value to provide a value replaced composite block. 26. The apparatus of claim 25 wherein said encoding 35 means further comprises: zig-zag scan serializer means for receiving said value replaced composite block and reordering values of said value replaced composite block to provide a reordered composite block; and value removal logic means for receiving said reordered composite block and removing selected values from said reordered composite block in accordance said selection signal to provide a value removed composite block. 27. The apparatus of claim 26 further comprising quantization means for receiving said value removed composite block and quantizing values of said value removed composite block in accordance with a predetermined quantization format a quantized DC value 50 composite block. 28. A method for compressing image data for a block of pixel data comprising the steps of: receiving an input block of pixel data; performing a discrete cosine transform (DCT) opera- 55 tion on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding AC and DC DCT coefficient values for said block and constituent sub-blocks; selecting ones of said AC and DC DCT coefficient values to provide a composite block of AC and DC DCT coefficient values representing said input block of pixel data; performing a series of DCT operations on said DC 65 DCT coefficient values for said constituent subblocks to provide AC and DC DQT coefficient values, with a first DCT operation performed on said DC DCT values of said constituent sub-blocks of pixel data and additional DCT operations performed on sub-blocks of DC DQT values from preceding DCT operations of said series of DCT operations; encoding ones of said AC and DC DQT coefficient values to provide compressed DC DCT coefficient values; and combining said composite block of AC and DC DCT and said compressed DC DCT coefficient values to provide a composite block of AC and compressed DC DCT coefficient values. 29. The method of claim 28 further comprising the providing a DC code length indicative of the number of bits to encode said DC DCT coefficient data of said blocks and sub-blocks of pixel date; providing an AC code length indicative of the number of bits to encode said AC DCT coefficient data of said blocks and sub-blocks of pixel data; and providing a selection signal in accordance with a weighted sum of said AC code length and DC code length. 30. The apparatus of claim 29 wherein said step of 31. The method of claim 30 wherein said step of step of encoding comprises: replacing selected ones of said AC and DC DQT coefficient values with a predetermined dummy value to provide a value removed composite block; reordering the members of said value removed composite block in accordance with a predetermined zig zag format to provide a reordered composite block; and removing selected values from said reordered composite block in accordance with a predetermined value removal format to provide a value removed composite block. 32. The method of claim 31 further comprising quantizing the values of said value removed composite block in accordance with a predetermined quantization format to provide compressed DC values. 33. In an image decoder wherein an image block of pixel data is processed by performing a discrete cosine transform (DCT) operation on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding block and sub-blocks of AC and DC DCT coefficient values, and wherein said DC DCT coefficient values are compressed by performing a series of DCT operations performed on said DC DCT coefficient valnes of said sub-blocks of pixel data to provide AC and DC DQT coefficient values with a first of said series of DCT operations performed on said sub-blocks of DC DCT coefficient values with at least one additional DCT of said series of additional DCT operations performed on selected sub-blocks of said DC DCT coefficient values and said DC DQT of previous DCT operations of said series of DCT operations to provide a composite block of AC and DC DQT coefficient values, and wherein selected values of said composite block of AC and DC DQT coefficient values are encoded to provide compressed DC DCT coefficient values, and wherein a signal is provided indicative of said compressed DC DCT coefficient values and selected ones of said block and sub-blocks of AC and DC DCT coefficient values, an apparatus for decoding said compressed DC DCT coefficient values comprising: 32 39. The apparatus of claim 38 wherein said selector means comprises: senarator means for receiving said signal indicative of said compressed DC DCT coefficient values and selected AC DCT values of said block and subblocks of AC and DC DCT coefficient values and providing a signal indicative of said compressed 5 DC DCT coefficient values in accordance with a predetermined separation format; decoder means for receiving said signal indicative of said compressed DC DCT coefficient values and providing said decoded DC DCT coefficient val- 10 ues in accordance with a predetermined decoding format; and inverse discrete quadtree means for receiving said decoded DC DCT coefficient values, performing a series of inverse discrete cosine transformation 15 (IDCI) operations to provide AC and DC IDCI coefficient values with a first IDCT performed on selected values of said processed DC DCT coefficiest values and additional IDCT operations performed on additional selected values of said pro- 20 cered DC DCT coefficient values and resultant AC and DC IDCT values from preceding IDCT operations and wherein ones of said AC and DC IDCT coefficient values are provided as said DC DCT coefficient values. 34. The apparatus of claim 33 wherein said decoder means comprises: lookup table means for receiving said signal indicative of said compressed DC DCT coefficient valnes, providing a composite block of quantized pro- 30 cessed DC DCT coefficient values in accordance with a predetermined lookup format; and inverse quantizer means for receiving said composite block of quantized processed DC DCT coefficient values and providing said decoded DC DCT coef- 35 ficient values in accordance with a predetermined inverse quantitation format. 35. The apparatus of claim 34 wherein said decoder means further comprises an expansion means disposed between lookup table means and said inverse quantizer 40 means for receiving said composite block of quantized processed DC DCT coefficient values and inserting a predetermined dummy value in said composite block of quantized processed DC DCT coefficient values and inverse zig zag format. 36. The apparatus of claim 35 wherein said expansion means is responsive to a block size assignment signal. 37. The apparatus of claim 36 wherein said inverse discrete quadtree means comprises; selector means for receiving said decoded DC DCT coefficient values and resultant AC and DC IDCT values from previous IDCT operations, and providing sub-blocks of selected decoded DC DCT coefficient values and resultant AC and DC IDCT 55 values in accordance with a predetermined selection format: and at least one inverse discrete cosine means for receiving said selected sub-blocks and performing an IDCT operation of said series IDCT operations on 60 said sub-blocks of selected decoded DC DCT coefficient values and resultant AC and DC IDCT 38. The apparatus of claim 37 wherein said at least one IDCT means comprises a plurality of single IDCT 65 means wherein each of said single IDCT means is for performing a corresponding one of said series of IDCT operations. plurality of separator means with a first separator means for receiving said decoded DC DCT coefficient values, providing a block of DCT coefficient values to a corresponding single IDCT means and separately providing remaining AC and DC DCT coefficient values to a corresponding multiplexer means and additional separator means for receiving a corresponding intermediate composite block of IDCT coefficient values and separating sub-blocks of AC and DC IDCT coefficient values from remaining AC and DC DCT coefficient values; and plurality of multiplexer means each of said multiplexer means for receiving resultant AC and DC IDCT coefficient values from a corresponding single IDCT means and said remaining AC and DC DCT coefficient values to provide an intermediate composite block of IDCT coefficient values. 40. In an image decoder wherein an image block of pixel data is processed by performing a discrete cosine transform (DCT) operation on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding block and sub-blocks of AC and DC DCT coefficient values, and wherein said DC DCT coefficient values are compressed by performing a series of DCT operations performed on said DC DCT coefficient values of said sub-blocks of pixel data to provide AC and DC DQT coefficient values with a first of said series of DCT operations performed on said sub-blocks of DC DCT coefficient values with at least one additional DCT of said series of additional DCT operations performed on selected sub-blocks of said DC DCT coefficient values and said DC DQT coefficient values of previous DCT operations of said series of DCT operations to provide a composite block of AC and DC DQT coefficient values, and wherein selected values of said composite block of AC and DC DQT coefficient values are encoded to provide compressed DC DCT coefficient values, and wherein a signal is provided indicative of said compressed DC DCT coefficient values and selected ones of said block and sub-blocks of AC and recordering said resulting values in accordance with an 45 DCDCT coefficient values, a method for decoding said compressed DC DCT coefficient values comprising the steps of: receiving said signal indicative of a composite block of AC and compressed DC coefficient values: providing compressed DC coefficient values from said composite block of AC and compressed DC coefficient values in accordance with a predetermined separation format: decoding compressed DC coefficient values accordance with a predetermined decoding format to provide decoded DC DCT coefficient values; and performing a series of inverse discrete cosine transformation (IDCT) operations to provide AC and DC IDCT coefficient values with a first IDCT performed on blocks of selected values of said compressed DC DCT coefficient values and additional IDCT operations performed on additional selected values of said compressed DC DCT coefficient values and resultant AC and DC IDCT values from preceding IDCT operations of said series of IDCT operations. 41. The apparatus of claim 40 wherein said step of decoding comprises the steps of comprises: receiving said signal indicative of said compressed DC DCT coefficient values; providing a composite block of quantized processed DC DCT coefficient values in accordance with a predetermined lookup formst; and inverse quantizing said processed DC DCT coefficient values in accordance with a predetermined inverse quantization format to provide said decoded DC DCT coefficient values. 42. The apparatus of claim 41 wherein said step of 10 decoding further comprises the steps of: inserting a predetermined dummy value in said composite block of quantized processed DC DCT coefficient values to provide a value inserted composite block; and reordering said value inserted composite block in accordance with a inverse zig zag format. 43. The apparatus of claim 42 wherein said step of decoding is responsive to a block size assignment signal. 44. In an image decoder wherein an image block of 20 pixel data is processed by performing a discrete cosine transform (DCT) operation on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding block and sub-blocks of AC and DC DCT coeffici- 25 ent values, performing a series of additional DCT operations on said sub-blocks of DC DCT coefficient values with additional DCT operations performed on selected sub-blocks of said DC DCT coefficient values and reseries of DCT operations to provide a composite block of AC and DC DQT coefficient values, encoding selected values of said composite block of AC and DC DQT coefficient values to provide compressed DC DCT coefficient values and combing selected ones of 35 said block and sub-blocks of AC and DC DCT coefficient values and said compressed DC DCT coefficient values to provide a signal indicative of a compressed block of AC and compressed DC coefficient values, an apparatus for decoding said processed DC DCT coeffi- 40 cient values comprising: separator means for receiving said signal indicative of a composite block of AC and compressed DC coefficient values and separating a signal indicative of said processed DC DCT coefficient values from 45 said signal indicative of a compressed block of AC and compressed DC coefficient values in accordence with a predetermined separation format; decoder means for receiving said signal indicative of providing said processed DC DCT coefficient valnes in accordance with a predetermined decoding inverse discrete quadtree means for receiving said processed DC DCT coefficient values, performing 55 a series of inverse discrete cosine transformation (IDCT) operations to provide AC and DC IDCT coefficient values with a first IDCT performed on selected values of said processed DC DCT coefficient values and additional IDCT operations per- 60 formed on additional selected values of said processed DC DCT coefficient values and resultant AC and DC IDCT values from preceding IDCT combination means for receiving said AC DCT coef- 65 ficient values and said DC IDCT coefficient values to provide a composite block of AC and decoded DC coefficient values and inverse transform for performing at least one IDCT operation on said composite block of AC and decoded DC coefficient values to provide a composite pixel block. 45. The apparatus of claim 44 wherein said decoder means comprises: lookup table means for receiving said signal indicative of said compressed DC DCT coefficient values providing a composite block of quantized processed DC DCT coefficient values in accordance with a predetermined lookup format; and inverse quantizer means for receiving said composite block of quantized processed DC DCT coefficient values to provide said processed DC DCT coefficient values in accordance with a predetermined inverse quantization format. 46. The apparatus of claim 45 wherein said decoder means further comprises: value insertion logic means for receiving said composite block of quantized processed DC DCT coefficient values for inserting a predetermined dummy value in said composite block of quantized processed DC DCT coefficient values to provide a value inserted composite block; and reordering means for receiving said value inserted composite block reordering the values of said value inserted composite block in accordance with a predetermined inverse zig zag format. 47. The apparatus of claim 46 wherein said value sultant DC DCT of previous DCT operations of said 30 insertion logic means and reordering means is responsive to a block size assignment signal. 48. The apparatus of claim 47 wherein said inverse discrete quadtree means comprises: selector means for receiving said processed DC DCT coefficient values and said AC and DC IDCT coefficient values and providing blocks of selected ones said of processed DC DCT coefficient values and said AC and DC IDCT coefficient values in accordance with a predetermined selection format; and at least one IDCT means for receiving said blocks of selected ones of processed DC DCT coefficient values and AC and DC IDCT coefficient values and performing a series of IDCT operations with each of said IDCT operations of said series of IDCT operations performed on blocks of said processed DC DCT coefficient values and resultant AC and DC IDCT values. 49. The apparatus of claim 48 wherein said at least one IDCT means comprises a plurality of single IDCT said processed DC DCT coefficient values and 50 means wherein each of said single IDCT means is for performing a corresponding one IDCT operation of said series of inverse discrete cosine operation. 50. The apparatus of claim 49 wherein said selector means comprises: plurality of separator means with a first separator means for receiving said processed DC DCT coefficient values providing a block of DCT coefficient values and separately providing remaining AC and DC DCT coefficient values with additional separator means for receiving a corresponding intermediate composite block of IDCT coefficient values and providing blocks of AC and DC IDCT coefficient values and separately providing additional remaining AC and DC IDCT coefficient values: plurality of multiplexer means each of said multiplexer means for receiving resultant AC and DC IDCT coefficient values from a corresponding single IDCT means and remaining AC and DC DCT coefficient values from a corresponding sepa- rator means to provide an intermediate composite inserting a predetermined dummy value in said composite block of quantized processed DC DCT coefficient values to provide a value inserted composite reordering the values of said value inserted composite block in accordance with a predetermined inverse zig zag format. 36 54. The method of claim 53 wherein said steps of inserting said predetermined dummy value and reordering the values of said value inserted composite block are responsive to a block size assignment signal. 55. In an adaptive block size compression system wherein a block of pixel data is transformed to AC and DC discrete cosine transform (DCT) coefficient data DCT coefficient values and resultant DC DCT of pre- 15 for constituent blocks of vary block size, a sub-system for compressing said DC DCT coefficient data com- > discrete quadtree means having a first input for receiving at least one block of data and having an output wherein said discrete quadtree means com- prises: plurality of DCT means with a first DCT means having an input for receiving said at least one block of data and having an output with each additional DCT means having an input and an at least one selector means disposed between each of said plurality of DCT means having and input coupled to a corresponding DCT means output and output coupled to a corresponding one of said additional DCT means input; and selection means having an input coupled to said discrete quadtree means output and having an output. - 56. The apparatus of claim 55 wherein said at least 35 one selector mesps has a second output and said discrete quadtree means further comprises at least one multiplexer means disposed between one of said additional DCT means and one of said at least one selector means having a first input coupled to said additional DCT means output and a second input coupled to said selector means second output and having an output coupled to said selector means input. - 57. The apparatus of claim 56 wherein selection means comprises: - first selection multiplexer having a first input coupled to said DQT means, a second input for receiving a selection signal, a third input for receiving a dummy signal, and having an output; and additional selection multiplexer means having a first input coupled to a corresponding selection multiplexer output, a second input for receiving a selection signal, a third input for receiving a dummy signal, and having an output. 58. The apparatus of claim 57 wherein said selection zig zag scan serializer having an input coupled to a last selection multiplexer means of said additional selection multiplexer means output and having an output: value removal logic means having an input coupled to said zig zag scan scrializer output and having and output: and code lookup table means having an input coupled to said value removal logic means output and having an output. 59. In an image decoder wherein and image block of pixel data is processed by performing a discrete cosine transform (DCT) operation on said block of pixel data block of IDCT coefficient values. 51. A method for decoding a block of pixel data 5 wherein an image block of pixel data is processed by performing a discrete cosine transform (DCT) operation on said block of pixel data and on at least one predetermined level of constituent sub-blocks of pixel data thereof to provide corresponding block and sub-blocks 10 of AC and DC DCT coefficient values, performing a series of additional DCT operations on said sub-blocks of DC DCT coefficient values with additional DCT operations performed on selected sub-blocks of said DC vious DCT operations of said series of DCT operations to provide a composite block of AC and DC DQT coefficient values, encoding selected values of said composite block of AC and DC DQT coefficient values to provide compressed DC DCT coefficient values and 20 combining selected ones of said block and sub-blocks of AC and DC DCT coefficient values and said compressed DC DCT coefficient values to provide a signal indicative of a compressed block of AC and compressed DC coefficient values, a method for decoding said 25 block of pixel data comprising the steps of: receiving said signal indicative of a composite block of AC and compressed DC coefficient values; providing said compressed DC coefficient values of 30 said composite block of AC and compressed DC coefficient values; separately providing said AC coefficient values of said composite block of AC and compressed DC coefficient values; decoding said compressed DC DCT coefficient values in accordance with a predetermined decoding format to provide decoded DC DCT values; performing a series of inverse discrete cosine transformation (IDCI) operations to provide AC and 40 DC IDCT coefficient values with a first IDCT performed on blocks of selected values of said processed DC DCT coefficient values and additional IDCT operations performed on blocks of selected values of said processed DC DCT coeffi- 45 cient values and resultant AC and DC IDCT values from preceding IDCT operations wherein ones of said AC and DC IDCT values and decoded DCT values are provided as uncompressed DC DCT coefficient values; and combining said AC DCT coefficient values and said uncompressed DC DCT coefficient values to provide a composite block of AC and uncompressed DC coefficient values; and performing at least one IDCT operation on said com- 55 means further comprises: posite block of AC and uncompressed DC coefficient values to provide a composite pixel block. 52. The method of claim 51 wherein said step of decoding comprises the steps of: receiving said compressed DC DCT coefficient val- 60 providing a composite block of quantized processed DC DCT coefficient values in accordance with a predetermined lookup format; and inverse quantizing said composite block of quantized 65 processed DC DCT coefficient values 53. The method of claim 52 wherein said step of decoding further comprises: 5,452,104 37 and on at least one predetermined level of constituent sub-blocks of pixel data thereof, and providing corresponding block and sub-blocks of AC and DC DCT coefficient values and wherein said DC DCT coefficient values is further processed by performing a series of at least one additional DCT operation on said sub-blocks of DC DCT coefficient values, a subsystem for decoding said processed DC DCT coefficient values comprising: decoder means having an input for receiving a signal indicative of said processed DC DCT coefficient values and having an output; and inverse discrete quadtree means having an input coupled to said decoder means output, wherein said 15 inverse discrete quadtree means comprises: plurality of separator means with a first separator means having an input for receiving said signal indicative of said processed DC DCT coefficient values and additional separator means having an 20 input and an output; at least one inverse discrete means disposed between said plurality of separator means having an input coupled to a corresponding separator means output. 60. The apparatus of claim 59 wherein said separator means further having a second output and wherein said discrete quadtree means further comprises: at least one multiplexer means having an input for receiving a timing signal, a second input coupled to a corresponding inverse cosine transform means output and a third input coupled to a corresponding second separator means output. 61. The apparatus of claim 60 wherein said decoder decode lookup table means having an input for receiving signal indicative of said processed DC DCT coefficient values and having an output; value insertion logic means having a first input coupled to said decode lookup table means output, a second input for receiving a selection signal, and having an output; inverse zig-zag scan insertion logic means having a first input coupled to said value insertion logic means output an a second input for receiving a selection signal, and having an output; and inverse quantizer means having an input coupled to said inverse zig-zag scan insertion logic means output and having an output. 30 35 40 45 50 55 60 65 ! . : US005576767A ### United States Patent [19] · Lee et al. (11) Patent Number: 5,576,767 [45] Date of Patent: Nov. 19, 1996 ### [54] INTERFRAME VIDEO ENCODING AND DECODING SYSTEM - [75] Inventors: Chong U. Lee; Donald Pian, both of San Diego, Calif. - [73] Assignce: Qualcomm Incorporated, San Diego, Calif. - [21] Appl. No.: 532,042 - [22] Filed: Sep. 21, 1995 ### Related U.S. Application Data [63] Continuation of Ser. No. 407,427, Mar. 17, 1995, abandoned, which is a continuation of Ser. No. 12,814, Feb. 3, 1993, abandoned. | [51] | Int CL° H04N 7/32 | |------|-----------------------------| | [52] | U.S. Cl | | [58] | Field of Search | | | 248/412 A12 A15 A16 600 A07 | ### [56] References Cited ### U.S. PATENT DOCUMENTS | 4,179,709 | 12/1979 | Workmen | 358/133 | |-----------|---------|-------------------|----------| | 4,293,920 | 10/1981 | Merola | 364/725 | | 4,504,860 | 3/1985 | Nicol et al | 358/133 | | 4,774,574 | 9/1988 | Daly et al | 358/133 | | 4,776,030 | 10/1988 | T200 | . 382/56 | | 4,796,087 | V1989 | Guichard et al | 348/402 | | 4,807,042 | 2/1989 | Tanaka | 358/260 | | 4,816,906 | 3/1989 | Kummerfeldt et al | 348/402 | | 4,821,119 | 4/1989 | Gherayl | 348/402 | | 4,922,341 | 5/1990 | Strobach | 358/136 | | 4,924,309 | 5/1990 | Hartnack et al | 358/133 | | 4,984,076 | 1/1991 | Watenabe et al | 358/133 | | 5,021,891 | 6/1991 | Lot | 358/432 | | 5,045,938 | 9/1991 | Sogiyama | 358/133 | | 5,073,820 | 12/1991 | Nakagawa et al | 358/133 | | 5,107,345 | 4/1992 | Let | 358/432 | | 5,126,857 | 6/1992 | Watanabe et al | 358/433 | | 5,151,784 | 9/1992 | La Vagetto et al | | | 5,235,419 | 8/1993 | Krane | | ### OTHER PUBLICATIONS Dinstein et al. "Variable Block-Size Transform Image Coder," *IEEE Transactions on Comm.*, pp. 2073–2078, Nov. 1990. Reininger et al. "Distributions of the Two-Dimensional DCT Coefficients for Images," *IEEE Transactions on Comm.*, pp. 835–839, Jun. 1983. Ahmed et al. "Discrete Cosine Transform," IEEE Transactions on Computers, pp. 90-93, Jan. 1973. Comstock et al. "Hamming Coding of DCT-Compressed Images Over Noisy Channels," *IEEE Transactions on Comm.*, pp. 856-861, Jul. 1984. ### (List continued on next page.) Primary Examiner.—Tommy P. Chin Assistant Examiner.—A. Au Attorney, Agent, or Firm.—Russell B. Miller, Scan English ### 57] ABSTRACT A video compression system and method for compressing . video data for transmission or storage by reducing the temporal redundancy in the video data is described. A frame of video data is divided into a variable number of blocks of pixel data of varying size, and each block of data is compared to a window of pixel data in a reference frame of pixel data, typically the previous frame. A best matched block of pixel data is selected from the window of pixel data in the reference frame, and a displacement vector is assigned to describe the selected block location in the reference frame relative to the current block of pixel data. The number and size of the blocks of pixel data are permitted to vary, in order to adapt to motion discontinuities in the sequential frames of pixel data. This is to allow prediction blocks of pixel data in the current frame to be smaller in areas of high activity, while maintaining high levels of compression, achieved by using larger prediction blocks, in areas of the frame with low levels of activity. A frame of predicted pixel data is assembled from variable size blocks of prediction data and subtracted from the current frame of pixel data. Only the residual difference, the displacement vectors and an indication of the block sizes used in the prediction are needed for transmission or storage, ### 24 Claims, 6 Drawing Sheets ### 5,576,767 Page 2 ### OTHER PUBLICATIONS Roese et al. "Interframe Cosine Transform Image Coding," IEEE Transactions on Comm., pp. 1329–1339, Nov. 1977. Chen et al. "Adaptive Coding of Monochrome and Color Images," IEEE Transactions on Comm., pp. 1285–1292, Nov. 1977. Chen et al. "Scene Adaptive Coder," IEEE Transactions on Comm., pp. 225-232, Mar. 1984. Strobach, Peter. "Quadtree-Structured Recursive Plane Decomposition Coding of Images," *IEEE Transactions on Comm.*, pp. 1380-1397, Jun. 1991. U.S. Patent Nov. 19, 1996 Sheet 2 of 6 5,576,767 Ex. 2-5 5,576,767 1 ## INTERFRAME VIDEO ENCODING AND DECODING SYSTEM This is a continuation of application Ser. No. 08/407,427, filed Mar. 17, 1995, abandoned which is a continuation of application Ser. No. 08/012,814 filed Feb. 3,1993, now abandoned. #### **BACKGROUND OF THE INVENTION** #### I. Field of the Invention The present invention relates to image processing. More particularly, the present invention relates to a novel and improved system and method for interframe video coding based upon motion compensated predictive discrete cosine transform coding techniques. ### II. Description of the Related Art In the field of transmission and reception of television signals, various improvements are being made to the NTSC 20 (National Television Systems Committee) System. Developments in the field of television are commonly directed towards a high definition television (HDTV) system. In the early development of HDTV, system developers have merely applied the Nyquist sampling theorem and low-pass 25 filter design with varying degrees of success. Modulation in these systems amounts to nothing more than a simple mapping of an analog quantity to a value of signal amplitude or frequency. It has most recently been recognized that it is possible to achieve further improvements in HDTV systems by using digital techniques. Many of the early HDTV transmission proposals share common factors. These systems all involve digital processing of the video signal, which necessitates analog-to-digital (A/D) conversion of the video signal, An 35 analog transmission format is then used thereby necessitating conversion of the digitally processed picture back to analog form for transmission. The receiver/processor must then reverse the process in order to provide image display. The received analog signal is therefore digitized, stored, processed and reconstructed into a signal according to the interface format used between the receiver/processor and the HDTV display. Furthermore the signal is most likely converted back to analog form once more for display. Many of the conversion operations mentioned above, however, may be avoided using a digital transmission format which transmits the processed picture, along with control, audio and authorization signals, using digital modulation techniques. The receiver may then be configured as a digital modem with digital outputs to the video processor function. Of course, the modem requires an A/D function as part of operation, but this implementation may only require a 4-bit resolution device rather than the 8-bit resolution device required by analog format receivers. Digital transmission is superior to analog transmission in many ways. Digital transmissions provide efficient use of power which is particularly important to satellite transmission and military applications. Digital transmissions also provides a robustness of the communications link to impairments such as multipath and jamming. Furthermore digital transmission facilitates ease in signal encryption, necessary for many military and broadcast applications. Digital transmission formats have been avoided in previous HDTV system proposals primarily because of the incorrect belief that they inherently require excessive bandwidth. 2 Therefore in order to realize the benefits of digital transmission, it is necessary to substantially compress the HDTV signal. HDTV signal compression must therefore be achieved to a level that enables transmission at bandwidths comparable to that required by analog transmission formats. Such levels of signal compression coupled with digital transmission of the signal will enable a HDTV system to operate on less power with greater immunity to channel immairments. Motion estimation/motion compensation techniques can be used to compress the amount of data required in the transmission of interframe coded motion video. Motion estimation/motion compensation processes exploit the high level of temporal redundancy in video data. This high level of temporal redundancy is a neccessary attribute of video data for the picture sequences to appear continuous. The process of estimating the motion of objects within a video sequence is known as motion estimation. The processing of images by compensating for the presence of motion in a scene or image is motion compensation. The combined processes of motion estimation and motion compensation produce a prediction of the current frame of data. The error in this prediction, known as the residual, can be further compressed and transmitted. It is therefore an object of the present invention to provide a novel and improved method and system for compressing HDTV signals that will enable digital transmission at bandwidths comparable to that of analog transmission of conventional TV signals. #### SUMMARY OF THE INVENTION The present invention is a novel and improved system and method for compressing image data for transmission and for reconstruction of the image data upon reception. The image compression system includes a subsystem for generating a prediction of a block of input pixel data in the current frame of pixel data from a corresponding composite block pixel data from a reference frame of data optimized for encoding a high precision reproduction of said pixel data at a minimum transmission data rate. In the present invention, novel techniques of motion estimation and motion compensation are employed. In standard motion estimation and motion compensation applications, a frame of data is divided into a fixed number of blocks of pixel data, and a prediction for each of the blocks of pixel data is calculated. The problem with using a fixed number of blocks is that using blocks that are too small results in a low level of compression and requires unacceptably high banwidth for transmission, and using blocks that are too large results in an unacceptably high level of picture degradation. In the present invention, however, the number and size of the blocks of pixel data varies in response to the amount of information in frame sequences. By employing this technique a high level of data compression can be achieved without picture degradation. The sub-system of the present invention comprises first selection means for providing a first data prediction by selecting a most similar block of pixel data from a first reference block of data wherein the first reference block of data is a block of data from a previous frame or a combination of blocks of data from previous frames of data, and at least one additional selection means for providing additional predictions of the block of pixel data as combinations of predictions of smaller sub-blocks of pixel data by selecting sets of most similar sub-blocks of pixel data from additional reference blocks of data and wherein the data and tional reference blocks of data can be data from a previous frame or a combination of blocks of data from previous frames of data. The decision means is included in the sub-system for selecting from the first data prediction and the additional data predictions an efficient prediction according to the similarity the current block of pixel data and the number of bits required to describe the efficient prediction and providing the efficient prediction as an output and a selection signal indicating the block size selection used in describing the 10 efficient prediction. The present invention also provides for a novel and improved method for reconstructing from a received encoded motion information value a corresponding block of pixel data. The present invention further envisions a novel and improved method for compressing an image signal as represented by a block of pixel data and for reconstructing the image signal from the compressed image signal. #### 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 25 the drawings in which like reference characters identify correspondingly throughout and wherein: FIG. 1 is a block diagram of an exemplary interframe encoder: FIG. 2 is a block diagram of an exemplary interframe <sup>30</sup> decoder: FIGS. 3a and 3b are illustrations of pixel block space with a matching of pixel blocks between frames for the purpose of motion prediction; FIGS. 4a, 4b, 4c and 4d are exemplary illustrations of alternative motion prediction block sizes for a 32x32 block of pixel data; FIG. 5 is an exemplary illustration of a composite 32x32 block of predicted pixel data; FIG. 6 is a simplified block diagram illustrating the processing elements in the block size assignment portion of an adaptive block size motion estimation element; FIG. 7 and 8 are block diagrams illustrating the processing elements in an exemplary adaptive block size motion <sup>45</sup> estimation element; and PIG. 9 is a block diagram illustrating the processing elements in an exemplary adaptive block size motion compensated prediction element. ### DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS Turning now to the drawings, FIQ. 1 illustrates in block 55 diagram form an exemplary implementation of a general motion-compensated predictive coding (MPC) system. The coding system of FIQ. 1 is comprised of intraframe encoder 10, channel encoder 12, intraframe decoder 14, frame buffer 16, motion-compensated prediction processor or predictor 60 18, motion estimation processor or estimator 20, and summers 22 and 24. It should be understood that the diagram of FIG. 1 is common to both conventional motion-compensated predictive coding systems and the present invention. However, in the present invention novel motion estimation 65 and motion compensated prediction techniques are employed. 4 A sequence of input pictures comprised of pixel data is input to the coding system of FIG. 1. The pixel data may be provided as serial pixel data or in blocks, typically a 32x32 pixel block or smaller such as 16x16, 8x8, etc., is input to summer 22 and to motion estimator 29. Summer 22 subtracts from the input pixel data a corresponding prediction picture generated by motion-compensated predictor 18. The output of summer 22 is a displaced frame difference (DFD) data that is provided to intraframe encoder 19. Intraframe encoder 10 encodes the DFD data using one of many possible intraframe compression techniques. Intraframe encoder 10 by way of example may be a block encoder which codes blocks of the DFD data. Should the DFD data be in serial form it is converted to block data for coding. An example of one type of intraframe decoder is the well known fixed block size discrete cosine transform (FBS-DCT) coder. Another example of an intraframe coder which has improved performance over the FBSDCT coder is one using the adaptive block size discrete cosine transform (ABSDCT) techniques disclosed in U.S. Pat. Nos. 5,021,891 and 5,107,345, and even further using the ABSDCT technique in combination with a Discrete Quadtree Transform technique disclosed in copending U.S. patent application Ser. No. 07/710,216, filed Jun. 4, 1991 each assigned to the assignce of the present invention and the disclosure of which is incorporated by reference. Although ABSDCT coders are preferred, other types of intraframe encoders well known in the art may be readily substituted therefore. The intraframe coded data generated by intraframe encoder 10 is provided both to channel encoder 12 and intraframe decoder 14. Channel encoder 12 is preferably used for encoding the intraframe coded data prior to transmission to protect the data from transmission channel induced errors. Channel encoder 12 typically uses conventional error correction encoding techniques. As such, encoder 12 may be a block, convolutional or trellis coder as is well known in the art. The encoded intraframe data along with motion vector data are encoded and provided for transmission by a transmitter (not shown). The intraframe coded data provided to intraframe decoder 14 is decoded to produce a reconstructed DFD block. Intraframe decoder 14 is by its nature of a type which complements intraframe encoder 10. When intraframe encoder 10 is of the type mentioned in the above patents and patent application, the decoder is typically of the corresponding type as also described therein. The reconstructed DFD block is provided from intraframe decoder 14 to summer 24 where it is added with a prediction picture generated by motion-compensated predictor 18 based upon a reference frame, typically the previous frame. of the input picture. The output of summer 24, which is a reconstructed picture, i.e. pixel block, is provided to frame buffer 16. Prame buffer 16 is thus updated by a reconstructed frame created by adding the reconstructed DFD that is produced by intraframe decoder 14 to the prediction picture. The reason for using the reconstructed DPD rather than the DFD is to keep frame buffer 16 and the frame buffer in the decoding system (FIG. 2) synchronized. In other words by using the reconstructed DFD the same picture is in both frame buffer 16 and the frame buffer in the decoding system (FIG. 2), since the DFD is not available to the decoding system. The reconstructed picture stored in frame buffer 16 is provided to motion-compensated predictor 18 and motion estimator 20. Estimator 20 uses the reconstructed picture stored in frame buffer 16 and the input picture of the next frame to generate a set of motion vectors for the next input picture frame. Predictor 18 uses the reconstructed picture from the current frame stored in frame buffer 16 and the motion vectors generated in estimator 20 to produce a prediction for the next frame. The motion vectors from 5 estimator 20 are also provided to channel encoder 12 for encoding and transmission along with the intraframe data for the next frame. FIG. 2 illustrates in block diagram form an exemplary implementation of a motion-compensated predictive decod- 10 ing system for decoding data encoded according to the encoding system of FIG. 1. The decoding system of FIG. 2 is comprised of channel decoder 30, intraframe decoder 32, motion-compensated predictor 34, summer 36 and frame buffer 38. A motion estimator is not needed in the decoding 15 system since the motion vectors along with the interframe data is received from the encoding system. Thus the operation of the decoding system except for the channel decoder is a subset of the operations of the coding system of FIG. 1. The signal received from the transmission channel 20 Day (L(4)) = receiver (not shown) is provided to channel decoder 30. Channel decoder 30 is of a type capable of decoding the data as encoded by channel encoder 12 of FIG. 1. Channel decoder 30 typically uses conventional decoding techniques and may be configured as a block, Viterbi or convolutional 25 If Fance(x, y)=|x-y|, Equation 1 simplifies to the following: decoder as is well known in the art. The decoded data includes both intraframe data and motion vector data. The intraframe data is provided to intraframe decoder 32 while the motion vector data is provided to motion compensated predictor 34. Intraframe decoder 32 produces from the intraframe data the reconstructed DFD which is provided to summer 36 along with a prediction picture generated by predictor 34. intraframe decoder is preferably of the same type as intraframe decoder 14 of FIG. 1. Summer 36 adds the reconstructed DFD to the prediction picture to produce a reconstructed picture. The current frame of the reconstructed picture is provided to frame buffer 38 where it is stored. The stored frame is provided to predictor 34 for use in generating the prediction picture for the next Returning to FIG. 1, in order to facilitate an understanding of the generation of the motion vectors of the present invention a description of conventional motion vector gencration techniques is provided. The input picture is an image sequence, e.g., motion video, which can be represented by an intensity function I(x, y, t) where x and y are the spatial coordinates of the pixel and t is the frame number. Using this nomenclature the current frame to be encoded may be identified as I(x, y, t) and a reference frame may be identified as I\_(x, y, t). A conventional motion estimator used in a conventional motion-compensated predictive coding system is based moon block matching. In the conventional motion estimator 55 an NxM block of pixels for the current frame is used to search for a matching block in the reference frame, typically the previous frame (i.e. $I_n(x, y, t)=I(x, y, t-1)$ ). N and M may be of the same integer value to provide a square pixel block or may be of different values to provide a rectangular pixel 60 FIG. 3a illustrates for current pixel frame 40 a selected NxM pixel block 42. For reference purposes the (x, y) coordinates of the first pixel in the upper left hand corner of frame 40, pixel 44, is (0, 0). The (x, y) coordinate of the first 65 pixel in the upper left hand corner of pixel block 42, pixel 46, is (k1, l1) with this pixel having an intensity function of 6 I(k1, l1, t). The vector associated with the location of pixel block 42 within frame 40 is (k1, 11). A search for the best matching block in the reference frame is conducted over a search window within the reference frame. The "goodness" of the match is often measured by a block matching distortion function F<sub>BMD</sub>(x, y) which for example may be a magnitude difference or squared error, e.g. $F_{RMD}(x, y)=tx-y$ for $F_{RMD}(x, y)=(x-y)^2$ . FIG. 3b illustrates the reference pixel frame 48 and a search window 50 over which the best match for pixel block 42' is to be searched. In FIG. 3b the position in reference frame 48 which the pixel block 42' occupied in the current frame is indicated in dotted lines by pixel block 52. The (x, y) coordinate of the first pixel in the upper left hand corner of pixel block 52, pixel 54, is (k1, 11) having an intensity function of $I_{H}(k_1, l_1, t)$ A full-search block-matching motion estimator computes the distortion figure D. .... $$D_{m,n}(k | i, j) =$$ (1) $$H-1 M-1 \ \Sigma \ \Sigma F_{BMD}(I(k+n,l+m,l),I_{R}(k+n+l,l+m+j,l)).$$ and made $$D_{K,n}(k|U) =$$ (2) The motion estimator further searches for the motion displacement (i, j) that minimizes $D_{MM}(k, l, i, j)$ to produce the minimum block distortion where: where S is the search window. From Equation 3 the displacement (i, j) that produces the minimum motion block distortion is called the motion vector (mx, my). The motion vector search range is often restricted to a maximum offset, typically -32≤mx, my≤32. It should be noted that mx and my need not be integer values. These values can be fractional numbers if a sub-pixel accuracy is used in motion estimation and compensation. It should be 45 noted that extra processing, including interpolation, is required to produce non-integer pixels. Using the above equations for the example illustrated in FIG. 3b, a pixel block 42 in the reference frame is identified as having the best match. The (x, y) coordinate of the first pixel in the upper left hand corner of pixel block 42', pixel 46', is $(k_1+i_1, l_1+j_1)$ having an intensity function of $l_n(k_1+i_1)$ l<sub>1</sub>+<sub>1</sub>, t). The motion vector associated with the location of pixel block 42' with respect to pixel block 52 in the reference frame 48 is (i<sub>1</sub>, j<sub>1</sub>). Referring back to FIG. 1, motion estimator 20 differs from a conventional motion estimation processor in that more than one block size is used in the motion estimation. For convenience, let the motion block be an NxN square (ie. M=N so that $D_{N,M}(k, i)=D_N(k, i)$ ). In an exemplary configuration four motion block sizes are used, for example N=4, 8, 16 and 32. In the exemplary configuration, there will be one motion block distortion D<sub>32</sub>(k, l) for the 32×32 base block, four motion block distortions for each of the four 16x16 blocks within that 32x32 block, sixteen distortions for each of the sixteen motion block distortions within the 32x32 block and aixty-four motion block distortions for each of the sixty-four 8x8 blocks within the 32x32 block. FIGS. 4a-4d, illustrate in an exemplary configuration, alternative block sizes used for motion estimation of the 32x32 block of pixel data. The block of pixel data in the current frame can be predicted by the selection of a single best match of a 32x32 block of pixel data from the reference frame as shown in FIG. 4a or alternatively can be predicted by selection frum a reference frame of best match blocks in the form of four 16x16 sub-blocks of pixel data in FIG. 4b, sixteen sub-blocks of pixel data in FIG. 4c, or sixty-four sub-blocks of pixel data in FIG. 4d. Alternatively the block of pixel data can be predicted by a composite of 16x16, 8x8, and 4x4 blocks of pixel data from the reference frame as illustrated in FIG. 5. In motion compensated prediction, predictions from the composite of smaller sub-blocks of pixel data will, in 15 general, always result in a lower than or equal to distortion level than the distortion level resulting from predictions from a larger block. However, motion compensated predictions from smaller sub-blocks of pixel data, requires the transmission of more information, i.e. more motion vectors. 20 The goal of an adaptive motion estimator 20 of FIG. 1 is to select smaller sub-block predictions only when it results in a significant improvement in local pixel reproduction quality. In a pixel area where a great amount of activity is present the predictions using the larger block sizes will result in 25 unacceptably high levels of distortion. On the other hand, in areas where little or no activity is taking place the larger block sizes are acceptable and result in greater compression at little cost to picture quality. The adaptive block size motion estimation processor produces the composite motion block by choosing an optimum combination of large and small motion blocks that best describe the motion within the image block. This is to produce an improved motion compensated prediction such that the residual DFD (displaced frame difference) contains less signal energy and is therefore easier to encode using the subsequent spatial only compression (i.e. DCT or ABS-DCT). Referring to FIG. 6, this adaptive motion block size decision is performed in the following manner. Four neighboring motion block distortions D<sub>p</sub>(k,l), D<sub>p</sub>(k,l+N), D<sub>p</sub>(k+N,l) and D<sub>p</sub>(k+N,l+N) are grouped and summed to produce an alternative block distortion for the 2N>QN block that contains the four blocks. In FIG. 6, this summing occurs in block 60. $$\hat{D}O_{0,k}(k,l,l) = \sum_{n=0}^{l} \sum_{m=0}^{l} D_{m}(k+m)(1+m)k)$$ (4) If this distortion is significantly smaller than the distortion $D_{2N}(k,l)$ , referring to the labeling acheme shown in FIG. 4, then the $D_{2N}(k,l)$ is replaced with $D_{2N}(k,l)$ and that decision so is entered in a block assignment register. This indicates that the 2NNAN block may be more efficiently encoded by sending four NNAN motion vectors. This process is repeated for all NNAN motion blocks, before the process is applied to the resulting 2NNAN motion blocks. In the end, the process stops at the largest block size 32N32 in this example. Although $\tilde{D}_{2M}(k,l)$ is likely to always be smaller or equal to $D_{2M}(k,l)$ , there is a cost associated with using the smaller motion blocks. This can be factored into the decision using a cost function $C_{M}(\cdot)$ calculator 62. If $$\tilde{D}_{RM}(k,l,l) < \sum_{i=1}^{l} \sum_{i} C_{il}(D_{il}(k+\pi N, 1+\pi N))$$ (5) then use 2NX2N block size otherwise use 4 NXN blocks. In a simplified comparison format, $$D_{\lambda\mu}(k_{\perp}) \cdot C_{\mu}(\bar{D}_{\lambda\mu}(k_{\perp}))$$ (6) 8 can be used. In the most simplistic form the cost function can be a scalar multiplication operation of the form $C_N(X) =_{u_N} X$ , where the bias factor $_{u_N} > 1$ . In FIG. 1, an image signal as represented by a 32x32 block of pixel data is received from the frame buffer (not shown). The pixel data may be either 8 bit black and white image data or 24 bit color image data. FIG. 7 illustrates the implementation of the motion estimation processor. The 32 x32 pixel block is input to a 32x32 motion vector calculator element 82a. The 32x32 pixel block is also input as four 16x16 pixel blocks to 16x16 motion vector calculator element 82b, as sixteen 8x8 pixel blocks to 8x8 motion vector calculator element 82c, and as sixty-four 4x4 pixel blocks to 4x4 motion vector calculator element 82c. Motion vector calculator elements \$20-\$2d select a best matched block of pixel data from a reference frame of pixel data and provide a motion vector corresponding to the location of the best matched block of pixel data within the search window of the reference frame. In the exemplary configuration, motion vector calculator element \$2a selects a single 32x32 best match block of pixel data from the reference frame and provides a single motion vector, motion vector calculator element 52b compares the four 16x16 sub-blocks of pixel data in the 32×32 block of pixel data to 16x16 blocks of pixel data in the reference frame and accordingly provides four motion vectors, motion vector calculator element \$2c compares the sixteen 8x8 sub-blocks of pixel data in the 32x32 block of pixel data to 8x8 blocks of pixel data in the reference frame and accordingly provides sixteen motion vectors, while motion vector calculator element 82d compares the sixty-four 4x4 sub-blocks of pixel data in the 32x32 block of pixel data to 4x4 blocks of pixel data from the reference frame and accordingly provides sixty-four motion vectors. Motion vectors are provided by motion vector calculators \$20-82d to respective distortion calculators 84o-84d. Distortion calculators 840-84d calculate a distortion quantity indicating "goodness" of the match the pixel data predictions. The distortion function can be a mean square error function or magnitude of the difference function. Other distortion functions are possible. The 32x32 distortion calculator 84a provides one distortion quantity D<sub>xx</sub>(k.i). Whereas, for example, the 16x16 distortion calculator 84b provides four distortion quantities D<sub>16</sub>(k,l), D<sub>16</sub>(k+16,l), D<sub>16</sub>(k+16,l), D<sub>16</sub>(k+16,l), D<sub>16</sub>(k+16,l), and D<sub>16</sub>(k+16,l+16) corresponding to each of the matched pairs of blocks of pixel data. Similarly, the 8x8 distortion calculator 84c provides sixteen distortion quantities and the 4x4 distortion calculator 84d provides aixty-four distortion quantities. The outputs of distortion calculators 84b-84d are respectively input to distortion summers 866-86d. The distortion summers 86b-86d sum distortion values of adjacent subblock predictions according to a grouping convention to provide alternative distortion values for larger blocks of pixel data. For example, the distortion in predictions of the four 4x4 sub-blocks of pixel data Da(k,l), Da(k+4,l), Da(k, 1+4) and D<sub>4</sub>(k+4,1+4) are summed by distortion summer 24d to produce the alternative distortion value Du(k,l). This value corresponds to a single block D<sub>s</sub>(k,l) produced by distortion calculator 84c. The procedure of grouping and summing proceeds at all levels except the 32x32 prediction level. The 4x4 distortion summer 86d provides sixteen alternative distortion values of the form D<sub>n</sub>(x,y), the 8x8 distortion summer 86c provides four alternative distortion values of the form $\tilde{D}_{16}(x,y)$ and the 16x16 distortion summer 866 provides one alternative distortion value of the form $\bar{D}_{32}(x,y)$ . Ex. 2-12 The alternative distortion values are provided to weighting factor multipliers \$8a, 88b and 88c. The cost of alternative distortion values are therein calculated according to a cost function to reflect the increase in number of bits associated with block predictions based on smaller blocks of pixel data. The weighting factor multipliers provide cost function adjusted alternative distortion values D'a(k,l), $\tilde{D}'_{16}(k,l)$ and $\tilde{D}'_{22}(k,l)$ to comparators 90s-90c. The comparators compare the prediction distortions to the cost function adjusted alternative distortion values and provide a 10 selection signal of "O" or "1". If the cost function adjusted alternative distortion value is less than the larger block prediction distortion, a one is output by the comparator to signal the selection of the group of smaller predictions over the single prediction based on a larger block of pixel data 15 from the reference frame. The values output from comparators 90a-90c are stored in block size assignment registers P, Q and R as motion block size assignment data. The motion estimator then combines the motion vectors of selected pixel prediction blocks into a composite motion 20 vector block. In an exemplary implementation of the selected motion vectors combiner portion of the motion estimator, as illustrated in FIG. 8, the P value output from comparator 90s (FIG. 7) is input serially to a sixteen-bit register, P register 100. Similarly, the output from compara- 25 tor 90b (FIG. 7) is input scrially to a four-bit register, Q register 102. Finally, the output from comparator 90c (FIG. 7) is input serially to a one-bit register, R register 104. The output from P register 100 is provided as a P output to the select input of the motion vector selector 106. Motion vector 30 selector 106, which may also be configured as a multiplexer, also has inputs as the MV4 and MV8 motion vector values respectively output from motion vector calculators 82d and 82c. The motion vector selector provides according to the block size assignment data a motion vector for the selected 35 8x8 prediction or a corresponding group of four motion vectors for each of the selected 4x4 predictions. The motion vector or vectors provided as output from motion vector selector 106 are provided as an input to motion vector selector 105, which also has as a second input for the MV16 40 motion vector values as output from motion vector calculator \$25. A select input to motion vector selector 105 is provided from the output of Q register 102. The ouput of Q register 102 determines whether the motion vector or vectors provided by motion vector selector 106 or the MV16, a 45 16×16 block motion vector provided by motion vector calculator 82b, is provided as output for motion vector selector 108. The output of motion vector selector 108 is coupled as one input to motion vector selector 110. The other input of motion vector selector 110 is coupled to the output 50 of motion vector calculator 82s for receiving the value of motion vector MV32. The select input of multiplexer 110 is coupled to the output of R register 104 so as to receive the output hit R. Motion vector selector 110 provides the final step of selection wherein the output bit of the R register 35 determines between providing the 32x32 block prediction vector MV32 or the output motion vectors of motion vector selector 108. As illustrated in FIG. 8, the value of P register 100 bit is used to select via motion vector selector 106, 4x4 or 8x8 60 motion vectors of block prediction data. The selection of MV4 data comprising four motion vectors or the corresponding MV8 data comprising a single motion vector occurs at motion vector selector 106 in response to the value of the bit output from P register 100. Motion vector selector 65 106, in response to the value of the bit output from Q register 102 selects between the output of motion vector selector 106 10 and the MV16 data. When the Q register bit value is a "1" bit, the output of motion vectors from motion vector selector 106 is selected for output of motion vector selector 108. When the Q register bit value is a "O" bit, motion vector selector 108 selects the MV16 motion vector. Therefore, the output bit value of Q register 102 selects between motion vectors for four 8x8 block predictions or one motion vector for a single 16x16 block prediction. As illustrated in FIG. 8, the four upper left hand blocks selected as output from motion vector selector 106 include the motion vectors for four 4x4 block predictions with the motion vectors for three neighboring 8x8 block predictions. However with the bit of the Q register being a "O" bit, motion vector selector 108 selects the motion vector corresponding to a 16-16 block prediction as an output. This example illustrates the conditional replacement scheme. The output of motion vector selector 108 is coupled as an input to motion vector selector 110. The other input of motion vector selector 110 is provided with the MV32 data, the 32×32 block of motion estimation vector MV32 as provided by motion vector calculator \$2a. The select input to motion vector selector 110 is the output bit of the R register. In the example illustrated in FIG. 8, the bit output from R register 104 is a "1" bit thus selecting data as output from motion vector selector 110 which was provided from motion vector selector 108. Should the R register 104 output bit value be a "0" bit motion vector selector 110 would output the MV32 data. The motion vector selector scheme as illustrated in FIG. 8 utilizes the block assignments to select motion vectors MV4, MV8, MV16, MV32 a composite motion vector. In essence this step is accomplished by three stages. The first stage conditionally replaces an 8x8 motion vector MV8 with four 4x4 MV4 motion vectors according to the content of the P register. The second stage conditionally replaces a 16x16 motion vector MV16 with output vectors from the previous stage according to the content of the P register. The third stage replaces the 32x32 motion vector MV32 with output vectors from the second stage if the R register contains a "1" bit. The composite motion vector is provided to the motion compensated predictor 18 (FIG. 1) along with the motion block size assignment data. After all decisions are made, the motion block size assignment (MBSA) data in registers P, Q and R along with the corresponding motion vectors (ie. chosen from $m_{20}(k, l)$ , and $m_{20}(k, l)$ are provided to the motion compensated predictor. The MBSA and the motion vectors are also provided to the channel encoder for encoding and transmission. The MBSA decision contained in the P, Q and R registers can be further compressed to fewer bits for transmission using variable length coding techniques or various other techniques. The motion vectors in the composite motion block can also be compressed and encoded for transmission. This compression is possible because the motion vectors in the adjacent blocks tend to be highly correlated, except near motion discontinuities. Given the composite motion vector block (CMV) above, the motion compensated predictor reads from the reference frame data stored in the frame buffer. The read address is generated by offsetting the current pixel address by the motion vector (m<sub>x</sub>,m<sub>x</sub>), and responsive to the block size assignment data for selecting the size of the pixel block from the reference frame. An exemplary implementation of the motion compensated predictor is illustrated in FIG. 9. The composite motion vector and the motion block assignment data are provided to the block selector 120. In response, to each of the motion vectors of the composite motion vector the block selector locates a block of pixel data from the reference frame of pixel data, and in response to the block size assignment data the block selector selects the size of the pixel block from the reference frame of data. The selected blocks of pixel data are provided to a block combiner 122 that orders the block of pixel data in the original frame format. The ordered pixel data is then presented to a pixel block buffer 124 that buffers the ordered pixel data so as to provide a complete frame of pixel data to summer 22 (FiG. 1). Let (k, 1) be the current pixel address of the current frame. In order to generate the prediction pixel I(k, 1, t) from the reference frame I<sub>p</sub>(k, 1, t) stored in the frame buffer, the address (k, 1) is offset by (m<sub>p</sub>m<sub>p</sub>) that is given by the 15 composite motion vector block. This predicted pixel data is provided to summer 22. The predicted pixel data intensity function is subtracted from the imput pixel data intensity function to provide the displaced frame difference (DFD) which is calculated by the equation: where $\tilde{I}(x, y, t)$ is the prediction picture generated by the motion compensated predictor as above. The displaced frame difference (DFD) is encoded and 30 transmitted along with the composite motion vector. The transmission of the DFD requires fewer bits than the original frame of data, because of its lower energy content. The transmission of the DFD information and the composite motion vector in place of the encoded frame of data represents a significant compression of data. The previous description of the preferred embodiments is provided to enable any person skilled in the art to make or use the present invention. The various modifications to these embodiments will be readily apparent to those skilled in the 40 art, and the generic principles defined herein may be applied to other embodiments without the use of the inventive faculty. Thus, the present invention is not intended to be limited to the embodiments shown herein but is to be accorded the widest scope consistent with the principles and 45 novel features disclosed herein. We claim: - 1. An interframe video compression system comprising: - a first motion predictor having an input for receiving a block of pixel data and having an output for providing <sup>50</sup> a first image prediction; - a first distortion calculator having a first input for receiving said block of pixel data and having a second input for receiving said first image prediction and having an output for providing a first distortion value; - at least one additional motion predictor provided in parallel with said first motion predictor having an input for receiving said block of pixel data and having an output for providing additional image predictions; - a second distortion calculator having a first input for receiving said block of pixel data and having a second input for receiving said additional image predictions and having a first output for providing a second distortion value: - an encoding format selector having a first input coupled to asid first distortion calculator output and having a 12 second input coupled to said second distortion calculator output and having an output for providing a selected encoding format; and encoder having a first input coupled to said encoding format selector output and having an output for providing a selectively encoded residual frame, having a second input for receiving a first displaced frame difference generated in accordance with said first image prediction and having a third input for receiving a second displaced frame difference generated in accordance with said second image prediction and for selectively encoding said first displaced frame difference and said second displaced frame difference in accordance with said selected encoding format. The system of claim 1 wherein said first motion predictor compares an NoA block of pixel data, where N is an integer, with NoA blocks of pixel data in a first reference block of data. 3. The system of claim 2 wherein said first motion predictor compares a 32x32 block of pixel data with 32x32 blocks of pixel data in a first reference block of data. 4. The system of claim 2 wherein said at least one additional motion predictor compares N/2cN/2 sub-blocks of pixel data with N/2cN/2 sub-blocks of data in said additional reference blocks of data. The system of claim 1 wherein said first motion predictor has a second input for receiving a first reference block of data comprising pixel data from a previous frame of pixel data. 6. The system of claim 1 wherein said first motion predictor has a second input for receiving a combination block of data determined in accordance with previous frames of pixel data. The system of claim 1 wherein said first motion predictor has a second output for providing a first motion vector. The system of claim 1 wherein said at least one additional motion predictor has a second output for providing additional motion vectors. The system of cizim I further comprising a weighting value multiplier disposed between said first distortion calculator and said encoding format selector. 10. An interframe video compression system comprising: first motion compensation means for receiving a block of video data and for comparing said block of video data with blocks of pixel data of a first block size to provide displaced frame difference (DFD) blocks, and for measuring distortion values for said DFD blocks, and for selecting a most similar block of pixel data of said first block size in accordance with said distortion values for said DFD blocks to provide a first motion vector, a first DFD block and a first distortion value; additional motion compensation means for receiving said block of video data and for comparing said block of video data with a plurality blocks of pixel data of a second block size to provide second DFD blocks, and for measuring distortion values for said second DFD blocks, and for selecting a set of most similar block of pixel data of said second block size in secondmee with said distortion values for said second DFD blocks to provide a set of additional motion vectors, a set of additional second DFD blocks, and a second distortion value: decision means for comparing said first distortion value and said second distortion value and for selecting an encoding format in accordance with said comparison; encoding means for selectively encoding said first motion vector and said first DFD block and said set of additional motion vectors and said second DFD blocks in accordance with said selected encoding format. 11. The system of claim 10 wherein said block of video 5 data is an NxN block where N is an integer, and wherein said first block size is NxN. 12. The system of claim 11 wherein said block of video data is a 32x32 block and wherein first block size is 32x32. 13. The system of claim 11 wherein said second block size 10 is N/2=N/2. 14. The system of claim 10 wherein said blocks of pixel data of a first block size comprise pixel data from a previous frame of pixel data. 15. The system of claim 10 wherein said blocks of pixel 15 data of a first block size are combinations of pixel data from previous frames of pixel data. 16. The system of claim 10 wherein said decision means performs said comparison responsive to a weighting format. 17. The system of claim 10 further comprising a weighting means for receiving said additional distortion value by a predetermined weighting format. 18. An interframe video compression method for compressing a block of video data comprising the steps of: comparing said block of video data with blocks of pixel <sup>25</sup> data of a first block size to provide displaced frame difference (DFD) blocks; measuring distortion values for said DFD blocks; selecting a most similar block of pixel data of said first block size in accordance with said distortion values to provide a first motion vector, a first DFD block and a first distortion value; 14 comparing said block of video data with a plurality blocks of pixel data of a second block size to provide additional DFD blocks; measuring distortion values for said DFD blocks; selecting a set of most similar block of pixel data of agid second block size in accordance with said distortion values for said additional DFD blocks to provide a set of additional motion vectors, a set of additional DFD blocks and a second distortion value; selecting an encoding format in accordance with said first distortion value and said second distortion value; and selectively encoding said first motion vector and said first DFD block and said set of additional motion vectors and said set of additional DFD blocks in accordance with said selected encoding format. 19. The method of claim 18 wherein said block of video data is an NNN block, where N is an integer, and wherein said first block size is NNN. 20. The method of claim 19 wherein said block of video data is a 32x32 block and wherein first block size is 32x32. 21. The method of claim 19 wherein said second block size is N/2AV/2. 22. The method of claim 18 wherein said blocks of pixel data of a first block size comprise pixel data from a previous frame of video data. 23. The method of claim 18 wherein said blocks of pixel data of a first block size are combinations of blocks of data from previous frames of video data. 24. The method of claim 18 further comprising the step of weighting said additional distortion value by a predetermined weighting format. . . . . . AO 120 (Rev.3/04) TO: Mail Stop 8 Director of the U.S. Patent and Trademark Office P.O. Box 1450 Alexandria, VA 22313-1450 # REPORT ON THE FILING OR DETERMINATION OF AN ACTION REGARDING A PATENT OR TRADEMARK In Compliance with 35 U.S.C. § 290 and/or 15 U.S.C. § 1116 you are hereby advised that a court action has been filed in the U.S. District Court San Diego on the following Patents or Trademarks: | | s occii fficu in the O.S. Di | that a court action has been filed in the U.S. District Court San Diego on the following Patents or Trademarks: | | | | | | | | |-------------------------------------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--| | DOCKET NO. | DATE FILED | U.S. DISTRICT COURT | | | | | | | | | 05cv1958 IEG(NLS) | 10/14/05 | United States District Court, Southern District of California | | | | | | | | | PLAINTIFF | | DEFENDANT | | | | | | | | | Qualcomm Inc | | Broadcom Corp | | | | | | | | | PATENT OR DATE OF PATENT OR TRADEMARK NO. | | HOLDER OF PATENT OR TRADEMARK | | | | | | | | | 1 5,452,104 | 09/19/95 | Qualcomm Inc | | | | | | | | | 25,576,767 | 11/19/96 | Qualcomm Inc | | | | | | | | | 3 | | | | | | | | | | | 4 | | | | | | | | | | | 5 | | | | | | | | | | | In the a | bove-entitled case, the fol | llowing patent(s)/trademark(s) have been included: | | | | | | | | | DATE INCLUDED | INCLUDED BY Amendment | Answer Cross Bill Other Pleading | | | | | | | | | PATENT OR<br>TRADEMARK NO. | DATE OF PATENT<br>OR TRADEMARK | HOLDER OF PATENT OR TRADEMARK | | | | | | | | | i | | | | | | | | | | | 1 | | | | | | | | | | | 2 | | | | | | | | | | | | | | | | | | | | | | 2 | | | | | | | | | | | 3 | | | | | | | | | | | 2<br>3<br>4<br>5 | ve-entitled case, the follo | wing decision has been rendered or judgment issued: | | | | | | | | | 2<br>3<br>4<br>5 | ve-entitled case, the follo | wing decision has been rendered or judgment issued: | | | | | | | | | 2<br>3<br>4<br>5<br>In the abo | ve-entitled case, the follo | wing decision has been rendered or judgment issued: | | | | | | | | | 2<br>3<br>4<br>5<br>In the abo | ve-entitled case, the follo | wing decision has been rendered or judgment issued: | | | | | | | | | 2<br>3<br>4<br>5<br>In the abo | ve-entitled case, the follo | wing decision has been rendered or judgment issued: | | | | | | | | Copy 1 - Upon initiation of action, mail this copy to Director Copy 3 - Upon termination of action, mail this copy to Director Copy 2 - Upon filing document adding patent(s), mail this copy to Director Copy 4 - Case file copy ### OJS 44 (Rev. 11/04) ### **CIVIL COVER SHEET** The IS 44 civil cover sheet and the information contained herein neither replace nor supplement the filing and service of pleadings or other papers as required by law, except as provided by local rules of court. This form, approved by the Judicial Conference of the United States in September 1974, is required for the use of the Clerk of Court for the purpose of initiating | the civil docket sheet. (SEE INST | TRUCTIONS ON THE REVERS | E OF THE FC | DRM.) | | | | | | | | |------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|----------------|--------------------------------------------|-------------------------------------------------------------------------------------------|-----------------------------------------------|----------------------| | I. (a) PLAINTIFFS QUALCOMM Incorporated | | | DEFENDA<br>Broadcom C | | on | | C2 OC | 7 L | Pi; 4: 01 | | | Quithounia monton | | | | | | | | | | | | (b) County of Residence of First Listed Plaintiff San Diego (EXCEPT IN U.S. PLAINTIFF CASES) | | | | County of Residence of First Listed Orange County (IN U.S. PLAINTIFF CASES ONLY) NOTE: IN LAND CONDEMNATION CASES, USE THE LOCATION OF THE LAND INVOLVED. | | | | | | | | (c) Attorney's (Firm Nam<br>James R. Batchelder (CSE | ne, Address, and Telephone Num<br>3, #136347) | iber) | | Attorneys (If K | nown) | | | | | | | Day Casebeer Madrid & F | | | | Í | | | | | | | | 20300 Stevens Creek Blv | d., Suite 400 | | | Ì. | | 4 0 | - ATTI | (1 | и с | | | Cupertino, CA 95014 | | | | 105 | CV | 19 | 58 leu | U | NLS, | | | (408) 873-0110<br>II. BASIS OF JURISDI | CTION (Place an "X" in One Bo | x Only) | III. C | <u> </u> | | | AL PARTIES ( | Place an "X" | in One Ro | s for Plaintiff | | 2 | | ,, | | (For Diversity C | ases Only) | ) | ·· | and One Box | for Defen | dant) | | U.S. Government Plaintiff | 3 Federal Question<br>(U.S. Government Not a Par | ty) | Cit | izen of This State | <b>₽11</b><br>□ 1 | DEF<br>[] I | Incorporated or Princ<br>of Business In Ti | | <b>₽ТТ</b> | DEF | | 2 U.S. Government Defendant | 4 Diversity<br>(Indicate Citizenship of Partic | s in Item III) | Cit | izen of Another Stat | <b>2</b> | <b>□</b> 2 | Incorporated and Prin<br>of Business In A | | O 5 | <b>5</b> | | | | | | izen or Subject of a<br>Foreign Country | □ 3 | □ 3 | Foreign Nation | | □ 6 | □ 6 | | IV. NATURE OF SUIT | (Place an "X" in One Box Only) | | | | | | | | | | | CONTRACT | PERSONAL INJURY P | ERSONAL IN | | FORFETTURE/ | | _ | Appeal 28 USC 158 | | ER STA | | | 120 Marine<br> 130 Miller Act<br> 140 Negotiable Instrument<br> 150 Recovery of Overpayment | 310 Airplane 362 Personal Ir 315 Airplane Product Med. Maly Liability 365 Personal Ir 320 Assault, Libel & Product Li | | jury—<br>ractice<br>jury —<br>bility | 620 Other Food & Drug 625 Drug Related Seizure of Property 21 USC \$8 | | 423 | Withdrawal<br>28 USC 157<br>PERTY RIGHTS | 400 State Reapportionment 410 Autimust 430 Banks and Banking 450 Commerce 460 Deportation | | | | & Enforcement of Judgment 151 Medicare Act | 330 Federal Employers | 68 Asbestos Pr<br>Injury Prod | | 640 R.R. & True | L. | | Copyrights<br>Patent | | upt Organ | izations | | 152 Recovery of Defaulted<br>Student Loans | Liability 340 Marine PE | Liability<br>RSONAL PRO | PERTY | 660 Occupation Safety/Heal | | | Trademark | 490 Cabi | | | | (Excl. Veterans) 153 Recovery of Overpayment | | 70 Other Fraud<br>171 Truth in Le | • [ | 690 Other | <del></del> _ | - | Car and Car and Sanda I | 810 Sele<br>850 Sect | | | | of Veteran's Benefits 160 Stockholders' Suits | | 80 Other Perso | ma1 Term | LABO | | | HIA (1395ff) | Exc. | hange<br>somer Chal | ilenge | | ☐ 190 Other Contract ☐ 195 Contract Product Liability | | Property Da<br>85 Property Da | emege | Act 720 Labor/Mgm | | <b>562</b> | Black Lung (923)<br>DIWC/DIWW (405(g) | 12 t | JSC 3410 | | | PEAL PROPERTY | | Product Lis | | 730 Labor/Mgrz | L Reporting | <b>1</b> 2 864 | SSID Title XVI<br>RSI (405(g)) | Î∏891 Agri | cultural A | | | 210 Land Condemnation | <del> </del> | SONER PET | | 740 Railway La | bor Act | <b> </b> | K31 (402( <u>1</u> )) | | rouncual | Matters | | 220 Foreclosure<br>230 Rent Lease & Ejectment | 442 Employment | Sentence<br>Inbens Corpus | | 790 Other Labor 791 Empl. Ret. 1 | nc. | FED: | ERAL TAX SUITS | ■895 Free | does of h | non Act<br>formation | | 240 Torts to Land | Accommodations 5 | 30 General | · | Security A | :1 | 870 | Taxes (U.S. Plaintiff<br>or Defendant) | — Act<br>☐900Appe | al of Fee I | Determination | | 245 Tort Product Liability 290 All Other Real Property | 445 Amer. w/Disabilities - 5 | 35 Death Pena<br>40 Mandamus | & Other | | | □ \$71 | IRS—Third Party | Und | ler Equal A<br>ustice | locess | | | | i 50 Civil Right<br>i 55 Prison Con | | | | | 26 USC 7609 | ☐950 Con | | ty of | | | Other 440 Other Civil Rights | | | | | | | 3.44 | : Junue) | | | □ | in One Box Only) | | 4 Reinstat<br>Reopen | ed or 🔲 5 ano | sferred fro<br>ther distric<br>cify) | | 6 Multidistrict Litigation | ☐ 7 Ju<br>M | opeal to D<br>dge from<br>agistrate<br>dgment | | | | Cite the U.S. Civil Statute | | you are fi | ling (Do not cite | jurisdicti | onal sta | tutes unless diversi | ly): | | | | VI. CAUSE OF ACTIO | N 35 U.S.C Sections 27 Brief description of cause | | | | | | | | | <del></del> | | | Patent Infringement | • | | | | | | | | | | VII. REQUESTED IN COMPLAINT: | CHECK IF THIS IS A CUNDER F.R.C.P. 23 | LASS ACTI | ON D | EMAND S | | | CHECK YES<br>JURY DEM | • | nanded in<br>⊠Yes | | | VIII. RELATED CASE IF ANY | (See distructions): | E Brewster | | | <u> </u> | DOCK | ET NUMBER CV | 05-1392 E | B (BLM | 0 | | FOR OFFICE USE ONLY | _ Qun h | IGN | FATTOR | NEY OF RECORD | | | _ <del></del> · | | | | | | | YING IFP | · | J JUDGE _ | | | MAG. JUDGE | | | | | | 117974 | \$250 | ) <sub>00</sub> | hV | | | American Le | gatNet, Inc. | ww.USCo | unt-orms.com | | | ( ) · · | | | | | | | | | | cn