METHOD AND APPARATUS FOR FRAME CODING IN VERTICAL RASTER SCAN ORDER FOR HEVC

Information

  • Patent Application
  • 20220279184
  • Publication Number
    20220279184
  • Date Filed
    May 17, 2022
    2 years ago
  • Date Published
    September 01, 2022
    a year ago
Abstract
A method and apparatus for frame coding in adaptive raster scan order. The method includes encoding at least one of image or video utilizing input frames and at least one of a data related to the input frame to produce bitstream with raster scan order information and displacement information for producing compressed video bitstream, at decoding time, decoding at least one of the encoded bitstream with raster scan order information and displacement information for producing compressed video bitstream.
Description
BACKGROUND OF THE INVENTION
Field of the Invention

Embodiments of the present invention generally relate to a method and apparatus for frame coding in vertical raster scan for HEVC.


Description of the Related Art

HEVC is a video coding standard being standardized to improve coding efficiency by 50% over H264/AVC. To achieve this goal, lots of new coding tools have been proposed for HEVC. However, all the proposed coding tools assume the horizontal raster scan of micro blocks, which has two problems: 1) Horizontal raster scan is not always effective in prediction especially for intra coding and 2) with sliding window memory for motion estimation (ME) and motion compensation (MC), large on-chip memory is required to compensate for large vertical motion. This is especially a challenging for UHD (ultra high definition) videos, such as, 4k×2k and 8k×4k. While UHD video coding is one of the application areas of HEVC, the frame coding in horizontal scan order is not cost effective at all for UHD videos with high vertical motion.


Therefore, there is a need for a method and/or apparatus for frame coding for HEVC.


SUMMARY OF THE INVENTION

Embodiments of the present invention relate to a method and apparatus for frame coding in adaptive raster scan order. The method includes encoding at least one of image or video utilizing input frames and at least one of a data related to the input frame to produce bitstream with raster scan order information and displacement information for producing compressed video bitstream, at decoding time, decoding at least one of the encoded bitstream with raster scan order information and displacement information for producing compressed video bitstream.





BRIEF DESCRIPTION OF THE DRAWINGS

So that the manner in which the above recited features of the present invention can be understood in detail, a more particular description of the invention, briefly summarized above, may be had by reference to embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments of this invention and are therefore not to be considered limiting of its scope, for the invention may admit to other equally effective embodiments.



FIG. 1 is an embodiment of a frame coding in horizontal raster scan order;



FIG. 2 is an embodiment of a frame coding in vertical raster scan order;



FIG. 3 is an embodiment of a vertical sliding window scheme for horizontal raster coding order;



FIG. 4 is an embodiment of a horizontal sliding window scheme for vertical raster coding order;



FIG. 5 is an embodiment depicting horizontal bottom-right to left;



FIG. 6 is an embodiment of a vertical right-bottom to top;



FIG. 7 is an embodiment of a portable device with video camera and motion sensor;



FIG. 8 is an embodiment of a video stabilizer in accordance with the prior art; and



FIG. 9 is an embodiment of an improved video stabilizer.





DETAILED DESCRIPTION

The proposed method and apparatus add a vertical raster scan order to the HEVC standard and adaptively select the best coding scan order between the horizontal and vertical raster scan orders based on any criteria, such as, size of horizontal/vertical motion, coding efficiency, on-chip memory saving and etc.


The vertical raster scan is effective for the frames which have lots of vertical discontinuities. FIG. 1 is an embodiment of a frame coding in horizontal raster scan order. FIG. 2 is an embodiment of a frame coding in vertical raster scan order. In FIG. 1 and FIG. 2, the frame with vertical discontinuities with horizontal and vertical raster scan orders are shown, respectively. When we apply the horizontal raster scan order, as shown in FIG. 1, more bits are used to encode micro block mode. This is due to incorrect mode prediction caused by discontinuity. However, the number of bits is reduced when we apply the vertical raster scan order, as shown in FIG. 2. Hence, the coding gain will be more significant for intra frames. The result indicates that the vertical raster scan can reduce bitrates up to 4% for some sequences, even without adaptive horizontal/vertical raster scan order decision. Thus, adaptive decision will result in even higher bit-rate saving.



