USRE34965E - Inter-frame predictive encoding system with encoded and transmitted prediction error - Google Patents

Inter-frame predictive encoding system with encoded and transmitted prediction error Download PDF

Info

Publication number
USRE34965E
USRE34965E US08/004,689 US468993A USRE34965E US RE34965 E USRE34965 E US RE34965E US 468993 A US468993 A US 468993A US RE34965 E USRE34965 E US RE34965E
Authority
US
United States
Prior art keywords
frame
frames
display information
dependent
signal
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
Application number
US08/004,689
Inventor
Kenji Sugiyama
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Victor Company of Japan Ltd
Original Assignee
Victor Company of Japan Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=26347033&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=USRE34965(E) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Priority claimed from JP1158789A external-priority patent/JP2530217B2/en
Priority claimed from JP1034161A external-priority patent/JPH07112283B2/en
Application filed by Victor Company of Japan Ltd filed Critical Victor Company of Japan Ltd
Priority to US08/004,689 priority Critical patent/USRE34965E/en
Application granted granted Critical
Publication of USRE34965E publication Critical patent/USRE34965E/en
Anticipated expiration legal-status Critical
Expired - Lifetime legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/76Television signal recording
    • H04N5/91Television signal processing therefor
    • H04N5/92Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback
    • H04N5/926Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation
    • H04N5/9261Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation involving data reduction
    • H04N5/9264Transformation of the television signal for recording, e.g. modulation, frequency changing; Inverse transformation for playback by pulse code modulation involving data reduction using transform coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/53Multi-resolution motion estimation; Hierarchical motion estimation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/577Motion compensation with bidirectional frame interpolation, i.e. using B-pictures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/587Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal sub-sampling or interpolation, e.g. decimation or subsequent interpolation of pictures in a video sequence
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/59Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial sub-sampling or interpolation, e.g. alteration of picture size or resolution
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/61Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/80Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
    • H04N19/82Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation involving filtering within a prediction loop

