Video decoding method and camera

11509859 · 2022-11-22

Assignee

Inventors

Cpc classification

International classification

Abstract

The present invention provides a video decoding method and a camera. Said method comprises: loading a video, and decoding each frame from the video; calculating, for any two adjacent frames, a first optical flow field; calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames; using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning the pixel value of the previous frame to the pixel of the frame to be inserted; and placing the inserted frame and the decoded original frame together according to a time sequence, so as to reconstitute a video having a high frame rate. The present invention eliminates or improves discrete motion, providing a more fluent viewing experience.

Claims

1. A video decoding method, comprising steps of: loading a video and decoding each frame from the video; calculating a first optical flow field for any two adjacent frames; calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames; using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted; and placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video; wherein the step of calculating a first optical flow field for any two adjacent frames, comprises: downsampling any two adjacent frames to a suitable resolution; calculating an optical flow of the two adjacent frames after downsampling to obtain the first optical flow field with a reduced resolution; upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution.

2. The method of claim 1, wherein after the step of upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution, the method further comprises a step: smoothing the first optical flow field of the original image resolution to ensure continuity.

3. The method of claim 2, wherein the step of smoothing the first optical flow field of the original image resolution to ensure continuity, specifically be: multiplying the optical flow of the first optical flow field of the original image resolution by a sampling coefficient to ensure that the optical flow is correct at the original image resolution.

4. The method of claim 1, wherein the step of calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames, specifically be: marking a first optical flow field from a first frame I.sub.1 to a second frame 12 in the adjacent two frames as M.sub.1; when inserting a frame between the first frame I.sub.1 and the second frame I.sub.2, marking a second optical flow field from the inserted frame to the first frame I.sub.1 as M, then: M(x+dx,y+dy)=—M.sub.1(x,y)/2, where(dx,dy)=M.sub.1(x,y), which is a motion vector from the (x, y) coordinate in the first frame I.sub.1 to the second frame I.sub.2.

5. The method of claim 4, wherein after calculating a second optical flow field of a position where a frame is to be inserted, the method further comprises: for invalid coordinates in the second optical flow field, taking a minimum area around the invalid coordinates where the area contains valid coordinates, and then filling a mean optical flow of the valid coordinates onto the invalid coordinates to fill the holes in the second optical flow, and finally smoothing the second optical flow field M.

6. The method of claim 1, wherein the step of using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted, specifically be: marking the inserted frame as I and the second optical flow field as M; calculating a position (x+dx,y+dy) of each coordinate (x, y) of the inserted frame I in the first frame I.sub.1 of the two adjacent frames, where (dx,dy)=M(x,y) is a motion vector at the coordinates (x, y) from the inserted frame I to the first frame I.sub.1; and assigning a value to each pixel of the inserted frame I, where the specific formula is: I(x,y)=I.sub.1(x+dx,y+dy).

7. The method of claim 1, wherein the step of placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video, specifically be: marking a frame sequence decoded from the video as I.sub.1, I.sub.i+1 . . . , and the frame inserted between the frame I.sub.i and I.sub.i+1 using optical flow as I.sub.i′, and encoding the frames in an order I.sub.1, I.sub.1′, I.sub.2, I.sub.2′ . . . into a video flow so as to form a high frame rate video.

8. A non-transitory computer-readable medium that stores a set of computer-executive program instructions, wherein the set of computer-executive program instructions are executed by one or more processors to perform steps of: loading a video and decoding each frame from the video; calculating a first optical flow field for any two adjacent frames; calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames; using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted; and placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video; wherein the step of using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted, specifically be: marking the inserted frame as I and the second optical flow field as M; calculating a position (x+dx,y+dy) of each coordinate (x, y) of the inserted frame I in the first frame I.sub.1 of the two adjacent frames, where (dx,dy)=M(x,y) is a motion vector at the coordinates (x, y) from the inserted frame I to the first frame I.sub.1; and assigning a value to each pixel of the inserted frame I, where the specific formula is: I(x,y)=I.sub.1(x+dx,y+dy).

9. The medium of claim 8, wherein the step of calculating a first optical flow field for any two adjacent frames, comprises: downsampling any two adjacent frames to a suitable resolution; calculating an optical flow of the two adjacent frames after downsampling to obtain the first optical flow field with a reduced resolution; upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution.

10. The medium of claim 9, wherein after the step of upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution, the method further comprises a step: smoothing the first optical flow field of the original image resolution to ensure continuity; specifically be: multiplying the optical flow of the first optical flow field of the original image resolution by a sampling coefficient to ensure that the optical flow is correct at the original image resolution.

