<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE ep-patent-document PUBLIC "-//EPO//EP PATENT DOCUMENT 1.5//EN" "ep-patent-document-v1-5.dtd">
<!-- This XML data has been generated under the supervision of the European Patent Office -->
<ep-patent-document id="EP10843962B1" file="EP10843962NWB1.xml" lang="en" country="EP" doc-number="2528331" kind="B1" date-publ="20210505" status="n" dtd-version="ep-patent-document-v1-5">
<SDOBI lang="en"><B000><eptags><B001EP>ATBECHDEDKESFRGBGRITLILUNLSEMCPTIESILTLVFIROMKCYALTRBGCZEEHUPLSK..HRIS..MTNORS..SM..................</B001EP><B005EP>J</B005EP><B007EP>BDM Ver 1.7.2 (20 November 2019) -  2100000/0</B007EP></eptags></B000><B100><B110>2528331</B110><B120><B121>EUROPEAN PATENT SPECIFICATION</B121></B120><B130>B1</B130><B140><date>20210505</date></B140><B190>EP</B190></B100><B200><B210>10843962.1</B210><B220><date>20101214</date></B220><B240><B241><date>20120716</date></B241><B242><date>20190313</date></B242></B240><B250>ja</B250><B251EP>en</B251EP><B260>en</B260></B200><B300><B310>2010008864</B310><B320><date>20100119</date></B320><B330><ctry>JP</ctry></B330></B300><B400><B405><date>20210505</date><bnum>202118</bnum></B405><B430><date>20121128</date><bnum>201248</bnum></B430><B450><date>20210505</date><bnum>202118</bnum></B450><B452EP><date>20201208</date></B452EP></B400><B500><B510EP><classification-ipcr sequence="1"><text>H04N  19/176       20140101AFI20201123BHEP        </text></classification-ipcr><classification-ipcr sequence="2"><text>H04N  19/129       20140101ALI20201123BHEP        </text></classification-ipcr><classification-ipcr sequence="3"><text>H04N  19/423       20140101ALI20201123BHEP        </text></classification-ipcr><classification-ipcr sequence="4"><text>H04N  19/85        20140101ALI20201123BHEP        </text></classification-ipcr><classification-ipcr sequence="5"><text>H04N  19/436       20140101ALN20201123BHEP        </text></classification-ipcr></B510EP><B540><B541>de</B541><B542>VERFAHREN ZUR ENKODIERUNG BEWEGTER BILDER, VERFAHREN ZUR DEKODIERUNG BEWEGTER BILDER UND VORRICHTUNG ZUR DEKODIERUNG BEWEGTER BILDER</B542><B541>en</B541><B542>MOVING IMAGE ENCODING METHOD, MOVING IMAGE DECODING METHOD, AND MOVING IMAGE DECODING DEVICE</B542><B541>fr</B541><B542>PROCÉDÉ DE CODAGE D'IMAGES ANIMÉES, PROCÉDÉ DE DÉCODAGE D'IMAGES ANIMÉES, ET DISPOSITIF DE DÉCODAGE D'IMAGES ANIMÉES</B542></B540><B560><B561><text>EP-A2- 0 633 699</text></B561><B561><text>JP-A- 2007 510 320</text></B561><B562><text>D-K KWON ET AL: "Frame coding in vertical raster scan order", 94. MPEG MEETING; 11-10-2010 - 15-10-2010; GUANGZHOU; (MOTION PICTURE EXPERT GROUP OR ISO/IEC JTC1/SC29/WG11), no. M18264, 2 October 2010 (2010-10-02), XP030046854,</text></B562><B562><text>IWATA, K. ET AL.: 'A 342mW Mobile Application Processor with Full-HDMulti-Standard Video Codec' IEEE INT. SOLID-STATE CIRCUITS CONF. 2009 DIGEST OF TECHNICAL PAPERS 08 February 2009, pages 158 - 159, 159A, XP031742209</text></B562><B562><text>IWATA, K. ET AL.: 'A 256mW Full-HD H.264 High- Profile CODECFeaturing Dual Macroblock-Pipeline Architecture in 65nm CMOS' PROC. OF IEEE SYMP. ON VLSI CIRCUITS 18 June 2008, pages 102 - 103, XP 31295818</text></B562><B562><text>Xiaolei Chen ET AL: "New Hardware Architecture Design for Intra Prediction in H.264/AVC High Profile", Computer Science and Engineering, 2009. WCSE '09. Second International Workshop on, 1 January 2009 (2009-01-01), pages 362-366, XP055564775, Piscataway, NJ, USA DOI: 10.1109/WCSE.2009.831 ISBN: 978-0-7695-3881-5</text></B562><B565EP><date>20151222</date></B565EP></B560></B500><B700><B720><B721><snm>MOCHIZUKI, Seiji</snm><adr><str>c/o Renesas Electronics Corporation
1753 Shimonumabe
Nakahara-ku</str><city>Kawasaki-shi
Kanagawa 211-8668</city><ctry>JP</ctry></adr></B721><B721><snm>AKIE, Kazushi</snm><adr><str>c/o Renesas Electronics Corporation
1753 Shimonumabe
Nakahara-ku</str><city>Kawasaki-shi
Kanagawa 211-8668</city><ctry>JP</ctry></adr></B721><B721><snm>SHIBAYAMA, Tetsuya</snm><adr><str>c/o Renesas Electronics Corporation
1753 Shimonumabe
Nakahara-ku</str><city>Kawasaki-shi
Kanagawa 211-8668</city><ctry>JP</ctry></adr></B721><B721><snm>IWATA, Kenichi</snm><adr><str>c/o Renesas Electronics Corporation
1753 Shimonumabe
Nakahara-ku</str><city>Kawasaki-shi
Kanagawa 211-8668</city><ctry>JP</ctry></adr></B721></B720><B730><B731><snm>Renesas Electronics Corporation</snm><iid>101540728</iid><irf>TRC/FP6837348</irf><adr><str>2-24, Toyosu 3-chome 
Koutou-ku</str><city>Tokyo 135-0061</city><ctry>JP</ctry></adr></B731></B730><B740><B741><snm>Mewburn Ellis LLP</snm><iid>101783151</iid><adr><str>Aurora Building 
Counterslip</str><city>Bristol BS1 6BX</city><ctry>GB</ctry></adr></B741></B740></B700><B800><B840><ctry>AL</ctry><ctry>AT</ctry><ctry>BE</ctry><ctry>BG</ctry><ctry>CH</ctry><ctry>CY</ctry><ctry>CZ</ctry><ctry>DE</ctry><ctry>DK</ctry><ctry>EE</ctry><ctry>ES</ctry><ctry>FI</ctry><ctry>FR</ctry><ctry>GB</ctry><ctry>GR</ctry><ctry>HR</ctry><ctry>HU</ctry><ctry>IE</ctry><ctry>IS</ctry><ctry>IT</ctry><ctry>LI</ctry><ctry>LT</ctry><ctry>LU</ctry><ctry>LV</ctry><ctry>MC</ctry><ctry>MK</ctry><ctry>MT</ctry><ctry>NL</ctry><ctry>NO</ctry><ctry>PL</ctry><ctry>PT</ctry><ctry>RO</ctry><ctry>RS</ctry><ctry>SE</ctry><ctry>SI</ctry><ctry>SK</ctry><ctry>SM</ctry><ctry>TR</ctry></B840><B860><B861><dnum><anum>JP2010072472</anum></dnum><date>20101214</date></B861><B862>ja</B862></B860><B870><B871><dnum><pnum>WO2011089798</pnum></dnum><date>20110728</date><bnum>201130</bnum></B871></B870></B800></SDOBI>
<description id="desc" lang="en"><!-- EPO <DP n="1"> -->
<heading id="h0001">BACKGROUND</heading>
<p id="p0001" num="0001">The present invention relates to a moving image encoding method, a moving image decoding method, a moving image encoding device and a moving image decoding device, and particularly it relates to a technique useful for curbing the increase in the storage capacity of a memory for storing surrounding macro-block information.</p>
<p id="p0002" num="0002">The general compression system for moving images referred to as "MPEG-2" is a standard standardized by ISO/IEC 13818-2. The MPEG-2 is based on the principle that the video storage capacity and the required bandwidth are reduced by removing redundant information from video streams. Incidentally, MPEG is an abbreviation for "Moving Picture Experts Group".</p>
<p id="p0003" num="0003">The MPEG-2 standard only defines the bit stream syntax (the compressed and encoded data string's rule or the method for forming a bit stream of encoded data) and the decode process. Therefore, the MPEG-2 standard is flexible enough to use in various situations such as satellite broadcasts and services, cable televisions, interactive televisions and the Internet.</p>
<p id="p0004" num="0004">In an encoding process in conformity with the MPEG-2 standard, video signals are sampled and quantized in order to<!-- EPO <DP n="2"> --> initially define color and brightness components of each pixel of a digital video. The values specifying color and brightness components are converted to frequency values by DCT(Discrete Cosine Transform). The conversion coefficients of DCT have different frequencies according to the brightness and color of a picture. The quantized DCT conversion coefficients are encoded according to VLC(Variable Length Coding) used to further compress video streams.</p>
<p id="p0005" num="0005">In the international standard moving image encoding methods such as MPEG-2, MPEG-4 and MPEG-4 AVC(H.264), interframe prediction coding is used in order to realize a high encoding efficiency by use of correlation in the direction of time. Frame encoding modes include I FRAME where a frame is encoded without using correlation between frames, P FRAME where a frame can be predicted from one frame which was encoded in the past, and B FRAME where a frame can be predicted from two frames which were encoded in the past.</p>
<p id="p0006" num="0006">In the interframe prediction coding, a reference image (prediction image) subjected to motion compensation is subtracted from a moving image, and prediction residuals resulting from the subtraction are encoded. The process of encoding includes the steps of: orthogonal transform such as DCT(Discrete Cosine Transform); quantization; and variable length coding. The motion compensation (motion correction) includes the step of spatially moving a reference frame for<!-- EPO <DP n="3"> --> interframe prediction. The motion compensation is performed in units of blocks of a frame to be encoded. With no motion in an image, which means no move, a pixel in the same position as that of a pixel to be predicted is used. However, with any motion included, the most adequate block is searched for, and a move vector is made based on a quantity of the move. A block involved in motion compensation is a block of 16x16 or 16x8 pixels in the MPEG-2 encoding, a block of 16x16, 16x8 or 8x8 pixels in the MPEG-4 encoding, and a block of 16x16, 16×8, 8x16, 8x8, 8x4, 4x8 or 4x4 pixels in the MPEG-4 AVC(H.264) encoding.</p>
<p id="p0007" num="0007">The encoding process described above is performed for each video picture frame or field. A picture frame is subdivided into blocks, and each block (usually composed of 16x16 pixels and referred to as "macro-block" or "MB" for short in MPEG) makes a unit of processing of the encoding process. In other words, the most similar block (prediction image) is selected from an already encoded reference image for each block to be encoded, and difference signals of an encoded image (block) and a prediction image are encoded (by orthogonal transform, quantization or the like). The difference in relative position between a block to be encoded in a picture frame and a prediction signal is referred to as "motion vector" .</p>
<p id="p0008" num="0008">A video encode technique compliant with the recommended H.246/AVC is described in the non patent document presented by <nplcit id="ncit0001" npl-type="s"><text>Thomas Wiegand et al, "Overview of the H. 264/AVC Video Coding<!-- EPO <DP n="4"> --> Standard", IEEE TRANSACTIONS ON CIRCUITS AND SYSTEMS FOR VIDEO TECHNOLOGY, JULY 2003, PP.1-19</text></nplcit>. Video coding according to the recommended H.246/AVC involves: a video coding layer (VCL) designed to effectively represent a video context; and a network abstraction layer (NCL) which formats a video VCL representation and provides header information according to a method adequate for various transfers by a transfer layer and a storage medium.</p>
<p id="p0009" num="0009">Further, the following description is included in the non-patent document presented by <nplcit id="ncit0002" npl-type="s"><text>GARY J. SULLIVAN et al., "Video Compression-From Concept to the H.264/AVC Standard", PROCEEDING OF THE IEEE, VOL.93, No.1, JANUARY 2005, PP.18-31</text></nplcit>. That is, the video coding layer (VCL) in H.246/AVC follows an approach referred to as "block based hybrid video coding" . The VCL design involves a macro-block, a slice and a slice block. Each picture is split into macro-blocks fixed in size. Each macro-block includes quadrangular picture regions of 16x16 samples in terms of luminance components, and quadrangular sample regions as two chrominance components corresponding to the 16×16 sample regions in connection with luminance components. Each picture can include one or more slices, and each slice is self-inclusive in terms of offering an active sequence and a picture parameter set. Basically a slice representation can be decoded without using information from another slice, and therefore a syntax element can be analyzed<!-- EPO <DP n="5"> --> on a bit stream and a value of a sample of a picture region. However, to apply a deblocking filter to an entire boundary of a slice for more perfect decoding, some information from other slices is required. Also, it is described in the non-patent document presented by GARY J. SULLIVAN et al. that slices can be used in parallel processing because each slice is encoded and decoded independently of other slices of the picture.</p>
<p id="p0010" num="0010">Incidentally, MPEG-2 is standardized as H.262 by ITU (International Telecommunication Union), and authorized as International Standard ISO/IEC 13818-2 by ISO/IEC. Further, MPEG-4 is authorized as International Standard ISO/IEC 14496-2 by ISO/IEC. Still further, MPEG-4 AVC (Advanced Video Coding) is standardized as H.264 by ITU(International Telecommunication Union), and authorized as International Standard ISO/IEC 14496-10 by ISO/IEC.</p>
<p id="p0011" num="0011"><patcit id="pcit0001" dnum="EP0633699A2"><text>EP0633699A2</text></patcit> discloses a forced intra-frame coding method in which video data is coded in the vertical direction of a frame and the coding is performed for forcibly intra-frame coded macro block lines set to have a predetermined vertical interval. Whenever the coding for respective frames is finished, the macro block lines are shifted downward by one macro block.<!-- EPO <DP n="6"> --></p>
<p id="p0012" num="0012"><nplcit id="ncit0003" npl-type="s"><text>Xiaolei Chen ET AL: "New Hardware Architecture Design for Intra Prediction in H.264/AVC High Profile", Computer Science and Engineering, 2009. WCSE'09. Second International Workshop on, 1 January 2009 (2009-01-01), pages 362-366, XP055564775, Piscataway, NJ, USA DOI: 10.1109/ WCSE.2009.831 ISBN: 978-0-7695-3881-5</text></nplcit>, discloses a reconfigurable hardware decoding architecture for intra prediction for use in an intra prediction method in H.264/AVC high profile. In particular, it discloses a buffer design in prediction mode selection and reference pixel access.</p>
<heading id="h0002">SUMMARY</heading>
<p id="p0013" num="0013">The inventor and others have performed Research and Development on a next-generation international standard moving image encoding scheme prior to the present invention.</p>
<p id="p0014" num="0014">On the other hand, as described above, in an encoding process, a frame of video picture, which is I-frame, P-frame or B-frame, is divided into plural small regions referred to as "Macro Block (MB)", and the encoding process is executed on<!-- EPO <DP n="7"> --> the macro-blocks (MBs) following an order of raster scan for display starting with a macro-block (MB) located at an upper left corner portion of the video picture frame to the right and downward, in turn. In moving image encoding, moving image information is compressed taking advantage of the spatial correlation among macro-blocks (MBs) in a picture frame of a moving image. Specifically, in processing a macro-block (MB) , the information of the macro-block (MB) to be processed is predicted from information of its surrounding macro-blocks (i.e. macro-blocks located in the upward direction and in the left in the video picture frame) . In the moving image encoding process, only a difference with the predicted information is encoded.</p>
<p id="p0015" num="0015">For instance, in MPEG-4 intra encoding, interblock prediction is executed using DC and AC components of a DCT coefficient as pixel information of a block. Further, in interblock prediction according to MPEG-4 AVC(H.264/AVC), interblock prediction is conducted on DC and AC components of pixel values of a block after DCT conversion processing.</p>
<p id="p0016" num="0016">Further, in motion prediction for motion vector detection in an encoding process according to MPEG-4 and MPEG-4 AVC(H.264/AVC), a block matching between encoding-target blocks of a frame to be encoded and blocks of a reference frame is performed. In the block matching, a search with a 2-pixel-accuracy motion vector and a search with a<!-- EPO <DP n="8"> --> 1-pixel-accuracy motion vector are executed on macro-blocks (MBs) surrounding one macro-block of a 4-pixel-accuracy motion vector, which was searched for initially, and thus a final motion vector is detected.</p>
<p id="p0017" num="0017">Still further, a deblocking filtering process to reduce the distortion of a block caused during image decoding compliant with the MPEG-4 AVC(H.264/AVC) requires that a filtering process according to a given arithmetic expression be performed on a total of 8 pixels located on the left and right of and bordering a block, and a total of 8 pixels on the upper and lower sides of and bordering the block thereby to rewrite, in total, the 8 pixels on the left and right and the 8 pixels on the upper and lower sides.</p>
<p id="p0018" num="0018">On another note, the image sizes of moving images used in television broadcast, video recording and the like tend to keep rising, and an HD (High Definition) size of 1920x1080 pixels has been in the mainstream in recent years. Hence, with regard to future moving image sizes, it is expected that e.g. a 4Kx2K size of 4096x2048 pixels and a 8K×4K size of 8192x4096 pixels which can offer very high definition images will come into wide use progressively.</p>
<p id="p0019" num="0019">The next-generation moving image encoding scheme on a trend toward larger image sizes like this is required to support very high definition images as described above. On another note, a moving image encoding process and a moving image<!-- EPO <DP n="9"> --> decoding process both need information of macro-blocks (MBs) surrounding a macro-block (MB) to be processed as described above. Therefore, it is necessary to integrate a built-in memory (on-chip SRAM) for storing surrounding macro-block information into a semiconductor chip of moving image encoding/decoding device including a system large-scale semiconductor integrated circuit (system LSI). In general, a semiconductor chip of moving image encoding/decoding device including a system LSI is connected with an external memory composed of a synchronous dynamic random access memory (SDRAM) or the like. The external memory is arranged so that moving image data before the encoding or decoding process and moving image data after the encoding or decoding process can be stored therein. However, the external memory is too slow in access rate to store surrounding macro-block information. Hence, the surrounding macro-block information is stored in a built-in memory (on-chip SRAM). After the examination, the inventor and others revealed the problem that a built-in memory (on-chip SRAM) has bounds in storage capacity although the amount of information of surrounding macro-blocks which must be stored in a built-in memory (on-chip SRAM) rises with increasing image sizes.</p>
<p id="p0020" num="0020">The invention was made as a result of the examination performed by the inventor and others prior to the invention as described above.<!-- EPO <DP n="10"> --></p>
<p id="p0021" num="0021">Therefore, it is an object of the invention to suppress the increase of the storage capacity of a memory for storing surrounding macro-block information.</p>
<p id="p0022" num="0022">The above and other objects of the invention and novel features thereof will become apparent from the description hereof and the accompanying drawings.</p>
<p id="p0023" num="0023">According to a first aspect of the present invention there is provided a moving image encoding method as specified in claim 1.</p>
<p id="p0024" num="0024">The moving image encoding method according to the first aspect of the present invention may optionally be as specified in any one of claims 2 to 5.</p>
<p id="p0025" num="0025">According to a second aspect of the present invention there is provided a moving image decoding method as specified in claim 6.</p>
<p id="p0026" num="0026">The moving image decoding method according to the second aspect of the present invention may optionally be as specified in any one of claims 7 to 10.</p>
<p id="p0027" num="0027">According to a third aspect of the present invention there is provided a moving image decoding device as specified in claim 11.</p>
<p id="p0028" num="0028">The moving image decoding device according to the third aspect of the present invention may optionally be as specified in any claim 12 or claim 13.<!-- EPO <DP n="11"> --></p>
<p id="p0029" num="0029">According to the invention, the increase in the storage capacity of a memory for storing surrounding macro-blocks' information can be curbed.</p>
<heading id="h0003">BRIEF DESCRIPTION OF THE DRAWINGS</heading>
<p id="p0030" num="0030">
<ul id="ul0001" list-style="none" compact="compact">
<li><figref idref="f0001">FIG. 1</figref> is a view for explanation of a layered structure of a moving image encoding/decoding scheme according to the first embodiment of the invention;</li>
<li><figref idref="f0001">FIG. 2</figref> is a view showing a structure of an encode video stream already encoded by the moving image encoding scheme according to the first embodiment of the invention shown with reference to <figref idref="f0001">FIG. 1</figref>;</li>
<li><figref idref="f0002">FIG. 3</figref> is a flow chart showing a moving image encoding/decoding procedure according to the first embodiment of the invention;</li>
<li><figref idref="f0002">FIG. 4</figref> is a view showing how macro-blocks (MBs) located at a two-dimensional macro-block coordinate (x,y) in a frame of video picture are processed in turn following the moving<!-- EPO <DP n="12"> --> image encoding/decoding procedure according to the first embodiment of the invention, which was shown by the flow chart of <figref idref="f0002">FIG. 3</figref>;</li>
<li><figref idref="f0003">FIG. 5</figref> is a view showing a configuration of the moving image encoding/decoding device according to the first embodiment of the invention, which is operable to execute the moving image encoding/decoding procedure according to the first embodiment of the invention shown by the flow chart of <figref idref="f0002">FIG. 3</figref>;</li>
<li><figref idref="f0003">FIG. 6</figref> is a view showing a data array of moving image encoded bit stream which the moving image encoding/decoding device according to the first embodiment of the invention shown in <figref idref="f0003">FIG. 5</figref> is supplied with in case that working as a decoding device;</li>
<li><figref idref="f0004">FIG. 7</figref> is a view showing the relation between a macro-block (MB) 401 to be processed, and four surrounding macro-blocks (MBs) 402-405 used for prediction of the macro-block (MB) 401 in the case of executing a conventional encoding process which is different from the encoding process according to the invention;</li>
<li><figref idref="f0004">FIG. 8</figref> is a view showing the relation between the macro-block (MB) 401 to be processed, and four surrounding macro-blocks (MBs) 406-409 used for prediction of the macro-block (MB) 401 in the case of executing the procedure of the moving image encoding/decoding process according to the<!-- EPO <DP n="13"> --> first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>;</li>
<li><figref idref="f0005">FIG. 9</figref> is a view showing how macro-blocks (MBs) of a frame of video picture are encoded sequentially following a conventional encoding process, in which the object of the encoding process is first shifted from the macro-block (MB) at the upper left portion of the picture frame toward the right in turn until reaching the macro-block at the right end thereof, and then changed downward, following the order of raster-scan for display;</li>
<li><figref idref="f0005">FIG. 10</figref> is a view showing how macro-blocks (MBs) of a frame of video picture are encoded sequentially following the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>, in which the object of the encoding process is first shifted from the macro-block (MB) located at the upper left portion of the picture frame downward until reaching the macro-block at the lower end thereof, and then changed to the right;</li>
<li><figref idref="f0005">FIG. 11</figref> is a view showing how two rows of pairs of macro-blocks (MBs) are encoded following a conventional encoding process in a macro-block adaptive type frame-field prediction mode introduced into an MPEG-4 AVC(H.264)-compliant encoding scheme;</li>
<li><figref idref="f0005">FIG. 12</figref> is a view showing how pairs of macro-blocks (MBs) of the macro-block adaptive type frame-field prediction mode<!-- EPO <DP n="14"> --> introduced into the MPEG-4 AVC(H.264)-compliant encoding scheme are encoded following the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>;</li>
<li><figref idref="f0006">FIG. 13</figref> is a view showing a configuration of a moving image encoding/decoding device according to the second embodiment of the invention;</li>
<li><figref idref="f0007">FIG. 14</figref> is a view showing a configuration of a moving image encoding/decoding device according to the third embodiment of the invention;</li>
<li><figref idref="f0008">FIG. 15</figref> is a view showing a configuration of a moving image encoding/decoding device according to the fourth embodiment of the invention; and</li>
<li><figref idref="f0009">FIG. 16</figref> is a view showing a structure of a moving image processing device 1750 according to the fifth embodiment of the invention, which can be used as any device or module of (1) the macro-block encoding/decoding module 203 of the moving image encoding/decoding device 201 according to the first embodiment of the invention shown in <figref idref="f0003">FIG. 5</figref>, (2) the encoding module 704 of the encoding device 701 and (3) the decoding module 714 of the decoding device 711 according to the second embodiment of the invention shown in <figref idref="f0006">FIG. 13</figref>, (4) the encoding module 904 of the encoding device 901, and (5) the decoding module 1914 of the decoding device 1911 according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref>, and (<figref idref="f0003">6</figref>) the<!-- EPO <DP n="15"> --> encoding module 1304 of the encoding device 1301 and (7) the decoding module 1914 of the decoding device 1311 according to the fourth embodiment of the invention shown in <figref idref="f0008">FIG. 15</figref>.</li>
</ul></p>
<heading id="h0004">DETAILED DESCRIPTION</heading>
<heading id="h0005">1. Summary of the embodiments</heading>
<p id="p0031" num="0031">The representative embodiments of the invention herein disclosed will be outlined first. Here, the reference numerals and character strings for reference to the drawings, which are accompanied with paired round brackets, only exemplify what the concepts of members or components referred to by the numerals or character strings contain.
<ol id="ol0001" compact="compact" ol-style="">
<li>[1] An embodiment of the invention is a moving image encoding method for encoding the plural macro-blocks (MBs) included in a landscape picture frame of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction by use of an encoding device (201).
<br/>
In encoding the macro-blocks, information pieces of the plural encoded macro-blocks (MBs) surrounding a macro-block (MB) to be encoded are stored in an information storing memory (204) built in the encoding device.
<br/>
In the encode of the macro-blocks, first an array of the plural vertically aligned macro-blocks (MBs) at a left end of the horizontal width of the landscape picture frame are encoded<!-- EPO <DP n="16"> --> sequentially, and consequently encoded information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end are stored in the information storing memory (204) .
<br/>
After encode of the array of vertically aligned macro-blocks, an adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame are encoded sequentially (see <figref idref="f0002 f0003">FIGs 3-5</figref>).
<br/>
According to the embodiment, the increase in the storage capacity of a memory for storing surrounding macro-block information can be curbed.
<br/>
According to a preferred embodiment, the step of sequentially encoding the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end involves using the encode information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end, the encode information pieces stored in the information storing memory (204) (see <figref idref="f0002 f0003">FIGs 3-5</figref>) .
<br/>
According to another preferred embodiment, the encoding device (201) judges whether or not the encoded macro-block is one of last and first macro-blocks located at lower and upper ends of the vertical width after having encoded each macro-block (MB) in the array of vertically aligned<!-- EPO <DP n="17"> --> macro-blocks (see <figref idref="f0002">FIG. 3</figref>, esp. Step 104).
<br/>
According to a more preferred embodiment, the encoding device (201) judges whether or not the encoded array of plural macro-blocks (MBs) is the last array of macro-blocks located at the right end of the horizontal width after having encoded the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIG. 3</figref>, esp. Step 106).
<br/>
According to another more preferred embodiment, in case that the encoding device (201) judges the encoded macro-block not to be any of the last and first macro-blocks located at the lower and upper ends of the vertical width, a count value of a vertical direction counter (205) showing a position of a macro-block to be encoded next in the vertical direction of the left end is incremented by one (see <figref idref="f0002">FIG 3</figref>, esp. Step 105) .
<br/>
According to a concrete embodiment, in case that the encoding device (201) judges the encoded array of macro-blocks (MBs) not to be the last array of macro-blocks located at the right end of the horizontal width, a count value of a horizontal direction counter (207) showing a position of an array of macro-blocks to be encoded next in the horizontal direction of the horizontal width of the landscape picture frame is incremented by one (see <figref idref="f0002">FIG. 3</figref>, esp. Step 107).
</li>
<li>[2] In another aspect of the invention, one<!-- EPO <DP n="18"> --> representative embodiment of the invention is a moving image decoding method for decoding the plural macro-blocks (MBs) included in a landscape picture frame of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction by use of an decoding device (201).
<br/>
In decoding the macro-blocks, information pieces of the plural decoded macro-blocks (MBs) surrounding a macro-block (MB) to be decoded are stored in an information storing memory (204) built in the decoding device.
<br/>
In the decode of the macro-blocks, first an array of the plural vertically aligned macro-blocks (MBs) at the left end of the horizontal width of the landscape picture frame are decoded sequentially, and consequently decode information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end are stored in the information storing memory (204).
<br/>
After decode of the array of vertically aligned macro-blocks, an adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame are decoded sequentially (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).
<br/>
According to the above embodiment, the increase in the storage capacity of a memory for storing surrounding macro-block information can be curbed.<!-- EPO <DP n="19"> -->
<br/>
According to a preferred embodiment, the step of sequentially decoding the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end involves using the decode information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end, the decode information pieces stored in the information storing memory (204) (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).
<br/>
According to another preferred embodiment, the decoding device (201) judges whether or not the decoded macro-block is one of last and first macro-blocks located at lower and upper ends of the vertical width after having decoded each macro-block in the array of vertically aligned macro-blocks (see <figref idref="f0002">FIG. 3</figref>, esp. Step 104).
<br/>
According to a more preferred embodiment, the decoding device (201) judges whether or not the decoded array of macro-blocks (MBs) is the last array of macro-blocks located at the right end of the horizontal width after having decoded the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIG 3</figref>, esp. Step 106).
<br/>
According to another more preferred embodiment, in case that the decoding device (201) judges the decoded macro-block not to be any of the last and first macro-blocks located at<!-- EPO <DP n="20"> --> the lower and upper ends of the vertical width, a count value of a vertical direction counter (205) showing a position of a macro-block to be decoded next in the vertical direction of the left end is incremented by one (see <figref idref="f0002">FIG 3</figref>, esp. Step 105) .
<br/>
According to a concrete embodiment, in case that the decoding device (201) judges the decoded array of macro-blocks (MBs) not to be the last array of macro-blocks located at the right end of the horizontal width, a count value of a horizontal direction counter (207) showing a position of an array of macro-blocks to be decoded next in the horizontal direction of the horizontal width of the landscape picture frame is incremented by one (see <figref idref="f0002">FIG. 3</figref>, esp. Step 107).
</li>
<li>[3] One representative embodiment of the invention is a moving image encoding device (201) for encoding the plural macro-blocks (MBs) included in a landscape picture frame of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction, which includes an encoding module (203) and an information storing memory (204).</li>
</ol></p>
<p id="p0032" num="0032">In encoding the macro-blocks by the encoding module (203), information pieces of macro-blocks (MBs) already encoded and surrounding a macro-block (MB) to be encoded are stored in the information storing memory (204).</p>
<p id="p0033" num="0033">In the encode of macro-blocks, first the encoding module (203) sequentially encodes the array of vertically aligned<!-- EPO <DP n="21"> --> macro-blocks (MBs) at the left end of the horizontal width of the landscape picture frame and consequently, the encoding module (203) stores encode information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end in the information storing memory (204).</p>
<p id="p0034" num="0034">After having encoded the array of vertically aligned macro-blocks, subsequently the encoding module (203) sequentially encodes an adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).</p>
<p id="p0035" num="0035">According to the above embodiment, the increase of the storage capacity of a memory for storing surrounding macro-block information can be curbed.</p>
<p id="p0036" num="0036">According to a preferred embodiment, the step of sequentially encoding the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end by use of the encoding module (203) involves using the encode information pieces of the array of vertically aligned macro-blocks (MBs) at the left end, the encode information pieces stored in the information storing memory (204) (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).</p>
<p id="p0037" num="0037">According to another preferred embodiment, the moving image encoding device (201) judges whether or not the encoded macro-block is one of last and first macro-blocks located at<!-- EPO <DP n="22"> --> lower and upper ends of the vertical width after having encoded each macro-block (MB) in the array of vertically aligned macro-blocks (see <figref idref="f0002">FIG. 3</figref>, esp. Step 104).</p>
<p id="p0038" num="0038">According to still another preferred embodiment, the moving image encoding device (201) judges whether or not the encoded array of macro-blocks (MBs) is the last array of macro-blocks located at the right end of the horizontal width after having encoded the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIG. 3</figref>, esp. Step 106).</p>
<p id="p0039" num="0039">According to still another preferred embodiment, the moving image encoding device (201) further includes a vertical direction counter (205) showing a position of a macro-block to be encoded next in the vertical direction (see <figref idref="f0003">FIG. 5</figref>)</p>
<p id="p0040" num="0040">In case that the moving image encoding device (201) judges the encoded macro-block not to be any of the last and first macro-blocks located at the lower and upper ends of the vertical width, a count value of the vertical direction counter (205) is incremented by one (see <figref idref="f0002">FIG 3</figref>, esp. Step 105).</p>
<p id="p0041" num="0041">According to another preferred embodiment, the moving image encoding device (201) further includes a horizontal direction counter (207) showing a position of an array of macro-blocks to be encoded next in the horizontal direction (see <figref idref="f0003">FIG. 5</figref>).<!-- EPO <DP n="23"> --></p>
<p id="p0042" num="0042">However, in case that the moving image encoding device (201) judges the encoded array of macro-blocks (MBs) not to be the last array of macro-blocks located at the right end of the horizontal width, a count value of the horizontal direction counter (207) is incremented by one (see <figref idref="f0002">FIG. 3</figref>, esp. Step 107) .</p>
<p id="p0043" num="0043">According to a more preferred embodiment, the moving image encoding device (201) is arranged to be connectable with an image memory (702, 902 and 1302) in which the macro-blocks included in the landscape picture frame of the moving image can be stored.</p>
<p id="p0044" num="0044">In the moving image encoding device (201), after an array of horizontally aligned macro-blocks (1, 2, 3, 4) at the upper end of the vertical width of the landscape picture frame have been stored in the image memory, an adjacent array of horizontally aligned macro-blocks located vertically below the upper end of the vertical width of the landscape picture frame can be stored in the image memory (5, 6, 7, 8) (see <figref idref="f0006 f0007 f0008">FIGs. 13 to 15</figref>).</p>
<p id="p0045" num="0045">According to another more preferred embodiment, the moving image encoding device (701) further includes an image-rotation module (703) which reads out the landscape picture frame from the image memory, rotates the image of the picture frame by 90° to produce a rotation image, and writes the rotation image into the image memory. In the moving image encoding device, the rotation image stored in the image memory<!-- EPO <DP n="24"> --> can be read out and supplied to the encoding module (704) (see <figref idref="f0006">FIG 13</figref>) .</p>
<p id="p0046" num="0046">According to another more preferred embodiment, the moving image encoding device (201) further includes an image memory interface (903, 906, 1303, 1306 and 1309) which can be connected with the image memory.</p>
<p id="p0047" num="0047">The image memory interface serves to: read out, from the image memory, the array of macro-blocks (9, 5, 1) vertically aligned and located at the left end of the horizontal width of the landscape picture frame to supply the read array of macro-blocks to the encoding module (904, 1304); and subsequently read out an adjacent array of macro-blocks (10, 6, 2) vertically aligned horizontally on the right of the left end of the horizontal width of the landscape picture frame to supply the read array of macro-blocks to the encoding module (904, 1304) (see <figref idref="f0007">FIGs 14</figref> and <figref idref="f0008">15</figref>).</p>
<p id="p0048" num="0048">According to another more preferred embodiment, the moving image encoding device further includes an image read address generating module (906, 1306) which serves to: read out, from the image memory, the array of macro-blocks (9, 5, 1) vertically aligned at the left end of the horizontal width of the landscape picture frame to supply the read array of macro-blocks to the encoding module (904, 1304); and subsequently read out an adjacent array of macro-blocks (10, 6, 2) vertically aligned horizontally on the right of the left<!-- EPO <DP n="25"> --> end of the horizontal width of the landscape picture frame to supply the read array of macro-blocks to the encoding module (904, 1304) (see <figref idref="f0007">FIGs. 14</figref> and <figref idref="f0008">15</figref>).</p>
<p id="p0049" num="0049">According to a concrete embodiment, the moving image encoding device further includes an image-rotation module (903, 1303) which serves to produce a rotation image by rotating by about 90° each macro-block in the array of macro-blocks read out from the image memory according to an address generated by the image read address generating module and to supply the rotation image to the encoding module (see <figref idref="f0007">FIGs. 14</figref> and <figref idref="f0008">15</figref>) .</p>
<p id="p0050" num="0050">In the moving image encoding device according to the most concrete embodiment, the encoding module (704, 904, 1304) includes operation functions of a variable length encoding module, an orthogonal transforming device/quantizer, and a motion prediction module (see <figref idref="f0009">FIG. 16</figref>).</p>
<p id="p0051" num="0051">One representative embodiment of the invention is a moving image decoding device (201) for decoding macro-blocks (MBs) included in a landscape picture frame of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction, which includes a decoding module (203) and an information storing memory (204).</p>
<p id="p0052" num="0052">In decoding the macro-blocks by the decoding module (203), information pieces of plural macro-blocks (MBs) already decoded and surrounding a macro-block (MB) to be decoded are<!-- EPO <DP n="26"> --> stored in the information storing memory (204).</p>
<p id="p0053" num="0053">In the decode of the macro-blocks, first the decoding module (203) sequentially decodes an array of the plural vertically aligned macro-blocks (MBs) at a left end of the horizontal width of the landscape picture frame to store, in the information storing memory (204), decode information pieces of the array of the plural vertically aligned macro-blocks (MBs) at the left end.</p>
<p id="p0054" num="0054">Subsequently, after having decoded the array of vertically aligned macro-blocks, the decoding module (203) sequentially decodes an adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).</p>
<p id="p0055" num="0055">According to the above embodiment, the increase in the storage capacity of a memory for storing surrounding macro-block information can be curbed.</p>
<p id="p0056" num="0056">According to a preferred embodiment, the step of sequentially decoding the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end by use of the decoding module (203) involves using the decode information pieces of the array of vertically aligned macro-blocks at the left end, the decode information pieces stored in the information storing memory (204) (see <figref idref="f0002">FIGs. 3, 4</figref> and <figref idref="f0003">5</figref>).<!-- EPO <DP n="27"> --></p>
<p id="p0057" num="0057">According to another preferred embodiment, the moving image decoding device (201) judges whether or not the decoded macro-block is one of last and first macro-blocks located at lower and upper ends of the vertical width after having decoded each macro-block (MB) in the array of vertically aligned macro-blocks (see <figref idref="f0002">FIG 3</figref>, esp. Step 104).</p>
<p id="p0058" num="0058">According to still another preferred embodiment, the moving image decoding device (201) judges whether or not the decoded array of macro-blocks (MBs) is the last array of macro-blocks located at the right end of the horizontal width after having decoded the adjacent array of the plural vertically aligned macro-blocks (MBs) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (see <figref idref="f0002">FIG. 3</figref>, esp. Step 106).</p>
<p id="p0059" num="0059">According to still another preferred embodiment, the moving image decoding device (201) further includes a vertical direction counter (205) showing a position of a macro-block to be decoded next in the vertical direction (see <figref idref="f0003">FIG. 5</figref>).</p>
<p id="p0060" num="0060">In case that the moving image decoding device (201) judges the decoded macro-block not to be any of the last and first macro-blocks located at the lower and upper ends of the vertical width, a count value of the vertical direction counter (205) is incremented by one (see <figref idref="f0002">FIG 3</figref>, esp. Step 105).</p>
<p id="p0061" num="0061">According to another preferred embodiment, the moving image decoding device (201) further includes a horizontal<!-- EPO <DP n="28"> --> direction counter (207) showing a position of an array of macro-blocks to be decoded next in the horizontal direction (see <figref idref="f0003">FIG 5</figref>).</p>
<p id="p0062" num="0062">In case that the moving image decoding device (201) judges the decoded array of macro-blocks (MBs) not to be the last array of macro-blocks located at the right end of the horizontal width, a count value of the horizontal direction counter (207) is incremented by one (see <figref idref="f0002">FIG. 3</figref>, esp. Step 107).</p>
<p id="p0063" num="0063">According to another preferred embodiment, the moving image decoding device (711, 911, 1311) is connectable with an image memory (712, 912, 1312) in which the macro-blocks can be stored, and which can be connected to the moving image decoding device.</p>
<p id="p0064" num="0064">According to a preferred embodiment, the moving image encoding device (711) further includes an image-rotation module (713) which reads out the landscape picture frame from the image memory, rotates the image of the picture frame by 90° to produce a rotation image, and writes the rotation image into the image memory (see <figref idref="f0006">FIG 13</figref>).</p>
<p id="p0065" num="0065">According to a more preferred embodiment, the moving image encoding device (911, 1311) further includes an external interface (913, 916, 918, 1313, 1316, 1318) to which moving image encode signals can be supplied.</p>
<p id="p0066" num="0066">The external interface serves to supply the decoding module (914, 1314) with an array of macro-blocks (9, 5, 1)<!-- EPO <DP n="29"> --> vertically aligned at the left end of the horizontal width of the landscape picture frame included in the moving image encode signals, and to subsequently supply the decoding module with the array of macro-blocks (10, 6, 2) vertically aligned horizontally on the right of the left end of the horizontal width of the landscape picture frame included in the moving image encode signals.</p>
<p id="p0067" num="0067">The moving image decoding device decodes the array of vertically aligned macro-blocks at the left end of the horizontal width of the landscape picture frame included in the moving image encode signals supplied from the external interface, and subsequently decodes the adjacent array of vertically aligned macro-blocks located horizontally on the right of the left end of the horizontal width of the landscape picture frame included in the moving image encode signals supplied from the external interface.</p>
<p id="p0068" num="0068">The moving image decoding device is connectable with an image memory (912, 1312) in which information pieces of a decoded moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction can be stored, and which can be connected with the moving image decoding device.</p>
<p id="p0069" num="0069">The moving image decoding device stores, in a first memory region (9, 5, 1) of the image memory, decode processing information pieces of the array of vertically aligned<!-- EPO <DP n="30"> --> macro-blocks at the left end of the horizontal width of the landscape picture frame, and subsequently stores, in a second memory region (10, 6, 2) of the image memory, decode processing information pieces of the array of vertically aligned macro-blocks located horizontally on the right of the left end of the horizontal width of the landscape picture frame included in the moving image encode signals.</p>
<p id="p0070" num="0070">The first and second memory regions of the image memory correspond to information of an array of images vertically aligned at a left end of the display horizontal width of a landscape moving image display picture frame having a larger display horizontal width in the horizontal direction in comparison to a display vertical width in a vertical direction, and information of images vertically aligned on the horizontally immediate right of images at the left end of the display horizontal width, respectively (see <figref idref="f0007">FIGs. 14</figref> and <figref idref="f0008">15</figref>) .</p>
<p id="p0071" num="0071">According to another more preferred embodiment, the moving image decoding device further includes an image write address generating module (918, 1318) which serves: to store decode processing information pieces of the array of vertically aligned macro-blocks at the left end of the horizontal width of the landscape picture frame in the first memory region of the image memory; and subsequently, to store in the second memory region of the image memory, decode processing information pieces of the adjacent array of vertically aligned<!-- EPO <DP n="31"> --> macro-blocks located horizontally on the right of the left end of the horizontal width of the landscape picture frame, the decode processing information pieces included in the moving image encode signals (see <figref idref="f0007">FIGs 14</figref> and <figref idref="f0008">15</figref>).</p>
<p id="p0072" num="0072">According to a concrete embodiment, the external interface rotates an array of macro-blocks included in the moving image encode signals by about 90° thereby to produce a rotation image, and supplies the decoding module with the rotation image (see <figref idref="f0007">FIG. 14</figref> and <figref idref="f0008">15</figref>).</p>
<p id="p0073" num="0073">In the moving image decoding device according to the most concrete embodiment, the decoding module (714, 914, 1314) includes operation functions of a variable length decoding module, an inverse quantizer/inverse orthogonal transforming device, and a motion compensation module (see <figref idref="f0009">FIG. 16</figref>).</p>
<heading id="h0006">2. Further detailed description of the embodiments</heading>
<p id="p0074" num="0074">Next, the embodiments will be described further in detail. It is noted that as to all the drawings, to which reference is made for describing the best mode for carrying out the invention, parts or components having the same function are identified by the same reference numeral or character string, and the repetition of the description thereof is avoided.</p>
<heading id="h0007">[First Embodiment]</heading>
<heading id="h0008">«Layered structure in moving image encoding/decoding scheme»&gt;&gt;</heading><!-- EPO <DP n="32"> -->
<p id="p0075" num="0075"><figref idref="f0001">FIG. 1</figref> is a view for explanation of a layered structure in a moving image encoding/decoding scheme according to the first embodiment of the invention.</p>
<p id="p0076" num="0076">As shown in <figref idref="f0001">FIG. 1</figref>, a moving image encoding scheme according to the first embodiment of the invention has a six-level-layered structure which includes Sequence 10 corresponding to an entire moving image to Blocks 15, 16 and 17, each making a unit of processing of DCT(Discrete Cosine Transform). Specifically, the first level includes Sequence 10, the second level includes Group of Pictures (GOP) 11, the third level includes Pictures 12, the fourth level includes Slices 13, the fifth level includes Macro-blocks 14, and the sixth level includes Blocks 15, 16 and 17. The number of Pictures 12 included in Group of Pictures (GOP) 11, and the number of Macro-blocks 14 included in Slice 13 are both relatively flexible.</p>
<p id="p0077" num="0077">As shown in <figref idref="f0001">FIG. 1</figref>, the picture frame vertical width of a moving image of Pictures 12 of the third level is shorter than the horizontal width thereof, and the picture frames are elongated laterally. In the conventional MPEG-2 moving image encoding/decoding scheme, Slices 13 of the fourth level are disposed along a horizontal width direction of Picture 12 of the third level, and Macro-blocks (MBs) 14 of the fifth level are also disposed along the horizontal width direction, and the encoding or decoding process is performed in the horizontal<!-- EPO <DP n="33"> --> width direction inside Slice 13 of the fourth level in turn. In contrast, in the moving image encoding scheme according to the first embodiment of the invention, Slices 13 of the fourth level are disposed in a vertical width direction of Picture 12 of the third level, Macro-blocks (MBs) 14 of the fifth level are also disposed in the vertical width direction, and the encoding or decoding process is performed in turn in the vertical width direction inside Slice 13 of the fourth level as shown by a dotted arrow.</p>
<heading id="h0009">&lt;&lt;Structure of encode video stream»</heading>
<p id="p0078" num="0078"><figref idref="f0001">FIG. 2</figref> is a view showing a structure of an encode video stream already encoded by the moving image encoding scheme according to the first embodiment of the invention shown with reference to <figref idref="f0001">FIG. 1</figref>.</p>
<p id="p0079" num="0079">The video stream shown in <figref idref="f0001">FIG. 2</figref> is layered, and composed of a stack of layers of different levels, i.e. a sequence level 211, a Group-of-Pictures (GOP) level 221, a picture level 231, a slice level 241 and a macro-block (MB) level 251. Therefore, the levels below make parts of the preceding levels. The sequence level 211 includes successive Sequences, and each Sequence includes plural Group-of-Pictures (GOP) groups. The groups of Group-of-Pictures(GOP) level 221 are composed of successive groups of Pictures, and each GOP includes one or a number of Pictures. The picture level 231 includes successive Pictures (I, P and B frames), and each Picture 230<!-- EPO <DP n="34"> --> includes one or a number of Slices 240. The slice level 242 includes successive Slices 240, and each Slice 240 includes one or a number of Macro-blocks 250. The macro-block (MB) level 251 includes successive Macro-blocks.</p>
<p id="p0080" num="0080">To decode a video stream as shown in <figref idref="f0001">FIG. 2</figref>, reliable information concerning the video stream is needed. Such information is often put in a header which the video stream includes. Therefore, each Block of data of each level of a video stream generally has a header including relevant information involved in the encoding and decoding of a video stream. For instance, Sequence 210 has a sequence header 212 in the sequence level 211; GOP 220 has a GOP header 222 in the GOP level 221; Picture 230 has a picture header 232 in the picture level 231; Slice 240 has a slice header 242 in the slice level 241; and Macro-block (MB) 250 has a macro-block (MB) header 252 in the MB level 251.</p>
<p id="p0081" num="0081">The sequence header 212 includes information pieces of e.g. the width of Picture 12 referred to as "horizontal size (horizontal_size)", the height of Picture 12 referred to as "vertical size (vertical-size)", the aspect ratio of a pixel referred to as "aspect ratio information(aspect_ratio_information)".</p>
<p id="p0082" num="0082">The GOP header 222 includes information pieces of a parameter referred to as "time code (time_code)", and parameters for describing a GOP structure, which are referred<!-- EPO <DP n="35"> --> to as "closed GOP(closed_gop)" and "broken link(broken_link)".</p>
<p id="p0083" num="0083">The picture header 232 includes an information piece such as a parameter referred to as "picture coding type (picture_coding_type)" and showing what type of picture of I-picture, P-picture and B-picture the picture is. The picture header 232 further includes a parameter referred to as "f code (f_code)" and showing which type of picture the motion vector was encoded from.</p>
<p id="p0084" num="0084">The slice header 242 includes information pieces, such as a slice start code (slice_start_code) showing the start of the slice, and a set of parameters showing the vertical position and horizontal position of the first macro-block (MB) of the slice.</p>
<p id="p0085" num="0085">The macro-block (MB) header 252 includes information pieces such as the address and type of the macro-block, whether or not the macro-block 250 includes a motion vector and a type of motion vector (forward or backward), and a quantizer scale which is specified for each macro-block. Further, the macro-block (MB) header 252 decides a type of Discrete Cosine Transform (DCT), DCT coefficients, etc.</p>
<heading id="h0010">&lt;&lt; Procedure of moving image encoding/decoding process »</heading>
<p id="p0086" num="0086"><figref idref="f0002">FIG. 3</figref> is a flow chart showing a moving image encoding/decoding procedure according to the first embodiment of the invention.<!-- EPO <DP n="36"> --></p>
<p id="p0087" num="0087">The syntax of bit streams (the rule for compressed and encoded data strings, or the method for forming a bit stream of encoded data) according to the moving image encoding scheme involved with the first embodiment of the invention shown in <figref idref="f0002">FIG. 3</figref> is based on the rule described with reference to <figref idref="f0001">FIGs. 1 and 2</figref>.</p>
<p id="p0088" num="0088">Prior to Step 101 of <figref idref="f0002">FIG. 3</figref>, a moving image encoding/decoding device operable to execute a moving image encoding/decoding process according to the first embodiment of the invention analyzes the above-described syntax thereby to decide whether to execute the moving image encoding/decoding process obeying the syntax according to the first embodiment of the invention.</p>
<p id="p0089" num="0089">After the decision, as shown in <figref idref="f0002">FIG. 3</figref>, the moving image encoding or decoding process on a frame of video picture (Picture 12) is started in Step 101. In Step 102, the coordinate (x,y) of a macro-block (MB) is initialized and set to the origin point (0,0). In Step 103, a macro-block (MB) located at the coordinate (x,y) of the macro-block is encoded or decoded. In Step 104, it is judged whether or not the macro-block (MB) processed in Step 103 is located at a lower end of the picture frame. In case that the processed macro-block (MB) is judged not to be at the lower end of the picture frame in Step 104, the vertical direction's variable y of the coordinate (x,y) of the macro-block is incremented<!-- EPO <DP n="37"> --> by one in Step 105. After that, the encoding or decoding process on a macro-block (MB) of Step 103 is conducted again. However, in case that the processed macro-block (MB) is judged to be at the lower end of the picture frame in Step 104, it is judged in Step 106 whether or not the processed macro-block (MB) is located at a right end of the picture frame. In case that the processed macro-block (MB) is judged not to be at the right end of the picture frame in Step 106, the lateral direction's variable x of the coordinate (x,y) of the macro-block is incremented by one, and the variable y of the vertical direction is reset to an initial value of zero(0) in Step 107. After that, the encoding or decoding process on a macro-block (MB) of Step 103 is conducted again. In contrast, in case that the processed macro-block (MB) is judged to be at the right end of the picture frame in Step 106, the moving image encoding/decoding process on the video picture is terminated in Step 108.</p>
<p id="p0090" num="0090"><figref idref="f0002">FIG. 4</figref> is a view showing how macro-blocks (MBs) located at two-dimensional macro-block coordinates (x,y) in a frame of video picture are processed in turn following the moving image encoding/decoding procedure according to the first embodiment of the invention shown by the flow chart of <figref idref="f0002">FIG. 3</figref>.</p>
<p id="p0091" num="0091">As shown in <figref idref="f0002">FIG. 4</figref>, the execution of the process is started from a macro-block (MB) located at the upper left corner portion<!-- EPO <DP n="38"> --> of the video picture frame. The direction to first shift the execution of the process is not the right-hand direction of the picture frame following the order of raster scan for display, but the vertically downward direction of the picture frame. The moving image encoding/decoding device continues executing the processing on the macro-blocks while changing an object of the execution of the processing in the vertically downward direction of the picture frame. After having finished the processing on the macro-block (MB) located at the lower end of the video picture frame, the image encoding/decoding device changes an object of the execution of the processing to, of an adjacent row of macro-blocks (MBs) on the right side, the macro-block (MB) located at the upper end of the row (repeats the same processing). The direction of the execution of the processing on the macro-blocks of the adjacent row is also the vertically downward direction of the picture frame. «Structure of the moving image encoding/decoding device»</p>
<p id="p0092" num="0092"><figref idref="f0003">FIG. 5</figref> is a view showing a configuration of the moving image encoding/decoding device according to the first embodiment of the invention, which is operable to execute the moving image encoding/decoding procedure according to the first embodiment of the invention shown by the flow chart of <figref idref="f0002">FIG. 3</figref>.</p>
<p id="p0093" num="0093">As shown in <figref idref="f0003">FIG. 5</figref>, the moving image encoding/decoding device 201 including a system LSI is connected with an external<!-- EPO <DP n="39"> --> memory 202 composed of a synchronous dynamic random access memory. The semiconductor chip of the moving image encoding/decoding device 201 includes: a macro-block encoding/decoding module 203; a surrounding macro-block information storing memory 204; a vertical direction macro-block counter 205; a picture frame lower end judging module 206; a horizontal direction macro-block counter 207; a picture frame right end judging module 208; and an AND logical gate circuit 209.</p>
<p id="p0094" num="0094">In the moving image encoding process, the moving image encoding/decoding device 201 uses an original image and a reference image stored in the external memory 202 to execute the moving image encoding process, and then outputs a moving image encoded bit stream and a reference image to the external memory 202. In the moving image decoding process, the moving image encoding/decoding device 201 uses the moving image encoded bit stream and the reference image stored in the external memory 202 to execute the moving image decoding process, and then outputs the decoded moving image to the external memory 202.</p>
<p id="p0095" num="0095">The macro-block encoding/decoding module 203 executes an encoding process or a decoding process on a macro-block (MB) located at a set of macro-block coordinates indicated by the vertical direction macro-block counter 205 and the horizontal direction macro-block counter 207.<!-- EPO <DP n="40"> --></p>
<p id="p0096" num="0096">In the surrounding macro-block information storing memory 204, information pieces of macro-blocks (MBs) in the vertically downward direction (vertical direction) of a picture frame output by the macro-block encoding/decoding module 203 are stored. The macro-block encoding/decoding module 203 reads out the information of macro-blocks (MBs) of the left-side array from the surrounding macro-block information storing memory 204, and executes an encoding process or a decoding process. The count value of the vertical direction macro-block counter 205 is incremented by one by a macro-block-processing termination signal output by the macro-block encoding/decoding module 203. A vertical direction macro-block position signal which is an output signal of the vertical direction macro-block counter 205 is supplied to the picture frame lower end judging module 206. In the case of the macro-block position judged to be the picture frame lower end as a result of judgment on the macro-block position by the picture frame lower end judging module 206, the vertical direction macro-block counter 205 is cleared or reset to its initial value (0), and the count value of the horizontal direction macro-block counter 207 is incremented by one. A horizontal direction macro-block position signal which is an output signal of the horizontal direction macro-block counter 207 is supplied to the picture frame right end judging module 208. In the case of the macro-block position judged to be the<!-- EPO <DP n="41"> --> picture frame right end as a result of judgment on the macro-block position by the picture frame right end judging module 208, and concurrently judged to be the picture frame lower end as a result of judgment on the macro-block position by the picture frame lower end judging module 206, the AND logical gate circuit 209 is supplied with the result of judgment by the picture frame lower end judging module 206, and the result of judgment by the picture frame right end judging module 208. Accordingly, a picture-frame-processing termination signal of High ("1") level arising from an output of the AND logical gate circuit 209 is supplied to the macro-block encoding/decoding module 203.</p>
<heading id="h0011">&lt;&lt;Data array of moving image encoded bit stream&gt;&gt;</heading>
<p id="p0097" num="0097"><figref idref="f0003">FIG. 6</figref> is a view showing a data array of moving image encoded bit stream which the moving image encoding/decoding device according to the first embodiment of the invention shown in <figref idref="f0003">FIG. 5</figref> is supplied with in case that working as a decoding device.</p>
<p id="p0098" num="0098">As shown in <figref idref="f0003">FIG. 6</figref>, the data array of moving image encoded bit stream has a picture header 301, and an encoded information piece 302 of the macro-block (MB (0,0)) at the upper left corner portion of the picture frame of MB coordinates (0,0), which is placed just behind the picture header 301. Subsequent to the encoded MB (0, 0) information piece, an encoded information piece 303 of the macro-block (MB (0,1)) at the MB coordinates<!-- EPO <DP n="42"> --> (0,1) in the vertically downward direction follows, and thereafter encoded information pieces of macro-blocks (MB) located after the macro-block (MB(0,1)) in the vertically downward direction follow in turn. After an encoded information piece 304 of the macro-block (MB(0,h-1)) at MB coordinates (0,h-1) of the picture frame lower left end, an encoded information piece 305 of the macro-block (MB(1,0)) at the MB coordinates (1, 0) in the second row from the left of the picture frame follows. After that, encoded information pieces of subsequent macro-blocks are aligned likewise until reaching the macro-block (MB(w-1,h-1)) at the MB coordinates (w-1,h-1) of the picture frame lower right end. The picture header 301 shown in <figref idref="f0003">FIG. 6</figref> actually includes a sequence header 212, a GOP header 222, a picture header 232, a slice header 242 and a macro-block (MB) header 252 as shown in <figref idref="f0001">FIG 2</figref>. As a result, it becomes possible to decide whether to execute the moving image encoding/decoding process obeying the syntax according to the first embodiment of the invention by analyzing the picture header 301 shown in <figref idref="f0003">FIG. 6</figref>. In addition, by analyzing the width of Picture 12 included in the sequence header 212 shown in <figref idref="f0001">FIG. 2</figref> and referred to as "horizontal size", and the height of Picture 12 referred to as "vertical size", it becomes possible to recognize the picture frame lower end on which a judgment is made in Step 104 of the process procedure shown in <figref idref="f0002">FIG. 3</figref>, and the picture frame right end on which a judgment<!-- EPO <DP n="43"> --> is made in Step 106.</p>
<heading id="h0012">«Surrounding macro-block»</heading>
<p id="p0099" num="0099"><figref idref="f0004">FIG. 7</figref> is a view showing the relation between a macro-block (MB) 401 to be processed, and four surrounding macro-blocks (MBs) 402-405 used for prediction of the macro-block (MB) 401 in the case of executing a conventional encoding process which is different from the encoding process according to the invention.</p>
<p id="p0100" num="0100"><figref idref="f0004">FIG. 8</figref> is a view showing the relation between the macro-block (MB) 401 to be processed, and four surrounding macro-blocks (MBs) 406-409 used for prediction of the macro-block (MB) 401 in the case of executing the procedure of the moving image encoding/decoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>.</p>
<p id="p0101" num="0101">In the case shown by <figref idref="f0004">FIG. 7</figref>, the macro-block (MB) 401 to be processed must be processed with the macro-block (MB) 404 at the upper right of the macro-block (MB) 401 remaining unprocessed and therefore, the accuracy of prediction is deteriorated because of a reduced amount of reference information. In contrast, in the case shown by <figref idref="f0004">FIG. 8</figref> according to the first embodiment of the invention, all the four surrounding macro-blocks (MB) 406-409 have been processed at the time of processing the macro-block (MB) 401 to be processed, and therefore the deterioration of the prediction accuracy<!-- EPO <DP n="44"> --> owing to a reduced amount of reference information can be avoided.</p>
<heading id="h0013">&lt;&lt;Memory for storing surrounding macro-block information&gt;&gt;</heading>
<p id="p0102" num="0102"><figref idref="f0005">FIG. 9</figref> is a view showing how macro-blocks (MBs) of a frame of video picture are encoded sequentially following a conventional encoding process, in which the object of the encoding process is first shifted from the macro-block (MB) at the upper left portion of the picture frame toward the right in turn until reaching the macro-block at the right end thereof, and then changed downward, following the order of raster-scan for display.</p>
<p id="p0103" num="0103">The conventional encoding process described with reference to <figref idref="f0005">FIG. 9</figref> requires a memory for storing surrounding macro-block information to have a storage capacity large enough to store the information 520 of macro-blocks (MBs) containing the horizontal width of a picture frame.</p>
<p id="p0104" num="0104"><figref idref="f0005">FIG. 10</figref> is a view showing how macro-blocks (MBs) of a frame of video picture are encoded sequentially following the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>, in which the object of the encoding process is first shifted from the macro-block (MB) located at the upper left portion of the picture frame downward until reaching the macro-block at the lower end thereof, and then changed to the right.</p>
<p id="p0105" num="0105">With the encoding process according to the first<!-- EPO <DP n="45"> --> embodiment of the invention as described with reference to <figref idref="f0005">FIG. 10</figref>, even a small storage capacity which the memory for storing surrounding macro-block information has is sufficient as long as it can store the information 504 of macro-blocks (MBs) containing the vertical width of a frame of picture.</p>
<p id="p0106" num="0106">In general, a picture frame of a moving image is laterally elongated, and the vertical width of the picture frame is shorter than the horizontal width thereof. Examples of picture frame sizes include: 320x240 pixels as QVGA(Quarter Video Graphic Array) size; 720x480 pixels as a standard size; 1920x1080 pixels as HD (High Definition) size; 4096x2048 pixels of 4Kx2K size; and 8192×4096 pixels of 8Kx4K size. Therefore, in comparison to a large capacity enough to store the information of macro-blocks containing the horizontal width of a frame of picture, which is necessary for the conventional encoding process as described with reference to <figref idref="f0005">FIG. 9</figref>, the storage capacity of the surrounding macro-block information storing memory which is required for the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0005">FIG. 10</figref> is smaller, which is comparable to the amount of information of macro-blocks containing the vertical width of a frame of picture.</p>
<heading id="h0014">«Macro-block adaptive type frame-field prediction mode&gt;&gt;</heading>
<p id="p0107" num="0107"><figref idref="f0005">FIG. 11</figref> is a view showing how two rows of pairs of macro-blocks (MBs) are encoded following a conventional<!-- EPO <DP n="46"> --> encoding process in a macro-block adaptive type frame-field prediction mode introduced into an MPEG-4 AVC(H.264)-compliant encoding scheme.</p>
<p id="p0108" num="0108">The conventional encoding process as shown by <figref idref="f0005">FIG. 11</figref> requires the surrounding macro-block information storing memory to have a storage capacity large enough to store the information 602 of macro-blocks (MBs) containing double the horizontal width of the picture frame.</p>
<p id="p0109" num="0109"><figref idref="f0005">FIG. 12</figref> is a view showing how pairs of macro-blocks (MBs) of the macro-block adaptive type frame-field prediction mode introduced into the MPEG-4 AVC(H.264)-compliant encoding scheme are encoded following the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>.</p>
<p id="p0110" num="0110">With the encoding process according to the first embodiment of the invention as described with reference to <figref idref="f0001 f0002 f0003">FIGs. 1 to 6</figref>, which is shown in <figref idref="f0005">FIG. 12</figref>, the memory for storing surrounding macro-block information having a storage capacity as small as the amount of information 604 of macro-blocks (MBs) containing the vertical width of a frame of picture will do.</p>
<heading id="h0015">[Second Embodiment]</heading>
<heading id="h0016">«Moving image encoding/decoding device according to the second embodiment»</heading>
<p id="p0111" num="0111"><figref idref="f0006">FIG. 13</figref> is a view showing a configuration of a moving image encoding/decoding device according to the second<!-- EPO <DP n="47"> --> embodiment of the invention.</p>
<p id="p0112" num="0112">The upper half portion of <figref idref="f0006">FIG. 13</figref> shows an encoding device 701 operable to execute a moving image encoding process according to the second embodiment of the invention, and the lower half portion thereof shows a decoding device 711 operable to execute a moving image decoding process according to the second embodiment of the invention.</p>
<p id="p0113" num="0113">The encoding device 701 includes: an image-rotation module 703; an encoding module 704; and a surrounding macro-block information storing memory 705. The encoding device 701 executes a moving image encoding process on an original image stored in the external memory 702, and then outputs a moving image encoded bit stream and a reference image to the external memory 702.</p>
<p id="p0114" num="0114">The original image stored in the external memory 702 is supplied to the image-rotation module 703 of the encoding device 701. The image-rotation module 703 rotates the original image by +90° clockwise, and provides the resultant rotation image to the external memory 702. Therefore, the horizontal width of the original image stored in the external memory 702 is larger than the vertical width thereof. The original image is elongated laterally, in which according to the order of raster scan for picture frame display, the macro-blocks (MBs) 1, 2, 3 and 4 are aligned in the rightward horizontal direction, and the macro-blocks (MBs) 1, 5 and 9<!-- EPO <DP n="48"> --> are aligned in the downward vertical direction. Hence, the number of the macro-blocks (MBs) 1, 2, 3 and 4 aligned in the rightward horizontal direction of the horizontal width of the original image stored in the external memory 702 is larger than the number of the macro-blocks (MBs) 1, 5 and 9 aligned in the downward vertical direction of the vertical width of the original image.</p>
<p id="p0115" num="0115">On another note, the rotation image produced by clockwise rotating the original image by +90° in the image-rotation module 703 and then supplied to the external memory 702 has a smaller number of macro-blocks (MBs) 1, 5 and 9 in the horizontal direction of the horizontal width, and a larger number of macro-blocks (MBs) 1, 2, 3 and 4 in the vertical direction of the vertical width. Like the rotation image, the reference image stored in the external memory 702 has a smaller number of macro-blocks (MBs) 1, 5 and 9 in the horizontal direction of the horizontal width, and a larger number of macro-blocks (MBs) 1, 2, 3 and 4 in the vertical direction of the vertical width.</p>
<p id="p0116" num="0116">First, the encoding module 704 reads out the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a rotation image stored in the external memory 702, and the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction the horizontal width of a reference image stored in<!-- EPO <DP n="49"> --> the external memory 702 to execute the moving image encoding process in turn. Next, the encoding module 704 reads out the smaller number of macro-blocks (MBs) 10, 6 and 2 aligned in the horizontal direction of the horizontal width of each of the rotation image and the reference image stored in the external memory 702 to execute the moving image encoding process in turn. A moving image encoded bit stream produced by the moving image encoding process is stored in the external memory 702. A capacity depending on the number of the macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width of the original image stored in the external memory 702 is good enough as the storage capacity of the surrounding macro-block information storing memory 705 required for the moving image encoding process.</p>
<p id="p0117" num="0117">Therefore, in the case of forming the encoding device 701 with a system LSI, the surrounding macro-block information storing memory 705 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 702 used to store an original image, a rotation image and a moving image encoded bit stream is composed of a synchronous dynamic random access memory (SDRAM).</p>
<p id="p0118" num="0118">The decoding device 711 includes: a decoding module 714; a surrounding macro-block information storing memory 715; and an image-rotation module 713.<!-- EPO <DP n="50"> --></p>
<p id="p0119" num="0119">First, the decoding module 714 reads out the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a moving image encoded bit stream stored in the external memory 712, and the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a reference image stored in the external memory 712 to execute the moving image decoding process in turn. Next, the decoding module 714 reads out the smaller number of macro-blocks (MBs) 10, 6 and 2 aligned in the horizontal direction of the horizontal width of the moving image encoded bit stream stored in the external memory 712, and the smaller number of macro-blocks (MBs) 10, 6 and 2 aligned in the horizontal direction of the horizontal width of the reference image stored in the external memory 712 to execute the moving image decoding process in turn. In addition, the moving image decoded bit stream produced by the moving image decoding process is stored in the external memory 712. Further, the image-rotation module 713 rotates, by 90°, a moving image decoded bit stream stored in the external memory 712 counterclockwise, and supplies the resultant streams, as a final moving image decoded bit stream, to the external memory 712 again. A capacity depending on the number of the macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of the moving image encoded bit stream stored in the external memory 712 is good enough<!-- EPO <DP n="51"> --> as the storage capacity of the surrounding macro-block information storing memory 715 which is necessary for the moving image decoding process.</p>
<p id="p0120" num="0120">Therefore, in the case of forming the decoding device 711 with a system LSI, the surrounding macro-block information storing memory 715 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 712 used to store a moving image encoded bit stream, a rotation image and a moving image decoded bit stream is composed of a synchronous dynamic random access memory (SDRAM).</p>
<p id="p0121" num="0121">The moving image encoding device 701 and the moving image decoding device 711 according to the second embodiment of the invention shown in <figref idref="f0006">FIG. 13</figref> can be integrated into a semiconductor chip of a moving image encoding/decoding device formed by a system LSI. In this case, the encoding module 704 and the decoding module 714 can be constituted by hardware resources common to them; the surrounding macro-block information storing memory 705 and the surrounding macro-block information storing memory 715 can be constituted by hardware resources common to them; and the image-rotation module 703 and the image-rotation module 713 can be constituted by hardware resources common to them. The moving image encoding/decoding device formed by a system LSI can be arranged to appropriately work as the encoding device 701 or the decoding<!-- EPO <DP n="52"> --> device 711 following operation mode setting information supplied during initialization sequence at power-on for example.</p>
<heading id="h0017">[Third Embodiment]</heading>
<heading id="h0018">«Moving image encoding/decoding device according to the third embodiment»</heading>
<p id="p0122" num="0122"><figref idref="f0007">FIG. 14</figref> is a view showing a configuration of a moving image encoding/decoding device according to the third embodiment of the invention.</p>
<p id="p0123" num="0123">Unlike the moving image encoding/decoding device according to the second embodiment of the invention shown in <figref idref="f0006">FIG. 13</figref>, the frequency of access to the external memory 902 can be reduced in the moving image encoding/decoding device according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref>.</p>
<p id="p0124" num="0124">The upper half portion of <figref idref="f0007">FIG. 14</figref> shows the encoding device 901 operable to execute a moving image encoding process according to the third embodiment of the invention, and the lower half portion thereof shows a decoding device 911 operable to execute a moving image decoding process according to the third embodiment of the invention.</p>
<p id="p0125" num="0125">The encoding device 901 includes: a 90°-clockwise rotation module 903; an encoding module 904; a surrounding macro-block information storing memory 905; and an image read address generating module 906. The encoding device 901<!-- EPO <DP n="53"> --> executes a moving image encoding process on an original image stored in the external memory 902, and then outputs a moving image encoded bit stream and a reference image to the external memory 902.</p>
<p id="p0126" num="0126">Macro-blocks (MBs) of the original image stored in the external memory 902 are supplied to the 90°-clockwise rotation module 903 of the encoding device 901 according to addresses generated by the image read address generating module 906. The 90°-clockwise rotation module 903 rotates the supplied macro-blocks (MBs) by +90° clockwise, and provides the resultant images to the encoding module 904. Specifically, an original image stored in the external memory 902 is laterally elongated with its horizontal width larger than the vertical width, in which according to the order of raster scan for picture frame display, the macro-blocks (MBs) 1, 2, 3 and 4 are aligned in the rightward horizontal direction, and the macro-blocks (MBs) 1, 5 and 9 are aligned in the downward vertical direction. Therefore, the number of the macro-blocks (MBs) 1, 2, 3 and 4 aligned in the rightward horizontal direction of the horizontal width of the original image stored in the external memory 902 is larger than the number of the macro-blocks (MBs) 1, 5 and 9 aligned in the downward vertical direction of the vertical width of the original image.</p>
<p id="p0127" num="0127">On another note, the rotation image supplied to the encoding module 904 after the +90° clockwise rotation by the<!-- EPO <DP n="54"> --> image-rotation module 703 includes a smaller number of macro-blocks (MBs) 9, 5 and 1 in the horizontal direction of the horizontal width, and a larger number of macro-blocks (MBs) 1, 2, 3 and 4 in the vertical direction of the vertical width. Also, a reference image stored in the external memory 902 includes a smaller number of macro-blocks (MBs) 9, 5 and 1 in the horizontal direction of the horizontal width, and a larger number of macro-blocks (MBs) 1, 2, 3 and 4 in the vertical direction of the vertical width as in the case of the rotation image.</p>
<p id="p0128" num="0128">The encoding module 904 first reads out the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a rotation image supplied from the 90°-clockwise rotation module 903, and the smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of the reference image stored in the external memory 902 to execute the moving image encoding process in turn. Next, the encoding module 904 reads out the smaller number of macro-blocks (MBs) 10, 6 and 2 aligned in the horizontal direction of the horizontal width of each of the rotation image supplied by the 90°-clockwise rotation module 903 and the reference image stored in the external memory 902 to execute the moving image encoding process in turn. Further, the moving image encoded bit stream produced by the moving image encoding process is<!-- EPO <DP n="55"> --> stored in the external memory 902. A capacity depending on the number of the macro-blocks (MBs) 1, 5 and 9 aligned in the vertical direction of the vertical width of the original image stored in the external memory 902 is good enough as the storage capacity of the surrounding macro-block information storing memory 905 which is necessary for the moving image encoding process.</p>
<p id="p0129" num="0129">Therefore, in the case of forming the encoding device 901 with a system LSI, the surrounding macro-block information storing memory 905 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 902 used to store the original image and the moving image encoded bit stream is composed of a synchronous dynamic random access memory (SDRAM). Further, a motion vector MV1 encoded by the moving image encoding process in the encoding device 901 is also rotated by +90° clockwise by the 90°-clockwise rotation module 903 with respect to the motion vector in the original image stored in the external memory 902.</p>
<p id="p0130" num="0130">The decoding device 911 includes: a decoding module 914; a surrounding macro-block information storing memory 915; a 90°-counterclockwise rotation module 913; an image read address generating module 916; a difference image generating module 917; and an image write address generating module 918.</p>
<p id="p0131" num="0131">The decoding module 914 first reads out, in turn, a<!-- EPO <DP n="56"> --> smaller number of macro-blocks (MBs) 9, 5 and 1 of a moving image encoded bit stream stored in the external memory 912, provided that the macro-blocks (MBs) 9, 5 and 1 are aligned in the horizontal direction of the horizontal width. The smaller number of macro-blocks (MBs) 9, 5 and 1 of moving image encoded bit stream so read out from the external memory 912 are supplied to the 90°-counterclockwise rotation module 913 through the difference image generating module 917. The 90°-counterclockwise rotation module 913 creates macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width and supplies them to the decoding module 914.</p>
<p id="p0132" num="0132">The image read address generating module 916 reads out macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width of a reference image stored in the external memory 712 in turn. Therefore, the decoding module 914 uses the macro-blocks (MBs) 9, 5 and 1 of moving image encoded bit stream, and the macro-blocks (MBs) 9, 5 and 1 of the reference image to execute the moving image decoding process. A moving image decode bit stream resulting from the moving image decoding process by the decoding module 914 is stored in the external memory 712 according to an address generated by the image write address generating module 918. A capacity depending on the number of the macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a moving image encoded bit stream stored in the<!-- EPO <DP n="57"> --> external memory 912 is good enough as the storage capacity of the surrounding macro-block information storing memory 915 which is necessary for the moving image decoding process.</p>
<p id="p0133" num="0133">Therefore, in the case of forming the decoding device 911 with a system LSI, the surrounding macro-block information storing memory 915 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 912 used to store a moving image encoded bit stream, a reference image and a moving image decode bit stream is composed of a synchronous dynamic random access memory (SDRAM). Further, a motion vector MV2 decoded by the moving image decoding process in the decoding device 911 is made by a coordinate transform of a motion vector MV1, by which the x-coordinate of the motion vector MV1 encoded by the moving image encoding process in the encoding device 901 is made a γ-coordinate of the motion vector MV2, and the γ-coordinate of the motion vector MV1 is made an x-coordinate of the motion vector MV2, provided that the sign of the x-coordinate of the motion vector MV2 is minus.</p>
<p id="p0134" num="0134">The moving image encoding device 901 and the moving image decoding device 911 according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref> can be integrated into a semiconductor chip of a moving image encoding/decoding device formed by a system LSI. In this case, the encoding module 904 and the decoding module 914 can be constituted by hardware<!-- EPO <DP n="58"> --> resources common to them; the surrounding macro-block information storing memory 905 and the surrounding macro-block information storing memory 915 can be constituted by hardware resources common to them; and the 90°-clockwise rotation module 903 and the 90°-counterclockwise rotation module 913 can be constituted by hardware resources common to them. The moving image encoding/decoding device formed by a system LSI can be arranged to appropriately work as the encoding device 901 or the decoding device 911 following operation mode setting information supplied during initialization sequence at power-on for example.</p>
<heading id="h0019">[Fourth Embodiment]</heading>
<heading id="h0020">&lt;&lt; Moving image encoding/decoding device according to the fourth embodiment&gt;&gt;</heading>
<p id="p0135" num="0135"><figref idref="f0008">FIG. 15</figref> is a view showing a configuration of a moving image encoding/decoding device according to the fourth embodiment of the invention.</p>
<p id="p0136" num="0136">Unlike the moving image encoding/decoding device according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref>, the arrangement of macro-blocks (MBs) of a reference image stored in the external memory 1302 can be made identical with the arrangement of macro-blocks (MBs) of an original image in the moving image encoding/decoding device according to the fourth embodiment of the invention shown in <figref idref="f0008">FIG. 15</figref>.</p>
<p id="p0137" num="0137">The upper half portion of <figref idref="f0008">FIG. 15</figref> shows the encoding<!-- EPO <DP n="59"> --> device 1301 operable to execute a moving image encoding process according to the fourth embodiment of the invention, and the lower half portion of <figref idref="f0008">FIG. 15</figref> shows the decoding device 1311 operable to execute a moving image decoding process according to the fourth embodiment of the invention.</p>
<p id="p0138" num="0138">The encoding device 1301 includes: a 90°-clockwise rotation module 1303; an encoding module 1304; a surrounding macro-block information storing memory 1305; an image read address generating module 1306; a difference image generating module 1307; a reference image address generating module 1308; and a 90°-counterclockwise rotation module 1309. The encoding device 1301 executes the moving image encoding process on an original image stored in the external memory 1302, and then outputs a moving image encoded bit stream and a reference image to the external memory 1302.</p>
<p id="p0139" num="0139">The smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width of each of an original image and a reference picture frame are read out from the external memory 1302 according to addresses generated by the image read address generating module 1306, and supplied to the difference image generating module 1307 in turn. An output signal of the difference image generating module 1307 is supplied to the 90°-clockwise rotation module 1303. The 90°-clockwise rotation module 1303 rotates the supplied macro-block (MB) by +90° clockwise into a rotation<!-- EPO <DP n="60"> --> image, and provides the rotation image to the encoding module 1304. Specifically, an original image stored in the external memory 1302 is laterally elongated with its horizontal width larger than the vertical width, in which according to the order of raster scan for picture frame display, the macro-blocks (MBs) 1, 2, 3 and 4 are aligned in the rightward horizontal direction, and the macro-blocks (MBs) 1, 5 and 9 are aligned in the downward vertical direction. Therefore, the number of the macro-blocks (MBs) 1, 2, 3 and 4 aligned in the rightward horizontal direction of the horizontal width of the original image stored in the external memory 1302 is larger than the number of the macro-blocks (MBs) 1, 5 and 9 aligned in the downward vertical direction of the vertical width of the original image.</p>
<p id="p0140" num="0140">On another note, the rotation image supplied to the encoding module 1304 after the +90° clockwise rotation by the 90°-clockwise rotation module 1303 includes a smaller number of macro-blocks (MBs) 9, 5 and 1 in the horizontal direction of the horizontal width, and a larger number of macro-blocks (MBs) 1, 2, 3 and 4 in the vertical direction of the vertical width.</p>
<p id="p0141" num="0141">The encoding module 1304 handles macro-blocks (MBs) 9, 5 and 1 of output signals of the difference image generating module 1307 which are supplied through the 90°-clockwise rotation module 1303 to execute the moving image encoding<!-- EPO <DP n="61"> --> process in turn. Next, the encoding module 1304 handles macro-blocks (MBs) 10, 6 and 2 of output signals of the difference image generating module 1307 which are supplied from the 90°-clockwise rotation module 1303 to execute the moving image encoding process in turn. A moving image encoded bit stream produced by the moving image encoding process by the encoding module 1304 and output therefrom is stored in the external memory 1302. An output of the encoding module 1304 is also supplied to the 90°-counterclockwise rotation module 1309. An output of the 90°-counterclockwise rotation module 1309 is stored in the external memory 1302 as a reference image, according to a reference image address generated by the reference image address generating module 1308. A capacity depending on the number of the macro-blocks (MBs) 1, 5 and 9 aligned in the vertical direction of the vertical width of the original image stored in the external memory 1302 is good enough as the storage capacity of the surrounding macro-block information storing memory 1305 which is necessary for the moving image encoding process.</p>
<p id="p0142" num="0142">Therefore, in the case of forming the encoding device 1301 with a system LSI, the surrounding macro-block information storing memory 1305 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 1302 used to store an original image, a reference image and a moving image<!-- EPO <DP n="62"> --> encoded bit stream is composed of a synchronous dynamic random access memory (SDRAM). Further, a motion vector MV1 encoded by the moving image encoding process in the encoding device 1301 is also rotated by +90° clockwise by the 90°-clockwise rotation module 1303 with respect to the motion vector in the original image stored in the external memory 1302.</p>
<p id="p0143" num="0143">The decoding device 1311 includes: a decoding module 1314; a surrounding macro-block information storing memory 1315; a 90°-counterclockwise rotation module 1313; an image read address generating module 1316; a difference image generating module 1317; and an image write address generating module 1318.</p>
<p id="p0144" num="0144">The decoding module 1314 first reads out a smaller number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a moving image encoded bit stream stored in the external memory 1312 in turn. The smaller number of macro-blocks (MBs) 9, 5 and 1 of the moving image encoded bit stream read out from the external memory 1312 in sequence, which are aligned in the horizontal direction of the horizontal width, are supplied to the 90°-counterclockwise rotation module 1313 through the difference image generating module 1317. The 90°-counterclockwise rotation module 1313 creates plural macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width and supplies them to the decoding module 1314.<!-- EPO <DP n="63"> --></p>
<p id="p0145" num="0145">Further, the image read address generating module 1316 reads out plural macro-blocks (MBs) 9, 5 and 1 aligned in the vertical direction of the vertical width of a reference image stored in the external memory 1312 in turn and therefore, the decoding module 1314 uses the macro-blocks (MBs) 9, 5 and 1 of the moving image encoded bit stream and the macro-blocks (MBs) 9, 5 and 1 of the reference image to execute the moving image decoding process. A moving image decode bit stream produced by the moving image decoding process by the decoding module 1314 is stored in the external memory 1312 according to an address generated by the image write address generating module 1318. A capacity depending on the number of macro-blocks (MBs) 9, 5 and 1 aligned in the horizontal direction of the horizontal width of a moving image encoded bit stream stored in the external memory 1312 is good enough as the storage capacity of the surrounding macro-block information storing memory 915 which is necessary for the moving image decoding process.</p>
<p id="p0146" num="0146">As a result, in the case of forming the decoding device 1311 with a system LSI, the surrounding macro-block information storing memory 1315 with a relatively small storage capacity can be arranged as a built-in memory (on-chip SRAM) of the system LSI readily. In addition, the external memory 1312 used to store a moving image encoded bit stream, a reference image and a moving image decode bit stream is composed of a<!-- EPO <DP n="64"> --> synchronous dynamic random access memory (SDRAM). Further, a motion vector MV2 decoded by the moving image decoding process in the decoding device 1311 is made by a coordinate transform of a motion vector MV1, by which the x-coordinate of the motion vector MV1 encoded by the moving image encoding process in the encoding device 1301 is made a γ-coordinate of the motion vector MV2, and the γ-coordinate of the motion vector MV1 is made an x-coordinate of the motion vector MV2, provided that the sign of the x-coordinate of the motion vector MV2 is minus.</p>
<p id="p0147" num="0147">The moving image encoding device 1301 and the moving image decoding device 1311 according to the fourth embodiment of the invention shown in <figref idref="f0008">FIG. 15</figref> can be integrated into a semiconductor chip of a moving image encoding/decoding device formed by a system LSI. In this case, the encoding module 1304 and the decoding module 1314 can be constituted by hardware resources common to them; the surrounding macro-block information storing memory 1305 and the surrounding macro-block information storing memory 1315 can be constituted by hardware resources common to them; and the 90°-clockwise rotation module 1303 and the 90°-counterclockwise rotation module 1313 can be constituted by hardware resources common to them. The moving image encoding/decoding device formed by a system LSI can be arranged to appropriately work as the encoding device 1301 or the decoding device 1311 following operation mode setting information supplied during<!-- EPO <DP n="65"> --> initialization sequence at power-on for example.</p>
<heading id="h0021">[Fifth Embodiment]</heading>
<heading id="h0022">&lt;&lt;Moving image processing device according to the fifth embodiment&gt;&gt;</heading>
<p id="p0148" num="0148"><figref idref="f0009">FIG. 16</figref> is a view showing a structure of a moving image processing device 1750 according to the fifth embodiment of the invention, which can be used as any of the following modules: the macro-block encoding/decoding module 203 of the moving image encoding/decoding device 201 according to the first embodiment of the invention shown in <figref idref="f0003">FIG. 5</figref>; the encoding module 704 of the encoding device 701 and the decoding module 714 of the decoding device 711 according to the second embodiment of the invention shown in <figref idref="f0006">FIG. 13</figref>; the encoding module 904 of the encoding device 901, and the decoding module 1914 of the decoding device 1911 according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref>; and the encoding module 1304 of the encoding device 1301 and the decoding module 1914 of the decoding device 1311 according to the fourth embodiment of the invention shown in <figref idref="f0008">FIG. 15</figref>.</p>
<p id="p0149" num="0149">The moving image processing device 1750 according to the fifth embodiment of the invention shown in <figref idref="f0009">FIG. 16</figref> includes: a variable length coding/decoding module (VLCS) 1703; a first moving image processing unit (CODEC1) 1719; a second moving image processing unit (CODEC2) 1729; a memory control module (MEC) 1714; a local memory controller (LMC) 1724; a total<!-- EPO <DP n="66"> --> control module (CTRL) 1715; a DMA controller (DMAC) 1725; an external bus 1701; and an internal bus 1702. According to a preferred embodiment, the moving image processing device 1750 is arranged in the form of a semiconductor LSI (Large Scale Integrated Circuits) formed on a semiconductor substrate, e.g. a monocrystalline silicon substrate. In addition, the moving image processing device 1750 according to the fifth embodiment of the invention shown in <figref idref="f0009">FIG. 16</figref> can be arranged to appropriately work as an encoding device or a decoding device following operation mode setting information supplied during initialization sequence at power-on.</p>
<heading id="h0023">«Variable length coding/decoding module»</heading>
<p id="p0150" num="0150">The variable length coding/decoding module (VLCS) 1703 is supplied with encoded data of a moving image in the form of a bit stream (BS) from a medium, such as a HDD(Hard Disk Drive), an optical disk drive, a large-capacity nonvolatile flash memory, or a wireless LAN (Local Area Network) through the DMA controller 1725. The variable length coding/decoding module (VLCS) 1703 has therein a stream-analyzing module. The stream-analyzing module supplies the first moving image processing unit (CODEC1) 1719 with macro-blocks located in rows labeled with odd ordinal numbers like the first row, the third row, and so on, and supplies the second moving image processing unit (CODEC2) 1729 with macro-blocks located in rows labeled with even ordinal numbers like the second row, the fourth row,<!-- EPO <DP n="67"> --> and so on.</p>
<p id="p0151" num="0151">The variable length coding/decoding module (VLCS) 1703 has therein a pipeline control module. The pipeline control module controls pipeline operations for a parallel operation of the first moving image processing unit (CODEC1) 1719 and the second moving image processing unit (CODEC2) 1729 on macro-blocks. Specifically, the pipeline operation involving the first variable length coding/decoding module (VLCF1) 1710, the first frequency conversion module (TRF1) 1711, the first motion compensation module (FME1) 1712 and the first deblocking filter (DEB1) 1713, which are internal circuits of the first moving image processing unit (CODEC1) 1719, is executed under the control of the pipeline control module of the variable length coding/decoding module (VLCS) 1703. Further, the pipeline operation involving the second variable length coding/decoding module (VLCF2) 1720, the second frequency conversion module (TRF2) 1721, the second motion compensation module (FME2) 1722, and the second deblocking filter (DEB2) 1723, which are internal circuits of the second moving image processing unit (CODEC2) 1729, is executed under the control of the pipeline control module of the variable length coding/decoding module (VLCS) 1703. Hence, the parallel operation of the first moving image processing unit (CODEC1) 1719 and the second moving image processing unit (CODEC2) 1729 which includes the execution of the pipeline operations is<!-- EPO <DP n="68"> --> arranged to be suitable for the encoding/decoding process of pairs of macro-blocks (MBs) in macro-block adaptive type frame-field prediction mode according to the first embodiment of the invention as described with reference to <figref idref="f0005">FIG. 12</figref>.</p>
<p id="p0152" num="0152">As described above, the variable length coding/decoding module (VLCS) 1703 has the function of determining values of a group of parameters necessary for the first moving image processing unit (CODEC1) 1719 and the second moving image processing unit (CODEC2) 1729 in the subsequent stage by performing the variable-length decoding of a bit stream supplied thereto thereby to extract a macro-block type and a motion vector.</p>
<heading id="h0024">«Variable length coding/decoding module»</heading>
<p id="p0153" num="0153">The variable length coding/decoding module (VLCS) 1703 supplies macro-blocks in rows labeled with odd ordinal numbers, and macro-blocks in rows labeled with even ordinal numbers to the first variable length coding/decoding module (VLCF1) 1710 and the second variable length coding/decoding module (VLCF2) 1720, respectively. Then, the first variable length coding/decoding module (VLCF1) 1710 and the second variable length coding/decoding module (VLCF2) 1720 perform context-based adaptive variable length coding/decoding on the macro-blocks, thereby to encode/decode motion vector information, macro-block parameters, and frequency conversion information.<!-- EPO <DP n="69"> --></p>
<heading id="h0025">«Frequency conversion module»</heading>
<p id="p0154" num="0154">On acceptance of supplies of frequency conversion information from the first variable length coding/decoding module (VLCF1) 710 and the second variable length coding/decoding module (VLCF2) 1720, the first frequency conversion module (TRF1) 1711 and the second frequency conversion module (TRF2) 1721 execute IQ(Inverse Quantization) and IDCT(Inverse Discrete Cosine Transform). Specifically, the first frequency conversion module (TRF1) 1711 and the second frequency conversion module (TRF2) 1721 process quantization conversion coefficients and quantization parameters as frequency conversion information supplied from the first variable length coding/decoding module (VLCF1) 1710 and the second variable length coding/decoding module (VLCF2) 1720, perform the inverse quantization conversion to calculate conversion coefficients, perform the inverse orthogonal transform on the conversion coefficients thus calculated to determine pixel values or interframe prediction residuals, add the interframe prediction residuals to a reference image supplied from the first motion compensation module (FME1) 1712 and the second motion compensation module (FME2) 1722 to calculate pixel values, and output a resultant image.</p>
<heading id="h0026">«Motion compensation module»</heading>
<p id="p0155" num="0155">The first Motion compensation module (FME1) 1712 and the second motion compensation module (FME2) 1722 execute motion<!-- EPO <DP n="70"> --> compensation. Specifically, the first motion compensation module (FME1) 1712 and the second motion compensation module (FME2) 1722 execute a motion search using a reference image supplied from the external memory through the memory control module (MEC) 1714, the internal bus 1702, the DMA controller (DMAC) 1725 and the external bus 1701, thereby to calculate a reference image at a position indicated by a motion vector, and output the reference image thus calculated to the first frequency conversion module (TRF1) 1711 and the second frequency conversion module (TRF2) 1721.</p>
<heading id="h0027">«Deblocking filter»</heading>
<p id="p0156" num="0156">The first deblocking filter (DEB1) 1713, and the second deblocking filter (DEB2) 1723 execute a deblocking filtering process for reducing a block distortion produced at the time of image decoding. Specifically, the first and second deblocking filters (DEB1, DEB2) 1713 and 1723 execute a deblocking filtering using image data of macro-blocks (MBs) made subjects of the processing and supplied from the first and second frequency conversion modules (TRF1, TRF2) 1711 and 1721, and image data of left-side macro-blocks (MBs) made subjects of the processing and supplied from built-in memories in the first and second deblocking filters(DEB1, DEB2) 1713 and 1723.</p>
<heading id="h0028">&lt;&lt;Memory control module&gt;&gt;</heading>
<p id="p0157" num="0157">According to the information of a motion vector supplied<!-- EPO <DP n="71"> --> from the first and second variable length coding/decoding modules (VLCF1, VLCF2) 1710 and 1720, the memory control module (MEC) 1714 supplies a reference image to use for interframe prediction from the external memory to the first and second motion compensation modules (FME1, FME2) 1712 and 1722 through the internal bus 1702, the DMA controller (DMAC) 1725 and the external bus 1701.</p>
<heading id="h0029">«Total control module»</heading>
<p id="p0158" num="0158">The total control module (CTRL) 1715 controls all the internal circuits of the moving image processing device 1750 in their operations. For instance, the total control module (CTRL) 1715 produces a operation control signal deb_start for controlling the operations of the first and second deblocking filters(DEB1, DEB2) 1713 and 1723.</p>
<heading id="h0030">&lt;&lt;Local memory controller&gt;&gt;</heading>
<p id="p0159" num="0159">The local memory controller (LMC) 1724 controls write and read operations on: the surrounding macro-block information storing memory 204 of the moving image encoding/decoding device (CODEC) 201 according to the first embodiment of the invention shown in <figref idref="f0003">FIG. 5</figref>; the surrounding macro-block information storing memory 705 of the encoding device 701, and the surrounding macro-block information storing memory 715 of the decoding device 711, according to the second embodiment of the invention shown in <figref idref="f0006">FIG. 13</figref>; the surrounding macro-block information storing memory 905 of the<!-- EPO <DP n="72"> --> encoding device 901, and the surrounding macro-block information storing memory 915 of the decoding device1911 according to the third embodiment of the invention shown in <figref idref="f0007">FIG. 14</figref>; and the surrounding macro-block information storing memory 1305 of the encoding device 1301, and the surrounding macro-block information storing memory 1315 of the decoding device 1311 according to the fourth embodiment of the invention shown in <figref idref="f0008">FIG. 15</figref>.</p>
<p id="p0160" num="0160">For instance, the local memory controller (LMC) 1724 stores results of the processing by the first moving image processing unit (CODEC1) 1719 assigned macro-blocks (MBs) of odd rows, and relevant parameters in the surrounding macro-block information storing memories, and transfers a required image and relevant parameters to the second moving image processing unit (CODEC2) 1729 assigned macro-blocks (MBs) of even rows. Also, the local memory controller (LMC) 1724 stores results of the processing by the second moving image processing unit (CODEC2) 1729 assigned the macro-blocks (MBs) of even rows, and the relevant parameters in the surrounding macro-block information storing memories, and transfers a required image and relevant parameters to the first moving image processing unit (CODEC1) 1719 assigned macro-blocks (MBs) of odd rows. As described above, the local memory controller (LMC) 1724 executes the operation of storing surrounding macro-block information in the surrounding<!-- EPO <DP n="73"> --> macro-block information storing memories, and the operation of reading such information from the surrounding macro-block information storing memories, and is connected with a built-in memory (on-chip SRAM) forming the surrounding macro-block information storing memory built in the semiconductor chip of the moving image encoding/decoding device (CODEC) including a system large-scale semiconductor integrated circuit (system LSI) .</p>
<heading id="h0031">«DMA controller»</heading>
<p id="p0161" num="0161">The DMA controller (DMAC: Direct Memory Access Controller) 1725 is connected with the external bus 1701 of the moving image processing device 1750. For instance, the DMA controller is used for high-speed data transfer of a reference image or encoded bit stream which includes a large volume of macro-blocks (MBs) between the external memory formed by a synchronous dynamic random access memory (SDRAM) and the first and second moving image processing units 1719 and 1729.</p>
<p id="p0162" num="0162">In the case of the moving image processing device 1750 according to the fifth embodiment of the invention shown in <figref idref="f0009">FIG. 16</figref> working as a decoding device, the first variable length coding/decoding module (VLCF1) 1710, the first frequency conversion module (TRF1) 1711 and the first motion compensation module (FME1) 1712 of the first moving image processing unit (CODEC1) 1719 operate as a variable length decoding module, an inverse quantizer/inverse DCT converter, and a motion<!-- EPO <DP n="74"> --> compensation module respectively. Likewise, the second variable length coding/decoding module (VLCF2) 1720, the second frequency conversion module (TRF2) 1721 and the second Motion compensation module (FME2) 1722 of the second moving image processing unit (CODEC2) 1729 operate as a variable length decoding module, an inverse quantizer/inverse DCT converter and a motion compensation module respectively.</p>
<p id="p0163" num="0163">Further, in the case of the moving image processing device 1750 according to the fifth embodiment of the invention shown in <figref idref="f0009">FIG. 16</figref> working as an encoding device, the first variable length coding/decoding module (VLCF1) 1710, the first frequency conversion module (TRF1) 1711 and the first motion compensation module (FME1) 1712 of the first moving image processing unit (CODEC1) 1719 operate as a variable length encoding module forming a residual encoding module, a DCT converter/quantizer, and a motion prediction module respectively. Likewise, the second variable length coding/decoding module (VLCF2) 1720, the second frequency conversion module (TRF2) 1721 and the second motion compensation module (FME2) 1722 of the second moving image processing unit (CODEC2) 1729 operate as a variable length encoding module forming a residual encoding module, a DCT converter/quantizer and a motion prediction module respectively.</p>
<p id="p0164" num="0164">The invention made by the inventor has been described<!-- EPO <DP n="75"> --> above based on the various embodiments thereof specifically. However, it is obvious that the invention is not so limited, and various changes and modifications thereof may be made without departing from the subject matter thereof.</p>
<p id="p0165" num="0165">For instance, in the fifth embodiment of the invention which has been described with reference to <figref idref="f0009">FIG. 16</figref>, the first variable length coding/decoding module (VLCF1) 1710, the first frequency conversion module (TRF1) 1711, and the first Motion compensation module (FME1) 1712 of the first moving image processing unit (CODEC1) 1719, and the second variable length coding/decoding module (VLCF2) 1720, the second frequency conversion module (TRF2) 1721, and the second motion compensation module (FME2) 1722 of the second moving image processing unit (CODEC2) 1729 are not limited to be materialized in the forms of hardware. Operation functions thereof can be realized by e.g. software processing by e.g. a microprocessor. In such case, cache memories of a microprocessor and the like may be used for the surrounding macro-block information storing memories 204, 705, 715, etc.</p>
<p id="p0166" num="0166">The moving image encoding/decoding devices according to the various embodiments of the invention described above can be provided in e.g. mobile telephones, car navigation systems, DVD/HDD/BD recorders, digital video cameras, digital cameras, digital television sets, and telephone meeting systems.</p>
</description>
<claims id="claims01" lang="en"><!-- EPO <DP n="76"> -->
<claim id="c-en-01-0001" num="0001">
<claim-text>A moving image encoding method for encoding a plurality of macro-blocks (14) included in a landscape picture frame (12) of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction by use of an encoding device (201), comprising:
<claim-text>storing information of the plurality of macro-blocks (14) already encoded and surrounding a macro-block (14) to be encoded in an information storing memory (204) built in the encoding device (201), wherein the information storing memory (204) and the encoding device (201) are built in a same semiconductor chip;</claim-text>
<claim-text><b>characterized in that</b> the method further comprises:
<claim-text>first, sequentially encoding an array of a plurality of vertically aligned macro-blocks (14) at a left end of the horizontal width of the landscape picture frame (12) to store, in the information storing memory (204), encoded information of the array of the plurality of vertically aligned macro-blocks (14) at the left end; and</claim-text>
<claim-text>subsequently, encoding an adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) after having encoded the array of the plurality of vertically aligned macro-blocks<!-- EPO <DP n="77"> --> (14) ,</claim-text>
<claim-text>wherein the step of sequentially encoding the adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end involves using the encoded information of the array of the plurality of vertically aligned macro-blocks (14) at the left end, the encoded information being stored in the information storing memory (204).</claim-text></claim-text></claim-text></claim>
<claim id="c-en-01-0002" num="0002">
<claim-text>The moving image encoding method according to Claim 1, wherein the encoding device (201) judges whether or not the encoded macro-block (14) is one of last and first macro-blocks (14) located at lower and upper ends of the vertical width after having encoded each macro-block (14) in the array of the plurality of vertically aligned macro-blocks (14).</claim-text></claim>
<claim id="c-en-01-0003" num="0003">
<claim-text>The moving image encoding method according to Claim 2, wherein the encoding device (201) judges whether or not the encoded array of macro-blocks (14) is a last array of macro-blocks (14) located at a right end of the horizontal width after having encoded the adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (12).</claim-text></claim>
<claim id="c-en-01-0004" num="0004">
<claim-text>The moving image encoding method according to Claim<!-- EPO <DP n="78"> --> 3, wherein in case that the encoding device (201) judges the encoded macro-block (14) not to be any of the last and first macro-blocks (14) located at the lower and upper ends of the vertical width, a count value of a vertical direction counter showing a position of the macro-block (14) to be encoded next in the vertical direction of the left end is incremented by one.</claim-text></claim>
<claim id="c-en-01-0005" num="0005">
<claim-text>The moving image encoding method according to Claim 4, wherein in case that the encoding device (201) judges the encoded array of the plurality of macro-blocks (14) not to be the last array of macro-blocks (14) located at the right end of the horizontal width, a count value of a horizontal direction counter showing a position of an array of the plurality of macro-blocks (14) to be encoded next in the horizontal direction of the horizontal width of the landscape picture frame (12) is incremented by one.</claim-text></claim>
<claim id="c-en-01-0006" num="0006">
<claim-text>A moving image decoding method for decoding macro-blocks (14) included in a landscape picture frame (12) of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction by use of a decoding device (201), comprising:
<claim-text>storing information of macro-blocks (14) already decoded and surrounding a macro-block (14) to be decoded in an information storing memory (204) built in the decoding device<!-- EPO <DP n="79"> --> (201), wherein the information storing memory (204) and the decoding device (201) are built in a same semiconductor chip;</claim-text>
<claim-text><b>characterized in that</b> the method further comprises:
<claim-text>first, sequentially decoding an array of a plurality of vertically aligned macro-blocks (14) at a left end of the horizontal width of the landscape picture frame (12) to store, in the information storing memory (204), decoded information of the array of the plurality of vertically aligned macro-blocks (14) at the left end; and</claim-text>
<claim-text>subsequently, decoding an adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) after having decoded the array of the plurality of vertically aligned macro-blocks (14),</claim-text>
<claim-text>wherein the step of sequentially decoding the adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end involves using the decoded information of the array of the plurality of vertically aligned macro-blocks (14) at the left end, the decoded information being stored in the information storing memory (204).</claim-text></claim-text></claim-text></claim>
<claim id="c-en-01-0007" num="0007">
<claim-text>The moving image decoding method according to Claim 6, wherein the decoding device (201) judges whether or not the decoded macro-block (14) is one of last and first macro-blocks<!-- EPO <DP n="80"> --> (14) located at lower and upper ends of the vertical width after having decoded each macro-block (14) in the array of the plurality of vertically aligned macro-blocks (14).</claim-text></claim>
<claim id="c-en-01-0008" num="0008">
<claim-text>The moving image decoding method according to Claim 7, wherein the decoding device (201) judges whether or not the decoded array of macro-blocks (14) is a last array of macro-blocks (14) located at a right end of the horizontal width after having decoded the adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (12).</claim-text></claim>
<claim id="c-en-01-0009" num="0009">
<claim-text>The moving image decoding method according to Claim 8, wherein in case that the decoding device (201) judges the decoded macro-block (14) not to be any of the last and first macro-blocks (14) located at the lower and upper ends of the vertical width, a count value of a vertical direction counter showing a position of a macro-block (14) to be decoded next in the vertical direction of the left end is incremented by one.</claim-text></claim>
<claim id="c-en-01-0010" num="0010">
<claim-text>The moving image decoding method according to Claim 9, wherein in case that the decoding device (201) judges the decoded array of macro-blocks (14) not to be the last array of macro-blocks (14) located at the right end of the horizontal width, a count value of a horizontal direction counter showing<!-- EPO <DP n="81"> --> a position of an array of macro-blocks (14) to be decoded next in the horizontal direction of the horizontal width of the landscape picture frame (12) is incremented by one.</claim-text></claim>
<claim id="c-en-01-0011" num="0011">
<claim-text>A moving image decoding device (201) for decoding macro-blocks (14) included in a landscape picture frame (12) of a moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction, comprising:
<claim-text>a decoding module (203), and</claim-text>
<claim-text>an information storing memory (204),</claim-text>
<claim-text>wherein the decoding module (203) and the information storing memory (204) are built in a same semiconductor chip,</claim-text>
<claim-text>wherein a plurality of macro-blocks (14) are decoded by use of the decoding module (203) by:
<claim-text>storing information of macro-blocks (14) already decoded and surrounding a macro-block (14) to be decoded in the information storing memory (204);</claim-text>
<claim-text><b>characterized in that</b> decoding the plurality of macro-blocks (14) by use of the decoding module (203) further comprises:
<claim-text>first, sequentially decoding an array of the plurality of vertically aligned macro-blocks (14) at a left end of the horizontal width of the landscape picture frame (12) to store, in the information storing memory (204), decoded information of the array of the plurality of vertically aligned macro-blocks<!-- EPO <DP n="82"> --> (14) at the left end; and</claim-text>
<claim-text>sequentially decoding an adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) after having decoded the array of the plurality of vertically aligned macro-blocks (14) of the landscape picture frame (12),</claim-text>
<claim-text>wherein the step of sequentially decoding the adjacent array of the plurality of vertically aligned macro-blocks (14) located horizontally on the right of the left end by use of the decoding module (203) involves using the decoded information of the array of the plurality of vertically aligned macro-blocks (14) at the left end, the decoded information being stored in the information storing memory (204) .</claim-text></claim-text></claim-text></claim-text></claim>
<claim id="c-en-01-0012" num="0012">
<claim-text>The moving image decoding device (201) according to Claim 11, further comprising:
<claim-text>an external interface (913, 916, 918, 1313, 1316, 1318) for supplying moving image encoded signals, the external interface (913, 916, 918, 1313, 1316, 1318) operable to supply the decoding module (203) with the array of macro-blocks (14) included in the moving image encoded signals and vertically aligned at the left end of the horizontal width of the landscape picture frame (12), and subsequently to supply the decoding module (203) with an adjacent array of the plurality<!-- EPO <DP n="83"> --> of vertically aligned macro-blocks (14) horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) included in the moving image encoded signals,</claim-text>
<claim-text>the moving image decoding device (201) being operable to decode the array of the plurality of vertically aligned macro-blocks (14) at the left end of the horizontal width of the landscape picture frame (12) included in the moving image encoded signal supplied from the external interface (913, 916, 918, 1313, 1316, 1318), and subsequently to decode an adjacent array of the plurality of vertically aligned macro-blocks (14) horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) included in moving image encoded signals supplied from the external interface (913, 916, 918, 1313, 1316, 1318),</claim-text>
<claim-text>the moving image decoding device (201) being connectable with an image memory (702, 902, 1302) in which image information of a decoded moving image having a larger horizontal width in a horizontal direction in comparison to a vertical width in a vertical direction can be stored,</claim-text>
<claim-text>the moving image decoding device (201) being operable to store image information obtained by decoding the array of the plurality of vertically aligned macro-blocks (14) at the left end of the horizontal width of the landscape picture frame (12) in a first memory region of the image memory (702, 902, 1302), which corresponds to an image area of the array of the<!-- EPO <DP n="84"> --> plurality of vertically aligned macro-blocks (14) at the left end of the horizontal width of the landscape picture frame (12), and subsequently to store image information obtained by decoding the adjacent array of the plurality of vertically aligned macro-blocks (14) horizontally on the right of the left end of the horizontal width of the landscape picture frame (12) in a second memory region of the image memory (702, 902, 1302), which corresponds to an image area of the adjacent array of the plurality of vertically aligned macro-blocks (14) horizontally on the right of the left end of the horizontal width of the landscape picture frame (12)</claim-text></claim-text></claim>
<claim id="c-en-01-0013" num="0013">
<claim-text>The moving image decoding device (201) according to Claim 12, wherein the external interface (913, 916, 918, 1313, 1316, 1318) is operable to generate a difference image of the plurality of macro-blocks (14) by a difference image generating module and to rotate the difference image of the plurality of macro-blocks (14) by a 90° counterclockwise rotation module, and supply a rotation image of the plurality of macro-blocks (14) to the decoding module (203).</claim-text></claim>
</claims>
<claims id="claims02" lang="de"><!-- EPO <DP n="85"> -->
<claim id="c-de-01-0001" num="0001">
<claim-text>Verfahren zur Kodierung von bewegten Bildern zur Kodierung einer Vielzahl von Makroblöcken (14), die in einem querformatigen Bildrahmen (12) eines bewegten Bildes mit einer größeren horizontalen Breite in einer horizontalen Richtung im Vergleich zu einer vertikalen Breite in einer vertikalen Richtung enthalten sind, durch Verwendung einer Kodiervorrichtung (201), wobei das Verfahren Folgendes umfasst:
<claim-text>das Speichern von Informationen der Vielzahl von Makroblöcken (14), die bereits kodiert sind, und die einen zu kodierenden Makroblock (14) umgeben, in einem informationsspeichernden Speicher (204), der in die Kodiervorrichtung (201) eingebaut ist, wobei der informationsspeichernde Speicher (204) und die Kodiervorrichtung (201) in einem selben Halbleiter-Chip eingebaut sind;</claim-text>
<claim-text><b>dadurch gekennzeichnet, dass</b> das Verfahren außerdem Folgendes umfasst:
<claim-text>zunächst das sequentielle Kodieren einer Matrix einer Vielzahl von vertikal ausgerichteten Makroblöcken (14) an einem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12), um kodierte Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende in dem informationsspeichernden Speicher (204) zu speichern; und</claim-text>
<claim-text>danach das Kodieren einer benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) angeordnet sind, nachdem die Matrix der Vielzahl von vertikal ausgerichteten Makroblöcke (14) kodiert wurde,</claim-text>
<claim-text>wobei der Schritt des sequentiellen Kodierens der benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende angeordnet sind, die Verwendung der kodierten Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende umfasst, wobei die kodierten Informationen in dem informationsspeichernden Speicher (204) gespeichert sind.</claim-text></claim-text></claim-text></claim>
<claim id="c-de-01-0002" num="0002">
<claim-text>Verfahren zur Kodierung von bewegten Bildern nach Anspruch 1, wobei die Kodiervorrichtung (201) beurteilt, ob der kodierte Makroblock (14) einer eines letzten und eines ersten Makroblocks (14) ist, die am unteren und oberen Ende der vertikalen Breite angeordnet sind, nachdem sie jeden Makroblock (14) in der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) kodiert hat.<!-- EPO <DP n="86"> --></claim-text></claim>
<claim id="c-de-01-0003" num="0003">
<claim-text>Verfahren zur Kodierung eines bewegten Bildes nach Anspruch 2, wobei die Kodiervorrichtung (201) beurteilt, ob die kodierte Matrix von Makroblöcken (14) eine letzte Matrix von Makroblöcken (14) ist, die an dem rechten Ende der horizontalen Breite angeordnet ist, nachdem sie die benachbarte Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) angeordnet sind, kodiert hat.</claim-text></claim>
<claim id="c-de-01-0004" num="0004">
<claim-text>Verfahren zur Kodierung von bewegten Bildern nach Anspruch 3, wobei in dem Fall, dass die Kodiervorrichtung (201) beurteilt, dass der kodierte Makroblock (14) nicht einer des letzten und ersten Makroblocks (14) ist, die an dem unteren und oberen Ende der vertikalen Breite angeordnet sind, ein Zählwert eines Zählers der vertikalen Richtung, der eine Position des Makroblocks (14) anzeigt, die in der vertikalen Richtung des linken Endes als nächstes zu kodieren ist, um eins erhöht wird.</claim-text></claim>
<claim id="c-de-01-0005" num="0005">
<claim-text>Verfahren zur Kodierung von bewegten Bildern nach Anspruch 4, wobei in dem Fall, dass die Kodiervorrichtung (201) beurteilt, dass die kodierte Matrix der Vielzahl von Makroblöcken (14) nicht die letzte Matrix der Makroblöcke (14) ist, die an dem rechten Ende der horizontalen Breite angeordnet sind, ein Zählwert eines Zählers der horizontalen Richtung, der eine Position einer Matrix der Vielzahl von Makroblöcken (14) anzeigt, die als nächstes in der horizontalen Richtung der horizontalen Breite des querformatigen Bildrahmens (12) zu kodieren ist, um eins erhöht wird.</claim-text></claim>
<claim id="c-de-01-0006" num="0006">
<claim-text>Verfahren zur Dekodierung von bewegten Bildern zur Dekodierung von Makroblöcken (14), die in einem querformatigen Bildrahmen (12) eines bewegten Bildes mit einer größeren horizontalen Breite in einer horizontalen Richtung im Vergleich zu einer vertikalen Breite in einer vertikalen Richtung enthalten sind, durch die Verwendung einer Dekodiervorrichtung (201), wobei das Verfahren Folgendes umfasst:
<claim-text>das Speichern von Informationen von Makroblöcken (14), die bereits dekodiert sind und die einen zu dekodierenden Makroblock (14) umgeben, in einem informationsspeichernden Speicher (204), der in der Dekodiervorrichtung (201) eingebaut ist, wobei der informationsspeichernde Speicher (204) und die Dekodiervorrichtung (201) in einem selben Halbleiter-Chip eingebaut sind;</claim-text>
<claim-text><b>dadurch gekennzeichnet, dass</b> das Verfahren außerdem Folgendes umfasst:<!-- EPO <DP n="87"> -->
<claim-text>zunächst das sequentielle Dekodieren einer Matrix einer Vielzahl von vertikal ausgerichteten Makroblöcken (14) an einem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12), um dekodierte Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende in dem informationsspeichernden Speicher (204) zu speichern; und</claim-text>
<claim-text>danach das Dekodieren einer benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) angeordnet sind, nachdem die Matrix der Vielzahl von vertikal angeordneten Makroblöcke (14) dekodiert wurde,</claim-text>
<claim-text>wobei der Schritt des sequentiellen Dekodierens der benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende angeordnet sind, die Verwendung der dekodierten Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende umfasst, wobei die dekodierten Informationen in dem informationsspeichernden Speicher (204) gespeichert sind.</claim-text></claim-text></claim-text></claim>
<claim id="c-de-01-0007" num="0007">
<claim-text>Verfahren zur Dekodierung von bewegten Bildern nach Anspruch 6, wobei die Dekodiervorrichtung (201) beurteilt, ob der dekodierte Makroblock (14) einer eines letzten und eines ersten Makroblocks (14) ist, die am unteren und oberen Ende der vertikalen Breite angeordnet sind, nachdem sie jeden Makroblock (14) in der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) dekodiert hat.</claim-text></claim>
<claim id="c-de-01-0008" num="0008">
<claim-text>Verfahren zur Dekodierung von bewegten Bildern nach Anspruch 7, wobei die Dekodiervorrichtung (201) beurteilt, ob die dekodierte Matrix von Makroblöcken (14) eine letzte Matrix von Makroblöcken (14) ist, die an dem rechten Ende der horizontalen Breite angeordnet ist, nachdem sie die benachbarte Matrix der Vielzahl von vertikal angeordneten Makroblöcken (14), die horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) angeordnet sind, dekodiert hat.</claim-text></claim>
<claim id="c-de-01-0009" num="0009">
<claim-text>Verfahren zur Dekodierung von bewegten Bildern nach Anspruch 8, wobei in dem Fall, dass die Dekodiervorrichtung (201) beurteilt, dass der dekodierte Makroblock (14) nicht einer des letzten und ersten Makroblocks (14) ist, die an dem unteren und oberen Ende der vertikalen Breite angeordnet sind, ein Zählwert eines Zählers der vertikalen Richtung, der<!-- EPO <DP n="88"> --> eine Position des Makroblocks (14) anzeigt, die in der vertikalen Richtung des linken Endes als nächstes zu dekodieren ist, um eins erhöht wird.</claim-text></claim>
<claim id="c-de-01-0010" num="0010">
<claim-text>Verfahren zur Dekodierung von bewegten Bildern nach Anspruch 9, wobei in dem Fall, dass die Dekodiervorrichtung (201) beurteilt, dass die dekodierte Matrix der Vielzahl von Makroblöcken (14) nicht die letzte Matrix der Makroblöcke (14) ist, die an dem rechten Ende der horizontalen Breite angeordnet sind, ein Zählwert eines Zählers der horizontalen Richtung, der eine Position einer Matrix von Makroblöcken (14) anzeigt, die als nächstes in der horizontalen Richtung der horizontalen Breite des querformatigen Bildrahmens (12) zu dekodieren ist, um eins hochgezählt wird.</claim-text></claim>
<claim id="c-de-01-0011" num="0011">
<claim-text>Vorrichtung zur Dekodierung von bewegten Bildern (201) zum Dekodieren von Makroblöcken (14), die in einem querformatigen Bildrahmen (12) eines bewegten Bildes mit einer größeren horizontalen Breite in einer horizontalen Richtung im Vergleich zu einer vertikalen Breite in einer vertikalen Richtung enthalten ist, wobei die Vorrichtung Folgendes umfasst:
<claim-text>ein Dekodierungsmodul (203) und</claim-text>
<claim-text>einen informationsspeichernden Speicher (204),</claim-text>
<claim-text>wobei das Dekodierungsmodul (203) und der informationsspeichernde Speicher (204) in einem selben Halbleiter-Chip eingebaut sind,</claim-text>
<claim-text>wobei eine Vielzahl von Makroblöcken (14) durch die Verwendung des Dekodierungsmoduls (203) dekodiert werden, durch:
<claim-text>Speichern von Informationen von Makroblöcken (14), die bereits dekodiert sind und einen zu dekodierenden Makroblock (14) umgeben, in dem informationsspeichernden Speicher (204);</claim-text>
<claim-text><b>dadurch gekennzeichnet, dass</b> das Dekodieren der Vielzahl von Makroblöcken (14) durch Verwendung des Dekodierungsmoduls (203) außerdem Folgendes umfasst:
<claim-text>zunächst das sequentielle Dekodieren einer Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an einem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12), um dekodierte Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende in dem informationsspeichernden Speicher (204) zu speichern; und</claim-text>
<claim-text>das sequentielle Dekodieren einer benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende der<!-- EPO <DP n="89"> --> horizontalen Breite des querformatigen Bildrahmens (12) angeordnet sind, nachdem die Matrix der Vielzahl von vertikal ausgerichteten Makroblöcke (14) des querformatigen Bildrahmens (12) dekodiert wurde,</claim-text>
<claim-text>wobei der Schritt des sequentiellen Dekodierens der benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14), die horizontal rechts von dem linken Ende angeordnet sind, unter Verwendung des Dekodierungsmoduls (203) die Verwendung der dekodierten Informationen der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende umfasst, wobei die dekodierten Informationen in dem informationsspeichernden Speicher (204) gespeichert sind.</claim-text></claim-text></claim-text></claim-text></claim>
<claim id="c-de-01-0012" num="0012">
<claim-text>Vorrichtung zur Dekodierung von bewegten Bildern (201) nach Anspruch 11, die außerdem Folgendes umfasst:
<claim-text>eine externe Schnittstelle (913, 916, 918, 1313, 1316, 1318), die kodierte Signale bewegter Bilder liefert, wobei die externe Schnittstelle (913, 916, 918, 1313, 1316, 1318) betreibbar ist, um das Dekodierungsmodul (203) mit der Matrix von Makroblöcken (14) zu versorgen, die in den kodierten Signalen bewegter Bilder enthalten und vertikal an dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) ausgerichtet ist, und nachfolgend das Dekodierungsmodul (203) mit einer benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) zu versorgen, die in den kodierten Signalen bewegter Bilder enthalten ist,</claim-text>
<claim-text>wobei die Vorrichtung zur Dekodierung von bewegten Bildern (201) betreibbar ist, um die Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12), die in dem kodierten Signal bewegter Bilder enthalten ist, und die von der externen Schnittstelle (913, 916, 918, 1313, 1316, 1318) geliefert wird, zu dekodieren, und nachfolgend eine benachbarte Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) zu dekodieren, die in kodierten Signalen bewegter Bilder enthalten ist und die von der externen Schnittstelle (913, 916, 918, 1313, 1316, 1318) geliefert wird,</claim-text>
<claim-text>wobei die Vorrichtung zur Dekodierung von bewegten Bildern (201) mit einem Bildspeicher (702, 902, 1302) verbindbar ist, in dem Bildinformationen eines dekodierten bewegten Bildes mit einer größeren horizontalen Breite in einer horizontalen Richtung im Vergleich zu einer vertikalen Breite in einer vertikalen Richtung gespeichert werden können,<!-- EPO <DP n="90"> --></claim-text>
<claim-text>wobei die Vorrichtung zur Dekodierung von bewegten Bildern (201) betreibbar ist, um Bildinformationen zu speichern, die durch Dekodierung der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) in einer ersten Speicherregion des Bildspeichers (702, 902, 1302), die einem Bildbereich der Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) an dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) entspricht, erhalten werden, und nachfolgend Bildinformationen zu speichern, die durch Dekodieren der benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) in einer zweiten Speicherregion des Bildspeichers (702, 902, 1302), die einem Bildbereich der benachbarten Matrix der Vielzahl von vertikal ausgerichteten Makroblöcken (14) horizontal rechts von dem linken Ende der horizontalen Breite des querformatigen Bildrahmens (12) entspricht, erhalten werden.</claim-text></claim-text></claim>
<claim id="c-de-01-0013" num="0013">
<claim-text>Vorrichtung zur Dekodierung von bewegten Bildern (201) nach Anspruch 12, wobei die externe Schnittstelle (913, 916, 918, 1313, 1316, 1318) betreibbar ist, um durch ein Differenzbilderzeugungsmodul ein Differenzbild der Vielzahl von Makroblöcken (14) zu erzeugen und das Differenzbild der Vielzahl von Makroblöcken (14) durch ein Modul für eine 90°-Drehung gegen den Uhrzeigersinn zu drehen, und ein Drehbild der Vielzahl von Makroblöcken (14) an das Dekodierungsmodul (203) zu liefern.</claim-text></claim>
</claims>
<claims id="claims03" lang="fr"><!-- EPO <DP n="91"> -->
<claim id="c-fr-01-0001" num="0001">
<claim-text>Procédé de codage d'images animées pour coder une pluralité de macroblocs (14), inclus dans une trame d'image de paysage (12) d'une image animée présentant une largeur horizontale qui est plus grande dans une direction horizontale qu'une largeur verticale dans une direction verticale, en utilisant un dispositif de codage (201), le procédé comprenant l'étape ci-dessous consistant à :
<claim-text>stocker des informations de la pluralité de macroblocs (14) déjà codés et entourant un macrobloc (14) à coder, dans une mémoire de stockage d'informations (204) intégrée dans le dispositif de codage (201), dans lequel la mémoire de stockage d'informations (204) et le dispositif de codage (201) sont intégrés dans une même puce semi-conductrice ;</claim-text>
<claim-text><b>caractérisé en ce que</b> le procédé comprend en outre les étapes ci-dessous consistant à :
<claim-text>premièrement, coder séquentiellement un réseau d'une pluralité de macroblocs alignés verticalement (14) à une extrémité gauche de la largeur horizontale de la trame d'image de paysage (12) en vue de stocker, dans la mémoire de stockage d'informations (204), des informations codées du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche ; et</claim-text>
<claim-text>subséquemment, coder un réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), après avoir codé le réseau de la pluralité de macroblocs alignés verticalement (14) ;</claim-text>
<claim-text>dans lequel l'étape de codage séquentiel du réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche implique l'utilisation des informations codées du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche, les informations codées étant stockées dans la mémoire de stockage d'informations (204).</claim-text></claim-text><!-- EPO <DP n="92"> --></claim-text></claim>
<claim id="c-fr-01-0002" num="0002">
<claim-text>Procédé de codage d'images animées selon la revendication 1, dans lequel le dispositif de codage (201) juge si le macrobloc codé (14) correspond ou non à l'un parmi des dernier et premier macroblocs (14) situés à des extrémités inférieure et supérieure de la largeur verticale, après avoir codé chaque macrobloc (14) dans le réseau de la pluralité de macroblocs alignés verticalement (14).</claim-text></claim>
<claim id="c-fr-01-0003" num="0003">
<claim-text>Procédé de codage d'images animées selon la revendication 2, dans lequel le dispositif de codage (201) juge si le réseau codé de macroblocs (14) correspond ou non à un dernier réseau de macroblocs (14) situé à une extrémité droite de la largeur horizontale, après avoir codé le réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12) .</claim-text></claim>
<claim id="c-fr-01-0004" num="0004">
<claim-text>Procédé de codage d'images animées selon la revendication 3, dans lequel, dans le cas où le dispositif de codage (201) juge que le macrobloc codé (14) ne correspond à aucun des dernier et premier macroblocs (14) situés aux extrémités inférieure et supérieure de la largeur verticale, une valeur de comptage d'un compteur de direction verticale montrant une position du macrobloc (14) à coder successivement dans la direction verticale de l'extrémité gauche est incrémentée de « 1 ».</claim-text></claim>
<claim id="c-fr-01-0005" num="0005">
<claim-text>Procédé de codage d'images animées selon la revendication 4, dans lequel, dans le cas où le dispositif de codage (201) juge que le réseau codé de la pluralité de macroblocs (14) ne correspond pas au dernier réseau de macroblocs (14) situé à l'extrémité droite de la largeur horizontale, une valeur de comptage d'un compteur de direction horizontale montrant une position d'un réseau de la pluralité de macroblocs (14) à coder successivement dans<!-- EPO <DP n="93"> --> la direction horizontale de la largeur horizontale de la trame d'image de paysage (12) est incrémentée de « 1 ».</claim-text></claim>
<claim id="c-fr-01-0006" num="0006">
<claim-text>Procédé de décodage d'images animées pour décoder des macroblocs (14) inclus dans une trame d'image de paysage (12) d'une image animée présentant une largeur horizontale qui est plus grande dans une direction horizontale qu'une largeur verticale dans une direction verticale, en utilisant un dispositif de décodage (201), le procédé comprenant l'étape ci-dessous consistant à :
<claim-text>stocker des informations de macroblocs (14) déjà décodés et entourant un macrobloc (14) à décoder, dans une mémoire de stockage d'informations (204) intégrée dans le dispositif de décodage (201), dans lequel la mémoire de stockage d'informations (204) et le dispositif de décodage (201) sont intégrés dans une même puce semi-conductrice ;</claim-text>
<claim-text><b>caractérisé en ce que</b> le procédé comprend en outre les étapes ci-dessous consistant à :
<claim-text>premièrement, décoder séquentiellement un réseau d'une pluralité de macroblocs alignés verticalement (14) à une extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), pour stocker, dans la mémoire de stockage d'informations (204), des informations décodées du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche ; et</claim-text>
<claim-text>subséquemment, décoder un réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), après avoir décodé le réseau de la pluralité de macroblocs alignés verticalement (14) ;</claim-text>
<claim-text>dans lequel l'étape de décodage séquentiel du réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche implique l'utilisation des informations décodées du réseau de la pluralité de macroblocs alignés verticalement (14) à<!-- EPO <DP n="94"> --> l'extrémité gauche, les informations décodées étant stockées dans la mémoire de stockage d'informations (204).</claim-text></claim-text></claim-text></claim>
<claim id="c-fr-01-0007" num="0007">
<claim-text>Procédé de décodage d'images animées selon la revendication 6, dans lequel le dispositif de décodage (201) juge si le macrobloc décodé (14) correspond ou non à l'un parmi des dernier et premier macroblocs (14) situés à des extrémités inférieure et supérieure de la largeur verticale, après avoir décodé chaque macrobloc (14) dans le réseau de la pluralité de macroblocs alignés verticalement (14).</claim-text></claim>
<claim id="c-fr-01-0008" num="0008">
<claim-text>Procédé de décodage d'images animées selon la revendication 7, dans lequel le dispositif de décodage (201) juge si le réseau décodé de macroblocs (14) correspond ou non à un dernier réseau de macroblocs (14) situé à une extrémité droite de la largeur horizontale, après avoir décodé le réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12) .</claim-text></claim>
<claim id="c-fr-01-0009" num="0009">
<claim-text>Procédé de décodage d'images animées selon la revendication 8, dans lequel, dans le cas où le dispositif de décodage (201) juge que le macrobloc décodé (14) ne correspond à aucun des dernier et premier macroblocs (14) situés aux extrémités inférieure et supérieure de la largeur verticale, une valeur de comptage d'un compteur de direction verticale montrant une position d'un macrobloc (14) à décoder successivement dans la direction verticale de l'extrémité gauche est incrémentée de « 1 ».</claim-text></claim>
<claim id="c-fr-01-0010" num="0010">
<claim-text>Procédé de décodage d'images animées selon la revendication 9, dans lequel, dans le cas où le dispositif de décodage (201) juge que le réseau décodé de macroblocs (14) ne correspond pas au dernier réseau de macroblocs (14) situé à l'extrémité droite de la largeur horizontale, une valeur de comptage d'un compteur de direction horizontale<!-- EPO <DP n="95"> --> montrant une position d'un réseau de macrobloc (14) à décoder successivement dans la direction horizontale de la largeur horizontale de la trame d'image de paysage (12) est incrémentée de « 1 ».</claim-text></claim>
<claim id="c-fr-01-0011" num="0011">
<claim-text>Dispositif de décodage d'images animées (201) destiné à décoder des macroblocs (14) inclus dans une trame d'image de paysage (12) d'une image animée présentant une largeur horizontale qui est plus grande dans une direction horizontale qu'une largeur verticale dans une direction verticale, le dispositif comprenant :
<claim-text>un module de décodage (203) ; et</claim-text>
<claim-text>une mémoire de stockage d'informations (204) ;</claim-text>
<claim-text>dans lequel le module de décodage (203) et la mémoire de stockage d'informations (204) sont intégrés dans une même puce semi-conductrice ;</claim-text>
<claim-text>dans lequel une pluralité de macroblocs (14) est décodée, en utilisant le module de décodage (203), en mettant en œuvre les étapes ci-dessous consistant à :
<claim-text>stocker des informations de macroblocs (14) déjà décodés et entourant un macrobloc (14) à décoder, dans la mémoire de stockage d'informations (204) ;</claim-text>
<claim-text><b>caractérisé en ce que</b> l'étape de décodage de la pluralité de macroblocs (14), en utilisant le module de décodage (203), comprend en outre les étapes ci-dessous consistant à :
<claim-text>premièrement, décoder séquentiellement un réseau d'une pluralité de macroblocs alignés verticalement (14) à une extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), pour stocker, dans la mémoire de stockage d'informations (204), des informations décodées du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche ; et</claim-text>
<claim-text>subséquemment, décoder séquentiellement un réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), après avoir décodé le réseau de la pluralité de<!-- EPO <DP n="96"> --> macroblocs alignés verticalement (14) de la trame d'image de paysage (12) ;</claim-text>
<claim-text>dans lequel l'étape de décodage séquentiel du réseau adjacent de la pluralité de macroblocs alignés verticalement (14) situés horizontalement à droite de l'extrémité gauche en utilisant le module de décodage (203) implique l'utilisation des informations décodées du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche, les informations décodées étant stockées dans la mémoire de stockage d'informations (204).</claim-text></claim-text></claim-text></claim-text></claim>
<claim id="c-fr-01-0012" num="0012">
<claim-text>Dispositif de décodage d'images animées (201) selon la revendication 11, comprenant en outre :
<claim-text>une interface externe (913, 916, 918, 1313, 1316, 1318) destinée à fournir des signaux codés d'images animées, l'interface externe (913, 916, 918, 1313, 1316, 1318) étant exploitable de manière à fournir, au module de décodage (203), le réseau de macroblocs (14) inclus dans les signaux codés d'images animées et alignés verticalement à l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), et à fournir subséquemment, au module de décodage (203), un réseau adjacent de la pluralité de macroblocs alignés verticalement (14), horizontalement, à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), inclus dans les signaux codés d'images animées ;</claim-text>
<claim-text>le dispositif de décodage d'images animées (201) étant exploitable de manière à décoder le réseau de la pluralité de macroblocs alignés verticalement (14), à l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), inclus dans le signal codé d'image animée fourni à partir de l'interface externe (913, 916, 918, 1313, 1316, 1318), et, subséquemment, à décoder un réseau adjacent de la pluralité de macroblocs alignés verticalement (14), horizontalement, à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), inclus dans<!-- EPO <DP n="97"> --> les signaux codés d'images animées fournis à partir de l'interface externe (913, 916, 918, 1313, 1316, 1318) ;</claim-text>
<claim-text>le dispositif de décodage d'images animées (201) pouvant être connecté à une mémoire d'images (702, 902, 1302) dans laquelle peuvent être stockées des informations d'image d'une image animée décodée présentant une largeur horizontale qui est plus grande dans une direction horizontale qu'une largeur verticale dans une direction verticale ;</claim-text>
<claim-text>le dispositif de décodage d'images animées (201) étant exploitable de manière à stocker des informations d'image, obtenues en décodant le réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), dans une première région de mémoire de la mémoire d'images (702, 902, 1302), qui correspond à une zone d'image du réseau de la pluralité de macroblocs alignés verticalement (14) à l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), et, subséquemment, à stocker des informations d'image obtenues en décodant le réseau adjacent de la pluralité de macroblocs alignés verticalement (14), horizontalement, à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12), dans une seconde région de mémoire de la mémoire d'images (702, 902, 1302), qui correspond à une zone d'image du réseau adjacent de la pluralité de macroblocs alignés verticalement (14), horizontalement, à droite de l'extrémité gauche de la largeur horizontale de la trame d'image de paysage (12).</claim-text></claim-text></claim>
<claim id="c-fr-01-0013" num="0013">
<claim-text>Dispositif de décodage d'images animées (201) selon la revendication 12, dans lequel l'interface externe (913, 916, 918, 1313, 1316, 1318) est exploitable de manière à générer une image de différence de la pluralité de macroblocs (14), par le biais d'un module de génération d'image de différence, et à faire tourner l'image de différence de la pluralité de macroblocs (14), par le biais d'un module de rotation de 90° dans le sens inverse des aiguilles d'une<!-- EPO <DP n="98"> --> montre, et à fournir une image de rotation de la pluralité de macroblocs (14), au module de décodage (203).</claim-text></claim>
</claims>
<drawings id="draw" lang="en"><!-- EPO <DP n="99"> -->
<figure id="f0001" num="1,2"><img id="if0001" file="imgf0001.tif" wi="143" he="220" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="100"> -->
<figure id="f0002" num="3,4"><img id="if0002" file="imgf0002.tif" wi="110" he="233" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="101"> -->
<figure id="f0003" num="5,6"><img id="if0003" file="imgf0003.tif" wi="165" he="217" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="102"> -->
<figure id="f0004" num="7,8"><img id="if0004" file="imgf0004.tif" wi="90" he="208" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="103"> -->
<figure id="f0005" num="9,10,11,12"><img id="if0005" file="imgf0005.tif" wi="114" he="233" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="104"> -->
<figure id="f0006" num="13"><img id="if0006" file="imgf0006.tif" wi="165" he="212" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="105"> -->
<figure id="f0007" num="14"><img id="if0007" file="imgf0007.tif" wi="165" he="198" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="106"> -->
<figure id="f0008" num="15"><img id="if0008" file="imgf0008.tif" wi="165" he="212" img-content="drawing" img-format="tif"/></figure><!-- EPO <DP n="107"> -->
<figure id="f0009" num="16"><img id="if0009" file="imgf0009.tif" wi="152" he="123" img-content="drawing" img-format="tif"/></figure>
</drawings>
<ep-reference-list id="ref-list">
<heading id="ref-h0001"><b>REFERENCES CITED IN THE DESCRIPTION</b></heading>
<p id="ref-p0001" num=""><i>This list of references cited by the applicant is for the reader's convenience only. It does not form part of the European patent document. Even though great care has been taken in compiling the references, errors or omissions cannot be excluded and the EPO disclaims all liability in this regard.</i></p>
<heading id="ref-h0002"><b>Patent documents cited in the description</b></heading>
<p id="ref-p0002" num="">
<ul id="ref-ul0001" list-style="bullet">
<li><patcit id="ref-pcit0001" dnum="EP0633699A2"><document-id><country>EP</country><doc-number>0633699</doc-number><kind>A2</kind></document-id></patcit><crossref idref="pcit0001">[0011]</crossref></li>
</ul></p>
<heading id="ref-h0003"><b>Non-patent literature cited in the description</b></heading>
<p id="ref-p0003" num="">
<ul id="ref-ul0002" list-style="bullet">
<li><nplcit id="ref-ncit0001" npl-type="s"><article><author><name>THOMAS WIEGAND et al.</name></author><atl>Overview of the H. 264/AVC Video Coding Standard</atl><serial><sertitle>IEEE TRANSACTIONS ON CIRCUITS AND SYSTEMS FOR VIDEO TECHNOLOGY</sertitle><pubdate><sdate>20030700</sdate><edate/></pubdate></serial><location><pp><ppf>1</ppf><ppl>19</ppl></pp></location></article></nplcit><crossref idref="ncit0001">[0008]</crossref></li>
<li><nplcit id="ref-ncit0002" npl-type="s"><article><author><name>GARY J. SULLIVAN et al.</name></author><atl>Video Compression-From Concept to the H.264/AVC Standard</atl><serial><sertitle>PROCEEDING OF THE IEEE</sertitle><pubdate><sdate>20050100</sdate><edate/></pubdate><vid>93</vid><ino>1</ino></serial><location><pp><ppf>18</ppf><ppl>31</ppl></pp></location></article></nplcit><crossref idref="ncit0002">[0009]</crossref></li>
<li><nplcit id="ref-ncit0003" npl-type="s"><article><author><name>XIAOLEI CHEN et al.</name></author><atl>New Hardware Architecture Design for Intra Prediction in H.264/AVC High Profile</atl><serial><sertitle>Computer Science and Engineering, 2009. WCSE'09. Second International Workshop on</sertitle><pubdate><sdate>20090101</sdate><edate/></pubdate><isbn>978-0-7695-3881-5</isbn></serial><location><pp><ppf>362</ppf><ppl>366</ppl></pp></location></article></nplcit><crossref idref="ncit0003">[0012]</crossref></li>
</ul></p>
</ep-reference-list>
</ep-patent-document>
