[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

WO2024079982A1 - メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム - Google Patents

メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム Download PDF

Info

Publication number
WO2024079982A1
WO2024079982A1 PCT/JP2023/029762 JP2023029762W WO2024079982A1 WO 2024079982 A1 WO2024079982 A1 WO 2024079982A1 JP 2023029762 W JP2023029762 W JP 2023029762W WO 2024079982 A1 WO2024079982 A1 WO 2024079982A1
Authority
WO
WIPO (PCT)
Prior art keywords
unit
mesh
subdivision
vertex
decoding
Prior art date
Application number
PCT/JP2023/029762
Other languages
English (en)
French (fr)
Inventor
広輝 岸本
圭 河村
Original Assignee
Kddi株式会社
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Kddi株式会社 filed Critical Kddi株式会社
Publication of WO2024079982A1 publication Critical patent/WO2024079982A1/ja

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T9/00Image coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/503Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving temporal prediction
    • H04N19/51Motion estimation or motion compensation
    • H04N19/537Motion estimation other than block-based
    • H04N19/54Motion estimation other than block-based using feature points or meshes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/50Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding
    • H04N19/593Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using predictive coding involving spatial prediction techniques
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/70Methods or arrangements for coding, decoding, compressing or decompressing digital video signals characterised by syntax aspects related to video coding, e.g. related to compression standards

Definitions

  • the present invention relates to a mesh decoding device, a mesh encoding device, a mesh decoding method, and a program.
  • Non-Patent Document 1 discloses a technique for encoding meshes using Non-Patent Document 2.
  • the present invention has been made in consideration of the above-mentioned problems, and aims to provide a mesh decoding device, mesh encoding device, mesh decoding method, and program that can improve the encoding efficiency of meshes.
  • the first feature of the present invention is that it includes a displacement prediction addition unit configured to intra-predict the displacement of a subdivision vertex based on a base mesh output from a base mesh decoding unit, calculate an intra-prediction value, and add the calculated intra-prediction value to an intra-prediction residual output from an inverse quantization wavelet transform unit, thereby decoding the displacement.
  • a displacement prediction addition unit configured to intra-predict the displacement of a subdivision vertex based on a base mesh output from a base mesh decoding unit, calculate an intra-prediction value, and add the calculated intra-prediction value to an intra-prediction residual output from an inverse quantization wavelet transform unit, thereby decoding the displacement.
  • the second feature of the present invention is a mesh decoding method comprising the steps of: step A of decoding a base mesh bitstream to generate and output a base mesh; step B of performing an inverse quantized wavelet transform on a quantized intra prediction residual to generate an intra prediction residual; step C of predicting the displacement amount of a subdivision vertex based on the base mesh output in step A to calculate an intra prediction value; and step C of decoding the displacement amount by adding the intra prediction residual output in step B and the intra prediction value calculated in step C.
  • the third feature of the present invention is a program for causing a computer to function as a mesh decoding device, the mesh decoding device comprising a displacement amount prediction addition unit configured to intra-predict the displacement amount of a subdivision vertex based on a base mesh output from a base mesh decoding unit, calculate an intra-prediction value, and add the calculated intra-prediction value to a prediction residual output from an inverse quantization wavelet transform unit, thereby decoding the displacement amount.
  • the present invention provides a mesh decoding device, a mesh encoding device, a mesh decoding method, and a program that can improve mesh encoding efficiency.
  • FIG. 1 is a diagram showing an example of the configuration of a mesh processing system 1 according to an embodiment.
  • FIG. 2 is a diagram showing an example of functional blocks of a mesh decoding device 200 according to an embodiment.
  • FIG. 3A is a diagram showing an example of a base mesh and a subdivision mesh.
  • FIG. 3B is a diagram showing an example of a base mesh and a subdivision mesh.
  • FIG. 4 is a diagram showing an example of a syntax configuration of a basic mesh bit stream.
  • FIG. 5 is a diagram showing an example of a syntax configuration of the BPH.
  • FIG. 6 is a diagram showing an example of functional blocks of the basic mesh decoding unit 202 of the mesh decoding device 200 according to an embodiment.
  • FIG. 7 is a diagram showing an example of functional blocks of the intra-decoding unit 202B of the basic mesh decoding unit 202 of the mesh decoding device 200 according to an embodiment.
  • FIG. 8 is a diagram showing an example of the correspondence between the vertices of the basic mesh of a P frame and the vertices of the basic mesh of an I frame.
  • FIG. 9 is a diagram showing an example of functional blocks of an inter-decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to an embodiment.
  • FIG. 10 is a diagram illustrating an example of a method for calculating the MVP of a vertex to be decoded by the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment.
  • FIG. 11 shows a flowchart illustrating an example of the operation of the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment.
  • Figure 12 shows a flowchart showing an example of the operation of the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment, calculating the sum of distances Total_D to surrounding vertices that have already been decoded.
  • FIG. 13 is a flowchart showing an example of an operation of the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment, which calculates an MVP using a weighted average.
  • FIG. 14 is a flowchart showing an example of the operation of the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment, in selecting an MV from a set of candidate MVs as an MVP.
  • FIG. 15 is a flowchart showing an example of an operation of the motion vector prediction unit 202E3 of the inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to one embodiment, whereby a set of candidate MVs is created.
  • FIG. 16 is a diagram illustrating an example of parallelogram prediction. FIG.
  • FIG. 17 is a flowchart showing an example of an operation for restoring the MVR precision to the original bit precision from the control information adaptive_mesh_flag, adaptive_bit_flag, and precision control parameters generated by decoding the basic mesh bit stream.
  • FIG. 18 is intended to illustrate an example of encoding of an MVR.
  • FIG. 19 is a diagram showing an example of functional blocks of an inter decoding unit 202E of the basic mesh decoding unit 202 of the mesh decoding device 200 according to an embodiment.
  • FIG. 20 is a diagram showing an example of an operation for determining connection information and the order of vertices using an Edgebreaker.
  • FIG. 21 is a diagram showing an example of functional blocks of the subdivision unit 203 of the mesh decoding device 200 according to an embodiment.
  • FIG. 22 is a diagram showing an example of functional blocks of a basic mesh subdivision unit 203A of the subdivision unit 203 of the mesh decoding device 200 according to an embodiment.
  • FIG. 23 is a diagram illustrating an example of a method for dividing a basic surface by the basic surface dividing unit 203A5 of the basic mesh subdivision unit 203A of the subdivision unit 203 in the mesh decoding device 200 according to an embodiment.
  • FIG. 24 is a flowchart showing an example of the operation of the basic mesh subdivision unit 203A of the subdivision unit 203 of the mesh decoding device 200 according to an embodiment.
  • FIG. 25 is a diagram showing an example of functional blocks of the subdivision mesh adjustment unit 203B of the subdivision unit 203 of the mesh decoding device 200 according to an embodiment.
  • Figure 26 is a diagram showing an example of a case in which an edge division point on a basic surface ABC is moved by the edge division point moving unit 701 of the subdivision mesh adjustment unit 203B of the subdivision unit 203 of the mesh decoding device 200 according to one embodiment.
  • Figure 27 is a diagram showing an example of a case in which subdivision surface X within a base surface is re-subdivided by the subdivision surface division unit 702 of the subdivision mesh adjustment unit 203B of the subdivision unit 203 of the mesh decoding device 200 according to one embodiment.
  • Figure 28 is a diagram showing an example of a case in which all subdivision surfaces are re-subdivided by the subdivision surface division unit 702 of the subdivision mesh adjustment unit 203B of the subdivision unit 203 of the mesh decoding device 200 according to one embodiment.
  • FIG. 29 is a diagram showing an example of functional blocks of the displacement amount decoding unit 206 of the mesh decoding device 200 according to an embodiment.
  • FIG. 29 is a diagram showing an example of the configuration of a displacement amount bit stream.
  • FIG. 31 is a diagram showing an example of a syntax configuration of a DPS.
  • FIG. 32 is a diagram illustrating an example of a syntax configuration.
  • FIG. 33 is a diagram showing a prefix code string and a suffix code string when the maximum value is 32.
  • FIG. 34 is a diagram showing a prefix code sequence and a suffix code sequence formed by kth order exponential-Golomb coding.
  • FIG. 35 is a diagram showing a specific example of a syntax configuration.
  • FIG. 31 is a diagram showing an example of a syntax configuration of a DPS.
  • FIG. 32 is a diagram illustrating an example of a syntax configuration.
  • FIG. 33 is a diagram showing a prefix code string and a suffix code string when the maximum value
  • FIG. 36 is a diagram showing a specific example of a syntax configuration.
  • FIG. 37 is a diagram showing an example of a syntax configuration of the DPH.
  • FIG. 38 is a diagram for explaining the operation of the context selection unit 206E of the mesh decoding device 200 according to an embodiment.
  • FIG. 39 is a diagram for explaining the operation of the context selection unit 206E of the mesh decoding device 200 according to an embodiment.
  • FIG. 40 is a diagram for explaining the operation of the context selection unit 206E of the mesh decoding device 200 according to an embodiment.
  • FIG. 41 is a flowchart showing an example of the operation of the coefficient level value decoding unit 206F2.
  • FIG. 42 is a flowchart showing an example of the operation of the arithmetic decoding unit 206B, the context selecting unit 206E, the context value updating unit 206C, and the multi-value conversion unit 206F.
  • FIG. 43 is a diagram illustrating an example of a correspondence relationship between subdivision vertices between a reference frame and a current frame to be decoded when inter prediction is performed in the spatial domain.
  • FIG. 44 is a flowchart showing an example of the operation of the displacement amount prediction addition unit 206K.
  • FIG. 45 is a diagram showing an example of generating a subdivision vertex C by dividing a line segment AB using the mid-edge division method.
  • FIG. 46 is a diagram showing an example of calculating the displacement amount of the subdivision vertex C.
  • FIG. 47 is a diagram showing an example of predicting the displacement amount of subdivision vertex D using cubic interpolation.
  • FIG. 48 is a diagram showing an example in which side AB is divided to generate subdivision vertex C after side KB, side BJ, side JK, side BF, and side FA are divided by the mid-edge division method.
  • FIG. 49 is a diagram showing an example of functional blocks of the displacement amount decoding unit 206 according to the first modification.
  • FIG. 1 is a diagram showing an example of the configuration of a mesh processing system 1 according to this embodiment.
  • the mesh processing system 1 includes a mesh encoding device 100 and a mesh decoding device 200.
  • FIG. 2 is a diagram showing an example of functional blocks of a mesh decoding device 200 according to this embodiment.
  • the mesh decoding device 200 includes a demultiplexing unit 201, a basic mesh decoding unit 202, a subdivision unit 203, a mesh decoding unit 204, a patch integration unit 205, a displacement amount decoding unit 206, and an image decoding unit 207.
  • the basic mesh decoding unit 202, the subdivision unit 203, the mesh decoding unit 204, and the displacement amount decoding unit 206 are configured to perform processing in units of patches into which the mesh is divided, and the results of this processing may then be integrated by the patch integration unit 205.
  • the mesh is divided into patch 1, which is made up of base faces 1 and 2, and patch 2, which is made up of base faces 3 and 4.
  • the demultiplexing unit 201 is configured to separate the multiplexed bit stream into a basic mesh bit stream, a displacement amount bit stream, and a texture bit stream.
  • the base mesh decoding unit 202 is configured to decode the base mesh bitstream and generate and output base meshes.
  • the base mesh is composed of multiple vertices in three-dimensional space and edges connecting these multiple vertices.
  • the basic mesh is constructed by combining basic faces represented by three vertices.
  • the base mesh decoding unit 202 may be configured to decode the base mesh bitstream using, for example, Draco as shown in Non-Patent Document 2.
  • the base mesh decoding unit 202 may also be configured to generate "subdivision_method_id" (described below) as control information that controls the type of subdivision method.
  • control information decoded by the basic mesh decoding unit 202 will be explained with reference to Figures 4 and 5.
  • Figure 4 shows an example of the syntax configuration of a basic mesh bitstream.
  • the base mesh bitstream may include a base patch header (BPH), which is a collection of control information corresponding to a base mesh patch.
  • BPH base patch header
  • the base mesh bitstream may include, following the BPH, base mesh patch data that encodes the base mesh patch.
  • the basic mesh bitstream is configured so that one BPH corresponds to each patch data.
  • the configuration in FIG. 4 is merely an example, and elements other than those described above may be added as components of the basic mesh bitstream, as long as each patch data corresponds to a BPH.
  • the basic mesh bit stream may include an SPS (Sequence Parameter Set), an FH (Frame Header) which is a collection of control information corresponding to a frame, or an MH (Mesh Header) which is control information corresponding to a mesh.
  • SPS Sequence Parameter Set
  • FH Fram Header
  • MH Mesh Header
  • Figure 5 shows an example of the syntax configuration of a BPH.
  • the syntax functions are similar, different syntax names may be used in addition to the syntax mates shown in Figure 5.
  • the Description column indicates how each syntax is coded. Also, ue(v) indicates an unsigned zeroth-order exponential Golomb code, and u(n) indicates an n-bit flag.
  • the BPH includes at least a control signal (mdu_face_count_minus1) that specifies the number of base faces contained in the base mesh patch.
  • the BPH also includes at least a control signal (mdu_subdivision_method_id) that specifies the type of subdivision method for the base mesh for each base patch.
  • the BPH may also include a control signal (mdu_subdivision_num_method_id) that specifies the type of subdivision number generation method for each basic mesh patch.
  • mdu_subdivision_num_method_id 0
  • mdu_subdivision_num_method_id 1
  • mdu_subdivision_num_method_id 2
  • mdu_subdivision_num_method_id 2
  • the BPH may include a control signal (mdu_max_depth) for identifying an upper limit on the number of recursive subdivisions to be performed for each base mesh patch when recursively generating the number of subdivisions of the base surface.
  • mdu_max_depth a control signal for identifying an upper limit on the number of recursive subdivisions to be performed for each base mesh patch when recursively generating the number of subdivisions of the base surface.
  • the BPH may include a control signal (mdu_subdivision_num) that specifies the number of subdivisions per subdivision.
  • the basic mesh decoding unit 202 includes a separation unit 202A, an intra decoding unit 202B, a mesh buffer unit 202C, a connection information decoding unit 202D, and an inter decoding unit 202E.
  • the separation unit 202A is configured to classify the basic mesh bit stream into an I frame (reference frame) bit stream and a P frame bit stream.
  • the intra decoder 202B is configured to decode the vertex coordinates and connection information of the I frame from the bit stream of the I frame using, for example, Draco described in Non-Patent Document 2.
  • FIG. 7 shows an example of the functional blocks of the intra decoder 202B.
  • the intra decoding unit 202B has a separation unit 202A, an arbitrary intra decoding unit 202B1, and an alignment unit 202B2.
  • the arbitrary intra-decoding unit 202B1 is configured to decode the coordinates and connection information of the unordered vertices of the I-frame from the bit stream of the I-frame using any method including Draco described in Non-Patent Document 2.
  • the sorting unit 202B2 is configured to output vertices by sorting the unordered vertices into a predetermined order.
  • the predetermined order may be, for example, the Morton code order or the raster scan order.
  • multiple vertices with the same coordinates i.e., duplicate vertices, may be combined into a single vertex and then rearranged in a specified order.
  • the mesh buffer unit 202C is configured to store the vertex coordinates and connection information of the I frame decoded by the intra decoding unit 202B.
  • connection information decoding unit 202D is configured to convert the connection information of the I frame extracted from the mesh buffer unit 202C into connection information of the P frame.
  • the inter-decoding unit 202E is configured to decode the coordinates of the vertices of the P frame by adding the coordinates of the vertices of the I frame extracted from the mesh buffer unit 202C to the motion vectors decoded from the bit stream of the P frame.
  • the motion vector decoded by the inter decoding unit 202E is a difference vector between the coordinates of the vertices of the base mesh of the P frame and the coordinates of the vertices of the base mesh of the I frame.
  • FIG. 9 is a diagram showing an example of functional blocks of the inter decoding unit 202E.
  • the inter-decoding unit 202E has a motion vector residual decoding unit 202E1, a motion vector buffer unit 202E2, a motion vector prediction unit 202E3, a motion vector calculation unit 202E4, and an adder 202E5.
  • the motion vector residual decoding unit 202E1 is configured to generate a motion vector residual (MVR) from the P frame bitstream.
  • MVR motion vector residual
  • MVR is the motion vector residual indicating the difference between MV (Motion Vector) and MVP (Motion Vector Prediction).
  • MV is the difference vector (motion vector) between the coordinates of the corresponding vertex in the I frame and the coordinates of the vertex in the P frame.
  • MVP is the predicted value of the MV of the target vertex using MV (motion vector prediction value).
  • the motion vector buffer unit 202E2 is configured to sequentially store the MVs output by the motion vector calculation unit 202E4.
  • the motion vector prediction unit 202E3 is configured to obtain the decoded MVs from the motion vector buffer unit 202E2 for the vertices connected to the vertex to be decoded, and output the MVP of the vertex to be decoded using all or part of the obtained decoded MVs, as shown in FIG. 10.
  • the motion vector calculation unit 202E4 is configured to add the MVR generated by the motion vector residual decoding unit 202E1 and the MVP output from the motion vector prediction unit 202E3, and output the MV of the vertex to be decoded.
  • the adder 202E5 is configured to add the coordinates of the vertex corresponding to the vertex to be decoded, which is obtained from the decoded base mesh of the corresponding I frame (reference frame), to the motion vector MV output from the motion vector calculation unit 202E3, and output the coordinates of the vertex to be decoded.
  • FIG. 11 shows a flowchart illustrating an example of the operation of the motion vector prediction unit 202E3.
  • step S1001 the motion vector prediction unit 202E3 sets MVP and N to 0.
  • step S1002 the motion vector prediction unit 202E3 obtains a set of MVs of vertices around the vertex to be decoded from the motion vector buffer unit 202E2, identifies vertices for which subsequent processing has not been completed, and transitions to No. If subsequent processing has been completed for all vertices, transitions to Yes.
  • step S1003 if the MV of the vertex to be processed has not been decoded, the motion vector prediction unit 202E3 transitions to No, and if the MV of the vertex to be processed has been decoded, the motion vector prediction unit 202E3 transitions to Yes.
  • step S1004 the motion vector prediction unit 202E3 adds MV to MVP and adds 1 to N.
  • step S1005 if N is greater than 0, the motion vector prediction unit 202E3 outputs the result of dividing MVP by N, and if N is 0, it outputs 0 and ends the process.
  • the motion vector prediction unit 202E3 is configured to output the MVP to be decoded by averaging the decoded motion vectors of the vertices around the vertex to be decoded.
  • the motion vector prediction unit 202E3 may be configured to set the MVP to 0 if the set of decoded motion vectors is an empty set.
  • the motion vector calculation unit 202E4 may be configured to calculate the MV of the vertex to be decoded from the MVP output by the motion vector prediction unit 202E3 and the MVR generated by the motion vector residual decoding unit 202E1 using equation (1).
  • MV(k) MVP(k)+MVR(k) ... (1) where k is the index of the vertex.
  • MV, MVR and MVP are vectors with x, y and z components.
  • MVP is used to encode only MVR instead of MV, which is expected to improve encoding efficiency.
  • the adder 202E5 is configured to calculate the coordinates of a vertex by adding the MV of the vertex calculated by the motion vector calculation unit 202E4 to the coordinates of the vertex in the reference frame corresponding to the vertex, and to keep the connectivity information (Connectivity) in the reference frame.
  • the adder 202E5 may be configured to calculate the coordinate v' i (k) of the k-th vertex using equation (2).
  • v'i (k) v'j (k)+MV(k)... (2)
  • v'i (k) is the coordinate of the kth vertex to be decoded in the frame to be decoded
  • v'j (k) is the coordinate of the kth vertex decoded in the reference frame
  • connection information of the frame to be decoded is made the same as the connection information of the reference frame.
  • the motion vector prediction unit 202E3 calculates the MVP using decoded MVs, so the order of decoding affects the MVP.
  • the order of such decoding is the order in which the vertices of the base mesh in the reference frame are decoded.
  • the decoding method uses a fixed repeating pattern to increase the number of base faces one by one from the starting edge, the order of the vertices of the decoded base mesh is determined during the decoding process.
  • the motion vector prediction unit 202E3 may use an edgebreaker to determine the order in which vertices are decoded in the base mesh of the reference frame.
  • MVs from a reference frame are encoded instead of vertex coordinates, which is expected to improve encoding efficiency.
  • the MVP calculated in the flowchart shown in FIG. 11 is calculated as a simple average of surrounding decoded MVs, but it may be calculated as a weighted average.
  • the motion vector prediction unit 202E3 may be configured to output a predicted value of the motion vector to be decoded by taking a weighted average of the decoded motion vectors of the vertices around the vertex to be decoded with a weight according to the distance between the vertex to be decoded and the vertices in the reference frame that correspond to the vertex to be decoded and the vertices around the vertex to be decoded.
  • the motion vector prediction unit 202E3 may be configured to output a predicted value of the motion vector to be decoded by taking a weighted average of some of the decoded motion vectors of the vertices around the vertex to be decoded, with a weight according to the distance between the vertex to be decoded and the vertices in the reference frame corresponding to the vertex to be decoded and the vertices around the vertex to be decoded.
  • the motion vector prediction unit 202E3 of the inter decoding unit 202E is configured to calculate the MVP in the following procedure.
  • the motion vector prediction unit 202E3 is configured to calculate weights.
  • FIG. 12 shows a flowchart illustrating an example of the operation of calculating the sum of distances to surrounding decoded vertices, Total_D.
  • step S1101 the motion vector prediction unit 202E3 sets Total_D to 0.
  • Step S1102 is the same as step S1002.
  • Step S1103 is the same as step S1003.
  • step S1104 the motion vector prediction unit 202E3 adds e(k) to Total_D.
  • the motion vector prediction unit 202E3 refers to the set of vertices around the vertex to be decoded, and adds the distances of the vertices that have already been decoded.
  • the motion vector prediction unit 202E3 is configured to calculate weights using distances in a reference frame in which the correspondence between vertices is known.
  • e(k) in step S1104 of FIG. 12 is the distance between corresponding vertices in the reference frame.
  • the motion vector prediction unit 202E3 may be configured to calculate the weight w(k) using equations (3) and (4).
  • is the set of decoded vertices in the face of the mesh that contains the vertex to be decoded
  • e(p/k) is the distance between the vertex to be decoded and the vertex corresponding to vertex p/k in the reference frame
  • w(k) is the weight at vertex k.
  • the motion vector prediction unit 202E3 may be configured to set weights according to predetermined rules depending on the distance.
  • the motion vector prediction unit 202E3 may be configured to set the weight to 1 if e(k) is smaller than a threshold TH1, to set the weight to 0.5 if e(k) is smaller than a threshold TH2, and to set the weight to 0 otherwise (no weight is used).
  • the MVP can be calculated with higher accuracy by increasing the weight when the distance to the vertex to be decoded is short.
  • the motion vector prediction unit 202E3 is configured to refer to the MVP.
  • FIG. 13 shows a flowchart illustrating an example of the operation of calculating the MVP using a weighted average.
  • step S1201 the motion vector prediction unit 202E3 sets MVP and N to 0.
  • Step S1202 is the same as step S1002.
  • Step S1203 is the same as step S1003.
  • step S1204 the motion vector prediction unit 202E3 adds w(k) ⁇ MV(k) to MVP and adds 1 to N.
  • Step S1205 is the same as step S1005.
  • the motion vector prediction unit 202E3 may be configured to calculate the MVP using equation (5).
  • is the set of decoded vertices in the mesh face that contains the vertex to be decoded.
  • the motion vector prediction unit 202E3 is configured to select one MV rather than calculating an MVP using a plurality of surrounding MVs.
  • the motion vector prediction unit 202E3 may be configured to select the MV of the nearest vertex from among the decoded MVs stored in the motion vector buffer unit 202E2 as the MV of the vertex connected to the vertex to be decoded.
  • the motion vector prediction unit 202E3 may be configured to construct a candidate list consisting of MVs of vertices connected to the vertex to be decoded from among the decoded MVs stored in the motion vector buffer unit 202E2, and to select a motion vector from the candidate list based on an index decoded from the bitstream of the P frame (the frame to be decoded).
  • FIG. 14 shows a flowchart illustrating an example of the operation of selecting an MV from a set of candidate MVs as an MVP.
  • step S1301 the motion vector prediction unit 202E3 decodes the list ID from the bit stream of the P frame.
  • step S1302 the motion vector prediction unit 202E3 selects an MV to which a list ID is to be assigned as an MVP from among the candidate MVs.
  • the surrounding MVs that have already been decoded and the MVs calculated by combining them are arranged in a certain order.
  • Figure 15 shows a flowchart illustrating an example of the operation of creating such a set of candidate MVs.
  • step S1401 the motion vector prediction unit 202E3 refers to the set of MVs of vertices around the vertex to be decoded and determines whether processing for all vertices around the vertex to be decoded has been completed.
  • step S1402 the motion vector prediction unit 202E3 determines whether the MV of the target vertex has been decoded.
  • step S1403 If the MV has been decoded, the operation proceeds to step S1403; if the MV has not been decoded, the operation returns to step S1401.
  • step S1403 the motion vector prediction unit 202E3 determines whether the MV overlaps with other decoded MVs.
  • step S1401 If there is an overlap, the operation returns to step S1401; if there is no overlap, the operation proceeds to step S1404.
  • step S1404 the motion vector prediction unit 202E3 determines the list ID to assign to the MV, and in step S1405, includes it in the set of candidate MVs.
  • the motion vector prediction unit 202E3 may increment the list ID by one in sequence, or may determine the list ID in the order of the distance between the vertex to be decoded and the vertex corresponding to vertex k in the reference frame (e(k) in formula (3)).
  • selecting one of the candidate MVs as the MVP may in some cases be closer to the MV than the average, which is expected to have the effect of improving coding efficiency.
  • the motion vector prediction unit 202E3 may be configured to add, from among the above-mentioned candidate MVs, an MV obtained by averaging consecutive MV0 and MV1 to the list as a new candidate MV.
  • the motion vector prediction unit 202E3 adds such an MV after MV0 and MV1, as shown in Table 1.
  • This configuration is expected to have the effect of increasing the probability that the selected candidate MV is closer to the MV of the vertex to be decoded.
  • the motion vector prediction unit 202E3 may be configured to select the MV of the nearest vertex from the set of candidate MVs without encoding the list ID. This configuration is expected to have the effect of further improving encoding efficiency.
  • the motion vector prediction unit 202E3 is configured to calculate the MVP by parallelogram prediction, i.e., by using vertices that are not directly connected to the vertex to be decoded.
  • parallelogram prediction also uses vertex D on the opposite side of the decoded face that has a shared edge BC with vertex A to be decoded.
  • the shared edges of the vertex A to be decoded are CE and BG. Therefore, in parallelogram prediction, vertices F and H can also be used in a similar manner.
  • the motion vector prediction unit 202E3 may be configured to calculate the MVP using the plane BCD shown in FIG. 16 and equation (6).
  • MVP MV(B) + MV(C) - MV(D) ... (6)
  • MV(X) is the motion vector of vertex X
  • MVP is the motion vector prediction value of vertex A to be decoded.
  • the motion vector prediction unit 202E3 may average the MVPs of each edge, or may select the face whose center of gravity is closest to the face. (Modification 4 of the inter decoding unit 202E) In this modification, the MVR generated by the motion vector residual decoding unit 202E1 is not directly converted, but the quantization width when the MVR is expressed as an integer is controlled.
  • the motion vector residual decoding unit 202E1 is configured to decode adaptive_mesh_flag, adaptive_bit_flag, and a precision control parameter as control information that controls the quantization width of the MVR.
  • the motion vector residual decoding unit 202E1 is configured to decode the adaptive_mesh_flag for the entire base mesh and the adaptive_bit_flag for each base patch.
  • adaptive_mesh_flag and adaptive_bit_flag are flags that indicate whether or not to adjust the quantization width of the MVR described above, and take the value of either 0 or 1.
  • the motion vector residual decoding unit 202E1 decodes adaptive_bit_flag only if adaptive_mesh_flag is enabled (i.e., 1).
  • adaptive_mesh_flag i.e., 0
  • the motion vector residual decoding unit 202E1 considers adaptive_bit_flag to be disabled (i.e., 0).
  • FIG. 17 shows a flowchart illustrating an example of an operation for controlling the quantization width of the decoded MVR from the control information adaptive_mesh_flag, adaptive_bit_flag, and precision control parameters generated by decoding the basic mesh bit stream.
  • step S1601 the motion vector prediction unit 202E3 determines whether adaptive_mesh_flag is 0.
  • adaptive_mesh_flag is 0 for the entire mesh
  • step S1602 the motion vector prediction unit 202E3 determines whether or not there are any unprocessed patches in the frame.
  • step S1603 the motion vector prediction unit 202E3 determines whether the adaptive_mesh_flag decoded for each patch is 0.
  • adaptive_mesh_flag 1
  • step S1604 the motion vector prediction unit 202E3 controls the quantization width of the MVR based on the accuracy control parameters described below.
  • MVRQ Motion Vector Residual Quantization
  • the motion vector prediction unit 202E3 may be configured to refer to a table such as Table 2, for example, and use the quantization width of the MVR corresponding to the quantization width control parameter generated by decoding the basic mesh bitstream.
  • the coding efficiency can be improved by controlling the MVR quantization width. Furthermore, it is expected that the hierarchical mechanism of the mesh level adaptive_mesh_flag and the patch level adaptive_mesh_flag can minimize the wasted bits when the MVR quantization width is not controlled.
  • the MVR can take values of 1, 2, 4, and 8 in six directions, the x-axis, y-axis, and z-axis.
  • An example of such encoding is shown in Tables 3 and 4.
  • MVR encoding may be performed using a combination of multiple directions. For example, correction may be performed in the order of 2 in the positive direction of the x-axis and 1 in the positive direction of the y-axis.
  • inter-decoding unit 202E Further modification examples of the inter-decoding unit 202E will be explained below.
  • inter-decoding unit 202E In a further modification of the inter-decoding unit 202E described above, the following functional blocks are added before implementing the inter-decoding unit 202E described above.
  • the inter-decoding unit 202E includes, in addition to the configuration shown in FIG. 9, an overlapping vertex search unit 202E6, an overlapping vertex determination unit 202E7, a motion vector acquisition unit 202E8, an all skip mode single determination unit 202E9, and a skip mode single determination unit 202E10.
  • the All skip mode single discrimination unit 202E9 is configured to discriminate whether the All skip mode single indicates Yes or No
  • the Skip mode single discrimination unit 202E10 is configured to discriminate whether the Skip mode single indicates Yes or No.
  • the All Skip Mode signal is at the beginning of the P frame bitstream, has at least two values, and is one bit or more than one bit.
  • One of them is a signal to not decode the motion vectors of all overlapped vertices of the P frame from the bitstream, but to copy the motion vectors of the overlapped vertices.
  • the other (when the All skip mode signal indicates No, for example, 0) is a signal that performs different processing at each vertex of the P frame. Furthermore, the other may have another value. For example, the other is a single signal that does not perform processing in the motion vector acquisition unit 202E8 for the motion vectors of all overlapping vertices, but performs processing similar to that of the inter decoding unit 202E shown in FIG. 9.
  • the Skip mode signal has two values for each duplicate vertex, and is 1 bit if the All skip mode signal indicates No.
  • the Skip mode signal is a signal that, if the All skip mode signal indicates Yes (e.g., 1), does not decode the motion vector of the vertex from the bitstream and copies the motion vectors of the duplicated vertices.
  • the Skip mode signal is a single signal that does not perform processing in the motion vector acquisition unit 202E8 for the motion vector of the vertex, and performs processing similar to that of the inter decoding unit 202E shown in FIG. 9.
  • the above-mentioned Skip mode signal may be decoded directly from the bit stream, or data identifying the overlapping vertices (e.g., the index of the overlapping vertex) that performs processing similar to that of the inter-decoding unit 202E shown in FIG. 9 may be decoded from the bit stream, and the Skip mode signal may be calculated from such data.
  • the motion vector decoding method for the vertex may be determined in the same manner as described above by using data identifying the overlapping vertex (e.g., the index of the overlapping vertex) that performs processing similar to that of the inter decoding unit 202E shown in FIG. 9.
  • the overlapping vertex search unit 202E6 is configured to search for the indexes of vertices with matching coordinates (hereinafter referred to as overlapping vertices) from the geometric information of the base mesh of the decoded reference frame, and store them in a buffer (not shown).
  • the input to the overlapping vertex search unit 202E6 is the index (in decoding order) and position coordinates of each vertex of the base mesh of the decoded reference frame.
  • the output of the duplicate vertex search unit 202E6 is a list of pairs of the index (vindex0) of a vertex where a duplicate vertex exists and the index (vindex1) of such duplicate vertex.
  • the list of such pairs is stored in the buffer repVert in the order of index0.
  • a special signal is used to decode the index of the duplicate vertex, rather than the position coordinate, for the vertex where the duplicate vertex exists. This special signal makes it possible to store pairs of the index of the vertex in question and the index of the duplicate vertex in the decoding order.
  • the duplicate vertex determination unit 202E7 is configured to determine whether or not there is a duplicate vertex among the vertices decoded by the corresponding vertex.
  • the duplicate vertex determination unit 202E7 determines that there is a duplicate vertex among the decoded vertices if the index of the relevant vertex is among the indexes of vertices in which a duplicate vertex exists. Note that since the relevant vertex comes in the decoding order, the above-mentioned search is not necessary.
  • the overlapping vertex determination unit 202E7 determines that there is no overlapping vertex for the corresponding vertex, the same processing as that of the inter-decoding unit 202E shown in FIG. 9 is performed.
  • the motion vector acquisition unit 202E8 is configured to acquire the motion vector of a vertex having the same index as the overlapping vertex from the motion vector buffer unit 202E2 that stores the decoded motion vectors when there is an overlapping vertex of the corresponding vertex, when the All skip mode signal indicates Yes, or when the All skip mode signal indicates No and the Skip mode signal of the corresponding vertex indicates Yes, and to set it as the motion vector of the corresponding vertex.
  • This configuration is expected to reduce the amount of code and the motion vector decoding calculations for vertices that have overlapping vertices.
  • the inter-decoding unit 202E obtains the correspondence between the vertices of the reference frame and the vertices of the frame to be decoded from the decoded base mesh of the reference frame.
  • the inter-decoding unit 202E is configured to make the vertex connection information of the frame to be decoded the same as the decoded vertex connection information of the reference frame without encoding it.
  • the inter-decoding unit 202E also divides the base mesh of the frame to be decoded into two types of regions based on the signal in the decoding order of the vertices of the reference frame. The first region is decoded using inter processing, and the second region is decoded using intra processing.
  • the above-mentioned area is defined as an area formed by multiple consecutive vertices in the decoding order when decoding the base mesh of the reference frame.
  • vertex_idx1 and vertex_idx2 are indices (vertex indices) in the decoding order of the vertices
  • intra_flag is a flag indicating whether the above-mentioned inter-decoding method or the intra-decoding method is used. There may be multiple such signals.
  • vertex_idx1 and vertex_idx2 are vertex indices that define the start and end positions of the above-mentioned partial regions (first region and second region).
  • the Edgebreaker decodes the connection information of the basic mesh of the reference frame, and the decoded order of the vertex coordinates is the order determined by the Edgebreaker.
  • Figure 20 shows an example of an operation for determining connection information and the order of vertices using Edgebreaker.
  • the arrows indicate the decoding order of the connection information
  • the numbers indicate the decoding order of the vertices
  • arrows of the same line type define the same area.
  • the signal is only intra_flag, which is a flag indicating whether the decoding method is inter or intra.
  • the inter-decoding unit 202E is configured to divide into a first region and a second region using an edgebreaker.
  • the subdivision unit 203 is configured to generate and output added subdivision vertices and their connection information from the basic mesh decoded by the basic mesh decoding unit 202 using a subdivision method indicated by the control information.
  • the base mesh the added subdivision vertices, and their connection information are collectively referred to as the "subdivision mesh.”
  • the subdivision unit 202 is configured to identify the type of subdivision method from the subdivision_method_id, which is control information generated by decoding the basic mesh bitstream.
  • the subdivision unit 202 will be described below with reference to Figures 3A and 3B.
  • Figures 3A and 3B are diagrams for explaining an example of the operation of generating subdivision vertices from a base mesh.
  • Figure 3A shows an example of a base mesh consisting of five vertices.
  • the subdivision may be performed, for example, using the mid-edge division method, which connects the midpoints of each edge of each basic face. This results in a basic face being divided into four faces.
  • Figure 3B shows an example of a subdivision mesh that is generated by dividing a base mesh consisting of five vertices.
  • eight subdivision vertices (white circles) have been generated in addition to the original five vertices (black circles).
  • a different subdivision method may be applied to each patch. This allows the displacement amount decoded by the displacement amount decoding unit 206 to be adaptively changed for each patch, which is expected to improve coding performance.
  • Information on the divided patch is received as patch_id, which is control information.
  • FIG. 22 is a diagram showing an example of the functional blocks of the subdivision unit 203.
  • the subdivision unit 203 has a basic mesh subdivision unit 203A and a subdivision mesh adjustment unit 203B.
  • the basic mesh subdivision unit 203A is configured to calculate the number of divisions (number of subdivisions) for each basic surface and basic patch based on the input basic mesh and division information of the basic mesh, subdivide the basic mesh based on the number of divisions, and output the subdivision surface.
  • the basic mesh subdivision unit 203A may be configured to be able to change the above-mentioned number of divisions on a basic surface and basic patch basis.
  • a base face is a face that makes up a base mesh
  • a base patch is a collection of several base faces.
  • the base mesh subdivision unit 203A may also be configured to predict the number of fine subdivisions of the base surface and calculate the number of subdivisions of the base surface by adding the predicted subdivision number residual to the predicted number of subdivisions of the base surface.
  • the base mesh subdivision unit 203A may also be configured to calculate the number of subdivisions of a base surface based on the number of subdivisions of adjacent base surfaces of the base surface.
  • the base mesh subdivision unit 203A may also be configured to calculate the number of subdivisions of a base surface based on the number of subdivisions of the base surface that was previously accumulated.
  • the basic mesh subdivision unit 203A may also be configured to generate vertices that divide the three sides that make up the basic surface, and to subdivide the basic surface by connecting the generated vertices.
  • the basic mesh subdivision unit 203A is followed by 203B, which includes a subdivision mesh adjustment unit, as described below.
  • FIG. 22 shows an example of the functional blocks of the basic mesh subdivision unit 203A
  • FIG. 24 is a flowchart showing an example of the operation of the basic mesh subdivision unit 203A.
  • the basic mesh subdivision unit 203A has a basic surface division number buffer unit 203A1, a basic surface division number reference unit 203A2, a basic surface division number prediction unit 203A3, an addition unit 203A4, and a basic surface division unit 203A5.
  • the basic surface division number buffer unit 203A1 stores division information of basic surfaces, including the division number of the basic surface, and is configured to output the division information of the basic surface to the basic surface division number reference unit 203A2.
  • the size of the basic surface division number buffer unit 203A1 may be set to 1, and the unit may be configured to output the most recently accumulated basic surface division number to the basic surface division number reference unit 203A2.
  • the size of the basic surface division number buffer unit 203A1 may be configured to refer only to the last decoded fine division number (the subdivision number decoded immediately before).
  • the basic surface division number reference unit 203A2 is configured to output a reference not possible to the basic surface division number prediction unit 203A3 if there is no adjacent basic surface to the basic surface to be decoded, or if there is an adjacent basic surface to the basic surface to be decoded but the division number has not been determined.
  • the basic face division number reference unit 203A2 is configured to output the number of divisions to the basic face division number prediction unit 203A3.
  • the basic surface division number prediction unit 203A3 is configured to predict the division number (number of subdivisions) of a basic surface based on one or more input division numbers, and output the predicted division number (predicted division number) to the addition unit 203A4.
  • the basic surface division number prediction unit 203A3 is configured to output 0 to the addition unit 203A4 if only reference impossible is input from the basic surface division number reference unit 203A2.
  • the basic surface division number prediction unit 203A3 may be configured to generate a predicted division number using any of the statistical values such as the average value, maximum value, minimum value, or mode of the input division numbers.
  • the basic face division number prediction unit 203A3 may be configured to generate the division number of the most adjacent face as the predicted division number when one or more division numbers are input.
  • the addition unit 203A4 is configured to output the division number obtained by adding the prediction division number residual decoded from the prediction residual bit stream and the prediction division number obtained from the basic surface division number prediction unit 203A3 to the basic surface division unit 203A5.
  • the basic surface division unit 203A5 is configured to subdivide the basic surface based on the division number input from the addition unit 203A4.
  • FIG. 23 shows an example of a case where a basic surface is divided into nine parts. The method of dividing a basic surface by the basic surface division unit 203A5 will be explained with reference to FIG. 23.
  • the basic surface division unit 203A5 divides sides BC and CA into N equal parts, generating points B_1, ..., B_(N-1), C_1, ..., C_(N-1), respectively.
  • This division method is hereinafter referred to as the N 2 division method.
  • step S2201 it is determined whether the subdivision process for the last base face is complete. If the process is complete, the process ends. If not, the process proceeds to step S2202.
  • step S2202 the basic mesh subdivision unit 203A determines whether Depth ⁇ mdu_max_depth.
  • Depth is a variable that represents the current depth, with an initial value of 0, and mdu_max_depth represents the maximum depth determined for each base surface.
  • step S2202 If the condition in step S2202 is met, the process proceeds to step S2203; if the condition is not met, the process returns to step S2201.
  • step S2203 the base mesh subdivision unit 203A determines whether mdu_subdivision_flag at the current depth is 1 or not.
  • step S2204 the base mesh subdivision unit 203A further subdivides all subdivision surfaces within the base surface.
  • the base mesh subdivision unit 203A subdivides the base surface.
  • the subdivision method is the same as that described in step S2204.
  • a basic face has never been subdivided, the basic face is subdivided as shown in Fig. 23. If the basic face has been subdivided at least once, the subdivision face is subdivided into N2 faces. Taking Fig. 23 as an example, a face consisting of vertices A_2, B, and B_1 is divided into N2 faces using the N2 division method in the same way as when dividing the basic face.
  • step S2205 the base mesh subdivision unit 203A adds 1 to Depth, and the process returns to step S2202.
  • the basic mesh subdivision unit 203A may perform subdivision processing so as to subdivide all basic faces by the same upper limit subdivision number mdu_max_depth.
  • the subdivision processing per time may be configured to perform subdivision using an N2 division method based on the subdivision number mdu_subdivision_num.
  • FIG. 25 shows an example of a functional block of the fine division mesh adjustment unit 203B.
  • the subdivision mesh adjustment unit 203B has an edge division point moving unit 701 and a subdivision surface division unit 702.
  • the edge division point moving unit 701 is configured to move an edge division point of a basic face to any of the edge division points of an adjacent basic face for an input initial subdivision face, and output a subdivision face.
  • FIG. 26 shows an example of moving an edge division point on base face ABC.
  • the edge division point moving unit 701 may be configured to move the edge division point of base face ABC to the edge division point of the nearest adjacent base face.
  • the subdivision surface division unit 702 is configured to re-subdivide the input subdivision surface and output a composite subdivision surface.
  • Figure 27 shows an example of a case where subdivision is performed again on subdivision surface X within a base surface.
  • the subdivision surface division unit 702 may be configured to generate new subdivision surfaces within a base surface by connecting the vertices that make up the subdivision surface to the edge division points of an adjacent base surface.
  • Figure 28 shows an example of a case where the above-mentioned subdivision process has been performed on all subdivision surfaces.
  • the mesh decoding unit 204 is configured to generate and output a decoded mesh using the subdivision mesh generated by the subdivision unit 203 and the displacement amount decoded by the displacement amount decoding unit 206.
  • the mesh decoding unit 204 is configured to generate a decoded mesh by adding the corresponding displacement amount to each subdivision vertex.
  • information regarding which subdivision vertex each displacement amount corresponds to is indicated by control information.
  • the patch integration unit 205 is configured to integrate and output the decoded mesh generated by the mesh decoding unit 206 for multiple patches.
  • the method of dividing the patch is defined by the mesh encoding device 100.
  • the method of dividing the patch may be configured to calculate a normal vector for each base face, select the base face with the most similar normal vector among the adjacent base faces, combine both base faces into the same patch, and repeat this procedure sequentially for the next base face.
  • the video decoding unit 207 is configured to decode and output the texture by video encoding.
  • the video decoding unit 207 may use HEVC in Non-Patent Document 1.
  • the displacement amount decoding unit 206 is configured to decode the displacement amount bitstream to generate and output the displacement amount.
  • the displacement amount decoding unit 206 is configured to define eight displacement amounts expressed as scalars or vectors for each subdivision vertex.
  • Fig. 29 is a diagram showing an example of functional blocks of the displacement amount decoding unit 206.
  • the displacement amount decoding unit 206 includes a control information decoding unit 206A, an arithmetic decoding unit 206B, a context value updating unit 206C, a context buffer...206D, a context selection unit 206E, a multi-value conversion unit 206F, a coefficient level value decoding unit F2, an inter prediction unit 206G, a frame buffer 206H, an adder 206I, an inverse quantization unit 206J, and a displacement amount prediction addition unit 206K.
  • FIG. 30 is a diagram showing an example of the configuration of a displacement amount bit stream.
  • the displacement bit stream may include a DPS (Displacement Parameter Set), which is a collection of control information related to the decoding of the displacement.
  • DPS Displayment Parameter Set
  • the displacement bitstream may include a DPH (Displacement Patch Header), which is a collection of control information corresponding to a patch.
  • DPH Displayment Patch Header
  • the displacement bitstream may contain, next to the DPH, the encoded displacements that make up the patch.
  • the displacement bitstream is structured so that each encoded displacement corresponds to one DPH and one DPS.
  • the displacement bit stream may include a sequence parameter set (SPS).
  • SPS sequence parameter set
  • Figure 31 shows an example of the syntax configuration of a DPS.
  • the Descriptor column indicates how each syntax is coded.
  • ue(v) means an unsigned zeroth-order exponential Golomb code
  • u(n) means an n-bit flag
  • the DPS includes at least DPS id information (dps_displacement_parameter_set_id) for identifying each DPS.
  • the DPS may also include a flag (interprediction_enabled_flag) that controls whether or not inter prediction is performed.
  • interprediction_enabled_flag when interprediction_enabled_flag is 0, it may be defined that inter prediction is not performed, and when interprediction_enabled_flag is 1, it may be defined that inter prediction is performed. When interprediction_enabled_flag is not included, it may be defined that inter prediction is not performed.
  • the DPS may also include a flag (wavelet_transform_flag) that controls whether or not to perform a wavelet transform.
  • wavelet_transform_flag when wavelet_transform_flag is 0, it may be defined that no wavelet transform is performed, and when wavelet_transform_flag is 1, it may be defined that a wavelet transform is performed. When wavelet_transform_flag is not included, it may be defined that a wavelet transform is performed.
  • the DPS may also include a flag (displacement_prediction_addition_flag) that controls whether or not to perform displacement prediction addition.
  • displacement_prediction_addition_flag when displacement_prediction_addition_flag is 0, it may be defined that no displacement prediction addition is performed, and when displacement_prediction_addition_flag is 1, it may be defined that no displacement prediction addition is performed. When displacement_prediction_addition_flag is not included, it may be defined that no displacement prediction addition is performed.
  • the DPS may include a flag (dct_enabled_flag) that controls whether or not to perform inverse DCT.
  • dct_enabled_flag when dct_enabled_flag is 0, it may be defined that inverse DCT is not performed, and when dct_enabled_flag is 1, it may be defined that inverse DCT is performed. When dct_enabled_flag is not included, it may be defined that inverse DCT is not performed.
  • the coefficient level values of the displacement are represented in each frame by a matrix of size 3xN.
  • 3 indicates the dimension in the spatial domain, and N indicates the total number of subdivision vertices.
  • This matrix is divided into blocks and encoded on a block-by-block basis.
  • FIG. 32 shows an example of a syntax configuration. There are syntaxes that are defined in matrix units and syntaxes that are defined in block units.
  • lastt_sig_coeff_prefix represents the prefix of the coordinate position of the first nonzero coefficient in scan order.
  • lastt_sig_coeff_suffix represents the suffix of the coordinate position of the first nonzero coefficient in scan order.
  • the prefix is represented by truncated Rice binarization
  • the suffix is represented with a fixed length.
  • Figure 33 shows the prefix code sequence and the suffix code sequence when the maximum value is 32.
  • the coded_block_flag is a flag that indicates that the block contains a nonzero coefficient. Only one such flag is defined for each block.
  • last_sig_coeff_block_prefix represents the prefix of the coordinate position of the first nonzero coefficient in scan order within the block.
  • last_sig_coeff_block_suffix represents the suffix of the coordinate position of the first nonzero coefficient in scan order within the block.
  • sig_coeff_flag is a flag indicating whether it is a nonzero coefficient.
  • coeff_abs_level_greater1_flag is a flag indicating whether the absolute value of the coefficient (non-zero coefficient) is 2 or greater.
  • the total number of coefficients represented by this flag may be limited to an upper limit, such as 8.
  • coeff_abs_level_greater2_flag is a flag that indicates whether the absolute value of the first coefficient (non-zero coefficient) in the scan order whose absolute value is 2 or greater is 3 or greater.
  • coeff_sign_flag is a flag that indicates the positive or negative sign of the coefficient.
  • coeff_abs_level_remaining represents the absolute value of the coefficient minus the value represented by the flag above.
  • coeff_abs_level_remaining is represented, for example, by the kth order exponential Golomb code.
  • FIG. 34 shows a prefix code sequence and a suffix code sequence using kth order exponential Golomb coding.
  • FIGS. 35 and 36 show specific examples of syntax configurations. As shown in FIG. 35, coefficient level values are decoded from each syntax, and then, as shown in FIG. 36, the decoded coefficient level values are rearranged.
  • Figure 37 shows an example of the syntax configuration of DPH.
  • the DPH includes at least DPS id information for specifying the DPS corresponding to each DPH.
  • the control information decoding unit 206A is configured to output control information by performing variable length decoding on the received displacement amount bit stream.
  • the arithmetic decoding unit 206B is configured to perform arithmetic decoding on the received displacement bit stream to output binarized coefficient level values, as will be described in detail later.
  • the arithmetic decoding unit 206B deals with binary values.
  • the arithmetic decoding unit 206B defines a number line from 0 to 1, and divides this interval for use. The interval is divided according to the probability of occurrence of the binary values (hereafter referred to as the context value).
  • the arithmetic decoding unit 206B receives a binary decimal and decodes the original value depending on which section on the number line the binary decimal falls within.
  • the context value may be always fixed, or may be changed for each bit of the input signal. If the context value is changed for each bit, the arithmetic decoding unit 206B receives the context value from the context selection unit 206E.
  • the context value update unit 206C is configured to update the context value using the binarized coefficient level value and output it to the frame buffer 206D.
  • the context value update unit 206C updates the context value each time one bit is decoded.
  • the context value update unit 206C sets the symbol with the highest probability of occurrence, between 0 and 1, as the Most Probable Symbol (MPS), and the symbol with the lowest probability of occurrence as the Least Probable Symbol (LPS).
  • MPS Most Probable Symbol
  • LPS Least Probable Symbol
  • the context value update unit 206C may use a probability update table that updates the probability value slightly when an MPS occurs and updates the probability value significantly when an LPS occurs.
  • Context selection unit 206E The context selection unit 206E is configured to generate and output a context value (output context value) using the context value, bit position, and syntax read from the context buffer 206D. Details will be described later.
  • the context selection unit 206E may create a context number table according to the matrix size and bit position, as shown in FIG. 38.
  • the context selection unit 206E may create a context number table according to the block size and bit position, as shown in FIG. 38.
  • the context selection unit 206E sets the context number to a value obtained by correcting a certain reference value based on the position of the coefficient or the coded_block_flag of the decoded right adjacent block. For example, the context selection unit 206E sets the reference value to 0 for the leftmost block and 3 for the other blocks.
  • the context selection unit 206E may set the context number to 0 if the decoded right adjacent block has a coefficient whose absolute value (level value) is 2 or more, and may set the context number to 1 if not.
  • the context buffer 206D is configured to output these in response to control information (not shown).
  • the multi-value conversion unit 206F is configured to generate and output coefficient level values by multi-value converting the binarized coefficient level values.
  • the generated (calculated) coefficient level values are also output to the context buffer 206D as bit positions and syntax.
  • the inter prediction unit G is configured to generate and output a predicted displacement amount using a reference frame read from the frame buffer 206D.
  • the frame buffer H is configured to acquire and store the decoded displacement amount.
  • the frame buffer H is configured to output the decoded displacement amount at the corresponding vertex in the reference frame in accordance with control information (not shown).
  • step S101 the coefficient level value decoding unit 206F2 decodes all coefficients after the position indicated by last_sig_coeff_prefix and last_sig_coeff_suffix as 0. Subsequent processing is performed on a block-by-block basis.
  • step S102 the coefficient level value decoding unit 206F2 performs decoding on coded_block_flag.
  • step S103 the coefficient level value decoding unit 206F2 determines whether coded_block_flag is 0 or 1.
  • step S104 the coefficient level value decoding unit 206F2 decodes all coefficients in the currently processed block after the position indicated by last_sig_coeff_block_prefix and last_sig_coeff_block_suffix as 0.
  • step S105 the coefficient level value decoding unit 206F2 performs decoding on sig_coeff_flag.
  • step S106 the coefficient level value decoding unit 206F2 determines whether sig_coeff_flag is 0 or 1.
  • step S107 the coefficient level value decoding unit 206F2 performs decoding for coeff_abs_level_greater1_flag.
  • step S108 the coefficient level value decoding unit 206F2 determines whether coeff_abs_level_greater1_flag is 0 or 1.
  • step S109 the coefficient level value decoding unit 206F2 performs decoding for coeff_abs_level_greater2_flag.
  • step S110 the coefficient level value decoding unit 206F2 determines whether coeff_abs_level_greater2_flag is 0 or 1.
  • step S112 the coefficient level value decoding unit 206F2 performs decoding on coeff_abs_level_remaining.
  • the coefficient level value decoding unit 206F2 performs exponential Golomb decoding and then adds 3 to it, which becomes the decoded coefficient level value.
  • step S113 the coefficient level value decoding unit 206F2 performs decoding on coeff_sign_flag.
  • step S114 the coefficient level value decoding unit 206F2 determines whether coeff_sign_flag is 0 or 1.
  • step S115 the coefficient level value decoding unit 206F2 converts the decoded coefficients into negative values.
  • step S116 the coefficient level value decoding unit 206F2 determines whether the block currently being processed is the final block.
  • step S111 If the answer is Yes, the operation ends; if the answer is No, the operation proceeds to step S111.
  • step S111 the coefficient level value decoding unit 206F2 proceeds to process the next block, and the operation returns to step S102.
  • the arithmetic decoding unit 206B is initialized in step S201, and sets an initial context value in step S202.
  • the arithmetic decoding unit 206B selects a context in step S203, and performs arithmetic decoding in step S204.
  • step S205 the context value update unit 206C and the context selection unit 206E update the context values, and in step S206, the multi-value conversion unit 206F performs multi-value conversion.
  • step S207 the multi-value conversion unit 206F determines whether all decoding is complete. If Yes, the operation proceeds to step S208; if No, the operation returns to step S203.
  • step S208 the multi-value conversion unit 206F saves the context values.
  • the inter prediction unit 206G is configured to perform inter prediction using the decoded displacement amount of the reference frame read from the frame buffer 206H, thereby generating and outputting an inter prediction residual and an inter prediction displacement amount.
  • the inter prediction unit 206G is configured to perform such inter prediction only when interprediction_enabled_flag is 1.
  • the inter prediction unit 206G may perform inter prediction in the spatial domain, or may perform inter prediction in the frequency domain. Inter prediction may be bidirectional prediction using a past reference frame and a future reference frame in time.
  • the inter prediction unit 206G may determine the predicted displacement amount of a subdivision vertex in the target frame by directly referring to the decoded displacement amount of the corresponding subdivision vertex in the reference frame.
  • the predicted displacement of a certain subdivision vertex in the target frame may be determined probabilistically according to a normal distribution with estimated mean and variance, using the decoded displacements of corresponding subdivision vertices in multiple reference frames.
  • the variance may be set to zero and the predicted displacement may be determined uniquely using only the mean.
  • the predicted displacement of a subdivision vertex in the target frame may be determined based on a regression curve estimated using the decoded displacements of corresponding subdivision vertices in multiple reference frames, with time as the explanatory variable and displacement as the objective variable.
  • the order of the decoded displacement amounts may be rearranged to improve coding efficiency for each frame.
  • the inter prediction unit 206G may be configured to perform inter prediction on the rearranged decoding displacement amounts.
  • the correspondence between the subdivision vertices between the reference frame and the frame to be decoded is indicated by the control information.
  • FIG. 43 is a diagram illustrating an example of the correspondence between subdivision vertices between a reference frame and a frame to be decoded when inter prediction is performed in the spatial domain.
  • the adder 206I is configured to obtain the inter prediction residual and the inter prediction displacement amount from the inter prediction unit 206G.
  • the adder 206I is configured to add these to generate and output the quantized intra prediction residual.
  • the generated (calculated) quantized intra prediction residual is also output to the frame buffer 206H.
  • the inverse quantization unit 206J is configured to perform inverse quantization on the quantized intra prediction residual obtained from the addition unit 206I and output the intra prediction residual.
  • the displacement amount prediction addition unit 206K is configured to intra-predict the displacement amount of the subdivision vertices based on the basic mesh output from the basic mesh decoding unit 202 to calculate an intra-prediction value, and to decode the displacement amount by adding the calculated intra-prediction value to the intra-prediction residual output from the inverse quantization unit 206J.
  • FIG. 44 is a flowchart showing an example of the operation of the displacement prediction addition unit 206K.
  • step S1 the displacement prediction addition unit 206K sets the current number of subdivisions it to 1.
  • step S2 the displacement prediction addition unit 206K determines whether the current number of subdivisions it is less than the upper limit number of subdivisions mdu_max_depth.
  • step S3 If the answer is Yes, the operation proceeds to step S3; if the answer is No, the operation ends.
  • step S3 the displacement prediction addition unit 206K determines whether division has been completed for all edges.
  • step S8 If the answer is Yes, the operation proceeds to step S8; if the answer is No, the operation proceeds to step S4.
  • step S4 the displacement prediction addition unit 206K selects an undivided edge and proceeds to step S5.
  • step S5 the displacement prediction addition unit 206K divides the selected edge based on the subdivision number mdu_subdivision_num and generates subdivision vertices.
  • step S6 the displacement prediction addition unit 206K predicts the displacement of the subdivision vertex from the displacement of the vertices at both ends, and proceeds to step S7.
  • Figures 45 and 46 are schematic diagrams showing an example of dividing a line segment AB using the mid-edge division method to generate a subdivision vertex C, and an example of calculating the displacement of the subdivision vertex C, respectively.
  • the normal vectors of end points A and B are (a x , a y ) and (b x , by ), respectively, and the normal vector of vertex P is calculated by linear interpolation.
  • the normal vector of vertex P can be calculated as ((1-t)a x +tb x , (1-t)a y + tby ).
  • the normal vector may be calculated using other interpolation methods such as spherical linear interpolation.
  • the normal vectors of endpoints A and B are calculated as the average of the normals of the base faces adjacent to each vertex. If subdivision is not performed, there is no need to calculate the normal vectors of the base faces.
  • the slope perpendicular to the calculated normal vector is calculated, and the displacement of subdivision vertex C is predicted by integrating it over the section from end point A to subdivision vertex C.
  • the displacement when predicting the displacement of subdivision vertex C can be calculated using the following formula.
  • the displacement amount of the subdivision vertex C may be predicted using a known interpolation method such as cosine interpolation, cubic interpolation, or Hermite interpolation, using the vertices of the surrounding base mesh or the decoded subdivision vertices as input.
  • a known interpolation method such as cosine interpolation, cubic interpolation, or Hermite interpolation, using the vertices of the surrounding base mesh or the decoded subdivision vertices as input.
  • Figure 47 shows an example of predicting the displacement of subdivision vertex D using cubic interpolation.
  • a cubic curve can be calculated from four vertices around subdivision vertex D, and the displacement of subdivision vertex D can be predicted as a vector connecting a point on the curve and subdivision vertex D.
  • the displacement of the subdivision vertices may be predicted using statistical values such as the average, mode, maximum, and minimum values of the displacement of vertices on the base surface or subdivision vertices that have already been decoded.
  • Figure 48 shows an example in which sides KB, BJ, JK, BF, and FA are each divided using the mid-edge division method, and then side AB is divided to generate subdivision vertex C.
  • the displacement at the point with the smallest distance may be used as the predicted value
  • the average of the displacements of the surrounding vertices such as subdivision vertices A, B, D, E, G, and I may be used as the predicted value of the displacement
  • the weighted average of the displacements of the surrounding vertices may be used as the predicted value of the displacement.
  • step S7 the displacement prediction addition unit 206K adds the predicted value and the displacement error to decode the displacement. Then, the process proceeds to step S3.
  • step S8 the displacement prediction addition unit 206K adds 1 to the current number of subdivisions it and proceeds to step S2.
  • FIG. 49 shows an example of a functional block of the displacement amount decoding unit 206 in this modification example 1.
  • the displacement amount decoding unit 206 includes an inverse quantization wavelet transform unit 206L instead of an inverse quantization unit 206J.
  • the inverse quantization wavelet transform unit 206L is configured to perform an inverse quantization wavelet transform on the quantized intra prediction residual output from the adder 206I to generate an intra prediction residual.
  • the above-mentioned mesh encoding device 100 and mesh decoding device 200 may be realized as a program that causes a computer to execute each function (each process).

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Abstract

本発明に係るメッシュ復号装置200は、基本メッシュ復号部202から出力された基本メッシュに基づいて細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出したイントラ予測値と逆量子化ウェーブレット変換部206Lから出力されたイントラ予測残差とを加算することで、変位量を復号するように構成されている変位量予測加算部206Kを備える。

Description

メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
 本発明は、メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラムに関する。
 非特許文献1には、非特許文献2を用いてメッシュを符号化する技術が開示されている。
Cfp for Dynamic Mesh Coding、ISO/IEC JTC1/SC29/WG7 N00231、MPEG136 - Online Google Draco、2022年5月26日アクセス[Online]、https://google.github.io/draco
 しかしながら、従来技術では、動的メッシュを構成する全ての頂点の座標や接続情報を可逆符号化するため、損失が許容される条件下であっても情報量を削減できず、符号化効率が低いという問題点があった。 そこで、本発明は、上述の課題に鑑みてなされたものであり、メッシュの符号化効率を向上させることができるメッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラムを提供することを目的とする。
 本発明の第1の特徴は、基本メッシュ復号部から出力された基本メッシュに基づいて細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出した前記イントラ予測値と逆量子化ウェーブレット変換部から出力されたイントラ予測残差とを加算することで、変位量を復号するように構成されている変位量予測加算部を備えることを要旨とする。
 本発明の第2の特徴は、メッシュ復号方法であって、基本メッシュビットストリームを復号し、基本メッシュを生成して出力する工程Aと、量子化イントラ予測残差に対して逆量子化ウェーブレット変換を行い、イントラ予測残差を生成する工程Bと、前記工程Aにおいて出力された前記基本メッシュに基づいて細分割頂点の変位量を予測してイントラ予測値を算出する工程Cと、前記工程Bにおいて出力されたイントラ予測残差と前記工程Cにおいて算出された前記イントラ予測値とを加算することで、変位量を復号する工程とを有することを要旨とする。
 本発明の第3の特徴は、コンピュータを、メッシュ復号装置として機能させるプログラムであって、前記メッシュ復号装置は、基本メッシュ復号部から出力された基本メッシュに基づいて細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出した前記イントラ予測値と逆量子化ウェーブレット変換部から出力された予測残差とを加算することで、変位量を復号するように構成されている変位量予測加算部を備えることを要旨とする。
 本発明によれば、メッシュの符号化効率を向上させることができるメッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラムを提供することができる。
図1は、一実施形態に係るメッシュ処理システム1の構成の一例を示す図である。 図2は、一実施形態に係るメッシュ復号装置200の機能ブロックの一例を示す図である。 図3Aは、基本メッシュ及び細分割メッシュの一例を示す図である。 図3Bは、基本メッシュ及び細分割メッシュの一例を示す図である。 図4は、基本メッシュビットストリームのシンタックス構成の一例を示す図である。 図5は、図5は、BPHのシンタックス構成の一例を示す図である。 図6は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202の機能ブロックの一例を示す図である。 図7は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のイントラ復号部202Bの機能ブロックの一例を示す図である。 図8は、Pフレームの基本メッシュの頂点とIフレームの基本メッシュの頂点との間の対応関係の一例を示す図である。 図9は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの機能ブロックの一例を示す図である。 図10は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3による復号対象の頂点のMVPの算出方法の一例を説明するための図である。 図11は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3の動作の一例を示すフローチャートを示す。 図12は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3が、復号済みの周りの頂点との距離の和Total_Dを算出する動作の一例を示すフローチャートを示す。 図13は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3が、重み付け平均を用いてMVPを算出する動作の一例を示すフローチャートである。 図14は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3が、MVPとして候補MVの集合からMVを選択する動作の一例を示すフローチャートである。 図15は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの動きベクトル予測部202E3が、候補MVの集合を作成する動作の一例を示すフローチャートである。 図16は、平行四辺形予測の一例について説明するための図である。 図17は、基本メッシュビットストリームを復号して生成した制御情報であるadaptive_mesh_flag、adaptive_bit_flag及び精度制御パラメータから、MVRの精度を元のビット精度に戻す動作の一例を示すフローチャートである。 図18は、MVRの符号化の一例を説明するための意図である。 図19は、一実施形態に係るメッシュ復号装置200の基本メッシュ復号部202のインター復号部202Eの機能ブロックの一例を示す図である。 図20は、Edgebreakerを用いて、接続情報及び頂点の順番を決める動作の一例を示す図である。 図21は、一実施形態に係るメッシュ復号装置200の細分割部203の機能ブロックの一例について示す図である。 図22は、一実施形態に係るメッシュ復号装置200の細分割部203の基本メッシュ細分割部203Aの機能ブロックの一例を示す図である。 図23は、一実施形態に係るメッシュ復号装置200の細分割部203の基本メッシュ細分割部203Aの基本面分割部203A5による基本面の分割方法の一例について説明するための図である。 図24は、一実施形態に係るメッシュ復号装置200の細分割部203の基本メッシュ細分割部203Aの動作の一例を示すフローチャートである。 図25は、一実施形態に係るメッシュ復号装置200の細分割部203の細分割メッシュ調整部203Bの機能ブロックの一例を示す図である。 図26は、一実施形態に係るメッシュ復号装置200の細分割部203の細分割メッシュ調整部203Bの辺分割点移動部701によって基本面ABC上の辺分割点が移動されたケースの一例を示す図である。 図27は、一実施形態に係るメッシュ復号装置200の細分割部203の細分割メッシュ調整部203Bの細分割面分割部702によって基本面内の細分割面Xに対して再度細分割が行われたケースの一例を示す図である。 図28は、一実施形態に係るメッシュ復号装置200の細分割部203の細分割メッシュ調整部203Bの細分割面分割部702によって全ての細分割面に対して再度細分割が行われたケースの一例を示す図である。 図29は、一実施形態に係るメッシュ復号装置200の変位量復号部206の機能ブロックの一例について示す図である。 図29は、変位量ビットストリームの構成の一例について示す図である。 図31は、DPSのシンタックス構成の一例について示す図である。 図32は、シンタックス構成の一例について示す図である。 図33は、最大値が32である場合のプリフィックス符号列及びサフィックス符号列を示す図である。 図34は、k次指数ゴロム符号によるプリフィックス符号列及びサフィックス符号列を示す図である。 図35は、シンタックス構成の具体例について示す図である。 図36は、シンタックス構成の具体例について示す図である。 図37は、DPHのシンタックス構成の一例について示す図である。 図38は、一実施形態に係るメッシュ復号装置200のコンテキスト選択部206Eの動作を説明するための図である。 図39は、一実施形態に係るメッシュ復号装置200のコンテキスト選択部206Eの動作を説明するための図である。 図40は、一実施形態に係るメッシュ復号装置200のコンテキスト選択部206Eの動作を説明するための図である。 図41は、係数レベル値復号部206F2の動作の一例について示すフローチャートである。 図42は、算術復号部206B、コンテキスト選択部206E、コンテキスト値更新部206C及び多値化部206Fの動作の一例について示すフローチャートである。 図43は、空間領域でインター予測が行われる場合の参照フレームと復号対象フレームとの間の細分割頂点の対応関係の一例について説明するための図である。 図44は、変位量予測加算部206Kの動作の一例を示すフローチャートである。 図45は、Mid-edge分割法によって線分ABを分割して細分割頂点C生成する例を模式的に示す図である。 図46は、細分割頂点Cの変位量を算出する例を模式的に示した図である。 図47は、キュービック補完を用いて細分割頂点Dの変位量を予測する例を示す図である。 図48は、辺KB、辺BJ、辺JK、辺BF、辺FAをそれぞれMid-edge分割法で分割した後に、辺ABを分割し細分割頂点Cを生成する例を示す図である。 図49は、変形例1に係る変位量復号部206の機能ブロックの一例を示す図である。
 以下、本発明の実施の形態について、図面を参照しながら説明する。なお、以下の実施形態における構成要素は、適宜、既存の構成要素等との置き換えが可能であり、また、他の既存の構成要素との組み合わせを含む様々なバリエーションが可能である。したがって、以下の実施形態の記載をもって、特許請求の範囲に記載された発明の内容を限定するものではない。
<第1実施形態>
 以下、図1~図48を参照して、本実施形態に係るメッシュ処理システムについて説明する。
 図1は、本実施形態に係るメッシュ処理システム1の構成の一例を示す図である。図1に示すように、メッシュ処理システム1は、メッシュ符号化装置100及びメッシュ復号装置200を備えている。
 図2は、本実施形態に係るメッシュ復号装置200の機能ブロックの一例を示す図である。
 図2に示すように、メッシュ復号装置200は、多重分離部201と、基本メッシュ復号部202と、細分割部203と、メッシュ復号部204と、パッチ統合部205と、変位量復号部206と、映像復号部207とを有する。
 ここで、基本メッシュ復号部202、細分割部203、メッシュ復号部204及び変位量復号部206は、メッシュを分割したパッチ単位で処理を行うように構成されており、その後、これの処理結果についてパッチ統合部205で統合されるように構成されていてもよい。
 図3Aの例では、メッシュが、基本面1及び2で構成されるパッチ1と、基本面3及び4で構成されるパッチ2とに分割されている。
 多重分離部201は、多重化されたビットストリームを、基本メッシュビットストリームと変位量ビットストリームとテクスチャビットストリームとに分離するように構成されている。
<基本メッシュ復号部202>
 基本メッシュ復号部202は、基本メッシュビットストリームを復号し、基本メッシュを生成して出力するように構成されている。
 ここで、基本メッシュは、3次元空間における複数の頂点と、かかる複数の頂点を接続する辺とで構成される。
 なお、図3Aに示すように、基本メッシュは、3つの頂点で表現される基本面を組み合わせて構成される。
 基本メッシュ復号部202は、例えば、非特許文献2に示すDracoを用いて、基本メッシュビットストリームを復号するように構成されていてもよい。
 また、基本メッシュ復号部202は、細分割手法の種別を制御する制御情報として、後述の「subdivision_method_id」を生成するように構成されていてもよい。
 以下、図4~図5を参照して、基本メッシュ復号部202で復号される制御情報について説明する。
 図4は、基本メッシュビットストリームのシンタックス構成の一例を示す図である。
 図4に示すように、第1に、基本メッシュビットストリームは、基本メッシュパッチに対応する制御情報の集合であるBPH(Base Patch header:ベースパッチヘッダ)を含んでいてもよい。第2に、基本メッシュビットストリームは、BPHの次に、基本メッシュパッチを符号化した基本メッシュパッチデータを含んでいてもよい。
 以上のように、基本メッシュビットストリームは、各パッチデータに、1つずつBPHが対応する構成となる。なお、図4の構成は、あくまで一例であり、各パッチデータに、BPHが対応する構成となっていれば、基本メッシュビットストリームの構成要素として、上述以外の要素が追加されてもよい。
 例えば、図4に示すように、基本メッシュビットストリームは、SPS(シーケンスパラメータセット:Sequence Parameter Set)を含んでいてもよいし、フレームに対応する制御情報の集合であるFH(Frame Header:フレームヘッダ)を含んでもよいし、メッシュに対応する制御情報であるMH(Mesh Header:メッシュヘッダ)を含んでもよい。
 図5は、BPHのシンタックス構成の一例を示す図である。ここで、シンタックスの機能が同様であれば、図5に示すシンタックスメイト異なるシンタックス名が用いられても差し支えない。
 図5に示すBPHのシンタックス構成において、Description欄は、各シンタックスが、どのように符号化されているかを意味している。また、ue(v)は、符号無し0次指数ゴロム符号であることを意味し、u(n)は、nビットのフラグであることを意味する。
 BPHは、基本メッシュパッチに含まれる基本面の個数を指定する制御信号(mdu_face_count_minus1)を少なくとも含む。
 また、BPHは、基本パッチごとに基本メッシュの細分割手法の種別を指定する制御信号(mdu_subdivision_method_id)を少なくとも含む。
 また、BPHは、基本メッシュパッチごとに細分割数生成手法の種別を指定する制御信号(mdu_subdivision_num_method_id)を含んでもよい。
 例えば、mdu_subdivision_num_method_id=0のとき、予測分割残差により基本面の細分割数を生成することと定義し、mdu_subdivision_num_method_id=1のとき、再帰的に基本面の細分割数を生成することと定義し、mdu_subdivision_num_method_id=2のとき、全ての基本面に対して同じ上限細分割回数だけ、再帰的に細分割を行うように定義してもよい。
 BPHは、予測分割残差により基本面の細分割数を生成するとき、インデックスi(i=0,…,mdu_face_count_minus1)ごとに基本面の予測分割残差を指定する制御信号(mdu_subdivision_resuiduals)を含んでもよい。
 BPHは、再帰的に基本面の細分割数を生成するとき、基本メッシュパッチごとに再帰的に行う細分割回数の上限を識別するための制御信号(mdu_max_depth)を含んでもよい。
 BPHは、インデックスi(i=0,…,mdu_face_count_minus1)及びj(j=0,…,mdu_subdivision_depth_index)ごとに、基本面を再帰的に細分割するか否かを指定する制御信号(mdu_subdivision_flag)を含んでもよい。
 BPHは、一度の細分割あたりの再分割数を指定する制御信号(mdu_subdivision_num)を含んでいてもよい。
 図6に示すように、基本メッシュ復号部202は、分離部202Aと、イントラ復号部202Bと、メッシュバッファ部202Cと、接続情報復号部202Dと、インター復号部202Eとを備える。
 分離部202Aは、基本メッシュビットストリームを、Iフレーム(参照フレーム)のビットストリームとPフレームのビットストリームとに分類するように構成されている。
(イントラ復号部202B)
 イントラ復号部202Bは、例えば、非特許文献2に示すDracoを用いて、Iフレームのビットストリームから、Iフレームの頂点の座標及び接続情報を復号するように構成されている。
 図7は、イントラ復号部202Bの機能ブロックの一例を示す図である。
 図7に示すように、イントラ復号部202Bは、分離部202Aと、任意イントラ復号部202B1と、整列部202B2とを有する。
 任意イントラ復号部202B1は、非特許文献2に示すDracoを含む任意の方式を用いて、Iフレームのビットストリームから、Iフレームの順序無し頂点の座標及び接続情報を復号するように構成されている。
 整列部202B2は、順序無し頂点を所定の順序に並び替えることによって頂点を出力するように構成されている。
 所定の順序として、例えば、モートンコード順を用いてもよく、ラスタスキャン順を用いてもよい。
 また、座標が一致する複数の頂点、すなわち重複頂点をまとめて、単一頂点としてから、所定の順序に並び替えてもよい。
 メッシュバッファ部202Cは、イントラ復号部202Bによって復号されたIフレームの頂点の座標及び接続情報を蓄積するように構成されている。
 接続情報復号部202Dは、メッシュバッファ部202Cから取り出したIフレームの接続情報をPフレームの接続情報にするように構成されている。
 インター復号部202Eは、メッシュバッファ部202Cから取り出したIフレームの頂点の座標とPフレームのビットストリームから復号した動きベクトルとを加算することによって、Pフレームの頂点の座標を復号するように構成されている。
 本実施形態では、図8に示すように、Pフレームの基本メッシュの頂点とIフレーム(参照フレーム)の基本メッシュの頂点との間で対応関係が存在する。ここで、インター復号部202Eによって復号される動きベクトルは、Pフレームの基本メッシュの頂点の座標とIフレームの基本メッシュの頂点の座標との差分ベクトルである。
(インター復号部202E)
 図9は、インター復号部202Eの機能ブロックの一例を示す図である。
 図9に示すように、インター復号部202Eは、動きベクトル残差復号部202E1と、動きベクトルバッファ部202E2と、動きベクトル予測部202E3と、動きベクトル算出部202E4と、加算器202E5とを有する。
 動きベクトル残差復号部202E1は、PフレームのビットストリームからMVR(Motion Vector Residual)を生成するように構成されている。
 ここで、MVRは、MV(Motion Vector)とMVP(Motion Vector Prediction)との差分を示す動きベクトル残差である。MVは、対応するIフレームの頂点の座標とPフレームの頂点の座標との間の差分ベクトル(動きベクトル)である。MVPは、MVを用いて対象の頂点のMVの予測した値(動きベクトルの予測値)である。
 動きベクトルバッファ部202E2は、動きベクトル算出部202E4によって出力されたMVを順次に保存するように構成されている。
 動きベクトル予測部202E3は、復号対象の頂点と接続している頂点について、動きベクトルバッファ部202E2から復号済みのMVを取得し、図10に示すように、取得された復号済みのMVの全部又は一部を用いて、復号対象の頂点のMVPを出力するように構成されている。
 動きベクトル算出部202E4は、動きベクトル残差復号部202E1で生成されたMVRと動きベクトル予測部202E3から出力されたMVPとを加算し、復号対象の頂点のMVを出力するように構成されている。
 加算器202E5は、対応関係を持つIフレーム(参照フレーム)の復号済みの基本メッシュから得られた復号対象の頂点に対応する頂点の座標と、動きベクトル算出部202E3から出力された動きベクトルMVとを加算し、復号対象の頂点の座標を出力するように構成されている。
 以下、インター復号部202Eの各部の詳細について説明する。
 図11に、動きベクトル予測部202E3の動作の一例を示すフローチャートを示す。
 図11に示すように、ステップS1001において、動きベクトル予測部202E3は、MVP及びNに0を設定する。
 ステップS1002において、動きベクトル予測部202E3は、動きベクトルバッファ部202E2から、復号対象の頂点の周りの頂点のMVの集合を取得し、後続の処理が終わっていない頂点を特定し、Noに遷移し、全ての頂点について後続の処理が終わっている場合は、Yesに遷移する。
 ステップS1003において、動きベクトル予測部202E3は、処理対象の頂点のMVが、復号済みでなければ、Noに遷移し、処理対象の頂点のMVが、復号済みであれば、Yesに遷移する。
 ステップS1004において、動きベクトル予測部202E3は、MVPにMVを加算し、Nに1を加算する。
 ステップS1005において、動きベクトル予測部202E3は、Nが0より大きければ、MVPをNで除した結果を出力し、Nが0であれば、0を出力し、処理を終了する。
 すなわち、動きベクトル予測部202E3は、復号対象の頂点の周りにある頂点の復号済みの動きベクトルを平均することによって、復号対象のMVPを出力するように構成されている。
 なお、動きベクトル予測部202E3は、かかる復号済みの動きベクトルの集合が空集合の場合、MVPを0とするように構成されていてもよい。
 動きベクトル算出部202E4は、式(1)によって、動きベクトル予測部202E3によって出力されたMVP及び動きベクトル残差復号部202E1によって生成されたMVRから、復号対象の頂点のMVを算出するように構成されていてもよい。
 MV(k)=MVP(k)+MVR(k) … (1)
 ここで、kは、頂点のインデックスである。MV、MVR及びMVPは、x成分、y成分及びz成分を有するベクターである。
 かかる構成によれば、MVPを用いて、MVの代わりにMVRのみを符号化するため、符号化効率を高める効果が期待できる。
 加算器202E5は、動きベクトル算出部202E4によって算出された頂点のMVと、かかる頂点に対応する参照フレームの頂点の座標とを加算することによって、かかる頂点の座標を算出し、接続情報(Connectivity)を参照フレームのままにするように構成されている。
 具体的には、加算器202E5は、式(2)を用いて、k番目の頂点の座標v’(k)を算出するように構成されていてもよい。
 v’(k)=v’(k)+MV(k) … (2)
 ここで、v’(k)は、復号対象のフレームで復号するk番目の頂点の座標であり、v’(k)は、参照フレームの復号したk番目の頂点の座標であり、MV(k)は、復号対象のフレームのk番目のMVであり、k=1,2…,Kである。
 また、復号対象のフレームの接続情報は、参照フレームの接続情報と同一にされる。
 なお、動きベクトル予測部202E3は、復号済みのMVを用いてMVPを算出するため、復号の順番がMVPに影響を及ぼす。
 かかる復号の順番は、参照フレームの基本メッシュの頂点の復号の順番にする。一般的に、一定の繰り返しパターンを用いて、起点となるエッジから基本面を1つずつ増やす復号手法であれば、復号した基本メッシュの頂点の順番が復号の過程で決められる。
 例えば、動きベクトル予測部202E3は、参照フレームの基本メッシュにおいて、Edgebreakerを用いて、頂点の復号の順番を決めてもよい。
 かかる構成によれば、頂点の座標の代わりに参照フレームからのMVを符号化するため、符号化効率を高める効果が期待できる。
(インター復号部202Eの変更例1)
 図11に示すフローチャートで算出したMVPは、復号済みの周りのMVの単純平均によって算出されているがが、重み付け平均によって算出されてもよい。
 すなわち、動きベクトル予測部202E3は、復号対象の頂点の周りにある頂点の復号済みの動きベクトルに対して、復号対象の頂点及び復号対象の頂点の周りにある頂点に対応する参照フレームの頂点間の距離に応じた重みで加重平均することで、復号対象の動きベクトルの予測値を出力するように構成されていてもよい。
 なお、動きベクトル予測部202E3は、復号対象の頂点の周りにある頂点の復号済みの動きベクトルの一部に対して、復号対象の頂点及び復号対象の頂点の周りにある頂点に対応する参照フレームの頂点間の距離に応じた重みで加重平均することで、復号対象の動きベクトルの予測値を出力するように構成されていてもよい。
 本変更例1では、インター復号部202Eの動きベクトル予測部202E3は、以下の手順で、MVPを算出するように構成されている。
 第1に、動きベクトル予測部202E3は、重みを算出するように構成されている。
 図12に、復号済みの周りの頂点との距離の和Total_Dを算出する動作の一例を示すフローチャートを示す。
 図12に示すように、ステップS1101において、動きベクトル予測部202E3は、Total_Dに0を設定する。
 ステップS1102は、ステップS1002と同じである。
 ステップS1103は、ステップS1003と同じである。
 ステップS1104において、動きベクトル予測部202E3は、Total_Dに対してe(k)を加算する。
 すなわち、動きベクトル予測部202E3は、復号対象の頂点の周りにある頂点の集合を参照して、復号済みの頂点の距離を加算する。
 本変更例1では、動きベクトル予測部202E3は、頂点間の対応関係が既知である参照フレームにおける距離を利用して重みを算出するように構成されている。
 つまり、図12のステップS1104におけるe(k)は、参照フレームにおける対応する頂点間の距離である。
 そして、動きベクトル予測部202E3は、式(3)及び(4)によって、重みw(k)を算出するように構成されていてもよい。
Figure JPOXMLDOC01-appb-M000001
 ここで、Θは、復号対象の頂点を含んでいるメッシュの面における復号済みの各頂点の集合であり、e(p/k)は、参照フレームで復号対象の頂点と頂点p/kと対応する頂点との間の距離であり、w(k)は、頂点kにおける重みである。
 なお、動きベクトル予測部202E3は、距離に応じて事前に決めたルールで、重みを設定するように構成されていてもよい。
 例えば、動きベクトル予測部202E3は、e(k)が閾値TH1よりも小さい場合、重みを1に設定し、e(k)が閾値TH2よりも小さい場合、重みを0.5に設定しし、それ以外の場合、重みを0に設定する(重みを利用しない)ように構成されていてもよい。
 かかる構成によれば、復号対象の頂点との距離が近い場合に重みを大きくすることで、より高い精度でMVPを算出することができるという効果が期待できる。
 第2に、動きベクトル予測部202E3は、MVPを参照するように構成されている。
 図13に、重み付け平均を用いてMVPを算出する動作の一例を示すフローチャートを示す。
 図13に示すように、ステップS1201において、動きベクトル予測部202E3は、MVP及びNに0を設定する。
 ステップS1202は、ステップS1002と同じである。
 ステップS1203は、ステップS1003と同じである。
 ステップS1204において、動きベクトル予測部202E3は、MVPにw(k)×MV(k)を加算し、Nに1を加算する。
 ステップS1205は、ステップS1005と同じである。
 或いは、動きベクトル予測部202E3は、式(5)によって、MVPを算出するように構成されていてもよい。
Figure JPOXMLDOC01-appb-M000002
 ここで、Θは、復号対象の頂点を含んでいるメッシュの面における復号済みの各頂点の集合である。
 かかる構成によれば、重み付け平均で、より高い精度のMVPを算出することができるため、MVRの値を小さくしてゼロ付近に集中させることにより、符号化効率を高めるという効果が期待できる。
(インター復号部202Eの変更例2)
 本変更例2では、動きベクトル予測部202E3は、周りの複数のMVを用いてMVPを算出するのではなく、1つのMVを選択するように構成されている。
 すなわち、動きベクトル予測部202E3は、復号対象の頂点と接続している頂点のMVとして、動きベクトルバッファ部202E2に蓄積されている復号済みのMVのうち最近傍の頂点のMVを選択するように構成されていてもよい。
 ここで、動きベクトル予測部202E3は、動きベクトルバッファ部202E2に蓄積されている復号済みのMVの中から、復号対象の頂点と接続している頂点のMVから成る候補リストを構築し、Pフレーム(復号対象のフレーム)のビットストリームから復号したインデックスに基づいて、候補リストから動きベクトルを選択するように構成されていてもよい。
 図14に、MVPとして候補MVの集合からMVを選択する動作の一例を示すフローチャートを示す。
 図14に示すように、ステップS1301において、動きベクトル予測部202E3は、PフレームのビットストリームからリストIDを復号する。
 ステップS1302において、動きベクトル予測部202E3は、候補MVの中から、リストIDを付けるMVをMVPとして選択する。
 なお、図13における候補MVの集合では、復号済みの周りのMV及びその組み合わせで算出されたMVが一定の順番で並んでいる。
 図15に、かかる候補MVの集合を作成する動作の一例を示すフローチャートを示す。
 図15に示すように、ステップS1401において、動きベクトル予測部202E3は、復号対象の頂点の周りの頂点のMVの集合を参照して、復号対象の頂点の周りの全ての頂点に対する処理が完了しているか否かについて判定する。
 かかる処理が完了している場合、本動作は、終了し、かかる処理が完了していない場合、本動作は、ステップS1402に進む。
 ステップS1402において、動きベクトル予測部202E3は、対象の頂点のMVが復号されているか否かについて判定する。
 かかるMVが復号されている場合、本動作は、ステップS1403に進み、かかるMVが復号されていない場合、本動作は、ステップS1401に戻る。
 ステップS1403において、動きベクトル予測部202E3は、かかるMVが他の復号済みのMVと重複するか否かについて判定する。
 重複する場合、本動作は、ステップS1401に戻り、重複していない場合、本動作は、ステップS1404に進む。
 動きベクトル予測部202E3は、ステップS1404において、かかるMVに対して付与するリストIDを決定し、ステップS1405において、候補MVの集合に含める。
 なお、図15において、動きベクトル予測部202E3は、リストIDを決定する際に、リストIDを順番に1つずつ増やしてもよいし、参照フレームで復号対象の頂点と頂点kに対応する頂点との間の距離(式(3)のe(k))の順でリストIDを決定してもよい。
 かかる構成によれば、候補MVの1つをMVPとして選択することが、場合によって平均よりMVと近いことがあるため、その場合には、符号化効率を高めるという効果が期待できる。
 更に、動きベクトル予測部202E3は、上述の候補MVの中から、連続するMV0及びMV1を平均したMVを、新たな候補MVとしてリストの中に追加するように構成されていてもよい。動きベクトル予測部202E3は、かかるMVの追加先としては、表1に示すように、MV0及びMV1の後にする。
Figure JPOXMLDOC01-appb-T000003
 かかる構成によれば、選択した候補MVが、復号対象の頂点のMVとより近い可能性を高めるという効果が期待できる。
 更に、動きベクトル予測部202E3は、リストIDを符号化せず、候補MVの集合から最も近傍の頂点のMVを選択するように構成されていてもよい。かかる構成によれば、符号化効率を更に高めるという効果が期待できる。
(インター復号部202Eの変更例3)
 上述の実施例及び変更例1~2では、周りの頂点は、復号対象の頂点と接続している頂点であった。
 これに対して、本変更例3では、動きベクトル予測部202E3は、平行四辺形予測によって、すなわち、復号対象の頂点と直接に接続していない頂点も利用して、MVPを算出するように構成されている。
 図16に示すように、平行四辺形予測では、復号対象の頂点Aと共有エッジBCを持つ復号済みの面の反対側の頂点Dも利用する。
 また、復号対象の頂点Aの共有エッジは、AB以外に、CE及びBGがある。したがって、平行四辺形予測では、同様に、頂点F及びHも利用できる。
 例えば、動きベクトル予測部202E3は、図16に示す面BCDを用いて、式(6)で、MVPを算出するように構成されていてもよい。
 MVP=MV(B)+MV(C)-MV(D) … (6)
 ここで、MV(X)は、頂点Xの動きベクトルであり、MVPは、復号対象の頂点Aの動きベクトル予測値である。
 また、上述の共有エッジが複数ある時に、動きベクトル予測部202E3は、それぞれのMVPを平均してもよいし、面の重心が最も近い面を選択してもよい。
(インター復号部202Eの変更例4)
 本変更例では、動きベクトル残差復号部202E1によって生成されたMVRは、そのままではなく、MVRを整数表現する際の量子化幅が制御されるように構成されている。
 本変更例では、動きベクトル残差復号部202E1は、MVRの量子化幅を制御する制御情報として、adaptive_mesh_flag、adaptive_bit_flag及び精度制御パラメータを復号するように構成されている。
 すなわち、動きベクトル残差復号部202E1は、基本メッシュ全体のadaptive_mesh_flag及び基本パッチ毎のadaptive_bit_flagを復号するように構成されている。
 ここで、adaptive_mesh_flag及びadaptive_bit_flagは、上述のMVRの量子化幅の調整を行うか否かについて示すフラグであり、0又は1のいずれかの値を採る。
 ここで、動きベクトル残差復号部202E1は、adaptive_mesh_flagが有効(すなわち、1)である場合のみ、adaptive_bit_flagを復号する。
 また、動きベクトル残差復号部202E1は、adaptive_mesh_flagが無効(すなわち、0)である場合、adaptive_bit_flagは無効(すなわち、0)とみなす。
 図17に、に基本メッシュビットストリームを復号して生成した制御情報であるadaptive_mesh_flag、adaptive_bit_flag及び精度制御パラメータから、復号されたMVRの量子化幅を制御する動作の一例を示すフローチャートを示す。
 図17に示すように、ステップS1601において、動きベクトル予測部202E3は、adaptive_mesh_flagが0であるか否かについて判定する。
 メッシュ全体のadaptive_mesh_flagが0であると判定された場合、本動作は、終了する。
 一方、メッシュ全体のadaptive_mesh_flagが1であると判定された場合、本動作は、ステップS1602に進む。
 ステップS1602において、動きベクトル予測部202E3は、フレーム内に未処理のパッチが存在するか否かについて判定する。
 ステップS1603において、動きベクトル予測部202E3は、パッチごとに復号されるadaptive_mesh_flagが0であるか否かについて判定する。
 adaptive_mesh_flagが0であると判定された場合、本動作は、ステップS1601に戻る。
 一方、adaptive_mesh_flagが1であると判定された場合、本動作は、ステップS1604に進む。
 ステップS1604において、動きベクトル予測部202E3は、後述の精度制御パラメータに基づいて、MVRの量子化幅を制御する。
 なお、このように量子化幅を制御されたMVRの値を「MVRQ(Motion Vector Residual Quantization)」と呼ぶ。
 ここで、動きベクトル予測部202E3は、例えば、表2のような表を参照して、基本メッシュビットストリーム復号して生成した量子化幅制御パラメータに対応するMVRの量子化幅を用いるように構成されていてもよい。
Figure JPOXMLDOC01-appb-T000004
 かかる構成によれば、MVR量子化幅の制御により、符号化効率を高めることができるという効果が期待できる。更に、メッシュレベルのadaptive_mesh_flag及びパッチレベルのadaptive_mesh_flagの階層的な仕組みにより、MVR量子化幅の制御をしない時に無駄なビットを最小化することができるという効果が期待できる。
(インター復号部202Eの変更例5)
 動きベクトル残差復号部202E1によって生成されたMVRを符号化しない場合、誤差が生じる。本変更例5では、かかる誤差を補正するため、離散的な動きベクトル差分を符号化する。
 具体的には、図18に示すように、MVRは、x軸、y軸及びz軸の6方向において、1、2、4及び8の大きさを採り得る。かかる符号化の一例について、表3及び表4に示す。
 また、複数の方向の組み合わせで、MVRの符号化を行ってもよい。例えば、x軸の+方向の2、y軸の+方向の1の順番で補正してもよい。
Figure JPOXMLDOC01-appb-T000005
Figure JPOXMLDOC01-appb-T000006
 かかる構成によれば、MVRの符号化よりも離散的な動きベクトル差分の符号化効率が高いという効果が期待できる。
 以降で、インター復号部202Eの更なる変更例について説明する。
 上述のインター復号部202Eの更なる変更例では、上述のインター復号部202Eを実施する前に、以下の機能ブロックを追加するように構成されている。
 具体的には、図19に示すように、インター復号部202Eは、図9に示す構成に加えて、重複頂点探索部202E6と、重複頂点判別部202E7と、動きベクトル取得部202E8と、All skip modeシングル判別部202E9と、Skip modeシングル判別部202E10とを備えている。
 All skip modeシングル判別部202E9は、All skip modeシングルがYes及びNoのいずれを示すかについて判別するように構成されており、Skip modeシングル判別部202E10は、skip modeシングルYes及びNoのいずれを示すかについて判別するように構成されている。
 ここで、All skip modeシグナルが、Pフレームのビットストリームの最初にあり、少なくとも2値を持ち、1ビット又は1ビット以上である。
 その1つ(All skip modeシグナルが、Yesを示す場合、例えば、1である場合)は、Pフレームの全ての重複頂点の動きベクトルをビットストリームから復号せず、重複された頂点の動きベクトルをコピーするシグナルである。
 もう1つ(All skip modeシグナルが、Noを示す場合、例えば、0である場合)は、Pフレームの各頂点で異なる処理を行うシグナルである。更に、もう1つは、他の値を持ってもよい。例えば、もう1つは、全ての重複頂点の動きベクトルについて、動きベクトル取得部202E8における処理を実施せず、図9に示すインター復号部202Eと同様の処理を行うシングルである。
 ここで、Skip modeシグナルは、All skip modeシグナルがNoを示す場合、重複頂点毎に2値を持ち、1ビットである。
 Skip modeシグナルは、All skip modeシグナルがYesを示す場合(例えば、1である場合)、当該頂点の動きベクトルをビットストリームから復号せず、重複された頂点の動きベクトルをコピーするシグナルルである。
 Skip modeシグナルは、All Skip modeシグナルがNoを示す場合(例えば、0である場合)、当該頂点の動きベクトルについて動きベクトル取得部202E8における処理を実施せず、図9に示すインター復号部202Eと同様の処理を行うシングルである。
 なお、上述のSkip modeシグナルは、ビットストリームから直接に復号されてもよいし、ビットストリームから図9に示すインター復号部202Eと同様の処理を行う重複頂点を特定するデータ(例えば、当該重複頂点のインデックス)を復号し、かかるデータからSkip modeシグナルを算出してもよい。
 更に、Skip modeシグナルを算出せず、上述の図9に示すインター復号部202Eと同様の処理を行う重複頂点を特定するデータ(例えば、重複頂点のインデックス)を用いて、上述の場合と同様に、当該頂点の動きベクトル復号方法を決めてもよい。
 重複頂点探索部202E6は、復号した参照フレームの基本メッシュの幾何情報から、座標が一致する頂点(以下、重複頂点と呼ぶ)のインデックスを探索してバッファ(図示せず)に保存するように構成されている。
 具体的には、重複頂点探索部202E6の入力は、復号した参照フレームの基本メッシュの各頂点のインデックス(復号順)及び位置座標である。
 また、重複頂点探索部202E6の出力は、重複頂点が存在する頂点のインデックス(vindex0)及びかかる重複頂点のインデックス(vindex1)のペアのリストである。ここで、かかるペアのリストは、index0の順で、バッファrepVertに保存される。
 また、vindex1の頂点が、vindex0の前に復号されたため、vindex0>vindex1の関係となる。
 なお、参照フレームの基本メッシュで重複頂点が分かる方法として、重複頂点が存在する頂点に対して、特別なシグナルにより、位置座標ではなく、重複頂点のインデックスを復号する。かかる特別なシグナルにより、該当頂点のインデックス及び重複頂点のインデックスのペアを復号順で保存できる。
 重複頂点判別部202E7は、該当頂点が復号した頂点の中に重複頂点があるかどうかを判別するように構成されている。
 ここで、重複頂点判別部202E7は、該当頂点のインデックスが、重複頂点が存在する頂点のインデックスの中のものであれば、復号した頂点の中に重複頂点があると判別する。なお、復号順で該当頂点が来るので、上述の探索が不要である。
 ここで、重複頂点判別部202E7が、該当頂点の重複頂点が存在しないと判断する場合は、図9に示すインター復号部202Eと同様の処理が行われる。
 動きベクトル取得部202E8は、該当頂点の重複頂点が存在する場合に、All skip modeシグナルがYesを示す場合、或いは、All skip modeシグナルがNoを示す場合、該当頂点のSkip modeシグナルがYesを示す場合、復号した動きベクトルを保存する動きベクトルバッファ部202E2から重複頂点と同じインデックスを持つ頂点の動きベクトルを取得し、該当頂点の動きベクトルにするように構成されている。
 ここで、All skip modeシグナルがNoを示し、該当頂点のSkip modeシグナルがNoを示す場合は、動きベクトル取得部202E8の代わりに、図9に示すインター復号部202Eと同様の処理が行われる。
 かかる構成によれば、重複頂点が存在する頂点に対して動きベクトルの復号計算及び符号量の削減効果が期待できる。
 上述のインター復号部202Eの更なる変更例では、インター復号部202Eは、参照フレームの復号済みの基本メッシュから、参照フレームの頂点と復号対象のフレームの頂点との間の対応関係を取得する。
 そして、インター復号部202Eは、かかる対応関係に基づいて、復号対象のフレームの頂点の接続情報について符号化せずに参照フレームの復号済みの頂点の接続情報と同一とするように構成されている。
 また、インター復号部202Eは、参照フレームの頂点の復号順で、復号対象のフレームの基本メッシュをシグナルに基づいて2種類の領域に分割する。第1領域では、インター処理を用いて復号し、第2領域では、イントラ処理を用いて復号する。
 なお、上述の領域は、参考フレームの基本メッシュを復号する際に、復号順上に連続する複数の頂点によって形成される領域であると定義する。
 また、シグナルを用いて、復号対象のフレームの基本メッシュの頂点の座標を復号する手段は、以下の2つの実装が想定される。
(手段1)
 手段1では、シグナルは、vertex_idx1、vertex_idx2及びintra_flagになる。
 ここで、vertex_idx1及びvertex_idx2は、頂点の復号順のインデックス(頂点インデックス)であり、intra_flagは、上述のインター復号手法であるかイントラ復号手法であるかについて示すフラグである。かかるシグナルは、複数あってもよい。
 すなわち、vertex_idx1及びvertex_idx2は、上述の一部の領域(第1領域及び第2領域)の開始位置及び終了位置を規定する頂点インデックスである。
(手段2)
 手段2では、Edgebreakerで参照フレームの基本メッシュの接続情報を復号し、頂点の座標の復号順をEdgebreakerで決めた順番にするという前提がある。
 図20は、Edgebreakerを用いて、接続情報及び頂点の順番を決める動作の一例を示す図である。
 図20において、矢印は、接続情報の復号順を示し、数字は、頂点の復号順を示し、同じ線種の矢印によって同じ領域を規定している。
 手段2では、シグナルは、インター復号手法であるかイントラ復号手法であるかについて示すフラグであるintra_flagのみになる。
 すなわち、手段2では、インター復号部202Eは、Edgebreakerを用いて、第1領域及び第2領域に分割するように構成されている。
<細分割部203>
 細分割部203は、制御情報によって示された細分割手法により、基本メッシュ復号部202によって復号された基本メッシュから、追加された細分割頂点及びそれらの接続情報を生成して出力するように構成されている。
 ここで、基本メッシュ、追加された細分割頂点、及び、それらの接続情報を、併せて「細分割メッシュ」と呼ぶ。
 細分割部202は、基本メッシュビットストリームを復号して生成した制御情報であるsubdivision_method_idから、細分割手法の種別を特定するように構成されている。
 以下、図3A及び図3Bを参照して、細分割部202について説明する。
 図3A及び図3Bは、基本メッシュから細分割頂点を生成する動作の一例について説明するための図である。
 図3Aは、5つの頂点で構成された基本メッシュの一例について示す図である。
 ここで、細分割には、例えば、各基本面において各辺の中点同士を接続するMid-edge分割法を用いてもよい。これによって、ある基本面は、4つの面に分割されることになる。
 図3Bは、5つの頂点で構成された基本メッシュを分割した細分割メッシュの一例を示す。図3Bに示す細分割メッシュでは、元の5つの頂点(黒丸)に加えて8つの細分割頂点(白丸)が生成されている。
 このように生成した細分割頂点ごとに、変位量復号部206で変位量を復号することによって、符号化性能の向上が期待できる。
 また、各パッチで異なる細分割方法を適用してもよい。これによって、変位量復号部206で復号される変位量をパッチごとに適応的に変化させ、符号化性能の向上が期待できる。分割したパッチの情報は、制御情報であるpatch_idとして受け取られる。
 以下、図21を参照して、細分割部203について説明する。図22は、細分割部203の機能ブロックの一例について示す図である。
 図22に示すように、細分割部203は、基本メッシュ細分割部203Aと細分割メッシュ調整部203Bとを有する。
(基本メッシュ細分割部203A)
 基本メッシュ細分割部203Aは、入力された基本メッシュ及び基本メッシュの分割情報に基づき、基本面及び基本パッチごとの分割数(細分割数)を算出し、かかる分割数に基づいて基本メッシュを細分割し、細分割面を出力するように構成されている。
 すなわち、基本メッシュ細分割部203Aは、基本面及び基本パッチ単位で、上述の分割数を変えることができるように構成されていてもよい。
 ここで、基本面は、基本メッシュを構成する面であり、基本パッチは、いくつかの基本面の集合である。
 また、基本メッシュ細分割部203Aは、基本面の細再分割数を予測し、予測した基本面の細分割数に対して予測分割数残差を加算することで、基本面の細分割数を算出するように構成されていてもよい。
 また、基本メッシュ細分割部203Aは、基本面の隣接基本面の細分割数に基づいて、基本面の細分割数を算出するように構成されていてもよい。
 また、基本メッシュ細分割部203Aは、直前に蓄積された基本面の細分割数に基づき、基本面の細分割数を算出するように構成されていてもよい。
 また、基本メッシュ細分割部203Aは、基本面を構成する3辺を分割する頂点を生成し、生成した頂点を接続することで、基本面を細分割するように構成されていてもよい。
 図22に示すように、基本メッシュ細分割部203Aの後段に、後述の細分割メッシュ調整部を備える203Bを備えている。
 以下、図22~図24を用いて、基本メッシュ細分割部203Aの処理の一例について説明する。
 図22は、基本メッシュ細分割部203Aの機能ブロックの一例を示す図であり、図24は、基本メッシュ細分割部203Aの動作の一例を示すフローチャートである。
 図22に示すように、基本メッシュ細分割部203Aは、基本面分割数バッファ部203A1と、基本面分割数参照部203A2と、基本面分割数予測部203A3と、加算部203A4と、基本面分割部203A5とを有する。
 基本面分割数バッファ部203A1は、基本面の分割数を含む基本面の分割情報を格納しており、基本面分割数参照部203A2に対して基本面の分割情報を出力するように構成されている。
 ここで、基本面分割数バッファ部203A1のサイズは、1とし、基本面分割数参照部203A2に対して、直前に蓄積された基本面の分割数を出力するように構成されていてもよい。
 すなわち、基本面分割数バッファ部203A1のサイズを1にすることで、最後に復号した細かい分割数(直前に復号した細分割数)のみを参照するように構成されていてもよい。
 基本面分割数参照部203A2は、復号対象の基本面に対して隣接する基本面が存在していない場合、或いは、復号対象の基本面に対して隣接する基本面が存在しているが分割数が確定していない場合は、基本面分割数予測部203A3に対して、参照不可を出力するように構成されている。
 一方、基本面分割数参照部203A2は、復号対象の基本面に対して隣接する基本面が存在し且つ分割数が確定している場合は、基本面分割数予測部203A3に対して、かかる分割数を出力するように構成されている。
 基本面分割数予測部203A3は、入力された1つ以上の分割数に基づいて基本面の分割数(細分割数)を予測し、加算部203A4に対して、予測した分割数(予測分割数)を出力するように構成されている。
 ここで、基本面分割数予測部203A3は、基本面分割数参照部203A2から参照不可のみが入力された場合は、加算部203A4に対して、0を出力するように構成されている。
 なお、基本面分割数予測部203A3は、1つ以上の分割数が入力された場合、入力された分割数の平均値や最大値や最小値や最頻値等の統計値のいずれかを用いて、予測分割数を生成するように構成されていてもよい。
 なお、基本面分割数予測部203A3は、1つ以上の分割数が入力された場合、最も隣接する面の分割数を予測分割数として生成するように構成されていてもよい。
 加算部203A4は、予測残差ビットストリームから復号した予測分割数残差と基本面分割数予測部203A3から取得した予測分割数とを加算することによって得られた分割数を、基本面分割部203A5に対して出力するように構成されている。
 基本面分割部203A5は、加算部203A4から入力された分割数に基づき、基本面を細分割するように構成されている。
 図23は、基本面を9分割したケースの一例である。図23を参照して、基本面分割部203A5による基本面の分割方法について説明する。
 基本面分割部203A5は、基本面を構成する辺ABに対してN等分(N=3)する点A_1,…,A_(N-1)を生成する。
 同様に、基本面分割部203A5は、辺BCや辺CAについてもN等分し、それぞれ点B_1,…,B_(N-1)、C_1,…,C_(N-1)を生成する。
 以降、辺AB、辺BC及び辺CA上の点を「辺分割点」と呼ぶ。
 基本面分割部203A5は、全てのi(i=1,2,…,N-1)に対して、辺A_i B_(N-i),B_i C_(N-i),C_i A_(N-i)を生成し、N個の細分割面を生成する。この分割方法を、以降、N分割法と呼ぶ。N分割法は、N=2のときMid-edge分割法と等価となる。
次に、図24を参照して、基本メッシュ細分割部203Aの処理手順について説明する。
 ステップS2201において、最後の基本面に対して再分割処理が完了したか否かを判定する。処理が完了した場合終了し、そうでない場合はステップS2202に進む。
 ステップS2202において、基本メッシュ細分割部203Aは、Depth<mdu_max_depthの判定を行う。
 ここで、Depthは、現在の深度を表す変数で、初期値は0であり、mdu_max_depthは、基本面ごとに決められた最大深度を表す。
 ステップS2202における条件を満たす場合は、本処理手順は、ステップS2203に進み、かかる条件を満たさない場合は、本処理手順は、ステップS2201に戻る。
 ステップS2203において、基本メッシュ細分割部203Aは、現在の深度におけるmdu_subdivision_flagが1であるか否かについて判定する。
 Yesの場合、本処理手順は、ステップS2201に戻り、Noの場合、本処理手順は、ステップS2204に進む。
 ステップS2204において、基本メッシュ細分割部203Aは、基本面内の全ての細分割面をさらに細分割する。
 ここで、基本メッシュ細分割部203Aは、基本面に対して一度も細分割処理が行われていない場合は、基本面を細分割する。
 なお、細分割の方法については、ステップS2204で説明した方法と同様である。
 具体的には、基本面が一度も細分割されていない場合は、基本面に対して図23のように細分割を行う。少なくとも1回は細分割されている場合は、細分割面をN個に細分割する。図23を例にすると、頂点A_2と頂点Bと頂点B_1とからなる面を、基本面の分割のときと同様にN分割法を用いて、N個の面を生成する。
 細分割処理が終了したとき、本処理手順は、ステップS2205に進む。
 ステップS2205において、基本メッシュ細分割部203Aは、Depthに1を加算し、本処理手順は、ステップS2202に戻る。
 また、基本メッシュ細分割部203Aは、全ての基本面に対して同じ上限細分割回数mdu_max_depthだけ細分割するように細分割処理を行ってもよい。このとき、一回あたりの細分割処理は、細分割数mdu_subdivision_numに基づき、N分割法を用いて細分割を行うように構成されていてもよい。
(細分割メッシュ調整部203B)
 次に、細分割メッシュ調整部203Bによって行われる処理の具体例について説明する。以下、図24~28を用いて細分割メッシュ調整部203Bによって行われる処理の一例について説明する。
 図25は、細分割メッシュ調整部203Bの機能ブロックの一例を示す図である。
 図25に示すように、細分割メッシュ調整部203Bは、辺分割点移動部701と、細分割面分割部702とを有する。
(辺分割点移動部701)
 辺分割点移動部701は、入力された初期細分割面に対して、基本面の辺分割点を隣接基本面の辺分割点のいずれかに移動し、細分割面を出力するように構成されている。
 図26は、基本面ABC上の辺分割点を移動した例である。例えば、図26に示すように、辺分割点移動部701は、基本面ABCの辺分割点を最も近い隣接基本面の辺分割点に移動するように構成されていてもよい。
(細分割面分割部702)
 細分割面分割部702は、入力された細分割面を再度細分割し、復号細分割面を出力するように構成されている。
 図27は、基本面内の細分割面Xに対して再度細分割が行われたケースの一例を示す図である。
 図27に示すように、細分割面分割部702は、細分割面を構成する頂点と隣接基本面の辺分割点とを接続することで、基本面内に新たな細分割面を生成するように構成されていてもよい。
 図28は、全ての細分割面に対して、上述の細分割処理を行ったケースの一例を示す図である。
 メッシュ復号部204は、細分割部203で生成された細分割メッシュ及び変位量復号部206で復号された変位量を用いて、復号メッシュを生成して出力するように構成されている。
 具体的には、メッシュ復号部204は、各細分割頂点に対して、対応する変位量を加算することによって、復号メッシュを生成するように構成されている。ここで、各変位量がどの細分割頂点に対応するかについての情報は、制御情報によって示される。
 パッチ統合部205は、メッシュ復号部206で生成された復号メッシュを、複数のパッチ分だけ統合して出力するように構成されている。
 ここで、パッチの分割方法は、メッシュ符号化装置100によって定義される。例えば、パッチの分割方法は、各基本面に対して法線ベクトルを算出しておき、隣接する基本面の中で最も法線ベクトルが類似した基本面を選択し、両基本面を同じパッチとしてまとめ、かかる手順を、次の基本面に対して順次繰り返すように構成されていてもよい。
 映像復号部207は、映像符号化によってテクスチャを復号して出力するように構成されている。例えば、映像復号部207は、非特許文献1のHEVCを用いてもよい。
<変位量復号部206>
 変位量復号部206は、変位量ビットストリームを復号して変位量を生成して出力するように構成されている。
 図3Bの例では、8個の細分割頂点が存在するため、変位量復号部206は、各細分割頂点に対してスカラー或いはベクトルで表現される変位量を8個定義するように構成されている。
 以下、図29を参照して、変位量復号部206について説明する。図29は、変位量復号部206の機能ブロックの一例について示す図である。
図29に示すように、変位量復号部206は、制御情報復号部206Aと、算術復号部206Bと、コンテキスト値更新部206Cと、コンテキストバッファ…206Dと、コンテキスト選択部206Eと、多値化部206Fと、係数レベル値復号部F2と、インター予測部206Gと、フレームバッファ206Hと、加算器206Iと、逆量子化部206Jと、変位量予測加算部206Kとを備えている。
 以下、図30を参照して、変位量ビットストリームの構成の一例について説明する。図30は、変位量ビットストリームの構成の一例について示す図である。
 図30に示すように、第1に、変位量ビットストリームは、変位量の復号に関する制御情報の集合であるDPS(Displacement Parameter Set:ディスプレイスメントパラメータセット)を含んでいてもよい。
 第2に、変位量ビットストリームは、パッチに対応する制御情報の集合であるDPH(Displacement Patch Header:ディスプレイスメントパッチヘッダ)を含んでいてもよい。
 第3に、変位量ビットストリームは、DPHの次に、パッチを構成する符号化された変位量を含んでいてもよい。
 以上のように、変位量ビットストリームは、各符号化された変位量に、1つずつDPH及びDPSが対応する構成となる。
 なお、図30の構成は、あくまで一例である。各符号化された変位量に、DPH及びDPSが対応する構成となっていれば、変位量ビットストリームの構成要素として、上述以外の要素が追加されてもよい。
 例えば、図30に示すように、変位量ビットストリームは、SPS(Sequence Parameter Set:シーケンスパラメータセット)を含んでいてもよい。
 図31は、DPSのシンタックス構成の一例について示す図である。
 図31において、Descriptor欄は、各シンタックスが、どのように符号化されているかを意味している。
 また、図31において、ue(v)は、符号無し0次指数ゴロム符号であることを意味し、u(n)は、nビットのフラグであることを意味する。
 DPSは、複数のDPSが存在する場合に、各DPSを識別するためのDPS id情報(dps_displacement_parameter_set_id)を少なくとも含む。
 また、DPSは、インター予測を行うか否かを制御するフラグ(interprediction_enabled_flag)を含んでもよい。
 例えば、interprediction_enabled_flagが0のときは、インター予測を行わないと定義し、interprediction_enabled_flagが1のときは、インター予測を行うと定義してもよい。interprediction_enabled_flagが含まれないときは、インター予測を行わないと定義してもよい。
 また、DPSは、ウェーブレット変換を行うか否かを制御するフラグ(wavelet_transform_flag)を含んでもよい。
 例えば、wavelet_transform_flagが0のときは、ウェーブレット変換を行わないと定義し、wavelet_transform_flagが1のときは、ウェーブレット変換を行うと定義してもよい。wavelet_transform_flagが含まれないときは、ウェーブレット変換を行うと定義してもよい。
 また、DPSは、変位量予測加算を行うか否かを制御するフラグ(displacement_prediction_addition_flag)を含んでもよい。
 例えば、displacement_prediction_addition_flagが0のときは、変位量予測加算を行わないと定義し、displacement_prediction_addition_flagが1のときは、変位量予測加算を行うと定義してもよい。displacement_prediction_addition_flagが含まれないときは、変位量予測加算を行わないと定義してもよい。
 DPSは、逆DCTを行うか否かを制御するフラグ(dct_enabled_flag)を含んでもよい。
 例えば、dct_enabled_flagが0のときは、逆DCTを行わないと定義し、dct_enabled_flagが1のときは、逆DCTを行うと定義してもよい。dct_enabled_flagが含まれないときは、逆DCTを行わないと定義してもよい。
 以下、図34~図36を参照して、シンタックス構成について説明する。
 まず、符号化時は、変位量の係数レベル値は、各フレームにおいて3×Nサイズの行列で表される。3は、空間領域における次元を示し、Nは、細分割頂点の総数を示す。かかる行列がブロックに分割され、ブロック単位で符号化される。
 ブロックサイズは、3×nサイズ(n<N)であってもよいし、1×nサイズであってもよい。或いは、ブロックサイズとして、1×nサイズ及び2×nサイズを併用してもよい。ブロックサイズに満たない行列要素については、最大となるd×mサイズ(d=1,2,3, m<n)でブロックを構成する。
 図32は、シンタックス構成の一例について示す図である。シンタックスは、行列単位で定義されるものとブロック単位で定義されるものがある。
 第1に、行列単位で定義されるシンタックスについて説明する。
 lastt_sig_coeff_prefixは、スキャン順で先頭の非零係数の座標位置のプリフィックスを表す。lastt_sig_coeff_suffixは、スキャン順で先頭の非零係数の座標位置のサフィックスを表す。
 例えば、プリフィックスは、トランケーテッド・ライス二値化によって表現され、サフィックスは、固定長で表現される。図33は、最大値が32である場合のプリフィックス符号列及びサフィックス符号列を示す図である。
 第2に、ブロック単位で定義されるシンタックスについて説明する。
 coded_block_flagは、ブロック内に非零係数があることを示すフラグである。かかるフラグは、各ブロックに1個だけ定義される。
 last_sig_coeff_block_prefixは、ブロック内においてスキャン順で先頭の非零係数の座標位置のプリフィックスを表す。last_sig_coeff_block_suffixは、ブロック内においてスキャン順で先頭の非零係数の座標位置のサフィックスを表す。sig_coeff_flagは、非零係数かであるかどうかを示すフラグである。
 coeff_abs_level_greater1_flagは、係数(非零係数)の絶対値が2以上であるかどうかを示すフラグである。かかるフラグで表す係数の総数には、例えば、8個のような上限を設けてもよい。
 coeff_abs_level_greater2_flagは、スキャン順で先頭の絶対値が2以上の係数(非零係数)の絶対値が3以上であるかどうかを示すフラグである。coeff_sign_flagは、係数の正負符号を示すフラグである。
 coeff_abs_level_remainingは、係数の絶対値から上述のフラグで表現した値を引いた値を表す。coeff_abs_level_remainingは、例えば、k次指数ゴロム符号によって表現される。
 図34は、k次指数ゴロム符号によるプリフィックス符号列及びサフィックス符号列を示す図である。
 図35及び図36は、シンタックス構成の具体例について示す図である。図35に示すように、各シンタックスから係数レベル値が復号され、その後、図36に示すように、復号された係数レベル値が並び替えられる。
 図37は、DPHのシンタックス構成の一例について示す図である。
 図37に示すように、DPHは、各DPHに対応するDPSを指定するためのDPS id情報を少なくとも含む。
 制御情報復号部206Aは、受信した変位量ビットストリームに対して可変長復号を行うことで、制御情報を出力するように構成されている。
(算術復号部206B)
 算術復号部206Bは、受信した変位量ビットストリームに対して算術復号を行うことで、2値化係数レベル値を出力するように構成されている。詳細については後述する。
 算術復号部206Bは、2値を対象とする。算術復号部206Bは、0から1までの数直線を定義し、その区間を分割して利用する。区間は、2値の発生確率(以降、コンテキスト値と呼ぶ)によって分割される。
 算術復号部206Bには、2進数小数が入力され、算術復号部206Bは、かかる2進数少数が数直線上のどの区間に含まれるかによって元の値を復号する。
 ここで、コンテキスト値は、常に固定とされてもよいし、入力信号1ビットごとに変更されてもよい。コンテキスト値が、1ビットごとに変更される場合は、算術復号部206Bは、コンテキスト選択部206Eからコンテキスト値を受け取る。
(コンテキスト値更新部206C)
 コンテキスト値更新部206Cは、2値化係数レベル値を用いて、コンテキスト値を更新し、フレームバッファ206Dに出力するように構成されている。
 コンテキスト値更新部206Cは、1ビットを復号する度にコンテキスト値を更新する。
 ここで、コンテキスト値更新部206Cは、0及び1のうち、発生確率が高いシンボルをMPS(Most Probable Symbol)とし、発生確率が低いシンボルをLPS(Least Probable Symbol)とする。
 コンテキスト値更新部206Cは、MPSが発生した場合は、少し確率値を更新し、LPSが発生した場合は、大きく確率値を更新するような確率更新テーブルを用いてもよい。
(コンテキスト選択部206E)
 コンテキスト選択部206Eは、コンテキストバッファ206Dから読み出されたコンテキスト値、ビット位置及びシンタックスを用いて、コンテキスト値(出力用コンテキスト値)を生成して出力するように構成されている。詳細については後述する。
 last_sig_coeff_prefix:コンテキスト選択部206Eは、図38に示すように、行列サイズやビット位置に応じたコンテキスト番号表を作成してもよい。
 last_sig_coeff_block_prefix:コンテキスト選択部206Eは、図38に示すように、ブロックサイズやビット位置に応じたコンテキスト番号表を作成してもよい。
 coded_block_flag:コンテキスト選択部206Eは、図39に示すような復号済みの右隣接ブロックで、coded_block_flag=0であればコンテキスト番号を0とし、coded_block_flag=1コンテキスト番号を1としてもよい。
 sig_coeff_flag:コンテキスト選択部206Eは、ある基準値を、係数の位置や復号済みの右隣接ブロックのcoded_block_flagによって補正した値をコンテキスト番号とする。例えば、コンテキスト選択部206Eは、基準値について、例えば、最も左のブロックでは0とし、それ以外のブロックでは3とする。コンテキスト選択部206Eは、コンテキスト番号の補正には、復号済みの右隣接ブロックでcoded_block_flag=0の場合は、図40-1及び図40-3に示すような表を用い、coded_block_flag=1の場合には、図40-2に示すような表を用いてもよい。
 coeff_abs_level_greater1_flag、coeff_abs_level_greater2_flag:コンテキスト選択部206Eは、復号済みの右隣接ブロックで、絶対値(レベル値)が2以上の係数がある場合は、コンテキスト番号を0とし、そうでない場合は、コンテキスト番号を1としてもよい。
 コンテキストバッファ206Dは、図示しない制御情報に応じてこれらを出力するように構成されている。
 多値化部206Fは、2値化係数レベル値を多値化することによって係数レベル値を生成して出力するように構成されている。生成(算出)された係数レベル値は、ビット位置及びシンタックスとしてコンテキストバッファ206Dにも出力される。
 インター予測部Gは、フレームバッファ206Dから読み出された参照フレームを用いて、予測変位量を生成して出力するように構成されている。
 フレームバッファHは、復号変位量を取得して蓄積するように構成されている。フレームバッファHは、図示しない制御情報に応じて、参照フレームにおいて対応する頂点における復号変位量を出力するように構成されている。
(係数レベル値復号部206F2の動作)
 以下、図41を参照して、係数レベル値復号部206F2の動作の一例について説明する。
 図41に示すように、ステップS101において、係数レベル値復号部206F2は、last_sig_coeff_prefixとlast_sig_coeff_suffixが示す位置以降の係数は全て0として復号する。この後の処理は、ブロック単位で行われる。
 ステップS102において、係数レベル値復号部206F2は、coded_block_flagについての復号を行う。
 ステップS103において、係数レベル値復号部206F2は、coded_block_flagが0であるか1であるかの判定を行う。
 coded_block_flag=0の場合は、係数レベル値復号部206F2は、現在処理しているブロック内の係数については全て0として復号し、本動作は、ステップS116に進み、coded_block_flag=1の場合は、本動作は、ステップS104に進む。
 ステップS104において、係数レベル値復号部206F2は、現在処理しているブロック内で、last_sig_coeff_block_prefixとlast_sig_coeff_block_suffixが示す位置以降の係数は全て0として復号する。
 ステップS105において、係数レベル値復号部206F2は、sig_coeff_flagについての復号を行う。
 ステップS106において、係数レベル値復号部206F2は、sig_coeff_flagが0であるか1であるかの判定を行う。
 sig_coeff_flag=0の場合は、本動作は、ステップS116に進み、sig_coeff_flag=1の場合は、本動作は、ステップS107に進む。
 ステップS107において、係数レベル値復号部206F2は、coeff_abs_level_greater1_flagについての復号を行う。
 ステップS108において、係数レベル値復号部206F2は、coeff_abs_level_greater1_flagが0であるか1であるかの判定を行う。
 coeff_abs_level_greater1_flag=0の場合は、本動作は、ステップS113に進み、coeff_abs_level_greater1_flag=1の場合は、本動作は、ステップS109に進む。
 ステップS109において、係数レベル値復号部206F2は、coeff_abs_level_greater2_flagについての復号を行う。
 ステップS110において、係数レベル値復号部206F2は、coeff_abs_level_greater2_flagが0であるか1であるかの判定を行う。
 coeff_abs_level_greater2_flag=0の場合は、本動作は、ステップS113に進み、coeff_abs_level_greater1_flag=1の場合は、本動作は、ステップS112に進む。
 ステップS112において、係数レベル値復号部206F2は、coeff_abs_level_remainingについての復号を行う。ここで、係数レベル値復号部206F2は、coeff_abs_level_remainingの復号については、指数ゴロム復号を行った後に3を加算したものを復号後の係数レベル値とする。
 ステップS113において、係数レベル値復号部206F2は、coeff_sign_flagについての復号を行う。
 ステップS114において、係数レベル値復号部206F2は、coeff_sign_flagが0であるか1であるかの判定を行う。
 coeff_sign_flag=0の場合は、本動作は、ステップS116に進み、coeff_sign_flag=1の場合は、本動作は、ステップS115に進む。
 ステップS115において、係数レベル値復号部206F2は、復号済みの係数を負値化する。
 ステップS116において、係数レベル値復号部206F2は、現在処理しているブロックが最終ブロックであるか否かについて判定する。
 Yesの場合、本動作は、終了し、Noの場合、本動作は、ステップS111に進む。
 ステップS111において、係数レベル値復号部206F2は、次のブロックへの処理に進み、本動作は、ステップS102に戻る。
 次に、図42を参照して、算術復号部206B、コンテキスト選択部206E、コンテキスト値更新部206C及び多値化部206Fの動作の一例について説明する。
 次に、図42を参照して、算術復号部206B、コンテキスト選択部206E、コンテキスト値更新部206C及び多値化部206Fの動作の一例について説明する。
 図42に示すように、算術復号部206Bは、ステップS201において、算術復号部206Bは、初期化され、ステップS202において、初期コンテキスト値を設定する。
 算術復号部206Bは、ステップS203において、コンテキストを選択し、ステップS204において、算術復号を行う。
 ステップS205において、コンテキスト値更新部206C及びコンテキスト選択部206Eは、コンテキスト値を更新し、ステップS206において、多値化部206Fは、多値化を行う。
 多値化部206Fは、ステップS207において、全ての復号が完了したか否かについて判定する。Yesの場合、本動作は、ステップS208に進み、Noの場合、本動作は、ステップS203に戻る。
 ステップS208において、多値化部206Fは、コンテキスト値を退避させる。
(インター予測部206G)
 インター予測部206Gは、フレームバッファ206Hから読み出された参照フレームの復号変位量を用いてインター予測を行うことによって、インター予測残差及びインター予測変位量を生成して出力するように構成されている。
 インター予測部206Gは、interprediction_enabled_flagが1の場合のみ、かかるインター予測を行うように構成されている。
 インター予測部206Gは、空間領域でインター予測を行ってもよいし、周波数領域でインター予測を行ってもよい。インター予測は、時間的に過去の参照フレームと未来の参照フレームとを用いて、双方向予測を行ってもよい。
 インター予測部206Gは、空間領域でインター予測を行う場合は、対象フレームにおける細分割頂点の予測変位量について、参照フレームにおける対応する細分割頂点の復号変位量をそのまま参照して決定してもよい。
 或いは、対象フレームにおけるある細分割頂点の予測変位量は、複数の参照フレームにおける対応する細分割頂点の復号変位量を用いて、平均と分散を推定した正規分布に従って確率的に決定してもよい。その際は、分散はゼロとして一意的に平均のみで決定してもよい。
 或いは、対象フレームにおけるある細分割頂点の予測変位量は、複数の参照フレームにおける対応する細分割頂点の復号変位量を用いて、時間を説明変数、変位量を目的変数として推定した回帰曲線に基づいて決定してもよい。
 メッシュ符号化装置100において、フレームごとに符号化効率向上のために、かかる復号変位量の順番が並び替えられていてもよい。
 かかる場合、インター予測部206Gは、並び替えられた復号変位量に対してインター予測を行うように構成されていてもよい。
 参照フレームと復号対象フレームとの間の細分割頂点の対応関係は、制御情報によって示される。
 図43は、空間領域でインター予測が行われる場合の参照フレームと復号対象フレームとの間の細分割頂点の対応関係の一例について説明するための図である。
 加算器206Iは、インター予測部206Gから、インター予測残差及びインター予測変位量を取得するように構成されている。加算器206Iは、これらを加算して、量子化イントラ予測残差を生成して出力するように構成されている。生成(算出)された量子化イントラ予測残差は、フレームバッファ206Hにも出力される。
 逆量子化部206Jは、加算部206Iから取得した量子化イントラ予測残差に対して逆量子化を行い、イントラ予測残差を出力するように構成されている。
(変位量予測加算部206K)
 変位量予測加算部206Kは、基本メッシュ復号部202から出力された基本メッシュに基づき細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出したイントラ予測値と逆量子化部206Jから出力されたイントラ予測残差とを加算することで、変位量を復号するように構成されている。
 図44は、変位量予測加算部206Kの動作の一例を示すフローチャートである。
 図44に示すように、ステップS1において、変位量予測加算部206K現在の細分割回数itを1に設定する。
 ステップS2において、変位量予測加算部206Kは、現在の細分割回数itが上限細分割回数mdu_max_depth未満かどうかを判定する。
 Yesの場合、本動作は、ステップS3に進み、Noの場合、本動作は、終了する。
 ステップS3において、変位量予測加算部206Kは、全ての辺に対して分割が終了したかを判定する。
 Yesの場合、本動作は、ステップS8に進み、Noの場合、本動作は、ステップS4に進む。
 ステップS4において、変位量予測加算部206Kは、未分割辺を選択し、ステップS5に進む。
 ステップS5において、変位量予測加算部206Kは、選択辺を細分割数mdu_subdivision_numに基づき分割し、細分割頂点を生成する。
 ステップS6において、変位量予測加算部206Kは、両端の頂点の変位量から細分割頂点の変位量を予測し、ステップS7に進む。
 以下に、細分割頂点の変位量を予測する方法について説明する。
 図45及び図46は、それぞれ、Mid-edge分割法によって線分ABを分割して細分割頂点C生成する例、及び、細分割頂点Cの変位量を算出する例を模式的に示した図である。
 図45及び図46を参照して、変位量を予測する方法について説明する。
 第1に、端点A(t=0)と端点B(t=1)との間の頂点P(t=x)の法線ベクトルを計算する。ここで、端点A、Bの法線ベクトルをそれぞれ(a,a)、(b,b)とし、頂点Pの法線ベクトルを線形補完によって計算する。その際、頂点Pの法線ベクトルは、((1-t)a+tb,(1-t)a+tb)と計算できる。このとき、法線ベクトルについては、球面線型補間等の他の補完方法を用いて計算してもよい。
 端点A及び端点Bが、基本メッシュ上の頂点のとき、端点A及び端点Bの法線ベクトルは、それぞれの頂点に隣接する基本面の法線の平均値で算出される。細分割を行わない場合、基本面の法線ベクトルについて、計算しなくてもよい。
 第2に、計算した法線ベクトルと直交する傾きを計算し、細分割頂点Cの変位量を、端点Aから細分割頂点Cの区間で積分することで予測する。すなわち、細分割頂点Cの変位量を予測する場合の変位量は、以下の式で計算できる。
Figure JPOXMLDOC01-appb-M000007
 或いは、細分割頂点Cの変位量を周囲の基本メッシュの頂点や復号済みの細分割頂点を入力として、コサイン補完、キュービック補完、エルミート補完などの既知の補完方法を用いて変位量を予測してもよい。
 図47は、キュービック補完を用いて細分割頂点Dの変位量を予測する例である。図47に示すように、細分割頂点D周辺の頂点4つから三次曲線を計算し、細分割頂点Dの変位量を、曲線上の点と細分割頂点Dを結ぶベクトルとして予測してもよい。
 或いは、既に復号済みの基本面上の頂点や細分割頂点の変位量の平均値や最頻値、最大値、最小値等の統計値を用いて、細分割頂点の変位量を予測してもよい。
 図48は、辺KB、辺BJ、辺JK、辺BF、辺FAをそれぞれMid-edge分割法で分割した後に、辺ABを分割し細分割頂点Cを生成する例である。
 例えば、細分割頂点Cの変位量を予測するときに、最も距離が小さい点上の変位量を予測値としてもよいし、細分割頂点A、B、D、E、G、Iのように周囲の頂点の変位量の平均値を変位量の予測値としてもよいし、周囲の頂点の変位量の重み付け平均値を変位量の予測値としてもよい。 
 ステップS7において、変位量予測加算部206Kは、予測値と変位量誤差とを加算し、変位量を復号する。その後、ステップS3に進む。
 ステップS8において、変位量予測加算部206Kは、現在の細分割数itを1加算して、ステップS2に進む。
<変形例1>
 以下、図49を参照して、上述の第1実施形態の変形例1について、上述の第1実施形態との相違点に着目して説明する。
 図49は、本変形例1に係る変位量復号部206の機能ブロックの一例を示す図である。
 図49に示すように、本変形例1に係る変位量復号部206は、逆量子化部206Jの代わりに、逆量子化ウェーブレット変換部206Lを備える。
 すなわち、本変形例1では、逆量子化ウェーブレット変換部206Lは、加算器206Iから出力された量子化イントラ予測残差に対して逆量子化ウェーブレット変換を行い、イントラ予測残差を生成するように構成されている。
 上述のメッシュ符号化装置100及びメッシュ復号装置200は、コンピュータに各機能(各工程)を実行させるプログラムであって実現されていてもよい。
 なお、本実施形態によれば、例えば、動画像通信において総合的なサービス品質の向上を実現できることから、国連が主導する持続可能な開発目標(SDGs)の目標9「レジリエントなインフラを整備し、持続可能な産業化を推進するとともに、イノベーションの拡大を図る」に貢献することが可能となる。
1…メッシュ処理システム
100…メッシュ符号化装置
200…メッシュ復号装置
201…多重分離部
202…基本メッシュ復号部
202A…分離部
202B…イントラ復号部
202B1…任意イントラ復号部
202B2…整列部
202C…メッシュバッファ部
202D…接続情報復号部
202E…インター復号部
202E1…動きベクトル復号部
202E2…動きベクトルバッファ部
202E3…動きベクトル予測部
202E4…動きベクトル算出部
202E5…加算器
202E6…重複頂点探索部
202E7…重複頂点判別部
202E8…動きベクトル取得部
202E9…All skip mode判別部
202E10…Skip mode判別部
203…細分割部
203A…基本メッシュ細分割部
203A1…基本面分割数バッファ部
203A2…基本面分割数参照部
203A3…基本面分割数予測部
203A4…加算部
203A5…基本面分割部
203B…細分割メッシュ調整部
701…辺分割点移動部
702…細分割面分割部
204…メッシュ復号部
205…パッチ統合部
206…変位量復号部
206A…制御情報復号部
206B…算術復号部
206C…コンテキスト値更新部
206D…コンテキストバッファ
206E…コンテキスト選択部
206F…多値化部
206F2…係数レベル値復号部
206G…インター予測部
206H…フレームバッファ
206I…加算器
206J…逆量子化部
206K…変位量予測加算部
206L…逆量子化ウェーブレット変換部
207…映像復号部
 
 

Claims (5)

  1.  メッシュ復号装置であって、
     基本メッシュ復号部から出力された基本メッシュに基づいて細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出した前記イントラ予測値と逆量子化ウェーブレット変換部から出力されたイントラ予測残差とを加算することで、変位量を復号するように構成されている変位量予測加算部を備えることを特徴とするメッシュ復号装置。
  2.  前記変位量予測加算部は、前記細分割頂点の両端の点の法線ベクトルに基づいて、前記変位量を復号するように構成されている請求項1に記載のメッシュ復号装置。
  3.  前記変位量加算部は、復号済みの細分割頂点の変位量に基づいて、前記変位量を復号するように構成されている請求項1に記載のメッシュ復号装置。
  4.  メッシュ復号方法であって、
     基本メッシュビットストリームを復号し、基本メッシュを生成して出力する工程Aと、
     量子化イントラ予測残差に対して逆量子化ウェーブレット変換を行い、イントラ予測残差を生成する工程Bと、
     前記工程Aにおいて出力された前記基本メッシュに基づいて細分割頂点の変位量を予測してイントラ予測値を算出する工程Cと、
     前記工程Bにおいて出力されたイントラ予測残差と前記工程Cにおいて算出された前記イントラ予測値とを加算することで、変位量を復号する工程とを有することを特徴とするメッシュ復号方法。
  5.  コンピュータを、メッシュ復号装置として機能させるプログラムであって、
     前記メッシュ復号装置は、
      基本メッシュ復号部から出力された基本メッシュに基づいて細分割頂点の変位量をイントラ予測してイントラ予測値を算出し、算出した前記イントラ予測値と逆量子化ウェーブレット変換部から出力された予測残差とを加算することで、変位量を復号するように構成されている変位量予測加算部を備えることを特徴とするプログラム。
PCT/JP2023/029762 2022-10-13 2023-08-17 メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム WO2024079982A1 (ja)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2022165084A JP2024058008A (ja) 2022-10-13 2022-10-13 メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
JP2022-165084 2022-10-13

Publications (1)

Publication Number Publication Date
WO2024079982A1 true WO2024079982A1 (ja) 2024-04-18

Family

ID=90669456

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2023/029762 WO2024079982A1 (ja) 2022-10-13 2023-08-17 メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム

Country Status (2)

Country Link
JP (1) JP2024058008A (ja)
WO (1) WO2024079982A1 (ja)

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH10191391A (ja) * 1996-09-20 1998-07-21 Sony Corp データ処理装置および方法、動画像符号化装置および方法、並びに、動画像復号化装置および方法
JP2004537887A (ja) * 2001-06-06 2004-12-16 フランス テレコム 入れ子メッシュを導入した画像の符号化及び復号のための方法及び装置とそれに対応するプログラム
JP2012068881A (ja) * 2010-09-22 2012-04-05 Univ Of Tokyo 3次元動画像の圧縮に用いる基本単位及び当該基本単位の生成方法、当該基本単位を用いた3次元動画像の圧縮方法
US20200098137A1 (en) * 2018-09-26 2020-03-26 Google Llc Texture coordinate compression using texture atlas
WO2022075428A1 (ja) * 2020-10-09 2022-04-14 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH10191391A (ja) * 1996-09-20 1998-07-21 Sony Corp データ処理装置および方法、動画像符号化装置および方法、並びに、動画像復号化装置および方法
JP2004537887A (ja) * 2001-06-06 2004-12-16 フランス テレコム 入れ子メッシュを導入した画像の符号化及び復号のための方法及び装置とそれに対応するプログラム
JP2012068881A (ja) * 2010-09-22 2012-04-05 Univ Of Tokyo 3次元動画像の圧縮に用いる基本単位及び当該基本単位の生成方法、当該基本単位を用いた3次元動画像の圧縮方法
US20200098137A1 (en) * 2018-09-26 2020-03-26 Google Llc Texture coordinate compression using texture atlas
WO2022075428A1 (ja) * 2020-10-09 2022-04-14 パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置

Also Published As

Publication number Publication date
JP2024058008A (ja) 2024-04-25

Similar Documents

Publication Publication Date Title
JP7525178B2 (ja) 適応的動きベクトル解像度を用いるビデオ信号処理方法及び装置
TWI813126B (zh) 相依量化技術
CN112369022B (zh) 图像编码/解码方法和装置以及存储比特流的记录介质
KR102509347B1 (ko) 비디오 신호를 인코딩, 디코딩하는 방법 및 장치
GB2559062A (en) Adaptive transform method based on in-screen prediction and apparatus using the method
CN107529705A (zh) 解码器、编码器、解码和编码视频的方法及存储介质
JP2010251946A (ja) 画像符号化装置、方法およびプログラム、並びに、画像復号装置、方法およびプログラム
WO2024014045A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024014042A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024079982A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024079981A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024014043A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024014196A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024079983A1 (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
WO2024014195A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024014044A1 (ja) メッシュ復号装置、メッシュ符号化装置、メッシュ復号方法及びプログラム
WO2024147277A1 (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
CN114556927A (zh) 用于视频编码和解码的熵编码
JP2024152168A (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
JP2024152167A (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
WO2024143056A1 (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
WO2024143057A1 (ja) メッシュ復号装置、メッシュ復号方法及びプログラム
KR20240114281A (ko) 영상 부호화/복호화 방법 및 비트스트림을 저장하는 기록 매체
CN116648910A (zh) 视频译码中多个颜色分量的符号预测
CN118972568A (zh) 图像编码/解码方法和装置以及存储比特流的记录介质

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 23876990

Country of ref document: EP

Kind code of ref document: A1