11. The medium of claim 8, wherein the step of calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames, specifically be: marking a first optical flow field from a first frame I.sub.1 to a second frame I.sub.2 in the adjacent two frames as M.sub.1; when inserting a frame between the first frame I.sub.1 and the second frame I.sub.2, marking a second optical flow field from the inserted frame to the first frame I.sub.1 as M, then: M(x+dx,y+dy)=—M.sub.1(x,y)/2, where (dx,dy)=M.sub.1(x,y), which is a motion vector from the (x, y) coordinate in the first frame I.sub.1 to the second frame I.sub.2; after calculating a second optical flow field of a position where a frame is to be inserted, the method further comprises: for invalid coordinates in the second optical flow field, taking a minimum area around the invalid coordinates where the area contains valid coordinates, and then filling a mean optical flow of the valid coordinates onto the invalid coordinates to fill the holes in the second optical flow, and finally smoothing the second optical flow field M.

12. The medium of claim 8, wherein the step of placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video, specifically be: marking a frame sequence decoded from the video as I.sub.i, I.sub.i+1 . . . , and the frame inserted between the frame I.sub.i and I.sub.i+1 using optical flow as I.sub.i′; and encoding the frames in an order I.sub.1, I.sub.1′, I.sub.2, I.sub.2′ . . . into a video flow so as to form a high frame rate video.

13. A camera, comprising: one or more processors, a non-transitory, computer readable memory, and a set of computer-executive program instructions, wherein the processor and the memory are connected by a bus, and the set of computer-executive program instructions are stored in the memory and are configured to be executed by the one or more processors to perform steps of: loading a video and decoding each frame from the video; calculating a first optical flow field for any two adjacent frames; calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames; using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted; and placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video; wherein the step of placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video, specifically be: marking a frame sequence decoded from the video as I.sub.i, I.sub.i+1, . . . , and the frame inserted between the frame I.sub.i and I.sub.i+1 using optical flow as I.sub.i′; and encoding the frames in an order I.sub.1, I.sub.1′, I.sub.2, I.sub.2′ . . . into a video flow so as to form a high frame rate video.

14. The camera of claim 13, wherein the step of calculating a first optical flow field for any two adjacent frames, comprises: downsampling any two adjacent frames to a suitable resolution; calculating an optical flow of the two adjacent frames after downsampling to obtain the first optical flow field with a reduced resolution; upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution.

15. The camera of claim 14, wherein after the step of upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution, the method further comprises a step: smoothing the first optical flow field of the original image resolution to ensure continuity; specifically be: multiplying the optical flow of the first optical flow field of the original image resolution by a sampling coefficient to ensure that the optical flow is correct at the original image resolution.

16. The camera of claim 13, wherein the step of calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames, specifically be: marking a first optical flow field from a first frame I.sub.1 to a second frame I.sub.2 in the adjacent two frames as M.sub.1; when inserting a frame between the first frame I.sub.1 and the second frame I.sub.2, marking a second optical flow field from the inserted frame to the first frame I.sub.1 as M, then: M(x+dx,y+dy)=—M.sub.1(x,y)/2, where (dx,dy)=M.sub.1(x,y), which is a motion vector from the (x, y) coordinate in the first frame I.sub.1 to the second frame I.sub.2; after calculating a second optical flow field of a position where a frame is to be inserted, the method further comprises: for invalid coordinates in the second optical flow field, taking a minimum area around the invalid coordinates where the area contains valid coordinates, and then filling a mean optical flow of the valid coordinates onto the invalid coordinates to fill the holes in the second optical flow, and finally smoothing the second optical flow field M.

17. The camera of claim 13, wherein the step of using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted, specifically be: marking the inserted frame as I and the second optical flow field as M; calculating a position (x+dx,y+dy) of each coordinate (x, y) of the inserted frame I in the first frame I.sub.1 of the two adjacent frames, where (dx,dy)=M(x,y) is a motion vector at the coordinates (x, y) from the inserted frame I to the first frame I.sub.1; and assigning a value to each pixel of the inserted frame I, where the specific formula is: I(x,y)=Ii(x+dx,y+dy).

Description

BRIEF DESCRIPTION OF THE DRAWINGS

(1) FIG. 1 is a flow diagram of a video decoding method in accordance with a first embodiment of the present invention; and

(2) FIG. 2 is a schematic diagram of a camera in accordance with a third embodiment of the present invention;

THE BEST EMBODIMENT OF THE INVENTION

(3) In order to make the objects, technical solutions and advantages of the present invention clearer, the present invention will be further described in detail below in conjunction with the accompanying drawings and embodiments. It should be understood that the specific embodiments described herein are only used to explain the present invention, and are not intended to limit the present invention.

(4) In order to explain the technical solution of the present invention, the following will be described with specific embodiments.

First Embodiment

(5) Referring to FIG. 1, a video decoding method provided in the first embodiment of the present invention includes the following steps. It should be noted that the video decoding method of the present invention is not limited to the flow order as shown in FIG. 1 if there are substantially the same results.