FIG. 3 is an embodiment of a vertical sliding window scheme for horizontal raster coding order. If a video contains large vertical motion, the vertical sliding window scheme may not cover the large vertical motion. In this scenario, inter mode may not be used because required reference area is not available. This eventually causes encoding efficiency degradation. However, this problem could be solved by employing a horizontal sliding window scheme with vertical raster coding order, as illustrated in FIG. 4. FIG. 4 is an embodiment of a horizontal sliding window scheme for vertical raster coding order. Utilizing adaptively choosing raster scan order improves the coding efficiency of inter frames at the same on-chip memory requirement. On the other hand, the required on-chip memory size without coding gain loss is reduced.


For horizontal and vertical search range srX*srY, on-chip memory size (byte) for sliding window for 8-bit luma can be calculated as follows:





MemSizeHorOrder=picWidth*(2*srY+N),





MemSizeVertOrder=picHeight*(2*srX+N).


MemSizeHorOrder and MemSizeVertOrder are on-chip memory sizes for vertical sliding window (horizontal raster coding order) and horizontal sliding window (vertical raster coding order), respectively. N*N is the largest coding unit, and picWidth and picHeight are the horizontal and vertical size of the picture. Based on the equations, Table 1 lists the search ranges for different available on-chip memory sizes for 4k×2k (3840×2160) videos. For a given on-chip memory size, srY is always limited in vertical sliding window, which potentially causes encoding efficiency degradation for large vertical motion videos as illustrated in FIG. 3. By introducing vertical coding order with horizontal sliding window, we can remove the limitation on srY and avoid the degradation for large vertical motion videos.









TABLE 1







Available on-chip memory sizes vs. search ranges











500 KBytes
750 Kbytes
1,000 KBytes














srX
srY
srX
srY
srX
srY

















Vertical sliding
unlimited
+/−33
unlimited
+/−65
Unlimited
+/−98


window


Horizontal
+/−83
unlimited
+/−141
Unlimited
+/−199
unlimited


sliding window









The idea of vertical raster scan can be realized with frame rotation. Hence, similar effect may be seen by rotating input frames with horizontal raster scan. This information can be simply added as SEI (Supplemental Enhancement information) or VUI (Video Usability Information) in bitstreams. Moreover, we can extend this idea to any arbitrary raster scan order. We can apply one of 8 different raster can orders for each frames; horizontal top-left to right, as shown in FIG. 1, horizontal top-right to left, horizontal bottom-left to right, horizontal bottom-right to left, as shown in FIG. 5, vertical left-top to bottom FIG. 2, vertical left-bottom to bottom, vertical right-top to bottom and vertical right-bottom to top FIG. 6. It also can be realized by modifying input frames, i.e., e.g. rotating and/or flipping using SEI or VUI.



FIG. 7 is an embodiment of a portable device with video camera and motion sensor. The motion sensor consists one of the following sensors or a combination of them: accelerometer, gyroscope, magnetosensor etc. The motion sensor provided the camera orientation or displacement information. The displacement can be specified in terms of a rotation matrix, quarternion, euler angle etc.



FIG. 8 and FIG. 9 show a video stabilization where camera displacement information can be used. Video stabilization compensates for jitter in video due to changing camera position in order to provide a steady video. FIG. 8 is an embodiment of a video stabilizer in accordance with the prior art. In FIG. 8, the video stabilization is carried out in decoder. The camera displacement parameters are deduced from decoded frames and are used to translates/rotate/warp the decoded frame to generate stabilized video frames. Calculation of camera displacement parameters from decoded frames is very computationally intensive and prone to incorrect estimation.


On the other hand, FIG. 9 is an embodiment of an improved video stabilizer. The camera displacement information is calculated in the transmitter by using motion sensors. The displacement information is encapsulated in SEI/VUI and transmitted inside compressed bitstreams to receiver. The decoder at the receiver decodes the compressed bitstream with camera displacement SEI/VUI and generates decoded frames and displacement information which is then passed on to the video stabilization module which carries out video stabilization.


While the foregoing is directed to embodiments of the present invention, other and further embodiments of the invention may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.

