This application claims the benefit, under 35 U.S.C. §365 of International Application PCT/EP2006/069852, filed Dec. 18, 2006, which was published in accordance with PCT Article 21(2) on Jul. 12, 2007 in English and which claims the benefit of European patent application No. 06290049.3, filed Jan. 5, 2006.
The invention relates to a method for generating for blocks of pixels of images of a high resolution sequence at least one motion predictor from motion data associated to blocks of pixels of images of a low resolution sequence.
State-of-art scalable hierarchical coding methods allow to encode the information hierarchically in order that it can be decoded at different resolution and/or quality levels. A data stream generated by a scalable coding device is thus divided into several layers, a base layer and one or more enhancement layers. These devices allow to adapt a unique data stream to variable transmission conditions (bandwidth, error rate . . . ) and also to the capacities of reception devices (CPU, characteristics of reproduction device . . . ). A spatially scalable hierarchical encoding (or decoding) method encodes (or decodes) a first part of data called base layer relating to low resolution images also called base layer images (BL images), and from this base layer encodes (or decodes) at least another data part called enhancement layer relating to high resolution images also called enhancement layer images (EL images). The coding information or coding data relating to enhancement layer is possibly inherited (i.e. derived) from coding information relating to the base layer by a method called inter-layer prediction method or inter-layer inheriting method. Each macroblock of a high resolution image is thus temporally predicted according to a classical prediction mode (e.g. bidirectional prediction mode, direct prediction mode, forward/backward prediction . . . ) or is predicted according to an inter-layer prediction mode. In this former case, motion information/data associated to a high resolution macroblock (e.g. partitioning pattern associated to macroblock/block of pixels of the high resolution image (for splitting said macroblock/block into several sub-blocks), coding modes associated to said blocks, possibly motion vectors and one or more image reference indices associated to some blocks allowing to reference the image used to predict said block) has to be derived or inherited from motion data associated to macroblocks of low resolution images whatever the format of the low or high resolution images is, i.e. progressive or interlaced.
The invention relates to a method, as part of a process of coding or decoding video signal, for generating for at least one macroblock of a high resolution image, called high resolution macroblock, at least one motion predictor from motion data associated to macroblock(s) of a low resolution image, called low resolution macroblock(s). The method comprises the following steps:
If the high resolution macroblock is in frame mode and if the corresponding low resolution macroblocks pair is in field mode, the deriving step comprises the steps of:
If the high resolution macroblock is in field mode and if the corresponding low resolution macroblocks pair is in frame mode, the deriving step comprises a step for downsampling vertically by a ratio of two motion data associated to the corresponding low resolution macroblocks pair.
The invention also relates to a device for coding a sequence of high resolution images made up of macroblocks, called high resolution macroblocks, and a sequence of low resolution images, called low resolution macroblocks. The device comprises:
The inheritance means comprise:
According to a specific embodiment, the first coding means are an MPEG-4 AVC video encoder.
The invention also relates to a device for decoding at least a coded sequence of high resolution images, the coded images arising in the form of a data stream, each image being divided in non overlapping macroblocks. The device comprising:
The inheritance means comprise:
According to a specific embodiment, the first decoding means are an MPEG-4 AVC video decoder.
Other features and advantages of the invention will appear with the following description of some of its embodiments, this description being made in connection with the drawings in which:
In the SVC standard currently defined by JVT (MPEG & ITU) in the document JVT-Q202 from ISO/IEC MPEG & ITU-T VCEG entitled <<Scalable Video Coding—Joint Draft 4>> and referenced as JSVM4 in the sequel, the spatial scalability is only considered for progressive material. Motion inter-layer prediction between two (or more) successive spatial layers (the base one and enhancement one(s)) are only addressed in case of progressive video sequences. The invention proposes to extend these inter-layer prediction processes in order to support any combinations of interlace/progressive scalability.
According to many video coding standards an interlaced image, which comprises a top field interlaced with a bottom field captured at different time instant, may be coded either as two field images (field image mode), i.e. the two fields of the image are coded separately, or as a frame image (frame image mode), i.e. the image is coded as a single frame. MPEG-4 AVC described in the document ISO/IEC JTC 1/SC 29/WG 11 N5546 entitled <<Text of 14496-2 Third Edition>> allows that decision to be made either independently for the entire image or independently for every two vertical macroblock-pair. When the decision is made at image level it is called PAFF coding (PAFF stands for Image Adaptative Frame/Field) and when the decision is made at macroblock-pair level it is called MBAFF (stands for Macroblock Adaptative Frame/Field). More precisely, according to MPEG-4 AVC, when an interlaced image is encoded as a frame image and if MBAFF is allowed, then each pair of vertical macroblocks (MBs) may be encoded as interlaced, i.e. field mode (right part of the
The method according to the invention allows to generate at least one inter-layer motion predictor for a macroblock of the high resolution image (also called Enhancement Layer MacroBlock and noted EL MB) from motion data associated to some macroblocks of the low resolution images (also called Base Layer MacroBlock and noted BL MB) whatever the format (interlace or progressive) of the high and low resolution sequences. An inter-layer motion predictor, more simply called motion predictor, associated to a macrocblock of a high resolution image is a macroblock to which is associated motion data (e.g. partition/sub-partition type, possibly reference indices allowing to identify reference images, motion vectors . . . ). According to MPEG-AVC, for each image of a sequence of images, the reference indices are selected among two reference lists (list0 et list1) defined as follows:
An invalid reference index corresponds to reference fields or frames not yet available (decoded) in the decoding process.
The motion predictor is generated using a motion downsampling method as the ESS (stands for Extended Spatial Scalability) method described in the JSVM4 document. If the high resolution image under consideration is interlaced, then two inter-layer prediction modes are potentially available to encode or decode each EL macroblock:
The invention proposes a method for generating these inter-layer macroblock predictors. To this aim the invention consists in defining at step 190 “Virtual Base Layer” (VBL) macroblocks from the BL MBs instead of modifying in depth the method described in JSVM4. A “Virtual Base Layer” (VBL) macroblock is a structure to which motion data is associated. The use of VBL structures avoids or at least significantly limits the JSVM4 upsampling process modifications, since most of the issues related to interlace are reported in the VBL data derivation. Indeed, “Virtual Base Layer” (VBL) macroblocks ensure the compatibility between BL and EL macroblocks and facilitates the direct re-use of inter-layer prediction defined in JSVM4 for progressive images. Instead of applying the resampling process directly to the BL macroblocks, BL macroblocks are first converted into VBL macroblocks that all have a field/frame mode compatible with the EL macroblock field/frame mode. Practically, this method requires the use of the following structures: a VBL Frame (with same dimension as BL Images), a VBL TOP field and a VBL BOTTOM field (with same width as BL Images and half height as BL Images) forming a VBL Field with same dimensions as BL image, as illustrated in
In reference to
The inter-layer mode IL_mode at the decoding side is derived from the bitstream. At the encoding side this mode is derived by a coding mode decision method. Such a method is for example based on a posteriori criteria, i.e. it selects the mode that minimizes a linear combination of the distortion and of the coding cost.
Frame-Field macroblocks conversion is required in the following cases.
Case 1: BL and EL frames are encoded with MBAFF mode, EL MB is field coded and corresponding BL MBs are frame coded. This requires frame-to-field conversion.
Case 2: The EL MB is frame coded, the BL is a frame image and corresponding BL MBs are field coded. In that case, field-to-frame conversion is required.
Case 3: BL image is progressive frame; EL MB is field coded in a frame image or belongs to a field image; and the EL field height He/2 is lower than the BL frame height Hb. In that case, frame-to-field conversion is required.
The step 200 consist in identifying the corresponding VBL macroblocks {c0,c1, . . . cN}. If EL MB mode is IL_P, i.e. VBL Frame MBs are used, then the corresponding VBL MBs will be determined using the following process:
xs=[x*wbase/wenh]/16
ys=[y*hbase/henh]/16
xe=[(x+15)*wbase/wenh]/16
ye=[(y+15)*hbase/henh]/16
where (x,y) are the top left sample position of the EL MB under consideration, (wbase, hbase) the base images dimensions and (wenh, henh) the enhancement images dimensions. The corresponding VBL macroblocks {c0,c1 . . . cN} are those located inside window delimited by top left position (xs,ys) and bottom right position (xe,ye).
If EL MB mode is IL_I, i.e. VBL TOP or BOTTOM Field MBs are used, then corresponding VBL MBs will be determined using the following process:
xs=[(x−x0)*wbase/wenh]/16
ys=[(y−y0)*(hbase/2)/henh]/16
xe=[(x+15−x0)*wbase/wenh]/16
ye=[(y+5−y0)*(hbase/2)/henh]/16
The corresponding VBL macroblocks {c0,c1, . . . cN} are those located inside window delimited by top left position (xs,ys) and bottom right position (xe,ye).
The step 210 consists in generating the VBL MBs and more particularly in deriving motion data associated to the VBL MBs. VBL TOP MB is generated as follows depending on BL image coding mode:
VBL BOTTOM MB is generated as follows depending on BL image coding mode:
VBL FRAME MB is generated as follows depending on BL image coding mode:
In this case, the VBL Frame MBs UP and DOWN of a MB pair are identical because they are generated from the same TOP and BOTTOM BL MBs.
VBL Frame MB ci is a merged version of BL TOP field MB at position (xi,yi/2) and BL BOTTOM field MB at position (xi,yi/2). This VBL Frame MB ci is generated using the new merging process.
The new downsampling process for deriving a vertically downsampled macroblock version of pairs of progressive macroblocks applies on a pair of BL macroblocks (UP and DOWN), at position (mbX, 2*mbY) and (mbX, 2*mbY+1), encoded in progressive format. It consists in a vertical downsampling by a ratio of 2 (one example is depicted on
As depicted in
Therefore a cleaning process is first applied on the BL UP and DOWN MBs to avoid these configurations. Each macroblock of the pair of progressive BL macroblocks is first cleaned-up for avoiding partitions with invalid motion vectors. The process, depicted in
The step 800 consists in removing invalid partitions, i.e. those using invalid reference index, corresponding to reference field or frame not yet available in the decoding process.
If MBBL mode is not INTRA, the following process is applied:
For each list (0 and 1), the following applies:
If for both lists, all partitions are INVALID, MBBL mode is set to INVALID.
If MBBL mode is INTRA, then nothing is done.
The step 810, consists in homogenizing reference indices within MBBL partition. It applies only if MBBL mode is not set to INVALID.
Possibly, at step 815, a partition merging process is applied. Partitions are merged into a single partition if they are not sub-partitioned and if for each list their reference index and motion vector are identical. Macroblock mode is modified as follows:
The step 815 is optional.
The step 820 consists in merging 4×4 and 8×4 sub-partitions. It applies only if MBBL mode is not set to INVALID. If MBBL mode is neither equal to INVALID nor to INTRA and macroblock partition is equal to 8×8, sub-partitions merging is applied to each 8×8 block of the macroblock with sub-partitioning equal to 8×4 or 4×4. 8×4 sub-partitions are merged into 8×8 sub-partitions, and 4×4 sub-partitions are merged into 4×8 sub-partitions as depicted on
After the cleaning process a downsampled macroblock named MBD is generated. It has two corresponding BL cleaned macroblocks, BMbUp and BMbDown. The
If BMbUp and BMbDown are INTRA, MBD mode is set to INTRA.
Otherwise if BMbUp and BMbDown are INTRA or INVALID (three cases are considered here, BMbUp is INTRA and BMbDown is INVALID or BMbUp is INVALID and BMbDown is INTRA or both macroblocks BMbUp and BMbDown are INVALID), MBD mode is set to INVALID.
Otherwise, the following process applies:
At step 1000, MBD is split in two 16×8 parts (noted 16×8 PartUp and 16×8 PartDown in the sequel). Each 16×8 part has one corresponding BL frame macroblock (16×8 PartUp corresponds to BMbUp, 16×8 PartDown corresponds to BMbDown).
At step 1200, each 16×8 part 16×8 PartZ (with Z being replaced by Up or Down) is built using the following process (illustrated in
The step 1200, consists in removing NEUTRAL partition if any. If one of the two 16×8 parts is classified as NEUTRAL, its content (partitioning/sub-partitioning, reference indices and motion vectors) is copied from the other 16×8 part content.
The step 1300, consists in deriving MBD partitioning as follows:
Possibly, at step 1400, the partition merging process of step 815 is applied. This step 1400 is optional.
The new merging process for merging a TOP macroblock (i.e. coming from BL TOP field) and a BOTTOM macroblock (i.e. coming from BL BOTTOM field) into a pair of progressive macroblocks (UP and DOWN) applies to two BL macroblocks encoded in interlaced format. The first considered macroblock is a TOP macroblock BMbTop. The second one is a BOTTOM macroblock BMbBot. The output of the process is a pair of progressive UP and DOWN macroblocks as depicted on
In reference to
The step 1500 consists in macroblock upsampling with a ratio 2 in the vertical direction. This step consists in applying directly the ESS upsampling process defined in JSVM4 (Joint Video Team (JVT) of ISO/IEC MPEG & ITU-T VCEG JVT-Q202, “Scalable Video Coding—Joint Draft 4”, J. Reichel, H. Schwarz, M. Wien) with a ratio of 1 in the horizontal direction and a ratio of two in the vertical direction.
The step 1510 applies on two macroblocks MbIn1 and MbIn2 and generates one merged macroblock MbOut. In reference to
According to a first embodiment, MbIn1 associated motion data is associated to MbOut.
According to a preferred embodiment, in reference to
At sub-step 1600, MbIn1 associated motion data is associated to MbOut. Then, If MbOut is not INTRA, the following process applies:
If for both lists, all partitions are INVALID, mode is set to INVALID.
At sub-step 1650, MbOut partitions may be merged by applying the partition merging process of step 815. This sub-step 1650 is optional.
In
The method for generating inter-layers motion predictors may be used of a process for coding video signals and of a process for coding video signals as the one described in JSVM4.
The invention also concerns a coding device 8 depicted on
The invention also concerns a decoding device 9 depicted on
According to another embodiment the decoding device receives two data streams: a base layer data stream and an enhancement layer data stream. In this case the device 9 does not comprise an extracting module 90.
Number | Date | Country | Kind |
---|---|---|---|
06290049 | Jan 2006 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2006/069852 | 12/18/2006 | WO | 00 | 4/3/2009 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2007/077116 | 7/12/2007 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5831678 | Proctor | Nov 1998 | A |
5978509 | Nachtergaele et al. | Nov 1999 | A |
6233283 | Chiu et al. | May 2001 | B1 |
6400768 | Nagumo et al. | Jun 2002 | B1 |
6510177 | De Bonet et al. | Jan 2003 | B1 |
6580832 | Kim et al. | Jun 2003 | B1 |
6639943 | Radha et al. | Oct 2003 | B1 |
6690724 | Kadono | Feb 2004 | B1 |
6728317 | Demos | Apr 2004 | B1 |
6741748 | Son et al. | May 2004 | B1 |
6957350 | Demos | Oct 2005 | B1 |
6980667 | Hamanaka | Dec 2005 | B2 |
7477690 | Wang et al. | Jan 2009 | B2 |
7777812 | Sun | Aug 2010 | B2 |
20010012322 | Nagaoka et al. | Aug 2001 | A1 |
20020001411 | Suzuki et al. | Jan 2002 | A1 |
20020009141 | Yamaguchi et al. | Jan 2002 | A1 |
20020051581 | Takeuchi et al. | May 2002 | A1 |
20020150158 | Wu et al. | Oct 2002 | A1 |
20030012279 | Chaddha | Jan 2003 | A1 |
20030169932 | Li et al. | Sep 2003 | A1 |
20040202250 | Kong et al. | Oct 2004 | A1 |
20040264791 | Jiang et al. | Dec 2004 | A1 |
20050008079 | Boon et al. | Jan 2005 | A1 |
20050030205 | Konoshima et al. | Feb 2005 | A1 |
20050129122 | Booth et al. | Jun 2005 | A1 |
20050175101 | Honda et al. | Aug 2005 | A1 |
20050207492 | Pao | Sep 2005 | A1 |
20060012719 | Karczewicz et al. | Jan 2006 | A1 |
20060083308 | Schwarz et al. | Apr 2006 | A1 |
20060126734 | Wiegand et al. | Jun 2006 | A1 |
20060133475 | Bruls et al. | Jun 2006 | A1 |
20060133510 | Saxena et al. | Jun 2006 | A1 |
20060140269 | Bruls | Jun 2006 | A1 |
20060176955 | Lu et al. | Aug 2006 | A1 |
20060221418 | Lee et al. | Oct 2006 | A1 |
20060222070 | Park et al. | Oct 2006 | A1 |
20070230914 | Garrido et al. | Oct 2007 | A1 |
Number | Date | Country |
---|---|---|
0577337 | Jan 1994 | EP |
0883300 | Dec 1998 | EP |
1811786 | Jul 2007 | EP |
06133290 | May 1994 | JP |
06209468 | Jul 1994 | JP |
11018085 | Jan 1999 | JP |
2000013790 | Jan 2000 | JP |
2001500674 | Jan 2001 | JP |
06209468 | Jul 2001 | JP |
2003531514 | Oct 2003 | JP |
2007081983 | Mar 2007 | JP |
2008536440 | Sep 2008 | JP |
WO9728507 | Aug 1997 | WO |
WO-0177871 | Oct 2001 | WO |
WO2004080079 | Sep 2004 | WO |
WO2006110013 | Oct 2006 | WO |
Entry |
---|
J. Reichel et al: “Joint Scalable Video Model JSVM-4” Joint Video Team (JVT) of ISO/IEC MPEG 8, ITU-T VCEG . . . ; Oct. 31, 2005, pp. 1-41 XP002372058. |
S.J. Wee Et All: “Field-to-Frame Transcoding With Spatial and Temporal Downsampling”, Image Processing, 1999, ICIP 99. Proceedings 1999, Int'l Conference on Kobe, Japan Oct. 24-28, 1999, vol. 4, pp. 271-275, XP010368707. |
Search Report Dated Mar. 8, 2007. |
J. Vieron et al. “CE4: Inter-layer prediction for interlace/progressive SVC” Joint Video Team (JVT) of ISO/IEC MPEG & ITU-T VCEG (ISO/IEC JTC1/SC29/WG11 and ITU-T SG16 Q6), 19th Meeting Geneva, Switzerland, Apr. 1-7, 2006, pp. 1-16, XP002410927. |
E. Francois et al. “Extended spatial scalability with a 3/2 size ratio” ISO/IEC JTC1/WG11 MPEG2005/M11958, Apr. 13, 2005, pp. 1-34, XP002383335, Busan. |
Reichel et al. “Joint Scalable Video Model JSVM-5” Joint Video Team of ISO/IEC MPEG & ITU MPEG & ITU-T VCEG (ISO/IEC JTC1/SC29/WG11 and ITU-T SG16 Q.6) Switzerland Apr. 7, 2006. |
“Description of core exeriments in SVC”, SO/IEC JTC1/SC29/WG11/N6898, XP002340411, Hong Kong (Jan. 2005). |
Reichel et al., “Joint Scalable Video Model JSVM-1.0 Reference Encoding Algorithm Description” JTC1/SC29/WG11 and ITU-T SG16 06, N6899 Jan. 2005 pp. 1-39. |
Reichel et al., “Joint Scalable Video Model JSVM-2”, Joint Video Team of ISO/IEC MPEG&ITU-T VCEG, Apr. 22, 2005, pp. 1-31. |
Reichel et al., “Joint Scalable Video Model JSVM-0”, Joint Video Team of ISO/IEC MPEG&ITU-T VCEG, Jan. 17, 2005, pp. 1-73. |
Francois, et al., “Generic Extended Spatial Scalability”, Joint Video Team (JVT) fo ISO/IEC MPEG 7 ITU-T VCEG (ISO/IEC JTC1/SC 29/WG 13th Meeting, Spain Oct. 22, 2004. |
Number | Date | Country | |
---|---|---|---|
20090225846 A1 | Sep 2009 | US |