Encoding/decoding moving images with forward and backward keyframes for forward and reverse display
First Claim
1. A method of encoding a first sequence of moving images as a second sequence of images in a computer system comprising:
- a. detecting a first scene change in the first sequence of moving images and generating a first keyframe containing complete scene information for a first image detected at said first scene change in the first sequence of moving images for play of the second sequence of images in the forward direction;
b. generating at least one intermediate frame for the second sequence of images following said first keyframe, the at least one intermediate frame containing difference information from the first image for at least one image following the first image in time in the first sequence of moving images; and
c. detecting a second scene change in the first sequence of moving images and generating a second keyframe following said at least one intermediate frame in the second sequence of images, said second keyframe containing complete scene information prior to the second scene change in the first sequence of moving images for play of the second sequence of images in reverse.
1 Assignment
0 Petitions
Accused Products
Abstract
A method of removing frame redundancy in a computer system for a sequence of moving images. The method comprises detecting a first scene change in the sequence of moving images and generating a first keyframe containing complete scene information for a first image. The first keyframe is known, in a preferred embodiment, as a "forward-facing" keyframe or intra frame, and it is normally present in CCITT compressed video data. The process then comprises generating at least one intermediate compressed frame, the at least one intermediate compressed frame containing difference information from the first image for at least one image following the first image in time in the sequence of moving images. In a preferred embodiment, this at least one frame is known as an inter frame. Finally, detecting a second scene change in the sequence of moving images and generating a second keyframe containing complete scene information for an image displayed at the time just prior to the second scene change. This is known, in the preferred embodiment, as a "backward-facing" keyframe. The first keyframe and the at least one intermediate compressed frame are linked for forward play, and the second keyframe and the intermediate compressed frames are linked in reverse for reverse play. In a preferred embodiment, the intra frame is used for generation of complete scene information when the images are played in the forward direction. When this sequence is played in reverse, the backward-facing keyframe is used for the generation of complete scene information.
412 Citations
20 Claims
-
1. A method of encoding a first sequence of moving images as a second sequence of images in a computer system comprising:
-
a. detecting a first scene change in the first sequence of moving images and generating a first keyframe containing complete scene information for a first image detected at said first scene change in the first sequence of moving images for play of the second sequence of images in the forward direction; b. generating at least one intermediate frame for the second sequence of images following said first keyframe, the at least one intermediate frame containing difference information from the first image for at least one image following the first image in time in the first sequence of moving images; and c. detecting a second scene change in the first sequence of moving images and generating a second keyframe following said at least one intermediate frame in the second sequence of images, said second keyframe containing complete scene information prior to the second scene change in the first sequence of moving images for play of the second sequence of images in reverse. - View Dependent Claims (2)
-
-
3. A method of encoding a sequence of images in a computer system comprising:
-
a. for playing said sequence of images in a forward direction, linking a first frame to a second frame, said first frame preceding said second frame temporally, the second frame containing complete image information for a first scene, and linking the second frame to a third frame, the third frame comprising image difference information from the second frame and following said second frame temporally in said sequence of images when said sequence of images is played in the forward direction; and b. for playing said sequence of images in a reverse direction, linking the third frame to a forth frame, the fourth frame containing complete image information for a second scene preceding said second frame and following said first frame temporally in said sequence of images, and linking the fourth frame to the first frame, the first frame comprising image difference information from the fourth frame in said sequence of images when said sequence of images is played in said reverse direction.
-
-
4. An improved method of displaying an encoded sequence of images in a display system, the encoded sequence of images comprising a first frame, second frame, third frame and fourth frame, the second frame containing complete scene information for said encoded sequence of images, the third frame containing difference information from the second image and following the second image temporally when said encoded sequence of images is displayed in a forward direction, the fourth frame containing complete scene information, preceding said second frame and following said first frame temporally in said sequence of images, said first frame containing difference information from the fourth frame, the method comprising:
-
a. displaying the sequence of images in said forward direction by first displaying the first frame, second skipping the fourth frame, third displaying the second frame, and forth generating a first sum image of the second frame and the third frame and displaying the first sum image; and b. displaying the sequence of images in a reverse direction by first displaying the third frame, second skipping the second frame, third displaying the fourth frame, fourth generating a second sum image of the fourth frame and the first frame and displaying the second sum image.
-
-
5. A sequence of encoded images for representing a sequence of unencoded images, said sequence of encoded images which may be displayed in a forward direction and in a reverse direction, said sequence of encoded images comprising:
-
a. a first intra frame, said first intra frame establishing complete scene information for a first scene change of said unencoded sequence of images, said intra frame being first in said encoded sequence of images; b. at least one inter frame, said at least one inter frame comprising difference information from said first intra frame for at least one second image in said unencoded sequence of images and following said first intraframe in said encoded sequence of images; and c. a second intra frame, said second intraframe comprising complete scene information for a frame prior to a second scene change of said unencoded sequence of images, said second intra frame following said at least one inter frame in said encoded sequence of images temporally, said first intra frame being displayed first during said forward display of said encoded sequence of images, followed by said at least one inter frame, and said second intra frame being displayed during said reverse display of said encoded sequence of images, said at least one inter frame following said second intra frame temporally during said reverse display of said encoded sequence of images. - View Dependent Claims (6, 7, 8, 9)
-
-
10. An apparatus for decoding an encoded sequence of images comprising:
-
a. a means for providing forward display of said encoded sequence of images, comprising means for decoding a forward keyframe in said encoded sequence of images which comprises complete scene information for the beginning of the encoded sequence of images, and which further comprises a means for decoding at least one intermediate frame comprising scene difference information from said forward keyframe when displaying said encoded sequence of images in a forward direction; and b. a means for providing reverse display of said encoded sequence of images, comprising means for decoding a reverse keyframe which comprises complete scene information for the end of said encoded sequence of images, and which further comprises a means for decoding said at least one intermediate frame while displaying said encoded sequence of images in a reverse direction. - View Dependent Claims (11, 12, 13, 14, 15)
-
-
16. An apparatus for encoding a first sequence of unencoded images as a sequence of encoded images which may be displayed in a forward direction and a reverse direction comprising:
-
a. scene change detection means for determining when the difference between a frame and preceding frames of said unencoded sequence of images has exceeded a predetermined threshold; b. forward keyframe creation means for creating a forward keyframe in said sequence of encoded images when a first scene change at a first frame has been detected in said unencoded sequence of images, said forward keyframe comprising complete scene information for said first frame of said unencoded sequence of images; c. difference frame creation means for creating at least one difference frame following said forward keyframe in said encoded sequence of images from at least one second frame in said unencoded sequence of images following said first frame, said at least one difference frame comprising difference information between the forward keyframe and said at least one second frame in said unencoded sequence of images following said first frame; d. reverse keyframe creation means for creating a reverse keyframe in said encoded sequence of images when a second scene change has been detected at a third frame in said unencoded sequence of images, said reverse keyframe comprising complete scene information for a fourth frame in said unencoded sequence of images, said fourth frame immediately preceding said third frame in said unencoded sequence of images; and e. linking means for linking said forward keyframe with said at least one difference frame in said encoded sequence of images for display of said encoded sequence of images in a forward direction, and further for linking said reverse keyframe with said at least one difference frame in said encoded sequence of images for display of said encoded sequence of images in a reverse direction. - View Dependent Claims (17, 18, 19, 20)
-
Specification