Claims
  • 1. A method comprising: determining, by a transmitter, displacement information of an image; andtransmitting, by the transmitter, the image and the displacement information in a bitstream.
  • 2. The method of claim 1, wherein: the displacement information is based on motion sensor data.
  • 3. The method of claim 2, wherein: the motion sensor data is collected from one of an accelerometer, a gyroscope, and a magneto sensor.
  • 4. The method of claim 1, wherein: the transmitter includes an encoder configured to encode the displacement information in the bitstream.
  • 5. The method of claim 1, wherein: a stability of the image is based on the displacement information.
  • 6. The method of claim 1, further comprising: determining, by the transmitter, a modification of a frame of the image based on one of a size of a horizontal motion, a size of a vertical motion, a coding efficiency, and an on-chip memory; andapplying, by the transmitter, the modification to the frame.
  • 7. The method of claim 6, wherein: the modification includes one of a rotation or a flip of the frame.
  • 8. The method of claim 1, further comprising: determining, by the transmitter, an adaptive scan order based on one of a size of a horizontal motion, a size of a vertical motion, a coding efficiency, and an on-chip memory; andapplying, by the transmitter, the adaptive scan order to a frame of the image.
  • 9. The method of claim 8, wherein: the adaptive scan order for the frame includes one of: horizontal top-left to right;horizontal top-right to left;horizontal bottom-left to right;horizontal bottom-right to left;vertical left-top to bottom;vertical top-left to bottom;vertical top-right to bottom;vertical bottom-left to top; andvertical bottom-right to top.
  • 10. The method of claim 9, further comprising: transmitting, by the transmitter, the adaptive scan order.
  • 11. A non-transitory computer readable medium comprising instructions that, when executed by a transmitter, cause the transmitter to:determine displacement information of an image; andtransmit the image and the displacement information in a bitstream.
  • 12. The instructions of claim 11, wherein: the displacement information is based on motion sensor data.
  • 13. The instructions of claim 12, wherein: the motion sensor data is collected from one of an accelerometer, a gyroscope, and a magneto sensor.
  • 14. The instructions of claim 11, wherein: the transmitter includes an encoder configured to encode the displacement information in the bitstream.
  • 15. The instructions of claim 11, wherein: a stability of the image is based on the displacement information.
  • 16. The instructions of claim 11, further cause the transmitter to: determine a modification of a frame of the image based on one of a size of a horizontal motion, a size of a vertical motion, a coding efficiency, and an on-chip memory; andapply the modification to the frame.
  • 17. The instructions of claim 16, wherein: the modification includes one of a rotation or a flip of the frame.
  • 18. The instructions of claim 11, further cause the transmitter to: determine an adaptive scan order based on one of a size of a horizontal motion, a size of a vertical motion, a coding efficiency, and an on-chip memory; andapply the adaptive scan order to a frame of the image.
  • 19. The instructions of claim 18, wherein: the adaptive scan order for the frame includes one of: horizontal top-left to right;horizontal top-right to left;horizontal bottom-left to right;horizontal bottom-right to left;vertical left-top to bottom;vertical top-left to bottom;vertical top-right to bottom;vertical bottom-left to top; andvertical bottom-right to top.
  • 20. The instructions of claim 19, further cause the transmitter to: transmit the adaptive scan order.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is a Continuation of U.S. patent application Ser. No. 16/185,401, filed Nov. 9, 2018, which is a continuation of Ser. No. 15/583,460, filed May 1, 2017, now U.S. Pat. No. 10,165,276, which is a continuation of Ser. No. 14/561,816, filed Dec. 5, 2014, now U.S. Pat. No. 9,641,856, which is a continuation of Ser. No. 13/250,806, filed Sep. 30, 2011, now U.S. Pat. No. 8,934,729, which claims the benefit of U.S. Provisional Patent Application Ser. No. 61/388,478 filed Sep. 30, 2010, and 61/474,435, filed Apr. 12, 2011, all of which are incorporated herein by reference in their entirety.

Provisional Applications (2)
Number Date Country
61474435 Apr 2011 US
61388478 Sep 2010 US
Continuations (4)
Number Date Country
Parent 16185401 Nov 2018 US
Child 17746916 US
Parent 15583460 May 2017 US
Child 16185401 US
Parent 14561816 Dec 2014 US
Child 15583460 US
Parent 13250806 Sep 2011 US
Child 14561816 US