Definitions

  • This invention relates to an inter-frame predictive encoding system for a video signal.
  • display information of a frame tends to correlate with display information of a subsequent frame and a preceding frame.
  • a correlation between successive frames is used in reducing a digital data transmission rate.
  • Inter-frame predictive encoding uses the correlation between successive frames to reduce the digital data transmission rate.
  • the inter-frame predictive encoding is generally effective in handling a video signal representing moving pictures.
  • an inter-frame predictive encoding system comprises means for setting reference frames separated at equal intervals, the reference frames being selected from successively inputted frames of a video signal; means for encoding each of the reference frames; means for generating a prediction signal for a dependent frame between the reference frames on the basis of a signal of the reference frames which precedes and follows the dependent frame respectively; means for predicting a signal of the dependent frame on the basis of the prediction signal corresponding thereto; and means for encoding an error of said predicting of the signal of the dependent frame.
  • an inter-frame predictive encoding system comprises means for separating successively-inputted frames of a video signal into reference frames and dependent frames, the reference frames being spaced at predetermined intervals, the dependent frames residing between the reference frames; means for encoding display information of the reference frames; means for predicting display information of each dependent frame on the basis of display information of reference frames which precede and follow said dependent frame respectively; means for generating an error between the predicted display information and corresponding actual display information of said dependent frame; and means for encoding said error.
  • an inter-frame predictive encoding system comprises means for performing motion-compensated inter-frame prediction using motion vectors between successively inputted frames of a video signal; the improvement comprising means for setting specified frames separated at equal intervals, the specified frames being selected from successively inputted frames of a video signal; means for detecting motion vectors between the specified frames; means for detecting motion vectors between adjacent non-specified frames between the specified frames as differences with respect to said motion vectors between the specified frames.
  • FIG. 1 is a block diagram of a conventional inter-frame predictive encoding system.
  • FIG. 2 is a block diagram of a conventional decoding system.
  • FIG. 3 is a diagram of a stream of successive frames in an inter-frame predictive encoding system and a decoding system according to a first embodiment of this invention.
  • FIG. 4 is a block diagram of the inter-frame predictive encoding system according to the first embodiment of this invention.
  • FIG. 5 is a diagram showing the relation between prediction values and successive frames in the encoding system of FIG. 4.
  • FIG. 6 is a block diagram of a decoding system according to the first embodiment of this invention.
  • FIG. 7 is a block diagram of an inter-frame predictive encoding system according to a second embodiment of this invention.
  • FIG. 8 is a block diagram of an inter-frame predictive encoding system according to a third embodiment of this invention.
  • FIG. 9 is a block diagram of the motion vector detector of FIG. 8.
  • FIG. 10 is a block diagram of the vector difference detector of FIG. 8.
  • FIG. 11 is a block diagram of a circuit for generating a control signal fed to the switches of FIG. 4.
  • FIG. 12 is a timing diagram of signals generated in the circuit of FIG. 11.
  • FIG. 1 shows a conventional inter-frame predictive encoding system.
  • a digitized video signal is fed to a subtracter 2 via an input terminal 1.
  • the subtracter 2 subtracts a prediction digital signal from the digitized video signal to generate a prediction error (difference) signal.
  • the prediction signal will be explained later.
  • the prediction error signal outputted from the substracter 2 is subjected to an orthogonal transform by an orthogonal transform device 3.
  • the orthogonal transform increases the efficiency of encoding.
  • the output signal from the orthogonal transform device 3 is quantized by a quantizer 4.
  • the output data from the quantizer 4 is encoded by an encoder S into variable-length codes such as Huffman codes.
  • the codes outputted from the encoder S are transmitted via an output terminal 6.
  • the output data from the quantizer 4 is subjected to an inverse quantization by an inverse quantizer 7 so that it is converted into a representative (setting of a representative).
  • the representative outputted from the inverse quantizer 7 is subjected to an inverse orthogonal transform by an inverse transform device 8.
  • the output signal from the inverse transform device 8 corresponds to a prediction error (difference) which is generated through a decoding process in a decoding system explained later.
  • An adder 9 adds the prediction error and a one-frame preceding prediction signal, generating a digitized video signal which corresponds to a digitized video signal generated by a decoding process in the decoding system.
  • a frame memory 10 delays the output signal from the adder 9 by a time corresponding to a period of one frame.
  • the output signal from the frame memory 10 is passed through a spatial low pass filter (a spatial LPF) 11, being converted into the prediction signal.
  • the prediction signal is fed from the spatial LPF 11 to the subtracter 2 and the adder 9 via a switch 12.
  • the spatial LPF 11 multiples the output data from the adder 9 by a coefficient which varies with a spatial frequency.
  • the spatial LPF 11 ensures that a quantization error remains in the prediction error at a reduced rate.
  • the spatial LPF 11 is effective and advantageous since a larger quantity of quantization errors are present in a high-frequency range and an inter-frame correlation is weakened by noises in the high-frequency range.
  • the switch 12 periodically couples and uncouples the spatial LPF 11 to and from the subtracter 2 and the adder 9 to periodically reset the inter-frame prediction.
  • the period of the resetting the inter-frame prediction is generally set so as to correspond to 30 to 100 frames.
  • the prediction signal is fixed and essentially intra-frame coding is performed.
  • the resetting prevents calculation errors from accumulating up to an unacceptable level. The calculation error would result from error codes generated in a transmission line and mismatching between orthogonal converters of a transmitter side and a receiver side in recursive-type inter-frame predictive en coding such as shown in FIG. 1.
  • a shorter period of the resetting enables calculating errors from less accumulating but decreases the efficiency of the encoding.
  • FIG. 2 shows a conventional decoding system designed for the combination with the encoding system of FIG. 1.
  • variable-length digital data is fed to a decoder 22 via an input terminal 21.
  • the decoder 22 converts the variable-length data into original fixed-length data.
  • the output data from the decoder 22 is subjected to an inverse quantization by an inverse quantizer 23 so that it is converted into a representative (setting of a representative).
  • the representative outputted from the inverse quantizer 23 is subjected to an inverse orthogonal transform by an inverse transform device 24.
  • the output signal from the inverse transform device 24 corresponds to a prediction error (difference).
  • An adder 25 adds the prediction error and a one-frame preceding prediction signal, generating a digitized video signal.
  • a frame memory 27 delays the output signal from the adder 25 by a time corresponding to a period of one frame.
  • the output signal from the frame memory 27 is passed through a spatial low pass filter (a spatial LPF) 28, being converted into the prediction signal.
  • the prediction signal is fed from the spatial LPF 28 to the adder 25.
  • the spatial LPF 28 is similar to the spatial LPF 11 of the encoding system.
  • the conventional encoding system of FIG. 1 and the conventional decoding system of FIG. 2 have problems as follows.
  • a short period of resetting the inter-frame prediction is necessary to decode data from arbitrary storage locations of the recording medium during a random access or a search.
  • a visual search requires a very short period of resetting the inter-frame prediction since the decoding is performed at intervals of several frames. The short period of resetting the inter-frame prediction decreases the efficiency of encoding.
  • the inter-frame prediction uses the preceding frame but does not use the subsequent frame, the accuracy and efficiency of the prediction tends to be inadequate.
  • the inter-frame prediction tends to be unreliable.
  • frames are separated into independent frames (denoted by hatched squares) and dependent frames (white squares).
  • the independent frames are also referred to as the reference frames.
  • the independent frames are separated at predetermined equal intervals corresponding to two or more frames.
  • a predetermined number of dependent frames are present between two adjacent independent frames. Display information in an independent frame is encoded independent of other frames. Display information in a dependent frame is encoded by prediction using the preceding and subsequent independent frames.
  • FIG. 4 shows an inter-frame predictive encoding system according to a first embodiment of this invention.
  • a digitized video signal is fed to a movable contact 37c of a switch 37 via an input terminal 1.
  • the movable contact 37c of the switch 37 periodically changes between a first position and a second position at a predetermined period.
  • the movable contact 37c of the switch 37 assumes the first position, it contacts with a first fixed contact 37a of the switch 37 and separates from a second fixed contact 37b of the switch 37.
  • the movable contact 37c of the switch 37 assumes the second position, it contacts with the second fixed contact 37b of the switch 37 and separates from the first fixed contact 37a of the switch 37.
  • the frame represented by the current input video signal is defined as an independent frame. Otherwise, the frame represented by the current input video signal is defined as a dependent frame.
  • the input video signal is transmitted through the switch 37 to a first fixed contact 38a of a switch 38.
  • a movable contact 38c of the switch 38 is connected to an input terminal of an orthogonal transform device 3.
  • the movable contact 38c of the switch 38 periodically contacts with and separates from the first fixed contact 38a and a second fixed contact 38b of the switch 38 in a manner and at a timing similar to those of the switch 37.
  • the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37
  • the movable contact 38c of the switch 38 contacts with the first fixed contact 38a of the switch 38 so that the input video signal is further transmitted through the switch 38 to the orthogonal transform device 3.
  • the multi-frame memory 31 delays the input video signal by a time corresponding to a predetermined number of frames. Specifically, the delay time of the multi-frame memory 31 corresponds to (N-1) frames in the case where one independent frame occurs per N successive frames and the letter N denotes a predetermined natural number equal to two or greater.
  • the output video signal from the multi-frame memory 31 is fed to a subtracter 2.
  • the subtracter 2 substracts a prediction signal from the video signal to generate a prediction error (difference) signal. The prediction signal will be explained later.
  • the prediction error signal is outputted from the subtracter 2 to the second fixed contact 38b of the switch 38.
  • the movable contact 37c of the switch 37 contacts with the second fixed contact 37b of the switch 37
  • the movable contact 38c of the switch 38 contacts with the second fixed contact 38b of the switch 38 so that the prediction error signal is transmitted through the switch 38 to the orthogonal transform device 3.
  • the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37 while the movable contact 38c of the switch 38 contacts with the first fixed contact 38a of the switch 38.
  • the movable contact 37c of the switch 37 contacts with the second fixed contact 37b of the switch 37 while the movable contact 38c of the switch 38 contacts with the second fixed contact 38b of the switch 38.
  • the independent-frame video signal or the dependent-frame prediction error signal outputted from the subtracter 2 is subjected to an orthogonal transform by the orthogonal transform device 3.
  • the orthogonal transform increases the efficiency of encoding.
  • the output signal from the orthogonal transform device 3 is quantized by a quantizer 4.
  • the output data from the quantizer 4 is encoded by an encoder 5 into variable-length codes such as Huffman codes.
  • the codes outputted from the encoder 5 are transmitted via an output terminal 6.
  • the output data from the quantizer 4 is applied to a first fixed contact 39a of a switch 39.
  • a second fixed contact 39b of the switch 39 has no connection with other circuits.
  • the movable contact 39c of the switch 39 is connected to an input terminal of an inverse quantizer 7.
  • the movable contact 39c of the switch 39 periodically contacts with and separates from the first fixed contact 39a and a second fixed contact 39b of the switch 39 in a manner and at a timing similar to those of the switch 37. Specifically, when the output signal from the quantizer 4 represents an independent frame, the movable contact 39c of the switch 39 contacts with the first fixed contact 39a of the switch 39 so that the output signal from the quantizer 4 is transmitted to the inverse quantizer 7.
  • the movable contact 39c of the switch 39 contacts with the second fixed contact 39b of the switch 39 so that the transmission of the output signal from the quantizer 4 to the inverse quantizer 7 is interrupted. In this way, only the output signal from the quantizer 4 which represents an independent frame is transmitted to the inverse quantizer 7.
  • the independent-frame output signal from the quantizer 4 is subjected to an inverse quantization by the inverse quantizer 7 so that it is convened into a representative (setting of a representative).
  • the representative outputted from the inverse quantizer 7 is subjected to an inverse orthogonal transform by an inverse transform device 8.
  • the output signal from the inverse transform device 8 corresponds to a reproduced signal of an independent frame.
  • the output signal from the inverse transform device 8, that is, the reproduced signal of an independent frame, is written into a frame memory 32.
  • a first fixed contact 40a of a switch 40 is connected to the output terminal of the frame memory 32.
  • a second fixed contact 40b of the switch 40 has no connection with other circuits.
  • a movable contact 40c of the switch 40 is connected to an input terminal of a frame memory 33. The movable contact 40c of the switch 40 periodically contacts with and separates from the first fixed contact 40a and the second fixed contact 40b of the switch 40 in a manner and at a timing similar to those of the switch 37.
  • the movable contact 40c of the switch 40 connects with the first fixed contact 40a of the switch 40 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 32 to the frame memory 33 via the switch 40.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are prepared in the frame memory 32 and the frame memory 33 respectively.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame remain stored in the frame memory 32 and the frame memory 33 respectively until the frame memory 32 is fed with the reproduced signal of the subsequent independent frame from the inverse transform device 8.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are repeatedly outputted from the frame memory 32 and the frame memory 33 to multipliers 34 and 35 respectively. Specifically, the number of times of outputting the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame is equal to N-1.
  • the multiplier 34 multiplies the reproduced signal of the current independent frame by a weight coefficient ct and outputs the resultant to an adder 36.
  • the multiplier 35 multiplies the reproduced signal of the preceding independent frame by a weight coefficient (1- ⁇ ) and outputs the resultant to the adder 36.
  • the adder 36 adds the resultants of the multiplications, generating a prediction signal fed to the subtracter 2.
  • the weight coefficients a and (1- ⁇ ) are determined in accordance with the time relation between the dependent frame inputted into the subtracter 2 and the independent frames related to the prediction signal inputted into the subtracter 2. For example, a linear prediction is used in the determination of the weight coefficients a and (1- ⁇ ). Specifically, the weight coefficient ⁇ is given by the following equation.
  • the character m denotes the order number (1, 2, 3, . . . ) of the frame being a coded object
  • the character mp denotes the order number (0, N, 2N, . . . ) of the previous independent frame
  • the number m is larger than the number mp
  • the character N denotes a predetermined natural number equal to or larger than 2.
  • FIG. 5 shows the relation between the frame number and the level of the prediction signal (the prediction value) in the case where the number N equals 4.
  • the prediction signal the prediction value
  • a larger weight is offered to the independent frame closer to the objective dependent frame while a smaller weight is offered to the other independent frame.
  • FIG. 5 in the case where display information of dependent frames linearly varies from the display information of the preceding independent frame to the display information of the current independent frame, very accurate prediction values are presented.
  • the operation of the switches 37 and 38 determines independent frames which are separated in a time axis at equal intervals corresponding to a predetermined number of frames.
  • dependent frames are defined between independent frames.
  • the inter-frame correlation between coded data is cut at each independent frame. Therefore, a visual search is enabled by decoding only data of independent frames or by performing a random access in unit corresponding to independent frames.
  • the prediction signal is generated by adding the data of the two adjacent independent frames with variable weighting parameters.
  • the weight coefficients ⁇ and (1- ⁇ ) used in the generation of the prediction signal are determined in accordance with the time relation between the dependent frame inputted into the subtracter 2 and the independent frames related to the prediction signal inputted into the subtracter 2. Therefore, the prediction can well follow the variation of display information between successive frames, and an S/N (a signal to noise ratio) of the prediction signal can be high.
  • encoded data are arranged symmetrically on a time axis so that a reverse reproduction of data from a recording medium can be realized.
  • FIG. 11 shows a circuit for generating the switch control signal.
  • the switch control circuit includes a frame sync separator 501 which separates a frame sync signal from the input video signal.
  • the frame sync signal has a train of pulses.
  • the pulses of the frame sync signal outputted from the frame sync separator 501 are counted by a counter 502.
  • the counter 502 outputs a pulse as shown in FIG. 12.
  • the duration of each output pulse from the counter 502 agrees with the one-frame period.
  • the sequentially-outputted pulses from the counter 502 compose the switch control signals fed to the switches 37-40.
  • FIG. 6 shows an inter-frame predictive decoding system according to the first embodiment of this invention.
  • variable-length digital data is fed to a decoder 22 via an input terminal 21.
  • the decoder 22 converts the variable-length data into original fixed-length data.
  • the output data from the decoder 22 is subjected to an inverse quantization by an inverse quantizer 23 so that it is converted into a representative (setting of a representative).
  • the representative outputted from the inverse quantizer 23 is subjected to an reverse orthogonal transform by an inverse transform device 24.
  • the output signal from the inverse transform device 24 corresponds to a reproduced video signal.
  • the output signal from the inverse transform device 24 corresponds to a prediction error signal.
  • the output signal from the inverse transform device 24 is applied to a movable contact 47c of a switch 47.
  • a first fixed contact 47a of the switch 47 is connected to an input terminal of a frame memory 42.
  • a second fixed contact 47b of the switch 47 is connected to an adder 41.
  • the movable contact 47c of the switch 47 periodically changes between a first position and a second position at a predetermined period. When the movable contact 47c of the switch 47 assumes the first position, it contacts with the first fixed contact 47a of the switch 47 and separates from the second fixed contact 47b of the switch 47. When the movable contact 47c of the switch 47 assumes the second position, it contacts with the second fixed contact 47b of the switch 47 and separates from the first fixed contact 47a of the switch 47.
  • the movable contact 47c of the switch 47 contacts with the first fixed contact 47a of the switch 47 so that the independent-frame signal is fed to and written into the frame memory 42.
  • the movable contact 47c of the switch 47 contacts with the second fixed contact 47b of the switch 47 so that the dependent-frame signal is fed to the adder 41.
  • the adder 41 adds the dependent-frame signal and a prediction signal, reproducing a digitized video signal of a dependent frame.
  • the prediction signal will be explained later.
  • the adder 41 outputs the reproduced video signal of a dependent frame to a second fixed contact 48b of a switch 48.
  • a first fixed contact 48a of the switch 48 is connected to a first fixed contact 49a of a switch 49 which will be explained later.
  • a movable contact 48c of the switch 48 is connected to an output terminal 26. The movable contact 48c of the switch 48 periodically contacts with and separates from the first fixed contact 48a and the second fixed contact 48b of the switch 48 in a manner and at a timing similar to those of the switch 47.
  • the movable contact 48c of the switch 48 contacts with the second fixed contact 48b of the switch 48 so that the dependent-frame video signal is transmitted from the adder 41 to the output terminal 26 via the switch 48.
  • a movable contact 49c of a switch 49 is connected to the output terminal of the frame memory 42.
  • a first fixed contact 49a of the switch 49 is connected to an input terminal of a frame memory 43.
  • a second fixed contact 49b of the switch 49 has no connection with other circuits.
  • the movable contact 49c of the switch 49 periodically contacts with and separates from the first fixed contact 49a and the second fixed contact 49b of the switch 49 in a manner and at a timing similar to those of the switch 47.
  • the movable contact 49c of the switch 49 connects with the first fixed contact 49a of the switch 49 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 42 to the frame memory 43 via the switch 49.
  • the movable contact 48c of the switch 48 connects with the first fixed contact 48a of the switch 48 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 42 to the output terminal 26 via the switches 48 and 49.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are prepared in the frame memory 42 and the frame memory 43 respectively.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame remain stored in the frame memory 42 and the frame memory 43 respectively until the frame memory 42 is fed with the reproduced signal of the subsequent independent frame from the inverse transform device 24.
  • the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are repeatedly outputted from the frame memory 42 and the frame memory 43 to multipliers 44 and 45 respectively. Specifically, the number of times of outputting the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame is equal to N-1.
  • the multiplier 44 multiplies the reproduced signal of the current independent frame by a weight coefficient a and outputs the resultant to an adder 445.
  • the multiplier 45 multiplies the reproduced signal of the current independent frame by a weight coefficient (1- ⁇ ) and outputs the resultant to the adder 445.
  • the adder 46 adds the resultants of the multiplications, generating a prediction signal fed to the adder 41.
  • the weight coefficients ⁇ and (1- ⁇ ) are determined similarly to the determination of the weight coefficients in the encoding system of FIG. 4.
  • the switches 47-49 are changed in response to a control signal generated by a circuit similar to the circuit of FIG. 11.
  • independent frames are advanced relative to dependent frames.
  • the reproduced video signal of an independent signal is outputted from the frame memory 42 to the output terminal 26 when the prediction process related to dependent frames between two independent frames is completed. Accordingly, the frame memory 42 also functions to perform the time correction.
  • FIG. 7 shows an inter-frame predictive encoding system according to a second embodiment of this invention which is similar to the embodiment of FIG. 4 except for designs explained later.
  • the inverse quantizer 7, the inverse transform device 8, and the switch 39 are omitted while the input terminal of the frame memory 32 is connected to the first fixed contact 37a of the switch 37.
  • the independent-frame signal is also fed to the frame memory 32 and is written thereinto. Accordingly, the input video signal of independent frames is directly used in the generation of a prediction signal fed to the subtracter 2. It should be noted that, in the encoding system of FIG. 4, the resultant of the processing of the input video signal of an independent frame by the devices 3, 4, 7, and 8 is used in the generation of a prediction signal.
  • the encoding system of FIG. 7 dispenses with a decoding process.
  • the encoding system of FIG. 7 has advantages similar to those of the encoding system of FIG. 4.
  • frames are separated into independent frames and dependent frames as in the embodiment of FIGS. 3-6.
  • FIG. 8 shows an inter-frame predictive encoding system according to a third embodiment of this invention.
  • a digitized video signal is fed to a movable contact 142c of a switch 142 via an input terminal 101.
  • the movable contact 142c of the switch 142 periodically changes between a first position and a second position at a predetermined period.
  • the movable contact 142c of the switch 142 assumes the first position, it contacts with a first fixed contact 142a of the switch 142 and separates from a second fixed contact 142b of the switch 142.
  • the movable contact 142c of the switch 142 When the movable contact 142c of the switch 142 assumes the second position, it contacts with the second fixed contact 142b of the switch 142 and separates from the first fixed contact 142a of the switch 142.
  • the frame represented by the current input video signal is defined as an independent frame. Otherwise, the frame represented by the current input video signal is defined as a dependent frame.
  • the input video signal is transmitted through the switch 142 to a first fixed contact 143a of a switch 143.
  • a movable contact 143c of the switch 143 is connected to an input terminal of an orthogonal transform device 103.
  • the movable contact 143c of the switch 143 periodically contacts with and separates from the first fixed contact 143a and a second fixed contact 143b of the switch 143 in a manner and at a timing similar to those of the switch 142.
  • the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142
  • the movable contact 143c of the switch 143 contacts with the first fixed contact 143a of the switch 143 so that the input video signal is further transmitted through the switch 143 to the orthogonal transform device 103.
  • the input video signal is transmitted through the switch 142 to a multi-frame memory 131.
  • the multi-frame memory 131 delays the input video signal by a time corresponding to a predetermined number of frames. Specifically, the delay time of the multi-frame memory 131 corresponds to (N-1) frames in the case where one independent frame occurs per N successive frames and the letter N denotes a predetermined natural number equal to two or greater.
  • the output video signal from the multi-frame memory 1;31 is fed to a subtracter 102.
  • the subtracter 102 subtracts a prediction signal from the video signal to generate a prediction error (difference) signal. The prediction signal will be explained later.
  • the prediction error signal is outputted from the subtracter 102 to the second fixed contact 143b of the switch 143.
  • the movable contact 142c of the switch 142 contacts with the second fixed contact 142b of the switch 142
  • the movable contact 143c of the switch 143 contacts with the second fixed contact 143b of the switch 143 so that the prediction error signal is transmitted through the switch 143 to the orthogonal transform device 103.
  • the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142 contacts while the movable contact 143c of the switch 143 contacts with the first fixed contact 143a of the switch 143.
  • the movable contact 142c of the switch 142 contacts with the second fixed contact 142b of the switch 142 while the movable contact 143c of the switch 143 contacts with the second fixed contact 143b of the switch 143.
  • the video signal of the independent-frame or the prediction error signal of the dependent-frame outputted from the subtracter 102 is subjected to an orthogonal transform by the orthogonal transform device 103.
  • the orthogonal transform increases the efficiency of encoding.
  • the output signal from the orthogonal transform device 103 is quantized by a quantizer 104.
  • the output data from the quantizer 104 is encoded by an encoder 105 into variable-length codes such as Huffman codes.
  • the codes outputted from the encoder 105 are transmitted via an output terminal 106.
  • the independent-frame video signal is transmitted via the switch 142 and is written into a frame memory 132.
  • a movable contact 144c of a switch 144 is connected to an output terminal of the frame memory 132.
  • a first fixed contact 144a of the switch 144 is connected to an input terminal of a frame memory 133.
  • a second fixed contact 144b of the switch 144 has no connection with other circuits.
  • the movable contact 144c of the switch 144 periodically contacts with and separates from the first fixed contact 144a and the second fixed contact 144b of the switch 144 in a manner and at a timing similar to those of the switch 142.
  • the movable contact 144e of the switch 144 connects with the first fixed contact 144a of the switch 144 so that the preceding independent-frame signal is transferred from the frame memory 132 to the frame memory 133 via the switch 144.
  • the current independent-frame signal and the preceding independent-frame signal are prepared in the frame memory 132 and the frame memory 133 respectively.
  • the current independent-frame signal and the preceding independent-frame signal remain stored in the frame memory 132 and the frame memory 133 respectively until the frame memory 132 is fed with the subsequent independent-frame signal via the switch 142.
  • the current independent-frame signal and the preceding independent-frame signal are repeatedly outputted from the frame memory 132 and the frame memory 133 to position shifters 134 and 135 respectively.
  • the position shifter 134 two-dimensionally shifts the current independent-frame signal by a magnitude which is determined by a shift calculator 136.
  • the position shifter 135 shifts the preceding independent-frame signal by a magnitude which is determined by the shift calculator 136.
  • the position shifter 134 includes an address generator, and a temporal memory into and from which the current independent-frame signal is written and read in accordance with an address signal from the address generator. During the reading out the signal from the temporal memory, the address generator shifts addresses relative to the write addresses in accordance with a signal from the shift calculator 136 to provide the two dimensional shift of the current independent-frame signal.
  • the position shifter 135 is designed similarly to the position shifter 134.
  • An output signal from a vector difference detector 141 which represents a motion vector is inputted into the shift calculator 136.
  • the shift calculator 136 multiplies the motion vector by (N-i), generating a magnitude of shift fed to the position shifter 134.
  • the shift calculator 136 multiplies the motion vector by (-i), generating a magnitude of shift fed to the position shifter 135.
  • Output signals from the position shifters 134 and 135 are fed to multipliers 137 and 138 respectively.
  • the multiplier 137 multiplies the output signal from the position shifter 137 by a weight coefficient a and feeds the resultant to an adder 139.
  • the multiplier 138 multiplies the output signal from the position shifter 135 by a weight coefficient (1- ⁇ ) and feeds the resultant to the adder 139.
  • the adder 139 adds the resultants of the multiplications, generating a prediction signal fed to the subtracter 102.
  • the weight coefficient ⁇ is defined as i/N.
  • the current independent-frame video signal is transmitted via the switch 142 to a motion vector detector 140.
  • the preceding independent-frame video signal is fed from the frame memory 132 to the motion vector detector 140.
  • the motion vector detector 140 detects motion vectors from the current independent-frame signal and the preceding independent-frame signal in a known way such as a block matching method.
  • the motion vector detector 140 outputs a signal representative of the detected motion vectors to the vector difference detector 141.
  • the motion vector detector 140 includes RAMs 153 and 154 receiving the current independent-frame signal and the preceding independent frame signal via input terminals 151 and 152 respectively.
  • the current independent-frame signal and the preceding independent-frame signal are written into the RAMs 153 and 154 respectively.
  • Each of the signals stored in the RAMs 153 and 154 is divided into spatial regions whose number is greater than the number of spatial regions corresponding to blocks of 8 ⁇ 8 or 16 ⁇ 16 pixels which are used in determining motion vectors.
  • motion vectors are used for dependent frames between the current independent frame and the preceding independent frame, it is necessary to handle the two independent frames similarly. Therefore, the two frames are moved symmetrically during the determination of motion vectors.
  • addresses fed to each of the RAMs 53 and 154 are directly made by main addresses of pixels in blocks.
  • addresses fed to each of the RAMs 153 and 154 are modified by a value of motion vectors which are generated in a vector generator 55.
  • the writing of the signal into each of the RAMs 53 and 154 is performed once for each independent frame, while the reading of the signal from each of the RAMs 153 and 154 is repeatedly performed a number of times which equals the number of motion vectors.
  • the address shift is composed of a vector which is generated by a vector generator 155 in correspondence with intervals of N frames.
  • the vector generator 155 includes a counter.
  • addresses to the RAM 153 for the current independent frame are generated by adding the vector output from the vector generator 155 to an output signal from a main address generator 156. This addition is performed by an adder 157.
  • the main address generator 156 includes a counter.
  • Addresses to the RAM 154 for the preceding independent frame are generated by subtracting the vector output of the vector generator 155 from an output signal of the main address generator 156. This subtraction is performed by a subtracter 158.
  • a subtracter 159 calculates a difference between the output data from the RAMs 153 and 154.
  • a squaring device 160 calculates the square of the data difference.
  • An integrator 161 accumulates the output data from the squaring device 160 during an interval corresponding to a period of one block. The integrator 161 obtains a mean square error for a setting vector.
  • the section corresponding to a part surrounded by the broken line of FIG. 9 includes the devices 153, 154, 156, 157, 158, 159, 160, and 161. This section performs a process of detecting a mean square error. For each setting vector in each block, the detecting process is repeatedly performed a number of times which equals the number of pixels within one block.
  • the mean square errors of respective vectors are sequentially fed from the integrator 161 to a vector selector 162.
  • the vector selector 162 detects the smallest among the mean square errors and outputs the motion vector corresponding to the selected smallest mean square error as a motion vector V' representing a motion corresponding to each of blocks of one frame.
  • the vector selector 162 includes a smallest value selector of the serial input type which is composed of a combination of latches and comparators.
  • The; motion vector V' is generated for each block.
  • the motion vectors of one frame are stored into a frame memory 163. During the prediction process for dependent frames between two adjacent independent frames, the motion vectors are repeatedly read out from the frame memory 163 and are transmitted via an output terminal 164 to the vector difference detector 141.
  • the vector difference detector 141 performs a process of calculating differences between vectors in each predicted frame. As will be made clear hereinafter, some circuit components are common to the vector difference detector 141 and the motion vector detector 140.
  • the vector difference detector 141 is fed with the dependent-frame signal from the multi-frame memory 131.
  • a first fixed contact 145d and a second fixed contact 145e of a switch 145 are connected to the output terminals of the frame memories 132 and 133 respectively.
  • a movable contact 145f of the switch 145 is connected to the vector difference detector 141. The movable contact 145f of the switch 145 periodically changes between a first position and a second position at a predetermined period.
  • the movable contact 145f of the switch 145 When the movable contact 145f of the switch 145 assumes the first position, it contacts with the first fixed contact 145d of the switch 145 and separates from the second fixed contact 145e of the switch 145 so that the preceding independent-frame signal is fed from the frame memory 133 to the vector difference detector 141 via the switch 145.
  • the movable contact 145f of the switch 145 assumes the second position, it contacts with the second fixed contact 145e of the switch 145 and separates from the first fixed contact 145d of the switch 145 so that the current independent-frame signal is fed from the frame memory 132 to the vector difference detector 141 via the switch 145. In this way, the current independent-frame signal and the preceding independent-frame signal are alternately fed to the vector difference detector 141.
  • the switch 145 is changed in response to the order number of a frame so that one of the current independent-frame signal and the preceding independent-frame signal is alternately and periodically selected and fed to the vector difference detector 141. Selected one of the current independent-frame signal and the preceding independent-frame signal relates to a larger weight in the predictive calculation.
  • the vector difference detector 141 includes the RAMs 153 and 154 receiving the dependent-frame signal and the independent-frame signal via the input terminals 151 and 152 respectively.
  • the dependent-frame signal and the independent-frame signal are written into the RAMs 153 and 154 respectively.
  • the motion vector V' determined between the current independent frame and the preceding independent frame is transmitted from the motion vector detector 140 to an adder 167 via an input terminal 165.
  • the adder 167 adds the motion vector V' and an output value vd from a vector difference generator 166, generating a resultant vector.
  • the vector difference generator 166 includes a counter.
  • a known detection of motion vectors use a method in which first vectors are set at a low distribution density and then second vectors are set around the first vectors at a high distribution density.
  • the output value vd from the vector difference generator 166 corresponds to a vector difference determined in respect of setting the second vectors in the known method.
  • a multiplier 168 multiplies the resultant vector by (-i) for the preceding independent frame.
  • the multiplier 168 multiplies the resultant vector by (N-i) for the current independent frame.
  • the output signal from the multiplier 168 represents an address shift.
  • addresses fed to each of the RAMs 153 and 154 are directly made by main addresses of pixels in blocks.
  • addresses fed to the RAM 153 are also directly made by the main addresses.
  • addresses fed to the RAM 154 are made by adding an address shift to the main addresses.
  • reading addresses to the RAM 154 for the independent frame are generated by adding the address shift from the multiplier 168 to the output signal from the main address generator 156. This addition is performed by an adder 169.
  • the output signal from the main address generator 156 are fed to the RAM 153 as reading and writing addresses.
  • the subtracter 159 calculates a difference between the output data from the RAMs 153 and 154.
  • the squaring device 160 calculates the square of the data difference.
  • the integrator 161 accumulates the output data from the squaring device 160 during an interval corresponding to a period of one block.
  • the integrator 161 obtains a mean square error for a setting vector.
  • the mean square errors of respective vectors are sequentially fed from the integrator 161 to the vector selector 162.
  • the vector selector 162 detects the smallest among the mean square errors and outputs the motion vector corresponding to the detected smallest mean square error as a motion vector dV' representing a motion corresponding to each of blocks of one frame.
  • the motion vector dV' is generated for each block.
  • An adder 170 adds the motion vector dV' and the motion vector V', generating a final motion vector V.
  • the final motion vector V outputted from the adder 170 is transmitted via the output terminal 164 to the shift calculator 136 and an encoder 113 (see FIG. 8).
  • the output data from the vector difference detector 141 is encoded by the encoder 113 into variable-length codes such as Huffman codes.
  • the motion vector V' or the motion vector dV' is selected from 9 different types while the final motion vector V is selected from 49 different vectors.
  • the processing by the motion vector detector 140 and the processing by the vector difference detector 141 are performed during different periods respectively. This design enables reliable operation of the detectors 140 and 141 although the circuit components are common to the detectors 140 and 141. It should be noted that the circuit components of the detector 140 may separate from the circuit components of the detector 141.
  • a signal of a frame is coded by referring to signals of frames which precede and follow that frame. This function enables the present invention to produce new advantages such as an increase in the efficiency of encoding.
  • reference frames are independently coded in the previously-mentioned embodiments, other designs may be adopted.
  • the reference frames may be coded by use of the correlation between the reference frames to further increase the efficiency of encoding.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