(6) S101, loading a video and decoding each frame from the video.

(7) S102, calculating a first optical flow field for any two adjacent frames.

(8) In the first embodiment of the present invention, S102 may specifically comprise steps of:

(9) downsampling any two adjacent frames to a suitable resolution;

(10) calculating an optical flow of the two adjacent frames after downsampling to obtain the first optical flow field with a reduced resolution;

(11) upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution.

(12) In the first embodiment of the present invention, after the step of upsampling the first optical flow field to an original image resolution to obtain the first optical flow field of the original image resolution, the method may further include the following step:

(13) smoothing the first optical flow field of the original image resolution to ensure continuity; specifically, multiplying the optical flow of the first optical flow field of the original image resolution by a sampling coefficient to ensure that the optical flow is correct at the original image resolution.

(14) S103, calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted, the position being located between two adjacent frames.

(15) In the first embodiment of the present invention, S103 can be:

(16) marking the first optical flow field from the first frame I.sub.1 to the second frame I.sub.2 in the adjacent two frames as M.sub.1; when inserting a frame between the first frame I.sub.1 and the second frame I.sub.2, marking the second optical flow field from the inserted frame to the first frame I.sub.1 as M, then: M(x+dx,y+dy)=−M.sub.1(x,y)/2, where (dx,dy)=M.sub.1(x,y), which is a motion vector from the (x, y) coordinate in the first frame I.sub.1 to the second frame I.sub.2.

(17) Since the second optical flow field M may have holes, that is, there are invalid coordinates. Therefore, in the first embodiment of the present invention, after calculating a second optical flow field of a position where a frame is to be inserted, the method may further include the following step:

(18) for the invalid coordinates in the second optical flow field, taking a minimum area (such as a square, a rectangle, etc.) around the invalid coordinates where the area contains valid coordinates, and then filling a mean optical flow of the valid coordinates onto the invalid coordinates so as to fill the holes in the second optical flow, and finally smoothing the second optical flow field M.

(19) S104, using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted.

(20) In the first embodiment of the present invention, S104 can be:

(21) marking the inserted frame as I and the second optical flow field as M; calculating a position (x+dx,y+dy) of each coordinate (x, y) of the inserted frame I in the first frame I.sub.1 of the two adjacent frames, where (dx,dy)=M(x,y) is a motion vector at the coordinates (x, y) from the inserted frame I to the first frame I.sub.1; and

(22) assigning a value to each pixel of the inserted frame I, where the specific formula is: I(x,y)=I.sub.1(x+dx,y+dy).

(23) S105, placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video.

(24) In the first embodiment of the present invention, S105 can be:

(25) marking a frame sequence decoded from the video as I.sub.i . . . , and the frame inserted between the frame I.sub.i and I.sub.i+1 using optical flow as I.sub.i′; and encoding these frames in an order I.sub.1, I.sub.1′, I.sub.2, I.sub.2′ . . . into a video flow so as to form a high frame rate video.

Second Embodiment

(26) In accordance with a second embodiment, the present invention provides a computer-readable medium that stores a computer program or programs, the computer program or programs are to be executed by a processor or processors to perform steps of the video decoding method provided in the first embodiment of the present invention.

Third Embodiment

(27) FIG. 2 shows a block diagram of a camera 100 provided in the third embodiment of the present invention. A camera 100 comprises: one or more processors 101, a memory 102, and one or more computer programs, where the processor 101 and the memory 102 are connected by a bus, and the one or more computer programs are stored in the memory 102 and are configured to be executed by the one or more processors 101 to perform steps of the video decoding method provided in the first embodiment of the present invention.

(28) In the present invention, calculating a first optical flow field for any two adjacent frames; calculating, according to the first optical flow field, a second optical flow field of a position where a frame is to be inserted; using the second optical flow field to calculate a corresponding pixel position, in a previous frame of two adjacent frames, of each pixel of the frame to be inserted, and assigning a pixel value of the previous frame to a pixel of the frame to be inserted; placing inserted frames and decoded original frames together in chronological order so as to reconstruct a high-frame-rate video; thereby eliminating or eliminates or improving discrete motion, and providing a more fluent viewing experience.

(29) A person of ordinary skill in the art may understand that all or part of the steps in the various methods of the above embodiments may be completed by a program or programs instructing related hardware. The program or programs can be stored in a computer-readable storage medium, and the storage media can be, ROM (ROM, Read Only Memory), RAM (RAM, Random Access Memory), magnetic disk, optical disk, etc.

(30) The above are only preferred embodiments of the present invention and are not intended to limit the present invention. Any modification, equivalents replacements and improvements made within the spirit and principle of the present invention should be included within the scope of the present invention.