USRE41569E1 - Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo - Google Patents
Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo Download PDFInfo
- Publication number
- USRE41569E1 USRE41569E1 US12/000,338 US33807A USRE41569E US RE41569 E1 USRE41569 E1 US RE41569E1 US 33807 A US33807 A US 33807A US RE41569 E USRE41569 E US RE41569E
- Authority
- US
- United States
- Prior art keywords
- data
- blocks
- fifo memory
- compressed data
- fifo
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/436—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation using parallelised computational arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/42—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation
- H04N19/423—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by implementation details or hardware specially adapted for video compression or decompression, e.g. dedicated software implementation characterised by memory arrangements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/44—Decoders specially adapted therefor, e.g. video decoders which are asymmetric with respect to the encoder
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/46—Embedding additional information in the video signal during the compression process
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/13—Adaptive entropy coding, e.g. adaptive variable length coding [AVLC] or context adaptive binary arithmetic coding [CABAC]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/90—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using coding techniques not provided for in groups H04N19/10-H04N19/85, e.g. fractals
- H04N19/91—Entropy coding, e.g. variable length coding [VLC] or arithmetic coding
Definitions
- This invention relates in general to data processing systems and in particular to a video data recovery and expansion system for use in connection with a digital high definition television system.
- the recently tested high definition television sysem of Zenith Electronics Corporation and AT&T Corporation includes a video compression scheme for compressing 37 MHz information for transmission over a 6 MHz wide television channel.
- U.S. Pat. No. 5,285,276 describes a temporally oriented video compression system in which compressed video information is transmitted in the form of motion vectors and difference signals with the motion vectors identifying previous portions of a frame of video that closely match the current portion and the difference signals representing the differences between the previous and current portions.
- the video information has a bandwidth of about 37 MHz and may comprise a progressively scanned video signal in the form of successive frames of binary video data having a vertical periodicity equal to the NTSC standard (i.e. about 59.4 Hz) and a horizontal periodicity equal to three times the NTSC standard (i.e. about 47.25 KHz).
- the data is in the form of a series stream of binary pixel values that have been transform coded in the frequency domain to develop discrete cosign transform coefficients.
- the transform coding process provides a series of clusters of spectral transform coefficients for each frame of video, with each cluster of coefficients corresponding to a different spatial region of the video image.
- Each cluster for example, may comprise an 8 ⁇ 8 array of coefficients with 14,400 clusters representing an entire video frame.
- the coefficient clusters are serially applied to a perceptual modelling system which develops an output that reflects the perceptual nature of the corresponding portion of the video image.
- the video data is then compressed in accordance with a selected compression algorithm.
- One well-known compression technique does not send all of the transform coefficients, the coefficients whose omission will have the least noticeable effect on the received image being dropped.
- the remaining coefficients are variable length encoded and sent as a series of codewords of unequal bit length, with the shortest codewords being assigned to those values that are most probable.
- the data may be ranked by importance, i.e. control data may be sent in more robust initial data segments, followed by data of the next level of importance such as motion vectors, etc.
- control data may be sent in more robust initial data segments, followed by data of the next level of importance such as motion vectors, etc.
- the number of motion vectors and difference signals may vary from frame to frame depending upon the perceptual nature of the video information in the frame and its relationship to the previous frame.
- the compressed variable length encoded information is assembled into Blocks consisting of a fixed number of 8 ⁇ 8 coefficient arrays, from most of which some coefficients have been omitted. Included with each Block is a Block header referred to as a selector, that consists of a fixed number of variable length encoded codewords containing the selector information.
- the selector information identifies which coefficients have been omitted from the 8 ⁇ 8 arrays in the Block and the total number of coefficients in the Block.
- the Blocks are assembled into data frames, each frame comprising a preselected number of equal length data segments.
- Each data segment has an initial fixed length segment sync portion, a fixed length data segment header and Block data, i.e. selector and coefficient data.
- the data segment header has a pointer that indicates the location in the data segment where the first Block beginning, if any, in that data segment occurs.
- the selector data and coefficient data may be recovered by counting codewords and coefficients.
- Block data any of a well known number of encoding systems may be used such that the data or codewords may be joined, i.e. sequentially transmitted without breaks therebetween.
- the receiving system can produce a state table for determining the boundaries or junctions between adjacent codewords.
- the encoding form known as Huffman encoding is presently preferred. This is all by way of background to the present invention which will be understood not to be restricted to any particular form of encoding or processing.
- variable signal groups of compressed data supplied to the buffers must be processed along with synchronizing or reset signals. Since the compressed data buffers are of the fifo type, an equal size auxiliary fifo buffer is required for the synchronizing signals to keep everything in synchronism. This is a very expensive solution, however, and the present invention is directed to a system for significantly reducing the size of the auxiliary buffer memory required for processing the sync signals.
- a principal object of the invention is to provide a novel digital data processing system.
- Another object of the invention is to provide a processing system for variable sized groups of compressed data that minimizes memory requirements.
- a further object of the invention is to provide an improved method of maintaining synchronism between variable sized groups of compressed data and accompanying synchronizing signals.
- FIG. 1 is a block diagram of a television transmission system utilizing the invention.
- FIG. 2 is a block diagram illustrating operation of the invention.
- a transmitter 10 includes an encoder 12 for receiving video from a suitable source and processing it in any of a variety of ways, including the one specified in U.S. Pat. No. 5,285,276 by developing motion vectors and discrete cosign transform coefficients for the difference signals.
- the data is supplied to a variable length encoder 14 in which the data is compressed and formatted in the form of codewords of variable length.
- the output of variable length encoder 14 is at a fixed video frame rate resulting in a variable data rate which, in accordance with the preferred embodiment, averages about 17 megabits per second.
- the variable rate data is applied to a compressed data (CD) buffer 16 which outputs data at a fixed data rate of 17 megabits per second.
- CD compressed data
- the data is transmitted by any suitable means, e.g. over the air or by cable, to a receiver 11 which includes a compressed data buffer (CD) 18 , a variable length decoder (VLD) 20 , an uncompressed data buffer (UD) 22 and a selector 24 .
- the uncompressed data buffer 22 is shown in a dashed line block to simplify the operational description of the processing system.
- selector 24 must provide pixel data in parallel form (at an assumed 8 bits per pixel), at a rate of about 75 megabytes per second. This 75 megabytes per second rate is referred to as the pixel clock (pclock). To achieve this rate, selector 24 requests data as needed (in parallel form) from VLD 20 via its request (req) line. The selector adds or fills in 0's for omitted coefficients in the transmitted Blocks of data. It therefore doesn't request as much data from VLD 20 for a Block that has omitted coefficients. The result is a relatively low data rate between VLD 20 and selector 24 when processing that Block.
- selector 24 For Blocks of data with no coefficients dropped, selector 24 must receive all coefficients at the pclock rate. To supply selector 24 with data at the pclock rate, VLD 20 must request data from CD buffer 18 at the rate of one variable length codeword per pclock. For example, assume a time period in which all incoming variable length codewords are of maximum 8 bit length. Because VLD 20 receives data serially, the data rate is 8 ⁇ pclock between CD buffer 18 and VLD 20 . This is a very high rate (8 ⁇ 75 MHz) at which to read data out of conventional memory. Hence, the CD buffer 18 in the receiver is placed before VLD 20 to keep the buffer size reasonable. (Buffering after VLD 20 would require a buffer of much larger size.)
- a circuit modification that helps to reduce the buffer size includes another buffer UD 22 in the dashed line box. Since worst case situations (no significant compression of data) will persist for relatively short and infrequent time periods, UD 22 provides data to selector 24 at the pclock rate while reading data from VLD 20 at a somewhat lesser rate. The result is that the rate at which data is read from CD buffer 18 is somewhat reduced. However, UD buffer 22 , which stores expanded data, would need to be very large to effect a significant reduction in the data rate from CD buffer 18 . The problem remains in that the high data rate between the CD buffer and the VLD requires the use of a very expensive high speed memory for the compressed data buffer.
- compressed data and data segment sync signals are applied to a first separator DS 1 .
- the data segment sync signals mark the boundaries between each of the fixed length data segments.
- DS 1 separates the data segment header from the Block data in the data segments and sends the Block data to a compressed data output.
- DS 1 determines the starting points in the compressed data stream for some of the Blocks, i.e. the first Block beginning, if any, in a data segment from the data segment header information. Specifically, a pointer in the data segment header points to the first Block beginning in the data segment. This information is used to create a partial Block boundary marker signal for synchronization of the subsequent circuitry.
- the compressed data and partial Block boundary marker signals are applied to a second data separator DS 2 .
- DS 2 includes means for finding the separation points between each of the individual variables length codewords in the compressed data stream. Such means may conveniently take the form of separate variable length decoders that are dedicated primarily to the task of finding these codeword boundaries.
- a partial Block boundary marker signal from DS 1 identifies a known, fixed number of following codewords as selector data for the Block.
- a variable length decoder decodes the data counting this known, fixed number of codewords to identify the boundary in the compressed data stream between the selector data and the coefficient data.
- the compressed selector data is sent to the compressed selector data output of DS 2 and the subsequent coefficient data is sent to the compressed data output of DS 2 .
- the portion of the decoded selector data that identifies the number of coefficient codewords in the Block is saved and used to control the VLD which decodes the identified number of coefficient codewords before the next Block (and the new selector data) is encountered.
- DS 2 stops routing the compressed data stream to the compressed data output and switches back to the compressed selector data output at that point. The remainder of the decoded selector data and all of the decoded coefficient data is discarded in DS 2 .
- DS 2 also generates a group boundary marker signal that denotes the boundaries between groups (i.e. an integral number of codewords) in the compressed coefficient data stream at the compressed data output. The integral number is determined according to an algorithm to be discussed.
- variable length decoders in DS 2 will be quickly resynchronized by the partial Block boundary marker signal from DS 1 .
- the compressed data and group boundary marker signals are applied to a demultiplexer and grouper 30 for demultiplexing and assembling the codewords into groups (determined by the algorithm) consisting of an integral number of codewords, the boundaries between the groups being determined by the group boundary marker signal.
- the compressed selector data signal from DS 2 is supplied, along with a data clock signal, to a compressed data buffer 34 .
- the clock signal is supplied to the WR (write) terminal of a CD buffer 34 , while the data signal is applied to its I (input) terminal.
- the output terminal O of buffer 34 supplies the compressed selector data to a selector data variable length decoder 39 .
- VLD 39 controls the rate of transmission of data from buffer 34 by means of a request line which is coupled to the R (read) terminal of buffer 34 .
- the partial Block boundary marker signal supplied from DS 1 to DS 2 is present for only the first-occurring Block beginning in a data segment as described above.
- DS 2 also develops a complete Block boundary marker signal that identifies each Block boundary when the separation points between the end of the compressed coefficient data and the beginning of the compressed selector data, as described above, are determined.
- An auxiliary buffer 35 is operated in parallel with buffer 34 for maintaining synchronism between the data (as it is processed) and the complete Block boundary marker signals. This arrangement for processing the marker signals constitutes the subject of the present invention and results in a significant reduction in the required size of the auxiliary buffer.
- An input bit counter 32 and an output bit counter 37 flank the auxiliary buffer 35 .
- the data clock signal is applied to input bit counter 32 .
- the count value of input bit counter 32 is supplied to the data input of the auxiliary buffer 35 .
- the reset terminal of input bit counter 32 and the write terminal of auxiliary buffer 35 are supplied with the complete Block boundary marker signal from DS 2 .
- the output of auxiliary buffer 35 is applied via a parallel load bus to output bit counter 37 which is stepped by the request signal from VLD 39 .
- the count value of output bit counter 37 is supplied to an “all zero” detector 38 which develops a reset signal for VLD 39 , for counter 37 and a lead signal for auxiliary buffer 35 .
- the selector data is applied to a selector/multiplexer 41 for controlling operation thereof.
- VLD 39 also generates a complete Block boundary marker signal for selector/multiplexer 41 .
- the buffers 34 and 35 are of the first-in, first-out (fifo) type that are well known in the
- demultiplexer and grouper 30 accepts the incoming serial data and the group boundary marker signal from DS 2 and apportions the data into groups, each consisting of an integral number of codewords, among a plurality of parallelly connected compressed data buffers 50 - 57 .
- the dashed line joining the buffers 50 - 57 indicates that buffers, corresponding to output terminals 1 - 6 of the demultiplexer and grouper 30 , are omitted.
- the output terminals 0 - 7 are arbitrary in number and that each output terminal has the same processing structure, i.e. buffers and variable length decoders, connected thereto. It will therefore suffice to describe operations for one output, it being understood that data at the other outputs is processed in an identical manner.
- the data from terminal O is applied to the input terminal of CD buffer 50 .
- the data clock signal is applied to the WR terminal of CD buffer 50 and to an input bit counter 40 .
- An auxiliary buffer 60 , an output bit counter 70 and a zero detector 80 are connected in a manner similar to the connection of auxiliary buffer 35 , output bit counter 37 and zero detector 38 described above.
- a variable length decoder 90 receives the serial data from CD buffer 50 , decodes it, and applies the decoded data in a parallel format to an uncompressed data buffer 100 .
- the output of uncompressed buffer 100 is supplied to the selector and multiplexer 41 , which also includes means for uncompressing the compressed data.
- variable length encoded codewords are decoded to a fixed 8 bit length. This is distinct from the uncompressing of the compressed data that occurs after the VLD.
- a similar arrangement of elements coupled to output terminal 7 of demultiplexer and grouper 30 i.e. CD buffer 57 , auxiliary buffer 67 , bit counters 47 and 77 , VLD 97 and uncompressed buffer 107 function in the same way to develop a parallel output of a block of data, which is assembled into a single serial stream by selector/multiplexer 41 .
- the incoming data is formatted such that the boundaries between codewords can be determined in the decoding process. Since the uncompressed data can reach extremely high rates, the plurality of parallel buffers 50 - 57 is employed to operate on sequential portions of the data stream. Since the required speed for each buffer is effectively divided by the number of buffers, relatively low cost fifo memories may therefore be used for the buffers.
- the codewords being of variable length, the grouping of the codewords to load the parallel buffers substantially equally is very important. The sizes or bit lengths of the codeword groups are determined with an algorithm based upon selecting a nominal group bit length equal to the maximum codeword size and adding successive codewords until the nominal size is reached or exceeded.
- the nominal bit length is subtracted from the actual number of totalled bits and compared with another total developed from the difference between the totalled number of bits minus the last-added codeword.
- the codeword arrangement that provides the smallest difference is selected as the group and demultiplexer 30 supplies that group of data to buffer 50 and switches to its next output for the next group of data.
- the process proceeds in a cyclical manner with each of the outputs of demultiplexer and grouper 30 receiving a group of data for its associated buffer.
- the loading of the buffers is substantially equalized so that no one buffer is loaded significantly faster or more fully than any other buffer. This contributes greatly to system economy and enables the smaller size buffers to process the information.
- the number of buffers need not be eight, but any number can be employed with equal effect. That invention is the subject matter of the U.S. Pat. No. 5,424,733.
- the subject matter of the present invention is the provision of the input and output bit counters to enable the use of an auxiliary buffer of a significantly smaller size than the CD buffer while preserving synchronism between the data that is being supplied to the CD buffer and the complete Block boundary marker signal.
- Counter 40 for example, counts up the bits written into CD buffer 50 until it is reset by the complete Block boundary marker signal. This signal is a pulse in which the trailing edge acts as a reset signal. The count total of counter 40 is transferred (as a parallel N bit word) to the auxiliary buffer 60 when its WR input is activated by leading edge of the complete Block boundary marker signal.
- Both CD buffer 50 and auxiliary buffer 60 are of the fifo variety, and as the data is serially transferred to buffer 50 , the N bit word, representing the number of bits in the Block of data, is clocked along.
- the Block of data supplied to buffer 50 may comprise a number of groups totalling many hundreds of bits in length whereas the corresponding word in auxiliary buffer 60 is only a few (N) bits long.
- VLD 90 requests data from buffer 50
- the parallel data in auxiliary buffer 60 is loaded into the output counter 70 and the counter begins to count down in response to signals on the request line.
- the zero detector 80 When the counter counts down to all zeros, the zero detector 80 generates a reset signal, which is applied to VLD 90 , counter 70 and auxiliary buffer 60 .
- N is readily determined by letting X equal the maximum number of expected coefficient bits in a Block. Since there are eight parallel paths and the X bits are approximately equally distributed to each of the parallel paths (CD buffers), any given buffer will hold a maximum of X/8 bits. Since the binary representation of N is log 2 (X/ 8 ), the input and output bit counters must be N bits wide.
- selector VLD 39 reads data out of CD buffer 34 and provides decoded selector data to the selector/multiplexer 41 .
- VLD 39 sends a new complete Block boundary marker signal (corresponding to the original Block boundary marker signal) to the selector/multiplexer 41 .
- VLD's 90 - 97 read data out of their corresponding CD buffers ( 50 - 57 ), decode the data and output it in parallel form to their corresponding UD buffers ( 100 - 107 ).
- VLD's 90 - 97 also keep track of codeword groups generated according to the previously described grouping algorithm and produce group boundary signals (bits) which are passed to the UD buffers along with the decoded codewords.
- the codeword data and group boundary signals pass through the UD buffers and are available to the selector/multiplexer 41 .
- the selector/multiplexer 41 outputs expanded coefficient data at the pclock rate.
- selector/multiplexer 41 reads the selector data for the current Block of data from selector VLD 39 .
- This information indicates which coefficients have been omitted from the Block of data and the total number of coefficients in the Block.
- the number of coefficients to be read from the parallel coefficient UD buffers is determined and the point at which selector data must be read for the next Block of data from selector VLD 39 is ascertained.
- the selector/multiplexer fills in O's for the omitted coefficients.
- data must be read from the parallel UD buffers a group of codewords at a time. This grouping is determined by the previously described group boundary marker signals.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Computing Systems (AREA)
- Theoretical Computer Science (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
- Compression, Expansion, Code Conversion, And Decoders (AREA)
Abstract
A digital data processing system receives compressed variable length encoded digital data in the form of variable length codewords in contiguous variable speed Blocks of data. The boundary signals between adjacent codewords are determined and a demultiplexer sequentially sorts the serial digital data among a plurality of parallelly connected buffers for reducing the bit read speed of the buffers. A corresponding plurality of variable length decoders decodes the data from the buffers and outputs the data in parallel form to a multiplexer where it is reassembled into a serial expanded data stream. The incoming data includes selector information in fixed length headers that are separated, buffered and variable length decoded for controlling the demultiplexer. In one aspect of the invention, the data is sorted into substantially equal sized groups of integral codewords for equalizing the loading of the parallel buffers. In another aspect of the invention, the Block boundary marker signals are processed through much smaller auxiliary buffers using counters to keep track of the Block boundary marker signals for synchronization with the data flowing through the buffers.
Description
Notice: More than one reissue application has been filed for the reissue of U.S. Pat. No. 5,563,920. The reissue applications are application Ser. Nos. 12/000,338 (the present application) filed Dec. 11, 2007, and 12/453,735 filed May 20, 2009, all of which are divisional reissues of U.S. Pat. No. 5,563,920.
This application is related to U.S. Pat. No. 5,285,276, entitled BI-RATE HIGH DEFINITION TELEVISION SIGNAL TRANSMISSION SYSTEM, issued Feb. 8, 1994, in the name of R. Citta and discloses an invention claimed in, U.S. Pat. No. 5,424,733, entitled PARALLEL PATH VARIABLE LENGTH DECODING FOR VIDEO SIGNALS, issued Jun. 13, 1995, in the names of the present inventors, all of which are assigned to Zenith Electronics Corporation.
This invention relates in general to data processing systems and in particular to a video data recovery and expansion system for use in connection with a digital high definition television system. The recently tested high definition television sysem of Zenith Electronics Corporation and AT&T Corporation includes a video compression scheme for compressing 37 MHz information for transmission over a 6 MHz wide television channel.
U.S. Pat. No. 5,285,276, describes a temporally oriented video compression system in which compressed video information is transmitted in the form of motion vectors and difference signals with the motion vectors identifying previous portions of a frame of video that closely match the current portion and the difference signals representing the differences between the previous and current portions. The video information has a bandwidth of about 37 MHz and may comprise a progressively scanned video signal in the form of successive frames of binary video data having a vertical periodicity equal to the NTSC standard (i.e. about 59.4 Hz) and a horizontal periodicity equal to three times the NTSC standard (i.e. about 47.25 KHz). The data is in the form of a series stream of binary pixel values that have been transform coded in the frequency domain to develop discrete cosign transform coefficients. The transform coding process provides a series of clusters of spectral transform coefficients for each frame of video, with each cluster of coefficients corresponding to a different spatial region of the video image. Each cluster, for example, may comprise an 8×8 array of coefficients with 14,400 clusters representing an entire video frame. The coefficient clusters are serially applied to a perceptual modelling system which develops an output that reflects the perceptual nature of the corresponding portion of the video image. The video data is then compressed in accordance with a selected compression algorithm. One well-known compression technique does not send all of the transform coefficients, the coefficients whose omission will have the least noticeable effect on the received image being dropped. The remaining coefficients are variable length encoded and sent as a series of codewords of unequal bit length, with the shortest codewords being assigned to those values that are most probable.
As further discussed in U.S. Pat. No. 5,285,276, the data may be ranked by importance, i.e. control data may be sent in more robust initial data segments, followed by data of the next level of importance such as motion vectors, etc. It will be noted that the number of motion vectors and difference signals may vary from frame to frame depending upon the perceptual nature of the video information in the frame and its relationship to the previous frame. The compressed variable length encoded information is assembled into Blocks consisting of a fixed number of 8×8 coefficient arrays, from most of which some coefficients have been omitted. Included with each Block is a Block header referred to as a selector, that consists of a fixed number of variable length encoded codewords containing the selector information. The selector information identifies which coefficients have been omitted from the 8×8 arrays in the Block and the total number of coefficients in the Block. The Blocks are assembled into data frames, each frame comprising a preselected number of equal length data segments. Each data segment has an initial fixed length segment sync portion, a fixed length data segment header and Block data, i.e. selector and coefficient data. The data segment header has a pointer that indicates the location in the data segment where the first Block beginning, if any, in that data segment occurs. Thus the selector data and coefficient data may be recovered by counting codewords and coefficients.
It will be noted that since the size of a Block is variable and the size of a data segment is fixed, the number of Blocks in a data segment will vary in accordance with the amount of compression. Therefore, several Blocks may be contained in a single data segment, or a single Block of data may extend over several data segments. As to the variable length encoding of the Block data, any of a well known number of encoding systems may be used such that the data or codewords may be joined, i.e. sequentially transmitted without breaks therebetween. The receiving system can produce a state table for determining the boundaries or junctions between adjacent codewords. The encoding form known as Huffman encoding is presently preferred. This is all by way of background to the present invention which will be understood not to be restricted to any particular form of encoding or processing.
The problem solved by the present invention is caused by the fact that the variable signal groups of compressed data supplied to the buffers must be processed along with synchronizing or reset signals. Since the compressed data buffers are of the fifo type, an equal size auxiliary fifo buffer is required for the synchronizing signals to keep everything in synchronism. This is a very expensive solution, however, and the present invention is directed to a system for significantly reducing the size of the auxiliary buffer memory required for processing the sync signals.
A principal object of the invention is to provide a novel digital data processing system.
Another object of the invention is to provide a processing system for variable sized groups of compressed data that minimizes memory requirements.
A further object of the invention is to provide an improved method of maintaining synchronism between variable sized groups of compressed data and accompanying synchronizing signals.
These and other objects and advantages of the invention will be apparent upon reading the following description in conjunction with the drawings, in which:
In FIG. 1 , a transmitter 10 includes an encoder 12 for receiving video from a suitable source and processing it in any of a variety of ways, including the one specified in U.S. Pat. No. 5,285,276 by developing motion vectors and discrete cosign transform coefficients for the difference signals. The data is supplied to a variable length encoder 14 in which the data is compressed and formatted in the form of codewords of variable length. The output of variable length encoder 14 is at a fixed video frame rate resulting in a variable data rate which, in accordance with the preferred embodiment, averages about 17 megabits per second. The variable rate data is applied to a compressed data (CD) buffer 16 which outputs data at a fixed data rate of 17 megabits per second. The data is transmitted by any suitable means, e.g. over the air or by cable, to a receiver 11 which includes a compressed data buffer (CD) 18, a variable length decoder (VLD) 20, an uncompressed data buffer (UD) 22 and a selector 24. The uncompressed data buffer 22 is shown in a dashed line block to simplify the operational description of the processing system.
The receiver requirements can best be understood by considering that selector 24 must provide pixel data in parallel form (at an assumed 8 bits per pixel), at a rate of about 75 megabytes per second. This 75 megabytes per second rate is referred to as the pixel clock (pclock). To achieve this rate, selector 24 requests data as needed (in parallel form) from VLD 20 via its request (req) line. The selector adds or fills in 0's for omitted coefficients in the transmitted Blocks of data. It therefore doesn't request as much data from VLD 20 for a Block that has omitted coefficients. The result is a relatively low data rate between VLD 20 and selector 24 when processing that Block. For Blocks of data with no coefficients dropped, selector 24 must receive all coefficients at the pclock rate. To supply selector 24 with data at the pclock rate, VLD 20 must request data from CD buffer 18 at the rate of one variable length codeword per pclock. For example, assume a time period in which all incoming variable length codewords are of maximum 8 bit length. Because VLD 20 receives data serially, the data rate is 8×pclock between CD buffer 18 and VLD 20. This is a very high rate (8×75 MHz) at which to read data out of conventional memory. Hence, the CD buffer 18 in the receiver is placed before VLD 20 to keep the buffer size reasonable. (Buffering after VLD 20 would require a buffer of much larger size.)
A circuit modification that helps to reduce the buffer size includes another buffer UD 22 in the dashed line box. Since worst case situations (no significant compression of data) will persist for relatively short and infrequent time periods, UD 22 provides data to selector 24 at the pclock rate while reading data from VLD 20 at a somewhat lesser rate. The result is that the rate at which data is read from CD buffer 18 is somewhat reduced. However, UD buffer 22, which stores expanded data, would need to be very large to effect a significant reduction in the data rate from CD buffer 18. The problem remains in that the high data rate between the CD buffer and the VLD requires the use of a very expensive high speed memory for the compressed data buffer.
The invention claimed in U.S. Pat. No. 5,424,733, above significantly reduces the reading speed requirement for the compressed data buffer by splitting the data among a number of buffers that operate in parallel. Referring to FIG. 2 , compressed data and data segment sync signals are applied to a first separator DS1. The data segment sync signals mark the boundaries between each of the fixed length data segments. DS1 separates the data segment header from the Block data in the data segments and sends the Block data to a compressed data output. DS1 determines the starting points in the compressed data stream for some of the Blocks, i.e. the first Block beginning, if any, in a data segment from the data segment header information. Specifically, a pointer in the data segment header points to the first Block beginning in the data segment. This information is used to create a partial Block boundary marker signal for synchronization of the subsequent circuitry. The compressed data and partial Block boundary marker signals are applied to a second data separator DS2.
DS2 includes means for finding the separation points between each of the individual variables length codewords in the compressed data stream. Such means may conveniently take the form of separate variable length decoders that are dedicated primarily to the task of finding these codeword boundaries. A partial Block boundary marker signal from DS1 identifies a known, fixed number of following codewords as selector data for the Block. A variable length decoder decodes the data counting this known, fixed number of codewords to identify the boundary in the compressed data stream between the selector data and the coefficient data. The compressed selector data is sent to the compressed selector data output of DS2 and the subsequent coefficient data is sent to the compressed data output of DS2. The portion of the decoded selector data that identifies the number of coefficient codewords in the Block is saved and used to control the VLD which decodes the identified number of coefficient codewords before the next Block (and the new selector data) is encountered. DS2 stops routing the compressed data stream to the compressed data output and switches back to the compressed selector data output at that point. The remainder of the decoded selector data and all of the decoded coefficient data is discarded in DS2. DS2 also generates a group boundary marker signal that denotes the boundaries between groups (i.e. an integral number of codewords) in the compressed coefficient data stream at the compressed data output. The integral number is determined according to an algorithm to be discussed. In the event of errors in the received data, the variable length decoders in DS2 will be quickly resynchronized by the partial Block boundary marker signal from DS1. The compressed data and group boundary marker signals are applied to a demultiplexer and grouper 30 for demultiplexing and assembling the codewords into groups (determined by the algorithm) consisting of an integral number of codewords, the boundaries between the groups being determined by the group boundary marker signal. The compressed selector data signal from DS2 is supplied, along with a data clock signal, to a compressed data buffer 34.
The clock signal is supplied to the WR (write) terminal of a CD buffer 34, while the data signal is applied to its I (input) terminal. The output terminal O of buffer 34 supplies the compressed selector data to a selector data variable length decoder 39. VLD 39 controls the rate of transmission of data from buffer 34 by means of a request line which is coupled to the R (read) terminal of buffer 34. The partial Block boundary marker signal supplied from DS1 to DS2 is present for only the first-occurring Block beginning in a data segment as described above. DS2 also develops a complete Block boundary marker signal that identifies each Block boundary when the separation points between the end of the compressed coefficient data and the beginning of the compressed selector data, as described above, are determined. An auxiliary buffer 35 is operated in parallel with buffer 34 for maintaining synchronism between the data (as it is processed) and the complete Block boundary marker signals. This arrangement for processing the marker signals constitutes the subject of the present invention and results in a significant reduction in the required size of the auxiliary buffer.
An input bit counter 32 and an output bit counter 37 flank the auxiliary buffer 35. The data clock signal is applied to input bit counter 32. The count value of input bit counter 32 is supplied to the data input of the auxiliary buffer 35. The reset terminal of input bit counter 32 and the write terminal of auxiliary buffer 35 are supplied with the complete Block boundary marker signal from DS2. The output of auxiliary buffer 35 is applied via a parallel load bus to output bit counter 37 which is stepped by the request signal from VLD 39. The count value of output bit counter 37 is supplied to an “all zero” detector 38 which develops a reset signal for VLD 39, for counter 37 and a lead signal for auxiliary buffer 35. The selector data is applied to a selector/multiplexer 41 for controlling operation thereof. VLD 39 also generates a complete Block boundary marker signal for selector/multiplexer 41. As indicated, the buffers 34 and 35 are of the first-in, first-out (fifo) type that are well known in the art.
Returning to DS2, demultiplexer and grouper 30 accepts the incoming serial data and the group boundary marker signal from DS2 and apportions the data into groups, each consisting of an integral number of codewords, among a plurality of parallelly connected compressed data buffers 50-57. The dashed line joining the buffers 50-57 indicates that buffers, corresponding to output terminals 1-6 of the demultiplexer and grouper 30, are omitted. It will be understood that the output terminals 0-7 are arbitrary in number and that each output terminal has the same processing structure, i.e. buffers and variable length decoders, connected thereto. It will therefore suffice to describe operations for one output, it being understood that data at the other outputs is processed in an identical manner.
The data from terminal O is applied to the input terminal of CD buffer 50. The data clock signal is applied to the WR terminal of CD buffer 50 and to an input bit counter 40. An auxiliary buffer 60, an output bit counter 70 and a zero detector 80 are connected in a manner similar to the connection of auxiliary buffer 35, output bit counter 37 and zero detector 38 described above. A variable length decoder 90 receives the serial data from CD buffer 50, decodes it, and applies the decoded data in a parallel format to an uncompressed data buffer 100. The output of uncompressed buffer 100 is supplied to the selector and multiplexer 41, which also includes means for uncompressing the compressed data. It will be noted that the VLD by its nature converts compressed data to a fixed length output and broadly performs some expansion. In practice, the variable length encoded codewords are decoded to a fixed 8 bit length. This is distinct from the uncompressing of the compressed data that occurs after the VLD.
A similar arrangement of elements coupled to output terminal 7 of demultiplexer and grouper 30, i.e. CD buffer 57, auxiliary buffer 67, bit counters 47 and 77, VLD 97 and uncompressed buffer 107 function in the same way to develop a parallel output of a block of data, which is assembled into a single serial stream by selector/multiplexer 41.
The parallel buffer arrangement will now be discussed. As mentioned, the incoming data is formatted such that the boundaries between codewords can be determined in the decoding process. Since the uncompressed data can reach extremely high rates, the plurality of parallel buffers 50-57 is employed to operate on sequential portions of the data stream. Since the required speed for each buffer is effectively divided by the number of buffers, relatively low cost fifo memories may therefore be used for the buffers. With the codewords being of variable length, the grouping of the codewords to load the parallel buffers substantially equally is very important. The sizes or bit lengths of the codeword groups are determined with an algorithm based upon selecting a nominal group bit length equal to the maximum codeword size and adding successive codewords until the nominal size is reached or exceeded. When this occurs, the nominal bit length is subtracted from the actual number of totalled bits and compared with another total developed from the difference between the totalled number of bits minus the last-added codeword. The codeword arrangement that provides the smallest difference is selected as the group and demultiplexer 30 supplies that group of data to buffer 50 and switches to its next output for the next group of data. The process proceeds in a cyclical manner with each of the outputs of demultiplexer and grouper 30 receiving a group of data for its associated buffer. With the arrangement, the loading of the buffers is substantially equalized so that no one buffer is loaded significantly faster or more fully than any other buffer. This contributes greatly to system economy and enables the smaller size buffers to process the information. It will be appreciated that the number of buffers need not be eight, but any number can be employed with equal effect. That invention is the subject matter of the U.S. Pat. No. 5,424,733.
The subject matter of the present invention is the provision of the input and output bit counters to enable the use of an auxiliary buffer of a significantly smaller size than the CD buffer while preserving synchronism between the data that is being supplied to the CD buffer and the complete Block boundary marker signal. Counter 40, for example, counts up the bits written into CD buffer 50 until it is reset by the complete Block boundary marker signal. This signal is a pulse in which the trailing edge acts as a reset signal. The count total of counter 40 is transferred (as a parallel N bit word) to the auxiliary buffer 60 when its WR input is activated by leading edge of the complete Block boundary marker signal. Both CD buffer 50 and auxiliary buffer 60 are of the fifo variety, and as the data is serially transferred to buffer 50, the N bit word, representing the number of bits in the Block of data, is clocked along. The Block of data supplied to buffer 50 may comprise a number of groups totalling many hundreds of bits in length whereas the corresponding word in auxiliary buffer 60 is only a few (N) bits long. When VLD 90 requests data from buffer 50, the parallel data in auxiliary buffer 60 is loaded into the output counter 70 and the counter begins to count down in response to signals on the request line. When the counter counts down to all zeros, the zero detector 80 generates a reset signal, which is applied to VLD 90, counter 70 and auxiliary buffer 60. Thus the synchronization of the compressed data and the Block boundary marker signal is maintained without requiring a duplicate size buffer for handling the boundary signal.
N is readily determined by letting X equal the maximum number of expected coefficient bits in a Block. Since there are eight parallel paths and the X bits are approximately equally distributed to each of the parallel paths (CD buffers), any given buffer will hold a maximum of X/8 bits. Since the binary representation of N is log2(X/8), the input and output bit counters must be N bits wide.
As mentioned previously, selector VLD 39 reads data out of CD buffer 34 and provides decoded selector data to the selector/multiplexer 41. In response to the reset signal from zero detector 38 which corresponds to the Block boundary points, VLD 39 sends a new complete Block boundary marker signal (corresponding to the original Block boundary marker signal) to the selector/multiplexer 41.
The parallel VLD's (90-97) read data out of their corresponding CD buffers (50-57), decode the data and output it in parallel form to their corresponding UD buffers (100-107). VLD's 90-97 also keep track of codeword groups generated according to the previously described grouping algorithm and produce group boundary signals (bits) which are passed to the UD buffers along with the decoded codewords. The codeword data and group boundary signals pass through the UD buffers and are available to the selector/multiplexer 41.
The selector/multiplexer 41 outputs expanded coefficient data at the pclock rate. In response to the reset (complete Block boundary marker signal) from selector VLD 39, selector/multiplexer 41 reads the selector data for the current Block of data from selector VLD 39. This information indicates which coefficients have been omitted from the Block of data and the total number of coefficients in the Block. Thus, the number of coefficients to be read from the parallel coefficient UD buffers is determined and the point at which selector data must be read for the next Block of data from selector VLD 39 is ascertained. The selector/multiplexer fills in O's for the omitted coefficients.
To maintain proper ordering of the data at the output of the selector/multiplexer, data must be read from the parallel UD buffers a group of codewords at a time. This grouping is determined by the previously described group boundary marker signals.
What has been described is a novel data processing system for decoding variable length encoded compressed data while maintaining synchronization that minimizes the need for fifo memories. It is recognized that numerous changes in the described embodiment of the invention will be apparent to those skilled in the art without departing from its true spirit and scope. The invention is to be limited only as defined in the claims.
Claims (14)
1. A method of dynamically processing variably sized Blocks of compressed data in a signal processing apparatus, the method comprising continuously:
providing a bit stream of the compressed data, the compressed data being processed by,
writing said compressed data into a first first-in first-out (fifo) memory;
developing input numbers representing the sizes of said Blocks of compressed data;
storing said developed input numbers in a second fifo memory: ; and
reading said stored input numbers from said second fifo memory to identify said Blocks of compressed data as said Blocks of compressed data are being read from said first fifo memory.
2. The method of claim 1 , further comprising: the compressed data being further processed by,
developing a Block boundary signal indicating the junctions between said Blocks of compressed data;
developing said input numbers by counting bits in said Blocks of compressed data under control of said Block boundary signal; and
controlling operation of said second fifo memory with said Block boundary signal.
3. The method of claim 2 , further including the compressed data being further processed by, stepping an input counter to develop said input numbers and stepping an output counter that is loaded with said input numbers as they are read from said second fifo memory.
4. The method of claim 3 , further comprising the compressed data being further processed by, developing a reset signal when said output counter has been stepped a number of counts equal to the input number loaded therein; and
controlling the read out of said second fifo memory and the reset of said output counter with said reset signal.
5. A method of dynamically synchronously processing contiguous unequal size Blocks of compressed data comprising continuously:
serially writing said compressed data into a first first-in first-out (fifo) memory;
developing counts of the numbers of bits in each of said Blocks;
storing said counts in a second fifo memory: ; and
sequentially reading said counts from said second fifo memory for identifying corresponding Blocks of data as said Blocks of data are being read from said first fifo memory.
6. The method of claim 5 wherein a Block boundary signal denoting the boundaries between said contiguous unequal size Blocks is developed and further comprising:
controlling an input counter with said Block boundary signal for counting the number of bits in each of said Blocks of data;
controlling an output counter loaded with the stored counts from said second fifo memory and operated by bits being read from said first fifo memory for developing a reset signal in synchronization with said Block boundary signal; and
resetting said output counter and controlling the reading of data from said second fifo memory with said reset signal.
7. A receiver for processing a continuous stream of digital data in contiguous Blocks of sequential bits wherein the number of bits of data in each Block is not uniform comprising:
a first and a second first-in first-out (fifo) memory;
an input counter and an output counter;
means for writing said digital data to said first fifo memory;
means for controlling said input counter to develop a count representative of the number of bits in a Block of data supplied to said first fifo memory and for writing said count to said second fifo memory;
detection means for reading said count from said second fifo memory and for loading said count in said output counter; and
means for controlling said output counter as said digital data is being read from said first fifo memory;
said detection means comprising means for determining when the number of bits read from said first fifo memory equals the count loaded in said output counter for developing a reset signal and means for resetting said output counter and controlling said second fifo memory with said reset signal.
8. The receiver of claim 7 wherein said output counter controlling means comprises a variable length decoder coupled to said first fifo memory, said variable length decoder including a request line for reading said digital data from said first fifo memory and for operating said output counter and wherein said detection means comprises means for resetting said variable length decoder with said reset signal.
9. The receiver of claim 8 wherein said determining means comprises an all zeroes detector and wherein said output counter is decremented responsive to said request line.
10. A method of dynamically processing variably sized blocks of compressed data in a signal processing apparatus, the method comprising continuously:
receiving a video bitstream including compressed data; and
processing the compressed data in the video bitstream by variable length decoding, the processing being based on inpput numbers representing sizes of Blocks of the compressed data by,
sequentially writing the compressed data into a first first-in first-out (fifo) memory,
sequentially developing the input numbers representing the sizes of the Blocks of the compressed data,
sequentially storing the developed input numbers in a second fifo memory, and
sequentially reading the stored input numbers from the second fifo memory in order to identify the Blocks of compressed data being read out from the first fifo memory.
11. The method of claim 10 , wherein the first fifo memory and the second fifo memory are arranged in a buffer memory.
12. The method of claim 11 , wherein a plurality of the buffer memories are arranged in parallel.
13. The method of claim 10 , wherein the Blocks include at least one of 8×8 arrays, partial blocks, frames, and header data.
14. The method of claim 13 , wherein the bitstream includes header data and wherein the input numbers are developed based on at least one of marker signals, boundary signal, starting points, and sync signals in the header data.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/000,338 USRE41569E1 (en) | 1993-02-17 | 2007-12-11 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
US12/453,735 USRE42147E1 (en) | 1993-02-17 | 2009-05-20 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/018,658 US5563920A (en) | 1993-02-17 | 1993-02-17 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
US12/000,338 USRE41569E1 (en) | 1993-02-17 | 2007-12-11 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/018,658 Reissue US5563920A (en) | 1993-02-17 | 1993-02-17 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/018,658 Division US5563920A (en) | 1993-02-17 | 1993-02-17 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Publications (1)
Publication Number | Publication Date |
---|---|
USRE41569E1 true USRE41569E1 (en) | 2010-08-24 |
Family
ID=21789103
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/018,658 Ceased US5563920A (en) | 1993-02-17 | 1993-02-17 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
US12/000,338 Expired - Lifetime USRE41569E1 (en) | 1993-02-17 | 2007-12-11 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
US12/453,735 Expired - Lifetime USRE42147E1 (en) | 1993-02-17 | 2009-05-20 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/018,658 Ceased US5563920A (en) | 1993-02-17 | 1993-02-17 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/453,735 Expired - Lifetime USRE42147E1 (en) | 1993-02-17 | 2009-05-20 | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo |
Country Status (1)
Country | Link |
---|---|
US (3) | US5563920A (en) |
Families Citing this family (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5737547A (en) * | 1995-06-07 | 1998-04-07 | Microunity Systems Engineering, Inc. | System for placing entries of an outstanding processor request into a free pool after the request is accepted by a corresponding peripheral device |
US5974516A (en) * | 1996-10-18 | 1999-10-26 | Samsung Electronics Co., Ltd. | Byte-writable two-dimensional FIFO buffer having storage locations with fields indicating storage location availability and data ordering |
US5872823A (en) * | 1997-04-02 | 1999-02-16 | Sutton; Todd R. | Reliable switching between data sources in a synchronous communication system |
US6145068A (en) * | 1997-09-16 | 2000-11-07 | Phoenix Technologies Ltd. | Data transfer to a non-volatile storage medium |
US6453365B1 (en) * | 1998-02-11 | 2002-09-17 | Globespanvirata, Inc. | Direct memory access controller having decode circuit for compact instruction format |
US6161155A (en) * | 1998-07-20 | 2000-12-12 | Hewlett-Packard Company | Apparatus and method for storing retrievable boundary information into a buffer memory of a receiving device |
US6563879B1 (en) * | 1999-05-17 | 2003-05-13 | Lucent Technologies Inc. | Method and apparatus for enabling transmission of variable length encoded data in a low signal to noise ratio environment |
US6677869B2 (en) * | 2001-02-22 | 2004-01-13 | Panasonic Communications Co., Ltd. | Arithmetic coding apparatus and image processing apparatus |
CN1310229C (en) * | 2003-11-17 | 2007-04-11 | 威盛电子股份有限公司 | Method and device for adjusting a control parameter of a servo of an optical drive |
TWI261226B (en) * | 2004-01-20 | 2006-09-01 | Via Tech Inc | Apparatus and method of dynamic adjusting the detection window |
CN100340114C (en) * | 2004-02-24 | 2007-09-26 | 上海交通大学 | Multi-path paralleled method for decoding codes with variable lengths |
TWI261240B (en) | 2004-08-17 | 2006-09-01 | Via Tech Inc | Method for determining data storage quality of optical disc |
WO2008111820A1 (en) * | 2007-03-15 | 2008-09-18 | Lg Electronics Inc. | Method of managing data blocks during handover |
KR101364932B1 (en) * | 2007-03-15 | 2014-02-20 | 엘지전자 주식회사 | Method for transmitting data using data generating pattern |
US8013765B1 (en) * | 2008-05-01 | 2011-09-06 | Cavium, Inc. | Modular scaleable processing engine for accelerating variable length coding |
EP2519006B1 (en) | 2011-04-26 | 2013-11-27 | BlackBerry Limited | Fast estimation of binary data length using memory corruption |
US9966972B1 (en) * | 2014-09-02 | 2018-05-08 | Marvell International Ltd. | Systems and methods for dynamic iteration control in a low-density parity-check (LDPC) decoder |
US10027984B2 (en) | 2016-11-30 | 2018-07-17 | Hewlett Packard Enterprise Development Lp | Methods and systems for efficiently reading a data block from a data seglet with compressed data blocks |
Citations (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3813485A (en) * | 1972-01-05 | 1974-05-28 | Ibm | System for compression of digital data |
JPS53136450A (en) * | 1977-05-04 | 1978-11-29 | Hitachi Ltd | Variable-length coding system |
US4520483A (en) * | 1981-09-28 | 1985-05-28 | Hitachi, Ltd. | Signal diagnostic method and apparatus for multiple transmission system |
EP0180345A2 (en) * | 1984-10-04 | 1986-05-07 | Nec Corporation | Method and apparatus for picture signal encoding and decoding |
US4596026A (en) * | 1983-05-09 | 1986-06-17 | Raytheon Company | Asynchronous data clock generator |
US4796280A (en) * | 1987-11-06 | 1989-01-03 | Standard Microsystems Corporation | Digital data separator |
US5034914A (en) * | 1986-05-15 | 1991-07-23 | Aquidneck Systems International, Inc. | Optical disk data storage method and apparatus with buffered interface |
US5038277A (en) * | 1983-11-07 | 1991-08-06 | Digital Equipment Corporation | Adjustable buffer for data communications in a data processing system |
US5111485A (en) * | 1990-05-18 | 1992-05-05 | Northern Telecom Limited | Method of and circuit for synchronizing data |
US5163072A (en) * | 1986-07-23 | 1992-11-10 | Optical Communications Corporation | Optical communications transmitter and receiver |
US5214642A (en) * | 1989-02-21 | 1993-05-25 | Hitachi, Ltd. | ATM switching system and adaptation processing apparatus |
US5237460A (en) * | 1990-12-14 | 1993-08-17 | Ceram, Inc. | Storage of compressed data on random access storage devices |
US5321521A (en) * | 1991-07-19 | 1994-06-14 | Ricoh Company, Ltd. | Image data compression transmission method utilizing a synchronization code |
US5361097A (en) * | 1993-04-02 | 1994-11-01 | Rca Thomson Licensing Corporation | Priority processing of encoded video signal including insertion of datastream null words during priority analysis intervals |
US5386212A (en) * | 1992-11-19 | 1995-01-31 | General Instrument Corporation | Double buffer scheme for variable length decoder |
-
1993
- 1993-02-17 US US08/018,658 patent/US5563920A/en not_active Ceased
-
2007
- 2007-12-11 US US12/000,338 patent/USRE41569E1/en not_active Expired - Lifetime
-
2009
- 2009-05-20 US US12/453,735 patent/USRE42147E1/en not_active Expired - Lifetime
Patent Citations (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3813485A (en) * | 1972-01-05 | 1974-05-28 | Ibm | System for compression of digital data |
JPS53136450A (en) * | 1977-05-04 | 1978-11-29 | Hitachi Ltd | Variable-length coding system |
US4520483A (en) * | 1981-09-28 | 1985-05-28 | Hitachi, Ltd. | Signal diagnostic method and apparatus for multiple transmission system |
US4596026A (en) * | 1983-05-09 | 1986-06-17 | Raytheon Company | Asynchronous data clock generator |
US5038277A (en) * | 1983-11-07 | 1991-08-06 | Digital Equipment Corporation | Adjustable buffer for data communications in a data processing system |
EP0180345A2 (en) * | 1984-10-04 | 1986-05-07 | Nec Corporation | Method and apparatus for picture signal encoding and decoding |
US5034914A (en) * | 1986-05-15 | 1991-07-23 | Aquidneck Systems International, Inc. | Optical disk data storage method and apparatus with buffered interface |
US5394442A (en) * | 1986-07-23 | 1995-02-28 | Optical Communications Corporation | Optical communications transmitter and receiver |
US5163072A (en) * | 1986-07-23 | 1992-11-10 | Optical Communications Corporation | Optical communications transmitter and receiver |
US4796280A (en) * | 1987-11-06 | 1989-01-03 | Standard Microsystems Corporation | Digital data separator |
US5214642A (en) * | 1989-02-21 | 1993-05-25 | Hitachi, Ltd. | ATM switching system and adaptation processing apparatus |
US5111485A (en) * | 1990-05-18 | 1992-05-05 | Northern Telecom Limited | Method of and circuit for synchronizing data |
US5237460A (en) * | 1990-12-14 | 1993-08-17 | Ceram, Inc. | Storage of compressed data on random access storage devices |
US5321521A (en) * | 1991-07-19 | 1994-06-14 | Ricoh Company, Ltd. | Image data compression transmission method utilizing a synchronization code |
US5386212A (en) * | 1992-11-19 | 1995-01-31 | General Instrument Corporation | Double buffer scheme for variable length decoder |
US5361097A (en) * | 1993-04-02 | 1994-11-01 | Rca Thomson Licensing Corporation | Priority processing of encoded video signal including insertion of datastream null words during priority analysis intervals |
Non-Patent Citations (1)
Title |
---|
Yuichi Sato, "DPCM Coding Method Using Variable-Length Codes For Video Telephone Signals", Fig. 1. * |
Also Published As
Publication number | Publication date |
---|---|
USRE42147E1 (en) | 2011-02-15 |
US5563920A (en) | 1996-10-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
USRE41569E1 (en) | Method of processing variable size blocks of data by storing numbers representing size of data blocks in a fifo | |
US5424733A (en) | Parallel path variable length decoding for video signals | |
KR100282981B1 (en) | Field Deleter for Video Compression / Decompression Systems | |
CN1052606C (en) | Reset control network for a video signal encoder | |
US4929946A (en) | Adaptive data compression apparatus including run length encoding for a tape drive system | |
FI75072C (en) | Data transmission system. | |
JP3171776B2 (en) | Compression method and context modeler | |
US5361097A (en) | Priority processing of encoded video signal including insertion of datastream null words during priority analysis intervals | |
US5504823A (en) | Image data partitioning circuit for parallel image decoding system | |
EP0453229A2 (en) | Method for transmission of variable length code | |
US5166684A (en) | Variable length encoder having sign bit separation | |
US5410355A (en) | Video signal processor including input codeword buffer for providing stored codewords to codeword priority analysis circuit | |
RU2119269C1 (en) | Television system for converting compressed data presenting images and placed in blocks into decompressed data and system for processing compressed video data transmitted in the form of blocks | |
JPH0955935A (en) | Picture and sound encoding device | |
US5404166A (en) | Variable-length to fixed-length data word reformatting apparatus | |
US6185229B1 (en) | Data multiplexing apparatus and method thereof | |
EP1119206A1 (en) | MPEG decoding device | |
JP3927443B2 (en) | Moving picture transmission / reception system and moving picture transmission / reception method | |
US5668547A (en) | Runlength coding method and apparatus for use in a video signal encoding system | |
JP3285220B2 (en) | Television system for transmitting image signals in digital form | |
USRE41179E1 (en) | Device for extracting parameters for decoding a video data flow coded according to an MPEG standard | |
JP2675130B2 (en) | Image data transfer reproduction method and transfer reproduction apparatus | |
KR0184405B1 (en) | Coding method and apparatus | |
JPH07255053A (en) | Zigzag scanning circuit | |
JPH02274126A (en) | Communication method, and parallel variable length coding circuit and parallel variable length decoding circuit |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |