1. Field of the Invention
This invention relates to data compression, specifically to the compression and decompression of video images.
2. Description of Prior Art
In the last few years, there have been tremendous advances in the speed of computer processors and in the availability of bandwidth of worldwide computer networks such as the Internet. These advances have led to a point where businesses and households now commonly have both the computing power and network connectivity necessary to have point-to-point digital communications of audio, rich graphical images, and video. However the transmission of video signals with the full resolution and quality of television is still out of reach. In order to achieve an acceptable level of video quality, the video signal must be compressed significantly without losing either spatial or temporal quality.
A number of different approaches have been taken but each has resulted in less than acceptable results. These approaches and their disadvantages are disclosed by Mark Nelson in a book entitled The Data Compression Book, Second Edition, published by M&T Book in 1996. Mark Morrision also discusses the state of the art in a book entitled The Magic of Image Processing, published by Sams Publishing in 1993.
Video Signals
Standard video signals are analog in nature. In the United States, television signals contain 525 scan lines of which 480 lines are visible on most televisions. The video signal represents a continuous stream of still images, also known as frames, which are fully scanned, transmitted and displayed at a rate of 30 frames per second. This frame rate is considered full motion.
A television screen has a 4:3 aspect ratio.
When an analog video signal is digitized, each of the 480 lines is sampled 640 times, and each sample is represented by a number. Each sample point is called a picture element, or pixel. A two dimensional array is created that is 640 pixels wide and 480 pixels high. This 640×480 pixel array is a still graphical image that is considered to be full frame. The human eye can perceive 16.7 thousand colors. A pixel value comprised of 24 bits can represent each perceivable color. A graphical image made up of 24-bit pixels is considered to be full color. A single, second-long, full frame, full color video requires over 220 millions bits of data.
The transmission of 640×480 pixels×24 bits per pixel times 30 frames requires the transmission of 221,184,000 million bits per second. A T1 Internet connection can transfer up to 1.54 million bits per second. A high-speed (56 Kb) modem can transfer data at a maximum rate of 56 thousand bits per second. The transfer of full motion, full frame, full color digital video over a T1 Internet connection, or 56 Kb modem, will require an effective data compression of over 144: 1, or 3949:1, respectively.
A video signal typically will contain some signal noise. In the case where the image is generated based on sampled data, such as an ultrasound machine, there is often noise and artificial spikes in the signal. A video signal recorded on magnetic tape may have fluctuations due the irregularities in the recording media. Florescent or improper lighting may cause a solid background to flicker or appear grainy. Such noise exists in the real world but may reduce the quality of the perceived image and lower the compression ratio that could be achieved by conventional methods.
Basic Run-length Encoding
An early technique for data compression is run-length encoding where a repeated series of items are replaced with one sample item and a count for the number of times the sample repeats. Prior art shows run-length encoding of both individual bits and bytes. These simple approaches by themselves have failed to achieve the necessary compression ratios.
Variable Length Encoding
In the late 1940s, Claude Shannon at Bell Labs and R. M. Fano at MIT pioneered the field of data compression. Their work resulted in a technique of using variable length codes where codes with low probabilities have more bits, and codes with higher probabilities have fewer bits. This approach requires multiple passes through the data to determine code probability and then to encode the data. This approach also has failed to achieve the necessary compression ratios.
D. A. Huffman disclosed a more efficient approach of variable length encoding known as Huffman coding in a paper entitled “A Method for Construction of Minimum Redundancy Codes,” published in 1952. This approach also has failed to achieve the necessary compression ratios.
Arithmetic, Finite Context, and Adaptive Coding
In the 1980s, arithmetic, finite coding, and adaptive coding have provided a slight improvement over the earlier methods. These approaches require extensive computer processing and have failed to achieve the necessary compression ratios.
Dictionary-Based Compression
Dictionary-based compression uses a completely different method to compress data. Variable length strings of symbols are encoded as single tokens. The tokens form an index to a dictionary. In 1977, Abraham Lempel and Jacob Ziv published a paper entitled, “A Universal Algorithm for Sequential Data Compression” in IEEE Transactions on Information Theory, which disclosed a compression technique commonly known as LZ77. The same authors published a 1978 sequel entitled, “Compression of Individual Sequences via Variable-Rate Coding,” which disclosed a compression technique commonly known as LZ78 (see U.S. Pat. No. 4,464,650). Terry Welch published an article entitled, “A Technique for High-Performance Data Compression,” in the June 1984 issue of IEEE Computer, which disclosed an algorithm commonly known as LZW, which is the basis for the GIF algorithm (see U.S. Pat. Nos. 4,558,302, 4,814,746, and 4,876,541). In 1989, Stack Electronics implemented a LZ77 based method called QIC-122 (see U.S. Pat. No. 5,532,694, U.S. Pat. No. 5,506,580, and U.S. Pat. No. 5,463,390).
These lossless (method where no data is lost) compression methods can achieve up to 10:1 compression ratios on graphic images typical of a video image. While these dictionary-based algorithms are popular, these approaches require extensive computer processing and have failed to achieve the necessary compression ratios.
JPEG and MPEG
Graphical images have an advantage over conventional computer data files: they can be slightly modified during the compression/decompression cycle without affecting the perceived quality on the part of the viewer. By allowing some loss of data, compression ratios of 25:1 have been achieved without major degradation of the perceived image. The Joint Photographic Experts Group (JPEG) has developed a standard for graphical image compression. The JPEG lossy (method where some data is lost) compression algorithm first divides the color image into three color planes and divides each plane into 8 by 8 blocks, and then the algorithm operates in three successive stages:
JPEG can be scaled to perform higher compression ratio by allowing more loss in the quantization stage of the compression. However this loss results in certain blocks of the image being compressed such that areas of the image have a blocky appearance and the edges of the 8 by 8 blocks become apparent because they no longer match the colors of their adjacent blocks. Another disadvantage of JPEG is smearing. The true edges in an image get blurred due to the lossy compression method.
The Moving Pictures Expert Group (MPEG) uses a combination of JPEG based techniques combined with forward and reverse temporal differencing. MPEG compares adjacent frames and, for those blocks that are identical to those in a previous or subsequent frame, only a description of the previous or subsequent identical block is encoded. MPEG suffers from the same blocking and smearing problems as JPEG.
These approaches require extensive computer processing and have failed to achieve the necessary compression ratios without unacceptable loss of image quality and artificially induced distortion.
QuickTime: CinePak, Sorensen, H.263
Apple Computer, Inc. released a component architecture for digital video compression and decompression, named QuickTime. Any number of methods can be encoded into a QuickTime compressor/decompressor (codec). Some popular codec are CinePak, Sorensen, and H.263. CinePak and Sorensen both require extensive computer processing to prepare a digital video sequence for playback in real time; neither can be used for live compression. H.263 compresses in real time but does so by sacrificing image quality resulting in severe blocking and smearing.
Fractal and Wavelet Compression
Extremely high compression ratios are achievable with fractal and wavelet compression algorithms. These approaches require extensive computer processing and generally cannot be completed in real time.
Sub-sampling
Sub-sampling is the selection of a subset of data from a larger set of data. For example, when every other pixel of every other row of a video image is selected, the resulting image has half the width and half the height. This is image sub-sampling. Other types of sub-sampling include frame sub-sampling, area sub-sampling, and bit-wise sub-sampling.
Image Stretching
If an image is to be enlarged but maintain the same number of pixels per inch, data must be filled in for the new pixels that are added. Various methods of stretching an image and filling in the new pixels to maintain image consistency are known in the art. Some methods known in the art are dithering (using adjacent colors that appear to be blended color), and error diffusion, “nearest neighbor”, bilinear and bicubic.
In accordance with the present invention a method of compression of a video stream comprises steps of sub-sampling a video frame, and run-length encoding the sub-sampled pixel values, whereby the method can be executed in real time and the compressed representation of pixels saves substantial space on a storage medium and requires substantially less time and bandwidth to be transported over a communications link. The present invention includes a corresponding method for decompressing the encoded data.
Objects and Advantages
Accordingly, beside the objects and advantages of the method described above, some additional objects and advantages of the present invention are:
In the drawings, closely related figures have the same number but different alphabetic suffixes.
FIG. 1—Compression and Decompression Steps
Video digitizing hardware typical has the options of storing the pixel values as a 32 bit pixel value 200 or a 24 bit pixel value 210, shown in
The 24-bit pixel value 210 is composed of a blue component 212, a green component 214, and a red component 216. There is no component for the alpha channel in the 24 bit pixel value 210. Regardless of the structure, the blue channel 202 is equivalent to the blue component 212, the green channel 204 is equivalent to the green component 214, and the red channel 206 is equivalent to the red component 216.
In the present invention, the 32 bit pixel value 200 alternative is preferred due to the consistent alignment of 32 bit values in most computer memories; however for simplicity of illustration the alpha channel 208 will be omitted in
If the video signal is digitized in color, the three color components may have different values. For example in
If the video signal being digitized is grayscale, the three color components will have the same values. For example in
The preferred embodiment of this invention uses the low order byte of the pixel value, which is typically the blue component as shown in
For additional compression, the filtered pixel value 299 can variably select any number of bits. For example, selection of the most significant four bits instead of all eight bits filters noise that may show up in the low order bits may be very suitable for an image such as one produced by an ultrasound medical device. An example of this is shown by ZL4804 in
FIGS. 3A and 3B—Encoding Formats
Speed of compression and decompression may be enhanced if the algorithms fit into computer memory native storage elements such as 8 bit bytes, 16 bit words, or 32 bit double words, or some other size for which the computer architecture is optimized.
A grayscale image may be stored at a higher bit level than the actual values require. This may occur when an image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar electronic technology. For example an ultrasound machine may only produce 16 levels of grayscale, requiring 4 bits of data per pixel, but the image digitizing may be performed at 8 to 12 bits per pixel. In this example, the low order bits (4 to 8) respectively provide no significant image data.
In the present invention, a fast and efficient compression and encoding method is implemented by using unused bits to store a repeat count for repeated values.
The most significant N bits of the pixel value are selected where N is the number of significant bits (determined by data analysis or by user selection). If N is less than W, where W is a native machine data type such as 8 bit byte, 16 bit word, or 32 bit double word or some other size for which the computer architecture is optimized, then W−N equals the number of unneeded bits, U. A repeat count, C, can contain a value from I to CMAX where CMA is 2 to the power of U. For example, if U equals 4, C can be a number from 1 to 16. In practice the maximum value will be encoded as a zero because the high order bit is truncated. In the example, decimal 16 has a binary value “10000” will be stored as “0000”.
For example, when W is 8, value pairs for N and U could include without limitation (2,6), (3,5), (4,4), (5,3), and (6,2). When W is 16, value pairs for N and U could include without limitation (2,14), (3,13), (4,12), (5,11), (6,10), (7, 9), (8, 8), (9, 7), (10, 6), (11, 5), (12, 4), (13, 3), and (14, 2). When W is 32, value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals 32 and N>1 and U>1. When W is not a multiple of 8, value pairs for N and U could include without limitation all combinations of values pairs for N and U where N+U equals W and N>1 and U>1.
Encoding
The most significant N bits of each pixel are selected from the image to obtain value V.
In the encryption embodiment of this invention V may be used to select an encoded value, E, from the encoding table. E is also a N-bit value. The number of elements in the encode table 1100 (
In the other embodiments of this invention V is used as E.
E is saved as the prior value, P. For each subsequent pixel, the encoded value, E, is obtained and compared to the prior value, P. If the prior value, P, is the same as E, then a repeat counter, C, is incremented; otherwise the accumulated repeat count, C, for the prior value, P, is merged with P and placed in an array A that implements the encoded data 140 (
FIG. 4A—Encode Flowchart
The encoding begins at an encode entry 402. In an encode initialization step 403, a prior value P is set to a known value, preferably decimal “255” or hexadecimal 0xFF, a repeat counter C is set to zero, an encoded length L is set to 0, and a completion flag “Done” is set to a logical value of false. Next, a get pixel step 404 obtains a pixel from the image being encoded. At a get value step 405, a value V is set to the N bit filtered pixel value 299 as derived from the pixel using one of the methods shown in
If the encode value E does not match the prior value P, then a check count overflow 412 decision is made. If the counter C is less than or equal to CMAX, then a new code step 414 is executed, otherwise a counter overflow step 420 is executed.
At step 414, the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing inside flowchart step 414, L is incremented, the repeat count C is set to 1 and the prior value P is set to E. After step 414, a “check end of data” decision is made by checking to see if there are any more pixels in the image, and, if not, if the last value has been processed. Because this method utilizes a read ahead technique step 414 must be executed one more time after the end of data is reached to process the last run-length. If there is more data in the image, flow continues to a check of the completion flag “Done” at step 422. If the check indicates that the process is not completed, flow continues to step 404.
If the end of data is reached but the completion flag “Done” is still false, flow continues to a set done step 418. At step 418, the completion flag “Done” is set to logical true, and flow continues to decision 412 where the last run-length will be output and flow will eventually exit through step 414, decision 416, decision 422, and then terminate at encode exit 428.
It is possible for the repeat count C to become larger than CMAX requiring more bits than allocated by this method. This situation is handled by making the “check count overflow” 412 decision and executing the “counter overflow” step 420. At step 420, the counter C is masked and bit-wise OR-ed with P shifted left by U bit positions and is placed in the A at the next available location as indexed by the encoded length L. Then, continuing inside flowchart step 414, L is incremented, and the repeat count C is decrement by CMAX. After step 420, flow continues to the “check count overflow” 412 decision. Thus when the encode value E repeats more than CMAX times, multiple sets of repeat counts and encoded values are output to the encoded data 140 buffer.
This entire process is repeated for each image or video frame selected during optional image sub-sampling (see 110 in
FIG. 4B—Image and Pixel Stream
Because the video signal being digitized is analog there will be some loss of information in the analog to digital conversion. The video digitizing hardware can be configured to sample the analog data into the image 430 with almost any width 440 and any height 450. The present invention achieves most of its effective compression by sub-sampling the data image with the width 440 value less than the conventional 640 and the height 450 value less than the convention 480. In a preferred embodiment of the invention, for use in a medical application with T1 Internet transmission bandwidth, image dimensions are sub-sampled at 320 by 240. However an image dimension sub-sampling resolution of 80 by 60 may be suitable for some video application.
FIGS. 5A to 5C—Run-length Encoding Formats of the RHN Method
In addition, the present invention provides for a larger count when the bit filtering is larger. For example, the alternate ZLN format where each byte contains 4 data bits, ZL4 (where N is 4 and U is 4), allows for a four bits of repeat count. For example, in practice, ZL4 is superior to RHN on a typical ultrasound image containing 16 shades of gray.
FIG. 6—Encoded Data Stream
FIG. 7—RHN Codes and Encoded Stream
The embodiment of the present invention shown in
FIGS. 8A and 8B—ZLN Formats
The ZLN method of the present invention provides for variable formats. The values of N 300, U 301, and W 302 can be dynamically changed between frames. For ease of communication a format is named with the prefix “ZL” and a digit representing the value of N. For example, “ZL5” refers to a format where bit width of N is equal to 5. There are multiple values of U depending of the W. To also specify the bit width of U a hyphen and a number can be appended. For example, “ZL5-13” represents a format where N=5 and U=13. “ZL5-3” is a common format and may be imprecisely referred to as “ZL5.”
Decoding
To decode the compressed array, the decoder has a decode table that corresponds with the encode table. For W*4 bit color pixels, the decode table contains the appropriate alpha, red, green, and blue values. For W*3 bit color pixels, the alpha value is not used. The compressed array is processed W bits at a time as X. The repeat count, C, is extracted from X by masking off the data value (C=X & (((2**N)−1)<<U)). The encoded value, E, is extracted from X by masking off the count (E=X & ((2**U)−1)). The encoded value, E maybe used to index into the decryption. The decoded pixels are placed in a reconstructed image and repeated C times. Each element of the compressed array, A, is processed until its entire length, L, has been processed.
FIG. 9—Decode Flowchart
The decoding begins at a decode entry 900. In a “decode initialization” step 901, a repeat counter C is set to one, an encoded length L is set to the value obtained with the encoded data 140 (
valueMask=−1<<U;
countMask=˜valueMask;
In this illustrative decryption embodiment of the present invention, flow goes to a “decode lookup” step 908 where the value of E is used to index into the decode table 1110 (
The 909 decision always fails the first time ensuring that a place pixel step 910 is executed. The place pixel step 910 places the pixel value V in the next location of the decompressed image and decrements the repeat counter C and returns to the 909 decision. The pixel value V is placed repeatedly until C decrements to zero. Then the 909 decision branches flow to a “reset counter” step 914. At step 914 the repeat counter is reset to 1.
Flow continues to the “check length” 916 decision where the index I is compared to the encoded length L to determine if there are more codes to be processed. If I is less than L flow returns to step 902, otherwise the decode process terminates at a “decode exit” 918.
The entire decode process is repeated for each encoded frame image.
FIG. 10—Interpolation
Pixels 1052, 1054, 1056, 1058 and 1060 are inserted due to the enlargement of the image. Their values are calculated by averaging the values of the two pixels above and below or to the left or the right of the new pixel. A preferred sequence is calculation of:
1. 1052 between 1010 and 1012
2. 1054 between 1010 and 1014
3. 1058 between 1012 and 1016
4. 1056 between 1054 and 1058
Pixel 1060 can be calculated on the interpolation for the subsequent row.
FIG. 11—Encryption
By using corresponding encoding and decoding tables the data can be encrypted and decrypted without using actual values. Encryption provides a level of security for the encoded data 140 while in storage or transit.
The encode table 1100 is 2 the power of N in length. If the target color image format is W*4 bit color, then the decode table 1110 has W bits for alpha, red, green, and blue each, respectively. If the target color image format is W*3 bit color, then the alpha value is not used. If the image is W bit grayscale then only the grayscale value is used to create the decompressed and decoded image.
The corresponding table elements are mapped to each other. For example, 0 could encode to 22 as long as the 22nd element of the decode table returns (øxff <<24|ø<<16|ø<<8|ø).
When these versions of the tables are used, the encode and decode processes and their speed of execution are substantially the same but the encoded data 140 (
FIGS. 12A through 12D—Compression and Decompression Devices
FIGS. 13A through 13J—Compressor Details, Encoding Circuit, and Bitwise Pixel Sub-Samplers
FIGS. 14A through 14C—Variable Selection of Bit-wise Sub-sampling
Likewise,
FIG. 15—Decompressor Elements
FIGS. 16A and 16B—Parameters Altered by a Remote Receiver
The settings 1660 include brightness 1661, contrast 1662, height 1663, width 1664, and frame rate 1665. The brightness 1661, contrast 1662, height 1663, and width 1664 setting alter the attributes of each frame as it is digitized in a frame sub-sampler 1620. The brightness 1661 and contrast 1662 settings alter the video digitizer 1310 (
The frame sub-sampler 1620 outputs a selected frame 1630 along path 1621. The transmitter pixel sub-sampler 1640 scans the selected frame 1630 getting each pixel from frame 1632 and outputs data values along path 1642 to a run length encoder 1650. The encoded data stream 1235 is then transmitted to the remote receiver 1610.
These embodiments illustrate the novel feature of the present invention of allowing a user at a remote receiver 1610 to control aspects of the transmitter 1600 or 1690 from a remote location, including brightness, contrast, frame dimensions, frame rate, image area, and the type of compression used.
FIG. 17—Further Lossless Compression Step
FIG. 18—Image Stretching
Advantages
Noise Filtering and Image Enhancement
The removal of the least significant bits of pixel values results in high quality decompressed images when the original image is generated by an electronic sensing device, such as an ultrasound machine, which is generating only a certain number of bits of grayscale resolution. By variably altering the number of most significant bits, various filters can be implemented to enhance the image quality. Such a noise filter can be beneficial when the image is generated by an imaging technology such as radar, ultrasound, x-ray, magnetic resonance, or similar technology. Variations can be made to enhance the perceived quality of the decompressed image. Therefore, altering the number of data bits selected and altering the width of the repeat count is anticipated by this invention and specific values in the examples should not be construed as limiting the scope of this invention.
Dynamic Variable Formats
While a video stream is being viewed a viewer on the decoding end of the transmission can vary the settings for the compressor. Different tradeoffs between image spatial and temporal quality can be made. As the contents of the video signal change an appropriate format can be selected. Control signals can be sent back to the compressor via a communications link.
Execution Speed
The preferred embodiment of this invention uses a number of techniques to reduce the time required to compress and decompress the data.
The methods require only a single sequential pass through the data. Both the compression steps 100 and the decompression steps 150 access a pixel once and perform all calculations.
When selecting the filtered pixel value 299, the preferred embodiment selects the low order byte from the 32 bit pixel value 200 or the 24 bit pixel value 210 so that an additional shift operation or addressing operation is avoided.
The shift operation is a fast and efficient way to convert a byte or word to the filtered pixel value 299.
General Purpose
The lossless compression of the sampled data achieved by the preferred embodiment of the present invention results in high quality video streams that have general purpose application in a number of areas including, without limitation, video conferencing, surveillance, manufacturing, rich media advertising, and other forms of video transmission, storage, and processing.
Lossless Nature/No Artifacts
Once the analog signal is sub-sampled and filtered to select a filtered pixel value that eliminates some of the real world defects, the methods of the present invention compress and decompress the data with no irreversible data loss. Unlike JPEG and MPEG, the decompressed image never suffers from artificially induced blocking or smearing or other artifacts that are result of the lossy compression algorithm itself. As a result even a small sub-sample of the image remains clear and true to the perceived quality of the original image.
Superior Features over RHN Format
When compared against the RHN format, the format and methods of the present invention provide a number of advantages, including, but not limited to, faster speed and smaller size of encoded data, better performance for both medical and typical video images, and a typically closer representation of the original video signal.
Conclusion, Ramification, and Scope
Accordingly, the reader will see that the compression and decompression steps of the present invention provides a means of digitally compressing a video signal in real time, communicating the encoded data stream over a transmission channel, and decoding each frame and displaying the decompressed video frames in real time.
Furthermore, the present invention has additional advantages in that:
Although the descriptions above contain many specifics, these should not be construed as limiting the scope of the invention but as merely providing illustrations of some of the preferred embodiments of this invention. For example, bit ordering can be altered and the same relative operation, relative performance, and relative perceived image quality will result. Also, these processes can each be implemented as a hardware apparatus that will improve the performance significantly.
Thus the scope of the invention should be determined by the appended claims and their legal equivalents, and not solely by the examples given.
This application is a continuation of U.S. patent application Ser. No. 09/467,721, filed on Dec. 20, 1999, entitled “VARIABLE GENERAL PURPOSE COMPRESSION FOR VIDEO IMAGES (ZLN)”, now U.S. Pat. No. 7,233,619, which hereby is incorporated by reference. This application and application Ser. No. 09/467,721 claim priority under 35 U.S.C. §119(e) of U.S. provisional application Ser. No. 60/113,051, filed on Dec. 21, 1998, and entitled “METHODS OF ZERO LOSS (ZL) COMPRESSION AND ENCODING OF GRAYSCALE IMAGES”, which hereby is incorporated by reference. A continuation in part of application Ser. No. 09/467,721, entitled “Handheld Video Transmission and Display,” application Ser. No. 11/262,106, was published as U.S. publication 2006/0114987. My U.S. patent application Ser. No. 09/470,566, filed on Dec. 22, 1999, and entitled GENERAL PURPOSE COMPRESSION FOR VIDEO IMAGES (RHN)”, known as the “RHN” method, now U.S. Pat. No. 7,016,417, hereby is incorporated by reference. The RHN application claims a priority date based on a U.S. provisional application Ser. No. 60/113,276 filed on Dec. 23, 1998, which also hereby is incorporated by reference. My U.S. patent application Ser. No. 90/312,922, filed on May 17, 1999, entitled “SYSTEM FOR TRANSMITTING VIDEO IMAGES OVER A COMPUTER NETWORK TO A REMOTE RECEIVER” describes an embodiment of the invention of the RHN method, as well as a system for practicing the compression method, and also hereby is incorporated by reference. My U.S. patent application, Ser. No. 09/473,190, filed on Dec. 20, 1999, entitled “ADDING DOPPLER ENHANCEMENT TO GRAY SCALE COMPRESSION (ZLD)” describes an invention that is related to this application, and also hereby is incorporated by reference.
Number | Name | Date | Kind |
---|---|---|---|
4301469 | Modeen et al. | Nov 1981 | A |
4302775 | Widergren et al. | Nov 1981 | A |
4385363 | Widergren et al. | May 1983 | A |
4394774 | Widergren et al. | Jul 1983 | A |
4410916 | Pratt et al. | Oct 1983 | A |
4546385 | Anastassiou | Oct 1985 | A |
4550437 | Kobayashi et al. | Oct 1985 | A |
4646356 | Anderson et al. | Feb 1987 | A |
4698672 | Chen et al. | Oct 1987 | A |
4704628 | Chen et al. | Nov 1987 | A |
4743959 | Frederiksen | May 1988 | A |
5014710 | Maslak et al. | May 1991 | A |
5046027 | Taaffe et al. | Sep 1991 | A |
5047853 | Hoffert et al. | Sep 1991 | A |
5271072 | Yoshida et al. | Dec 1993 | A |
5287452 | Newman | Feb 1994 | A |
5309232 | Hartung et al. | May 1994 | A |
5339392 | Risberg et al. | Aug 1994 | A |
5416602 | Inga et al. | May 1995 | A |
5471989 | Roundhill et al. | Dec 1995 | A |
5552832 | Astle | Sep 1996 | A |
5581613 | Nagashima et al. | Dec 1996 | A |
5583561 | Baker et al. | Dec 1996 | A |
5586196 | Sussman | Dec 1996 | A |
5619995 | Lobodzinski | Apr 1997 | A |
5621660 | Chaddha et al. | Apr 1997 | A |
5646618 | Walsh | Jul 1997 | A |
5684968 | Flurry | Nov 1997 | A |
5696940 | Liu et al. | Dec 1997 | A |
5715823 | Wood et al. | Feb 1998 | A |
5721815 | Ottesen et al. | Feb 1998 | A |
5754820 | Yamagami | May 1998 | A |
5794072 | Nomura et al. | Aug 1998 | A |
5809145 | Slik et al. | Sep 1998 | A |
5812119 | Tateyama | Sep 1998 | A |
5812788 | Agarwal | Sep 1998 | A |
5828856 | Bowes et al. | Oct 1998 | A |
5860068 | Cook | Jan 1999 | A |
5882206 | Gillio | Mar 1999 | A |
5897498 | Canfield, II et al. | Apr 1999 | A |
5920317 | McDonald | Jul 1999 | A |
5959639 | Wada | Sep 1999 | A |
5966728 | Amini et al. | Oct 1999 | A |
5973750 | Ogawa et al. | Oct 1999 | A |
5999655 | Kalker et al. | Dec 1999 | A |
6005979 | Chang et al. | Dec 1999 | A |
6009346 | Ostrow | Dec 1999 | A |
6018713 | Coli et al. | Jan 2000 | A |
6025854 | Hinz et al. | Feb 2000 | A |
6054990 | Tran | Apr 2000 | A |
6058215 | Schwartz et al. | May 2000 | A |
6063032 | Grundwald | May 2000 | A |
6064324 | Shimizu et al. | May 2000 | A |
6078691 | Luttmer | Jun 2000 | A |
6084598 | Chekerylla | Jul 2000 | A |
6091777 | Guetz et al. | Jul 2000 | A |
6115485 | Dumoulin et al. | Sep 2000 | A |
6144392 | Rogers | Nov 2000 | A |
6181711 | Zhang et al. | Jan 2001 | B1 |
6219358 | Pinder et al. | Apr 2001 | B1 |
6230241 | McKenney | May 2001 | B1 |
6324599 | Zhou et al. | Nov 2001 | B1 |
6335990 | Chen et al. | Jan 2002 | B1 |
6338119 | Anderson et al. | Jan 2002 | B1 |
6339616 | Kovalev | Jan 2002 | B1 |
6384862 | Brusewitz et al. | May 2002 | B1 |
6571392 | Zigmond et al. | May 2003 | B1 |
6574278 | McVeigh et al. | Jun 2003 | B1 |
6592629 | Cullen et al. | Jul 2003 | B1 |
6621933 | Chung et al. | Sep 2003 | B2 |
6651113 | Grimsrud | Nov 2003 | B1 |
7016417 | Roman et al. | Mar 2006 | B1 |
7257158 | Figuredo et al. | Aug 2007 | B1 |
7308413 | Tota et al. | Dec 2007 | B1 |
20070223574 | Roman et al. | Sep 2007 | A1 |
Number | Date | Country |
---|---|---|
9959472 | Nov 1999 | WO |
0055791 | Sep 2000 | WO |
Number | Date | Country | |
---|---|---|---|
20100034287 A1 | Feb 2010 | US |
Number | Date | Country | |
---|---|---|---|
60113051 | Dec 1998 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09467721 | Dec 1999 | US |
Child | 11638989 | US |