In an inter-frame predictive encoding system, reference frames are set. The reference frames are separated at equal intervals. The reference frames are selected from successively inputted frames of a video signal. Each of the reference frames is encoded. A prediction signal for a dependent frame between the reference frames is generated on the basis of a signal of the reference frames which precedes and follows the dependent frame respectively. A signal of the dependent frame is generated on the basis of the prediction signal corresponding thereto. An error of the predicting of the signal of the dependent frame is encoded. .Iadd.A complementary decoding system reconstructs the video signal from the encoded reference frames and the encoded error. .Iaddend.

Description

BACKGROUND OF THE INVENTION
.Iadd.This application is a reissue of Ser. No. 07/465,747, now U.S. Pat. No. 4,985,768. .Iaddend.
This invention relates to an inter-frame predictive encoding system for a video signal.
In a general video signal, display information of a frame tends to correlate with display information of a subsequent frame and a preceding frame. In the transmission of a digitized video signal, such a correlation between successive frames is used in reducing a digital data transmission rate.
Inter-frame predictive encoding uses the correlation between successive frames to reduce the digital data transmission rate. The inter-frame predictive encoding is generally effective in handling a video signal representing moving pictures.
As will be explained later, a prior-art inter-frame predictive encoding system has some problems.
SUMMARY OF THE INVENTION
It is an object of this invention to provide an improved inter-frame predictive encoding system.
According to a first aspect of this invention, an inter-frame predictive encoding system comprises means for setting reference frames separated at equal intervals, the reference frames being selected from successively inputted frames of a video signal; means for encoding each of the reference frames; means for generating a prediction signal for a dependent frame between the reference frames on the basis of a signal of the reference frames which precedes and follows the dependent frame respectively; means for predicting a signal of the dependent frame on the basis of the prediction signal corresponding thereto; and means for encoding an error of said predicting of the signal of the dependent frame.
According to a second aspect of this invention, an inter-frame predictive encoding system comprises means for separating successively-inputted frames of a video signal into reference frames and dependent frames, the reference frames being spaced at predetermined intervals, the dependent frames residing between the reference frames; means for encoding display information of the reference frames; means for predicting display information of each dependent frame on the basis of display information of reference frames which precede and follow said dependent frame respectively; means for generating an error between the predicted display information and corresponding actual display information of said dependent frame; and means for encoding said error.
According to a third aspect of this invention, an inter-frame predictive encoding system comprises means for performing motion-compensated inter-frame prediction using motion vectors between successively inputted frames of a video signal; the improvement comprising means for setting specified frames separated at equal intervals, the specified frames being selected from successively inputted frames of a video signal; means for detecting motion vectors between the specified frames; means for detecting motion vectors between adjacent non-specified frames between the specified frames as differences with respect to said motion vectors between the specified frames.
BRIEF DESCRIPTION OF THE DRAWING
FIG. 1 is a block diagram of a conventional inter-frame predictive encoding system.
FIG. 2 is a block diagram of a conventional decoding system.
FIG. 3 is a diagram of a stream of successive frames in an inter-frame predictive encoding system and a decoding system according to a first embodiment of this invention.
FIG. 4 is a block diagram of the inter-frame predictive encoding system according to the first embodiment of this invention.
FIG. 5 is a diagram showing the relation between prediction values and successive frames in the encoding system of FIG. 4.
FIG. 6 is a block diagram of a decoding system according to the first embodiment of this invention.
FIG. 7 is a block diagram of an inter-frame predictive encoding system according to a second embodiment of this invention.
FIG. 8 is a block diagram of an inter-frame predictive encoding system according to a third embodiment of this invention.
FIG. 9 is a block diagram of the motion vector detector of FIG. 8.
FIG. 10 is a block diagram of the vector difference detector of FIG. 8.
FIG. 11 is a block diagram of a circuit for generating a control signal fed to the switches of FIG. 4.
FIG. 12 is a timing diagram of signals generated in the circuit of FIG. 11.
DESCRIPTION OF THE PRIOR ART
FIG. 1 shows a conventional inter-frame predictive encoding system. With reference to FIG. 1, a digitized video signal is fed to a subtracter 2 via an input terminal 1. The subtracter 2 subtracts a prediction digital signal from the digitized video signal to generate a prediction error (difference) signal. The prediction signal will be explained later.
The prediction error signal outputted from the substracter 2 is subjected to an orthogonal transform by an orthogonal transform device 3. The orthogonal transform increases the efficiency of encoding. The output signal from the orthogonal transform device 3 is quantized by a quantizer 4. The output data from the quantizer 4 is encoded by an encoder S into variable-length codes such as Huffman codes. The codes outputted from the encoder S are transmitted via an output terminal 6.
The output data from the quantizer 4 is subjected to an inverse quantization by an inverse quantizer 7 so that it is converted into a representative (setting of a representative). The representative outputted from the inverse quantizer 7 is subjected to an inverse orthogonal transform by an inverse transform device 8. The output signal from the inverse transform device 8 corresponds to a prediction error (difference) which is generated through a decoding process in a decoding system explained later. An adder 9 adds the prediction error and a one-frame preceding prediction signal, generating a digitized video signal which corresponds to a digitized video signal generated by a decoding process in the decoding system. A frame memory 10 delays the output signal from the adder 9 by a time corresponding to a period of one frame. The output signal from the frame memory 10 is passed through a spatial low pass filter (a spatial LPF) 11, being converted into the prediction signal. The prediction signal is fed from the spatial LPF 11 to the subtracter 2 and the adder 9 via a switch 12. The spatial LPF 11 multiples the output data from the adder 9 by a coefficient which varies with a spatial frequency. The spatial LPF 11 ensures that a quantization error remains in the prediction error at a reduced rate. The spatial LPF 11 is effective and advantageous since a larger quantity of quantization errors are present in a high-frequency range and an inter-frame correlation is weakened by noises in the high-frequency range.
The switch 12 periodically couples and uncouples the spatial LPF 11 to and from the subtracter 2 and the adder 9 to periodically reset the inter-frame prediction. The period of the resetting the inter-frame prediction is generally set so as to correspond to 30 to 100 frames. When the inter-frame prediction is being reset, the prediction signal is fixed and essentially intra-frame coding is performed. The resetting prevents calculation errors from accumulating up to an unacceptable level. The calculation error would result from error codes generated in a transmission line and mismatching between orthogonal converters of a transmitter side and a receiver side in recursive-type inter-frame predictive en coding such as shown in FIG. 1. A shorter period of the resetting enables calculating errors from less accumulating but decreases the efficiency of the encoding.
FIG. 2 shows a conventional decoding system designed for the combination with the encoding system of FIG. 1. With reference to FIG. 2, variable-length digital data is fed to a decoder 22 via an input terminal 21. The decoder 22 converts the variable-length data into original fixed-length data. The output data from the decoder 22 is subjected to an inverse quantization by an inverse quantizer 23 so that it is converted into a representative (setting of a representative). The representative outputted from the inverse quantizer 23 is subjected to an inverse orthogonal transform by an inverse transform device 24. The output signal from the inverse transform device 24 corresponds to a prediction error (difference). An adder 25 adds the prediction error and a one-frame preceding prediction signal, generating a digitized video signal. A frame memory 27 delays the output signal from the adder 25 by a time corresponding to a period of one frame. The output signal from the frame memory 27 is passed through a spatial low pass filter (a spatial LPF) 28, being converted into the prediction signal. The prediction signal is fed from the spatial LPF 28 to the adder 25. The spatial LPF 28 is similar to the spatial LPF 11 of the encoding system.
The conventional encoding system of FIG. 1 and the conventional decoding system of FIG. 2 have problems as follows. In the case where these conventional systems are used for recording and reproducing data into a storage medium such as an information recording disk or an information recording tape, a short period of resetting the inter-frame prediction is necessary to decode data from arbitrary storage locations of the recording medium during a random access or a search. Especially, a visual search requires a very short period of resetting the inter-frame prediction since the decoding is performed at intervals of several frames. The short period of resetting the inter-frame prediction decreases the efficiency of encoding.
In the case of reverse play back from the recording medium, the predictive decoding is impossible since the direction of a time axis is opposite to the direction of a time axis which occurs during the encoding and recording.
Since the inter-frame prediction uses the preceding frame but does not use the subsequent frame, the accuracy and efficiency of the prediction tends to be inadequate. When a picture represented by data changes greatly or when a scene represented by data changes, the inter-frame prediction tends to be unreliable.
Since it is necessary for the encoding system to also perform the decoding process, the structure of the encoding system tends to be complicated.
DESCRIPTION OF THE FIRST PREFERRED EMBODIMENT
In an inter-frame predictive encoding system and an inter-frame predictive decoding system according to a first embodiment of this invention, as shown in FIG. 3, frames are separated into independent frames (denoted by hatched squares) and dependent frames (white squares). The independent frames are also referred to as the reference frames. On a time axis, the independent frames are separated at predetermined equal intervals corresponding to two or more frames. A predetermined number of dependent frames are present between two adjacent independent frames. Display information in an independent frame is encoded independent of other frames. Display information in a dependent frame is encoded by prediction using the preceding and subsequent independent frames.
FIG. 4 shows an inter-frame predictive encoding system according to a first embodiment of this invention. With reference to FIG. 4, a digitized video signal is fed to a movable contact 37c of a switch 37 via an input terminal 1. The movable contact 37c of the switch 37 periodically changes between a first position and a second position at a predetermined period. When the movable contact 37c of the switch 37 assumes the first position, it contacts with a first fixed contact 37a of the switch 37 and separates from a second fixed contact 37b of the switch 37. When the movable contact 37c of the switch 37 assumes the second position, it contacts with the second fixed contact 37b of the switch 37 and separates from the first fixed contact 37a of the switch 37. As will be made clear hereinafter, when the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37, the frame represented by the current input video signal is defined as an independent frame. Otherwise, the frame represented by the current input video signal is defined as a dependent frame.
When the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37, the input video signal is transmitted through the switch 37 to a first fixed contact 38a of a switch 38. A movable contact 38c of the switch 38 is connected to an input terminal of an orthogonal transform device 3. The movable contact 38c of the switch 38 periodically contacts with and separates from the first fixed contact 38a and a second fixed contact 38b of the switch 38 in a manner and at a timing similar to those of the switch 37. Specifically, when the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37, the movable contact 38c of the switch 38 contacts with the first fixed contact 38a of the switch 38 so that the input video signal is further transmitted through the switch 38 to the orthogonal transform device 3.
When the movable contact 37c of the switch 37 contacts with the second fixed contact 37b of the switch switch 37 to a multi-frame memory 31. The multi-frame memory 31 delays the input video signal by a time corresponding to a predetermined number of frames. Specifically, the delay time of the multi-frame memory 31 corresponds to (N-1) frames in the case where one independent frame occurs per N successive frames and the letter N denotes a predetermined natural number equal to two or greater. The output video signal from the multi-frame memory 31 is fed to a subtracter 2. The subtracter 2 substracts a prediction signal from the video signal to generate a prediction error (difference) signal. The prediction signal will be explained later. The prediction error signal is outputted from the subtracter 2 to the second fixed contact 38b of the switch 38. When the movable contact 37c of the switch 37 contacts with the second fixed contact 37b of the switch 37, the movable contact 38c of the switch 38 contacts with the second fixed contact 38b of the switch 38 so that the prediction error signal is transmitted through the switch 38 to the orthogonal transform device 3.
During one-frame periods separated by equal intervals corresponding to a predetermined number of frames, that is, during periods corresponding to independent frames, the movable contact 37c of the switch 37 contacts with the first fixed contact 37a of the switch 37 while the movable contact 38c of the switch 38 contacts with the first fixed contact 38a of the switch 38. During other periods, that is, during periods corresponding to dependent frames, the movable contact 37c of the switch 37 contacts with the second fixed contact 37b of the switch 37 while the movable contact 38c of the switch 38 contacts with the second fixed contact 38b of the switch 38.
The independent-frame video signal or the dependent-frame prediction error signal outputted from the subtracter 2 is subjected to an orthogonal transform by the orthogonal transform device 3. The orthogonal transform increases the efficiency of encoding. The output signal from the orthogonal transform device 3 is quantized by a quantizer 4. The output data from the quantizer 4 is encoded by an encoder 5 into variable-length codes such as Huffman codes. The codes outputted from the encoder 5 are transmitted via an output terminal 6.
The output data from the quantizer 4 is applied to a first fixed contact 39a of a switch 39. A second fixed contact 39b of the switch 39 has no connection with other circuits. The movable contact 39c of the switch 39 is connected to an input terminal of an inverse quantizer 7. The movable contact 39c of the switch 39 periodically contacts with and separates from the first fixed contact 39a and a second fixed contact 39b of the switch 39 in a manner and at a timing similar to those of the switch 37. Specifically, when the output signal from the quantizer 4 represents an independent frame, the movable contact 39c of the switch 39 contacts with the first fixed contact 39a of the switch 39 so that the output signal from the quantizer 4 is transmitted to the inverse quantizer 7. When the output signal from the quantizer 4 represents a dependent frame, the movable contact 39c of the switch 39 contacts with the second fixed contact 39b of the switch 39 so that the transmission of the output signal from the quantizer 4 to the inverse quantizer 7 is interrupted. In this way, only the output signal from the quantizer 4 which represents an independent frame is transmitted to the inverse quantizer 7.
The independent-frame output signal from the quantizer 4 is subjected to an inverse quantization by the inverse quantizer 7 so that it is convened into a representative (setting of a representative). The representative outputted from the inverse quantizer 7 is subjected to an inverse orthogonal transform by an inverse transform device 8. The output signal from the inverse transform device 8 corresponds to a reproduced signal of an independent frame. The output signal from the inverse transform device 8, that is, the reproduced signal of an independent frame, is written into a frame memory 32.
A first fixed contact 40a of a switch 40 is connected to the output terminal of the frame memory 32. A second fixed contact 40b of the switch 40 has no connection with other circuits. A movable contact 40c of the switch 40 is connected to an input terminal of a frame memory 33. The movable contact 40c of the switch 40 periodically contacts with and separates from the first fixed contact 40a and the second fixed contact 40b of the switch 40 in a manner and at a timing similar to those of the switch 37. Specifically, when the output signal from the inverse transform device 8 which represents the current independent frame is written into the frame memory 32, the movable contact 40c of the switch 40 connects with the first fixed contact 40a of the switch 40 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 32 to the frame memory 33 via the switch 40. In this way, the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are prepared in the frame memory 32 and the frame memory 33 respectively.
The reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame remain stored in the frame memory 32 and the frame memory 33 respectively until the frame memory 32 is fed with the reproduced signal of the subsequent independent frame from the inverse transform device 8. The reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are repeatedly outputted from the frame memory 32 and the frame memory 33 to multipliers 34 and 35 respectively. Specifically, the number of times of outputting the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame is equal to N-1.
The multiplier 34 multiplies the reproduced signal of the current independent frame by a weight coefficient ct and outputs the resultant to an adder 36. The multiplier 35 multiplies the reproduced signal of the preceding independent frame by a weight coefficient (1-α) and outputs the resultant to the adder 36. The adder 36 adds the resultants of the multiplications, generating a prediction signal fed to the subtracter 2.
The weight coefficients a and (1-α) are determined in accordance with the time relation between the dependent frame inputted into the subtracter 2 and the independent frames related to the prediction signal inputted into the subtracter 2. For example, a linear prediction is used in the determination of the weight coefficients a and (1-α). Specifically, the weight coefficient α is given by the following equation.
α=(m-mp)/N
where the character m denotes the order number (1, 2, 3, . . . ) of the frame being a coded object; the character mp denotes the order number (0, N, 2N, . . . ) of the previous independent frame; the number m is larger than the number mp; and the character N denotes a predetermined natural number equal to or larger than 2.
FIG. 5 shows the relation between the frame number and the level of the prediction signal (the prediction value) in the case where the number N equals 4. In the generation of the prediction signal, a larger weight is offered to the independent frame closer to the objective dependent frame while a smaller weight is offered to the other independent frame. As understood from FIG. 5, in the case where display information of dependent frames linearly varies from the display information of the preceding independent frame to the display information of the current independent frame, very accurate prediction values are presented.
In the encoding system of FIG. 4, the operation of the switches 37 and 38 determines independent frames which are separated in a time axis at equal intervals corresponding to a predetermined number of frames. In addition, dependent frames are defined between independent frames. The inter-frame correlation between coded data is cut at each independent frame. Therefore, a visual search is enabled by decoding only data of independent frames or by performing a random access in unit corresponding to independent frames.
In the encoding system of FIG. 4, the prediction signal is generated by adding the data of the two adjacent independent frames with variable weighting parameters. Specifically, the weight coefficients α and (1-α) used in the generation of the prediction signal are determined in accordance with the time relation between the dependent frame inputted into the subtracter 2 and the independent frames related to the prediction signal inputted into the subtracter 2. Therefore, the prediction can well follow the variation of display information between successive frames, and an S/N (a signal to noise ratio) of the prediction signal can be high.
In the encoding system of FIG. 4, encoded data are arranged symmetrically on a time axis so that a reverse reproduction of data from a recording medium can be realized.
The switches 37-40 are changed in response to a switch control signal. FIG. 11 shows a circuit for generating the switch control signal. As shown in FIG. 11, the switch control circuit includes a frame sync separator 501 which separates a frame sync signal from the input video signal. As shown in FIG. 12, the frame sync signal has a train of pulses. The pulses of the frame sync signal outputted from the frame sync separator 501 are counted by a counter 502. Each time four successive pulses of the frame sync signal are counted by the counter 502, the counter 502 outputs a pulse as shown in FIG. 12. The duration of each output pulse from the counter 502 agrees with the one-frame period. The sequentially-outputted pulses from the counter 502 compose the switch control signals fed to the switches 37-40.
FIG. 6 shows an inter-frame predictive decoding system according to the first embodiment of this invention. With reference to FIG. 6, variable-length digital data is fed to a decoder 22 via an input terminal 21. The decoder 22 converts the variable-length data into original fixed-length data. The output data from the decoder 22 is subjected to an inverse quantization by an inverse quantizer 23 so that it is converted into a representative (setting of a representative). The representative outputted from the inverse quantizer 23 is subjected to an reverse orthogonal transform by an inverse transform device 24. For independent frames, the output signal from the inverse transform device 24 corresponds to a reproduced video signal. For dependent frames, the output signal from the inverse transform device 24 corresponds to a prediction error signal.
The output signal from the inverse transform device 24 is applied to a movable contact 47c of a switch 47. A first fixed contact 47a of the switch 47 is connected to an input terminal of a frame memory 42. A second fixed contact 47b of the switch 47 is connected to an adder 41. The movable contact 47c of the switch 47 periodically changes between a first position and a second position at a predetermined period. When the movable contact 47c of the switch 47 assumes the first position, it contacts with the first fixed contact 47a of the switch 47 and separates from the second fixed contact 47b of the switch 47. When the movable contact 47c of the switch 47 assumes the second position, it contacts with the second fixed contact 47b of the switch 47 and separates from the first fixed contact 47a of the switch 47. When the output signal from the inverse transform device 24 represents an independent frame, the movable contact 47c of the switch 47 contacts with the first fixed contact 47a of the switch 47 so that the independent-frame signal is fed to and written into the frame memory 42. When the output signal from the inverse transform device 24 represents a dependent frame, the movable contact 47c of the switch 47 contacts with the second fixed contact 47b of the switch 47 so that the dependent-frame signal is fed to the adder 41.
The adder 41 adds the dependent-frame signal and a prediction signal, reproducing a digitized video signal of a dependent frame. The prediction signal will be explained later. The adder 41 outputs the reproduced video signal of a dependent frame to a second fixed contact 48b of a switch 48. A first fixed contact 48a of the switch 48 is connected to a first fixed contact 49a of a switch 49 which will be explained later. A movable contact 48c of the switch 48 is connected to an output terminal 26. The movable contact 48c of the switch 48 periodically contacts with and separates from the first fixed contact 48a and the second fixed contact 48b of the switch 48 in a manner and at a timing similar to those of the switch 47. Specifically, when the adder 41 outputs the reproduced video signal of a dependent frame, the movable contact 48c of the switch 48 contacts with the second fixed contact 48b of the switch 48 so that the dependent-frame video signal is transmitted from the adder 41 to the output terminal 26 via the switch 48.
As described previously, the output signal from the inverse transform device 24 which agrees with the reproduced signal of an independent frame is written into the frame memory 42. A movable contact 49c of a switch 49 is connected to the output terminal of the frame memory 42. A first fixed contact 49a of the switch 49 is connected to an input terminal of a frame memory 43. A second fixed contact 49b of the switch 49 has no connection with other circuits. The movable contact 49c of the switch 49 periodically contacts with and separates from the first fixed contact 49a and the second fixed contact 49b of the switch 49 in a manner and at a timing similar to those of the switch 47. Specifically, when the output signal from the inverse transform device 24 represents the current independent frame and is thus written into the frame memory 42, the movable contact 49c of the switch 49 connects with the first fixed contact 49a of the switch 49 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 42 to the frame memory 43 via the switch 49. At the same time, the movable contact 48c of the switch 48 connects with the first fixed contact 48a of the switch 48 so that the reproduced signal of the preceding independent frame is transferred from the frame memory 42 to the output terminal 26 via the switches 48 and 49. As understood from the previous description, the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are prepared in the frame memory 42 and the frame memory 43 respectively.
The reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame remain stored in the frame memory 42 and the frame memory 43 respectively until the frame memory 42 is fed with the reproduced signal of the subsequent independent frame from the inverse transform device 24. The reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame are repeatedly outputted from the frame memory 42 and the frame memory 43 to multipliers 44 and 45 respectively. Specifically, the number of times of outputting the reproduced signal of the current independent frame and the reproduced signal of the preceding independent frame is equal to N-1.
The multiplier 44 multiplies the reproduced signal of the current independent frame by a weight coefficient a and outputs the resultant to an adder 445. The multiplier 45 multiplies the reproduced signal of the current independent frame by a weight coefficient (1-α) and outputs the resultant to the adder 445. The adder 46 adds the resultants of the multiplications, generating a prediction signal fed to the adder 41. The weight coefficients α and (1-α) are determined similarly to the determination of the weight coefficients in the encoding system of FIG. 4.
The switches 47-49 are changed in response to a control signal generated by a circuit similar to the circuit of FIG. 11.
During the processing of the input video signal by the encoding system of FIG. 4, independent frames are advanced relative to dependent frames. To compensate the advance of the independent frames, the reproduced video signal of an independent signal is outputted from the frame memory 42 to the output terminal 26 when the prediction process related to dependent frames between two independent frames is completed. Accordingly, the frame memory 42 also functions to perform the time correction.
DESCRIPTION OF THE SECOND PREFERRED EMBODIMENT
FIG. 7 shows an inter-frame predictive encoding system according to a second embodiment of this invention which is similar to the embodiment of FIG. 4 except for designs explained later.
In the encoding system of FIG. 7, the inverse quantizer 7, the inverse transform device 8, and the switch 39 (see FIG. 4) are omitted while the input terminal of the frame memory 32 is connected to the first fixed contact 37a of the switch 37.
When the input video signal of an independent frame is fed to the orthogonal transform device 3 via the switches 37 and 38, the independent-frame signal is also fed to the frame memory 32 and is written thereinto. Accordingly, the input video signal of independent frames is directly used in the generation of a prediction signal fed to the subtracter 2. It should be noted that, in the encoding system of FIG. 4, the resultant of the processing of the input video signal of an independent frame by the devices 3, 4, 7, and 8 is used in the generation of a prediction signal.
The encoding system of FIG. 7 dispenses with a decoding process. In addition, the encoding system of FIG. 7 has advantages similar to those of the encoding system of FIG. 4.
DESCRIPTION OF THE THIRD PREFERRED EMBODIMENT
In an inter-frame predictive encoding system according to a third embodiment of this invention, frames are separated into independent frames and dependent frames as in the embodiment of FIGS. 3-6.
FIG. 8 shows an inter-frame predictive encoding system according to a third embodiment of this invention. With reference to FIG. 8, a digitized video signal is fed to a movable contact 142c of a switch 142 via an input terminal 101. The movable contact 142c of the switch 142 periodically changes between a first position and a second position at a predetermined period. When the movable contact 142c of the switch 142 assumes the first position, it contacts with a first fixed contact 142a of the switch 142 and separates from a second fixed contact 142b of the switch 142. When the movable contact 142c of the switch 142 assumes the second position, it contacts with the second fixed contact 142b of the switch 142 and separates from the first fixed contact 142a of the switch 142. As will be made clear hereinafter, when the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142, the frame represented by the current input video signal is defined as an independent frame. Otherwise, the frame represented by the current input video signal is defined as a dependent frame.
When the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142, the input video signal is transmitted through the switch 142 to a first fixed contact 143a of a switch 143. A movable contact 143c of the switch 143 is connected to an input terminal of an orthogonal transform device 103. The movable contact 143c of the switch 143 periodically contacts with and separates from the first fixed contact 143a and a second fixed contact 143b of the switch 143 in a manner and at a timing similar to those of the switch 142. Specifically, when the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142, the movable contact 143c of the switch 143 contacts with the first fixed contact 143a of the switch 143 so that the input video signal is further transmitted through the switch 143 to the orthogonal transform device 103.
When the movable contact 142c of the switch 142 contacts with the second fixed contact 142b of the switch 142, the input video signal is transmitted through the switch 142 to a multi-frame memory 131. The multi-frame memory 131 delays the input video signal by a time corresponding to a predetermined number of frames. Specifically, the delay time of the multi-frame memory 131 corresponds to (N-1) frames in the case where one independent frame occurs per N successive frames and the letter N denotes a predetermined natural number equal to two or greater. The output video signal from the multi-frame memory 1;31 is fed to a subtracter 102. The subtracter 102 subtracts a prediction signal from the video signal to generate a prediction error (difference) signal. The prediction signal will be explained later. The prediction error signal is outputted from the subtracter 102 to the second fixed contact 143b of the switch 143. When the movable contact 142c of the switch 142 contacts with the second fixed contact 142b of the switch 142, the movable contact 143c of the switch 143 contacts with the second fixed contact 143b of the switch 143 so that the prediction error signal is transmitted through the switch 143 to the orthogonal transform device 103.
During one-frame periods separated by equal intervals corresponding to a predetermined number of frames, that is, during periods corresponding to independent frames, the movable contact 142c of the switch 142 contacts with the first fixed contact 142a of the switch 142 contacts while the movable contact 143c of the switch 143 contacts with the first fixed contact 143a of the switch 143. During other periods, that is, during periods corresponding to dependent frames, the movable contact 142c of the switch 142 contacts with the second fixed contact 142b of the switch 142 while the movable contact 143c of the switch 143 contacts with the second fixed contact 143b of the switch 143.
The video signal of the independent-frame or the prediction error signal of the dependent-frame outputted from the subtracter 102 is subjected to an orthogonal transform by the orthogonal transform device 103. The orthogonal transform increases the efficiency of encoding. The output signal from the orthogonal transform device 103 is quantized by a quantizer 104. The output data from the quantizer 104 is encoded by an encoder 105 into variable-length codes such as Huffman codes. The codes outputted from the encoder 105 are transmitted via an output terminal 106.
The independent-frame video signal is transmitted via the switch 142 and is written into a frame memory 132. A movable contact 144c of a switch 144 is connected to an output terminal of the frame memory 132. A first fixed contact 144a of the switch 144 is connected to an input terminal of a frame memory 133. A second fixed contact 144b of the switch 144 has no connection with other circuits. The movable contact 144c of the switch 144 periodically contacts with and separates from the first fixed contact 144a and the second fixed contact 144b of the switch 144 in a manner and at a timing similar to those of the switch 142. Specifically, when the current independent-frame signal is transmitted via the switch 142 and is written into the frame memory 132, the movable contact 144e of the switch 144 connects with the first fixed contact 144a of the switch 144 so that the preceding independent-frame signal is transferred from the frame memory 132 to the frame memory 133 via the switch 144. In this way, the current independent-frame signal and the preceding independent-frame signal are prepared in the frame memory 132 and the frame memory 133 respectively.
The current independent-frame signal and the preceding independent-frame signal remain stored in the frame memory 132 and the frame memory 133 respectively until the frame memory 132 is fed with the subsequent independent-frame signal via the switch 142. The current independent-frame signal and the preceding independent-frame signal are repeatedly outputted from the frame memory 132 and the frame memory 133 to position shifters 134 and 135 respectively. The position shifter 134 two-dimensionally shifts the current independent-frame signal by a magnitude which is determined by a shift calculator 136. Similarly, the position shifter 135 shifts the preceding independent-frame signal by a magnitude which is determined by the shift calculator 136.
The position shifter 134 includes an address generator, and a temporal memory into and from which the current independent-frame signal is written and read in accordance with an address signal from the address generator. During the reading out the signal from the temporal memory, the address generator shifts addresses relative to the write addresses in accordance with a signal from the shift calculator 136 to provide the two dimensional shift of the current independent-frame signal. The position shifter 135 is designed similarly to the position shifter 134.
An output signal from a vector difference detector 141 which represents a motion vector is inputted into the shift calculator 136. The shift calculator 136 multiplies the motion vector by (N-i), generating a magnitude of shift fed to the position shifter 134. In addition, the shift calculator 136 multiplies the motion vector by (-i), generating a magnitude of shift fed to the position shifter 135. The character i denotes the order number of a predicted frame which is determined in view of the time relation between frames. Specifically, the number i is 0 for each independent frame and varies as i=1, 2, 3, . . . , (N-i) for dependent frames.
Output signals from the position shifters 134 and 135 are fed to multipliers 137 and 138 respectively. The multiplier 137 multiplies the output signal from the position shifter 137 by a weight coefficient a and feeds the resultant to an adder 139. The multiplier 138 multiplies the output signal from the position shifter 135 by a weight coefficient (1-α) and feeds the resultant to the adder 139. The adder 139 adds the resultants of the multiplications, generating a prediction signal fed to the subtracter 102. For example, according to a linear prediction, the weight coefficient α is defined as i/N.
The current independent-frame video signal is transmitted via the switch 142 to a motion vector detector 140. The preceding independent-frame video signal is fed from the frame memory 132 to the motion vector detector 140. The motion vector detector 140 detects motion vectors from the current independent-frame signal and the preceding independent-frame signal in a known way such as a block matching method. The motion vector detector 140 outputs a signal representative of the detected motion vectors to the vector difference detector 141.
As shown in FIG. 9, the motion vector detector 140 includes RAMs 153 and 154 receiving the current independent-frame signal and the preceding independent frame signal via input terminals 151 and 152 respectively. The current independent-frame signal and the preceding independent-frame signal are written into the RAMs 153 and 154 respectively. Each of the signals stored in the RAMs 153 and 154 is divided into spatial regions whose number is greater than the number of spatial regions corresponding to blocks of 8×8 or 16×16 pixels which are used in determining motion vectors.
Since motion vectors are used for dependent frames between the current independent frame and the preceding independent frame, it is necessary to handle the two independent frames similarly. Therefore, the two frames are moved symmetrically during the determination of motion vectors.
During the writing of the signal into each of the RAMs 153 and 154, addresses fed to each of the RAMs 53 and 154 are directly made by main addresses of pixels in blocks. During the reading of the signal from each of the RAMs 153 and 154, addresses fed to each of the RAMs 153 and 154 are modified by a value of motion vectors which are generated in a vector generator 55. The writing of the signal into each of the RAMs 53 and 154 is performed once for each independent frame, while the reading of the signal from each of the RAMs 153 and 154 is repeatedly performed a number of times which equals the number of motion vectors. The address shift is composed of a vector which is generated by a vector generator 155 in correspondence with intervals of N frames. For example, the vector generator 155 includes a counter.
Specifically, addresses to the RAM 153 for the current independent frame are generated by adding the vector output from the vector generator 155 to an output signal from a main address generator 156. This addition is performed by an adder 157. For example, the main address generator 156 includes a counter. Addresses to the RAM 154 for the preceding independent frame are generated by subtracting the vector output of the vector generator 155 from an output signal of the main address generator 156. This subtraction is performed by a subtracter 158.
A subtracter 159 calculates a difference between the output data from the RAMs 153 and 154. A squaring device 160 calculates the square of the data difference. An integrator 161 accumulates the output data from the squaring device 160 during an interval corresponding to a period of one block. The integrator 161 obtains a mean square error for a setting vector.
The section corresponding to a part surrounded by the broken line of FIG. 9 includes the devices 153, 154, 156, 157, 158, 159, 160, and 161. This section performs a process of detecting a mean square error. For each setting vector in each block, the detecting process is repeatedly performed a number of times which equals the number of pixels within one block.
The mean square errors of respective vectors are sequentially fed from the integrator 161 to a vector selector 162. The vector selector 162 detects the smallest among the mean square errors and outputs the motion vector corresponding to the selected smallest mean square error as a motion vector V' representing a motion corresponding to each of blocks of one frame. For example, the vector selector 162 includes a smallest value selector of the serial input type which is composed of a combination of latches and comparators. The; motion vector V' is generated for each block. The motion vectors of one frame are stored into a frame memory 163. During the prediction process for dependent frames between two adjacent independent frames, the motion vectors are repeatedly read out from the frame memory 163 and are transmitted via an output terminal 164 to the vector difference detector 141.
Returning to FIG. 8, the vector difference detector 141 performs a process of calculating differences between vectors in each predicted frame. As will be made clear hereinafter, some circuit components are common to the vector difference detector 141 and the motion vector detector 140.
The vector difference detector 141 is fed with the dependent-frame signal from the multi-frame memory 131. A first fixed contact 145d and a second fixed contact 145e of a switch 145 are connected to the output terminals of the frame memories 132 and 133 respectively. A movable contact 145f of the switch 145 is connected to the vector difference detector 141. The movable contact 145f of the switch 145 periodically changes between a first position and a second position at a predetermined period. When the movable contact 145f of the switch 145 assumes the first position, it contacts with the first fixed contact 145d of the switch 145 and separates from the second fixed contact 145e of the switch 145 so that the preceding independent-frame signal is fed from the frame memory 133 to the vector difference detector 141 via the switch 145. When the movable contact 145f of the switch 145 assumes the second position, it contacts with the second fixed contact 145e of the switch 145 and separates from the first fixed contact 145d of the switch 145 so that the current independent-frame signal is fed from the frame memory 132 to the vector difference detector 141 via the switch 145. In this way, the current independent-frame signal and the preceding independent-frame signal are alternately fed to the vector difference detector 141.
Specifically, the switch 145 is changed in response to the order number of a frame so that one of the current independent-frame signal and the preceding independent-frame signal is alternately and periodically selected and fed to the vector difference detector 141. Selected one of the current independent-frame signal and the preceding independent-frame signal relates to a larger weight in the predictive calculation.
As shown in FIG. 10, the vector difference detector 141 includes the RAMs 153 and 154 receiving the dependent-frame signal and the independent-frame signal via the input terminals 151 and 152 respectively. The dependent-frame signal and the independent-frame signal are written into the RAMs 153 and 154 respectively.
The motion vector V' determined between the current independent frame and the preceding independent frame is transmitted from the motion vector detector 140 to an adder 167 via an input terminal 165. The adder 167 adds the motion vector V' and an output value vd from a vector difference generator 166, generating a resultant vector. For example, the vector difference generator 166 includes a counter.
A known detection of motion vectors use a method in which first vectors are set at a low distribution density and then second vectors are set around the first vectors at a high distribution density. The output value vd from the vector difference generator 166 corresponds to a vector difference determined in respect of setting the second vectors in the known method.
A multiplier 168 multiplies the resultant vector by (-i) for the preceding independent frame. The multiplier 168 multiplies the resultant vector by (N-i) for the current independent frame. The character i denotes the order number of a predicted frame which is determined in view of the time relation between frames. Specifically, the number i is 0 for each independent frame and varies as i=1, 2, 3, . . . , (N-i) for dependent frames. The output signal from the multiplier 168 represents an address shift.
During the writing of the signal into each of the RAMs 153 and 154, addresses fed to each of the RAMs 153 and 154 are directly made by main addresses of pixels in blocks. During the reading of the signal from the RAM 153, addresses fed to the RAM 153 are also directly made by the main addresses. During the reading of the signal from the RAM 154, addresses fed to the RAM 154 are made by adding an address shift to the main addresses.
Specifically, reading addresses to the RAM 154 for the independent frame are generated by adding the address shift from the multiplier 168 to the output signal from the main address generator 156. This addition is performed by an adder 169. The output signal from the main address generator 156 are fed to the RAM 153 as reading and writing addresses.
The subtracter 159 calculates a difference between the output data from the RAMs 153 and 154. The squaring device 160 calculates the square of the data difference. The integrator 161 accumulates the output data from the squaring device 160 during an interval corresponding to a period of one block. The integrator 161 obtains a mean square error for a setting vector.
The mean square errors of respective vectors are sequentially fed from the integrator 161 to the vector selector 162. The vector selector 162 detects the smallest among the mean square errors and outputs the motion vector corresponding to the detected smallest mean square error as a motion vector dV' representing a motion corresponding to each of blocks of one frame. The motion vector dV' is generated for each block. An adder 170 adds the motion vector dV' and the motion vector V', generating a final motion vector V. The final motion vector V outputted from the adder 170 is transmitted via the output terminal 164 to the shift calculator 136 and an encoder 113 (see FIG. 8). The output data from the vector difference detector 141 is encoded by the encoder 113 into variable-length codes such as Huffman codes.
The motion vector V' or the motion vector dV' is selected from 9 different types while the final motion vector V is selected from 49 different vectors.
The processing by the motion vector detector 140 and the processing by the vector difference detector 141 are performed during different periods respectively. This design enables reliable operation of the detectors 140 and 141 although the circuit components are common to the detectors 140 and 141. It should be noted that the circuit components of the detector 140 may separate from the circuit components of the detector 141.
ADVANTAGE OF THE INVENTION AND ANOTHER EMBODIMENT
As understood from the previous description, in this invention, a signal of a frame is coded by referring to signals of frames which precede and follow that frame. This function enables the present invention to produce new advantages such as an increase in the efficiency of encoding.
While the reference frames (the independent frames) are independently coded in the previously-mentioned embodiments, other designs may be adopted. For example, the reference frames may be coded by use of the correlation between the reference frames to further increase the efficiency of encoding.

