U.S. patent application number 17/740712 was filed with the patent office on 2022-08-25 for method and device for decoding images using cclm prediction in image coding system.
The applicant listed for this patent is LG ELECTRONICS INC.. Invention is credited to Jangwon CHOI, Jin Heo, Seunghwan Kim.
Application Number | 20220272327 17/740712 |
Document ID | / |
Family ID | |
Filed Date | 2022-08-25 |
United States Patent
Application |
20220272327 |
Kind Code |
A1 |
CHOI; Jangwon ; et
al. |
August 25, 2022 |
METHOD AND DEVICE FOR DECODING IMAGES USING CCLM PREDICTION IN
IMAGE CODING SYSTEM
Abstract
An image decoding method performed by a decoding device
according to the present document comprises: a step for deriving
the number of samples of upper peripheral chroma samples and left
peripheral chroma samples of a current chroma block on the basis of
a specific value and the width and height of the current chroma
block; a step for deriving said number of upper peripheral chroma
samples and said number of left peripheral chroma samples; and a
step for deriving CCLM parameters on the basis of the upper
peripheral chroma samples, the left peripheral chroma samples, and
down-sampled peripheral luma samples, wherein, when the specific
value is derived as 2 and the width and the height of the current
chroma block are larger than the specific value, the number of
samples is derived as the specific value.
Inventors: |
CHOI; Jangwon; (Seoul,
KR) ; Kim; Seunghwan; (Seoul, KR) ; Heo;
Jin; (Seoul, KR) |
|
Applicant: |
Name |
City |
State |
Country |
Type |
LG ELECTRONICS INC. |
Seoul |
|
KR |
|
|
Appl. No.: |
17/740712 |
Filed: |
May 10, 2022 |
Related U.S. Patent Documents
|
|
|
|
|
|
Application
Number |
Filing Date |
Patent Number |
|
|
17277621 |
Mar 18, 2021 |
|
|
|
PCT/KR2019/012193 |
Sep 20, 2019 |
|
|
|
17740712 |
|
|
|
|
62735186 |
Sep 23, 2018 |
|
|
|
62735030 |
Sep 22, 2018 |
|
|
|
International
Class: |
H04N 19/105 20060101
H04N019/105; H04N 19/132 20060101 H04N019/132; H04N 19/159 20060101
H04N019/159; H04N 19/176 20060101 H04N019/176; H04N 19/186 20060101
H04N019/186; H04N 19/46 20060101 H04N019/46 |
Claims
1-15. (canceled)
16. An image decoding method performed by a decoding apparatus, the
method comprising: obtaining image information including prediction
mode information for a current luma block and prediction mode
information and residual information for a current chroma block;
deriving an intra prediction mode of the current luma block based
on the prediction mode information; generating luma samples for the
current luma block based on the intra prediction mode and
neighboring luma samples of the current luma block; deriving an
intra prediction mode of the current chroma block as a
cross-component linear model (CCLM) mode based on the prediction
mode information for the current chroma block; deriving a sample
number for top neighboring chroma samples and left neighboring
chroma samples of the current chroma block based on a specific
value, a width and a height of the current chroma block; deriving
the top neighboring chroma samples of the sample number and the
left neighboring chroma samples of the sample number; deriving
down-sampled neighboring luma samples based on the neighboring luma
samples of the current luma block; deriving down-sampled luma
samples based on the luma samples of the current luma block;
deriving CCLM parameters based on the top neighboring chroma
samples, the left neighboring chroma samples, and the down-sampled
neighboring luma samples; deriving prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples; deriving residual samples for the
current chroma block based on the residual information; and
generating reconstructed samples for the current chroma block based
on the prediction samples and the residual samples, wherein the
specific value is derived as 2, and wherein based on the width and
the height of the current chroma block being greater than the
specific value, the sample number is derived as the specific
value.
17. The image decoding method of claim 16, wherein based on the
width and the height being less than or equal to the specific
value, the sample number is derived as one value of the width and
the height.
18. The image decoding method of claim 16, wherein the down-sampled
neighboring luma samples include down-sampled top neighboring luma
samples of the sample number related with the top neighboring
chroma samples, and down-sampled left neighboring luma samples of
the sample number related with the left neighboring chroma
samples.
19. The image decoding method of claim 16, wherein the specific
value is derived as a preset value for the current chroma block to
which the CCLM mode is applied.
20. The image decoding method of claim 16, wherein the specific
value is derived based on the size of the current chroma block.
21. The image decoding method of claim 16, wherein the image
information includes information indicating the specific value, and
the specific value is derived based on the information indicating
the specific value.
22. The image decoding method of claim 21, wherein the information
indicating the specific value is signaled in units of a coding unit
(CU).
23. The image decoding method of claim 21, wherein the information
indicating the specific value is signaled in a slice header, a
picture parameter set (PPS), or a sequence parameter set (SPS).
24. The image decoding method of claim 16, wherein: the image
information includes flag information indicating whether to derive
the sample number based on the specific value; based on the value
of the flag information being 1, the image information includes
information indicating the specific value and the specific value is
derived based on the information indicating the specific value.
25. The image decoding method of claim 16, wherein the specific
value is derived based on whether a smaller value between the width
and the height of the current block is greater than a specific
threshold value.
26. The image decoding method of claim 25, wherein the specific
threshold is preset, and, based on the smaller value between the
width and the height being less than or equal to the specific
threshold value, the specific value is derived as 2.
27. An image encoding method performed by an encoding apparatus,
the method comprising: deriving an intra prediction mode of a
current luma block; generating luma samples for the current luma
block based on the intra prediction mode and neighboring luma
samples of the current luma block; determining an intra prediction
mode of a current chroma block as a cross-component linear model
(CCLM) mode; deriving a sample number for top neighboring chroma
samples and left neighboring chroma samples of the current chroma
block based on a specific value, a width and a height of the
current chroma block; deriving the top neighboring chroma samples
of the sample number and the left neighboring chroma samples of the
sample number; deriving down-sampled neighboring luma samples based
on the neighboring luma samples of the current luma block; deriving
down-sampled luma samples based on the luma samples of the current
luma block; deriving CCLM parameters based on the top neighboring
chroma samples, the left neighboring chroma samples, and the
down-sampled neighboring luma samples; deriving prediction samples
for the current chroma block based on the CCLM parameters and the
down-sampled luma samples; deriving residual samples for the
current chroma block based on the prediction samples; and encoding
image information including prediction mode information for the
current luma block and prediction mode information and residual
information for the current chroma block, wherein the specific
value is derived as 2, and wherein based on the width and the
height of the current chroma block being greater than the specific
value, the sample number is derived as the specific value.
28. The image encoding method of claim 27, wherein based on the
width and the height being less than or equal to the specific
value, the sample number is derived as one value of the width and
the height.
29. The image encoding method of claim 27, wherein the down-sampled
neighboring luma samples include down-sampled top neighboring luma
samples of the sample number related with the top neighboring
chroma samples, and down-sampled left neighboring luma samples of
the sample number related with the left neighboring chroma
samples.
30. The image encoding method of claim 27, wherein the specific
value is derived as a preset value for the current chroma block to
which the CCLM mode is applied.
31. A non-transitory computer-readable storage medium storing a
bitstream generated by a method, the method comprising: deriving an
intra prediction mode of a current luma block; generating luma
samples for the current luma block based on the intra prediction
mode and neighboring luma samples of the current luma block;
determining an intra prediction mode of a current chroma block as a
cross-component linear model (CCLM) mode; deriving a sample number
for top neighboring chroma samples and left neighboring chroma
samples of the current chroma block based on a specific value, a
width and a height of the current chroma block; deriving the top
neighboring chroma samples of the sample number and the left
neighboring chroma samples of the sample number; deriving
down-sampled neighboring luma samples based on the neighboring luma
samples of the current luma block; deriving down-sampled luma
samples based on the luma samples of the current luma block;
deriving CCLM parameters based on the top neighboring chroma
samples, the left neighboring chroma samples, and the down-sampled
neighboring luma samples; deriving prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples; deriving residual samples for the
current chroma block based on the prediction samples; encoding
image information including prediction mode information for the
current luma block and prediction mode information and residual
information for the current chroma block; and generating the
bitstream including the image information, wherein the specific
value is derived as 2, and wherein based on the width and the
height of the current chroma block being greater than the specific
value, the sample number is derived as the specific value.
Description
BACKGROUND OF THE DISCLOSURE
Field of the Disclosure
[0001] The present disclosure relates generally to an image coding
technology and, more particularly, to an image decoding method
using CCLM prediction in an image coding system, and an apparatus
therefor.
Related Art
[0002] Recently, demand for high-resolution, high-quality images
such as HD (High Definition) images and UHD (Ultra High Definition)
images have been increasing in various fields. As the image data
has high resolution and high quality, the amount of information or
bits to be transmitted increases relative to the legacy image data.
Therefore, when image data is transmitted using a medium such as a
conventional wired/wireless broadband line or image data is stored
using an existing storage medium, the transmission cost and the
storage cost thereof are increased.
[0003] Accordingly, there is a need for a highly efficient image
compression technique for effectively transmitting, storing, and
reproducing information of high resolution and high quality
images.
SUMMARY
[0004] The present disclosure provides a method and device for
improving image coding efficiency.
[0005] The present disclosure also provides a method and device for
improving intra-prediction efficiency.
[0006] The present disclosure also provides a method and device for
improving intra-prediction efficiency based on Cross Component
Linear Model (CCLM).
[0007] The present disclosure also provides efficient encoding and
decoding methods of CCLM prediction, and apparatuses for performing
the encoding and decoding methods.
[0008] The present disclosure provides a method and apparatus for
selecting a neighboring sample for deriving a linear model
parameter for CCLM.
[0009] According to an embodiment of the present disclosure, an
image decoding method which is performed by a decoding apparatus is
provided. The method includes obtaining image information including
prediction mode information for a current chroma block, deriving an
intra prediction mode of the current chroma block as a
cross-component linear model (CCLM) mode based on the prediction
mode information, deriving a sample number for top neighboring
chroma samples and left neighboring chroma samples of the current
chroma block based on a specific value, a width and a height of the
current chroma block, deriving the top neighboring chroma samples
of the sample number and the left neighboring chroma samples of the
sample number, deriving down-sampled neighboring luma samples and
down-sampled luma samples of a current luma block, wherein the
down-sampled neighboring luma samples correspond to the top
neighboring chroma samples and the left neighboring chroma samples,
deriving CCLM parameters based on the top neighboring chroma
samples, the left neighboring chroma samples, and the down-sampled
neighboring luma samples, deriving prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples, and generating reconstructed samples for
the current chroma block based on the prediction samples, wherein
the specific value is derived as 2, and wherein based on the width
and the height of the current chroma block being greater than the
specific value, the sample number is derived as the specific
value.
[0010] According to another embodiment of the present disclosure, a
decoding apparatus which performs image decoding is provided. The
decoding apparatus includes an entropy decoder which obtains image
information including prediction mode information for a current
chroma block; a predictor which derives an intra prediction mode of
the current chroma block as a cross-component linear model (CCLM)
mode based on the prediction mode information, derives a sample
number for top neighboring chroma samples and left neighboring
chroma samples of the current chroma block based on a specific
value, a width and a height of the current chroma block, derives
the top neighboring chroma samples of the sample number and the
left neighboring chroma samples of the sample number, derives
down-sampled neighboring luma samples and down-sampled luma samples
of a current luma block, with the down-sampled neighboring luma
samples corresponding to the top neighboring chroma samples and the
left neighboring chroma samples, derives CCLM parameters based on
the top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples, and derives
prediction samples for the current chroma block based on the CCLM
parameters and the down-sampled luma samples; and an adder which
generates reconstructed samples for the current chroma block based
on the prediction samples, wherein the specific value is derived as
2, and wherein based on the width and the height of the current
chroma block being greater than the specific value, the sample
number is derived as the specific value.
[0011] According to still another embodiment of the present
disclosure, a video encoding method which is performed by an
encoding apparatus is provided. The method includes determining an
intra prediction mode of a current chroma block as a
cross-component linear model (CCLM) mode, deriving a sample number
for top neighboring chroma samples and left neighboring chroma
samples of the current chroma block based on a specific value, a
width and a height of the current chroma block, deriving the top
neighboring chroma samples of the sample number and the left
neighboring chroma samples of the sample number, deriving
down-sampled neighboring luma samples and down-sampled luma samples
of a current luma block, wherein the down-sampled neighboring luma
samples correspond to the top neighboring chroma samples and the
left neighboring chroma samples, deriving CCLM parameters based on
the top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples, deriving
prediction samples for the current chroma block based on the CCLM
parameters and the down-sampled luma samples, and encoding image
information including prediction mode information for the current
chroma block, wherein the specific value is derived as 2, and
wherein based on the width and the height of the current chroma
block being greater than the specific value, the sample number is
derived as the specific value.
[0012] According to still another embodiment of the present
disclosure, a video encoding apparatus is provided. The encoding
apparatus includes a predictor which determines an intra prediction
mode of a current chroma block as a cross-component linear model
(CCLM) mode, derives a sample number for top neighboring chroma
samples and left neighboring chroma samples of the current chroma
block based on a specific value, a width and a height of the
current chroma block, derives the top neighboring chroma samples of
the sample number and the left neighboring chroma samples of the
sample number, derives down-sampled neighboring luma samples and
down-sampled luma samples of a current luma block with the
down-sampled neighboring luma samples corresponding to the top
neighboring chroma samples and the left neighboring chroma samples,
derives CCLM parameters based on the top neighboring chroma
samples, the left neighboring chroma samples, and the down-sampled
neighboring luma samples, and derives prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples; and an entropy encoder which encodes
image information including prediction mode information of the
current chroma block, wherein the specific value is derived as 2,
and wherein based on the width and the height of the current chroma
block being greater than the specific value, the sample number is
derived as the specific value.
[0013] According to the present disclosure, overall image/video
compression efficiency can be improved.
[0014] According to the present disclosure, the efficiency of
intra-prediction can be improved.
[0015] According to the present disclosure, the image coding
efficiency can be improved by performing an intra-prediction based
on CCLM.
[0016] According to the present disclosure, the efficiency of intra
prediction based on the CCLM can be improved.
[0017] According to the present disclosure, the complexity of intra
prediction can be reduced by limiting the number of neighboring
samples selected to derive a linear model parameter for the CCLM of
a chroma block with big size to a specific number.
BRIEF DESCRIPTION OF THE DRAWINGS
[0018] FIG. 1 briefly illustrates an example of a video/image
coding device to which embodiments of the present disclosure are
applicable.
[0019] FIG. 2 is a schematic diagram illustrating a configuration
of a video/image encoding apparatus to which the embodiment(s) of
the present disclosure may be applied.
[0020] FIG. 3 is a schematic diagram illustrating a configuration
of a video/image decoding apparatus to which the embodiment(s) of
the present disclosure may be applied.
[0021] FIG. 4 illustrates intra-directional modes of 65 prediction
directions.
[0022] FIG. 5 is a diagram for describing a process of deriving an
intra-prediction mode of a current chroma block according to an
embodiment.
[0023] FIG. 6 illustrates 2N reference samples for parameter
calculation for CCLM prediction described above.
[0024] FIGS. 7a and 7b are diagrams for describing a procedure of
performing CCLM prediction for a current chroma block according to
an embodiment.
[0025] FIGS. 8a and 8b are diagrams for describing a procedure of
performing CCLM prediction for a current chroma block according to
an embodiment.
[0026] FIGS. 9a and 9b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 1 of the present
embodiment described above.
[0027] FIGS. 10a and 10b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 2 of the present
embodiment described above.
[0028] FIGS. 11a and 11b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 3 of the present
embodiment described above.
[0029] FIGS. 12a and 12b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 4 of the present
embodiment described above.
[0030] FIGS. 13a and 13b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 1 of the present
embodiment described above.
[0031] FIGS. 14a and 14b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 2 of the present
embodiment described above.
[0032] FIGS. 15a and 15b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 3 of the present
embodiment described above.
[0033] FIG. 16 schematically represents an image encoding method by
an encoding apparatus according to the present disclosure.
[0034] FIG. 17 schematically represents an encoding apparatus
performing an image encoding method according to the present
disclosure.
[0035] FIG. 18 schematically represents an image decoding method by
a decoding apparatus according to the present disclosure.
[0036] FIG. 19 schematically represents a decoding apparatus for
performing an image decoding method according to the document.
[0037] FIG. 20 illustratively represents a contents streaming
system structure diagram to which embodiments of the present
disclosure are applied.
DESCRIPTION OF EMBODIMENTS
[0038] The present disclosure may be modified in various forms, and
specific embodiments thereof will be described and illustrated in
the drawings. However, the embodiments are not intended for
limiting the disclosure. The terms used in the following
description are used to merely describe specific embodiments but
are not intended to limit the disclosure. An expression of a
singular number includes an expression of the plural number, so
long as it is clearly read differently. The terms such as "include"
and "have" are intended to indicate that features, numbers, steps,
operations, elements, components, or combinations thereof used in
the following description exist and it should be thus understood
that the possibility of existence or addition of one or more
different features, numbers, steps, operations, elements,
components, or combinations thereof is not excluded.
[0039] Meanwhile, elements in the drawings described in the
disclosure are independently drawn for the purpose of convenience
for explanation of different specific functions, and do not mean
that the elements are embodied by independent hardware or
independent software. For example, two or more elements of the
elements may be combined to form a single element, or one element
may be divided into plural elements. The embodiments in which the
elements are combined and/or divided belong to the disclosure
without departing from the concept of the disclosure.
[0040] Hereinafter, embodiments of the present disclosure will be
described in detail with reference to the accompanying drawings. In
addition, like reference numerals are used to indicate like
elements throughout the drawings, and the same descriptions on the
like elements will be omitted.
[0041] FIG. 1 briefly illustrates an example of a video/image
coding device to which embodiments of the present disclosure are
applicable.
[0042] Referring to FIG. 1, a video/image coding system may include
a first device (source device) and a second device (receiving
device). The source device may deliver encoded video/image
information or data in the form of a file or streaming to the
receiving device via a digital storage medium or network.
[0043] The source device may include a video source, an encoding
apparatus, and a transmitter. The receiving device may include a
receiver, a decoding apparatus, and a renderer. The encoding
apparatus may be called a video/image encoding apparatus, and the
decoding apparatus may be called a video/image decoding apparatus.
The transmitter may be included in the encoding apparatus. The
receiver may be included in the decoding apparatus. The renderer
may include a display, and the display may be configured as a
separate device or an external component.
[0044] The video source may acquire video/image through a process
of capturing, synthesizing, or generating the video/image. The
video source may include a video/image capture device and/or a
video/image generating device. The video/image capture device may
include, for example, one or more cameras, video/image archives
including previously captured video/images, and the like. The
video/image generating device may include, for example, computers,
tablets and smartphones, and may (electronically) generate
video/images. For example, a virtual video/image may be generated
through a computer or the like. In this case, the video/image
capturing process may be replaced by a process of generating
related data.
[0045] The encoding apparatus may encode input video/image. The
encoding apparatus may perform a series of procedures such as
prediction, transform, and quantization for compression and coding
efficiency. The encoded data (encoded video/image information) may
be output in the form of a bitstream.
[0046] The transmitter may transmit the encoded image/image
information or data output in the form of a bitstream to the
receiver of the receiving device through a digital storage medium
or a network in the form of a file or streaming. The digital
storage medium may include various storage mediums such as USB, SD,
CD, DVD, Blu-ray, HDD, SSD, and the like. The transmitter may
include an element for generating a media file through a
predetermined file format and may include an element for
transmission through a broadcast/communication network. The
receiver may receive/extract the bitstream and transmit the
received bitstream to the decoding apparatus.
[0047] The decoding apparatus may decode the video/image by
performing a series of procedures such as dequantization, inverse
transform, and prediction corresponding to the operation of the
encoding apparatus.
[0048] The renderer may render the decoded video/image. The
rendered video/image may be displayed through the display.
[0049] This document relates to video/image coding. For example,
the methods/embodiments disclosed in this document may be applied
to a method disclosed in the versatile video coding (VVC), the EVC
(essential video coding) standard, the AOMedia Video 1 (AV1)
standard, the 2nd generation of audio video coding standard (AVS2),
or the next generation video/image coding standard (ex. H.267 or
H.268, etc.).
[0050] This document presents various embodiments of video/image
coding, and the embodiments may be performed in combination with
each other unless otherwise mentioned.
[0051] In this document, video may refer to a series of images over
time. Picture generally refers to a unit representing one image in
a specific time zone, and a slice/tile is a unit constituting part
of a picture in coding. The slice/tile may include one or more
coding tree units (CTUs). One picture may consist of one or more
slices/tiles. One picture may consist of one or more tile groups.
One tile group may include one or more tiles. A brick may represent
a rectangular region of CTU rows within a tile in a picture. A tile
may be partitioned into multiple bricks, each of which consisting
of one or more CTU rows within the tile. A tile that is not
partitioned into multiple bricks may be also referred to as a
brick. A brick scan is a specific sequential ordering of CTUs
partitioning a picture in which the CTUs are ordered consecutively
in CTU raster scan in a brick, bricks within a tile are ordered
consecutively in a raster scan of the bricks of the tile, and tiles
in a picture are ordered consecutively in a raster scan of the
tiles of the picture. A tile is a rectangular region of CTUs within
a particular tile column and a particular tile row in a picture.
The tile column is a rectangular region of CTUs having a height
equal to the height of the picture and a width specified by syntax
elements in the picture parameter set. The tile row is a
rectangular region of CTUs having a height specified by syntax
elements in the picture parameter set and a width equal to the
width of the picture. A tile scan is a specific sequential ordering
of CTUs partitioning a picture in which the CTUs are ordered
consecutively in CTU raster scan in a tile whereas tiles in a
picture are ordered consecutively in a raster scan of the tiles of
the picture. A slice includes an integer number of bricks of a
picture that may be exclusively contained in a single NAL unit. A
slice may consists of either a number of complete tiles or only a
consecutive sequence of complete bricks of one tile. Tile groups
and slices may be used interchangeably in this document. For
example, in this document, a tile group/tile group header may be
called a slice/slice header.
[0052] A pixel or a pel may mean a smallest unit constituting one
picture (or image). Also, `sample` may be used as a term
corresponding to a pixel. A sample may generally represent a pixel
or a value of a pixel, and may represent only a pixel/pixel value
of a luma component or only a pixel/pixel value of a chroma
component.
[0053] A unit may represent a basic unit of image processing. The
unit may include at least one of a specific region of the picture
and information related to the region. One unit may include one
luma block and two chroma (ex. cb, cr) blocks. The unit may be used
interchangeably with terms such as block or area in some cases. In
a general case, an M.times.N block may include samples (or sample
arrays) or a set (or array) of transform coefficients of M columns
and N rows.
[0054] In this document, the term "/" and "," should be interpreted
to indicate "and/or." For instance, the expression "A/B" may mean
"A and/or B." Further, "A, B" may mean "A and/or B." Further,
"A/B/C" may mean "at least one of A, B, and/or C." Also, "A/B/C"
may mean "at least one of A, B, and/or C."
[0055] Further, in the document, the term "or" should be
interpreted to indicate "and/or." For instance, the expression "A
or B" may comprise 1) only A, 2) only B, and/or 3) both A and B. In
other words, the term "or" in this document should be interpreted
to indicate "additionally or alternatively."
[0056] FIG. 2 is a schematic diagram illustrating a configuration
of a video/image encoding apparatus to which the embodiment(s) of
the present disclosure may be applied. Hereinafter, the video
encoding apparatus may include an image encoding apparatus.
[0057] Referring to FIG. 2, the encoding apparatus 200 includes an
image partitioner 210, a predictor 220, a residual processor 230,
and an entropy encoder 240, an adder 250, a filter 260, and a
memory 270. The predictor 220 may include an inter predictor 221
and an intra predictor 222. The residual processor 230 may include
a transformer 232, a quantizer 233, a dequantizer 234, and an
inverse transformer 235. The residual processor 230 may further
include a subtractor 231. The adder 250 may be called a
reconstructor or a reconstructed block generator. The image
partitioner 210, the predictor 220, the residual processor 230, the
entropy encoder 240, the adder 250, and the filter 260 may be
configured by at least one hardware component (ex. an encoder
chipset or processor) according to an embodiment. In addition, the
memory 270 may include a decoded picture buffer (DPB) or may be
configured by a digital storage medium. The hardware component may
further include the memory 270 as an internal/external
component.
[0058] The image partitioner 210 may partition an input image (or a
picture or a frame) input to the encoding apparatus 200 into one or
more processors. For example, the processor may be called a coding
unit (CU). In this case, the coding unit may be recursively
partitioned according to a quad-tree binary-tree ternary-tree
(QTBTIT) structure from a coding tree unit (CTU) or a largest
coding unit (LCU). For example, one coding unit may be partitioned
into a plurality of coding units of a deeper depth based on a quad
tree structure, a binary tree structure, and/or a ternary
structure. In this case, for example, the quad tree structure may
be applied first and the binary tree structure and/or ternary
structure may be applied later. Alternatively, the binary tree
structure may be applied first. The coding procedure according to
this document may be performed based on the final coding unit that
is no longer partitioned. In this case, the largest coding unit may
be used as the final coding unit based on coding efficiency
according to image characteristics, or if necessary, the coding
unit may be recursively partitioned into coding units of deeper
depth and a coding unit having an optimal size may be used as the
final coding unit. Here, the coding procedure may include a
procedure of prediction, transform, and reconstruction, which will
be described later. As another example, the processor may further
include a prediction unit (PU) or a transform unit (TU). In this
case, the prediction unit and the transform unit may be split or
partitioned from the aforementioned final coding unit. The
prediction unit may be a unit of sample prediction, and the
transform unit may be a unit for deriving a transform coefficient
and/or a unit for deriving a residual signal from the transform
coefficient.
[0059] The unit may be used interchangeably with terms such as
block or area in some cases. In a general case, an M.times.N block
may represent a set of samples or transform coefficients composed
of M columns and N rows. A sample may generally represent a pixel
or a value of a pixel, may represent only a pixel/pixel value of a
luma component or represent only a pixel/pixel value of a chroma
component. A sample may be used as a term corresponding to one
picture (or image) for a pixel or a pel.
[0060] In the encoding apparatus 200, a prediction signal
(predicted block, prediction sample array) output from the inter
predictor 221 or the intra predictor 222 is subtracted from an
input image signal (original block, original sample array) to
generate a residual signal residual block, residual sample array),
and the generated residual signal is transmitted to the transformer
232. In this case, as shown, a unit for subtracting a prediction
signal (predicted block, prediction sample array) from the input
image signal (original block, original sample array) in the encoder
200 may be called a subtractor 231. The predictor may perform
prediction on a block to be processed (hereinafter, referred to as
a current block) and generate a predicted block including
prediction samples for the current block. The predictor may
determine whether intra prediction or inter prediction is applied
on a current block or CU basis. As described later in the
description of each prediction mode, the predictor may generate
various information related to prediction, such as prediction mode
information, and transmit the generated information to the entropy
encoder 240. The information on the prediction may be encoded in
the entropy encoder 240 and output in the form of a bitstream.
[0061] The intra predictor 222 may predict the current block by
referring to the samples in the current picture. The referred
samples may be located in the neighborhood of the current block or
may be located apart according to the prediction mode. In the intra
prediction, prediction modes may include a plurality of
non-directional modes and a plurality of directional modes. The
non-directional mode may include, for example, a DC mode and a
planar mode. The directional mode may include, for example, 33
directional prediction modes or 65 directional prediction modes
according to the degree of detail of the prediction direction.
However, this is merely an example, more or less directional
prediction modes may be used depending on a setting. The intra
predictor 222 may determine the prediction mode applied to the
current block by using a prediction mode applied to a neighboring
block.
[0062] The inter predictor 221 may derive a predicted block for the
current block based on a reference block (reference sample array)
specified by a motion vector on a reference picture. Here, in order
to reduce the amount of motion information transmitted in the inter
prediction mode, the motion information may be predicted in units
of blocks, subblocks, or samples based on correlation of motion
information between the neighboring block and the current block.
The motion information may include a motion vector and a reference
picture index. The motion information may further include inter
prediction direction (L0 prediction, L1 prediction, Bi prediction,
etc.) information. In the case of inter prediction, the neighboring
block may include a spatial neighboring block present in the
current picture and a temporal neighboring block present in the
reference picture. The reference picture including the reference
block and the reference picture including the temporal neighboring
block may be the same or different. The temporal neighboring block
may be called a collocated reference block, a co-located CU
(colCU), and the like, and the reference picture including the
temporal neighboring block may be called a collocated picture
(colPic). For example, the inter predictor 221 may configure a
motion information candidate list based on neighboring blocks and
generate information indicating which candidate is used to derive a
motion vector and/or a reference picture index of the current
block. Inter prediction may be performed based on various
prediction modes. For example, in the case of a skip mode and a
merge mode, the inter predictor 221 may use motion information of
the neighboring block as motion information of the current block.
In the skip mode, unlike the merge mode, the residual signal may
not be transmitted. In the case of the motion vector prediction
(MVP) mode, the motion vector of the neighboring block may be used
as a motion vector predictor and the motion vector of the current
block may be indicated by signaling a motion vector difference.
[0063] The predictor 220 may generate a prediction signal based on
various prediction methods described below. For example, the
predictor may not only apply intra prediction or inter prediction
to predict one block but also simultaneously apply both intra
prediction and inter prediction. This may be called combined inter
and intra prediction (CIIP). In addition, the predictor may be
based on an intra block copy (IBC) prediction mode or a palette
mode for prediction of a block. The IBC prediction mode or palette
mode may be used for content image/video coding of a game or the
like, for example, screen content coding (SCC). The IBC basically
performs prediction in the current picture but may be performed
similarly to inter prediction in that a reference block is derived
in the current picture. That is, the IBC may use at least one of
the inter prediction techniques described in this document. The
palette mode may be considered as an example of intra coding or
intra prediction. When the palette mode is applied, a sample value
within a picture may be signaled based on information on the
palette table and the palette index.
[0064] The prediction signal generated by the predictor (including
the inter predictor 221 and/or the intra predictor 222) may be used
to generate a reconstructed signal or to generate a residual
signal. The transformer 232 may generate transform coefficients by
applying a transform technique to the residual signal. For example,
the transform technique may include at least one of a discrete
cosine transform (DCT), a discrete sine transform (DST), a
karhunen-loeve transform (KLT), a graph-based transform (GBT), or a
conditionally non-linear transform (CNT). Here, the GBT means
transform obtained from a graph when relationship information
between pixels is represented by the graph. The CNT refers to
transform generated based on a prediction signal generated using
all previously reconstructed pixels. In addition, the transform
process may be applied to square pixel blocks having the same size
or may be applied to blocks having a variable size rather than
square.
[0065] The quantizer 233 may quantize the transform coefficients
and transmit them to the entropy encoder 240 and the entropy
encoder 240 may encode the quantized signal (information on the
quantized transform coefficients) and output a bitstream. The
information on the quantized transform coefficients may be referred
to as residual information. The quantizer 233 may rearrange block
type quantized transform coefficients into a one-dimensional vector
form based on a coefficient scanning order and generate information
on the quantized transform coefficients based on the quantized
transform coefficients in the one-dimensional vector form.
Information on transform coefficients may be generated. The entropy
encoder 240 may perform various encoding methods such as, for
example, exponential Golomb, context-adaptive variable length
coding (CAVLC), context-adaptive binary arithmetic coding (CABAC),
and the like. The entropy encoder 240 may encode information
necessary for video/image reconstruction other than quantized
transform coefficients (ex. values of syntax elements, etc.)
together or separately. Encoded information (ex. encoded
video/image information) may be transmitted or stored in units of
NALs (network abstraction layer) in the form of a bitstream. The
video/image information may further include information on various
parameter sets such as an adaptation parameter set (APS), a picture
parameter set (PPS), a sequence parameter set (SPS), or a video
parameter set (VPS). In addition, the video/image information may
further include general constraint information. In this document,
information and/or syntax elements transmitted/signaled from the
encoding apparatus to the decoding apparatus may be included in
video/picture information. The video/image information may be
encoded through the above-described encoding procedure and included
in the bitstream. The bitstream may be transmitted over a network
or may be stored in a digital storage medium. The network may
include a broadcasting network and/or a communication network, and
the digital storage medium may include various storage media such
as USB, SD, CD, DVD, Blu-ray, HDD, SSD, and the like. A transmitter
(not shown) transmitting a signal output from the entropy encoder
240 and/or a storage unit (not shown) storing the signal may be
included as internal/external element of the encoding apparatus
200, and alternatively, the transmitter may be included in the
entropy encoder 240.
[0066] The quantized transform coefficients output from the
quantizer 233 may be used to generate a prediction signal. For
example, the residual signal (residual block or residual samples)
may be reconstructed by applying dequantization and inverse
transform to the quantized transform coefficients through the
dequantizer 234 and the inverse transformer 235. The adder 250 adds
the reconstructed residual signal to the prediction signal output
from the inter predictor 221 or the intra predictor 222 to generate
a reconstructed signal (reconstructed picture, reconstructed block,
reconstructed sample array). If there is no residual for the block
to be processed, such as a case where the skip mode is applied, the
predicted block may be used as the reconstructed block. The adder
250 may be called a reconstructor or a reconstructed block
generator. The generated reconstructed signal may be used for intra
prediction of a next block to be processed in the current picture
and may be used for inter prediction of a next picture through
filtering as described below.
[0067] Meanwhile, luma mapping with chroma scaling (LMCS) may be
applied during picture encoding and/or reconstruction.
[0068] The filter 260 may improve subjective/objective image
quality by applying filtering to the reconstructed signal. For
example, the filter 260 may generate a modified reconstructed
picture by applying various filtering methods to the reconstructed
picture and store the modified reconstructed picture in the memory
270, specifically, a DPB of the memory 270. The various filtering
methods may include, for example, deblocking filtering, a sample
adaptive offset, an adaptive loop filter, a bilateral filter, and
the like. The filter 260 may generate various information related
to the filtering and transmit the generated information to the
entropy encoder 240 as described later in the description of each
filtering method. The information related to the filtering may be
encoded by the entropy encoder 240 and output in the form of a
bitstream.
[0069] The modified reconstructed picture transmitted to the memory
270 may be used as the reference picture in the inter predictor
221. When the inter prediction is applied through the encoding
apparatus, prediction mismatch between the encoding apparatus 200
and the decoding apparatus may be avoided and encoding efficiency
may be improved.
[0070] The DPB of the memory 270 DPB may store the modified
reconstructed picture for use as a reference picture in the inter
predictor 221. The memory 270 may store the motion information of
the block from which the motion information in the current picture
is derived (or encoded) and/or the motion information of the blocks
in the picture that have already been reconstructed. The stored
motion information may be transmitted to the inter predictor 221
and used as the motion information of the spatial neighboring block
or the motion information of the temporal neighboring block. The
memory 270 may store reconstructed samples of reconstructed blocks
in the current picture and may transfer the reconstructed samples
to the intra predictor 222.
[0071] FIG. 3 is a schematic diagram illustrating a configuration
of a video/image decoding apparatus to which the embodiment(s) of
the present disclosure may be applied.
[0072] Referring to FIG. 3, the decoding apparatus 300 may include
an entropy decoder 310, a residual processor 320, a predictor 330,
an adder 340, a filter 350, a memory 360. The predictor 330 may
include an inter predictor 331 and an intra predictor 332. The
residual processor 320 may include a dequantizer 321 and an inverse
transformer 321. The entropy decoder 310, the residual processor
320, the predictor 330, the adder 340, and the filter 350 may be
configured by a hardware component (ex. a decoder chipset or a
processor) according to an embodiment. In addition, the memory 360
may include a decoded picture buffer (DPB) or may be configured by
a digital storage medium. The hardware component may further
include the memory 360 as an internal/external component.
[0073] When a bitstream including video/image information is input,
the decoding apparatus 300 may reconstruct an image corresponding
to a process in which the video/image information is processed in
the encoding apparatus of FIG. 2. For example, the decoding
apparatus 300 may derive units/blocks based on block partition
related information obtained from the bitstream. The decoding
apparatus 300 may perform decoding using a processor applied in the
encoding apparatus. Thus, the processor of decoding may be a coding
unit, for example, and the coding unit may be partitioned according
to a quad tree structure, binary tree structure and/or ternary tree
structure from the coding tree unit or the largest coding unit. One
or more transform units may be derived from the coding unit. The
reconstructed image signal decoded and output through the decoding
apparatus 300 may be reproduced through a reproducing
apparatus.
[0074] The decoding apparatus 300 may receive a signal output from
the encoding apparatus of FIG. 2 in the form of a bitstream, and
the received signal may be decoded through the entropy decoder 310.
For example, the entropy decoder 310 may parse the bitstream to
derive information (ex. video/image information) necessary for
image reconstruction (or picture reconstruction). The video/image
information may further include information on various parameter
sets such as an adaptation parameter set (APS), a picture parameter
set (PPS), a sequence parameter set (SPS), or a video parameter set
(VPS). In addition, the video/image information may further include
general constraint information. The decoding apparatus may further
decode picture based on the information on the parameter set and/or
the general constraint information. Signaled/received information
and/or syntax elements described later in this document may be
decoded may decode the decoding procedure and obtained from the
bitstream. For example, the entropy decoder 310 decodes the
information in the bitstream based on a coding method such as
exponential Golomb coding, CAVLC, or CABAC, and output syntax
elements required for image reconstruction and quantized values of
transform coefficients for residual. More specifically, the CABAC
entropy decoding method may receive a bin corresponding to each
syntax element in the bitstream, determine a context model using a
decoding target syntax element information, decoding information of
a decoding target block or information of a symbol/bin decoded in a
previous stage, and perform an arithmetic decoding on the bin by
predicting a probability of occurrence of a bin according to the
determined context model, and generate a symbol corresponding to
the value of each syntax element. In this case, the CABAC entropy
decoding method may update the context model by using the
information of the decoded symbol/bin for a context model of a next
symbol/bin after determining the context model. The information
related to the prediction among the information decoded by the
entropy decoder 310 may be provided to the predictor (the inter
predictor 332 and the intra predictor 331), and the residual value
on which the entropy decoding was performed in the entropy decoder
310, that is, the quantized transform coefficients and related
parameter information, may be input to the residual processor 320.
The residual processor 320 may derive the residual signal (the
residual block, the residual samples, the residual sample array).
In addition, information on filtering among information decoded by
the entropy decoder 310 may be provided to the filter 350.
Meanwhile, a receiver (not shown) for receiving a signal output
from the encoding apparatus may be further configured as an
internal/external element of the decoding apparatus 300, or the
receiver may be a component of the entropy decoder 310. Meanwhile,
the decoding apparatus according to this document may be referred
to as a video/image/picture decoding apparatus, and the decoding
apparatus may be classified into an information decoder
(video/image/picture information decoder) and a sample decoder
(video/image/picture sample decoder). The information decoder may
include the entropy decoder 310, and the sample decoder may include
at least one of the dequantizer 321, the inverse transformer 322,
the adder 340, the filter 350, the memory 360, the inter predictor
332, and the intra predictor 331.
[0075] The dequantizer 321 may dequantize the quantized transform
coefficients and output the transform coefficients. The dequantizer
321 may rearrange the quantized transform coefficients in the form
of a two-dimensional block form. In this case, the rearrangement
may be performed based on the coefficient scanning order performed
in the encoding apparatus. The dequantizer 321 may perform
dequantization on the quantized transform coefficients by using a
quantization parameter (ex. quantization step size information) and
obtain transform coefficients.
[0076] The inverse transformer 322 inversely transforms the
transform coefficients to obtain a residual signal (residual block,
residual sample array).
[0077] The predictor may perform prediction on the current block
and generate a predicted block including prediction samples for the
current block. The predictor may determine whether intra prediction
or inter prediction is applied to the current block based on the
information on the prediction output from the entropy decoder 310
and may determine a specific intra/inter prediction mode.
[0078] The predictor 320 may generate a prediction signal based on
various prediction methods described below. For example, the
predictor may not only apply intra prediction or inter prediction
to predict one block but also simultaneously apply intra prediction
and inter prediction. This may be called combined inter and intra
prediction (CIIP). In addition, the predictor may be based on an
intra block copy (IBC) prediction mode or a palette mode for
prediction of a block. The IBC prediction mode or palette mode may
be used for content image/video coding of a game or the like, for
example, screen content coding (SCC). The IBC basically performs
prediction in the current picture but may be performed similarly to
inter prediction in that a reference block is derived in the
current picture. That is, the IBC may use at least one of the inter
prediction techniques described in this document. The palette mode
may be considered as an example of intra coding or intra
prediction. When the palette mode is applied, a sample value within
a picture may be signaled based on information on the palette table
and the palette index.
[0079] The intra predictor 331 may predict the current block by
referring to the samples in the current picture. The referred
samples may be located in the neighborhood of the current block or
may be located apart according to the prediction mode. In the intra
prediction, prediction modes may include a plurality of
non-directional modes and a plurality of directional modes. The
intra predictor 331 may determine the prediction mode applied to
the current block by using a prediction mode applied to a
neighboring block.
[0080] The inter predictor 332 may derive a predicted block for the
current block based on a reference block (reference sample array)
specified by a motion vector on a reference picture. In this case,
in order to reduce the amount of motion information transmitted in
the inter prediction mode, motion information may be predicted in
units of blocks, subblocks, or samples based on correlation of
motion information between the neighboring block and the current
block. The motion information may include a motion vector and a
reference picture index. The motion information may further include
inter prediction direction (L0 prediction, L1 prediction, Bi
prediction, etc.) information. In the case of inter prediction, the
neighboring block may include a spatial neighboring block present
in the current picture and a temporal neighboring block present in
the reference picture. For example, the inter predictor 332 may
configure a motion information candidate list based on neighboring
blocks and derive a motion vector of the current block and/or a
reference picture index based on the received candidate selection
information. Inter prediction may be performed based on various
prediction modes, and the information on the prediction may include
information indicating a mode of inter prediction for the current
block.
[0081] The adder 340 may generate a reconstructed signal
(reconstructed picture, reconstructed block, reconstructed sample
array) by adding the obtained residual signal to the prediction
signal (predicted block, predicted sample array) output from the
predictor (including the inter predictor 332 and/or the intra
predictor 331). If there is no residual for the block to be
processed, such as when the skip mode is applied, the predicted
block may be used as the reconstructed block.
[0082] The adder 340 may be called reconstructor or a reconstructed
block generator. The generated reconstructed signal may be used for
intra prediction of a next block to be processed in the current
picture, may be output through filtering as described below, or may
be used for inter prediction of a next picture.
[0083] Meanwhile, luma mapping with chroma scaling (LMCS) may be
applied in the picture decoding process.
[0084] The filter 350 may improve subjective/objective image
quality by applying filtering to the reconstructed signal. For
example, the filter 350 may generate a modified reconstructed
picture by applying various filtering methods to the reconstructed
picture and store the modified reconstructed picture in the memory
360, specifically, a DPB of the memory 360. The various filtering
methods may include, for example, deblocking filtering, a sample
adaptive offset, an adaptive loop filter, a bilateral filter, and
the like.
[0085] The (modified) reconstructed picture stored in the DPB of
the memory 360 may be used as a reference picture in the inter
predictor 332. The memory 360 may store the motion information of
the block from which the motion information in the current picture
is derived (or decoded) and/or the motion information of the blocks
in the picture that have already been reconstructed. The stored
motion information may be transmitted to the inter predictor 260 so
as to be utilized as the motion information of the spatial
neighboring block or the motion information of the temporal
neighboring block. The memory 360 may store reconstructed samples
of reconstructed blocks in the current picture and transfer the
reconstructed samples to the intra predictor 331.
[0086] In the present disclosure, the embodiments described in the
filter 260, the inter predictor 221, and the intra predictor 222 of
the encoding apparatus 200 may be the same as or respectively
applied to correspond to the filter 350, the inter predictor 332,
and the intra predictor 331 of the decoding apparatus 300. The same
may also apply to the unit 332 and the intra predictor 331.
[0087] Meanwhile, as described above, in performing video coding, a
prediction is performed to enhance compression efficiency.
Accordingly, a prediction block including prediction samples for a
current block, that is, a coding target block, may be generated. In
this case, the predicted block includes prediction samples in a
spatial domain (or pixel domain). The prediction block is
identically derived in the encoding apparatus and the decoding
apparatus. The encoding apparatus may improve image coding
efficiency by signaling residual information on a residual between
an original block and the predicted block not an original sample
value of the original block itself to the decoding apparatus. The
decoding apparatus may derive a residual block including residual
samples based on the residual information, may generate a
reconstructed block including reconstructed samples by adding up
the residual block and the prediction block, and may generate a
reconstructed picture including the reconstructed block.
[0088] The residual information may be generated through a
transform and quantization procedure. For example, the encoding
apparatus may derive the residual block between the original block
and the predicted block, may derive transform coefficients by
performing a transform procedure on the residual samples (residual
sample array) included in the residual block, may derive quantized
transform coefficients by performing a quantization procedure on
the transform coefficients, and may signal related residual
information to the decoding apparatus (through a bit stream). In
this case, the residual information may include information, such
as value information, location information, a transform scheme, a
transform kernel and a quantization parameter of the quantized
transform coefficients. The decoding apparatus may perform a
dequantization/inverse transform procedure based on the residual
information and may derive the residual samples (or residual
block). The decoding apparatus may generate the reconstructed
picture based on the prediction block and the residual block. The
encoding apparatus may also derive the residual block by performing
a dequantization/inverse transform on the quantized transform
coefficients for the reference of inter prediction of a subsequent
picture and may generate the reconstructed picture based on the
residual block.
[0089] FIG. 4 illustrates intra-directional modes of 65 prediction
directions.
[0090] Referring to FIG. 4, intra-prediction modes having
horizontal directionality and intra-prediction modes having
vertical directionality may be classified based on an
intra-prediction mode #34 having an upper left diagonal prediction
direction. H and V in FIG. 3 represent the horizontal
directionality and the vertical directionality, respectively, and
the numbers from -32 to 32 represent displacements of 1/32 unit on
sample grid positions. Intra-prediction modes #2 to #33 have the
horizontal directionality and intra-prediction modes #34 to #66
have the vertical directionality. Intra-prediction mode #18 and
intra-prediction mode #50 represent a horizontal intra-prediction
mode and a vertical intra-prediction mode, respectively.
Intra-prediction modes #2 may be called a lower left diagonal
intra-prediction mode, intra-prediction mode #34 may be called an
upper left diagonal intra-prediction mode and intra-prediction mode
#66 may be called an upper right diagonal intra-prediction
mode.
[0091] FIG. 5 is a diagram for describing a process of deriving an
intra-prediction mode of a current chroma block according to an
embodiment.
[0092] In the present disclosure, "chroma block", "chroma image",
and the like may represent the same meaning of chrominance block,
chrominance image, and the like, and accordingly, chroma and
chrominance may be commonly used. Likewise, "luma block", "luma
image", and the like may represent the same meaning of luminance
block, luminance image, and the like, and accordingly, luma and
luminance may be commonly used.
[0093] In the present disclosure, a "current chroma block" may mean
a chroma component block of a current block, which is a current
coding unit, and a "current luma block" may mean a luma component
block of a current block, which is a current coding unit.
Accordingly, the current luma block and the current chroma block
correspond with each other. However, block formats and block
numbers of the current luma block and the current chroma block are
not always the same but may be different depending on a case. In
some cases, the current chroma block may correspond to the current
luma region, and in this case, the current luma region may include
at least one luma block.
[0094] In the present disclosure, "reference sample template" may
mean a set of reference samples neighboring a current chroma block
for predicting the current chroma block. The reference sample
template may be predefined, or information for the reference sample
template may be signaled to the decoding apparatus 300 from the
encoding apparatus 200.
[0095] Referring to FIG. 5, a set of samples one shaded line
neighboring 4.times.4 block, which is a current chroma block,
represents a reference sample template. It is shown in FIG. 5 that
the reference sample template includes a reference sample of one
line, but the reference sample region in a luma region
corresponding to the reference sample template includes two
lines.
[0096] In an embodiment, when an intra encoding of a chroma image
is performed in Joint Exploration TEST Model (JEM) used in Joint
Video Exploration Team (JVET), Cross Component Linear Model (CCLM)
may be used. CCLM is a method of predicting a pixel value of a
chroma image based on a pixel value of a reconstructed luma image,
which is based on the property of high correlation between a chroma
image and a luma image.
[0097] CCLM prediction of Cb and Cr chroma images may be based on
the equation below.
P .times. r .times. e .times. d C ( i , j ) = .alpha. Rec L ' ( i ,
j ) + .beta. [ Equation .times. 1 ] ##EQU00001##
[0098] Herein, pred.sub.c (i, j) means Cb or Cr chroma image to be
predicted, Rec.sub.L'(i, j) means a luma image to be reconstructed
which is adjusted to a chroma block size and (i, j) means a
coordinate of a pixel. In 4:2:0 color format, since a size of luma
image is double of that of a chroma image, Rec.sub.L' of a chroma
block size should be generated through down-sampling, and
accordingly, a pixel of luma image to be used in chroma image
pred.sub.e (i, j) may also use neighboring pixels in addition to
Rec.sub.L(2i, 2j). The pred.sub.c (i, j) may be represented as a
down-sampled luma sample.
[0099] For example, the pred.sub.c (i, j) may be derived by using 6
neighboring pixels as represented in the equation below.
Rec L ' ( i , j ) = ( 2 .times. Rec L ( 2 .times. i , 2 .times. j )
+ 2 .times. R .times. e .times. c L ( 2 .times. i , 2 .times. j + 1
) + R .times. e .times. c L ( 2 .times. i - 1 , 2 .times. j ) + R
.times. e .times. c L ( 2 .times. i + 1 , 2 .times. j ) + R .times.
e .times. c L ( 2 .times. i - 1 , 2 .times. j + 1 ) [ Equation
.times. 2 ] ##EQU00002##
[0100] In addition, as shown in the shaded area of FIG. 3, .alpha.
and .beta. represent a cross-correlation and a difference of
average values between Cb or Cr chroma block neighboring template
and luma block neighboring template, and .alpha. and .beta. are
represented as Equation 3 below.
.alpha. = M .function. ( t L ( i , j ) - M .function. ( t L ) )
.times. M .function. ( t C ( i , j ) - M .function. ( t C ) ) M
.function. ( t L ( i , j ) - M .function. ( t L ) ) .times. M
.function. ( t L ( i , j ) - M .function. ( t L ) ) , [ Equation
.times. 3 ] ##EQU00003## .beta. = M .function. ( t c ) - .alpha.
.times. M .function. ( t L ) ##EQU00003.2##
[0101] Here, t.sub.L means a neighboring reference sample of a luma
block corresponding to a current chroma image, t.sub.C means
neighboring reference sample of a current chroma block to which
encoding is applied currently, and (i, j) means a position of a
pixel. In addition, M(A) means an average of A pixels.
[0102] Meanwhile, samples for parameter calculation (i.e., for
example, .alpha. and .beta.) for CCLM prediction described above
may be selected as below. [0103] In the case that a current chroma
block is a chroma block of N.times.N size, total 2N (N horizontal
and N vertical) neighboring reference sample pairs (luma and
chroma) of the current chroma block may be selected. [0104] In the
case that a current chroma block is a chroma block of N.times.M
size or M.times.N size (herein, N<=M), total 2N (N horizontal
and N vertical) neighboring reference sample pairs of the current
chroma block may be selected. Meanwhile, since M is greater than N
(e.g., M=2N or 3N, etc.), among M samples, N sample pairs may be
selected through subsampling.
[0105] FIG. 6 illustrates 2N reference samples for parameter
calculation for CCLM prediction described above. Referring to FIG.
6, 2N reference sample pairs are shown, which is derived for
parameter calculation for the CCLM prediction. The 2N reference
sample pairs may include 2N reference samples adjacent to the
current chroma block and 2N reference samples adjacent to the
current luma block.
[0106] As described above, 2N sample pairs may be derived, and in
the case that CCLM parameters .alpha. and .beta. are calculated
using Equation 3 using the sample pair described above, the
operation of numbers as represented in Table 1 below may be
required.
TABLE-US-00001 TABLE 1 operations Number of operations
Multiplications 2N + 5 Sums 8N - 1 Division 2
[0107] Referring to Table 1 above, for example, in the case of a
chroma block of 4.times.4 size, 21 multiplication operations and 31
addition operations may be required for calculating CCLM parameter,
and in the case of a chroma block of 32.times.32 size, 133
multiplication operations and 255 addition operations may be
required for calculating CCLM parameter. That is, as the size of
the chroma block increases, an amount of operation required for
calculating CCLM parameter increases rapidly, which may be directly
connected to a delay problem in hardware implementation.
Particularly, since the CCLM parameter should be derived through
calculation eve in the decoding apparatus, the amount of operation
may be connected to a delay problem in hardware implementation of
the decoding apparatus and increase of implementation cost.
[0108] Therefore, the present embodiment may reduce operation
complexity for deriving CCLM parameters, and through this, may
reduce hardware cost and complexity and time of decoding
procedure.
[0109] As an example, in order to solve the problem of increase of
CCLM parameter operation amount as the chroma block size increase
described above, an embodiment may be proposed for calculating a
CCLM parameter by selecting a chroma block neighboring pixel, after
configuring a neighboring sample selection upper limit N.sub.th as
described below. The N.sub.th may also be represented as a maximum
neighboring sample number. For example, N.sub.th may be set as 2,
4, 8 or 16.
[0110] The CCLM parameter calculation procedure according to the
present embodiment may be as below. [0111] In the case that a
current chroma block is a chroma block of N.times.N size and
N.sub.th>=N, total 2N (N horizontal and N vertical) neighboring
reference sample pairs of the current chroma block may be selected.
[0112] In the case that a current chroma block is a chroma block of
N.times.N size and N.sub.th<N, total 2*N.sub.th (2*N.sub.th
horizontal and 2*N.sub.th vertical) neighboring reference sample
pairs of the current chroma block may be selected. [0113] In the
case that a current chroma block is a chroma block of N.times.M
size or M.times.N size (herein, N<=M) and N.sub.th>=N, total
2N (N horizontal and N vertical) neighboring reference sample pairs
of the current chroma block may be selected. Since M is greater
than N (e.g., M=2N or 3N, etc.), among M samples, N sample pairs
may be selected through subsampling. [0114] In the case that a
current chroma block is a chroma block of N.times.M size or
M.times.N size (herein, N<=M) and N.sub.th<N, total
2*N.sub.th (2*N.sub.th horizontal and 2*N.sub.th vertical)
neighboring reference sample pairs of the current chroma block may
be selected. Since M is greater than N (e.g., M=2N or 3N, etc.),
among M samples, N.sub.th sample pairs may be selected through
subsampling.
[0115] As described above, according to the present embodiment, a
neighboring reference sample number for CCLM parameter calculation
may be limited by setting N.sub.th which is a maximum number of
selected neighboring sample numbers, and through this, a CCLM
parameter may be calculated through relatively less calculations
even in a chroma block of big size.
[0116] In addition, in the case of setting N.sub.th as relatively
small number (e.g., 4 or 8), in hardware implementation of CCLM
parameter calculation, a worst case operation (e.g., chroma block
of 32.times.32 size) may be avoided, and therefore, a required
hardware gate numbers may be reduced in comparison with the worst
case, and through this, there is also an effect of reducing
hardware implementation cost.
[0117] For example, in the case that N.sub.th is 2, 4 and 8, an
amount of the CCLM parameter calculation for a chroma block size
may be represented as the following table.
TABLE-US-00002 TABLE 2 Number of operations ( multiplication + sums
) Proposed Proposed Proposed Block Original method method method
size CCLM (N.sub.th = 2) (N.sub.th = 4) (N.sub.th = 8) N = 2 24 24
24 24 N = 4 44 24 44 44 N = 8 84 24 44 84 N = 16 164 24 44 84 N =
32 324 24 44 84
[0118] Meanwhile, N.sub.th may be derived as a predetermined value
in the encoding apparatus and the decoding apparatus without need
to transmit additional information representing N.sub.th.
Alternatively, additional information representing N.sub.th may be
transmitted in a unit of a Coding Unit (CU), a slice, a picture or
a sequence, and N.sub.th may be derived based on the additional
information representing N.sub.th.
[0119] For example, in the case that the additional information
representing N.sub.th is transmitted in a CU unit, when an
intra-prediction mode of a current chroma block is the CCLM mode,
as described below, a method may be proposed to parse syntax
element cclm_reduced_sample_flag and perform a CCLM parameter
calculation procedure. The cclm_reduced_sample_flag may represent a
syntax element of CCLM reduced sample flag. [0120] In the case that
the cclm_reduced_sample_flag is 0 (false), a CCLM parameter
calculation is performed through the existing CCLM neighboring
sample selection method. [0121] In the case that the
cclm_reduced_sample_flag is 1 (true), N.sub.th is set to 2, and a
CCLM parameter calculation is performed through the neighboring
sample selection method proposed in the present embodiment
described above.
[0122] Alternatively, in the case that the additional information
representing N.sub.th is transmitted in a unit of slice, picture or
sequence, as described below, N.sub.th value may be decoded based
on the additional information transmitted through a high level
syntax (HLS).
[0123] For example, the additional information signaled through a
slice header may be represented as the following table.
TABLE-US-00003 TABLE 3 slice_header( ) { Descriptor ...
cclm_reduced_sample_num f(2) ...
[0124] cclm_reduced_sample_num may represent a syntax element of
the additional information representing N.sub.th.
[0125] Alternatively, for example, the additional information
signaled through a Picture Parameter Set (PPS) may be represented
as the following table.
TABLE-US-00004 TABLE 4 pic_parameter_set_rbsp( ) { Descriptor ...
cclm_reduced_sample_num f(2) ...
[0126] Alternatively, for example, the additional information
signaled through a Sequence Parameter Set (SPS) may be represented
as the following table.
TABLE-US-00005 TABLE 5 seq_parameter_set_rbsp( ) { Descriptor ...
cclm_reduced_sample_num f(2) ...
[0127] N.sub.th value, which is derived based on the
cclm_reduced_sample_num value (i.e., a value derived by decoding
cclm_reduced_sample_num) transmitted through the slice header, the
PPS or the SPS, may be derived as represented in the following
table.
TABLE-US-00006 TABLE 6 cclm_reduced_sample_num N.sub.th 0 2 1 4 2 8
3 16
[0128] For example, referring to Table 6 above, N.sub.th may be
derived based on the cclm_reduced_sample_num. In the case that the
cclm_reduced_sample_num value is 0, N.sub.th may be derived as 2,
in the case that the cclm_reduced_sample_num value is 1, N.sub.th
may be derived as 4, in the case that the cclm_reduced_sample_num
value is 2, N.sub.th may be derived as 8, and in the case that the
cclm_reduced_sample_num value is 3, N.sub.th may be derived as
16.
[0129] Meanwhile, in the case that the additional information
representing N.sub.th is transmitted in a unit of CU, slice,
picture or sequence, the encoding apparatus may determine the
N.sub.th value as below and transmit the additional information
representing N.sub.th that represent the N.sub.th value. [0130] In
the case that the additional information representing N.sub.th is
transmitted in a unit of CU, when an intra-prediction mode of the
current chroma block is CCLM mode, the encoding apparatus may
determine a side of good encoding efficiency between two following
cases through RDO and transmit information of the determined method
to the decoding apparatus.
[0131] 1) In the case that encoding efficiency is good when a CCLM
parameter calculation is performed through the existing CCLM
reference sample selection method, cclm_reduced_sample_flag of
value 0 (false) is transmitted.
[0132] 2) In the case that encoding efficiency is good when
N.sub.th is set to 2 and a CCLM parameter calculation is performed
through the CCLM reference sample selection method proposed in the
present embodiment, cclm_reduced_sample_flag of value 1 (true) is
transmitted. [0133] Alternatively, in the case that the additional
information representing N.sub.th is transmitted in a unit of
slice, picture or sequence, the encoding apparatus may add a high
level syntax (HLS) as represented in Table 3, Table 4 or Table 5
described above and transmit the additional information
representing N.sub.th. The encoding apparatus may configure the
N.sub.th value by considering a size of input image or in
accordance with an encoding target bitrate.
[0134] 1) For example, in the case that an input image is HD
quality or more, the encoding apparatus may set as N.sub.th=8, and
in the case that an input image is HD quality or less, the encoding
apparatus may set as N.sub.th=4.
[0135] 2) In the case that image encoding of high quality is
required, the encoding apparatus may set as N.sub.th=8, and in the
case that image encoding of normal quality is required, the
encoding apparatus may set as N.sub.th=2.
[0136] Meanwhile, as represented in Table 2 described above, when
the method proposed in the present embodiment is used, it is
identified that an amount of operation required for the CCLM
parameter calculation is not increase even a block size is
increased. As an example, in the case that a current chroma block
size is 32.times.32, an amount of operation required for the CCLM
parameter calculation may be reduced as 86% through the method
proposed in the present embodiment (e.g., it is set:
N.sub.th=4).
[0137] The table below may represent an experiment result data in
the case that the N.sub.th is 2.
TABLE-US-00007 TABLE 7 All Intra Main10 Over VTM-2.0.1 Y U V EncT
DecT Class A1 0.58% 2.19% 1.87% 100% 99% Class A2 0.37% 1.92% 0.83%
100% 100% Class B 0.21% 0.91% 1.08% 100% 98% Class C 0.21% 1.07%
1.35% 99% 99% Class E 0.13% 1.14% 0.88% 99% 98% Overall 0.28% 1.37%
1.20% 100% 99% Class D 0.18% 1.05% 0.72% 99% 95%
[0138] In addition, the table below may represent an experiment
result data in the case that the N.sub.th is 4.
TABLE-US-00008 TABLE 8 All Intra Main10 Over VTM-2.0.1 Y U V EncT
DecT Class A1 0.07% 0.11% 0.00% 99% 98% Class A2 0.08% 0.37% 0.10%
98% 99% Class B 0.03% 0.03% 0.01% 96% 94% Class C 0.02% 0.07% 0.14%
96% 93% Class E 0.02% 0.10% 0.09% 97% 91% Overall 0.04% 0.12% 0.07%
97% 95% Class D 0.02% 0.27% -0.09% 97% 92%
[0139] In addition, the table below may represent an experiment
result data in the case that the N.sub.th is 8.
TABLE-US-00009 TABLE 9 All Intra Main10 OverVTM-2.0.1 Y U V EncT
DecT Class A1 0.00% -0.22% -0.14% 98% 98% Class A2 0.01% 0.18%
-0.05% 98% 98% Class B 0.00% -0.04% -0.06% 97% 94% Class C -0.01%
0.02% 0.00% 95% 92% Class E -0.02% 0.00% -0.17% 97% 95% Overall
0.00% -0.01% -0.08% 97% 95% Class D 0.01% 0.02% -0.10% 97% 92%
[0140] In addition, the table below may represent an experiment
result data in the case that the N.sub.th is 16.
TABLE-US-00010 TABLE 10 All Intra Main10 Over VTM-2.0.1 Y U V EncT
DecT Class A1 -0.04% -0.22% -0.16% 99% 98% Class A2 -0.00% -0.06%
-0.02% 98% 97% Class B -0.01% -0.02% -0.09% 97% 94% Class C -0.01%
-0.01% -0.11% 97% 93% Class E -0.01% -0.21% -0.12% 96% 90% Overall
-0.01% -0.07% -0.05% 97% 94% Class D -0.01% -0.06% -0.07% 98%
92%
[0141] Table 7 to Table 10 above may represent coding efficiency
and operation complexity in the case that the N.sub.th is 2, 4, 8
and 16, respectively.
[0142] Referring to Table 7 to Table 10 above, it is identified
that encoding efficiency is not significantly changed even in the
case of reducing an amount of operation required for the CCLM
parameter calculation. For example, referring to Table 8, in the
case that the N.sub.th is set to 4 (N.sub.th=4), encoding
efficiency for each component is Y 0.04%, Cb 0.12% and Cr 0.07%,
which identifies that encoding efficiency is not significantly
changed in comparison with the case of not setting the N.sub.th,
and encoding and decoding complexity is reduced to 97% and 95%,
respectively.
[0143] In addition, referring to Table 9 and Table 10, in the case
of reducing an amount of operation required for the CCLM parameter
calculation (i.e., N.sub.th=8 or 16), it is identified that
encoding efficiency becomes better, and encoding and decoding
complexity is reduced.
[0144] The method proposed in the present embodiment may be used
for a CCLM mode which is an intra-prediction mode for a chroma
component, and the chroma block predicted through the CCLM mode may
be used for deriving a residual image through a differential from
an original image in the encoding apparatus or used for
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0145] FIGS. 7a and 7b are diagrams for describing a procedure of
performing CCLM prediction for a current chroma block according to
an embodiment.
[0146] Referring to FIG. 7a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S700). For example, the CCLM parameter may be calculated as
the embodiment shown in FIG. 7b.
[0147] FIG. 7b may illustratively represent a specific embodiment
of calculating a CCLM parameter. For example, referring to FIG. 7b,
the encoding apparatus/decoding apparatus may set N.sub.th for the
current chroma block (step, S705). The N.sub.th may be a preset
value, or may be derived based on additional information on the
signaled N.sub.th. The N.sub.th may be set as 2, 4, 8, or 16.
[0148] Thereafter, the encoding apparatus/decoding apparatus may
determine whether the current chroma block is a square chroma block
(step, S710).
[0149] When the current chroma block is the square chroma block,
the encoding apparatus/decoding apparatus may determine whether the
width N of the current block is greater than the N.sub.th (step,
S715).
[0150] When the N is greater than the N.sub.th, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for calculating the CCLM parameter (step,
S720).
[0151] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S725).
[0152] Additionally, in the case that the N is not greater than the
N.sub.th, the encoding apparatus/decoding apparatus may select 2N
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S730). Thereafter, the encoding apparatus/decoding apparatus
may derive parameters .alpha. and .beta. for the CCLM prediction
based on the selected reference samples (step, S725).
[0153] Meanwhile, in the case that the current chroma block is not
the square chroma block, the size of the current chroma block may
be derived as M.times.N size or N.times.M size (step, S735). Here,
the M may represent a value greater than the N (N<M).
[0154] Thereafter, the encoding apparatus/decoding apparatus may
determine whether the N is greater than the N.sub.th (step,
S740).
[0155] In the case that the N is greater than the Nm, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for calculating the CCLM parameter (step,
S745).
[0156] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S725).
[0157] Additionally, in the case that the N is not greater than the
N.sub.th, the encoding apparatus/decoding apparatus may select 2N
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S750). Thereafter, the encoding apparatus/decoding apparatus
may derive parameters .alpha. and .beta. for the CCLM prediction
based on the selected reference samples (step, S725).
[0158] Referring back to FIG. 7a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S760). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0159] Meanwhile, in the present disclosure, in deriving the CCLM
parameter, an embodiment which is different from the present
embodiment of reducing operation complexity for deriving the CCLM
parameter may be proposed.
[0160] As an example, in order to solve the problem of increase of
the CCLM parameter operation amount as the chroma block size
increase described above, an embodiment may be proposed for
calculating the CCLM parameter by configuring a neighboring sample
selection upper limit N.sub.th to a block size of the current
chroma block adaptively and selecting a neighboring pixel of the
current chroma block based on the configured N.sub.th. The N.sub.th
may also be represented as a maximum neighboring sample number.
[0161] For example, the N.sub.th may be configured to a block size
of the current chroma block adaptively as below. [0162] In the case
that N<=TH in the current chroma block of N.times.M size or
M.times.N size (here, N<=M), it is configured: N.sub.th=2.
[0163] In the case that N>TH in the current chroma block of
N.times.M size or M.times.N size (here, N<=M), it is configured:
N.sub.th=4.
[0164] In this case, for example, depending on a threshold value
TH, a reference sample used for calculating the CCLM parameter may
be selected as below.
[0165] For example, in the case that the TH is 4 (TH=4), and in the
case that the N of the current chroma block is 2 or 4, two sample
pairs for a block side is used, and the CCLM parameter may be
calculated, and in the case that the N is 8, 16 or 32, four sample
pairs for a block side is used, and the CCLM parameter may be
calculated.
[0166] In addition, for example, in the case that the TH is 8
(TH=8), two sample pairs for a block side is used, and the CCLM
parameter may be calculated, and in the case that the N is 16 or
32, four sample pairs for a block side is used, and the CCLM
parameter may be calculated.
[0167] As described above, according to the present embodiment, the
N.sub.th is configured to a block size of the current chroma block
adaptively, a sample number which is optimized for a block size may
be selected.
[0168] For example, an amount of operation for the CCLM parameter
calculation according to the existing CCLM reference sample
selection method and the present embodiment may be represented as
the following table.
TABLE-US-00011 TABLE 11 Number of operations ( multiplication +
sums ) Proposed Proposed Block Original method method size CCLM (TH
= 4) (TH = 8) N = 2 24 24 24 N = 4 44 24 24 N = 8 84 44 24 N = 16
164 44 44 N = 32 324 44 44
[0169] Here, the N may represent the smallest value of a width and
a height of the current block. Referring to Table 11 above, in the
case that the CCLM reference sample selection method proposed in
the present embodiment is used, an amount of operation required for
the CCLM parameter calculation is not increased even in the case
that a block size is increased.
[0170] Meanwhile, the TH may be derived as a predetermined value in
the encoding apparatus and the decoding apparatus without need to
transmit additional information representing the TH. Alternatively,
additional information representing the TH may be transmitted in a
unit of Coding Unit (CU), slice, picture or sequence, and the TH
may be derived based on the additional information representing the
TH. The additional information representing the TH may represent a
value of the TH.
[0171] For example, in the case that the additional information
representing TH is transmitted in a CU unit, when an
intra-prediction mode of a current chroma block is the CCLM mode,
as described below, a method may be proposed to parse syntax
element cclm_reduced_sample_flag and perform a CCLM parameter
calculation procedure. The cclm_reduced_sample_flag may represent a
syntax element of CCLM reduced sample flag. [0172] In the case that
the cclm_reduced_sample_flag is 0 (false), it is configured the
N.sub.th=4 for all blocks, and a CCLM parameter calculation is
performed through the neighboring sample selection method of the
present embodiment proposed in FIG. 7 described above. [0173] In
the case that the cclm_reduced_sample_flag is 1 (true), it is
configured the TH=4, and a CCLM parameter calculation is performed
through the neighboring sample selection method proposed in the
present embodiment described above.
[0174] Alternatively, in the case that the additional information
representing TH is transmitted in a unit of slice, picture or
sequence, as described below, TH value may be decoded based on the
additional information transmitted through a high level syntax
(HLS).
[0175] For example, the additional information signaled through a
slice header may be represented as the following table.
TABLE-US-00012 TABLE 12 slice_header( ) { Descriptor ...
cclm_reduced_sample_threshold u(1) ...
[0176] cclm_reduced_sample_threshold may represent a syntax element
of the additional information representing TH.
[0177] Alternatively, for example, the additional information
signaled through a Picture Parameter Set (PPS) may be represented
as the following table.
TABLE-US-00013 TABLE 13 pic_parameter_set_rbsp( ) { Descriptor ...
cclm_reduced_sample_threshold u(1) ...
[0178] Alternatively, for example, the additional information
signaled through a Sequence Parameter Set (SPS) may be represented
as the following table.
TABLE-US-00014 TABLE 14 sps_parameter_set_rbsp( ) { Descriptor ...
cclm_reduced_sample_threshold u(1) ...
[0179] TH value, which is derived based on the
cclm_reduced_sample_threshold value (i.e., a value derived by
decoding cclm_reduced_sample_threshold) transmitted through the
slice header, the PPS or the SPS, may be derived as represented in
the following table.
TABLE-US-00015 TABLE 15 cclm_reduced_sample_threshold TH 0 4 1
8
[0180] For example, referring to Table 15 above, the TH may be
derived based on the cclm_reduced_sample_threshold. In the case
that the cclm_reduced_sample_threshold value is 0, the TH may be
derived as 4, and in the case that the
cclm_reduced_sample_threshold value is 1, the TH may be derived as
8.
[0181] Meanwhile, in the case that the TH is derived as a
predetermined value in the encoding apparatus and the decoding
apparatus without transmitting separate additional information, the
encoding apparatus may perform the CCLM parameter calculation for
the CCLM prediction as the present embodiment described above based
on the predetermined TH value.
[0182] Alternatively, the encoding apparatus may determine whether
to use the threshold value TH and may transmit information
representing whether to use the TH and the additional information
representing the TH value to the decoding apparatus as below.
[0183] In the case that the information representing whether to use
the TH is transmitted in a unit of CU, when an intra-prediction
mode of the current chroma block is CCLM mode (i.e., the CCLM
prediction is applied to the current chroma block), the encoding
apparatus may determine a side of good encoding efficiency between
two following cases through RDO and transmit information of the
determined method to the decoding apparatus.
[0184] 1) In the case that encoding efficiency is good when the
N.sub.th is set to 4 for all blocks and a CCLM parameter
calculation is performed through the reference sample selection
method of the present embodiment proposed in FIG. 7 described
above, cclm_reduced_sample_flag of value 0 (false) is
transmitted.
[0185] 2) In the case that encoding efficiency is good when the TH
is set to 4 and a CCLM parameter calculation is performed through
the reference sample selection method of the present embodiment
proposed, cclm_reduced_sample_flag of value 1 (true) is
transmitted. [0186] Alternatively, in the case that the information
representing whether to use the TH is transmitted in a unit of
slice, picture or sequence, the encoding apparatus may add a high
level syntax (HLS) as represented in Table 12, Table 13 or Table 14
described above and transmit the information representing whether
to use the TH. The encoding apparatus may configure the use of the
TH by considering a size of input image or in accordance with an
encoding target bitrate.
[0187] 1) For example, in the case that an input image is HD
quality or more, the encoding apparatus may set as TH=8, and in the
case that an input image is HD quality or less, the encoding
apparatus may set as TH=4.
[0188] 2) In the case that image encoding of high quality is
required, the encoding apparatus may set as TH=8, and in the case
that image encoding of normal quality is required, the encoding
apparatus may set as TH=4.
[0189] The method proposed in the present embodiment may be used
for a CCLM mode which is an intra-prediction mode for a chroma
component, and the chroma block predicted through the CCLM mode may
be used for deriving a residual image through a differential from
an original image in the encoding apparatus or used for
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0190] FIGS. 8a and 8b are diagrams for describing a procedure of
performing CCLM prediction for a current chroma block according to
an embodiment.
[0191] Referring to FIG. 8a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S800). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 8b.
[0192] FIG. 8b may illustratively represent a specific embodiment
of calculating a CCLM parameter. For example, referring to FIG. 8b,
the encoding apparatus/decoding apparatus may set TH for the
current chroma block (step, S805). The TH may be a preset value, or
may be derived based on additional information on the signaled TH.
The TH may be set as 4 or 8.
[0193] Thereafter, the encoding apparatus/decoding apparatus may
determine whether the current chroma block is a square chroma block
(step, S810).
[0194] In the case that the current chroma block is the square
chroma block, the encoding apparatus/decoding apparatus may
determine whether the width N of the current block is greater than
the TH (step, S815).
[0195] In the case that the N is greater than the TH, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for calculating the CCLM parameter (step, S820).
Here, the N.sub.th may be 4. That is, in the case that the N is
greater than the TH, the N.sub.th may be 4.
[0196] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S825).
[0197] Additionally, in the case that the N is not greater than the
TH, the encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S830). Here, the N.sub.th may be 2. That is, in the cast
that the N is greater than the TH, the Na may be 2. Thereafter, the
encoding apparatus/decoding apparatus may derive parameters .alpha.
and .beta. for the CCLM prediction based on the selected reference
samples (step, S825).
[0198] Meanwhile, in the case that the current chroma block is not
the square chroma block, the size of the current chroma block may
be derived as M.times.N size or N.times.M size (step, S835). Here,
the M may represent a value greater than the N (N<M).
[0199] Thereafter, the encoding apparatus/decoding apparatus may
determine whether the N is greater than the TH (step, S840).
[0200] In the case that the N is greater than the TH, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for calculating the CCLM parameter (step, S845).
Here, the N.sub.th may be 4. That is, in the case that the N is
greater than the TH, the N.sub.th may be 4.
[0201] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S825).
[0202] Additionally, in the case that the N is not greater than the
TH, the encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S850). Here, the N.sub.th may be 2. That is, in the cast
that the N is greater than the TH, the N.sub.th may be 2.
Thereafter, the encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S825).
[0203] Referring back to FIG. 8a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S860). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0204] Meanwhile, in the present disclosure, in deriving the CCLM
parameter, an embodiment which is different from the present
embodiment of reducing operation complexity for deriving the CCLM
parameter may be proposed.
[0205] Particularly, in order to solve the problem of increase of
CCLM parameter operation amount as the chroma block size increase
described above, the present embodiment proposes a method of
configuring a pixel selection upper limit N.sub.th adaptively. In
addition, in the case that N=2 (here, N is a smaller value between
a width and a height of a chroma block), in order to prevent the
worst case operation (a case CCLM prediction is performed for all
chroma blocks, after all chroma blocks in a CTU is divided into
2.times.2 size) occurred in CCLM prediction for a chroma block of
2.times.2 size, the present embodiment proposes a method of
configuring N.sub.th adaptively, and through this, an amount of
operation for CCLM parameter calculation in the worst cast may be
reduced by about 40%.
[0206] For example, according to the present embodiment, the
N.sub.th may be configured to a block size adaptively as below.
[0207] Method 1 in the present embodiment (proposed method 1)
[0208] In the case that N<=2 in the current chroma block of
N.times.M size or M.times.N size (here, e.g., N<=M), N.sub.th
may be set to 1 (N.sub.th=1). [0209] In the case that N=4 in the
current chroma block of N.times.M size or M.times.N size (here,
e.g., N<=M), N.sub.th may be set to 2 (N.sub.th=2). [0210] In
the case that N>4 in the current chroma block of N.times.M size
or M.times.N size (here, e.g., N<=M), N.sub.th may be set to 4
(N.sub.th=4).
[0211] Alternatively, for example, according to the present
embodiment, the N.sub.th may be configured to a block size
adaptively as below. [0212] Method 2 in the present embodiment
(proposed method 2) [0213] In the case that N<=2 in the current
chroma block of N.times.M size or M.times.N size (here, e.g.,
N<=M), N.sub.th may be set to 1 (N.sub.th=1). [0214] In the case
that N=4 in the current chroma block of N.times.M size or M.times.N
size (here, e.g., N<=M), N.sub.th may be set to 2 (N.sub.th=2).
[0215] In the case that N=8 in the current chroma block of
N.times.M size or M.times.N size (here, e.g., N<=M), N.sub.th
may be set to 4 (N.sub.th=4). [0216] In the case that N>8 in the
current chroma block of N.times.M size or M.times.N size (here,
e.g., N<=M), N.sub.th may be set to 8 (N.sub.th=8).
[0217] Alternatively, for example, according to the present
embodiment, the N.sub.th may be configured to a block size
adaptively as below. [0218] Method 3 in the present embodiment
(proposed method 3) [0219] In the case that N<=2 in the current
chroma block of N.times.M size or M.times.N size (here, e.g.,
N<=M), N.sub.th may be set to 1 (N.sub.th=1). [0220] In the case
that N>2 in the current chroma block of N.times.M size or
M.times.N size (here, e.g., N<=M), N.sub.th may be set to 2
(N.sub.th=2).
[0221] Alternatively, for example, according to the present
embodiment, the N.sub.th may be configured to a block size
adaptively as below. [0222] Method 4 in the present embodiment
(proposed method 4) [0223] In the case that N<=2 in the current
chroma block of N.times.M size or M.times.N size (here, e.g.,
N<=M), N.sub.th may be set to 1 (N.sub.th=1). [0224] In the case
that N>2 in the current chroma block of N.times.M size or
M.times.N size (here, e.g., N<=M), N.sub.th may be set to 4
(N.sub.th=4).
[0225] Method 1 to method 4 described above in the present
embodiment may reduce a complexity of the worst case by about 40%,
and since N.sub.th may be adaptively applied to each chroma block
size, encoding loss may be minimized. In addition, for example,
since method 2 may apply N.sub.th up to 8 in variable manner, this
may proper to high quality image encoding. Since method 3 and
method 4 may reduce N.sub.th to 4 or 2, CCLM complexity may be
reduced significantly, and may proper to low image quality or
middle image quality.
[0226] As described in method 1 to method 4, according to the
present embodiment, N.sub.th may be configured adaptively to a
block size, and through this, a reference sample number for
deriving an optimized CCLM parameter may be selected.
[0227] The encoding apparatus/decoding apparatus may set the upper
limit N.sub.th for neighboring sample selection, and then,
calculate a CCLM parameter by selecting a chroma block neighboring
sample as described above.
[0228] An amount of CCLM parameter calculation according to a
chroma block size in the case to which the present embodiment
described above is applied may be represented as the following
table.
TABLE-US-00016 TABLE 16 Number of operations (multiplication +
sums) Proposed Proposed Proposed Proposed Block Original method 1
method 2 method 3 method 4 size CCLM (N.sub.th = 1, 2, 4) (N.sub.th
= 1, 2, 4, 8) (N.sub.th = 1, 2) (N.sub.th = 1, 4) N = 2 24 14 14 14
14 N = 4 44 24 24 24 44 N = 8 84 44 44 24 44 N = 16 164 44 84 24 44
N = 32 324 44 84 24 44
[0229] As represented in Table 16 above, in the case that the
methods proposed in the present embodiment is used, it is
identified that an amount of operation required for the CCLM
parameter calculation is not increase even a block size is
increased.
[0230] Meanwhile, according to the present embodiment, without need
to transmit additional information, a promised value may be used in
the encoding apparatus and the decoding apparatus, or it may be
transmitted whether to use the proposed method and information
representing the N.sub.th value in a unit of CU, slice, picture and
sequence.
[0231] For example, in the case that information representing
whether to use the proposed method is used in a unit of CU, when an
intra-prediction mode of a current chroma block is CCLM mode (i.e.,
in the case that CCLM prediction is applied to the current chroma
block), cclm_reduced_sample_flag may be parsed and the present
embodiment described above may be performed as below. [0232] In the
case that the cclm_reduced_sample_flag is 0 (false), it is
configured N.sub.th=4 for all blocks, and a CCLM parameter
calculation is performed through the neighboring sample selection
method of the present embodiment proposed in FIG. 7 described
above. [0233] In the case that the cclm_reduced_sample_flag is 1
(true), a CCLM parameter calculation is performed through method 3
of the present embodiment described above.
[0234] Alternatively, in the case that the information representing
the applied method is transmitted in a unit of slice, picture or
sequence, as described below, the method among method 1 to method 4
may be selected based on the information transmitted through a high
level syntax (HLS), and based on the selected method, the CCLM
parameter may be calculated.
[0235] For example, the information representing the applied method
signaled through a slice header may be represented as the following
table.
TABLE-US-00017 TABLE 17 slice_header( ) { Descriptor . . .
cclm_reduced_sample_threshold f(2) . . .
[0236] cclm_reduced_sample_threshold may represent a syntax element
of the information representing the applied method.
[0237] Alternatively, for example, the information representing the
applied method signaled through a Picture Parameter Set (PPS) may
be represented as the following table.
TABLE-US-00018 TABLE 18 pic_parameter_sct_rbsp( ) { Descriptor . .
. cclm_reduced_sample_threshold f(2) . . .
[0238] Alternatively, for example, the information representing the
applied method signaled through a Sequence Parameter Set (SPS) may
be represented as the following table.
TABLE-US-00019 TABLE 19 sps_parameter_set_rbsp( ) { Descriptor . .
. cclm_reduced_sample_threshold f(2) . . .
[0239] The method selected based on cclm_reduced_sample_threshold
value (i.e., a value derived by decoding
cclm_reduced_sample_threshold) transmitted through the slice
header, the PPS or the SPS may be derived as represented in the
following table.
TABLE-US-00020 TABLE 20 cclm_reduced_sample_threshold Proposed
method 0 1 (N.sub.th = 1, 2, 4) 1 2 (N.sub.th = 1, 2, 4, 8) 2 3
(N.sub.th = 1, 2) 3 4 (N.sub.th = 1, 4)
[0240] Referring to Table. 20, in the case that the
cclm_reduced_sample_threshold value is 0, method 1 may be selected
as the method applied to the current chroma block, in the case that
the cclm_reduced_sample_threshold value is 1, method 2 may be
selected as the method applied to the current chroma block, in the
case that the cclm_reduced_sample_threshold value is 2, method 3
may be selected as the method applied to the current chroma block,
and in the case that the cclm_reduced_sample_threshold value is 3,
method 4 may be selected as the method applied to the current
chroma block.
[0241] The method proposed in the present embodiment may be used a
CCLM mode which is an intra-prediction mode for a chroma component,
and the chroma block predicted through the CCLM mode may be used
for deriving a residual image through a differential from an
original image in the encoding apparatus or used for deriving a
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0242] Meanwhile, in the case that the information representing one
of the methods is transmitted in a unit of CU, slice, picture and
sequence, the encoding apparatus may determine one of method 1 to
method 4 and transmit the information to the decoding apparatus as
below. [0243] In the case that the information representing whether
the method of the present embodiment described above is applied is
transmitted in a unit of CU, when an intra-prediction mode of the
current chroma block is CCLM mode (i.e., the CCLM prediction is
applied to the current chroma block), the encoding apparatus may
determine a side of good encoding efficiency between two following
cases through RDO and transmit information of the determined method
to the decoding apparatus.
[0244] 1) In the case that encoding efficiency is good when the
N.sub.th is set to 4 for all blocks and a CCLM parameter
calculation is performed through the reference sample selection
method of the present embodiment proposed in FIG. 7 described
above, cclm_reduced_sample_flag of value 0 (false) is
transmitted.
[0245] 2) In the case that encoding efficiency is good when it is
configured that method 3 is applied and a CCLM parameter
calculation is performed through the reference sample selection
method of the present embodiment proposed, cclm_reduced_sample_flag
of value 1 (true) is transmitted. [0246] Alternatively, in the case
that the information representing whether the method of the present
embodiment described above is applied is transmitted in a unit of
slice, picture or sequence, the encoding apparatus may add a high
level syntax (HLS) as represented in Table 17, Table 18 or Table 19
described above and transmit the information representing one
method among the methods. The encoding apparatus may configure the
method applied among the methods by considering a size of input
image or in accordance with an encoding target bitrate.
[0247] 1) For example, in the case that an input image is HD
quality or more, the encoding apparatus may apply method 2
(N.sub.th=1, 2, 4 or 8), and in the case that an input image is HD
quality or less, the encoding apparatus may apply method 1
(N.sub.th=1, 2 or 4).
[0248] 2) In the case that image encoding of high quality is
required, the encoding apparatus may apply method 2 (N.sub.th=1, 2,
4 or 8), and in the case that image encoding of normal quality is
required, the encoding apparatus may apply method 4 (N.sub.th=1 or
4).
[0249] The method proposed in the present embodiment may be used
for a CCLM mode which is an intra-prediction mode for a chroma
component, and the chroma block predicted through the CCLM mode may
be used for deriving a residual image through a differential from
an original image in the encoding apparatus or used for
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0250] FIGS. 9a and 9b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 1 of the present
embodiment described above.
[0251] Referring to FIG. 9a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S900). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 9b.
[0252] FIG. 9b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 9b, the encoding
apparatus/decoding apparatus may determine whether the current
chroma block is a square chroma block (step, S905).
[0253] In the case that the current chroma block is the square
chroma block, the encoding apparatus/decoding apparatus may set a
width or a height of the current block to N (step, S910), and
determine whether the N is smaller than 2 (N<2) (step,
S915).
[0254] Alternatively, in the case that the current chroma block is
not the square chroma block, the size of the current chroma block
may be derived in M.times.N size or N.times.M size (step, S920).
The encoding apparatus/decoding apparatus may determine whether the
N is less than 2 (step, S915). Here, the M may represent a value
greater than the N (N<M).
[0255] In the case that the N is smaller than 2, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S925).
Here, the N.sub.th may be 1 (N.sub.th=1).
[0256] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S930).
[0257] Meanwhile, in the case that the N is not smaller than 2, the
encoding apparatus/decoding apparatus may determine whether the N
is 4 or less (N<=4) (step, S935).
[0258] In the case that the N is 4 or less, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S940).
Here, the N.sub.th may be 2 (N.sub.th=2). Thereafter, the encoding
apparatus/decoding apparatus may derive parameters .alpha. and
.beta. for the CCLM prediction based on the selected reference
samples (step, S930).
[0259] Alternatively, in the case that the N is greater than 4, the
encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for the CCLM parameter calculation
(step, S945). Here, the N.sub.th may be 4 (N.sub.th=4). Thereafter,
the encoding apparatus/decoding apparatus may derive parameters
.alpha. and .beta. for the CCLM prediction based on the selected
reference samples (step, S930).
[0260] Referring back to FIG. 9a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S950). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0261] FIGS. 10a and 10b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 2 of the present
embodiment described above.
[0262] Referring to FIG. 10a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1000). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 10b.
[0263] FIG. 10b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 10b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1005).
[0264] In the case that the current chroma block is the square
chroma block, the encoding apparatus/decoding apparatus may set a
width or a height of the current block to N (step, S1010) and
determine whether N is smaller than 2 (N<2) (step, S1015).
[0265] Alternatively, in the case that the current chroma block is
not the square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1020). The
encoding apparatus/decoding apparatus determine whether the N is
smaller than 2 (step, S1015). Here, the M represents a value
greater than the N (N<M).
[0266] In the case that the N is smaller than 2, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1025).
Here, the N.sub.th may be 1 (N.sub.th=1).
[0267] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1030).
[0268] Meanwhile, in the case that the N is not smaller than 2, the
encoding apparatus/decoding apparatus may determine whether the N
is 4 or less (N<=4) (step, S1035).
[0269] In the case that N is 4 or less, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1040).
Here, the N.sub.th may be 2. Later, the encoding apparatus/decoding
apparatus may derive the parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1030).
[0270] Meanwhile, in the case that the N is greater than 4, the
encoding apparatus/decoding apparatus may determine whether the N
is 8 or less (N<=8) (step, S1045).
[0271] In the case that the N is less than or equal to 8, the
encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S1050). Here, the N.sub.th may be 4 (N.sub.th=4).
Thereafter, the encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1030).
[0272] Alternatively, in the case that the N is greater than 8, the
encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for calculating the CCLM parameter
(step, S1055). Here, the N.sub.th may be 8 (N.sub.th=8).
Thereafter, the encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1030).
[0273] Referring back to FIG. 10a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1060). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0274] FIGS. 11a and 11b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 3 of the present
embodiment described above.
[0275] Referring to FIG. 11a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1100). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 11b.
[0276] FIG. 11b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 11b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1105).
[0277] In the case that the current chroma block is a square chroma
block, the encoding apparatus/decoding apparatus may set a width or
a height of the current block to N (step, S1110) and determine
whether N is smaller than 2 (N<2) (step, S1115).
[0278] Alternatively, in the case that the current chroma block is
not a square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1120). The
encoding apparatus/decoding apparatus determine whether the N is
smaller than 2 (step, S115). Here, the M represents a value greater
than the N (N<M).
[0279] In the case that the N is smaller than 2, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1125).
Here, the N.sub.th may be 1 (N.sub.th=1).
[0280] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1130).
[0281] Meanwhile, in the case that the N is not smaller than 2, the
encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for the CCLM parameter calculation
(step, S1135). Here, the N.sub.th may be 2 (N.sub.th=2).
Thereafter, the encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1130).
[0282] Referring back to FIG. 11a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1140). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0283] FIGS. 12a and 12b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 4 of the present
embodiment described above.
[0284] Referring to FIG. 12a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1200). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 12b.
[0285] FIG. 12b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 12b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1205).
[0286] In the case that the current chroma block is a square chroma
block, the encoding apparatus/decoding apparatus may set a width or
a height of the current block to N (step, S1210) and determine
whether N is smaller than 2 (N<2) (step, S1215).
[0287] Alternatively, in the case that the current chroma block is
not a square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1220). The
encoding apparatus/decoding apparatus determine whether the N is
smaller than 2 (step, S1215). Here, the M represents a value
greater than the N (N<M).
[0288] In the case that the N is smaller than 2, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1225).
Here, the N.sub.th may be 1 (N.sub.th=1).
[0289] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1230).
[0290] Meanwhile, in the case that the N is not smaller than 2, the
encoding apparatus/decoding apparatus may select 2N.sub.th
neighboring samples in a reference line adjacent to the current
block as a reference sample for the CCLM parameter calculation
(step, S1235). Here, the N.sub.th may be 4 (N.sub.th=4).
Thereafter, the encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1230).
[0291] Referring back to FIG. 12a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1240). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0292] Meanwhile, in the present disclosure, in deriving the CCLM
parameter, an embodiment which is different from the present
embodiment of reducing operation complexity for deriving the CCLM
parameter may be proposed.
[0293] Particularly, in order to solve the problem of increase of
CCLM parameter operation amount as the chroma block size increase
described above, the present embodiment proposes a method of
configuring a pixel selection upper limit N.sub.th adaptively.
[0294] For example, according to the present embodiment, the
N.sub.th may be configured to a block size adaptively as below.
[0295] Method 1 in the present embodiment (proposed method 1)
[0296] In the case that a current chroma block is a chroma block of
2.times.2 size, N.sub.th may be set to 1 (N.sub.th=1). [0297] In
the case that N=2 in the current chroma block of N.times.M size or
M.times.N size (here, e.g., N<M), N.sub.th may be set to 2
(N.sub.th=2). [0298] In the case that N>2 in the current chroma
block of N.times.M size or M.times.N size (here, e.g., N<=M),
N.sub.th may be set to 4 (N.sub.th=4).
[0299] Alternatively, for example, according to the present
embodiment, the N.sub.th may be configured to a block size
adaptively as below. [0300] Method 2 in the present embodiment
(proposed method 2) [0301] In the case that a current chroma block
is a chroma block of 2.times.2 size, N.sub.th may be set to 1
(N.sub.th=1). [0302] In the case that N=2 in the current chroma
block of N.times.M size or M.times.N size (here, e.g., N<M),
N.sub.th may be set to 2 (N.sub.th=2). [0303] In the case that N=4
in the current chroma block of N.times.M size or M.times.N size
(here, e.g., N<=M), N.sub.th may be set to 2 (N.sub.th=2).
[0304] In the case that N>4 in the current chroma block of
N.times.M size or M.times.N size (here, e.g., N<=M), N.sub.th
may be set to 4 (N.sub.th=4).
[0305] Alternatively, for example, according to the present
embodiment, the N.sub.th may be configured to a block size
adaptively as below. [0306] Method 3 in the present embodiment
(proposed method 3) [0307] In the case that a current chroma block
is a chroma block of 2.times.2 size, N.sub.th may be set to 1
(N.sub.th=1). [0308] In the case that N=2 in the current chroma
block of N.times.M size or M.times.N size (here, e.g., N<M),
N.sub.th may be set to 2 (N.sub.th=2). [0309] In the case that N=4
in the current chroma block of N.times.M size or M.times.N size
(here, e.g., N<=M), N.sub.th may be set to 4 (N.sub.th=4).
[0310] In the case that N>4 in the current chroma block of
N.times.M size or M.times.N size (here, e.g., N<=M), N.sub.th
may be set to 8 (N.sub.t=8).
[0311] Method 1 to method 3 described above in the present
embodiment may reduce a complexity of the worst case in the case
that the current chroma block is 2.times.2 by about 40%, and since
N.sub.th may be adaptively applied to each chroma block size,
encoding loss may be minimized. In addition, for example, since
method 1 and method 3 may apply N.sub.th to 4 in the case of
N>2, this may proper to high quality image encoding. Since
method 2 may reduce N.sub.th to 2 even in the case of N=4, CCLM
complexity may be reduced significantly, and may proper to low
image quality or middle image quality.
[0312] As described in method 1 to method 3, according to the
present embodiment, N.sub.th may be configured adaptively to a
block size, and through this, a reference sample number for
deriving an optimized CCLM parameter may be selected.
[0313] The encoding apparatus/decoding apparatus may set the upper
limit N.sub.th for neighboring sample selection, and then,
calculate a CCLM parameter by selecting a chroma block neighboring
sample as described above.
[0314] An amount of CCLM parameter calculation according to a
chroma block size in the case to which the present embodiment
described above is applied may be represented as the following
table.
TABLE-US-00021 TABLE 21 Number of operations (multiplication +
sums) Proposed Proposed Proposed Block Original method 1 method 2
method 2 size CCLM (N.sub.th = 1, 2, 4) (N.sub.th = 1, 2, 2, 4)
(N.sub.th = 1, 2, 4, 8) 2 .times. 2 24 14 14 14 N = 2 24 24 24 24 N
= 4 44 44 24 44 N = 8 84 44 44 84 N = 16 164 44 44 84 N = 32 324 44
44 84
[0315] As represented in Table 21 above, in the case that the
methods proposed in the present embodiment is used, it is
identified that an amount of operation required for the CCLM
parameter calculation is not increase even a block size is
increased.
[0316] Meanwhile, according to the present embodiment, without need
to transmit additional information, a promised value may be used in
the encoding apparatus and the decoding apparatus, or it may be
transmitted whether to use the proposed method and information
representing the N.sub.th value in a unit of CU, slice, picture and
sequence.
[0317] For example, in the case that information representing
whether to use the proposed method is used in a unit of CU, when an
intra-prediction mode of a current chroma block is CCLM mode (i.e.,
in the case that CCLM prediction is applied to the current chroma
block), cclm_reduced_sample_flag may be parsed and the present
embodiment described above may be performed as below. [0318] In the
case that the cclm_reduced_sample_flag is 0 (false), it is
configured N.sub.th=2 for all blocks, and a CCLM parameter
calculation is performed through the neighboring sample selection
method of the present embodiment proposed in FIG. 7 described
above. [0319] In the case that the cclm_reduced_sample_flag is 1
(true), a CCLM parameter calculation is performed through method 1
of the present embodiment described above.
[0320] Alternatively, in the case that the information representing
the applied method is transmitted in a unit of slice, picture or
sequence, as described below, the method among method 1 to method 3
may be selected based on the information transmitted through a high
level syntax (HLS), and based on the selected method, the CCLM
parameter may be calculated.
[0321] For example, the information representing the applied method
signaled through a slice header may be represented as the following
table.
TABLE-US-00022 TABLE 22 slicc_header( ) { Descriptor . . .
cclm_reduced_sample_threshold f(2) . . .
[0322] cclm_reduced_sample_threshold may represent a syntax element
of the information representing the applied method.
[0323] Alternatively, for example, the information representing the
applied method signaled through a Picture Parameter Set (PPS) may
be represented as the following table.
TABLE-US-00023 TABLE 23 pic_parameter_set_rbsp( ) { Descriptor . .
. cclm_reduced_sample_threshold f(2) . . .
[0324] Alternatively, for example, the information representing the
applied method signaled through a Sequence Parameter Set (SPS) may
be represented as the following table.
TABLE-US-00024 TABLE 24 sps_parameter_sct_rbsp( ) { Descriptor . .
. cclm_reduced_sample_threshold f(2) . . .
[0325] The method selected based on cclm_reduced_sample_threshold
value (i.e., a value derived by decoding
cclm_reduced_sample_threshold) transmitted through the slice
header, the PPS or the SPS may be derived as represented in the
following table.
TABLE-US-00025 TABLE 25 cclm_reduced_sample_threshold Proposed
method 0 Not apply 1 1 (N.sub.th = 1, 2, 4) 2 2 (N.sub.th = 1, 2,
2, 4) 3 3 (N.sub.th = 1, 2, 4, 8)
[0326] Referring to Table. 25, in the case that the
cclm_reduced_sample_threshold value is 0, the methods of the
present embodiment described above may not be applied to the
current chroma block, in the case that the
cclm_reduced_sample_threshold value is 1, method 1 may be selected
as the method applied to the current chroma block, in the case that
the cclm_reduced_sample_threshold value is 2, method 2 may be
selected as the method applied to the current chroma block, and in
the case that the cclm_reduced_sample_threshold value is 3, method
3 may be selected as the method applied to the current chroma
block.
[0327] The method proposed in the present embodiment may be used a
CCLM mode which is an intra-prediction mode for a chroma component,
and the chroma block predicted through the CCLM mode may be used
for deriving a residual image through a differential from an
original image in the encoding apparatus or used for deriving a
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0328] Meanwhile, in the case that the information representing one
of the methods is transmitted in a unit of CU, slice, picture and
sequence, the encoding apparatus may determine one of method 1 to
method 3 and transmit the information to the decoding apparatus as
below. [0329] In the case that the information representing whether
the method of the present embodiment described above is applied is
transmitted in a unit of CU, when an intra-prediction mode of the
current chroma block is CCLM mode (i.e., the CCLM prediction is
applied to the current chroma block), the encoding apparatus may
determine a side of good encoding efficiency between two following
cases through RDO and transmit information of the determined method
to the decoding apparatus.
[0330] 1) In the case that encoding efficiency is good when the
N.sub.th is set to 2 for all blocks and a CCLM parameter
calculation is performed through the reference sample selection
method of the present embodiment proposed in FIG. 7 described
above, cclm_reduced_sample_flag of value 0 (false) is
transmitted.
[0331] 2) In the case that encoding efficiency is good when it is
configured that method 1 is applied and a CCLM parameter
calculation is performed through the reference sample selection
method of the present embodiment proposed, cclm_reduced_sample_flag
of value 1 (true) is transmitted. [0332] Alternatively, in the case
that the information representing whether the method of the present
embodiment described above is applied is transmitted in a unit of
slice, picture or sequence, the encoding apparatus may add a high
level syntax (HLS) as represented in Table 22, Table 23 or Table 24
described above and transmit the information representing one
method among the methods. The encoding apparatus may configure the
method applied among the methods by considering a size of input
image or in accordance with an encoding target bitrate.
[0333] 1) For example, in the case that an input image is HD
quality or more, the encoding apparatus may apply method 3
(N.sub.th=1, 2, 4 or 8), and in the case that an input image is HD
quality or less, the encoding apparatus may apply method 1
(N.sub.th=1, 2 or 4).
[0334] 2) In the case that image encoding of high quality is
required, the encoding apparatus may apply method 3 (N.sub.th=1, 2,
4 or 8), and in the case that image encoding of normal quality is
required, the encoding apparatus may apply method 2 (N.sub.th=1, 2,
2 or 4) or method 1 (N.sub.th=1, 2 or 4).
[0335] The method proposed in the present embodiment may be used
for a CCLM mode which is an intra-prediction mode for a chroma
component, and the chroma block predicted through the CCLM mode may
be used for deriving a residual image through a differential from
an original image in the encoding apparatus or used for
reconstructed image through an addition with a residual signal in
the decoding apparatus.
[0336] FIGS. 13a and 13b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 1 of the present
embodiment described above.
[0337] Referring to FIG. 13a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1300). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 13b.
[0338] FIG. 13b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 13b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1305).
[0339] In the case that the current chroma block is the square
chroma block, the encoding apparatus/decoding apparatus may set a
width or a height of the current block to N (step, S1310) and
determine whether the size of the current chroma block is 2.times.2
size (step, S1315).
[0340] Alternatively, in the case that the current chroma block is
not the square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1320). The
encoding apparatus/decoding apparatus determine whether the size of
the current chroma block is 2.times.2 size (step, S1315). Here, the
M may represent a value greater than the N (N<M).
[0341] In the case that the size of the current chroma block is
2.times.2 size, the encoding apparatus/decoding apparatus may
select 2N.sub.th neighboring samples in a reference line adjacent
to the current block as a reference sample for the CCLM parameter
calculation (step, S1325). Here, the N.sub.th may be 1
(N.sub.th=1).
[0342] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1330).
[0343] Meanwhile, in the case that the size of the current chroma
block is not 2.times.2 size, the encoding apparatus/decoding
apparatus may determine whether the N is 2 (N=2) (step, S1335).
[0344] In the case that the N is 2, the encoding apparatus/decoding
apparatus may select 2N.sub.th neighboring samples in a reference
line adjacent to the current block as a reference sample for the
CCLM parameter calculation (step, S1340). Here, the N.sub.th may be
2 (N.sub.th=2). Thereafter, the encoding apparatus/decoding
apparatus may derive parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1330).
[0345] Alternatively, in the case that the N is not 2, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1345).
Here, the N.sub.th may be 4 (N.sub.th=4). Thereafter, the encoding
apparatus/decoding apparatus may derive parameters .alpha. and
.beta. for the CCLM prediction based on the selected reference
samples (step, S1330).
[0346] Referring back to FIG. 13a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1350). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0347] FIGS. 14a and 14b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 2 of the present
embodiment described above.
[0348] Referring to FIG. 14a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1400). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 14b.
[0349] FIG. 14b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 14b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1405).
[0350] In the case that the current chroma block is a square chroma
block, the encoding apparatus/decoding apparatus may set a width or
a height of the current block to N (step, S1410) and determine
whether a size of the current chroma block is 2.times.2 (step,
S1415).
[0351] Alternatively, in the case that the current chroma block is
not a square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1420). The
encoding apparatus/decoding apparatus determine whether a size of
the current chroma block is 2.times.2 (step, S1415). Here, the M
represents a value greater than the N (N<M).
[0352] In the case that a size of the current chroma block is
2.times.2, the encoding apparatus/decoding apparatus may select
2N.sub.th neighboring samples in a reference line adjacent to the
current block as a reference sample for the CCLM parameter
calculation (step, S1425). Here, the N.sub.th may be 1
(N.sub.th=1).
[0353] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1430).
[0354] Meanwhile, in the case that a size of the current chroma
block is not 2.times.2, the encoding apparatus/decoding apparatus
determine whether the N is 2 (N=2) (step, S1435).
[0355] In the case that the N is 2, the encoding apparatus/decoding
apparatus may select 2N.sub.th neighboring samples in a reference
line adjacent to the current block as a reference sample for the
CCLM parameter calculation (step, S1440). Here, the N.sub.th may be
2 (N.sub.th=2). Later, the encoding apparatus/decoding apparatus
may derive the parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1430).
[0356] Meanwhile, in the case that the N is not 2, the encoding
apparatus/decoding apparatus may determine whether the N is 4(N=4)
(step, S1445).
[0357] In the case that the N is 4, the encoding apparatus/decoding
apparatus may select 2N.sub.th neighboring samples in a reference
line adjacent to the current block as a reference sample for the
CCLM parameter calculation (step, S1450). Here, the N.sub.th may be
2 (N.sub.th=2). Thereafter, the encoding apparatus/decoding
apparatus may derive parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1430).
[0358] Alternatively, in the case that the N is not 4, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1455).
Here, the N.sub.th may be 4 (N.sub.th=4). Thereafter, the encoding
apparatus/decoding apparatus may derive parameters .alpha. and
.beta. for the CCLM prediction based on the selected reference
samples (step, S1430).
[0359] Referring back to FIG. 14a, in the case that the parameters
for CCLM prediction for the current chroma block are calculated,
the encoding apparatus/decoding apparatus may perform CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1460). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0360] FIGS. 15a and 15b are diagrams for describing a procedure of
performing CCLM prediction based on the CCLM parameters of the
current chroma block derived according to method 3 of the present
embodiment described above.
[0361] Referring to FIG. 15a, the encoding apparatus/decoding
apparatus may calculate a CCLM parameter for the current block
(step, S1500). For example, the CCLM parameter may be calculated as
the present embodiment shown in FIG. 15b.
[0362] FIG. 15b may illustrate a specific embodiment of calculating
the CCLM parameter. For example, referring to FIG. 15b, the
encoding apparatus/decoding apparatus may determine whether the
current chroma block is a square chroma block (step, S1505).
[0363] In the case that the current chroma block is a square chroma
block, the encoding apparatus/decoding apparatus may set a width or
a height of the current block to N (step, S1510) and determine
whether a size of the current chroma block is 2.times.2 (step,
S1515).
[0364] Alternatively, in the case that the current chroma block is
not a square chroma block, a size of the current chroma block may
be derived in M.times.N size or N.times.M size (step, S1520). The
encoding apparatus/decoding apparatus determine whether a size of
the current chroma block is 2.times.2 (step, S1515). Here, the M
represents a value greater than the N (N<M).
[0365] In the case that a size of the current chroma block is
2.times.2, the encoding apparatus/decoding apparatus may select
2N.sub.th neighboring samples in a reference line adjacent to the
current block as a reference sample for the CCLM parameter
calculation (step, S1525). Here, the N.sub.th may be 1
(N.sub.th=1).
[0366] The encoding apparatus/decoding apparatus may derive
parameters .alpha. and .beta. for the CCLM prediction based on the
selected reference samples (step, S1530).
[0367] Meanwhile, in the case that a size of the current chroma
block is not 2.times.2, the encoding apparatus/decoding apparatus
determine whether the N is 2 (N=2) (step, S1535).
[0368] In the case that the N is 2, the encoding apparatus/decoding
apparatus may select 2N.sub.th neighboring samples in a reference
line adjacent to the current block as a reference sample for the
CCLM parameter calculation (step, S1540). Here, the N.sub.th may be
2 (N.sub.th=2). Later, the encoding apparatus/decoding apparatus
may derive the parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1530).
[0369] Meanwhile, in the case that the N is not 2, the encoding
apparatus/decoding apparatus may determine whether the N is 4 (N=4)
(step, S1545).
[0370] In the case that the N is 4, the encoding apparatus/decoding
apparatus may select 2N.sub.th neighboring samples in a reference
line adjacent to the current block as a reference sample for the
CCLM parameter calculation (step, S1550). Here, the N.sub.th may be
4 (N.sub.th=4). Later, the encoding apparatus/decoding apparatus
may derive the parameters .alpha. and .beta. for the CCLM
prediction based on the selected reference samples (step,
S1530).
[0371] Alternatively, in the case that the N is not 4, the encoding
apparatus/decoding apparatus may select 2N.sub.th neighboring
samples in a reference line adjacent to the current block as a
reference sample for the CCLM parameter calculation (step, S1555).
Here, the N.sub.th may be 8 (N.sub.th=8). Later, the encoding
apparatus/decoding apparatus may derive the parameters .alpha. and
.beta. for the CCLM prediction based on the selected reference
samples (step, S1530).
[0372] Referring to FIG. 15a again, in the case that the parameters
for CCLM prediction for the current chroma block is calculated, the
encoding apparatus/decoding apparatus may perform the CCLM
prediction based on the parameters and generate a prediction sample
for the current chroma block (step, S1560). For example, the
encoding apparatus/decoding apparatus may generate a prediction
sample for the current chroma block based on above Equation 1 in
which the calculated parameters and reconstructed samples of the
current luma block for the current chroma block are used.
[0373] FIG. 16 schematically represents an image encoding method by
an encoding apparatus according to the present disclosure. The
method disclosed in FIG. 16 may be performed by the encoding
apparatus disclosed in FIG. 2. Specifically, for example, S1600 to
S1660 in FIG. 16 may be performed by the predictor of the encoding
apparatus, and S1670 may be performed by the entropy encoder of the
encoding apparatus. Further, although not shown in the figure, the
process of deriving a residual sample for the current chroma block
based on the original sample and the prediction sample for the
current chroma block may be performed by the subtractor of the
encoding apparatus; the process of deriving reconstructed samples
for the current chroma block based on the residual samples and the
prediction samples for the current chroma block may be performed by
the adder of the encoding apparatus; the process of generating
information on a residual for the current chroma block based on the
residual sample may be performed by the transformer of the encoding
apparatus; and the process of encoding the information on a
residual may be performed by an entropy encoder of the encoding
apparatus.
[0374] The encoding apparatus determines the intra prediction mode
of the current chroma block as a cross-component linear model
(CCLM) mode (step, S1600). For example, the encoding apparatus may
determine the intra prediction mode of the current chroma block
based on a rate-distortion cost (RDO). Here, the RD cost may be
derived based on the sum of absolute differences (SAD). The
encoding apparatus may determine the CCLM mode as the intra
prediction mode of the current chroma block based on the RD
cost.
[0375] In addition, the encoding apparatus may encode information
indicating the intra prediction mode of the current chroma block,
and the prediction mode information may be signaled through a
bitstream. A syntax element indicating the prediction mode
information for the current chroma block may be
intra_chroma_pred_mode. The image information may include the
prediction mode information.
[0376] The encoding apparatus derives a sample number for top
neighboring chroma samples and left neighboring chroma samples of
the current chroma block based on a width and a height of the
current chroma block and a specific value (step, S1610).
[0377] The encoding apparatus may derive the sample number of the
top neighboring chroma samples and the left neighboring chroma
samples by comparing the width and the height with the specific
value.
[0378] For example, in the case that the width and the height of
the current chroma block are greater than the specific value, the
sample number may be derived as the specific value.
[0379] Further, for example, in the case that the width and the
height of the current chroma block are less than or equal to the
specific value, the sample number may be derived as one value of
the width and the height. As an example, it may be derived as a
smaller value between the width and the height.
[0380] Meanwhile, the specific value may be derived to derive CCLM
parameters of the current chroma block. Here, the specific value
may also be expressed as neighboring sample number upper limit or a
maximum neighboring sample number. As an example, the specific
value may be derived as 2. Alternatively, the specific value may be
derived as 4, 8 or 16.
[0381] Further, for example, the specific value may be derived as a
preset value. That is, the specific value may be derived as a value
promised between the encoding apparatus and the decoding apparatus.
In other words, the specific value may be derived as a preset value
for the current chroma block to which the CCLM mode is applied.
[0382] Alternatively, for example, the encoding apparatus may
encode the information indicating the specific value, and may
signal the information indicating the specific value through a
bitstream. The image information may include information indicating
the specific value. The information indicating the specific value
may be signaled in units of a coding unit (CU). Alternatively, the
information indicating the specific value may be signaled in units
of a slice header, a picture parameter set (PPS), or a sequence
parameter set (SPS). That is, the information indicating the
specific value may be signaled in a slice header, a picture
parameter set (PPS), or a sequence parameter set (SPS).
[0383] Alternatively, for example, the encoding apparatus may
encode flag information indicating whether to derive the number of
neighboring reference samples based on the specific value, and may
signal the flag information through a bitstream. The image
information may include flag information indicating whether to
derive the number of neighboring reference samples based on the
specific value. In the case that the value of the flag information
is 1, the flag information may indicate that the number of
neighboring reference samples is derived based on the specific
value, while, in the case that the value of the flag information is
0, the flag information may indicate that the number of neighboring
reference samples is not derived based on the specific value. In
the case that the value of the flag information is 1, the
prediction related information may include information indicating
the specific value, and the specific value may be derived based on
the information indicating the specific value. The flag information
and/or the information indicating the specific value may be
signaled in units of a coding unit (CU). Alternatively, the flag
information and/or the information indicating the specific value
may be signaled in units of a slice header, a picture parameter set
(PPS), or a sequence parameter set (SPS). That is, the flag
information and/or the information indicating the specific value
may be signaled as a slice header, PPS, or SPS.
[0384] Alternatively, for example, the specific value may be
derived based on the size of the current chroma block.
[0385] For example, in the case that the smaller value between the
width and the height of the current chroma block is 2 or less, the
specific value may be derived as 1; in the case that the smaller
value between the width and the height of the current chroma block
is 4, the specific value may be derived as 2; and in the case that
the smaller value between the width and the height of the current
chroma block is greater than 4, the specific value may be derived
as 4.
[0386] In addition, for example, in the case that the smaller value
between the width and the height of the current chroma block is 2
or less, the specific value may be derived as 1; in the case that
the smaller value between the width and the height of the current
chroma block is 4, the specific value may be derived as 2; in the
case that the smaller value between the width and the height of the
current chroma block is 8, the specific value may be derived as 4;
and in the case that the smaller value between the width and the
height of the current chroma block is greater than 8, the specific
value may be derived as 8.
[0387] Additionally, for example, in the case that the smaller
value between the width and the height of the current chroma block
is 2 or less, the specific value may be derived as 1; and in the
case that the smaller value between the width and the height of the
current chroma block is greater than 2, the specific value may be
derived as 2.
[0388] Additionally, for example, in the case that the smaller
value between the width and the height of the current chroma block
is 2 or less, the specific value may be derived as 1; and in the
case that the smaller value between the width and the height of the
current chroma block is greater than 2, the specific value may be
derived as 4.
[0389] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; and in the case that the smaller value between
the width and the height of the current chroma block is greater
than 2, the specific value may be derived as 4.
[0390] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; in the case that the smaller value between the
width and the height of the current chroma block is 4, the specific
value may be derived as 2; and in the case that the smaller value
between the width and the height of the current chroma block is
greater than 4, the specific value may be derived as 4.
[0391] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; in the case that the smaller value between the
width and the height of the current chroma block is 4, the specific
value may be derived as 4; and in the case that the smaller value
between the width and the height of the current chroma block is
greater than 4, the specific value may be derived as 8.
[0392] Further, as an example, the specific value may be derived
based on whether a smaller value between the width and the height
of the current block is greater than a specific threshold value.
For example, in the case that a smaller value between the width and
the height of the current block is greater than a specific
threshold value, the specific value may be derived as 4, while, in
the case that a smaller value between the width and the height of
the current block is less than or equal to a specific threshold
value, the specific value may be derived as 2. The specific
threshold value may be derived as a preset value. That is, the
specific threshold value may be derived as a value promised between
the encoding apparatus and the decoding apparatus. Alternatively,
for example, the encoding apparatus may encode image information
including prediction related information, which may include
information indicating the specific threshold value. In this case,
the specific threshold value may be derived based on the
information indicating the specific threshold value. For example,
the derived specific threshold value may be 4 or 8.
[0393] The encoding apparatus derives the top neighboring chroma
samples of the sample number and the left neighboring chroma
samples of the sample number (step, S1620). The encoding apparatus
may derive the top neighboring chroma samples of the sample number
and the left neighboring chroma samples of the sample number.
[0394] The encoding apparatus derives down-sampled neighboring luma
samples and down-sampled luma samples of the current luma block
(step, S1630). Here, the neighboring luma samples may correspond to
the top neighboring chroma samples and the left neighboring chroma
samples. The down-sampled neighboring luma samples may include
down-sampled top neighboring luma samples of the current luma block
corresponding to the top neighboring chroma samples, and
down-sampled left neighboring luma samples of the current luma
block corresponding to the left neighboring chroma samples.
[0395] That is, for example, the neighboring luma samples may
include down-sampled top neighboring luma samples of the sample
number corresponding to the top neighboring chroma samples, and
down-sampled left neighboring luma samples of the sample number
corresponding to the left neighboring chroma samples.
[0396] The encoding apparatus derives CCLM parameters based on the
top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples (step,
S1640). The encoding apparatus may derive CCLM parameters based on
the top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples. For
example, the CCLM parameters may be derived based on Equation 3
described above.
[0397] The encoding apparatus derives prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples (step, S1650). The encoding apparatus may
derive prediction samples for the current chroma block based on the
CCLM parameters and the down-sampled luma samples. The encoding
apparatus may generate prediction samples for the current chroma
block by applying the CCLM derived with the CCLM parameters to the
down-sampled luma samples. That is, the encoding apparatus may
generate prediction samples for the current chroma block by
performing CCLM prediction based on the CCLM parameters. For
example, the prediction samples may be derived based on Equation 1
described above.
[0398] The encoding apparatus encodes image information including
prediction mode information on the current chroma block (step,
S1660). The encoding apparatus may encode image information
including prediction mode information on the current chroma block,
and signal the encoded image information through a bitstream.
[0399] In addition, for example, the image information may include
information indicating the specific value. Further, for example,
the image information may include information indicating the
specific threshold value. Additionally, for example, the image
information may include flag information indicating whether to
derive the number of neighboring reference samples based on the
specific value.
[0400] Meanwhile, although not shown, the encoding apparatus may
derive residual samples for the current chroma block based on
original samples and prediction samples for the current chroma
block, generate information on a residual for the current chroma
block based on the residual samples, and encode the information on
a residual. The image information may include the information on a
residual. Further, the encoding apparatus may generate
reconstructed samples for the current chroma block based on the
prediction samples and the residual samples for the current chroma
block.
[0401] Meanwhile, the bitstream may be transmitted to the decoding
apparatus through a network or a (digital) storage medium. Here,
the network may include a broadcast network, a communication
network and/or the like, and the digital storage medium may include
various storage media, such as USB, SD, CD, DVD, Blu-ray, HDD, SSD,
and the like.
[0402] FIG. 17 schematically represents an encoding apparatus
performing an image encoding method according to the present
disclosure. The method disclosed in FIG. 16 may be performed by the
encoding apparatus disclosed in FIG. 17. Specifically, for example,
the predictor of the encoding apparatus of FIG. 17 may perform
S1600 to S1650 of FIG. 16, and the entropy encoder of the encoding
apparatus of FIG. 17 may perform S1660 of FIG. 19. Further,
although not shown, the process of deriving residual samples for
the current chroma block based on the original samples and the
prediction samples for the current chroma block may be performed by
the subtractor of the encoding apparatus in FIG. 17; the process of
deriving reconstructed samples for the current chroma block based
on the residual samples and the prediction samples for the current
chroma block may be performed by the adder of the encoding
apparatus in FIG. 17; the process of generating information on a
residual for the current chroma block based on the residual samples
may be performed by the transformer of the encoding apparatus in
FIG. 17; and the process of encoding the information on a residual
may be performed by an entropy encoder of the encoding apparatus in
FIG. 17.
[0403] FIG. 18 schematically represents an image decoding method by
a decoding apparatus according to the present disclosure. The
method disclosed in FIG. 18 may be performed by the decoding
apparatus disclosed in FIG. 3. Specifically, for example, S1800 of
FIG. 18 may be performed by the entropy decoder of the decoding
apparatus; S1810 to S1850 may be performed by the predictor of the
decoding apparatus; and S1860 may be performed by the adder of the
decoding apparatus. Further, although not shown, the process of
obtaining information on a residual of the current block through a
bitstream may be performed by the entropy decoder of the decoding
apparatus, and the process of deriving the residual sample for the
current block based on the residual information may be performed by
the inverse transformer of the decoding apparatus.
[0404] The decoding apparatus obtains image information including
prediction mode information on the current chroma block (step,
S1800). The decoding apparatus may receive image information
including prediction mode information for the current chroma block
through a bitstream. The prediction mode information may indicate
an intra prediction mode of the current chroma block. Further, a
syntax element indicating the prediction mode information for the
current chroma block may be intra_chroma_pred_mode. The image
information may include the prediction mode information.
[0405] The decoding apparatus derives an intra prediction mode of
the current chroma block as a cross-component linear model (CCLM)
mode based on the prediction mode information (step, S1810). The
decoding apparatus may derive an intra prediction mode of the
current chroma intra prediction mode based on the prediction mode
information. For example, the prediction mode information may
indicate the CCLM mode.
[0406] The decoding apparatus derives a sample number for top
neighboring chroma samples and left neighboring chroma samples of
the current chroma block based on a width and a height of the
current chroma block and a specific value (step, S1820).
[0407] The decoding apparatus may derive the sample number of the
top neighboring chroma samples and the left neighboring chroma
samples by comparing the width and the height with the specific
value.
[0408] For example, in the case that the width and the height of
the current chroma block are greater than the specific value, the
sample number may be derived as the specific value.
[0409] Further, for example, in the case that the width and the
height of the current chroma block are less than or equal to the
specific value, the sample number may be derived as one value of
the width and the height. As an example, it may be derived as a
smaller value between the width and the height.
[0410] Meanwhile, the specific value may be derived to derive CCLM
parameters of the current chroma block. Here, the specific value
may also be expressed as neighboring sample number upper limit or a
maximum neighboring sample number. As an example, the specific
value may be derived as 2. Alternatively, the specific value may be
derived as 4, 8 or 16.
[0411] Further, for example, the specific value may be derived as a
preset value. That is, the specific value may be derived as a value
promised between the encoding apparatus and the decoding apparatus.
In other words, the specific value may be derived as a preset value
for the current chroma block to which the CCLM mode is applied.
[0412] Alternatively, for example, the decoding apparatus may
obtain prediction related information through a bitstream. In other
words, the image information may include information indicating the
specific value, and the specific value may be derived based on
information indicating the specific value. The information
indicating the specific value may be signaled in units of a coding
unit (CU). Alternatively, the information indicating the specific
value may be signaled in units of a slice header, a picture
parameter set (PPS), or a sequence parameter set (SPS). That is,
the information indicating the specific value may be signaled as a
slice header, PPS, or SPS.
[0413] Alternatively, for example, the decoding apparatus may
obtain flag information indicating whether to derive the number of
neighboring reference samples based on the specific value through
the bitstream. In other words, the image information may include
flag information indicating whether to derive the sample number
based on the specific value, and in the case that the value of the
flag information is 1, the image information may include
information indicating the specific value, and the specific value
may be derived based on the information indicating the specific
value. In the case that the value of the flag information is 0, the
flag information may indicate that the number of neighboring
reference samples is not derived based on the specific value. The
flag information and/or the information indicating the specific
value may be signaled in units of a coding unit (CU).
Alternatively, the flag information and/or the information
indicating the specific value may be signaled in units of a slice
header, a picture parameter set (PPS), or a sequence parameter set
(SPS). That is, the flag information and/or the information
indicating the specific value may be signaled as a slice header,
PPS, or SPS.
[0414] Alternatively, for example, the specific value may be
derived based on the size of the current chroma block.
[0415] For example, in the case that the smaller value between the
width and the height of the current chroma block is 2 or less, the
specific value may be derived as 1; in the case that the smaller
value between the width and the height of the current chroma block
is 4, the specific value may be derived as 2; and in the case that
the smaller value between the width and the height of the current
chroma block is greater than 4, the specific value may be derived
as 4.
[0416] In addition, for example, in the case that the smaller value
between the width and the height of the current chroma block is 2
or less, the specific value may be derived as 1; in the case that
the smaller value between the width and the height of the current
chroma block is 4, the specific value may be derived as 2; in the
case that the smaller value between the width and the height of the
current chroma block is 8, the specific value may be derived as 4;
and in the case that the smaller value between the width and the
height of the current chroma block is greater than 8, the specific
value may be derived as 8.
[0417] Additionally, for example, in the case that the smaller
value between the width and the height of the current chroma block
is 2 or less, the specific value may be derived as 1; and in the
case that the smaller value between the width and the height of the
current chroma block is greater than 2, the specific value may be
derived as 2.
[0418] Additionally, for example, in the case that the smaller
value between the width and the height of the current chroma block
is 2 or less, the specific value may be derived as 1; and in the
case that the smaller value between the width and the height of the
current chroma block is greater than 2, the specific value may be
derived as 4.
[0419] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; and in the case that the smaller value between
the width and the height of the current chroma block is greater
than 2, the specific value may be derived as 4.
[0420] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; in the case that the smaller value between the
width and the height of the current chroma block is 4, the specific
value may be derived as 2; and in the case that the smaller value
between the width and the height of the current chroma block is
greater than 4, the specific value may be derived as 4.
[0421] In addition, for example, in the case that the size of the
current chroma block is 2.times.2, the specific value may be
derived as 1; in the case that the smaller value between the width
and the height of the current chroma block is 2, the specific value
may be derived as 2; in the case that the smaller value between the
width and the height of the current chroma block is 4, the specific
value may be derived as 4; and in the case that the smaller value
between the width and the height of the current chroma block is
greater than 4, the specific value may be derived as 8.
[0422] Further, as an example, the specific value may be derived
based on whether a smaller value between the width and the height
of the current block is greater than a specific threshold value.
For example, in the case that a smaller value between the width and
the height of the current block is greater than a specific
threshold value, the specific value may be derived as 4, while, in
the case that a smaller value between the width and the height of
the current block is less than or equal to a specific threshold
value, the specific value may be derived as 2. The specific
threshold value may be derived as a preset value. That is, the
specific threshold value may be derived as a value promised between
the encoding apparatus and the decoding apparatus. Alternatively,
for example, the image information may include information
indicating the specific threshold value. In this case, the specific
threshold value may be derived based on the information indicating
the specific threshold value. For example, the derived specific
threshold value may be 4 or 8.
[0423] The decoding apparatus derives the top neighboring chroma
samples of the sample number and the left neighboring chroma
samples of the sample number (step, S1830). The decoding apparatus
may derive the top neighboring chroma samples of the sample number
and the left neighboring chroma samples of the sample number.
[0424] The decoding apparatus derives down-sampled neighboring luma
samples and down-sampled luma samples of the current luma block
(step, S1840). Here, the neighboring luma samples may correspond to
the top neighboring chroma samples and the left neighboring chroma
samples. The down-sampled neighboring luma samples may include
down-sampled top neighboring luma samples of the current luma block
corresponding to the top neighboring chroma samples, and
down-sampled left neighboring luma samples of the current luma
block corresponding to the left neighboring chroma samples.
[0425] That is, for example, the neighboring luma samples may
include down-sampled top neighboring luma samples of the sample
number corresponding to the top neighboring chroma samples, and
down-sampled left neighboring luma samples of the sample number
corresponding to the left neighboring chroma samples.
[0426] The decoding apparatus derives CCLM parameters based on the
top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples (step,
S1850). The decoding apparatus may derive CCLM parameters based on
the top neighboring chroma samples, the left neighboring chroma
samples, and the down-sampled neighboring luma samples. For
example, the CCLM parameters may be derived based on Equation 3
described above.
[0427] The decoding apparatus derives prediction samples for the
current chroma block based on the CCLM parameters and the
down-sampled luma samples (step, S1860). The decoding apparatus may
derive prediction samples for the current chroma block based on the
CCLM parameters and the down-sampled luma samples. The decoding
apparatus may generate prediction samples for the current chroma
block by applying the CCLM derived with the CCLM parameters to the
down-sampled luma samples. That is, the decoding apparatus may
generate prediction samples for the current chroma block by
performing CCLM prediction based on the CCLM parameters. For
example, the prediction samples may be derived based on Equation 1
described above.
[0428] The decoding apparatus generates reconstructed samples for
the current chroma block based on the prediction samples (step,
S1870). The decoding apparatus may generate reconstructed samples
based on the prediction samples. For example, the decoding
apparatus may receive information on the residual for the current
chroma block from the bitstream. The information on the residual
may include a transform coefficient relating to a (chroma) residual
sample. The decoding apparatus may derive the residual sample (or
residual sample array) for the current chroma block based on the
residual information. In this case, the decoding apparatus may
generate the reconstructed samples based on the prediction samples
and the residual samples. The decoding apparatus may derive a
reconstructed block or a reconstructed picture based on the
reconstructed sample. Thereafter, as described above, the decoding
apparatus may apply an in-loop filtering procedure such as
deblocking filtering and/or an SAO procedure to the reconstructed
picture in order to improve subjective/objective video quality, as
needed.
[0429] FIG. 19 schematically represents a decoding apparatus for
performing an image decoding method according to the document. The
method disclosed in FIG. 18 may be performed by the decoding
apparatus disclosed in FIG. 19. Specifically, for example, an
entropy decoder of the decoding apparatus of FIG. 19 may perform
S1800 in FIG. 18; a predictor of the decoding apparatus of FIG. 19
may perform S1810 to S1860 of FIG. 18; and an adder of the decoding
apparatus of FIG. 19 may perform S1870 of FIG. 18. Further,
although not shown, the process of obtaining image information
including information on the residual of the current block through
a bitstream may be performed by the entropy decoder of the decoding
apparatus of FIG. 19, and the process of deriving the residual
samples for the current block based on the information on the
residual may be performed by the inverse transformer of the
decoding apparatus of FIG. 19.
[0430] According to the above-described document, image coding
efficiency can be improved by performing the intra prediction based
on the CCLM.
[0431] In addition, according to this document, it is possible to
increase the efficiency of intra prediction based on the CCLM.
[0432] In addition, according to this document, the complexity of
intra prediction can be reduced by limiting the number of
neighboring samples selected to derive a linear model parameter for
the CCLM of a chroma block with big size to a specific number.
[0433] In the above-described embodiment, the methods are described
based on the flowchart having a series of steps or blocks. The
present disclosure is not limited to the order of the above steps
or blocks. Some steps or blocks may occur simultaneously or in a
different order from other steps or blocks as described above.
Further, those skilled in the art will understand that the steps
shown in the above flowchart are not exclusive, that further steps
may be included, or that one or more steps in the flowchart may be
deleted without affecting the scope of the present disclosure.
[0434] The embodiments described in this specification may be
performed by being implemented on a processor, a microprocessor, a
controller or a chip. For example, the functional units shown in
each drawing may be performed by being implemented on a computer, a
processor, a microprocessor, a controller or a chip. In this case,
information for implementation (e.g., information on instructions)
or algorithm may be stored in a digital storage medium.
[0435] In addition, the decoding device and the encoding device to
which the present disclosure is applied may be included in a
multimedia broadcasting transmission/reception apparatus, a mobile
communication terminal, a home cinema video apparatus, a digital
cinema video apparatus, a surveillance camera, a video chatting
apparatus, a real-time communication apparatus such as video
communication, a mobile streaming apparatus, a storage medium, a
camcorder, a VoD service providing apparatus, an Over the top (OTT)
video apparatus, an Internet streaming service providing apparatus,
a three-dimensional (3D) video apparatus, a teleconference video
apparatus, a transportation user equipment (e.g., vehicle user
equipment, an airplane user equipment, a ship user equipment, etc.)
and a medical video apparatus and may be used to process video
signals and data signals. For example, the Over the top (OTT) video
apparatus may include a game console, a blue-ray player, an
internet access TV, a home theater system, a smart phone, a tablet
PC, a Digital Video Recorder (DVR), and the like.
[0436] Furthermore, the processing method to which the present
disclosure is applied may be produced in the form of a program that
is to be executed by a computer and may be stored in a
computer-readable recording medium. Multimedia data having a data
structure according to the present disclosure may also be stored in
computer-readable recording media. The computer-readable recording
media include all types of storage devices in which data readable
by a computer system is stored. The computer-readable recording
media may include a BD, a Universal Serial Bus (USB), ROM, PROM,
EPROM, EEPROM, RAM, CD-ROM, a magnetic tape, a floppy disk, and an
optical data storage device, for example. Furthermore, the
computer-readable recording media includes media implemented in the
form of carrier waves (e.g., transmission through the Internet). In
addition, a bit stream generated by the encoding method may be
stored in a computer-readable recording medium or may be
transmitted over wired/wireless communication networks.
[0437] In addition, the embodiments of the present disclosure may
be implemented with a computer program product according to program
codes, and the program codes may be performed in a computer by the
embodiments of the present disclosure. The program codes may be
stored on a carrier which is readable by a computer.
[0438] FIG. 20 illustrates a structural diagram of a contents
streaming system to which the present disclosure is applied.
[0439] The content streaming system to which the embodiment(s) of
the present disclosure is applied may largely include an encoding
server, a streaming server, a web server, a media storage, a user
device, and a multimedia input device.
[0440] The encoding server compresses content input from multimedia
input devices such as a smartphone, a camera, a camcorder, etc.
into digital data to generate a bitstream and transmit the
bitstream to the streaming server. As another example, when the
multimedia input devices such as smartphones, cameras, camcorders,
etc. directly generate a bitstream, the encoding server may be
omitted.
[0441] The bitstream may be generated by an encoding method or a
bitstream generating method to which the embodiment(s) of the
present disclosure is applied, and the streaming server may
temporarily store the bitstream in the process of transmitting or
receiving the bitstream.
[0442] The streaming server transmits the multimedia data to the
user device based on a user's request through the web server, and
the web server serves as a medium for informing the user of a
service. When the user requests a desired service from the web
server, the web server delivers it to a streaming server, and the
streaming server transmits multimedia data to the user. In this
case, the content streaming system may include a separate control
server. In this case, the control server serves to control a
command/response between devices in the content streaming
system.
[0443] The streaming server may receive content from a media
storage and/or an encoding server. For example, when the content is
received from the encoding server, the content may be received in
real time. In this case, in order to provide a smooth streaming
service, the streaming server may store the bitstream for a
predetermined time.
[0444] Examples of the user device may include a mobile phone, a
smartphone, a laptop computer, a digital broadcasting terminal, a
personal digital assistant (PDA), a portable multimedia player
(PMP), navigation, a slate PC, tablet PCs, ultrabooks, wearable
devices (ex. smartwatches, smart glasses, head mounted displays),
digital TVs, desktops computer, digital signage, and the like. Each
server in the content streaming system may be operated as a
distributed server, in which case data received from each server
may be distributed.
* * * * *