Claims (7)

What is claimed is:
1. An inter-frame predictive encoding system comprising:
means for separating successively-inputted frames of a video signal into reference frames and dependent frames, the reference frames being spaced at predetermined intervals, the dependent frames situated between the reference frames;
means for encoding display information of the reference frames;
means for predicting display information of each dependent frame on the basis of display information of reference frames which precede and follow said dependent frame respectively;
means for generating an error between the predicted display information and corresponding actual display information of said dependent frame; and
means for encoding said error.
2. The inter-frame predictive encoding system of claim 1 wherein said predicting means comprises means for multiplying the two dimensional position of the preceding reference frame by a first predetermined weight coefficient; means for multiplying the display information of the following reference frame by a second predetermined weight coefficient; and means for predicting the display information of the dependent frame on the basis of a resultant of said multiplication between the display information and the first weight coefficient and a resultant of said multiplication between the display information and the second weight coefficient.
3. In an inter-frame predictive encoding system comprising means for performing motion-compensated inter-frame prediction using motion vectors between successively inputted frames of a video signal; the improvement comprising:
means for setting specified frames separated at equal intervals, the specified frames being selected from successively inputted frames of a video signal;
means for detecting motion vectors between the specified frames;
means for detecting motion vectors between .[.adjacent.]. .Iadd.a .Iaddend.non-specified .[.frames.]. .Iadd.frame located .Iaddend.between the specified frames .Iadd.and the specified frames .Iaddend.as differences with respect to said motion vectors between the specified frames.
4. An inter-frame predictive encoding system as recited in claim 3 further comprising:
means for generating a prediction signal for a non-specified frame between the specified frames on the basis of a signal of the specified frames which precede and follow the non-specified frame respectively;
means for generating a prediction error representing a difference between the prediction signal and a signal of the non-specified frame corresponding thereto;
encoding means for encoding said prediction error; and
means for outputting and transmitting encoded data which are generated by the encoding in the encoding means.
5. An inter-frame predictive encoding system comprising:
means for setting reference frames separated at equal intervals, the reference frames being selected from successively inputted frames of a video signal;
first encoding means for encoding each of the reference frames;
means for generating a prediction signal for a dependent frame between the reference frames on the basis of a signal of the reference frames which precede and follow the dependent frame respectively;
means for generating a prediction error representing a difference between the prediction signal and a signal of the dependent frame corresponding thereto;
second encoding means for encoding said prediction error; and
means for outputting and transmitting encoded data which are generated by the encoding in the first encoding means and the second encoding means. .Iadd.
6. A decoding system for decoding video signals encoded by the system of claim 1, said decoding system comprising:
decoding means for receiving and decoding the encoded display information of said reference frames and said encoded error, each of said decoded reference frames producing an output which corresponds to the display information for said reference frame;
prediction signal generating means for reconstructing said predicted display information for each dependent frame based upon the two reference frames which respectively precede and follow said dependent frame;
means for combining said error and said predicted display information for said dependent frame; and
means for outputting the display information for each reference and dependent frame in proper sequence to produce a video signal. .Iaddend. .Iadd.7. A decoding system for decoding video signals that have been encoded in an encoder by arranging said video signals into spaced-apart reference frames and dependent frames located therebetween; said display information of said reference frames being out from said encoder in encoded form and used therein to predict the display information for said dependent frames, said encoder generating and outputting a prediction error signal for each dependent frame corresponding to the difference between the predicted and actual display information for each dependent frame, said decoding system comprising:
decoding means for receiving and decoding each of the encoded reference frames and the prediction error signal for each of the dependent frames; and
processing means for reconstructing the display information for each dependent frame from the corresponding prediction error signal and the reference frames which precede and follow said dependent frame. .Iaddend. .Iadd.8. The decoding system in accordance with claim 7 including means for outputting the display information for said reference frames and said dependent frames in proper sequence. .Iaddend. .Iadd.9. The decoding system in accordance with claim 7, wherein said processing means includes
memory means for storing the display information of said two reference frames which respectively precede and follow said dependent frame;
means for combining weighted values of said display information for said two reference frames to generate predicted display information for said dependent frame; and
means for combining the predicted display information and the prediction error signal for each dependent frame to reconstruct the display information for each dependent frame. .Iaddend. .Iadd.10. The decoding system in accordance with claim 9, wherein said weighted values are generated by multiplying said display information by weighting coefficients selected such that the reference frame temporally closer to the dependent frame is given a greater weight. .Iaddend. .Iadd.11. The decoding system in accordance with claim 9, wherein said weighted values are generated by multiplying said display information by weighting coefficients that are selected to be linearly related to the temporal position of said dependent frame relative to the two reference frames on either side thereof. .Iaddend. .Iadd.12. The decoding system in accordance with claim 9, wherein said processing means further includes means for calculating motion vectors representative of image movement between said two reference frames and means for calculating motion-compensated predicted display information for each of said dependent frames located between said two reference frames from said motion vectors and the display information of said reference frames. .Iaddend. .Iadd.13. A method for decoding video signals that have been encoded in an encoder by arranging said video signals into spaced-apart reference frames and dependent frames located therebetween, said display information of said reference frames being output from said encoder in encoded form and used therein to predict the display information for said dependent frames, said encoder generating and outputting a prediction error signal for each dependent frame corresponding to the difference between the predicted and actual display information for each dependent frame, said method comprising the steps of:
(a) receiving and decoding each of the encoded reference frames and the prediction error signal for each of the dependent frames;
(b) reconstructing the display information for each dependent frame from the corresponding prediction error signal and the reference frames which precede and follow said dependent frame; and
(c) outputting the display information for said reference frames and said dependent frames in proper sequence to generate a video signal. .Iaddend. .Iadd.14. The method in accordance with claim 13 wherein step (b) includes the steps of;
storing the display information of said two reference frames which respectively precede and follow each dependent frame;
combining weighted values of said display information for said two reference frames to generate predicted display information for said dependent frame; and
combining the predicted display information and the prediction error signal for each dependent frame to reconstruct the display information for each
dependent frame. .Iaddend. .Iadd.15. The method in accordance with claim 14 wherein said weighted values are generated by multiplying said display information for said two reference frames by weighting coefficients selected such that the reference frame temporally closer to the dependent frame is given a greater weight. .Iaddend. .Iadd.16. The method in accordance with claim 13, wherein step (b) includes the steps of;
calculating motion vectors representative of image movement between said two reference frames; and
calculating motion-compensated predicted display information for each of said dependent frames located between said two frames from said motion vectors and the display information of said two reference frames. .Iaddend.
US08/004,689 1989-01-20 1993-01-14 Inter-frame predictive encoding system with encoded and transmitted prediction error Expired - Lifetime USRE34965E (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US08/004,689 USRE34965E (en) 1989-01-20 1993-01-14 Inter-frame predictive encoding system with encoded and transmitted prediction error

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
JP1-11587 1989-01-20
JP1158789A JP2530217B2 (en) 1989-01-20 1989-01-20 Interframe predictive coding device and decoding device
JP1-34161 1989-02-14
JP1034161A JPH07112283B2 (en) 1989-02-14 1989-02-14 Motion vector detection device and detection method
US07/465,747 US4985768A (en) 1989-01-20 1990-01-18 Inter-frame predictive encoding system with encoded and transmitted prediction error
US08/004,689 USRE34965E (en) 1989-01-20 1993-01-14 Inter-frame predictive encoding system with encoded and transmitted prediction error

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US07/465,747 Reissue US4985768A (en) 1989-01-20 1990-01-18 Inter-frame predictive encoding system with encoded and transmitted prediction error

Publications (1)

Publication Number Publication Date
USRE34965E true USRE34965E (en) 1995-06-13

Family

ID=26347033

Family Applications (2)

Application Number Title Priority Date Filing Date
US07/465,747 Ceased US4985768A (en) 1989-01-20 1990-01-18 Inter-frame predictive encoding system with encoded and transmitted prediction error
US08/004,689 Expired - Lifetime USRE34965E (en) 1989-01-20 1993-01-14 Inter-frame predictive encoding system with encoded and transmitted prediction error

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US07/465,747 Ceased US4985768A (en) 1989-01-20 1990-01-18 Inter-frame predictive encoding system with encoded and transmitted prediction error

Country Status (4)

Country Link
US (2) US4985768A (en)
EP (2) EP0572046B1 (en)
DE (2) DE69030819T2 (en)
HK (2) HK1001183A1 (en)

Cited By (40)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5818534A (en) * 1991-10-31 1998-10-06 Victor Company Of Japan, Ltd. Video signal interframe predictive coding apparatus using motion detection
US20010053183A1 (en) * 1998-04-02 2001-12-20 Mcveigh Jeffrey S. Method and apparatus for simplifying field prediction motion estimation
US6408029B1 (en) 1998-04-02 2002-06-18 Intel Corporation Method and apparatus for simplifying real-time data encoding
US6490321B1 (en) 1998-03-19 2002-12-03 Victor Company Of Japan, Ltd. Apparatus and method of encoding/decoding moving picture using second encoder/decoder to transform predictive error signal for each field
US20040008899A1 (en) * 2002-07-05 2004-01-15 Alexandros Tourapis Optimization techniques for data compression
US6709387B1 (en) * 2000-05-15 2004-03-23 Given Imaging Ltd. System and method for controlling in vivo camera capture and display rate
US6731809B1 (en) 1998-04-28 2004-05-04 Brother Kogyo Kabushiki Kaisha Moving picture data compression device
US20050013497A1 (en) * 2003-07-18 2005-01-20 Microsoft Corporation Intraframe and interframe interlace coding and decoding
US20050025368A1 (en) * 2003-06-26 2005-02-03 Arkady Glukhovsky Device, method, and system for reduced transmission imaging
US20050053292A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Advanced bi-directional predictive coding of interlaced video
US20050053295A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Chroma motion vector derivation for interlaced forward-predicted fields
US20050053294A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Chroma motion vector derivation
US20060072662A1 (en) * 2002-01-25 2006-04-06 Microsoft Corporation Improved Video Coding
US7046734B2 (en) 1998-04-02 2006-05-16 Intel Corporation Method and apparatus for performing real-time data encoding
US20060280253A1 (en) * 2002-07-19 2006-12-14 Microsoft Corporation Timestamp-Independent Motion Vector Prediction for Predictive (P) and Bidirectionally Predictive (B) Pictures
US20070014358A1 (en) * 2002-06-03 2007-01-18 Microsoft Corporation Spatiotemporal prediction for bidirectionally predictive(B) pictures and motion vector prediction for multi-picture reference motion compensation
US20070036222A1 (en) * 2005-08-12 2007-02-15 Microsoft Corporation Non-zero coefficient block pattern coding
US20070116117A1 (en) * 2005-11-18 2007-05-24 Apple Computer, Inc. Controlling buffer states in video compression coding to enable editing and distributed encoding
US20070116115A1 (en) * 2005-11-18 2007-05-24 Xin Tong Video bit rate control method
US20070116437A1 (en) * 2005-11-18 2007-05-24 Apple Computer, Inc. Region-based processing of predicted pixels
US7224731B2 (en) 2002-06-28 2007-05-29 Microsoft Corporation Motion estimation/compensation for screen capture video
US7408990B2 (en) 1998-11-30 2008-08-05 Microsoft Corporation Efficient motion vector coding for video compression
US7499495B2 (en) 2003-07-18 2009-03-03 Microsoft Corporation Extended range motion vectors
US7567617B2 (en) 2003-09-07 2009-07-28 Microsoft Corporation Predicting motion vectors for fields of forward-predicted interlaced video frames
US7577200B2 (en) 2003-09-07 2009-08-18 Microsoft Corporation Extended range variable length coding/decoding of differential motion vector information
US7599438B2 (en) 2003-09-07 2009-10-06 Microsoft Corporation Motion vector block pattern coding and decoding
US7609763B2 (en) 2003-07-18 2009-10-27 Microsoft Corporation Advanced bi-directional predictive coding of video frames
US7616692B2 (en) 2003-09-07 2009-11-10 Microsoft Corporation Hybrid motion vector prediction for interlaced forward-predicted fields
US7620106B2 (en) 2003-09-07 2009-11-17 Microsoft Corporation Joint coding and decoding of a reference field selection and differential motion vector information
US7623574B2 (en) 2003-09-07 2009-11-24 Microsoft Corporation Selecting between dominant and non-dominant motion vector predictor polarities
US20090300204A1 (en) * 2008-05-30 2009-12-03 Microsoft Corporation Media streaming using an index file
US7672369B2 (en) 2002-02-13 2010-03-02 Reify Corporation Method and apparatus for acquisition, compression, and characterization of spatiotemporal signals
US7738554B2 (en) 2003-07-18 2010-06-15 Microsoft Corporation DC coefficient signaling at small quantization step sizes
US8031777B2 (en) 2005-11-18 2011-10-04 Apple Inc. Multipass video encoding and rate control using subsampling of frames
US8189666B2 (en) 2009-02-02 2012-05-29 Microsoft Corporation Local picture identifier and computation of co-located information
US8254455B2 (en) 2007-06-30 2012-08-28 Microsoft Corporation Computing collocated macroblock information for direct mode macroblocks
US8687697B2 (en) 2003-07-18 2014-04-01 Microsoft Corporation Coding of motion vector information
US8780997B2 (en) 2005-11-18 2014-07-15 Apple Inc. Regulation of decode-side processing based on perceptual masking
US8911360B2 (en) 2009-11-20 2014-12-16 Given Imaging Ltd. System and method for controlling power consumption of an in vivo device
US10554985B2 (en) 2003-07-18 2020-02-04 Microsoft Technology Licensing, Llc DC coefficient signaling at small quantization step sizes

Families Citing this family (65)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2521145B2 (en) * 1989-02-20 1996-07-31 日本ビクター株式会社 Motion compensated predictive coding / decoding system
JP3159309B2 (en) * 1989-09-27 2001-04-23 ソニー株式会社 Video signal encoding method and video signal encoding device
EP0424026B1 (en) * 1989-10-14 1997-07-23 Sony Corporation Video signal transmitting system and method
JP3159310B2 (en) * 1989-10-14 2001-04-23 ソニー株式会社 Video signal encoding method and video signal encoding device
US5146326A (en) * 1989-11-14 1992-09-08 Fujitsu Limited Coded picture information decoding apparatus having means for improving picture distortion
JPH07112284B2 (en) * 1990-01-20 1995-11-29 日本ビクター株式会社 Predictive encoding device and decoding device
FR2660138B1 (en) * 1990-03-26 1992-06-12 France Telecom Cnet DEVICE FOR CODING / DECODING IMAGE SIGNALS.
JP2885322B2 (en) * 1990-03-27 1999-04-19 日本ビクター株式会社 Inter-field prediction encoding device and decoding device
US5134480A (en) * 1990-08-31 1992-07-28 The Trustees Of Columbia University In The City Of New York Time-recursive deinterlace processing for television-type signals
JPH05503828A (en) * 1990-12-05 1993-06-17 ドイチェ・アイテイーテイー・インダストリーズ・ゲゼルシャフト・ミト・ベシュレンクタ・ハフツンク How to encode and decode video data of an image sequence
US5305400A (en) * 1990-12-05 1994-04-19 Deutsche Itt Industries Gmbh Method of encoding and decoding the video data of an image sequence
JP2514111B2 (en) * 1990-12-28 1996-07-10 日本ビクター株式会社 Interframe coded output data amount control method and image coded output data amount control method
JP2855861B2 (en) * 1991-01-16 1999-02-10 日本ビクター株式会社 Inter-frame / inter-field predictive encoding apparatus and method
JP3070110B2 (en) * 1991-02-27 2000-07-24 日本電気株式会社 Video signal transmission system
US5151784A (en) * 1991-04-30 1992-09-29 At&T Bell Laboratories Multiple frame motion estimation
AU657510B2 (en) * 1991-05-24 1995-03-16 Apple Inc. Improved image encoding/decoding method and apparatus
US5349348A (en) * 1991-08-15 1994-09-20 International Business Machines Corporation Multi-mode data stream generator
US5198901A (en) * 1991-09-23 1993-03-30 Matsushita Electric Corporation Of America Derivation and use of motion vectors in a differential pulse code modulation system
JPH0595540A (en) * 1991-09-30 1993-04-16 Sony Corp Dynamic picture encoder
JP2606508B2 (en) * 1991-10-29 1997-05-07 日本ビクター株式会社 Video prediction encoding apparatus and decoding apparatus therefor
JP2802694B2 (en) * 1991-10-30 1998-09-24 富士写真フイルム株式会社 Image reproducing apparatus and method
JPH05137131A (en) * 1991-11-13 1993-06-01 Sony Corp Inter-frame motion predicting method
JP2646921B2 (en) * 1991-11-15 1997-08-27 日本ビクター株式会社 Adaptive quantizer
JPH05236466A (en) * 1992-02-25 1993-09-10 Nec Corp Device and method for inter-frame predictive image encoding for motion compensation
US5293229A (en) * 1992-03-27 1994-03-08 Matsushita Electric Corporation Of America Apparatus and method for processing groups of fields in a video data compression system
US5329313A (en) * 1992-04-01 1994-07-12 Intel Corporation Method and apparatus for real time compression and decompression of a digital motion video signal using a fixed Huffman table
JPH05308630A (en) * 1992-04-28 1993-11-19 Victor Co Of Japan Ltd Motion vector detecting method
KR950004124B1 (en) * 1992-05-19 1995-04-25 주식회사금성사 Image motion compensation apparatus
US5461423A (en) * 1992-05-29 1995-10-24 Sony Corporation Apparatus for generating a motion vector with half-pixel precision for use in compressing a digital motion picture signal
EP0574746A1 (en) * 1992-06-19 1993-12-22 Intel Corporation Method and apparatus for real time compression and decompression of a digital motion video signal using a fixed Huffman table
JP3443867B2 (en) * 1992-06-26 2003-09-08 ソニー株式会社 Image signal encoding / decoding method and image signal recording medium
US5353061A (en) * 1992-10-08 1994-10-04 International Business Machines Corporation System and method for frame-differencing video compression/decompression using perceptually-constant information and image analysis
US5298992A (en) * 1992-10-08 1994-03-29 International Business Machines Corporation System and method for frame-differencing based video compression/decompression with forward and reverse playback capability
US5436666A (en) * 1993-05-21 1995-07-25 Intel Corporation Limited-domain motion estimation/compensation for video encoding/decoding
JPH0730896A (en) * 1993-06-25 1995-01-31 Matsushita Electric Ind Co Ltd Moving vector coding and decoding method
JP2947389B2 (en) * 1993-07-12 1999-09-13 日本ビクター株式会社 Image processing memory integrated circuit
TW297202B (en) * 1993-10-13 1997-02-01 Rca Thomson Licensing Corp
US5706386A (en) * 1994-05-24 1998-01-06 Sony Corporation Image information recording method and apparatus, image information reproducing method and apparatus and editing method and system
NO942080D0 (en) * 1994-06-03 1994-06-03 Int Digital Tech Inc Picture Codes
BR9508764A (en) 1994-08-24 1998-01-13 Siemens Ag Process for recoding compressed video data with reduced memory requirement
GB2305797B (en) * 1995-09-27 2000-03-01 Sony Uk Ltd Video data compression
US6571361B1 (en) * 1995-09-29 2003-05-27 Kabushiki Kaisha Toshiba Encoder and decoder
JP3676525B2 (en) * 1996-10-30 2005-07-27 日本ビクター株式会社 Moving picture coding / decoding apparatus and method
JP3348612B2 (en) * 1996-10-31 2002-11-20 日本ビクター株式会社 Inter-block prediction coding device, inter-block prediction decoding device, inter-block prediction coding method, inter-block prediction decoding method, and inter-block prediction coding / decoding device
JP3164031B2 (en) 1997-05-30 2001-05-08 日本ビクター株式会社 Moving image encoding / decoding device, moving image encoding / decoding method, and moving image encoded recording medium
US6351545B1 (en) 1999-12-14 2002-02-26 Dynapel Systems, Inc. Motion picture enhancing system
JP4011327B2 (en) * 2000-11-15 2007-11-21 株式会社レクサー・リサーチ Display object providing apparatus, display object providing method, and display object providing program
US20020135695A1 (en) * 2001-03-26 2002-09-26 Edelson Steven D. Video data reduction by selected frame elimination
JP2002354476A (en) * 2001-05-24 2002-12-06 Pioneer Electronic Corp Quantization unit setting device and method therefor, encoding device and encoding method, information recording medium, and quantization unit setting program
US7266150B2 (en) 2001-07-11 2007-09-04 Dolby Laboratories, Inc. Interpolation of video compression frames
US8111754B1 (en) 2001-07-11 2012-02-07 Dolby Laboratories Licensing Corporation Interpolation of video compression frames
SG152047A1 (en) * 2002-01-18 2009-05-29 Toshiba Kk Video encoding method and apparatus and video decoding method and apparatus
KR20020059269A (en) * 2002-06-04 2002-07-12 신승엽 Aromatic matter and capsule for flowerpot
US8406301B2 (en) * 2002-07-15 2013-03-26 Thomson Licensing Adaptive weighting of reference pictures in video encoding
US7376186B2 (en) * 2002-07-15 2008-05-20 Thomson Licensing Motion estimation with weighting prediction
US7903742B2 (en) * 2002-07-15 2011-03-08 Thomson Licensing Adaptive weighting of reference pictures in video decoding
US7020200B2 (en) * 2002-08-13 2006-03-28 Lsi Logic Corporation System and method for direct motion vector prediction in bi-predictive video frames and fields
US7813429B2 (en) * 2002-08-13 2010-10-12 Lsi Corporation System and method for segmentation of macroblocks
CN1689242B (en) * 2002-10-01 2011-09-14 汤姆森许可贸易公司 Implicit weighting of reference pictures in a video decoder
US7801217B2 (en) * 2002-10-01 2010-09-21 Thomson Licensing Implicit weighting of reference pictures in a video encoder
JP4752631B2 (en) * 2006-06-08 2011-08-17 株式会社日立製作所 Image coding apparatus and image coding method
CN100551063C (en) * 2006-11-30 2009-10-14 中兴通讯股份有限公司 The method that a kind of multimedia broadcasting (DMB) channels is play fast
EP2051524A1 (en) * 2007-10-15 2009-04-22 Panasonic Corporation Image enhancement considering the prediction error
US9445121B2 (en) 2008-08-04 2016-09-13 Dolby Laboratories Licensing Corporation Overlapped block disparity estimation and compensation architecture
US8320455B2 (en) * 2009-03-05 2012-11-27 Qualcomm Incorporated System and method to process motion vectors of video data

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4383272A (en) * 1981-04-13 1983-05-10 Bell Telephone Laboratories, Incorporated Video signal interpolation using motion estimation
JPS61248692A (en) * 1985-04-26 1986-11-05 Hitachi Ltd Detector for inter-frame motion vector of television signal

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
GB2195216B (en) * 1986-09-01 1990-11-21 British Broadcasting Corp Video transmission system

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4383272A (en) * 1981-04-13 1983-05-10 Bell Telephone Laboratories, Incorporated Video signal interpolation using motion estimation
JPS61248692A (en) * 1985-04-26 1986-11-05 Hitachi Ltd Detector for inter-frame motion vector of television signal

Cited By (95)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5818534A (en) * 1991-10-31 1998-10-06 Victor Company Of Japan, Ltd. Video signal interframe predictive coding apparatus using motion detection
US6490321B1 (en) 1998-03-19 2002-12-03 Victor Company Of Japan, Ltd. Apparatus and method of encoding/decoding moving picture using second encoder/decoder to transform predictive error signal for each field
US7215384B2 (en) 1998-04-02 2007-05-08 Intel Corporation Method and apparatus for simplifying field prediction motion estimation
US6408029B1 (en) 1998-04-02 2002-06-18 Intel Corporation Method and apparatus for simplifying real-time data encoding
US6574278B1 (en) 1998-04-02 2003-06-03 Intel Corporation Method and apparatus for performing real-time data encoding
US7263127B1 (en) 1998-04-02 2007-08-28 Intel Corporation Method and apparatus for simplifying frame-based motion estimation
US20010053183A1 (en) * 1998-04-02 2001-12-20 Mcveigh Jeffrey S. Method and apparatus for simplifying field prediction motion estimation
US7046734B2 (en) 1998-04-02 2006-05-16 Intel Corporation Method and apparatus for performing real-time data encoding
US6731809B1 (en) 1998-04-28 2004-05-04 Brother Kogyo Kabushiki Kaisha Moving picture data compression device
US7231091B2 (en) 1998-09-21 2007-06-12 Intel Corporation Simplified predictive video encoder
US20050265615A1 (en) * 1998-09-21 2005-12-01 Michael Keith Simplified predictive video encoder
US7408990B2 (en) 1998-11-30 2008-08-05 Microsoft Corporation Efficient motion vector coding for video compression
US6904174B1 (en) 1998-12-11 2005-06-07 Intel Corporation Simplified predictive video encoder
US20040073087A1 (en) * 2000-05-15 2004-04-15 Arkady Glukhovsky System and method for controlling in vivo camera capture and display rate
US20050110881A1 (en) * 2000-05-15 2005-05-26 Arkady Glukhovsky System and method for in-vivo imaging
US6709387B1 (en) * 2000-05-15 2004-03-23 Given Imaging Ltd. System and method for controlling in vivo camera capture and display rate
US8159549B2 (en) 2000-05-15 2012-04-17 Given Imaging Ltd. System and method for in-vivo imaging
US7022067B2 (en) 2000-05-15 2006-04-04 Given Imaging Ltd. System and method for controlling in vivo camera capture and display rate
US8406300B2 (en) 2002-01-25 2013-03-26 Microsoft Corporation Video coding
US20060072662A1 (en) * 2002-01-25 2006-04-06 Microsoft Corporation Improved Video Coding
US7646810B2 (en) 2002-01-25 2010-01-12 Microsoft Corporation Video coding
US8638853B2 (en) 2002-01-25 2014-01-28 Microsoft Corporation Video coding
US20090245373A1 (en) * 2002-01-25 2009-10-01 Microsoft Corporation Video coding
US9888237B2 (en) 2002-01-25 2018-02-06 Microsoft Technology Licensing, Llc Video coding
US10284843B2 (en) 2002-01-25 2019-05-07 Microsoft Technology Licensing, Llc Video coding
US20100135390A1 (en) * 2002-01-25 2010-06-03 Microsoft Corporation Video coding
US7672369B2 (en) 2002-02-13 2010-03-02 Reify Corporation Method and apparatus for acquisition, compression, and characterization of spatiotemporal signals
US20100104203A1 (en) * 2002-02-13 2010-04-29 Reify Corporation Method and Apparatus for Acquisition, Compression, and Characterization of Spatiotemporal Signals
US9001884B2 (en) 2002-02-13 2015-04-07 Reify Corporation Method and apparatus for acquisition, compression, and characterization of spatiotemporal signals
US9571854B2 (en) 2002-06-03 2017-02-14 Microsoft Technology Licensing, Llc Spatiotemporal prediction for bidirectionally predictive (B) pictures and motion vector prediction for multi-picture reference motion compensation
US8873630B2 (en) 2002-06-03 2014-10-28 Microsoft Corporation Spatiotemporal prediction for bidirectionally predictive (B) pictures and motion vector prediction for multi-picture reference motion compensation
US9185427B2 (en) 2002-06-03 2015-11-10 Microsoft Technology Licensing, Llc Spatiotemporal prediction for bidirectionally predictive (B) pictures and motion vector prediction for multi-picture reference motion compensation
US8374245B2 (en) 2002-06-03 2013-02-12 Microsoft Corporation Spatiotemporal prediction for bidirectionally predictive(B) pictures and motion vector prediction for multi-picture reference motion compensation
US20070014358A1 (en) * 2002-06-03 2007-01-18 Microsoft Corporation Spatiotemporal prediction for bidirectionally predictive(B) pictures and motion vector prediction for multi-picture reference motion compensation
US10116959B2 (en) 2002-06-03 2018-10-30 Microsoft Technology Licesning, LLC Spatiotemporal prediction for bidirectionally predictive (B) pictures and motion vector prediction for multi-picture reference motion compensation
US7224731B2 (en) 2002-06-28 2007-05-29 Microsoft Corporation Motion estimation/compensation for screen capture video
US20040008899A1 (en) * 2002-07-05 2004-01-15 Alexandros Tourapis Optimization techniques for data compression
US7280700B2 (en) 2002-07-05 2007-10-09 Microsoft Corporation Optimization techniques for data compression
US8379722B2 (en) 2002-07-19 2013-02-19 Microsoft Corporation Timestamp-independent motion vector prediction for predictive (P) and bidirectionally predictive (B) pictures
US20060280253A1 (en) * 2002-07-19 2006-12-14 Microsoft Corporation Timestamp-Independent Motion Vector Prediction for Predictive (P) and Bidirectionally Predictive (B) Pictures
US8774280B2 (en) 2002-07-19 2014-07-08 Microsoft Corporation Timestamp-independent motion vector prediction for predictive (P) and bidirectionally predictive (B) pictures
US20050025368A1 (en) * 2003-06-26 2005-02-03 Arkady Glukhovsky Device, method, and system for reduced transmission imaging
US7492935B2 (en) 2003-06-26 2009-02-17 Given Imaging Ltd Device, method, and system for reduced transmission imaging
US7609763B2 (en) 2003-07-18 2009-10-27 Microsoft Corporation Advanced bi-directional predictive coding of video frames
US8687697B2 (en) 2003-07-18 2014-04-01 Microsoft Corporation Coding of motion vector information
US9148668B2 (en) 2003-07-18 2015-09-29 Microsoft Technology Licensing, Llc Coding of motion vector information
US7499495B2 (en) 2003-07-18 2009-03-03 Microsoft Corporation Extended range motion vectors
US8917768B2 (en) 2003-07-18 2014-12-23 Microsoft Corporation Coding of motion vector information
US10063863B2 (en) 2003-07-18 2018-08-28 Microsoft Technology Licensing, Llc DC coefficient signaling at small quantization step sizes
US10554985B2 (en) 2003-07-18 2020-02-04 Microsoft Technology Licensing, Llc DC coefficient signaling at small quantization step sizes
US7426308B2 (en) 2003-07-18 2008-09-16 Microsoft Corporation Intraframe and interframe interlace coding and decoding
US10659793B2 (en) 2003-07-18 2020-05-19 Microsoft Technology Licensing, Llc DC coefficient signaling at small quantization step sizes
US7738554B2 (en) 2003-07-18 2010-06-15 Microsoft Corporation DC coefficient signaling at small quantization step sizes
US20050013497A1 (en) * 2003-07-18 2005-01-20 Microsoft Corporation Intraframe and interframe interlace coding and decoding
US9313509B2 (en) 2003-07-18 2016-04-12 Microsoft Technology Licensing, Llc DC coefficient signaling at small quantization step sizes
US7623574B2 (en) 2003-09-07 2009-11-24 Microsoft Corporation Selecting between dominant and non-dominant motion vector predictor polarities
US7529302B2 (en) 2003-09-07 2009-05-05 Microsoft Corporation Four motion vector coding and decoding in bi-directionally predicted interlaced pictures
US20050053292A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Advanced bi-directional predictive coding of interlaced video
US7924920B2 (en) 2003-09-07 2011-04-12 Microsoft Corporation Motion vector coding and decoding in interlaced frame coded pictures
US20050053295A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Chroma motion vector derivation for interlaced forward-predicted fields
US20050053294A1 (en) * 2003-09-07 2005-03-10 Microsoft Corporation Chroma motion vector derivation
US8064520B2 (en) 2003-09-07 2011-11-22 Microsoft Corporation Advanced bi-directional predictive coding of interlaced video
US7680185B2 (en) 2003-09-07 2010-03-16 Microsoft Corporation Self-referencing bi-directionally predicted frames
US7317839B2 (en) 2003-09-07 2008-01-08 Microsoft Corporation Chroma motion vector derivation for interlaced forward-predicted fields
US7352905B2 (en) 2003-09-07 2008-04-01 Microsoft Corporation Chroma motion vector derivation
US7852936B2 (en) 2003-09-07 2010-12-14 Microsoft Corporation Motion vector prediction in bi-directionally predicted interlaced field-coded pictures
US7567617B2 (en) 2003-09-07 2009-07-28 Microsoft Corporation Predicting motion vectors for fields of forward-predicted interlaced video frames
US7577200B2 (en) 2003-09-07 2009-08-18 Microsoft Corporation Extended range variable length coding/decoding of differential motion vector information
US7664177B2 (en) 2003-09-07 2010-02-16 Microsoft Corporation Intra-coded fields for bi-directional frames
US7630438B2 (en) 2003-09-07 2009-12-08 Microsoft Corporation Direct mode motion vectors for Bi-directionally predicted interlaced pictures
US7590179B2 (en) 2003-09-07 2009-09-15 Microsoft Corporation Bitplane coding of prediction mode information in bi-directionally predicted interlaced pictures
US8625669B2 (en) 2003-09-07 2014-01-07 Microsoft Corporation Predicting motion vectors for fields of forward-predicted interlaced video frames
US7620106B2 (en) 2003-09-07 2009-11-17 Microsoft Corporation Joint coding and decoding of a reference field selection and differential motion vector information
US7616692B2 (en) 2003-09-07 2009-11-10 Microsoft Corporation Hybrid motion vector prediction for interlaced forward-predicted fields
US7599438B2 (en) 2003-09-07 2009-10-06 Microsoft Corporation Motion vector block pattern coding and decoding
US9077960B2 (en) 2005-08-12 2015-07-07 Microsoft Corporation Non-zero coefficient block pattern coding
US20070036222A1 (en) * 2005-08-12 2007-02-15 Microsoft Corporation Non-zero coefficient block pattern coding
US8295343B2 (en) 2005-11-18 2012-10-23 Apple Inc. Video bit rate control method
US20070116115A1 (en) * 2005-11-18 2007-05-24 Xin Tong Video bit rate control method
US10382750B2 (en) 2005-11-18 2019-08-13 Apple Inc. Region-based processing of predicted pixels
US8780997B2 (en) 2005-11-18 2014-07-15 Apple Inc. Regulation of decode-side processing based on perceptual masking
US9049451B2 (en) 2005-11-18 2015-06-02 Apple Inc. Region-based processing of predicted pixels
US8031777B2 (en) 2005-11-18 2011-10-04 Apple Inc. Multipass video encoding and rate control using subsampling of frames
US8233535B2 (en) 2005-11-18 2012-07-31 Apple Inc. Region-based processing of predicted pixels
US20070116117A1 (en) * 2005-11-18 2007-05-24 Apple Computer, Inc. Controlling buffer states in video compression coding to enable editing and distributed encoding
US20070116437A1 (en) * 2005-11-18 2007-05-24 Apple Computer, Inc. Region-based processing of predicted pixels
US9706201B2 (en) 2005-11-18 2017-07-11 Apple Inc. Region-based processing of predicted pixels
US8254455B2 (en) 2007-06-30 2012-08-28 Microsoft Corporation Computing collocated macroblock information for direct mode macroblocks
US20090300204A1 (en) * 2008-05-30 2009-12-03 Microsoft Corporation Media streaming using an index file
US8819754B2 (en) 2008-05-30 2014-08-26 Microsoft Corporation Media streaming with enhanced seek operation
US8370887B2 (en) 2008-05-30 2013-02-05 Microsoft Corporation Media streaming with enhanced seek operation
US7949775B2 (en) 2008-05-30 2011-05-24 Microsoft Corporation Stream selection for enhanced media streaming
US7925774B2 (en) 2008-05-30 2011-04-12 Microsoft Corporation Media streaming using an index file
US8189666B2 (en) 2009-02-02 2012-05-29 Microsoft Corporation Local picture identifier and computation of co-located information
US8911360B2 (en) 2009-11-20 2014-12-16 Given Imaging Ltd. System and method for controlling power consumption of an in vivo device

Also Published As

Publication number Publication date
EP0379217A3 (en) 1992-05-13
DE69024235T2 (en) 1996-05-15
US4985768A (en) 1991-01-15
DE69030819T2 (en) 1997-09-11
EP0572046A1 (en) 1993-12-01
DE69024235D1 (en) 1996-02-01
HK1001183A1 (en) 1998-05-29
EP0572046B1 (en) 1997-05-28
DE69030819D1 (en) 1997-07-03
HK1001182A1 (en) 1998-05-29
EP0379217A2 (en) 1990-07-25
EP0379217B1 (en) 1995-12-20

Similar Documents

Publication Publication Date Title
USRE34965E (en) Inter-frame predictive encoding system with encoded and transmitted prediction error
USRE35158E (en) Apparatus for adaptive inter-frame predictive encoding of video signal
KR930002119B1 (en) Moving image signal encoding apparatus and decoding apparatus
KR100519871B1 (en) Method and arrangement for creating a high-resolution still picture
KR950011199B1 (en) Progressive coding system
JP2699703B2 (en) Motion compensation prediction method and image signal encoding method using the same
KR930004311B1 (en) Encoding/decoding system utilizing local properties
KR0148130B1 (en) Apparatus and method for encoding/decoding due to restrain blocking artifact
US4802005A (en) High efficiency encoding system
EP1028592B1 (en) Motion vector decoder
US5694171A (en) Moving image encoding apparatus
US4710810A (en) Predictive coding/decoding apparatus for video signal
JPH06505136A (en) Method and apparatus for decoding video signals
JPH11262018A (en) Motion compensation coder, motion compensation coding method and motion compensation recording medium therefor
US5103307A (en) Interframe predictive coding/decoding system for varying interval between independent frames
JPS61118085A (en) Coding system and device for picture signal
US5191414A (en) Interfield predictive encoder and decoder for reproducing a signal subjected to predictive encoding by encoder into an image signal
US5818534A (en) Video signal interframe predictive coding apparatus using motion detection
JP2939996B2 (en) Adaptive Frame Interpolation for Inter-frame Prediction Decoder with Motion Compensation
JPH02214283A (en) Moving compensation coding system
KR930006522B1 (en) Video signal band compression apparatus
KR100245790B1 (en) Apparatus for coding video signals
JPS62176279A (en) Video coding/decoding device
JPH06113275A (en) Reception/reproduction device for digital picture signal
JPS639394A (en) High efficiency coding device

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

FPAY Fee payment

Year of fee payment: 8

FPAY Fee payment

Year of fee payment: 12