WO2022149589A1 - 三次元データ復号方法、三次元データ符号化方法、三次元データ復号装置、及び三次元データ符号化装置 - Google Patents
三次元データ復号方法、三次元データ符号化方法、三次元データ復号装置、及び三次元データ符号化装置 Download PDFInfo
- Publication number
- WO2022149589A1 WO2022149589A1 PCT/JP2022/000172 JP2022000172W WO2022149589A1 WO 2022149589 A1 WO2022149589 A1 WO 2022149589A1 JP 2022000172 W JP2022000172 W JP 2022000172W WO 2022149589 A1 WO2022149589 A1 WO 2022149589A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- position information
- information
- point
- coordinate system
- dimensional data
- Prior art date
Links
- 238000000034 method Methods 0.000 title claims abstract description 408
- 238000006243 chemical reaction Methods 0.000 claims description 160
- 238000012545 processing Methods 0.000 description 217
- 238000010586 diagram Methods 0.000 description 167
- 230000008569 process Effects 0.000 description 165
- 230000005540 biological transmission Effects 0.000 description 125
- 238000004891 communication Methods 0.000 description 101
- 239000000872 buffer Substances 0.000 description 89
- 230000033001 locomotion Effects 0.000 description 64
- 238000013139 quantization Methods 0.000 description 61
- 238000013480 data collection Methods 0.000 description 52
- 230000006870 function Effects 0.000 description 33
- 238000012546 transfer Methods 0.000 description 31
- 238000004364 calculation method Methods 0.000 description 28
- 238000003860 storage Methods 0.000 description 24
- 230000006835 compression Effects 0.000 description 19
- 238000007906 compression Methods 0.000 description 19
- 238000013500 data storage Methods 0.000 description 18
- 238000012544 monitoring process Methods 0.000 description 18
- 230000002441 reversible effect Effects 0.000 description 16
- 230000004044 response Effects 0.000 description 14
- 238000001514 detection method Methods 0.000 description 13
- 239000000284 extract Substances 0.000 description 12
- 230000015572 biosynthetic process Effects 0.000 description 11
- 238000003786 synthesis reaction Methods 0.000 description 11
- 230000002093 peripheral effect Effects 0.000 description 10
- 230000009466 transformation Effects 0.000 description 10
- 238000012937 correction Methods 0.000 description 9
- 239000003550 marker Substances 0.000 description 9
- 230000001360 synchronised effect Effects 0.000 description 9
- 230000008878 coupling Effects 0.000 description 8
- 238000010168 coupling process Methods 0.000 description 8
- 238000005859 coupling reaction Methods 0.000 description 8
- 238000006073 displacement reaction Methods 0.000 description 8
- 230000008859 change Effects 0.000 description 7
- 238000007726 management method Methods 0.000 description 7
- 230000002194 synthesizing effect Effects 0.000 description 7
- 230000006837 decompression Effects 0.000 description 5
- 230000003287 optical effect Effects 0.000 description 5
- 238000000926 separation method Methods 0.000 description 5
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- TVMXDCGIABBOFY-UHFFFAOYSA-N octane Chemical compound CCCCCCCC TVMXDCGIABBOFY-UHFFFAOYSA-N 0.000 description 4
- 230000003044 adaptive effect Effects 0.000 description 3
- FFBHFFJDDLITSX-UHFFFAOYSA-N benzyl N-[2-hydroxy-4-(3-oxomorpholin-4-yl)phenyl]carbamate Chemical compound OC1=C(NC(=O)OCC2=CC=CC=C2)C=CC(=C1)N1CCOCC1=O FFBHFFJDDLITSX-UHFFFAOYSA-N 0.000 description 3
- 238000010276 construction Methods 0.000 description 3
- 230000001419 dependent effect Effects 0.000 description 3
- 238000010606 normalization Methods 0.000 description 3
- 230000003068 static effect Effects 0.000 description 3
- 230000001131 transforming effect Effects 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 230000009191 jumping Effects 0.000 description 2
- 230000007246 mechanism Effects 0.000 description 2
- 239000002023 wood Substances 0.000 description 2
- 238000012935 Averaging Methods 0.000 description 1
- 230000005856 abnormality Effects 0.000 description 1
- 230000001133 acceleration Effects 0.000 description 1
- 230000001174 ascending effect Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 238000004422 calculation algorithm Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 230000008034 disappearance Effects 0.000 description 1
- 238000009826 distribution Methods 0.000 description 1
- 230000009189 diving Effects 0.000 description 1
- 238000007689 inspection Methods 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
- 230000007774 longterm Effects 0.000 description 1
- 230000005389 magnetism Effects 0.000 description 1
- 239000000463 material Substances 0.000 description 1
- 238000003825 pressing Methods 0.000 description 1
- 238000011002 quantification Methods 0.000 description 1
- 238000007430 reference method Methods 0.000 description 1
- 238000009877 rendering Methods 0.000 description 1
- 238000010187 selection method Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 238000004904 shortening Methods 0.000 description 1
- 230000011664 signaling Effects 0.000 description 1
- 230000000153 supplemental effect Effects 0.000 description 1
- 238000013519 translation Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T9/00—Image coding
Definitions
- the present disclosure relates to a three-dimensional data coding method, a three-dimensional data decoding method, a three-dimensional data coding device, and a three-dimensional data decoding device.
- 3D data In the future, devices or services that utilize 3D data are expected to become widespread in a wide range of fields such as computer vision for autonomous operation of automobiles or robots, map information, monitoring, infrastructure inspection, or video distribution.
- the three-dimensional data is acquired by various methods such as a distance sensor such as a range finder, a stereo camera, or a combination of a plurality of monocular cameras.
- point cloud As one of the expression methods of 3D data, there is an expression method called point cloud that expresses the shape of a 3D structure by a point cloud in a 3D space. In the point cloud, the position and color of the point cloud are stored. Point clouds are expected to become the mainstream method for expressing 3D data, but point clouds have a very large amount of data. Therefore, in the storage or transmission of 3D data, it is essential to compress the amount of data by encoding, as in the case of 2D moving images (for example, MPEG-4 AVC or HEVC standardized by MPEG). Become.
- 2D moving images for example, MPEG-4 AVC or HEVC standardized by MPEG.
- the compression of the point cloud is partially supported by a public library (Point Cloud Library) that performs processing related to the point cloud.
- a public library Point Cloud Library
- Patent Document 1 a technique for searching and displaying facilities located around a vehicle using three-dimensional map data is known (see, for example, Patent Document 1).
- the coding efficiency can be improved or the processing amount can be reduced.
- the three-dimensional data decoding method acquires the bit stream including the coded position information in which the position information of the three-dimensional point is encoded, and decodes the coded position information to obtain the position information.
- the position information is represented in the Cartesian coordinate system
- the position information is shifted, and when the position information is represented in the polar coordinate system, the position information is not shifted.
- the three-dimensional data coding method generates coded position information by encoding the position information of the three-dimensional points, and the coded position information is decoded by the three-dimensional data decoding device.
- a bit stream including shift information indicating whether or not the three-dimensional data decoding device shifts the decoding position information is generated, and the decoding position information is orthogonal to the three-dimensional data decoding device based on the shift information.
- the decoded position information is shifted, and when the decoded position information is represented in the polar coordinate system, the decoded position information is not shifted.
- the present disclosure can provide a three-dimensional data coding method, a three-dimensional data decoding method, a three-dimensional data coding device, or a three-dimensional data decoding device that can improve the coding efficiency or reduce the processing amount.
- FIG. 1 is a diagram showing a configuration of a three-dimensional data coding / decoding system according to the first embodiment.
- FIG. 2 is a diagram showing a configuration example of point cloud data according to the first embodiment.
- FIG. 3 is a diagram showing a configuration example of a data file in which the point cloud data information according to the first embodiment is described.
- FIG. 4 is a diagram showing the types of point cloud data according to the first embodiment.
- FIG. 5 is a diagram showing a configuration of a first coding unit according to the first embodiment.
- FIG. 6 is a block diagram of the first coding unit according to the first embodiment.
- FIG. 7 is a diagram showing a configuration of a first decoding unit according to the first embodiment.
- FIG. 1 is a diagram showing a configuration of a three-dimensional data coding / decoding system according to the first embodiment.
- FIG. 2 is a diagram showing a configuration example of point cloud data according to the first embodiment.
- FIG. 3 is a diagram showing a
- FIG. 8 is a block diagram of the first decoding unit according to the first embodiment.
- FIG. 9 is a block diagram of the three-dimensional data coding apparatus according to the first embodiment.
- FIG. 10 is a diagram showing an example of position information according to the first embodiment.
- FIG. 11 is a diagram showing an example of an ocree representation of position information according to the first embodiment.
- FIG. 12 is a block diagram of the three-dimensional data decoding device according to the first embodiment.
- FIG. 13 is a block diagram of the attribute information coding unit according to the first embodiment.
- FIG. 14 is a block diagram of the attribute information decoding unit according to the first embodiment.
- FIG. 15 is a block diagram showing the configuration of the attribute information coding unit according to the first embodiment.
- FIG. 16 is a block diagram of the attribute information coding unit according to the first embodiment.
- FIG. 17 is a block diagram showing a configuration of an attribute information decoding unit according to the first embodiment.
- FIG. 18 is a block diagram of the attribute information decoding unit according to the first embodiment.
- FIG. 19 is a diagram showing a configuration of a second coding unit according to the first embodiment.
- FIG. 20 is a block diagram of a second coding unit according to the first embodiment.
- FIG. 21 is a diagram showing a configuration of a second decoding unit according to the first embodiment.
- FIG. 22 is a block diagram of a second decoding unit according to the first embodiment.
- FIG. 23 is a diagram showing a protocol stack related to PCC coded data according to the first embodiment.
- FIG. 24 is a diagram showing a configuration of a coding unit and a multiplexing unit according to the second embodiment.
- FIG. 25 is a diagram showing a configuration example of coded data according to the second embodiment.
- FIG. 26 is a diagram showing a configuration example of the coded data and the NAL unit according to the second embodiment.
- FIG. 27 is a diagram showing an example of semantics of pcc_nal_unit_type according to the second embodiment.
- FIG. 28 is a diagram showing an example of a prediction tree used in the three-dimensional data coding method according to the third embodiment.
- FIG. 29 is a flowchart showing an example of the three-dimensional data coding method according to the third embodiment.
- FIG. 30 is a flowchart showing an example of the three-dimensional data decoding method according to the third embodiment.
- FIG. 31 is a diagram for explaining a method of generating a predicted tree according to the third embodiment.
- FIG. 32 is a diagram for explaining a first example of the prediction mode according to the third embodiment.
- FIG. 33 is a diagram showing a second example of a table showing predicted values calculated in each prediction mode according to the third embodiment.
- FIG. 34 is a diagram showing a specific example of the second example of the table showing the predicted values calculated in each prediction mode according to the third embodiment.
- FIG. 35 is a diagram showing a third example of a table showing predicted values calculated in each prediction mode according to the third embodiment.
- FIG. 31 is a diagram for explaining a method of generating a predicted tree according to the third embodiment.
- FIG. 32 is a diagram for explaining a first example of the prediction mode according to the third embodiment.
- FIG. 33 is a diagram showing a second example of a table showing predicted values calculated in
- FIG. 36 is a diagram showing an example of the syntax of the header of the position information according to the third embodiment.
- FIG. 37 is a diagram showing an example of the syntax of position information according to the third embodiment.
- FIG. 38 is a diagram showing another example of the position information syntax according to the third embodiment.
- FIG. 39 is a block diagram of the three-dimensional data coding apparatus according to the fourth embodiment.
- FIG. 40 is a block diagram of the three-dimensional data decoding device according to the fourth embodiment.
- FIG. 41 is a block diagram of the three-dimensional data coding apparatus according to the fourth embodiment.
- FIG. 42 is a block diagram of the three-dimensional data decoding device according to the fourth embodiment.
- FIG. 43 is a diagram showing an example of inter-prediction according to the fourth embodiment.
- FIG. 44 is a diagram showing an example of SPS syntax according to the fourth embodiment.
- FIG. 45 is a diagram showing an example of GPS syntax according to the fourth embodiment.
- FIG. 46 is a flowchart of the three-dimensional data coding process according to the fourth embodiment.
- FIG. 47 is a flowchart of the three-dimensional data decoding process according to the fourth embodiment.
- FIG. 48 is a block diagram of the three-dimensional data coding apparatus according to the fifth embodiment.
- FIG. 49 is a block diagram of the three-dimensional data decoding device according to the fifth embodiment.
- FIG. 50 is a flowchart showing an example of a procedure for coding each three-dimensional point of the prediction tree according to the fifth embodiment.
- FIG. 51 is a flowchart showing an example of a procedure for decoding each three-dimensional point of the predicted tree according to the fifth embodiment.
- FIG. 52 is a block diagram of a three-dimensional data coding device according to a modified example of the fifth embodiment.
- FIG. 53 is a block diagram of a three-dimensional data decoding device according to a modified example of the fifth embodiment.
- FIG. 54 is an example of the GPS syntax according to the fifth embodiment.
- FIG. 55 is an example of the syntax of each three-dimensional point according to the fifth embodiment.
- FIG. 56 is a flowchart showing the three-dimensional data coding process according to the fifth embodiment.
- FIG. 57 is a flowchart showing the three-dimensional data decoding process according to the fifth embodiment.
- FIG. 58 is a flowchart showing a coordinate system switching process in the coding process according to the fifth embodiment.
- FIG. 59 is a flowchart showing a coordinate system switching process in the decoding process according to the fifth embodiment.
- FIG. 60 is a flowchart showing another example of the three-dimensional data coding process according to the fifth embodiment.
- FIG. 61 is a flowchart showing another example of the three-dimensional data decoding process according to the fifth embodiment.
- FIG. 62 is a block diagram of the position information coding unit according to the sixth embodiment.
- FIG. 63 is a block diagram of the position information coding unit according to the sixth embodiment.
- FIG. 64 is a block diagram of the position information coding unit according to the sixth embodiment.
- FIG. 65 is a block diagram of the position information decoding unit according to the sixth embodiment.
- FIG. 66 is a block diagram of the position information decoding unit according to the sixth embodiment.
- FIG. 67 is a block diagram of the position information decoding unit according to the sixth embodiment.
- FIG. 68 is a block diagram of the three-dimensional data coding apparatus according to the sixth embodiment.
- FIG. 69 is a block diagram of the three-dimensional data decoding device according to the sixth embodiment.
- FIG. 70 is a flowchart of the three-dimensional data decoding process according to the sixth embodiment.
- FIG. 71 is a flowchart of the three-dimensional data coding process according to the sixth embodiment.
- FIG. 72 is a flowchart of the three-dimensional data decoding process according to the sixth embodiment.
- FIG. 70 is a flowchart of the three-dimensional data decoding process according to the sixth embodiment.
- FIG. 73 is a block diagram of a position information coding unit that encodes position information in a Cartesian coordinate system according to the seventh embodiment.
- FIG. 74 is a diagram showing an example of shift processing for the position information of the orthogonal coordinate system according to the seventh embodiment.
- FIG. 75 is a diagram showing an example of shift processing for the position information of the orthogonal coordinate system according to the seventh embodiment.
- FIG. 76 is a block diagram of a position information coding unit that encodes position information in a polar coordinate system according to the seventh embodiment.
- FIG. 77 is a diagram showing an example of processing for position information in a polar coordinate system according to the seventh embodiment.
- FIG. 78 is a block diagram of a position information decoding unit that decodes position information in a Cartesian coordinate system according to the seventh embodiment.
- FIG. 79 is a block diagram of a position information decoding unit that decodes position information in a polar coordinate system according to the seventh embodiment.
- FIG. 80 is a block diagram of a position information coding unit that encodes the position information of the orthogonal coordinate system and the position information of the polar coordinate system according to the seventh embodiment.
- FIG. 81 is a block diagram of a position information decoding unit that decodes the position information of the orthogonal coordinate system and the position information of the polar coordinate system according to the seventh embodiment.
- FIG. 82 is a block diagram of a position information decoding unit that performs coordinate conversion according to the seventh embodiment.
- FIG. 83 is a flowchart of the three-dimensional data decoding process according to the seventh embodiment.
- FIG. 84 is a diagram showing an example of GPS syntax according to the seventh embodiment.
- FIG. 85 is a diagram showing an example of GDU header syntax according to the seventh embodiment.
- FIG. 86 is a flowchart of the three-dimensional data decoding process according to the seventh embodiment.
- FIG. 87 is a flowchart of the three-dimensional data coding process according to the seventh embodiment.
- FIG. 88 is a block diagram of the three-dimensional data creation device according to the eighth embodiment.
- FIG. 89 is a flowchart of the three-dimensional data creation method according to the eighth embodiment.
- FIG. 90 is a diagram showing a configuration of the system according to the eighth embodiment.
- FIG. 90 is a diagram showing a configuration of the system according to the eighth embodiment.
- FIG. 91 is a block diagram of the client device according to the eighth embodiment.
- FIG. 92 is a block diagram of the server according to the eighth embodiment.
- FIG. 93 is a flowchart of the three-dimensional data creation process by the client device according to the eighth embodiment.
- FIG. 94 is a flowchart of the sensor information transmission process by the client device according to the eighth embodiment.
- FIG. 95 is a flowchart of the three-dimensional data creation process by the server according to the eighth embodiment.
- FIG. 96 is a flowchart of the three-dimensional map transmission process by the server according to the eighth embodiment.
- FIG. 97 is a diagram showing a configuration of a modified example of the system according to the eighth embodiment.
- FIG. 98 is a diagram showing a configuration of a server and a client device according to the eighth embodiment.
- FIG. 99 is a diagram showing a configuration of a server and a client device according to the eighth embodiment.
- FIG. 100 is a flowchart of processing by the client device according to the eighth embodiment.
- FIG. 101 is a diagram showing a configuration of a sensor information collection system according to the eighth embodiment.
- FIG. 102 is a diagram showing an example of the system according to the eighth embodiment.
- FIG. 103 is a diagram showing a modified example of the system according to the eighth embodiment.
- FIG. 104 is a flowchart showing an example of application processing according to the eighth embodiment.
- FIG. 105 is a diagram showing a sensor range of various sensors according to the eighth embodiment.
- FIG. 106 is a diagram showing a configuration example of the automated driving system according to the eighth embodiment.
- FIG. 107 is a diagram showing a configuration example of a bit stream according to the eighth embodiment.
- FIG. 108 is a flowchart of the point group selection process according to the eighth embodiment.
- FIG. 109 is a diagram showing a screen example of the point group selection process according to the eighth embodiment.
- FIG. 110 is a diagram showing a screen example of the point group selection process according to the eighth embodiment.
- FIG. 111 is a diagram showing a screen example of the point group selection process according to the eighth embodiment.
- the position information is obtained by acquiring a bit stream including the coded position information in which the position information of the three-dimensional point is encoded and decoding the coded position information.
- the position information is represented in the Cartesian coordinate system, the position information is shifted, and when the position information is represented in the polar coordinate system, the position information is not shifted.
- the three-dimensional data decoding method it is possible to switch whether or not to perform shift processing on the position information depending on whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. ..
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding method can appropriately decode a bit stream with improved coding efficiency by performing shift processing when the position information is in a Cartesian coordinate system.
- the processing amount can be reduced by not performing the shift processing.
- the first flag information indicating whether or not the position information is represented in the polar coordinate system and the position information represented in the polar coordinate system are represented in the Cartesian coordinate system. It may include the second flag information indicating whether or not it is converted into the conversion position information.
- the shift may not be performed.
- the quantity indicated by the shift information is zero and is represented by the polar coordinate system.
- the shift process can be applied to the position information regardless of whether the position information is a Cartesian coordinate system or a polar coordinate system, and it is possible to control whether or not the shift process is performed. Since it is unnecessary, the process can be simplified.
- the position information is shifted based on the amount indicated by the shift information, and the position information is shifted.
- the quantity may be considered to be zero regardless of the quantity indicated by the shift information.
- the three-dimensional data decoding method considers that the amount of shift is zero regardless of the amount of shift indicated by the shift information. As a result, the processing amount of the three-dimensional data coding device that generates the bit stream can be reduced. Further, the three-dimensional data decoding method may be able to correctly decode the bitstream even if the bitstream contains an error.
- the bit stream contains shift information indicating the amount of the shift
- the position information is represented by the polar coordinate system, and the position information may not be shifted.
- the bitstream when the position information is in a polar coordinate system, the bitstream does not include the shift information. Therefore, the amount of bitstream data can be reduced.
- the bit stream includes coded information in which position information of a plurality of three-dimensional points including the three-dimensional point is encoded, and the coded information is a plurality of divisions obtained by dividing the plurality of three-dimensional points. It is divided into units, and the shift information may be included in a parameter set common to the plurality of division units.
- the bit stream includes coded information in which position information of a plurality of three-dimensional points including the three-dimensional point is encoded, and the coded information is a plurality of divisions obtained by dividing the plurality of three-dimensional points. It is divided into units, and the shift information may be included in the header for each of the plurality of division units.
- the position information when the position information is represented by the polar coordinate system, the position information may be converted into the converted position information represented by the orthogonal coordinate system, and the converted position information may be shifted.
- the three-dimensional data decoding method converts the position information of the polar coordinate system into the position information of the Cartesian coordinate system even when the encoded position information is the polar coordinate system, and the position information of the orthogonal coordinate system. Can be output.
- the three-dimensional data coding method generates coded position information by encoding the position information of the three-dimensional points, and the coded position information is decoded by the three-dimensional data decoding device.
- a bit stream including shift information indicating whether or not the three-dimensional data decoding device shifts the decoding position information is generated, and the decoding position information is orthogonal to the three-dimensional data decoding device based on the shift information.
- the decoded position information is shifted, and when the decoded position information is represented in the polar coordinate system, the decoded position information is not shifted.
- the three-dimensional data coding method determines whether or not the position information is shifted according to whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. It is possible to generate a bit stream that can be switched in the decoder.
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding device can appropriately decode the bit stream with improved coding efficiency by performing the shift process. Further, the three-dimensional data decoding device can reduce the processing amount by not performing the shift processing when the position information is in the polar coordinate system.
- the first flag information indicating whether or not the position information is represented in the polar coordinate system and the position information represented in the polar coordinate system are represented in the Cartesian coordinate system. It may include the second flag information indicating whether or not it is converted into the conversion position information.
- the shift may not be performed.
- the shift information indicates the amount of the shift at the time of shifting the decoded position information, and when the position information is represented by the polar coordinate system, the amount indicated by the shift information is zero, and the said.
- the three-dimensional data decoding device shifts the position information represented by the polar coordinate system by shifting the position information represented by the polar coordinate system based on the amount indicated by the shift information. It does not have to be.
- the shift process can be applied to the position information, and control of whether or not the shift process is performed is performed. Is not required, so that the processing in the three-dimensional data decoding device can be simplified.
- the shift information indicates the amount of the shift when the decoding position information is shifted, and when the position information is represented in the polar coordinate system. It is not necessary to store the shift information in the bit stream.
- the bitstream when the position information is in a polar coordinate system, the bitstream does not include the shift information. Therefore, the amount of bitstream data can be reduced.
- the bit stream includes coded information in which position information of a plurality of three-dimensional points including the three-dimensional point is encoded, and the coded information is a plurality of divisions obtained by dividing the plurality of three-dimensional points. It is divided into units, and the shift information may be included in a parameter set common to the plurality of division units.
- the bit stream includes coded information in which position information of a plurality of three-dimensional points including the three-dimensional point is encoded, and the coded information is a plurality of divisions obtained by dividing the plurality of three-dimensional points. It is divided into units, and the shift information may be included in the header for each of the plurality of division units.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to encode coded position information in which the position information of a three-dimensional point is encoded. A bit stream containing When represented by, the position information is not shifted.
- the three-dimensional data decoding device can switch whether or not to perform shift processing on the position information depending on whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. ..
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding device can appropriately decode a bit stream having improved coding efficiency by performing shift processing.
- the three-dimensional data decoding device can reduce the processing amount by not performing the shift processing.
- the three-dimensional data coding apparatus includes a processor and a memory, and the processor encodes the position information position information of the three-dimensional point by using the memory.
- the three-dimensional data decoding device shifts the decoded position information when the decoded position information is represented by the orthogonal coordinate system, and the decoded position information is represented by the polar coordinate system. If this is the case, the decoding position information is not shifted.
- the three-dimensional data coding apparatus determines whether or not the position information is shifted according to whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. It is possible to generate a bit stream that can be switched in the decoder.
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding device can appropriately decode the bit stream with improved coding efficiency by performing the shift process. Further, the three-dimensional data decoding device can reduce the processing amount by not performing the shift processing when the position information is in the polar coordinate system.
- a recording medium such as a system, method, integrated circuit, computer program or computer readable CD-ROM, and the system, method, integrated circuit, computer program. And may be realized by any combination of recording media.
- a three-dimensional data coding method and a three-dimensional data coding device for providing a function of transmitting and receiving necessary information according to an application in the coded data of a three-dimensional point cloud, and the code thereof.
- a three-dimensional data decoding method and a three-dimensional data decoding device for decoding the encoded data, a three-dimensional data multiplexing method for multiplexing the encoded data, and a three-dimensional data transmission method for transmitting the encoded data will be described. do.
- a first coding method and a second coding method are being studied as a coding method (coding method) for point group data, but the configuration of the coded data and the coded data are used as a system.
- the method of storing in the format is not defined, and there is a problem that the MUX processing (multiplexing), transmission or storage in the coding unit cannot be performed as it is.
- PCC Point Cloud Compression
- FIG. 1 is a diagram showing a configuration example of a three-dimensional data coding / decoding system according to the present embodiment.
- the three-dimensional data coding / decoding system includes a three-dimensional data coding / decoding system 4601, a three-dimensional data decoding system 4602, a sensor terminal 4603, and an external connection unit 4604.
- the three-dimensional data coding system 4601 generates coded data or multiplexed data by encoding point cloud data which is three-dimensional data.
- the three-dimensional data coding system 4601 may be a three-dimensional data coding device realized by a single device, or may be a system realized by a plurality of devices. Further, the three-dimensional data coding apparatus may include a part of a plurality of processing units included in the three-dimensional data coding system 4601.
- the three-dimensional data coding system 4601 includes a point cloud data generation system 4611, a presentation unit 4612, a coding unit 4613, a multiplexing unit 4614, an input / output unit 4615, and a control unit 4616.
- the point cloud data generation system 4611 includes a sensor information acquisition unit 4617 and a point cloud data generation unit 4618.
- the sensor information acquisition unit 4617 acquires sensor information from the sensor terminal 4603 and outputs the sensor information to the point cloud data generation unit 4618.
- the point cloud data generation unit 4618 generates point cloud data from the sensor information and outputs the point cloud data to the coding unit 4613.
- the presentation unit 4612 presents sensor information or point cloud data to the user. For example, the presentation unit 4612 displays information or an image based on sensor information or point cloud data.
- the coding unit 4613 encodes (compresses) the point cloud data, and outputs the obtained coded data, the control information obtained in the coding process, and other additional information to the multiplexing unit 4614.
- the additional information includes, for example, sensor information.
- the multiplexing unit 4614 generates multiplexed data by multiplexing the coded data input from the coding unit 4613, the control information, and the additional information.
- the format of the multiplexed data is, for example, a file format for storage or a packet format for transmission.
- the input / output unit 4615 (for example, the communication unit or the interface) outputs the multiplexed data to the outside.
- the multiplexed data is stored in a storage unit such as an internal memory.
- the control unit 4616 (or application execution unit) controls each processing unit. That is, the control unit 4616 controls coding, multiplexing, and the like.
- the sensor information may be input to the coding unit 4613 or the multiplexing unit 4614. Further, the input / output unit 4615 may output the point cloud data or the coded data as it is to the outside.
- the transmission signal (multiplexed data) output from the three-dimensional data coding system 4601 is input to the three-dimensional data decoding system 4602 via the external connection unit 4604.
- the three-dimensional data decoding system 4602 generates point cloud data, which is three-dimensional data, by decoding encoded data or multiplexed data.
- the three-dimensional data decoding system 4602 may be a three-dimensional data decoding device realized by a single device, or may be a system realized by a plurality of devices. Further, the three-dimensional data decoding device may include a part of a plurality of processing units included in the three-dimensional data decoding system 4602.
- the three-dimensional data decoding system 4602 includes a sensor information acquisition unit 4621, an input / output unit 4622, a demultiplexing unit 4623, a decoding unit 4624, a presentation unit 4625, a user interface 4626, and a control unit 4627.
- the sensor information acquisition unit 4621 acquires sensor information from the sensor terminal 4603.
- the input / output unit 4622 acquires the transmission signal, decodes the multiplexed data (file format or packet) from the transmitted signal, and outputs the multiplexed data to the demultiplexed unit 4623.
- the demultiplexing unit 4623 acquires coded data, control information and additional information from the multiplexing data, and outputs the coded data, control information and additional information to the decoding unit 4624.
- the decoding unit 4624 reconstructs the point cloud data by decoding the coded data.
- the presentation unit 4625 presents the point cloud data to the user. For example, the presentation unit 4625 displays information or an image based on the point cloud data.
- the user interface 4626 acquires instructions based on user operations.
- the control unit 4627 (or application execution unit) controls each processing unit. That is, the control unit 4627 controls demultiplexing, decoding, presentation, and the like.
- the input / output unit 4622 may acquire the point cloud data or the coded data as it is from the outside. Further, the presentation unit 4625 may acquire additional information such as sensor information and present information based on the additional information. Further, the presentation unit 4625 may make a presentation based on the user's instruction acquired by the user interface 4626.
- the sensor terminal 4603 generates sensor information, which is information obtained by the sensor.
- the sensor terminal 4603 is a terminal equipped with a sensor or a camera, and includes, for example, a moving object such as an automobile, a flying object such as an airplane, a mobile terminal, or a camera.
- the sensor information that can be acquired by the sensor terminal 4603 is, for example, (1) the distance between the sensor terminal 4603 and the object obtained from the LIDAR, the millimeter-wave radar, or the infrared sensor, or the reflectance of the object, and (2) a plurality.
- the sensor information may include the attitude, orientation, gyro (angular velocity), position (GPS information or altitude), speed, acceleration, and the like of the sensor.
- the sensor information may include temperature, atmospheric pressure, humidity, magnetism, and the like.
- the external connection unit 4604 is realized by communication with an integrated circuit (LSI or IC), an external storage unit, a cloud server via the Internet, broadcasting, or the like.
- LSI integrated circuit
- IC integrated circuit
- cloud server via the Internet, broadcasting, or the like.
- FIG. 2 is a diagram showing the structure of point cloud data.
- FIG. 3 is a diagram showing a configuration example of a data file in which information on point cloud data is described.
- the point cloud data includes data of a plurality of points.
- the data at each point includes position information (three-dimensional coordinates) and attribute information for the position information.
- a point cloud is a collection of multiple points. For example, a point cloud indicates a three-dimensional shape of an object.
- Position information such as three-dimensional coordinates may be called geometry.
- the data at each point may include attribute information (attribute) of a plurality of attribute types.
- the attribute type is, for example, color or reflectance.
- One attribute information may be associated with one position information, or attribute information having a plurality of different attribute types may be associated with one position information. Further, a plurality of attribute information of the same attribute type may be associated with one position information.
- the configuration example of the data file shown in FIG. 3 is an example in which the position information and the attribute information have a one-to-one correspondence, and shows the position information and the attribute information of N points constituting the point cloud data. There is.
- the position information is, for example, information on three axes of x, y, and z.
- the attribute information is, for example, RGB color information.
- a typical data file is a ply file or the like.
- FIG. 4 is a diagram showing the types of point cloud data.
- the point cloud data includes a static object and a dynamic object.
- the static object is 3D point cloud data at an arbitrary time (certain time).
- a dynamic object is three-dimensional point cloud data that changes over time.
- the three-dimensional point cloud data at a certain time is referred to as a PCC frame or a frame.
- the object may be a point cloud whose area is limited to some extent like ordinary video data, or a large-scale point cloud whose area is not limited such as map information.
- the sensor information is acquired by various methods such as a distance sensor such as LIDAR or a range finder, a stereo camera, or a combination of a plurality of monocular cameras.
- the point cloud data generation unit 4618 generates point cloud data based on the sensor information obtained by the sensor information acquisition unit 4617.
- the point cloud data generation unit 4618 generates position information as point cloud data, and adds attribute information for the position information to the position information.
- the point cloud data generation unit 4618 may process the point cloud data when generating position information or adding attribute information. For example, the point cloud data generation unit 4618 may reduce the amount of data by deleting the point clouds whose positions overlap. Further, the point cloud data generation unit 4618 may convert the position information (position shift, rotation, normalization, etc.), or may render the attribute information.
- point cloud data generation system 4611 is included in the three-dimensional data coding system 4601 in FIG. 1, it may be independently provided outside the three-dimensional data coding system 4601.
- the coding unit 4613 generates coded data by coding the point cloud data based on a predetermined coding method.
- a predetermined coding method There are roughly the following two types of coding methods.
- the first is a coding method using position information, and this coding method will be hereinafter referred to as a first coding method.
- the second is a coding method using a video codec, and this coding method will be hereinafter referred to as a second coding method.
- the decoding unit 4624 decodes the point cloud data by decoding the coded data based on a predetermined coding method.
- the multiplexing unit 4614 generates multiplexed data by multiplexing the coded data using an existing multiplexing method.
- the generated multiplexed data is transmitted or accumulated.
- the multiplexing unit 4614 multiplexes other media such as video, audio, subtitles, applications, and files, or reference time information. Further, the multiplexing unit 4614 may further multiplex the attribute information related to the sensor information or the point cloud data.
- the multiplexing method or file format includes ISOBMFF, MPEG-DASH, MMT, MPEG-2 TS Systems, RMP, etc., which are ISOBMFF-based transmission methods.
- the demultiplexing unit 4623 extracts PCC coded data, other media, time information, etc. from the multiplexing data.
- the input / output unit 4615 transmits the multiplexed data by using a method suitable for the medium to be transmitted or the medium to be stored, such as broadcasting or communication.
- the input / output unit 4615 may communicate with other devices via the Internet, or may communicate with a storage unit such as a cloud server.
- http http, ftp, TCP, UDP, etc. are used.
- a PULL type communication method may be used, or a PUSH type communication method may be used.
- Either wired transmission or wireless transmission may be used.
- Ethernet registered trademark
- USB registered trademark
- RS-232C USB-232C
- HDMI registered trademark
- coaxial cable or the like
- wireless transmission a wireless LAN, Wi-Fi (registered trademark), Bluetooth (registered trademark), millimeter wave, or the like is used.
- DVB-T2 DVB-S2, DVB-C2, ATSC3.0, ISDB-S3 and the like are used.
- FIG. 5 is a diagram showing the configuration of the first coding unit 4630, which is an example of the coding unit 4613 that encodes the first coding method.
- FIG. 6 is a block diagram of the first coding unit 4630.
- the first coding unit 4630 generates coded data (coded stream) by coding the point cloud data by the first coding method.
- the first coding unit 4630 includes a position information coding unit 4631, an attribute information coding unit 4632, an additional information coding unit 4633, and a multiplexing unit 4634.
- the first coding unit 4630 has a feature of performing coding while being aware of the three-dimensional structure. Further, the first coding unit 4630 has a feature that the attribute information coding unit 4632 performs coding using the information obtained from the position information coding unit 4631.
- the first coding method is also called GPCC (Geometry based PCC).
- the point cloud data is PCC point cloud data such as a PLY file, or PCC point cloud data generated from sensor information, and is position information (Position), attribute information (Attribute), and other additional information (MetaData). including.
- the position information is input to the position information coding unit 4631, the attribute information is input to the attribute information coding unit 4632, and the additional information is input to the additional information coding unit 4633.
- the position information coding unit 4631 generates coded position information (Compressed Geometry) which is coded data by encoding the position information.
- the position information coding unit 4631 encodes the position information by using an N-branch structure such as an octa-tree. Specifically, in the octane tree, the target space is divided into eight nodes (subspaces), and 8-bit information (occupancy code) indicating whether or not each node contains a point cloud is generated. .. Further, the node including the point cloud is further divided into eight nodes, and 8-bit information indicating whether or not each of the eight nodes includes the point cloud is generated. This process is repeated until it becomes equal to or less than the threshold value of the number of point clouds included in the predetermined hierarchy or node.
- the attribute information coding unit 4632 generates coded attribute information (Compressed Attribute) which is coded data by encoding using the configuration information generated by the position information coding unit 4631. For example, the attribute information coding unit 4632 determines a reference point (reference node) to be referred to in the coding of the target point (target node) to be processed based on the octal tree structure generated by the position information coding unit 4631. do. For example, the attribute information coding unit 4632 refers to a node whose parent node in the octal tree is the same as the target node among the peripheral nodes or adjacent nodes. The method of determining the reference relationship is not limited to this.
- the attribute information coding process may include at least one of a quantization process, a prediction process, and an arithmetic coding process.
- the reference means that the reference node is used to calculate the predicted value of the attribute information, or the state of the reference node (for example, occupancy indicating whether or not the reference node contains a point group) is used to determine the encoding parameter. Information) is used.
- the coding parameter is a quantization parameter in the quantization process, a context in arithmetic coding, or the like.
- the additional information coding unit 4633 generates coded additional information (Compressed MetaData) which is coded data by encoding the compressible data among the additional information.
- Compressed MetaData coded additional information
- the multiplexing unit 4634 generates a coded stream (Compressed Stream) which is coded data by multiplexing the coded position information, the coded attribute information, the coded additional information, and other additional information.
- the generated coded stream is output to a processing unit of a system layer (not shown).
- FIG. 7 is a diagram showing the configuration of the first decoding unit 4640.
- FIG. 8 is a block diagram of the first decoding unit 4640.
- the first decoding unit 4640 generates point cloud data by decoding the coded data (coded stream) encoded by the first coding method by the first coding method.
- the first decoding unit 4640 includes a demultiplexing unit 4641, a position information decoding unit 4642, an attribute information decoding unit 4643, and an additional information decoding unit 4644.
- a coded stream (Compressed Stream), which is coded data, is input to the first decoding unit 4640 from a processing unit of a system layer (not shown).
- the demultiplexing unit 4641 separates the coded position information (Compressed Geometry), the coded attribute information (Compressed Attribute), the coded additional information (Compressed Metadata), and other additional information from the coded data.
- the position information decoding unit 4642 generates position information by decoding the coded position information. For example, the position information decoding unit 4642 restores the position information of the point cloud represented by the three-dimensional coordinates from the coded position information represented by the N-branch structure such as the octal tree.
- the attribute information decoding unit 4643 decodes the coded attribute information based on the configuration information generated by the position information decoding unit 4642. For example, the attribute information decoding unit 4643 determines a reference point (reference node) to be referred to in decoding the target point (target node) to be processed, based on the octave tree structure obtained by the position information decoding unit 4642. For example, the attribute information decoding unit 4643 refers to a node in which the parent node in the octal tree is the same as the target node among the peripheral nodes or adjacent nodes. The method of determining the reference relationship is not limited to this.
- the attribute information decoding process may include at least one of an inverse quantization process, a prediction process, and an arithmetic decoding process.
- the reference is the occupancy information indicating whether or not the reference node is used to calculate the predicted value of the attribute information, or the state of the reference node (for example, whether or not the reference node contains a point cloud) is used to determine the decoding parameter. ) Is used.
- the decoding parameter is a quantization parameter in the inverse quantization process, a context in arithmetic decoding, or the like.
- the additional information decoding unit 4644 generates additional information by decoding the coded additional information. Further, the first decoding unit 4640 uses the additional information necessary for the decoding process of the position information and the attribute information at the time of decoding, and outputs the additional information necessary for the application to the outside.
- FIG. 9 is a block diagram of the position information coding unit 2700 according to the present embodiment.
- the position information coding unit 2700 includes an ocree generation unit 2701, a geometric information calculation unit 2702, a coding table selection unit 2703, and an entropy coding unit 2704.
- the ocree generation unit 2701 generates, for example, an ocree from the input position information, and generates an occupancy code for each node of the ocree.
- the geometric information calculation unit 2702 acquires information indicating whether or not the node adjacent to the target node is an occupied node. For example, the geometric information calculation unit 2702 calculates the occupancy information of the adjacent node (information indicating whether or not the adjacent node is an occupancy node) from the occupancy code of the parent node to which the target node belongs. Further, the geometric information calculation unit 2702 may save the encoded nodes in a list and search for adjacent nodes from the list. The geometric information calculation unit 2702 may switch the adjacent node according to the position in the parent node of the target node.
- the coding table selection unit 2703 selects a coding table to be used for entropy coding of the target node using the occupancy information of the adjacent node calculated by the geometric information calculation unit 2702. For example, the coded table selection unit 2703 may generate a bit string using the occupancy information of the adjacent node, and select the coded table of the index number generated from the bit string.
- the entropy coding unit 2704 generates coded position information and metadata by performing entropy coding on the occupancy code of the target node using the coding table of the selected index number.
- the entropy coding unit 2704 may add information indicating the selected coding table to the coding position information.
- the position information (position data) is converted into an octa-tree structure (octree-ized) and then coded.
- the ocree tree structure consists of nodes and leaves. Each node has eight nodes or leaves, and each leaf has voxel (VXL) information.
- FIG. 10 is a diagram showing a structural example of position information including a plurality of voxels.
- FIG. 11 is a diagram showing an example in which the position information shown in FIG. 10 is converted into an octal tree structure.
- the leaves 1, 2 and 3 represent the voxels VXL1, VXL2 and VXL3 shown in FIG. 10, respectively, and represent the VXL (hereinafter, effective VXL) including the point cloud.
- the node 1 corresponds to the entire space including the position information of FIG.
- the entire space corresponding to node 1 is divided into eight nodes, and among the eight nodes, the node containing the valid VXL is further divided into eight nodes or leaves, and this process is repeated for the hierarchy of the tree structure.
- each node corresponds to a subspace, and has information (occupancy code) indicating at which position the next node or leaf is held after division as node information.
- the lowest block is set in the leaf, and the number of point clouds included in the leaf is held as leaf information.
- FIG. 12 is a block diagram of the position information decoding unit 2710 according to the present embodiment.
- the position information decoding unit 2710 includes an octane tree generation unit 2711, a geometric information calculation unit 2712, a coding table selection unit 2713, and an entropy decoding unit 2714.
- the ocree generation unit 2711 generates an ocree in a certain space (node) by using the header information or metadata of the bitstream. For example, the 8-branch tree generation unit 2711 creates a large space (root node) using the x-axis, y-axis, and z-axis directions of a certain space added to the header information, and uses that space as the x-axis. Eight small spaces A (nodes A0 to A7) are generated by dividing into two in the y-axis and z-axis directions, respectively, to generate an eight-part tree. Further, nodes A0 to A7 are sequentially set as target nodes.
- the geometric information calculation unit 2712 acquires occupancy information indicating whether or not the node adjacent to the target node is an occupancy node. For example, the geometric information calculation unit 2712 calculates the occupancy information of the adjacent node from the occupancy code of the parent node to which the target node belongs. Further, the geometric information calculation unit 2712 may save the decoded nodes in a list and search for adjacent nodes from the list. The geometric information calculation unit 2712 may switch the adjacent node according to the position in the parent node of the target node.
- the coding table selection unit 2713 selects a coding table (decoding table) to be used for entropy decoding of the target node using the occupancy information of the adjacent node calculated by the geometric information calculation unit 2712. For example, the coded table selection unit 2713 may generate a bit string using the occupancy information of the adjacent node and select the coded table of the index number generated from the bit string.
- a coding table decoding table
- the entropy decoding unit 2714 generates position information by entropy decoding the occupancy code of the target node using the selected coding table.
- the entropy decoding unit 2714 may decode and acquire the information of the selected coding table from the bitstream, and may entropy-decode the occupancy code of the target node using the coding table indicated by the information. ..
- FIG. 13 is a block diagram showing a configuration example of the attribute information coding unit A100.
- the attribute information coding unit may include a plurality of coding units that execute different coding methods. For example, the attribute information coding unit may switch between the following two methods according to the use case.
- the attribute information coding unit A100 includes a LoD attribute information coding unit A101 and a conversion attribute information coding unit A102.
- the LoD attribute information coding unit A101 classifies each 3D point into a plurality of layers using the position information of the 3D points, predicts the attribute information of the 3D points belonging to each layer, and encodes the predicted residual. To become.
- each classified layer is referred to as LoD (Level of Detail).
- the conversion attribute information coding unit A102 encodes the attribute information using RAHT (Region Adaptive Hierarchical Transfer Form). Specifically, the conversion attribute information coding unit A102 generates high-frequency components and low-frequency components of each layer by applying RAHT or Har conversion to each attribute information based on the position information of the three-dimensional point. Then, those values are encoded by using quantization, entropy coding, or the like.
- RAHT Registered Adaptive Hierarchical Transfer Form
- FIG. 14 is a block diagram showing a configuration example of the attribute information decoding unit A110.
- the attribute information decoding unit may include a plurality of decoding units that execute different decoding methods. For example, the attribute information decoding unit may switch and decode the following two methods based on the information included in the header and the metadata.
- the attribute information decoding unit A110 includes a LoD attribute information decoding unit A111 and a conversion attribute information decoding unit A112.
- the LoD attribute information decoding unit A111 classifies each three-dimensional point into a plurality of layers using the position information of the three-dimensional points, and decodes the attribute value while predicting the attribute information of the three-dimensional points belonging to each layer.
- the conversion attribute information decoding unit A112 decodes the attribute information using RAHT (Region Adaptive Hierarchical Transfer Form). Specifically, the conversion attribute information decoding unit A112 applies the invoke RAHT or invoke Haar conversion to the high frequency component and the low frequency component of each attribute value based on the position information of the three-dimensional point to obtain the attribute value. Decrypt.
- RAHT Restion Adaptive Hierarchical Transfer Form
- FIG. 15 is a block diagram showing the configuration of the attribute information coding unit 3140, which is an example of the LoD attribute information coding unit A101.
- the attribute information coding unit 3140 includes a LoD generation unit 3141, a peripheral search unit 3142, a prediction unit 3143, a prediction residual calculation unit 3144, a quantization unit 3145, an arithmetic coding unit 3146, and an inverse quantization unit. It includes 3147, a decoding value generation unit 3148, and a memory 3149.
- LoD generation unit 3141 generates LoD using the position information of the three-dimensional point.
- the surrounding search unit 3142 searches for neighboring three-dimensional points adjacent to each three-dimensional point by using the LoD generation result by the LoD generation unit 3141 and the distance information indicating the distance between each three-dimensional point.
- the prediction unit 3143 generates a prediction value of the attribute information of the target three-dimensional point to be encoded.
- the predicted residual calculation unit 3144 calculates (generates) the predicted residual of the predicted value of the attribute information generated by the prediction unit 3143.
- the quantization unit 3145 quantizes the predicted residual of the attribute information calculated by the predicted residual calculation unit 3144.
- the arithmetic coding unit 3146 arithmetically encodes the predicted residual after being quantized by the quantization unit 3145.
- the arithmetic coding unit 3146 outputs a bit stream including an arithmetically coded predicted residual to, for example, a three-dimensional data decoding device.
- the predicted residual may be binarized by, for example, the quantization unit 3145 before being arithmetically coded by the arithmetic coding unit 3146.
- the arithmetic coding unit 3146 may initialize the coding table used for arithmetic coding before arithmetic coding.
- the arithmetic coding unit 3146 may initialize the coding table used for arithmetic coding for each layer.
- the arithmetic coding unit 3146 may include information indicating the position of the layer in which the coding table is initialized in the bit stream and output the information.
- the dequantization unit 3147 dequantizes the predicted residual after being quantized by the quantization unit 3145.
- the decoded value generation unit 3148 generates a decoded value by adding the predicted value of the attribute information generated by the prediction unit 3143 and the predicted residual after dequantization by the inverse quantization unit 3147.
- the memory 3149 is a memory that stores the decoded value of the attribute information of each three-dimensional point decoded by the decoded value generation unit 3148. For example, when the prediction unit 3143 generates a predicted value of an unencoded three-dimensional point, the prediction unit 3143 generates the predicted value by using the decoded value of the attribute information of each three-dimensional point stored in the memory 3149. ..
- FIG. 16 is a block diagram of the attribute information coding unit 6600, which is an example of the conversion attribute information coding unit A102.
- the attribute information coding unit 6600 includes a sorting unit 6601, a Har conversion unit 6602, a quantization unit 6603, an inverse quantization unit 6604, an inverse Haar conversion unit 6605, a memory 6606, and an arithmetic coding unit 6607. Be prepared.
- the sort unit 6601 generates a Morton code using the position information of the three-dimensional points, and sorts a plurality of three-dimensional points in the order of the Morton code.
- the Haar conversion unit 6602 generates a coding coefficient by applying the Haar conversion to the attribute information.
- the quantization unit 6603 quantizes the coding coefficient of the attribute information.
- the dequantization unit 6604 dequantizes the coding coefficient after quantization.
- the inverse Haar conversion unit 6605 applies the inverse Har conversion to the coding coefficient.
- the memory 6606 stores the values of the attribute information of the plurality of decoded three-dimensional points. For example, the attribute information of the decoded three-dimensional point stored in the memory 6606 may be used for predicting an unencoded three-dimensional point.
- the arithmetic coding unit 6607 calculates ZeroCnt from the coding coefficient after quantization, and arithmetically encodes ZeroCnt. In addition, the arithmetic coding unit 6607 arithmetically encodes the non-zero coding coefficient after quantization. The arithmetic coding unit 6607 may binarize the coding coefficient before arithmetic coding. Further, the arithmetic coding unit 6607 may generate and encode various header information.
- FIG. 17 is a block diagram showing the configuration of the attribute information decoding unit 3150, which is an example of the LoD attribute information decoding unit A111.
- the attribute information decoding unit 3150 includes a LoD generation unit 3151, a peripheral search unit 3152, a prediction unit 3153, an arithmetic decoding unit 3154, an inverse quantization unit 3155, a decoding value generation unit 3156, and a memory 3157. ..
- the LoD generation unit 3151 generates LoD using the position information of the three-dimensional point decoded by the position information decoding unit (not shown in FIG. 17).
- the surrounding search unit 3152 searches for neighboring three-dimensional points adjacent to each three-dimensional point by using the LoD generation result by the LoD generation unit 3151 and the distance information indicating the distance between each three-dimensional point.
- the prediction unit 3153 generates a predicted value of the attribute information of the target three-dimensional point to be decoded.
- the arithmetic decoding unit 3154 arithmetically decodes the predicted residual in the bit stream acquired from the attribute information coding unit 3140 shown in FIG.
- the arithmetic decoding unit 3154 may initialize the decoding table used for arithmetic decoding.
- the arithmetic decoding unit 3154 initializes the decoding table used for arithmetic decoding for the layer subjected to the coding process by the arithmetic coding unit 3146 shown in FIG.
- the arithmetic decoding unit 3154 may initialize the decoding table used for arithmetic decoding for each layer. Further, the arithmetic decoding unit 3154 may initialize the decoding table based on the information included in the bitstream indicating the position of the layer in which the coding table is initialized.
- the dequantization unit 3155 dequantizes the predicted residual that is arithmetically decoded by the arithmetic decoding unit 3154.
- the decoded value generation unit 3156 generates a decoded value by adding the predicted value generated by the prediction unit 3153 and the predicted residual after dequantization by the inverse quantization unit 3155.
- the decoded value generation unit 3156 outputs the decoded attribute information data to another device.
- the memory 3157 is a memory that stores the decoded value of the attribute information of each three-dimensional point decoded by the decoded value generation unit 3156. For example, when the prediction unit 3153 generates a predicted value of a three-dimensional point that has not been decoded yet, the prediction unit 3153 generates a predicted value by using the decoded value of the attribute information of each three-dimensional point stored in the memory 3157. ..
- FIG. 18 is a block diagram of the attribute information decoding unit 6610, which is an example of the conversion attribute information decoding unit A112.
- the attribute information decoding unit 6610 includes an arithmetic decoding unit 6611, an inverse quantization unit 6612, an inverse Har conversion unit 6613, and a memory 6614.
- the arithmetic decoding unit 6611 arithmetically decodes ZeroCnt and the coding coefficient included in the bit stream.
- the arithmetic decoding unit 6611 may decode various header information.
- the dequantization unit 6612 dequantizes the arithmetically decoded coding coefficient.
- the inverse Haar conversion unit 6613 applies the inverse Har conversion to the coding coefficient after the inverse quantization.
- the memory 6614 stores the values of the attribute information of the plurality of decoded three-dimensional points. For example, the attribute information of the decoded three-dimensional point stored in the memory 6614 may be used for predicting the undecoded three-dimensional point.
- FIG. 19 is a diagram showing the configuration of the second coding unit 4650.
- FIG. 20 is a block diagram of the second coding unit 4650.
- the second coding unit 4650 generates coded data (coded stream) by coding the point cloud data by the second coding method.
- the second coding unit 4650 includes an additional information generation unit 4651, a position image generation unit 4652, an attribute image generation unit 4653, a video coding unit 4654, an additional information coding unit 4655, and a multiplexing unit 4656. And include.
- the second coding unit 4650 generates a position image and an attribute image by projecting the three-dimensional structure onto the two-dimensional image, and encodes the generated position image and the attribute image using an existing video coding method. It has the feature.
- the second coding method is also called VPCC (Video based PCC).
- the point cloud data is PCC point cloud data such as a PLY file, or PCC point cloud data generated from sensor information, and includes position information (Position), attribute information (Attribute), and other additional information (MetaData).
- Position information Position
- attribute information Attribute
- MetaData Other additional information
- the additional information generation unit 4651 generates map information of a plurality of two-dimensional images by projecting the three-dimensional structure onto the two-dimensional image.
- the position image generation unit 4652 generates a position image (Geometry Image) based on the position information and the map information generated by the additional information generation unit 4651.
- This position image is, for example, a distance image in which a distance (Dept) is shown as a pixel value.
- this distance image may be an image in which a plurality of point groups are viewed from one viewpoint (an image in which a plurality of point groups are projected on one two-dimensional plane), or a plurality of point groups from a plurality of viewpoints. It may be a plurality of images that have been viewed, or it may be a single image that is a combination of these plurality of images.
- the attribute image generation unit 4653 generates an attribute image based on the attribute information and the map information generated by the additional information generation unit 4651.
- This attribute image is, for example, an image in which attribute information (for example, color (RGB)) is shown as a pixel value.
- RGB color
- this image may be an image in which a plurality of point groups are viewed from one viewpoint (an image in which a plurality of point groups are projected on one two-dimensional plane), or a plurality of point groups are viewed from a plurality of viewpoints. It may be a plurality of images viewed, or it may be a single image in which these plurality of images are integrated.
- the video coding unit 4654 encodes the position image and the attribute image by using the video coding method, so that the coded position image (Compressed Geometry Image) and the coded attribute image (Compressed Attribute Image) which are the coded data are encoded. ) Is generated.
- the video coding method any known coding method may be used.
- the video coding method is AVC, HEVC, or the like.
- the additional information coding unit 4655 generates encoded additional information (Compressed Metadata Data) by encoding the additional information included in the point cloud data, the map information, and the like.
- the multiplexing unit 4656 generates a coded stream (Compressed Stream) which is coded data by multiplexing the coded position image, the coded attribute image, the coded additional information, and other additional information.
- the generated coded stream is output to a processing unit of a system layer (not shown).
- FIG. 21 is a diagram showing the configuration of the second decoding unit 4660.
- FIG. 22 is a block diagram of the second decoding unit 4660.
- the second decoding unit 4660 generates point cloud data by decoding the coded data (coded stream) encoded by the second coding method by the second coding method.
- the second decoding unit 4660 includes a demultiplexing unit 4661, a video decoding unit 4662, an additional information decoding unit 4663, a position information generation unit 4664, and an attribute information generation unit 4665.
- a coded stream (Compressed Stream), which is coded data, is input to the second decoding unit 4660 from a processing unit of a system layer (not shown).
- the demultiplexing unit 4661 separates a coded position image (Compressed Geometry Image), a coded attribute image (Compressed Attribute Image), a coded additional information (Compressed Metadata Image), and other additional information from the coded data. ..
- the video decoding unit 4662 generates a position image and an attribute image by decoding the coded position image and the coded attribute image using a video coding method.
- a video coding method any known coding method may be used.
- the video coding method is AVC, HEVC, or the like.
- the additional information decoding unit 4663 generates additional information including map information by decoding the coded additional information.
- the position information generation unit 4664 generates position information using the position image and the map information.
- the attribute information generation unit 4665 generates attribute information using the attribute image and the map information.
- the second decoding unit 4660 uses the additional information necessary for decoding at the time of decoding, and outputs the additional information necessary for the application to the outside.
- FIG. 23 is a diagram showing a protocol stack related to PCC coded data.
- FIG. 23 shows an example in which data of another medium such as video (for example, HEVC) or audio is multiplexed with PCC coded data and transmitted or stored.
- video for example, HEVC
- audio is multiplexed with PCC coded data and transmitted or stored.
- the multiplexing method and file format have a function for multiplexing, transmitting or storing various coded data.
- the coded data In order to transmit or store the coded data, the coded data must be converted to a multiplexing format.
- HEVC defines a technique for storing coded data in a data structure called a NAL unit and storing the NAL unit in ISOBMFF.
- a first coding method (Codec1) and a second coding method (Codec2) are being studied as a method for coding point group data.
- the method of storing in the system format is not defined, and there is a problem that MUX processing (multiplexing), transmission and storage in the coding unit cannot be performed as it is.
- the coded data (position information (Geometry), attribute information (Attribute), additional information (Metatatta)) generated by the first coding unit 4630 or the second coding unit 4650 described above.
- the type of the data, the method of generating additional information (metadata), and the multiplexing process in the multiplexing unit will be described.
- the additional information (metadata) may be referred to as a parameter set or control information.
- the dynamic object (three-dimensional point cloud data that changes with time) described with reference to FIG. 4 will be described as an example, but even in the case of a static object (three-dimensional point cloud data at an arbitrary time). A similar method may be used.
- FIG. 24 is a diagram showing a configuration of a coding unit 4801 and a multiplexing unit 4802 included in the three-dimensional data coding apparatus according to the present embodiment.
- the coding unit 4801 corresponds to, for example, the first coding unit 4630 or the second coding unit 4650 described above.
- the multiplexing unit 4802 corresponds to the multiplexing unit 4634 or 4656 described above.
- the coding unit 4801 encodes the point cloud data of a plurality of PCC (Point Cloud Compression) frames and generates the coded data (Multiple Compressed Data) of a plurality of position information, attribute information and additional information.
- PCC Point Cloud Compression
- the multiplexing unit 4802 converts data of a plurality of data types (position information, attribute information, and additional information) into a NAL unit, thereby converting the data into a data configuration in consideration of data access in the decoding device.
- FIG. 25 is a diagram showing a configuration example of coded data generated by the coding unit 4801.
- the arrow in the figure shows the dependency related to the decoding of the coded data, and the source of the arrow depends on the data at the tip of the arrow. That is, the decoding device decodes the data at the tip of the arrow, and uses the decoded data to decode the original data of the arrow.
- dependence means that the dependent data is referenced (used) in the processing (encoding or decoding, etc.) of the dependent data.
- the coding unit 4801 encodes the position information of each frame to generate coded position data (Compressed Geometry Data) for each frame. Further, the coded position data is represented by G (i). i indicates a frame number, a frame time, or the like.
- the coding unit 4801 generates a position parameter set (GPS (i)) corresponding to each frame.
- the position parameter set contains parameters that can be used to decode the coded position data. Also, the coded position data for each frame depends on the corresponding position parameter set.
- the coded position data consisting of a plurality of frames is defined as a position sequence (Geometry Sequence).
- the coding unit 4801 generates a position sequence parameter set (also referred to as Geometry Sequence PS: position SPS) that stores parameters commonly used for decoding processing for a plurality of frames in the position sequence.
- the position sequence depends on the position SPS.
- the coding unit 4801 encodes the attribute information of each frame to generate the coded attribute data (Compressed Attribute Data) for each frame. Further, the coded attribute data is represented by A (i). Further, FIG. 25 shows an example in which the attribute X and the attribute Y exist, the coded attribute data of the attribute X is represented by AX (i), and the coded attribute data of the attribute Y is represented by AY (i). ..
- the coding unit 4801 generates an attribute parameter set (APS (i)) corresponding to each frame.
- the attribute parameter set of the attribute X is represented by AXPS (i)
- the attribute parameter set of the attribute Y is represented by AYPS (i).
- the attribute parameter set contains parameters that can be used to decode the coded attribute information.
- the coded attribute data depends on the corresponding set of attribute parameters.
- the coded attribute data consisting of a plurality of frames is defined as an attribute sequence (Attribute Sequence).
- the coding unit 4801 generates an attribute sequence parameter set (attribute Sequence PS: also referred to as attribute SPS) that stores parameters commonly used for decoding processing for a plurality of frames in the attribute sequence.
- attribute sequence PS also referred to as attribute SPS
- the attribute sequence depends on the attribute SPS.
- the coding attribute data depends on the coding position data.
- FIG. 25 shows an example in which two types of attribute information (attribute X and attribute Y) exist.
- attribute information for example, the respective data and metadata are generated by the two coding units.
- an attribute sequence is defined for each type of attribute information, and an attribute SPS is generated for each type of attribute information.
- FIG. 25 shows an example in which there is one type of position information and two types of attribute information, but the present invention is not limited to this, and the attribute information may be one type or three or more types. good.
- the coded data can be generated by the same method.
- the attribute information may not be present. In that case, the coding unit 4801 does not have to generate the parameter set related to the attribute information.
- the coding unit 4801 generates a PCC stream PS (PCC Stream PS: also referred to as a stream PS), which is a parameter set for the entire PCC stream.
- the coding unit 4801 stores in the stream PS a parameter that can be commonly used in the decoding process for one or more position sequences and one or more attribute sequences.
- the stream PS includes identification information indicating a codec of point cloud data, information indicating an algorithm used for encoding, and the like.
- the position sequence and attribute sequence depend on the stream PS.
- An access unit is a basic unit for accessing data at the time of decryption, and is composed of one or more data and one or more metadata.
- the access unit is composed of position information at the same time and one or more attribute information.
- a GOF is a random access unit and is composed of one or more access units.
- the coding unit 4801 generates an access unit header (AU Header) as identification information indicating the head of the access unit.
- the coding unit 4801 stores the parameters related to the access unit in the access unit header.
- the access unit header contains the structure or information of the coded data contained in the access unit.
- the access unit header includes parameters commonly used for data included in the access unit, for example, parameters related to decoding of coded data.
- the coding unit 4801 may generate an access unit delimiter that does not include parameters related to the access unit instead of the access unit header.
- This access unit delimiter is used as identification information indicating the head of the access unit.
- the decryption device identifies the head of the access unit by detecting the access unit header or the access unit delimiter.
- the coding unit 4801 generates a GOF header (GOF Header) as identification information indicating the head of the GOF.
- the coding unit 4801 stores the parameters related to the GOF in the GOF header.
- the GOF header contains the structure or information of the coded data contained in the GOF.
- the GOF header includes parameters commonly used for the data included in the GOF, for example, parameters related to decoding of the coded data.
- the coding unit 4801 may generate a GOF delimiter that does not include the parameters related to the GOF instead of the GOF header.
- This GOF delimiter is used as identification information indicating the head of the GOF.
- the decoding device identifies the head of the GOF by detecting the GOF header or the GOF delimiter.
- the access unit is defined as a PCC frame unit.
- the decoding device accesses the PCC frame based on the identification information at the head of the access unit.
- GOF is defined as one random access unit.
- the decoding device accesses the random access unit based on the identification information at the head of the GOF.
- a PCC frame may be defined as a random access unit as long as the PCC frames are not dependent on each other and can be decoded independently.
- one access unit may be assigned two or more PCC frames, or one GOF may be assigned a plurality of random access units.
- the coding unit 4801 may define and generate a parameter set or metadata other than the above.
- the coding unit 4801 may generate an SEI (Supplemental Enhancement Information) that stores parameters (optional parameters) that may not necessarily be used at the time of decoding.
- SEI Supplemental Enhancement Information
- FIG. 26 is a diagram showing an example of coded data and a NAL unit.
- the coded data includes a header and a payload.
- the coded data may include length information indicating the length (data amount) of the coded data, the header or the payload. Further, the coded data does not have to include a header.
- the header contains, for example, identification information for identifying data.
- This identification information indicates, for example, a data type or a frame number.
- the header contains, for example, identification information indicating a reference relationship. This identification information is stored in the header when there is a dependency between the data, and is information for referencing the reference destination from the reference source. For example, the referenced header contains identification information for identifying the data. The header of the reference source contains identification information indicating the reference destination.
- the identification information for specifying the data or the identification information indicating the reference relationship may be omitted.
- the multiplexing unit 4802 stores the coded data in the payload of the NAL unit.
- the NAL unit header includes pcc_nal_unit_type which is identification information of the coded data.
- FIG. 27 is a diagram showing an example of the semantics of pcc_nal_unit_type.
- pcc_codec_type is codec 1 (Codec 1: first coding method)
- the values 0 to 10 of pcc_nal_unit_type are codec position data (Geometry) and coding attribute X data in codec 1.
- HeaderX Codec Attribute Y Data (HeaderY), Position PS (Geom.PS), Attribute XPS (AttrX.PS), Attribute YPS (AttrX.PS), Position SPS (Heometri Function PS), Attribute XSPS (HeaderX) It is assigned to PS), attribute YSPS (AttributeY Sequence PS), AU header (AU Header), and GOF header (GOF Header). Further, the value 11 or later is assigned to the reserve of the codec 1.
- pcc_codec_type is codec 2 (Codec 2: second coding method)
- the values 0 to 2 of pcc_nal_unit_type are assigned to codec data A (DataA), metadata A (MetaDataA), and metadata B (MetaDataB). .. Further, the value 3 or later is assigned to the reserve of the codec 2.
- the position information of a plurality of three-dimensional points is encoded by using the prediction tree generated based on the position information.
- FIG. 28 is a diagram showing an example of a prediction tree used in the three-dimensional data coding method according to the third embodiment.
- FIG. 29 is a flowchart showing an example of the three-dimensional data coding method according to the third embodiment.
- FIG. 30 is a flowchart showing an example of the three-dimensional data decoding method according to the third embodiment.
- a prediction tree is generated using a plurality of three-dimensional points, and then the node information included in each node of the prediction tree is encoded. This gives a bitstream containing the coded node information.
- Each node information is, for example, information about one node of the prediction tree.
- Each node information is, for example, the position information of one node, the index of the one node, the number of child nodes of the one node, the prediction mode used for encoding the position information of the one node, and the like.
- the predicted residual is included.
- each coded node information included in the bit stream is decoded, and then the position information is decoded while generating a prediction tree. ..
- FIG. 31 is a diagram for explaining a method of generating a predicted tree according to the third embodiment.
- the three-dimensional data coding device first adds a point 0 as the initial point of the prediction tree.
- the position information of the point 0 is indicated by the coordinates including the three elements (x0, y0, z0).
- the position information of the point 0 may be indicated by the coordinates of the three-axis Cartesian coordinate system or may be indicated by the coordinates of the polar coordinate system.
- the child_count is incremented by 1 each time one child node is added to the node for which the child_count is set.
- the child_count of each node after the generation of the predicted tree is completed indicates the number of child nodes possessed by each node, and is added to the bitstream.
- the pred_mode indicates a prediction mode for predicting the value of the position information of each node. The details of the prediction mode will be described later.
- the three-dimensional data coding device adds point 1 to the prediction tree.
- the three-dimensional data encoding device may search for the nearest point of the point 1 from the point cloud already added to the prediction tree, and add the point 1 as a child node of the nearest point.
- the position information of the point 1 is indicated by the coordinates including the three elements (x1, y1, z1).
- the position information of the point 1 may be indicated by the coordinates of the three-axis Cartesian coordinate system or may be indicated by the coordinates of the polar coordinate system.
- point 0 is the nearest point to point 1
- point 1 is added as a child node of point 0.
- the three-dimensional data coding device increments the value indicated by the child_count at point 0 by 1.
- the predicted value of the position information of each node may be calculated when the node is added to the prediction tree.
- the three-dimensional data coding device may add point 1 as a child node of point 0 and calculate the position information of point 0 as a predicted value.
- pred_mode 1 may be set.
- the pred_mode is prediction mode information (prediction mode value) indicating the prediction mode.
- the three-dimensional data coding apparatus may calculate the error_value (predicted residual) of point 1 after calculating the predicted value.
- residual_value is a difference value obtained by subtracting the predicted value calculated in the predicted mode indicated by pred_mode from the position information of each node.
- the coding efficiency can be improved by coding the difference value from the predicted value instead of the position information itself.
- the three-dimensional data coding device adds the point 2 to the prediction tree.
- the three-dimensional data encoding device may search for the nearest point of the point 2 from the point cloud already added to the prediction tree, and add the point 2 as a child node of the nearest point.
- the position information of the point 2 is indicated by the coordinates including the three elements (x2, y2, z2).
- the position information of the point 2 may be indicated by the coordinates of the three-axis Cartesian coordinate system or may be indicated by the coordinates of the polar coordinate system.
- point 1 is the nearest point to point 2, and point 2 is added as a child node of point 1.
- the three-dimensional data coding device increments the value indicated by the child_count of point 1 by 1.
- the three-dimensional data coding device adds the point 3 to the prediction tree.
- the three-dimensional data encoding device may search for the nearest point 3 from the point cloud already added to the prediction tree, and add the point 3 as a child node of the nearest point 3.
- the position information of the point 3 is indicated by the coordinates including the three elements (x3, y3, z3).
- the position information of the point 3 may be indicated by the coordinates of the three-axis Cartesian coordinate system or may be indicated by the coordinates of the polar coordinate system.
- point 0 is the nearest point to point 3
- point 3 is added as a child node of point 0.
- the three-dimensional data coding device increments the value indicated by the child_count at point 0 by 1.
- the 3D data coding device adds all the points to the prediction tree and completes the generation of the prediction tree.
- the three-dimensional data coding device encodes the children_count, pred_mode, and residual_value of each node selected from the nodes of the root in the order of depth priority. That is, when selecting nodes in the order of depth priority, the three-dimensional data encoding device selects a child node that has not yet been selected from one or more child nodes of the selected node as the node next to the selected node. .. If the selected node does not have a child node, the 3D data encoding device selects another unselected child node of the parent node of the selected node.
- the coding order is not limited to the depth priority order, but may be, for example, a breadth first order.
- the three-dimensional data encoding device selects a node that has not yet been selected from one or more nodes in the same depth (hierarchy) as the selected node as the node next to the selected node. select. If the node of the same depth as the selected node does not exist, the three-dimensional data coding device selects a node of one or more of the next depth that has not been selected yet.
- points 0 to 3 are examples of a plurality of three-dimensional points.
- child_count, pred_mode, and residual_value are calculated when each point is added to the prediction tree, but the present invention is not limited to this, and for example, after the generation of the prediction tree is completed. , They may be calculated.
- the input order of a plurality of three-dimensional points to the three-dimensional data encoding device may be such that the input three-dimensional points are rearranged in ascending or descending order of the Morton orderer and processed in order from the first three-dimensional point.
- the three-dimensional data coding apparatus can efficiently search for the nearest point of the three-dimensional point to be processed, and can improve the coding efficiency.
- the three-dimensional data coding apparatus may process the three-dimensional points in the input order without rearranging them.
- the 3D data coding device may generate a predictive tree without branches in the input order of a plurality of 3D points.
- the three-dimensional data encoding device adds the input three-dimensional point next to the input three-dimensional point as a child node of a predetermined three-dimensional point in the input order of a plurality of three-dimensional points. You may.
- FIG. 32 is a diagram for explaining a first example of the prediction mode according to the third embodiment.
- FIG. 32 is a diagram showing a part of the predicted tree.
- Eight prediction modes may be set as shown below. For example, as shown in FIG. 32, a case of calculating the predicted value of the point c will be described as an example.
- the prediction tree shows that the parent node at point c is point p0, the grandfather node at point c is point p1, and the great-grandfather node at point c is point p2.
- the point c, the point p0, the point p1, and the point p2 are examples of a plurality of three-dimensional points.
- the prediction mode in which the prediction mode value is 0 (hereinafter referred to as prediction mode 0) may be set without prediction. That is, the three-dimensional data coding apparatus may calculate the input position information of the point c as the predicted value of the point c in the prediction mode 0.
- prediction mode 1 the prediction mode in which the prediction mode value is 1 (hereinafter referred to as prediction mode 1) may be set to the difference prediction with the point p0. That is, the three-dimensional data coding device may calculate the position information of the point p0, which is the parent node of the point c, as the predicted value of the point c.
- the prediction mode in which the prediction mode value is 2 (hereinafter referred to as prediction mode 2) may be set to linear prediction by points p0 and points p1. That is, the three-dimensional data coding device obtains the prediction result of the point c by linear prediction using the position information of the point p0 which is the parent node of the point c and the position information of the point p1 which is the grandfather node of the point c. It may be calculated as a predicted value. Specifically, the three-dimensional data coding device calculates the predicted value of the point c in the prediction mode 2 using the following equation T1.
- Predicted value 2 ⁇ p0-p1 (Equation T1)
- p0 indicates the position information of the point p0
- p1 indicates the position information of the point p1.
- the prediction mode in which the prediction mode value is 3 may be set to Parallelogram prediction using points p0, point p1 and point p2. That is, the three-dimensional data encoding device has the position information of the point p0 which is the parent node of the point c, the position information of the point p1 which is the grandfather node of the point c, and the position information of the point p2 which is the great-grandfather node of the point c.
- the prediction result by the Parentogram prediction using and may be calculated as the prediction value of the point c.
- the three-dimensional data coding device calculates the predicted value of the point c in the prediction mode 3 using the following equation T2.
- p0 indicates the position information of the point p0
- p1 indicates the position information of the point p1
- p2 indicates the position information of the point p2.
- prediction mode 4 may be set to the difference prediction with the point p1. That is, the three-dimensional data coding device may calculate the position information of the point p1, which is the grandfather node of the point c, as the predicted value of the point c.
- prediction mode 5 may be set to the difference prediction with the point p2. That is, the three-dimensional data coding device may calculate the position information of the point p2, which is the great-grandfather node of the point c, as the predicted value of the point c.
- the prediction mode in which the prediction mode value is 6 may be set to the average of any two or more of the points p0, the point p1, and the point p2. That is, the three-dimensional data encoding device has the position information of the point p0 which is the parent node of the point c, the position information of the point p1 which is the grandfather node of the point c, and the position information of the point p2 which is the great-grandfather node of the point c.
- the average value of two or more position information of the above may be calculated as the predicted value of the point c.
- the following equation T3 is used to calculate the predicted value of the point c in the prediction mode 6. do.
- p0 indicates the position information of the point p0
- p1 indicates the position information of the point p1.
- prediction mode 7 the prediction mode in which the prediction mode value is 7 (hereinafter referred to as prediction mode 7) is used for non-linear prediction using the distance d0 between the points p0 and p1 and the distance d1 between the points p2 and p1. It may be set. That is, the three-dimensional data coding apparatus may calculate the prediction result by the non-linear prediction using the distance d0 and the distance d1 as the prediction value of the point c.
- the prediction method assigned to each prediction mode is not limited to the above example. Further, the above eight prediction modes and the above eight prediction methods do not have to be the above combinations, and may be any combination. For example, when the prediction mode is encoded by using entropy coding such as arithmetic coding, the prediction mode 0 may be assigned a frequently used prediction method. Thereby, the coding efficiency can be improved. Further, the three-dimensional data coding apparatus may improve the coding efficiency by dynamically changing the allocation of the prediction mode according to the frequency of use of the prediction mode while advancing the coding process.
- the three-dimensional data coding apparatus may count, for example, the frequency of use of each prediction mode at the time of coding, and may assign a prediction mode indicated by a smaller value to a prediction method having a higher frequency of use. This can improve the coding efficiency.
- the three-dimensional data coding device uses the predicted value (px, py, pz) of the position information (x, y, z) of the three-dimensional point as a code among the three-dimensional points around the three-dimensional point to be encoded.
- the predicted value used for calculating the position information of the three-dimensional point to be encoded may be calculated by using the position information of the three-dimensional point whose distance is close to the three-dimensional point to be encoded. Further, the three-dimensional data coding apparatus may add prediction mode information (pred_mode) for each three-dimensional point so that the predicted value calculated according to the prediction mode can be selected.
- the position information of the three-dimensional point p0 of the nearest neighbor point is assigned to the prediction mode 0, ...
- the position information of the three-dimensional point p2 is assigned to the prediction mode M-1 and used for prediction. It is conceivable to add the predicted mode to the bitstream for each three-dimensional point.
- FIG. 33 is a diagram showing a second example of a table showing predicted values calculated in each prediction mode according to the third embodiment.
- the predicted value of the position information of the point c is calculated using the position information of at least one of the point p0, the point p1, and the point p2.
- the prediction mode is added for each three-dimensional point to be encoded.
- the predicted value is calculated according to the added prediction mode.
- FIG. 34 is a diagram showing a specific example of the second example of the table showing the predicted values calculated in each prediction mode according to the third embodiment.
- the three-dimensional data coding apparatus selects, for example, the prediction mode 1, and encodes the position information (x, y, z) of the three-dimensional point to be encoded by using the predicted values (p0x, p0y, p0z), respectively. May be changed.
- "1" which is a prediction mode value indicating the selected prediction mode 1, is added to the bit stream.
- the three-dimensional data coding apparatus can be used as one prediction mode for calculating the prediction value of each of the three elements including the position information of the three-dimensional point to be encoded in the selection of the prediction mode. You may choose a common prediction mode for the three elements.
- FIG. 35 is a diagram showing a third example of a table showing predicted values calculated in each prediction mode according to the third embodiment.
- the predicted value of the position information of the point c is calculated using the position information of at least one of the point p0 and the point p1.
- the prediction mode is added for each three-dimensional point to be encoded.
- the predicted value is calculated according to the added prediction mode.
- the prediction mode in which the predicted value is not assigned may be set to not available.
- another prediction method may be assigned to the prediction mode.
- the position information of the point p2 may be assigned as the predicted value to the prediction mode.
- the prediction mode may be assigned a prediction value assigned to another prediction mode.
- the position information of the point p1 assigned to the prediction mode 4 may be assigned to the prediction mode 3 in which the not variable is set. At that time, the position information of the point p2 may be newly assigned to the prediction mode 4. In this way, when a prediction mode in which not variable is set occurs, the coding efficiency can be improved by assigning a new prediction method to the prediction mode.
- FIG. 36 is a diagram showing an example of the syntax of the header of the position information.
- the NuMNeightborPoint, NuPredMode, Thfix, QP, and unique_point_per_leaf in the syntax of FIG. 36 will be described in order.
- NuMeightborPoint indicates the upper limit of the number of surrounding points used to generate the predicted value of the position information of the three-dimensional point.
- the predicted value may be calculated using the M peripheral points in the calculation process of the predicted value.
- NuMRedMode indicates the total number M of prediction modes used for predicting position information.
- the maximum value MaxM that can be taken by the number of prediction modes may be specified by a standard or the like.
- the number of prediction modes NuMRedMode does not have to be added to the bit stream, and the value may be specified by a profile or level such as a standard. Further, the number of prediction modes may be defined by NumberBorPoint + NumberPredMode.
- the prediction mode is fixed at ⁇ .
- ⁇ is a prediction mode for calculating a prediction value using linear prediction, and is “2” in the above embodiment. It should be noted that Thfix does not have to be added to the bitstream, and the value may be specified by a profile or level such as a standard.
- the three-dimensional data coding apparatus may calculate the quantization step from the quantization parameter and quantize the position information using the calculated quantization step.
- the determination of whether or not to fix the prediction mode is performed using the absolute difference value between the distance d0 and the distance d1, but the determination is not necessarily limited to this, and any method is used. You can judge. For example, this judgment calculates the distance d0 between the points p1 and p0, and if the distance d0 is larger than the threshold value, it is determined that the point p1 cannot be used for prediction, and the prediction mode value is set to "1" (predicted value). It may be fixed to p0), and if not, the prediction mode may be set. As a result, the coding efficiency can be improved while suppressing the overhead.
- the NumNeigborPoint, NumPredMode, Thfix, and unique_point_per_leaf may be entropy-coded and added to the header. For example, each value may be binarized and calculated and coded. Further, each value may be encoded with a fixed length in order to reduce the amount of processing.
- FIG. 37 is a diagram showing an example of the syntax of location information. NumofPoint, child_count, pred_mode, and residual_value [j] in the syntax of FIG. 37 will be described in order.
- NuMofPoint indicates the total number of 3D points included in the bitstream.
- Child_count indicates the number of child nodes possessed by the i-th three-dimensional point (node [i]).
- Pred_mode indicates a prediction mode for encoding or decoding the position information of the i-th three-dimensional point.
- ⁇ is a prediction mode for calculating a prediction value using linear prediction, and is “2” in the above embodiment. In addition, ⁇ is not limited to “2”, and any value from 0 to M-1 may be set as an estimated value.
- the estimated value when pred_mode is not in the bitstream may be added to the header or the like separately.
- the pred_mode may be arithmetically coded by binarizing with a truncated unary code using the number of prediction modes to which the predicted value is assigned.
- the specific prediction mode is a predetermined prediction mode.
- Residual_value [j] indicates the coded data of the predicted residual between the predicted value and the predicted value of the position information.
- the residual_value [0] may indicate the element x of the position information
- the residual_value [1] may indicate the element y of the position information
- the residual_value [2] may indicate the element z of the position information.
- FIG. 38 is a diagram showing another example of the syntax of location information.
- the example of FIG. 38 is a modification of the example of FIG. 37.
- the pred_mode may indicate the prediction mode for each of the three elements of the position information (x, y, z). That is, pred_mode [0] indicates the prediction mode of the element x, pred_mode [1] indicates the prediction mode of the element y, and pred_mode [2] indicates the prediction mode of the element z.
- the pred_mode [0], pred_mode [1], and pred_mode [2] may be added to the bitstream.
- FIG. 39 is a block diagram of the three-dimensional data coding apparatus 12800 according to the present embodiment.
- FIG. 39 describes a processing unit for coding the position information (geometry) of the point cloud
- the three-dimensional data coding device 12800 is a processing unit or the like that encodes the attribute information of the point cloud. Other processing units may be provided.
- the point cloud to be coded is encoded with reference to the coded point cloud.
- the three-dimensional data coding device 12800 includes an ocree tree section 12801, a buffer 12802, an entropy coding section 12803, a buffer 12804, a buffer 12805, a point cloud grouping section 12806, a buffer 12807, and motion detection compensation.
- a unit 12808, an ocree wood unit 12809, a buffer 12810, and a control unit 12811 are provided.
- the ocree tree unit 12801 converts the target point cloud, which is the input data of the point cloud to be encoded, into an octree representation, so that the position information of the target point cloud is converted into an ocree. Generate the expressed target ocree.
- the position of the point cloud is represented by, for example, three-dimensional coordinates (for example, x, y, z).
- Buffer 12802 holds the generated target ocree.
- the ocree is composed of a plurality of nodes (branch points), and the information of each node is an 8-bit occupancy code indicating whether or not each of the eight child nodes of the node contains a three-dimensional point. including.
- the buffer 12802 may initialize the data held for each ocree (target point cloud).
- the entropy coding unit 12803 generates a bit stream by entropy coding information for each node (for example, an entropy code).
- a probability parameter (encoding table or) is based on the information of the coded node (intra-reference node) in the target point group or the information of the node (inter-reference node) in the coded point group. (Also called a probability table) is controlled.
- the buffer 12804 holds the information of the target node (for example, the occupancy code) as the intra reference node (encoded node). For example, the buffer 12804 may initialize the data held for each ocree (target point cloud).
- Buffer 12805 holds information on the target node (for example, an occupancy code). Further, the buffer 12805 holds the information of the target node in units of an ocree as an encoded ocree. For example, the buffer 12805 may initialize the data held for each ocree (target point cloud).
- the point cloud grouping unit 12806 generates an interreference point cloud (encoded point cloud) by converting the encoded octane tree into a point cloud.
- Buffer 12807 holds a group of interreference points. That is, the buffer 12807 holds a plurality of interreference point clouds, which are one or a plurality of coded point clouds.
- the motion detection compensation unit 12808 detects the displacement between the inter-reference point group and the target point group (motion detection), and corrects the inter-reference point cloud based on the detected displacement (motion compensation) to perform the inter-alignment after alignment. Generates a post-alignment point cloud, which is a reference point cloud.
- the octal tree conversion unit 12809 converts the alignment point cloud into an octal tree representation to generate an interreference octave tree in which the position information of the alignment point cloud is expressed by an octal tree.
- Buffer 12810 holds the generated interreference ocree. Further, for example, the buffer 12810 may initialize the data held for each ocree (target point cloud).
- the three-dimensional data coding device 12800 may perform motion detection and motion compensation in units of frames or ocree, or may be performed for each node (point). Further, the three-dimensional data coding device 12800 may describe information related to motion compensation such as a motion vector in the header portion of a frame or an ocree, or after entropy coding the information, the header of the node information. It may be described in the section.
- the interreference point cloud may be a point cloud included in a coded frame different from the coded frame, or may be a coded point cloud included in the same frame as the coded frame. There may be.
- the control unit 12811 uses the intra-reference node stored in the buffer 12804 or the inter-reference node contained in the inter-reference 8-branch tree stored in the buffer 12810, and the entropy coding unit 12803 uses the target node. Controls the stochastic parameters used for entropy coding (arithmetic coding). Whether the control of the probability parameter using the intra-reference node (hereinafter referred to as the intra-reference) is used or the control of the probability parameter using the inter-reference node (hereinafter referred to as the inter-reference) is used, for example. , It may be predetermined in units of frames or point clouds, or it may be determined by any method. For example, a reference method (intra-reference or inter-reference) in which the actual code amount is calculated and the code amount is reduced may be selected.
- a probability parameter is selected from a plurality of probability parameters based on the occupancy state (whether or not the node contains a point) of a plurality of adjacent nodes (intra reference nodes) of the target node.
- the node When an interreference is used, a plurality of probability parameters are based on the occupied state of the node (interreference node) at the same position as at least one of the target node and the plurality of adjacent nodes included in the interreference ocree.
- the probability parameter is selected from.
- the probability parameter may be controlled by combining the interreference and the intrareference.
- the plurality of probability parameters may include probability parameters that are updated according to the frequency of occurrence, or may include fixed values.
- the three-dimensional data coding device 12800 controls the probability parameter of entropy coding based on the information of the inter-reference node in addition to the information of the intra-reference node, so that the probability of occurrence of the information of the target node can be determined. Prediction accuracy can be improved. Therefore, there is a possibility that the coding efficiency can be improved.
- the three-dimensional data encoding device 12800 does not always need to refer to the inter-reference point cloud, and has a predetermined time interval (for example, every 1 second), a predetermined frame interval (for example, every 30 frames), or three-dimensional.
- the target point cloud may be encoded based only on the information of the target point cloud, such as by clearing the buffer 12807 storing the interreference point cloud at an arbitrary timing of notifying the data decoding device.
- FIG. 40 is a block diagram of the three-dimensional data decoding device 12820 according to the present embodiment.
- the three-dimensional data decoding device 12820 has another processing unit such as a processing unit for decoding the attribute information of the point cloud. It may be provided with a processing unit.
- the three-dimensional data decoding device 12820 performs inter-predictive decoding that decodes the point cloud from the encoded bit stream while referring to the encoded point cloud. For example, the three-dimensional data decoding device 12820 decodes the bitstream generated by the three-dimensional data coding device 12800 shown in FIG. 39.
- the three-dimensional data decoding device 12820 includes an entropy decoding unit 12821, a buffer 12822, a buffer 12823, a point cloud grouping unit 12824, a buffer 12825, a motion compensation unit 12826, an ocree tree unit 12827, and a buffer 12828. ,
- the control unit 12829 is provided.
- the entropy decoding unit 12821 generates information (for example, an occupancy code) of the decoding node by entropy decoding the input bit stream at each branch point (node) of the octave tree.
- the probability parameter (both the coding table and the probability table) is based on the information of the decoded node (intra-reference node) in the target point cloud or the information of the node (inter-reference node) in the decoded point cloud. Call) is controlled.
- the buffer 12822 holds the generated information of the decrypted node as an intra-reference node (decrypted node). For example, the buffer 12822 may initialize the data to be held for each ocree (decoding point group).
- the buffer 12823 holds information on the decoding node (for example, an occupancy code). Further, the buffer 12823 holds the information of the decoding node in units of an ocree as a decoding ocree. For example, the buffer 12823 may initialize the data to be held for each ocree (decoding point group).
- the point cloud grouping unit 12824 generates a decoded point cloud by converting the decoded octaree into a point cloud.
- the buffer 12825 holds the decoding point cloud as an interreference point cloud.
- the motion compensation unit 12826 corrects (motion compensation) the displacement between the inter-reference point cloud and the point cloud to be decoded to generate a post-alignment point cloud which is an inter-reference point cloud after alignment.
- the motion compensation unit 12826 acquires information related to motion compensation such as a motion vector from the header unit of a frame or an ocree, or the header unit of node information, and performs motion compensation using the acquired information. ..
- the ocree tree conversion unit 12827 converts the alignment after-point cloud into an octa-tree representation to generate an interreference octa-division tree in which the position information of the alignment after-point cloud is expressed by an ocree.
- Buffer 12828 holds the generated interreference ocree. Further, for example, the buffer 12828 may initialize the data held for each ocree (decoding point group).
- the three-dimensional data decoding device 12820 may perform motion compensation in units of frames or ocree, or may be performed for each node (point).
- the interreference point cloud may be a point cloud included in a decoded frame different from the frame to be decoded, or may be a decoded point cloud included in the same frame as the frame to be decoded. ..
- the control unit 12829 uses the intra-reference node stored in the buffer 12822 or the inter-reference node included in the inter-reference ocree stored in the buffer 12828, and the entropy decoding unit 12821 uses the entropy of the target node. Controls the probability parameters used for decoding (arithmetic decoding). Whether an intra reference is used or an interreference is used may be determined, for example, based on the control information included in the bitstream, or may be predetermined in units of frames or point clouds. It may be determined by any method.
- a probability parameter is selected based on the occupancy state (whether or not the node contains a point) of a plurality of adjacent nodes (intra reference nodes) of the target node.
- the probability parameter is selected based on the occupied state of the node (interreference node) at the same position as at least one of the target node and a plurality of adjacent nodes included in the interreference ocree. Will be done.
- the probability parameter may be controlled by combining the interreference and the intrareference.
- the three-dimensional data decoding device 12820 controls the entropy decoding probability parameter based on the information of the inter-reference node in addition to the information of the intra-reference node, thereby referring to the coded point group.
- the point group can be decoded from the coded bit stream (for example, the bit stream output from the three-dimensional data coding apparatus 12800 shown in FIG. 39).
- the three-dimensional data decoding device 12820 does not always need to refer to the inter-reference point cloud, and has a predetermined time interval (for example, every second) and a predetermined frame interval (for example, every second) according to the three-dimensional data coding device. Based only on the information of the decoding target point cloud, such as by clearing the buffer 12825 storing the interreference point cloud at an arbitrary timing notified from the 3D data encoding device (every 30 frames, etc.). The decoding target point cloud may be decoded. As a result, the three-dimensional data decoding device 12820 can realize the dive reproduction start from the point cloud that does not refer to the interreference point cloud other than the head of the bit stream.
- FIG. 41 is a block diagram of the three-dimensional data coding device 12800A, which is a modification of the three-dimensional data coding device 12800.
- the three-dimensional data coding device 12800A shown in FIG. 41 further includes a motion compensation unit 12812 with respect to the three-dimensional data coding device 12800 shown in FIG. 39.
- the motion compensation unit 12812 aligns with the inter-reference point cloud already stored in the buffer 12807 by performing motion compensation on the coded point cloud generated by the point cloud grouping unit 12806.
- the buffer 12807 updates the stored inter-reference point cloud by integrating the motion-compensated coded point cloud into the already stored inter-reference point cloud.
- the inter-reference point cloud a dense point cloud in which the point clouds of a plurality of frames are superimposed can be used.
- other processing is the same as, for example, the three-dimensional data coding apparatus 12800.
- the interreference point cloud may be a point cloud included in a coded frame different from the coded frame, or may be a coded point cloud included in the same frame as the coded frame. There may be.
- the three-dimensional data coding device 12800A may be able to improve the point cloud density of the interreference point cloud by aligning and integrating the coded point clouds. As a result, the accuracy of predicting the occurrence probability of the information of the target node is improved, so that there is a possibility that the coding efficiency can be further improved.
- the three-dimensional data coding device 12800A does not need to refer to all the coded point clouds as an interreference point cloud, and has a predetermined time interval (for example, every 1 second) and a predetermined frame interval (for example, 5 frames). (Every time, etc.), or at any time to notify the 3D data decoder, clear all or part of the buffer 12807 that stores the interreference point cloud, etc., and either only the target point cloud or encode it.
- the target point cloud may be encoded based on the information of the target point cloud and a part of the coded point cloud.
- FIG. 42 is a block diagram of the three-dimensional data decoding device 12820A, which is a modification of the three-dimensional data decoding device 12820.
- the three-dimensional data decoding device 12820A shown in FIG. 42 further includes a motion compensation unit 12830 with respect to the three-dimensional data decoding device 12820 shown in FIG. 40.
- the three-dimensional data decoding device 12820A decodes a point cloud from the bit stream generated by the three-dimensional data coding device 12800A shown in FIG. 41.
- the motion compensation unit 12830 performs motion compensation to the decoding point group to align with the inter-reference point group already stored in the buffer 12825.
- the buffer 12825 updates the stored inter-reference point group by integrating the motion-compensated decoding point group with the already stored inter-reference point group.
- the inter-reference point cloud a dense point cloud in which the point clouds of a plurality of frames are superimposed can be used.
- other processing is the same as, for example, the three-dimensional data decoding device 12820.
- the interreference point cloud may be a point cloud included in a decoded frame different from the frame to be decoded, or may be a decoded point cloud included in the same frame as the frame to be decoded. ..
- the three-dimensional data decoding device 12820A has a configuration in which the decoded point clouds are aligned and integrated, so that the bit stream encoded by the three-dimensional data coding apparatus having the same configuration (for example,).
- the point cloud can be decoded from the bit stream generated by the three-dimensional data coding apparatus 12800A shown in FIG. 41.
- the three-dimensional data decoding device 12820A does not need to refer to all the decoded point clouds as an interreference point cloud, and has a predetermined time interval (for example, every 1 second) and a predetermined frame interval (for example, every 5 frames). ) Or at an arbitrary timing notified from the three-dimensional data encoding device, such as clearing all or part of the buffer 12825 storing the interreference point cloud, and only the decoding target point cloud or decoding.
- the decoding target point cloud may be decoded based on the information of the target point cloud and a part of the decoded point cloud.
- the three-dimensional data decoding device 12820A can realize the jump-reproduction start from the point cloud that does not refer to the inter-reference point cloud other than the head of the bit stream. Therefore, there is a possibility that the random accessibility and error tolerance of the bitstream can be improved. Further, when the three-dimensional data decoding device performs decoding based on the information of the decoding target point cloud and a part of the decoded point cloud, the capacity of the buffer 12825 holding the interreference point cloud can be reduced. Therefore, there is a possibility that the mounting cost of the three-dimensional data coding device and the three-dimensional data decoding device can be reduced.
- FIG. 43 is a diagram showing an example of inter-prediction in the three-dimensional data coding apparatus shown in FIGS. 39 and 41. The same applies to the inter-prediction in the three-dimensional data decoding apparatus shown in FIGS. 40 and 42.
- the three-dimensional data coding device sets a first rectangular cuboid including a target point cloud.
- the three-dimensional data coding device sets a second rectangular cuboid that is translated from the first rectangular cuboid.
- the second rectangular cuboid is a space containing the coded point cloud referred to in the coding of the target point cloud.
- the three-dimensional data coding device describes the x, y, and z components of the parallel movement distance between the first rectangular cuboid and the second rectangular cuboid in the header portion of the frame or the octal tree as the motion vector information.
- the information may be entropy-encoded and then described in the header portion of the node information.
- FIG. 44 is a diagram showing an example of the syntax of the sequence parameter set (SPS) included in the bit stream.
- SPS is control information common to a plurality of frames, a plurality of point clouds, or a plurality of slices, and is control information common to attribute information and position information.
- the SPS includes sps_inter_prescription_enable_flag and sps_max_num_ref_frames_minus1.
- Sps_inter_prescription_enable_flag 1 specifies that the use of interprediction is allowed for bitstreams that reference the SPS.
- Sps_inter_prescription_enable_flag 0 specifies that interprediction is invalid for the bitstream that references the SPS.
- Sps_max_num_ref_frames_minus1 + 1 (value obtained by adding 1 to sps_max_num_ref_frames_minus1) specifies the maximum number of reference point cloud frames referenced by the frame.
- the value of sps_max_num_ref_frames_minus1 must be in the range 0 to MaxNumRefFrames-1.
- Sps_max_num_ref_frames_minus1 is included in SPS when sps_inter_prepition_enabled_flag is 1, and is not included in SPS when sps_inter_prepition_enable_flag is 0.
- FIG. 45 is a diagram showing an example of the syntax of the position information parameter set (GPS) included in the bit stream.
- GPS is control information common to a plurality of frames, a plurality of point clouds, or a plurality of slices), and is position information control information.
- GPS includes gps_inter_prescription_enable_flag and gps_num_ref_frames_minus1.
- Gps_inter_prescription_enable_flag which is equal to 1, specifies that the use of inter-prediction is permitted in the decoding process of the position information data unit of the bitstream that refers to GPS. Specifies that inter-prediction is invalid in the decoding process of the position information data unit of the bitstream that refers to gps_inter_prescription_enable_flag, which is equal to 0, and GPS.
- gps_inter_prescription_enable_flag is 0.
- Gps_num_ref_frames_minus1 + 1 (value obtained by adding 1 to gps_num_ref_frames_minus1) specifies the number of reference point cloud frames referenced in the frame that refers to GPS.
- the value of gps_num_ref_frames_minus1 must be in the range from 0 to sps_max_num_ref_frames_minus1.
- Gps_num_ref_frames_minus1 is included in GPS when gps_inter_prepition_enabled_flag is 1, and is not included in GPS when gps_inter_prepition_enable_flag is 0.
- the 3D data encoding device indicates whether the sequence parameter set and the position information parameter set are allowed to perform inter-predictive coding, for example, sps_inter_prediction_enable_flag and gps_inter_prediction_enable_flag.
- the information may be notified to the three-dimensional data decoder.
- the inter-predictive encoding is performed, for example, sps_max_num_ref_frames_minus1 and gps_num_ref_frames_minus1.
- Information regarding the number of frames referred to in the above or the maximum value thereof may be notified to the three-dimensional data decoding device.
- MaxNumRefFrames is a fixed value defined as a requirement that the 3D data decoding device should satisfy, and it is conceivable to set it to several frames such as 6 frames, but the 3D data coding device and the 3D data decoding device If both of them are processed using the same value, a value larger than these may be used.
- the information indicating whether or not the above-mentioned inter-predictive coding is permitted and the information regarding the number of frames referred to in the inter-predictive coding or the maximum value thereof are stored in both SPS and GPS. It may be stored in only one of them. Further, these information may be stored in control information other than SPS and GPS.
- FIGS. 39 to 45 may be carried out in combination with at least a part of other disclosures in the present disclosure.
- a part of the apparatus, processing, and syntax disclosed using FIGS. 39 to 45 may be carried out in combination with other disclosures.
- each device may include only a part of the components.
- the three-dimensional data coding apparatus performs the processing shown in FIG.
- the three-dimensional data coding device performs motion compensation on a plurality of coded point clouds (S12801).
- the three-dimensional data coding apparatus generates a reference point cloud (for example, the inter-reference point cloud shown in FIG. 41) by integrating (synthesizing) a plurality of coded point clouds after motion compensation (S1282).
- the three-dimensional data encoding device generates an N-divided tree structure of a target point cloud (N is an integer of 2 or more) (for example, an object octa-divided tree shown in FIG. 41) (S12803).
- the three-dimensional data coding apparatus encodes the N-branch structure of the target point cloud using the reference point cloud (S12804).
- N is, for example, it may be any power of 2 or any other value.
- the three-dimensional data coding device can improve the coding efficiency by coding the target point cloud using the reference point cloud that integrates a plurality of coded point clouds.
- the reference point group in encoding the N-division structure of the target point group (S12804), the reference point group is compensated for the motion of the target point group, and the N-branch of the reference point group after the motion compensation is compensated.
- a structure for example, the inter-reference octaree tree shown in FIG. 41
- the N-branch structure of the target point cloud is encoded using the N-branch structure of the reference point cloud.
- the N-branch structure of the target point group in encoding the N-branch structure of the target point group (S12804), is entropy-coded and used in entropy coding based on the reference point group. Control the probability parameters to be.
- the three-dimensional data coding device selects a probability parameter to be used from a plurality of probability parameters based on a reference point cloud.
- the three-dimensional data coding device generates a coded target point cloud (for example, the coded point cloud shown in FIG. 41) from the N-branch structure of the target point cloud, and encodes the target point cloud.
- the reference point cloud is updated by performing motion compensation for the reference point cloud and integrating the coded target point cloud after motion compensation into the reference point cloud.
- each of the plurality of coded point clouds belongs to a frame different from the target point cloud.
- each of a plurality of encoded point clouds belongs to the same frame as the target point cloud.
- the three-dimensional data coding device provides the first information (for example, sps_inter_prescription_enable_flag or gps_inter_prescription_enable_flag) indicating whether or not the coding using the reference point cloud is permitted, to the control information common to the plurality of point clouds.
- the first information for example, sps_inter_prescription_enable_flag or gps_inter_prescription_enable_flag
- a three-dimensional data coding apparatus may use second information (eg, for example) regarding the number of encoded points, if the first information indicates that coding with a reference point cloud is allowed.
- second information eg, for example
- the control information for example, SPS or GPS
- the second information indicates the number or maximum number of coded point clouds to be integrated.
- the three-dimensional data encoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the three-dimensional data decoding device performs the process shown in FIG. 47.
- the three-dimensional data decoding device performs motion compensation on a plurality of decoded point clouds (S12811).
- the three-dimensional data decoding device generates a reference point cloud (for example, the inter-reference point cloud shown in FIG. 42) by integrating (synthesizing) a plurality of decoded point clouds after motion compensation (S12812).
- the three-dimensional data decoding device decodes the N-division structure (N is an integer of 2 or more) (for example, the decoding octa-tree shown in FIG. 42) of the target point cloud using the reference point cloud (S12813).
- the three-dimensional data decoding device acquires the N-branch structure of the target point cloud by decoding the bitstream (encoded data) generated by encoding the N-branch structure of the target point cloud. ..
- the three-dimensional data decoding device generates a decoding point cloud of the target point cloud from the N-branch structure of the target point cloud (S12814).
- N is, for example, it may be any power of 2 or any other value.
- the three-dimensional data decoding device can decode the target point cloud using a reference point cloud that integrates a plurality of decoded point clouds.
- the three-dimensional data decoding device compensates the reference point group for motion with respect to the target point group, and the N-branch structure of the reference point group after motion compensation (S12813).
- the inter-reference octave tree shown in FIG. 42 is generated, and the N-branch structure of the target point cloud is decoded using the N-branch structure of the reference point group.
- the three-dimensional data decoding device in decoding the N-branch structure of the target point cloud (S12813), the three-dimensional data decoding device entropy-decodes the N-branch structure of the target point cloud, and the probability parameter used in the entropy decoding based on the reference point cloud. To control. For example, the three-dimensional data decoding device selects a probability parameter to be used from a plurality of probability parameters based on a reference point cloud.
- the three-dimensional data decoding device updates the reference point cloud by performing motion compensation for the reference point cloud on the decoding point cloud of the target point cloud and integrating the decoding point cloud after motion compensation into the reference point cloud.
- each of the decoded point clouds belongs to a frame different from the target point cloud.
- each of the decoded point clouds belongs to the same frame as the target point cloud.
- the three-dimensional data decoding device provides first information (for example, sps_inter_prediction_enable_flag or gps_inter_prescription_enable_flag) indicating whether or not decoding using the reference point cloud is permitted, and control information common to the plurality of point clouds (for example,). Obtained from SPS or GPS).
- first information for example, sps_inter_prediction_enable_flag or gps_inter_prescription_enable_flag
- the second information regarding the number of the plurality of decoded point clouds is acquired from the control information (for example, SPS or GPS) common to the plurality of point clouds.
- the control information for example, SPS or GPS
- the second information indicates the number of decoded point clouds to be integrated, or the maximum number.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- FIG. 48 is a block diagram of the three-dimensional data coding device 12900 according to the present embodiment.
- FIG. 48 describes a processing unit for coding the position information (geometry) of the point cloud
- the three-dimensional data coding device 12900 is a processing unit or the like that encodes the attribute information of the point cloud.
- Other processing units may be provided.
- the point cloud to be coded is encoded with reference to the coded point cloud.
- the three-dimensional data coding device 12900 includes a grouping unit 12901, a buffer 12902, a quantization unit 12903, an inverse quantization unit 12904, a buffer 12905, an intra prediction unit 12906, a buffer 12907, and a motion detection compensation unit. It includes a 12908, an inter-prediction unit 12909, a switching unit 12910, and an entropy coding unit 12911.
- the grouping unit 12901 extracts a point cloud to be a prediction tree (Predtree), which is a unit of coding, from the target point cloud which is the data of the input point cloud to be coded, and sets it as one group. ..
- the position of the point cloud is represented by, for example, three-dimensional coordinates (for example, x, y, z).
- Buffer 12902 holds the generated prediction tree.
- the buffer 12902 may initialize the data held for each predicted tree. Processing for coding is sequentially executed for each of a plurality of three-dimensional points included in the prediction tree (Predtree) held in the buffer 12902.
- the three-dimensional coordinates may be expressed in Cartesian coordinates or polar coordinates. In the following, the position information expressed in Cartesian coordinates will be referred to as the position information in the Cartesian coordinate system, and the position information expressed in polar coordinates will be referred to as the position information in the polar coordinate system.
- first residual signal the difference between each of the plurality of three-dimensional points included in the predicted tree and the selected predicted point is calculated.
- This first residual signal is also referred to as a predicted residual.
- the first residual signal is an example of the first residual.
- the quantization unit 12903 quantizes the first residual signal.
- the entropy coding unit 12911 entropy-codes the quantized first residual signal to generate coded data, and outputs (generates) a bit stream including the coded data.
- the inverse quantization unit 12904 dequantizes the first residual signal quantized by the quantization unit 12903.
- the dequantized first residual signal is added to the predicted value based on the selected predicted points (one or more candidate points) to serve as a three-dimensional point (reference point) used for intra-prediction and inter-prediction. It is decrypted.
- the predicted value is calculated based on the position information of one or more candidate points as described in the above embodiment.
- the buffer 12905 holds the reference point cloud of the decoded intra prediction. For example, the buffer 12905 may initialize the data held for each prediction tree (target point cloud). Further, the buffer 12907 holds a reference point cloud for inter-prediction. For example, the buffer 12907 may initialize the data held for each prediction tree (target point cloud).
- the intra prediction unit 12906 sets the intra prediction point used for prediction to a plurality of three-dimensional points (reference point cloud for intra prediction) included in a prediction tree (Predtree) including the three-dimensional point to be encoded. It is determined by a predetermined method with reference to the information in the predtree. For example, the intra prediction unit 12906 uses two three-dimensional points (decoding points) that have been dequantized immediately before the three-dimensional point to be encoded (for example, an ancestor node such as the parent node of the prediction tree). The intra prediction point may be determined by inserting it.
- the motion detection compensation unit 12908 reproduces a coded point cloud based on a plurality of three-dimensional points (multiple decoding points) included in the prediction tree (Predtree) including the three-dimensional points to be encoded, and encodes the code.
- Motion detection detecting the displacement between the encoded point cloud and the point cloud to be encoded
- motion compensation correcting the encoded point cloud based on the detected displacement (motion compensation), after alignment.
- inter-prediction point cloud which is a reference point cloud for inter-prediction.
- the inter-prediction unit 12909 determines the inter-prediction point to be used for prediction by a predetermined method based on the motion-compensated inter-prediction point group. For example, the inter prediction unit 12909 may select the point closest to the intra prediction point from the inter prediction point group as the inter prediction point, or encode it immediately before (last) without referring to the intra prediction point.
- An inter-prediction point is a 3D point near a 3D point (for example, a 3D point corresponding to an ancestor node such as the parent node of a prediction tree) (for example, the 3D point closest to the 3D point encoded immediately before). You may choose.
- the switching unit 12910 determines the prediction point to be used for prediction by selecting either the intra prediction point or the inter prediction point.
- the position information of one or more candidate points among the plurality of coded three-dimensional points is determined as the prediction point, and the prediction value is calculated based on the prediction point.
- the prediction point is determined based on the three-dimensional point encoded immediately before the three-dimensional point to be encoded. That is, the three-dimensional data coding apparatus 12900 determines one or more candidate points for calculating the predicted value based on one or more reference points among the plurality of coded three-dimensional points.
- One or more reference points are three-dimensional points encoded immediately before the three-dimensional point to be encoded, and correspond to, for example, the parent node (ancestor node) of one three-dimensional point to be encoded in the prediction tree. It may be a three-dimensional point.
- the three-dimensional data coding device 12900 may select any one of the intra prediction point and the inter prediction point as the prediction point according to the procedure of the flowchart of FIG. 50 described later. Further, even if the information related to the prediction (prediction information) for selecting which of the intra prediction point and the inter prediction point is used as the prediction point is entropy-coded and described in the header part of each three-dimensional point. Alternatively, it may be described as being interleaved with each three-dimensional point. Further, information on motion compensation such as a motion vector may be described in the header portion of a frame or a prediction tree (Predtree), or may be entropy-coded and described in the header portion of each three-dimensional point.
- Prediction information information related to the prediction
- Predtree prediction tree
- the reference point cloud of the inter-prediction may be a point cloud included in a coded frame different from the coded frame, or a coded point cloud included in the same frame as the coded frame. It may be a group.
- the three-dimensional data coding device 12900 reduces the amount of information of the first residual signal to be entropy-coded by predicting the coding target point by using inter-prediction in addition to intra-prediction. There is a possibility that the coding efficiency can be improved.
- the three-dimensional data encoding device 12900 does not always need to refer to the inter-prediction point, and has a predetermined time interval (for example, every 1 second), a predetermined frame interval (for example, every 30 frames), or three-dimensional.
- the buffer 12907 that stores the reference point cloud of the inter-prediction is initialized, and the coding is performed based only on the information of the point cloud to be encoded. You may.
- the corresponding 3D data decoding device it is possible to start jumping playback from a point cloud that is not the beginning of the bitstream that does not refer to the inter-predicted point, and it is possible to improve the random accessibility or error tolerance of the bitstream. there is a possibility.
- the three-dimensional data encoding device 12900 encodes the position information indicated by the coordinates expressed in Cartesian coordinates.
- the three-dimensional data coding apparatus 12900 encodes the position information represented by the coordinates expressed in polar coordinates.
- FIG. 49 is a block diagram of the three-dimensional data decoding device 12920 according to the present embodiment.
- the three-dimensional data decoding device 12920 has other processing units such as a processing unit for decoding the attribute information of the point cloud. It may be provided with a processing unit.
- the three-dimensional data decoding device 12920 performs inter-predictive decoding to decode the point cloud to be decoded while referring to the decoded point cloud. For example, the three-dimensional data decoding device 12920 decodes the bitstream generated by the three-dimensional data coding device 12900 shown in FIG. 48.
- the three-dimensional data decoding device 12920 includes an entropy decoding unit 12921, an inverse quantization unit 12922, a buffer 12923, an intra prediction unit 12924, a buffer 12925, a motion compensation unit 12926, an inter prediction unit 12927, and a switching unit 12928. And prepare.
- the three-dimensional data decoding device 12920 acquires the bit stream generated by the three-dimensional data coding device 12900.
- the entropy decoding unit 12921 generates a quantized first residual signal by entropy decoding the input bit stream for each three-dimensional point of the prediction tree (Predtree).
- the dequantization unit 12922 dequantizes the quantized first residual signal and reproduces the first residual signal.
- the first residual signal of each three-dimensional point is added to the predicted value based on the predicted point corresponding to each three-dimensional point, and then generated (output) as a decoding point. That is, the three-dimensional data decoding device 12920 calculates the position information of one three-dimensional point to be decoded by adding the predicted value and the predicted residual.
- Buffer 12923 holds the generated decoding points as a reference point cloud for intra-prediction. For example, the buffer 12923 may initialize the data held for each prediction tree (target point cloud). Further, the buffer 12925 holds the generated decoding point as a reference point group for interprediction. For example, the buffer 12925 may initialize the data held for each prediction tree (target point cloud).
- the intra prediction unit 12924 uses the intra prediction point for prediction as a prediction such as a plurality of three-dimensional points (reference point cloud for intra prediction) included in a prediction tree (Predtree) including the three-dimensional points to be decoded. It is determined by a predetermined method with reference to the information in the tree (Predtree). For example, the intra prediction unit 12924 extrapolates using two dequantized three-dimensional points (decoding points) immediately before the three-dimensional point to be decoded (for example, an ancestor node such as the parent node of the prediction tree). The intra prediction point may be determined by doing so.
- a prediction such as a plurality of three-dimensional points (reference point cloud for intra prediction) included in a prediction tree (Predtree) including the three-dimensional points to be decoded. It is determined by a predetermined method with reference to the information in the tree (Predtree). For example, the intra prediction unit 12924 extrapolates using two dequantized three-dimensional points (decoding points
- the motion compensation unit 12926 reproduces the decoded point cloud based on the plurality of three-dimensional points (plural decoding points) included in the prediction tree (Predtree) including the three-dimensional points to be decoded, and the decoded points. By correcting the displacement (motion compensation) between the group and the point cloud to be decoded, an inter-prediction point cloud, which is a reference point cloud for inter-prediction after alignment, is generated.
- the inter-prediction unit 12927 determines the inter-prediction point to be used for prediction by a predetermined method based on the motion-compensated inter-prediction point group. For example, the inter prediction unit 12927 may select the point closest to the intra prediction point from the inter prediction point group and select it as the inter prediction point, or the tertiary decoded immediately before without referring to the intra prediction point. Select a 3D point near the original point (for example, the 3D point corresponding to the ancestor node such as the parent node of the prediction tree) (for example, the 3D point closest to the immediately decoded 3D point) as the inter-prediction point. You may.
- the switching unit 12928 determines the prediction point to be used for prediction by selecting either the intra prediction point or the inter prediction point.
- the position information of one or more candidate points among the plurality of decoded three-dimensional points is determined as the prediction point, and the prediction value is calculated based on the prediction point.
- the intra prediction unit 12924 and the inter prediction unit 12927 determine the prediction point (intra prediction point or inter prediction point) based on the three-dimensional point decoded immediately before the three-dimensional point to be decoded. That is, the three-dimensional data decoding device 12920 determines one or more candidate points for calculating the predicted value based on one or more reference points among the plurality of decoded three-dimensional points.
- the reference point of 1 or more is a 3D point encoded immediately before the 3D point to be decoded.
- the cubic corresponding to the parent node (ancestor node) of one 3D point to be decoded It may be the original point.
- the three-dimensional data decoding device 12920 may select any one of the intra prediction point and the inter prediction point as the prediction point according to the procedure of the flowchart of FIG. 51 described later. Further, the three-dimensional data decoding device 12920 uses the intra prediction point and the inter prediction point based on the information related to the prediction (prediction information) for selecting which of the intra prediction point and the inter prediction point is used as the prediction point. Any one of the above may be selected as the prediction point.
- the prediction information may be entropy-coded and described in the header portion of each three-dimensional point, or may be described interleaved with each three-dimensional point.
- information on motion compensation such as a motion vector may be described in the header portion of a frame or a prediction tree (Predtree), may be entropy-coded and described in the header portion of each point, or may be described in the header portion of each point. It may be described as being interleaved with the original point.
- the prediction information or the information regarding the motion compensation may be notified to the three-dimensional data decoding device 12920 from the corresponding three-dimensional data coding device 12900.
- the reference point cloud of the inter-prediction may be a point cloud included in a coded frame different from the coded frame, or a coded point cloud included in the same frame as the coded frame. It may be a group.
- the three-dimensional data decoding device 12920 predicts the decoding target point by using the inter-prediction in addition to the intra-prediction, so that the encoded bit stream (for example, for example) with reference to the decoded point cloud is used.
- the point cloud can be decoded from the bit stream (bit stream output from the three-dimensional data encoding device 12900 in FIG. 48).
- the three-dimensional data decoding device 12920 does not always need to refer to the inter-prediction point, and has a predetermined time interval (for example, every 1 second), a predetermined frame interval (for example, every 30 frames), or a corresponding tertiary. Decoding is performed based only on the information of the point cloud to be decoded, such as by initializing the buffer 12925 that stores the reference point cloud of the inter-prediction at an arbitrary timing notified from the original data encoding device 12900. You may do so. As a result, the three-dimensional data decoding device 12920 can start jumping playback from a point cloud that is not the beginning of the bitstream that does not refer to the inter-predicted point, and can improve the random accessibility and error tolerance of the bitstream. There is sex.
- the three-dimensional data decoding device 12920 decodes the position information represented by the coordinates expressed in Cartesian coordinates when the bitstream has the coded data in which the position information represented by the coordinates expressed in Cartesian coordinates is encoded. ..
- the three-dimensional data decoding apparatus 12920 decodes the position information represented by the coordinates expressed in polar coordinates.
- FIG. 50 is a flowchart showing an example of a procedure for coding each three-dimensional point of the prediction tree (Predtree) in the three-dimensional data coding apparatus 12900.
- the three-dimensional data coding device 12900 first determines the intra prediction point from the reference point group of the intra prediction (S12901).
- the three-dimensional data coding apparatus 12900 may determine the intra prediction point by using, for example, the method of determining the prediction point using the prediction tree disclosed in the embodiment described above.
- the 3D data coding device 12900 generates a prediction tree using a plurality of coded 3D points, and selects one or more candidate points from a plurality of coded 3D points based on the prediction tree. You may choose.
- the three-dimensional data coding apparatus 12900 may determine the prediction point having the smallest code amount as the intra prediction point among at least one intra prediction point determined by at least one of the above methods. Further, in the three-dimensional data coding apparatus 12900, among at least one intra prediction point determined by at least one of the above methods, the prediction point having the smallest absolute sum (or square sum) of the coordinate residuals. May be determined as an intra prediction point.
- the three-dimensional data coding device 12900 outputs an intra-prediction-related parameter (S12902).
- the three-dimensional data encoding device 12900 outputs information indicating the candidate for the selected determination method to the bitstream as an intra prediction-related parameter. You may.
- the three-dimensional data coding device 12900 determines the inter-prediction point with reference to at least one candidate point extracted from the inter-prediction point group. For example, the three-dimensional data coding apparatus 12900 may determine one candidate point as an inter-prediction point, or determine a prediction point having an average value of the coordinates of a plurality of candidate points as an inter-prediction point. May be good. Alternatively, the three-dimensional data coding apparatus 12900 may determine a prediction point having the average value of the coordinates of the intra prediction point and at least one candidate point as the coordinates as the inter prediction point.
- the three-dimensional data coding device 12900 may search for a point located in the vicinity of the intra prediction point as at least one candidate point (S12903).
- the three-dimensional data coding apparatus 12900 may assign smaller index values to each of the determined at least one inter-prediction point in order of proximity to the intra-prediction point (S12904).
- the three-dimensional data coding apparatus 12900 determines whether or not the search is completed (S12905), and if the search is completed (Yes in S12905), the process proceeds to the next step S12906, and the search is not completed. If (No in S12905), the process returns to step S12903.
- the completion of the search may be determined by finding a predetermined number of inter-predicted points, may be determined by searching all of a predetermined range of point clouds, or may be determined by searching all of a predetermined range of inter-predicted points. May be determined by satisfying either the discovery of the above point cloud or the search for all of the point clouds in the predetermined range.
- the three-dimensional data coding device 12900 determines the prediction method (S12906). Specifically, the three-dimensional data coding device 12900 determines whether the method for determining the prediction point is intra-prediction or inter-prediction. That is, the three-dimensional data coding device 12900 determines whether to determine the intra prediction point as the prediction point or the inter prediction point as the prediction point. For example, the three-dimensional data coding apparatus 12900 may determine the prediction method of the prediction point having the smallest code amount among the intra prediction points and the inter prediction points. Further, the three-dimensional data coding apparatus 12900 may determine the prediction method of the prediction point having the smallest absolute sum (or square sum) of the coordinate residuals among the intra prediction points and the inter prediction points.
- the three-dimensional data coding apparatus 12900 determines whether the mode of the determined prediction method is an intermode indicating that the prediction method is interprediction or an intraprediction mode indicating that the prediction method is intraprediction. Judgment (S12907).
- the three-dimensional data coding apparatus 12900 provides a bitstream with identification information (for example, a flag) indicating that the inter-prediction point is determined as the prediction point.
- identification information for example, a flag
- the three-dimensional data encoding device 12900 uses information about the number of candidate points used for determining the coordinates of the inter-prediction points, the index value of each candidate point used, and the like as bits as inter-prediction-related parameters. Output to the stream (S12909).
- the index value may be assigned to one or more candidate points used to determine the predicted value.
- the three-dimensional data coding apparatus 12900 sets the bit of the identification information (for example, a flag) indicating that the intra prediction point is determined as the prediction point.
- the identification information in step S12908 and step S12911 is information indicating whether the inter prediction point is determined as the prediction point or the intra prediction point is determined as the prediction point.
- the three-dimensional data coding apparatus 12900 encodes the coordinate information of the three-dimensional point to be encoded with reference to the predicted point obtained by the determined prediction method (S12910).
- the three-dimensional data coding apparatus 12900 determines at least one inter-prediction point with reference to the inter-prediction point cloud and the intra-prediction point, and obtains the prediction point from these intra-prediction points and the inter-prediction points. The method is determined, and the position information (coordinate information) of the three-dimensional point to be encoded is encoded with reference to the predicted point.
- the intra prediction-related parameters such as the three-dimensional point encoded immediately before (for example, the three-dimensional point corresponding to the ancestor node such as the parent node of the prediction tree) are not referred to, without referring to the intra prediction point.
- An inter-prediction point may be searched in the vicinity of a three-dimensional point uniquely determined.
- S12902 may not be carried out immediately after S12901, but S12902 may be carried out immediately after S12911.
- FIG. 51 is a flowchart showing an example of a procedure for decoding each three-dimensional point of the predicted tree (Predtree) in the three-dimensional data decoding device 12920.
- FIG. 51 corresponds to the decoding of the bitstream generated according to the coding procedure of FIG. That is, the bitstream contains a coded first residual signal (predicted residual) and an index value assigned to one candidate point used to calculate the predicted value.
- the 3D data decoding device 12920 first acquires the intra-prediction-related parameters from the bitstream (S12921).
- the three-dimensional data decoding device 12920 determines the intra prediction point based on the acquired intra prediction related parameters (S12922). Specifically, the three-dimensional data decoding device 12920 determines the intra prediction point by the same method as in step S12901 of FIG. In the three-dimensional data decoding device 12920, the intra-prediction-related parameter is notified from the corresponding three-dimensional data coding device 12900, and the intra-prediction point is determined according to the intra-prediction-related parameter.
- the intra-prediction-related parameters are acquired in step S12921 and include information specifying at least one method of determining the intra-prediction point and parameters accompanying this information.
- the three-dimensional data decoding device 12920 acquires identification information indicating the mode of the prediction method from the bit stream (S12923).
- the three-dimensional data decoding device 12920 indicates whether the acquired identification information indicates an intermode indicating that the prediction method is inter-prediction or an intra-prediction mode indicating that the prediction method is intra-prediction. Judgment (S12924).
- the three-dimensional data decoding device 12920 acquires the inter-prediction-related parameters from the bit stream (S12925).
- the three-dimensional data decoding device 12920 executes a process (S12926 to S12929) for determining the inter prediction point. Specifically, the three-dimensional data decoding device 12920 determines the inter prediction point by the same method as in steps S12903 to S12905 of FIG. For example, the three-dimensional data decoding device 12920 determines the inter-prediction point with reference to at least one candidate point extracted from the inter-prediction point cloud. For example, the three-dimensional data decoding device 12920 may determine one candidate point as an inter-prediction point, or may determine a prediction point having an average value of the coordinates of a plurality of candidate points as an inter-prediction point. good. Alternatively, the three-dimensional data decoding device 12920 may determine a prediction point having an average value of the coordinates of the intra prediction point and at least one candidate point as the coordinates as the inter prediction point.
- the three-dimensional data decoding device 12920 may search for a point located in the vicinity of the intra prediction point as at least one candidate point (S12926).
- the three-dimensional data decoding device 12920 may assign smaller index values to each of the determined at least one inter-prediction point in order of proximity to the intra-prediction point (S12927).
- the three-dimensional data decoding device 12920 determines whether or not the search is completed (S12928), and if the search is completed (Yes in S12928), the process proceeds to the next step S12929, and the search is not completed. (No in S12928), the process returns to step S12926.
- the completion of the search may be determined by finding a predetermined number of inter-predicted points, may be determined by searching all of a predetermined range of point clouds, or may be determined by searching all of a predetermined range of inter-predicted points. May be determined by satisfying either the discovery of the above point cloud or the search for all of the point clouds in the predetermined range.
- the three-dimensional data decoding device 12920 determines the inter-prediction point based on the inter-prediction-related parameter while referring to the inter-prediction point group and the intra-prediction point (S12929).
- the three-dimensional data decoder 12920 contains information on the number of candidate points used to determine the coordinates of the inter-prediction points included in the inter-prediction-related parameters, and the index value assigned to each candidate point used.
- the candidate points used for determining the coordinates of the inter-predicted points are specified, and the coordinates of the inter-predicted points are determined using the specified candidate points to determine the inter-predicted points. That is, the three-dimensional data decoding device 12920 selects one candidate point from a plurality of decoded three-dimensional points based on the index value included in the bit stream.
- the three-dimensional data decoding device 12920 refers to the prediction point obtained by the specified prediction method after step S12929 or in the case of the intra mode in step S12924, and the position information (coordinate information) of the three-dimensional point to be decoded is referred to. ) Is decoded (S12930).
- the three-dimensional data decoding device 12920 decodes the coordinate information of the point to be decoded by referring to the inter-prediction point when the prediction method is inter-prediction, and intra-prediction when the prediction method is intra-prediction.
- the coordinate information of the point to be decoded is decoded by referring to the point.
- the intra prediction-related parameters such as the three-dimensional point decoded immediately before (for example, the three-dimensional point corresponding to the ancestor node such as the parent node of the prediction tree) without referring to the intra prediction point are not used.
- An inter-prediction point may be searched in the vicinity of a uniquely determined three-dimensional point.
- S12921 and S12922 may not be executed immediately before S12923, but S12921 and S12922 may be executed when the intra mode is determined by S12924.
- FIG. 52 is a block diagram of a three-dimensional data coding device 12930 according to a modified example of the present embodiment.
- FIG. 52 describes a processing unit for coding the position information (geometry) of the point cloud
- the three-dimensional data coding device 12930 is a processing unit or the like that encodes the attribute information of the point cloud. Other processing units may be provided.
- the point cloud to be coded is encoded with reference to the coded point cloud.
- the three-dimensional data coding device 12930 is located in polar coordinates, which is a group of points having position information expressed in Cartesian coordinates, as compared with the three-dimensional data coding device 12900 in FIG.
- the three-dimensional data coding device 12930 is the same in its configuration and operation as compared with the three-dimensional data coding device 12900, except for the above-mentioned differences.
- the three-dimensional data coding device 12930 includes a coordinate conversion unit 12931, a grouping unit 12932, a buffer 12933, a buffer 12934, an intra prediction unit 12935, a buffer 12936, a motion detection compensation unit 12937, and an inter prediction unit 12938. , A switching unit 12939, a coordinate conversion unit 12940, a buffer 12941, a quantization unit 12942, and an entropy coding unit 12943.
- the coordinate conversion unit 12931 converts the coordinate system of the position information of the target point cloud, which is the input data of the point cloud to be encoded, from the orthogonal coordinate system to the polar coordinate system. That is, the coordinate conversion unit 12931 generates the position information of the polar coordinate system by converting the coordinate system of the position information of the orthogonal coordinate system of one three-dimensional point to be encoded.
- the point cloud to be coded converted into polar coordinates is output to the grouping unit 12932.
- the grouping unit 12932 extracts a point cloud to be a prediction tree (Predtree), which is a unit of coding, from a target point cloud which is a point cloud to be coded converted into polar coordinates, and sets it as one group. .. Buffer 12933 holds the generated prediction tree. For example, the buffer 12933 may initialize the data held for each predicted tree. Processing for coding is sequentially executed for each of a plurality of three-dimensional points included in the prediction tree (Predtree) held in the buffer 12933.
- Predtree a prediction tree
- This first residual signal is a residual signal of position information expressed in polar coordinates.
- the first residual signal is also referred to as a predicted residual.
- This first residual signal is an example of the first residual. Since the position information of the plurality of three-dimensional points held in the buffer 12933 is converted into the polar coordinate system, the first residual is the difference between the position information of the transformed polar coordinate system and the predicted value.
- the first residual signal and the prediction point are added and held in the buffer 12934, 12936 as the decoded points that have been coded.
- the position information of the decoding point held in the buffer 12934 and 12936 is expressed in polar coordinates.
- the functions of buffers 12934 and 12936 are different from those of buffers 12905 and 12907, but the other functions are the same.
- the intra prediction unit 12935, the motion detection compensation unit 12937, the inter prediction unit 12938, and the switching unit 12939 also have the intra prediction unit 12906 in that the position information of the three-dimensional point to be processed is expressed in polar coordinates.
- the functions thereof are different from those of the motion detection compensation unit 12908, the inter-prediction unit 12909, and the switching unit 12910, but the other functions are the same.
- the coordinate conversion unit 12940 acquires the same decoding point as the decoding point held in the buffer 12934, 12936, and converts the coordinate system of the position information of the acquired decoding point from the polar coordinate system to the orthogonal coordinate system. That is, the coordinate conversion unit 12940 generates the position information of the Cartesian coordinate system by inversely converting the coordinate system of the position information of the polar coordinate system after the conversion by the coordinate conversion unit 12931.
- the buffer 12941 holds the position information of the three-dimensional points expressed in Cartesian coordinates, which is input to the three-dimensional data coding device 12930.
- the difference (second residual signal) between the input position information of the Cartesian coordinate system and the position information of the Cartesian coordinate system in which the coordinate system is converted from the polar coordinate system to the Cartesian coordinate system by the coordinate conversion unit 12940 is calculated.
- This second residual signal is an example of the second residual. That is, the second residual signal includes the position information of the orthogonal coordinate system in which the coordinate conversion unit 12931 has not been subjected to coordinate conversion, and the position information after being once converted to polar coordinates and then further back-converted to the orthogonal coordinate system. It is a difference of, and is a conversion error generated by coordinate transformation.
- the quantization unit 12942 quantizes the second residual signal.
- the entropy coding unit 12943 entropy-codes the first residual signal and the quantized second residual signal to generate coded data, and outputs a bit stream including the coded data.
- the three-dimensional data coding device 12930 converts the coordinate system of the position information of the three-dimensional point from the Cartesian coordinate system to the polar coordinate system, and encodes the position information of the polar coordinate system. As a result, it is possible to improve the prediction accuracy of the point to be encoded when encoding the point cloud generated by acquiring the three-dimensional position of the surrounding object around the sensor position such as LiDAR. , There is a possibility that the coding efficiency can be improved.
- FIG. 53 is a block diagram of a three-dimensional data decoding device 12950 according to a modified example of the present embodiment.
- FIG. 53 describes a processing unit for decoding the position information (geometry) of the point cloud
- the three-dimensional data decoding device 12950 is another processing unit or the like that decodes the attribute information of the point cloud. It may be provided with a processing unit.
- the three-dimensional data decoding device 12950 performs inter-predictive decoding that decodes the point cloud to be decoded while referring to the decoded point cloud.
- the three-dimensional data decoding device 12950 decodes the bitstream generated by the three-dimensional data coding device 12930 shown in FIG. 52.
- the three-dimensional data decoding device 12950 does not perform inverse quantization of the first residual signal (predicted residual) as compared with the three-dimensional data decoding device 12920 of FIG. 49 in the basic configuration and operation.
- the second residual signal of Cartesian coordinates which corresponds to the conversion error caused by the conversion between rectangular coordinates and polar coordinates, is entropy-decoded, inversely quantized, and reproduced, and the point converted from the decoded point of the corresponding polar coordinates to Cartesian coordinates. It is different from the point that is added to and output as a decoding point of Cartesian coordinates.
- the three-dimensional data decoding device 12950 is the same as the three-dimensional data decoding device 12920 except for the above-mentioned differences.
- the three-dimensional data decoding device 12950 includes an entropy decoding unit 12951, a buffer 12952, an intra prediction unit 12953, a buffer 12954, a motion compensation unit 12955, an inter prediction unit 12965, a switching unit 12957, and a coordinate conversion unit 12985. , With an inverse quantization unit 12959.
- the entropy decoding unit 12951 generates a first residual signal and a quantized second residual signal by entropy decoding the input bit stream for each three-dimensional point of the prediction tree (Predtree).
- the first residual signal of each three-dimensional point is added to the predicted value based on the predicted point corresponding to each three-dimensional point, and then generated (output) as a decoding point expressed in polar coordinates.
- the buffer 12952 holds the generated decoding point as a reference point cloud for intra-prediction. For example, the buffer 12952 may initialize the data held for each prediction tree (target point cloud). Further, the buffer 12954 holds the generated decoding point as a reference point cloud for interprediction. For example, the buffer 12954 may initialize the data held for each prediction tree (target point cloud).
- the position information of the decoding point held in the buffer 12952, 12954 is expressed in polar coordinates. In this respect, the functions of buffers 12952 and 12954 are different from those of buffers 12923 and 12925, but the other functions are the same.
- the intra prediction unit 12953, the motion compensation unit 12955, the inter prediction unit 12965, and the switching unit 12957 also have the intra prediction unit 12924 and the movement in that the position information of the three-dimensional point to be processed is expressed in polar coordinates.
- the functions thereof are different from those of the compensation unit 12926, the inter-prediction unit 12927, and the switching unit 12928, but the other functions are the same.
- the coordinate conversion unit 12985 acquires the same decoding point as the decoding point held in the buffer 12952, 12954, and converts the coordinate system of the position information of the acquired decoding point from the polar coordinate system to the orthogonal coordinate system.
- the dequantization unit 12959 dequantizes the quantized second residual signal and reproduces the second residual signal.
- the position information of the Cartesian coordinate system obtained by coordinate transformation by the coordinate conversion unit 12985 and the second residual signal reproduced by inverse quantization by the inverse quantization unit 12959 are added and then added to the Cartesian coordinate system. It is generated (output) as a decoding point including the position information of.
- the three-dimensional data decoding device 12950 converts the coordinate system of the decoding point having the position information of the polar coordinate system from the polar coordinate system to the orthogonal coordinate system, and obtains the position information of the orthogonal coordinate system and the position information of the polar coordinate system.
- a means for adding to the second residual signal of the orthogonal coordinates corresponding to the error generated by the conversion between the two is provided.
- the three-dimensional data decoding device 12950 is derived from a bit stream encoded with reference to a point cloud encoded in polar coordinates (for example, a bit stream output from the three-dimensional data coding device 12930 of FIG. 52).
- the point cloud can be decoded.
- FIG. 54 is an example of the geometry parameter set (GPS) syntax. This syntax is used in the three-dimensional data coding apparatus 12900, 12930 and the three-dimensional data decoding apparatus 12920, 12950 described with reference to FIGS. 48 to 53.
- GPS geometry parameter set
- GPS may notify information indicating whether or not to use a coordinate system different from orthogonal coordinates such as polar coordinates in the decoding process of each point, for example, gps_alt_coordinates_flag.
- a coordinate system different from orthogonal coordinates such as polar coordinates in the decoding process of each point
- gps_alt_coordinates_flag 1
- the alternative coordinate system for example, polar coordinate system
- gps_alt_coordinates_flag 1 (that is, when the first identification information indicates that the coded data includes the first coded data), specifically, one or more candidates used for calculating the predicted value.
- the position information of the points and the position information of one three-dimensional point to be encoded used for calculating the first residual are the position information of the polar coordinate system.
- the bitstream contains gps_coordinate_trans_enabled_flag.
- gps_coordinate_trans_enabled_flag is an example of the second identification information indicating whether to output the position information of the polar coordinate system or the position information of the orthogonal coordinate system in decoding.
- gps_alt_coordinates_flag 1
- gps_coordinate_trans_enabled_flag 0
- the position information of the polar coordinate system is encoded
- bitstream does not include the gps_coordinate_trans_enabled_flag (second identification information). May be good.
- the gps_alt_coordinates_flag and gps_coordinate_trans_enabled_flag may be included in the SPS, may be included in the header of the data unit, or may be included in other control information as metadata. May be included as.
- FIG. 55 is an example of the syntax of each three-dimensional point (Node of Predtree). This syntax is used in the three-dimensional data coding apparatus 12900, 12930 and the three-dimensional data decoding apparatus 12920, 12950 described with reference to FIGS. 48 to 54.
- the three-dimensional data encoding device 12900, 12930 first transfers the identification information (pred_mode) indicating how to obtain the intra prediction point at the three-dimensional point to be encoded or decoded to the three-dimensional data decoding device 12920, 12950. Notice.
- the three-dimensional data coding device 12900, 12930 may notify the three-dimensional data decoding device 12920, 12950 of additional information for determining the intra prediction point according to the identification information (pred_mode).
- the 3D data encoding device 12900, 12930 encodes.
- Information (intra_pred_flag) indicating whether or not the prediction method at the target or the three-dimensional point to be decoded is intra-prediction (that is, inter-prediction) may be notified to the three-dimensional data decoding apparatus 12920, 12950.
- intra_pred_flag 0, the value of intra_pred_flag may be set to 1 (intra prediction).
- the identification information (inter_pred_mode) indicating how to obtain the inter-prediction point at the 3D point of the coding target or the decoding target. May be notified. Further, the three-dimensional data encoding device 12900, 12930 sets the number of candidate points in the inter-prediction point cloud to be referred to when determining the inter-prediction point in NumRefPoints according to the identification information (inter_pred_mode), and sets each candidate point in NumRefPoints.
- inter_ref_point_idx Only NumRefPoints of indexes (inter_ref_point_idx) may be notified to the three-dimensional data decoding apparatus 12920, 12950.
- the average value of the coordinates of the plurality of designated candidate points may be used as the coordinates of the inter-prediction point. ..
- the three-dimensional data coding apparatus 12900 and 12930 may provide an inter_pred_mode for selecting a specific candidate point such as the smallest index by omitting the notification of the index of the candidate point.
- the three-dimensional data encoding device 12900, 12930 provides notification of the index of candidate points by providing a determination process of whether or not inter_pred_mode indicates the mode, setting the value of NumRefPoints to 0, and the like. May be omitted.
- inter_pred_mode indicates the mode, setting the value of NumRefPoints to 0, and the like. May be omitted.
- inter_pred_mode the number of candidate points in the inter-predicted point cloud to be referred to when determining the inter-predicted points is used. You may be notified.
- the identification information (pred_mode) indicating how to obtain the intra prediction point such as the three-dimensional point encoded or decoded immediately before (for example, the three-dimensional point corresponding to the ancestor node such as the parent node of the prediction tree), is not used.
- the three-dimensional data encoding device 12900, 12930 notifies the first difference (1st_residual_value) of the position information (coordinate value) of the point to be encoded or decoded and the position information (coordinate value) of the predicted point. May be good.
- the decoding result in another coordinate system such as polar coordinates is obtained in Cartesian coordinates.
- the second difference (2nd_residual_value) between the position information (coordinate value) converted into the original coordinate system and the original position information (coordinate value) may be notified.
- the notification may be decomposed into a plurality of syntaxes such as positive / negative information and absolute value information.
- the three-dimensional data coding device 12900, 12930 and the three-dimensional data decoding device 12920, 12950 match.
- the predicted processing can be performed, and the three-dimensional data decoding apparatus 12920, 12950 can decode the three-dimensional point to be processed without causing inconsistency with the corresponding three-dimensional data encoding apparatus 12900, 12930.
- the apparatus or process, syntax, etc. disclosed with reference to FIGS. 48 to 55 may be implemented in combination with at least a part of other embodiments. Further, the apparatus or process disclosed with reference to FIGS. 48 to 55, a part of the syntax, and the like may be carried out in combination with other embodiments. Further, not all the components disclosed with reference to FIGS. 48 to 55 are necessary, and only some of the components may be included.
- the three-dimensional data coding apparatus performs the processing shown in FIG. 56.
- the three-dimensional data coding apparatus determines a predicted value based on the position information of one or more candidate points among a plurality of coded three-dimensional points (S12931).
- the three-dimensional data coding apparatus calculates the predicted residual, which is the difference between the position information of one three-dimensional point to be encoded among the plurality of three-dimensional points and the predicted value (S12932).
- the three-dimensional data coding apparatus generates coded data by coding the predicted residual (S12933).
- the three-dimensional data coding device generates a bit stream containing the coded data (S12934).
- step S12931 the three-dimensional data coding apparatus determines one or more candidate points based on one or more reference points among a plurality of coded three-dimensional points.
- a plurality of three-dimensional points constitute a prediction tree.
- One or more reference points include a three-dimensional point corresponding to the parent node of one three-dimensional point to be encoded.
- one or more candidate points used for calculating the predicted value are determined based on the parent node of one three-dimensional point to be coded in the predicted tree, so that the predicted residual can be reduced. It is possible to improve the coding efficiency.
- an index value is assigned to one or more candidate points.
- the bitstream further contains an index value assigned to the candidate point used to determine the predicted value.
- the three-dimensional data decoding device can easily identify the candidate point based on the index value. Therefore, the processing load in the three-dimensional data decoding device can be reduced.
- the three-dimensional data encoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the three-dimensional data decoding device performs the process shown in FIG. 57.
- the three-dimensional data decoder acquires a bitstream containing the coded predicted residuals and the index value assigned to one candidate point used to calculate the predicted value (S12941).
- the three-dimensional data decoding device determines one candidate point based on one or more reference points among a plurality of decoded three-dimensional points based on the index value (S12942).
- the three-dimensional data decoding device calculates a predicted value based on the position information of one determined candidate point (S12943).
- the three-dimensional data decoding device calculates the predicted residual by decoding the encoded predicted residual (S12944).
- the three-dimensional data decoding device calculates the position information of one three-dimensional point to be decoded by adding the predicted value and the predicted residual (S12945).
- one candidate point is determined based on one or more reference points among a plurality of coded three-dimensional points, and decoding is performed using a predicted value based on the position information of the determined one candidate point.
- the target three-dimensional point can be decoded.
- a plurality of three-dimensional points constitute a prediction tree.
- One or more reference points include a three-dimensional point corresponding to the parent node of one three-dimensional point to be encoded.
- an index value is assigned to one or more candidate points.
- the bitstream further contains an index value assigned to the candidate point used to determine the predicted value.
- the three-dimensional data decoding device can easily identify the candidate point based on the index value. Therefore, the processing load in the three-dimensional data decoding device can be reduced.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- FIG. 58 is a flowchart showing a coordinate system switching process in the coding process.
- switching between coding using the three-dimensional data coding device 12900 described with reference to FIG. 48 and coding using the three-dimensional data coding device 12930 described with reference to FIG. 52 is performed. conduct. Further, in the flowchart of FIG. 58, it is also switched between coding the position information of the orthogonal coordinate system and coding the position information of the polar coordinate system.
- the three-dimensional data coding device confirms the coordinate system of the input point cloud, and determines the coordinate system of the coding process and the decoding process (S13001). That is, the three-dimensional data coding device determines the coordinate system of the position information to be the target of the coding process and the decoding process.
- the three-dimensional data coding device determines whether or not the coordinate system of the input point group and the determined coordinate system of the coding process and the decoding process are the same (S1302).
- the coordinate system of the input point group is polar coordinates and the coordinate system of the coding process and the decoding process are orthogonal coordinates is shown as an example.
- the coordinate system of the input point group may be Cartesian coordinates, and the coordinate system of the coding process and the decoding process may be polar coordinates.
- the polar coordinate system can be read as an orthogonal coordinate system, and the orthogonal coordinate system can be read as a polar coordinate system.
- the three-dimensional data coding device determines whether or not the coding coordinate system is a polar coordinate system (Orthogonal coordinate system) (S13005).
- the gps_coordinate_trans_enabled_flag and gps_alt_coordinates_flag described with reference to FIG. 54 may have a syntax configuration that is independently shown regardless of the dependency. That is, gps_coordinate_trans_enabled_flag may be shown in GPS regardless of the presence or absence of gps_alt_coordinates_flag or the value of gps_alt_coordinates_flag.
- the configuration may be adopted.
- FIG. 59 is a flowchart showing a coordinate system switching process in the decoding process.
- it is switched between decoding using the three-dimensional data decoding device 12920 described with reference to FIG. 49 and decoding using the three-dimensional data decoding device 12950 described with reference to FIG. 53. Further, in the flowchart of FIG. 59, it is also switched between decoding the position information of the orthogonal coordinate system and decoding the position information of the polar coordinate system.
- the three-dimensional data decoder analyzes the metadata contained in the bitstream (S13011). Specifically, the metadata is control information included in GPS, SPS, headers and the like. The 3D data decoder confirms the gps_alt_coordinates_flag and gps_coordinate_trans_enabled_flag contained in the metadata.
- the coordinate system of the position information of one three-dimensional point to be decoded is determined according to the value of gps_alt_coordinates_flag, and therefore whether or not the first coded data indicated by the first identification information is included.
- the coordinate system is determined according to.
- the 3D data decoding device decodes the position information in the coordinate system determined without coordinate conversion (S13016).
- the coordinate system of the position information of one three-dimensional point to be decoded is a polar coordinate system.
- the first residual are added to convert the coordinate system of the position information of the polar coordinate system, and the position information of the Cartesian coordinate system obtained by the conversion is used for one three-dimensional point to be decoded. Calculated as position information.
- the coded data includes the second residual, and the three-dimensional data decoding device calculates the second residual by decoding the encoded second residual, and one tertiary of the decoding target.
- the position information of the Cartesian coordinate system obtained by transforming the coordinate system and the second residual are added, and the position information obtained by the addition is 1 of the decoding target. It is calculated as the position information of three three-dimensional points.
- the process proceeds to process 2 of steps S13015 to S13017, and process 1 is performed. If the coordinate system to be decoded is determined to be Cartesian coordinates, the determination in process 2 may be skipped and decoding may be performed using the three-dimensional data decoding device 12920 having the configuration shown in FIG. 49.
- the gps_coordinate_trans_enabled_flag is coordinate conversion information indicating whether or not to perform coordinate conversion of the decoding point before outputting each point from the three-dimensional data decoding device, but the coordinate conversion is performed when each three-dimensional point is encoded. It may be information indicating whether or not the above is performed, or it may be information indicating whether or not the error information (conversion error) generated by the coordinate conversion is included in the bit stream. Further, when the information is included, it may be determined whether or not the coordinate conversion is performed by the three-dimensional data decoding device or the application.
- the processing can be switched by combining the coordinate system of the input point group, the coordinate system of the output point group, the coordinate system of the position information to be the target of the coding process, and the coordinate system of the position information to be the target of the decoding process.
- the signaling method showing these coordinate systems has been described by taking the coding using the predictive tree as an example, but the same method may be used in the case of the octane tree coding.
- the coordinate system of the input point group, the coordinate system of the output point group, the coordinate system of the position information to be the target of the coding process, and the coordinate system of the position information to be the target of the decoding process are any one type.
- the switching process may be omitted, or the process may be expanded when there are three or more types of coordinate systems.
- the coordinate system related to the coding and decoding of the position information has been described as an example, when the coordinate system related to the coding and decoding of the attribute information corresponds to a plurality of coordinate systems, or the input point group and the output point group. If there is a possibility that the coordinate system will switch to another coordinate system, the processing may be switched using the same method. For example, the same syntax as in FIG. 54 may be included in attribute_parameter_set.
- the coordinate system related to the coding and decoding of the position information and the coordinate system related to the coding and decoding of the attribute information may be controlled to be the same.
- the three-dimensional data coding apparatus performs the processing shown in FIG. 60.
- the three-dimensional data coding device encodes a plurality of three-dimensional points in either a Cartesian coordinate system or a polar coordinate system.
- the three-dimensional data coding apparatus calculates a predicted value based on the position information of one or more candidate points among a plurality of coded three-dimensional points (S13021).
- the three-dimensional data coding apparatus calculates the first residual, which is the difference between the position information of one three-dimensional point to be encoded among the plurality of three-dimensional points and the predicted value (S13022).
- the three-dimensional data coding apparatus generates coded data by coding the first residual (S13023).
- the three-dimensional data coding apparatus generates a bit stream including the coded data and the first identification information indicating whether or not the coded data includes the first coded data calculated in the polar coordinate system (S13024). ..
- the three-dimensional data decoding apparatus uses the first identification information.
- the decryption process can be appropriately performed based on the above.
- the bitstream further contains a second identification information.
- the first identification information indicates that the coded data includes the first coded data calculated in a polar coordinate system.
- the second identification information indicates whether to output the position information of the polar coordinate system or the position information of the orthogonal coordinate system in the decoding.
- the bitstream does not include the second identification information.
- the second identification information indicates that the position information of the polar coordinate system is output in the decoding.
- the first residual is quantized and the quantized first residual is encoded.
- the position information of the polar coordinate system is generated by further converting the coordinate system of the position information of the Cartesian coordinate system of one three-dimensional point to be encoded, and the first residual.
- the three-dimensional data coding device reverse-converts the coordinate system of the position information of the polar coordinate system after conversion to obtain a Cartesian coordinate system. Generates the position information of.
- the three-dimensional data coding apparatus calculates a second residual which is a difference between the position information of the Cartesian coordinate system and the position information of the Cartesian coordinate system after the inverse transformation.
- the coded data is generated by encoding the first residual and the second residual.
- the first identification information indicates that the coded data includes the first coded data.
- the second identification information indicates that the position information of the Cartesian coordinate system is output in the decoding.
- the second identification information indicates whether or not the coded data of the second residual is included in the bit stream.
- the three-dimensional data encoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the three-dimensional data decoding device performs the process shown in FIG. 61.
- the three-dimensional data decoding device decodes a plurality of three-dimensional points in either a Cartesian coordinate system or a polar coordinate system.
- the three-dimensional data decoding device includes coded data in which the first residual is encoded and first identification information indicating whether or not the coded data includes the first coded data calculated in the polar coordinate system. Acquire a bit stream (S13031).
- the three-dimensional data decoding device calculates a predicted value based on the position information of one or more candidate points among the plurality of decoded three-dimensional points (S13032).
- the three-dimensional data decoding device calculates the first residual by decoding the encoded first residual (S13033).
- the three-dimensional data decoding device calculates the position information of one three-dimensional point to be decoded by adding the predicted value and the first residual.
- the coordinate system of the position information of one three-dimensional point to be decoded is the coordinate system depending on whether or not the first coded data indicated by the first identification information is included.
- the coordinate system of the position information of one three-dimensional point to be decoded is determined based on the first identification information indicating whether or not the coded data includes the first coded data calculated in the polar coordinate system. Therefore, the three-dimensional data decoding device can appropriately perform the decoding process based on the first identification information.
- the bitstream further includes a second identification information indicating whether to output the position information of the polar coordinate system or the position information of the orthogonal coordinate system in decoding.
- the first identification information indicates that the coded data includes the first coded data
- the position information of one three-dimensional point of interest is the position information of the polar coordinate system.
- the bitstream does not include the second identification information.
- the coded data is the data in which the first residual is quantized and encoded.
- the coordinate system of the position information of one three-dimensional point to be decoded is the polar coordinate system.
- the decoding target when the first identification information indicates that the coded data includes the first coded data and the second identification information indicates that the position information of the Cartesian coordinate system is output in the decoding, the decoding target.
- the coordinate system of the position information of the polar coordinate system obtained by adding the predicted value and the first residual is converted, and the Cartesian coordinates obtained by the conversion are converted.
- the position information of the system is calculated as the position information of one three-dimensional point to be decoded.
- the coded data when the first identification information indicates that the coded data includes the first coded data and the second identification information indicates that the position information of the Cartesian coordinate system is output in decoding, the coded data. Further includes a coded second residual.
- the three-dimensional data coding device calculates the second residual by decoding the encoded second residual. In the calculation of the position information of one three-dimensional point to be decoded, the position information of the Cartesian coordinate system obtained by transforming the coordinate system and the second residual are added and added to obtain the position. The information is calculated as the position information of one three-dimensional point to be decoded.
- the second identification information indicates whether or not the coded data of the second residual is included in the bit stream.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- (x, y, z) in the block indicates that processing using the Cartesian coordinate system is performed
- (r, q, f) in the block uses the polar coordinate system. Indicates that the processing that was performed is performed.
- the signal with (x, y, z) indicates that the signal uses the Cartesian coordinate system
- the signal with (r, q, f) indicates that the signal uses the polar coordinate system.
- Gps_alt_cordinates_flag is included in, for example, GPS (position information parameter set).
- GPS position information control information (parameter set) included in a bit stream, and is control information common to a plurality of frames, a plurality of point clouds, or a plurality of slices.
- the gps_alt_coordinates_flag is information indicating whether or not a coordinate system different from the orthogonal coordinates such as polar coordinates is used in the coding process or the decoding process of each point. That is, gps_alt_codeinates_flag indicates whether or not the position information coded data includes the first position information coded data calculated in the polar coordinate system.
- gps_alt_codeinates_flag 1 indicates that a polar coordinate system is used for coding or decoding of position information that refers to GPS.
- gps_alt_codeinates_flag 0 indicates that an orthogonal coordinate system is used in the coding process or the decoding process of the position information referring to the GPS.
- the position information coding unit includes a prediction unit 13601, a quantization unit 13602, and a coding unit 13603.
- the prediction unit 13601 calculates the predicted value of the input position information of the orthogonal coordinate system, and calculates the residual which is the difference between the position information and the predicted value.
- the predicted value and the residual calculated here are represented by a Cartesian coordinate system.
- the quantization unit 13602 quantizes the residuals of the Cartesian coordinate system.
- the coding unit 13603 generates a bitstream by coding the quantized residuals (eg, entropy coding or arithmetic coding). That is, in the position information coding unit shown in FIG. 62, all the processing is performed in the Cartesian coordinate system.
- Gps_coordinate_trans_enabled_flag is included in GPS, for example.
- the position information coding unit includes a conversion unit 13611, a prediction unit 13612, a coding unit 13613, a conversion unit 13614, a subtraction unit 13615, a quantization unit 13616, and a coding unit 13617. , With a coupling portion 13618.
- the conversion unit 13611 converts the input position information of the orthogonal coordinate system into the position information of the polar coordinate system.
- the prediction unit 13612 calculates the predicted value of the position information of the polar coordinate system, and calculates the residual 1 which is the difference between the position information and the predicted value.
- the predicted value and the residual 1 calculated here are represented by a polar coordinate system.
- the coding unit 13613 encodes the residual 1 (for example, entropy coding or arithmetic coding).
- the conversion unit 13614 restores the position information of the polar coordinate system by adding the predicted value to the residual 1, and converts the position information into the position information of the orthogonal coordinate system.
- the conversion unit 13614 may convert the position information of the polar coordinate system generated by the conversion unit 13611 into the position information of the orthogonal coordinate system.
- the subtraction unit 13615 calculates the residual 2 which is the difference between the input position information of the orthogonal coordinate system and the position information of the orthogonal coordinate system obtained by the conversion unit 13614. This residual 2 corresponds to a conversion error when the position information of the orthogonal coordinate system is converted into the position information of the polar coordinate system and the obtained position information of the polar coordinate system is returned to the position information of the orthogonal coordinate system.
- the quantization unit 13616 quantizes the residual 2 of the Cartesian coordinate system.
- the coding unit 13617 encodes the quantized residual 2 (for example, entropy coding or arithmetic coding).
- the coupling unit 13618 generates a bitstream containing the coded residual 1 and the coded residual 2.
- the position information of the orthogonal coordinate system is converted into the position information of the polar coordinate system, and the coding process (prediction, coding) is performed on the position information of the polar coordinate system. Will be.
- the position information coding unit includes a prediction unit 13621, a quantization unit 13622, and a coding unit 13623.
- the prediction unit 13621 calculates the predicted value of the input polar coordinate system position information, and calculates the residual which is the difference between the position information and the predicted value.
- the predicted value and the residual calculated here are expressed in a polar coordinate system.
- the quantization unit 13622 quantizes the residuals of the polar coordinate system.
- the coding unit 13623 generates a bitstream by coding the quantized residuals (eg, entropy coding or arithmetic coding). That is, in the position information coding unit shown in FIG. 64, all the processing is performed in the polar coordinate system.
- the configuration shown in FIG. 62 and the configuration shown in FIG. 64 are similar, the coordinate systems of the data handled in the prediction, quantization, and coding for calculating the residual are different.
- the data processing content may differ between the configuration shown in FIG. 62 and the configuration shown in FIG. 64.
- the three-dimensional data coding device may switch the function of the position information coding unit to any of FIGS. 62 to 64 by using gps_alt_codeinates_flag and gps_coordinate_trans_enabled_flag.
- the three-dimensional data coding device has three position information coding units shown in FIGS. 62 to 64, and the position information coding unit to be used may be switched.
- the three-dimensional data coding apparatus may switch the presence / absence and content of processing in units of processing blocks by using gps_alt_codeinates_flag and gps_coordinate_trans_enabled_flag.
- the common processing block among the processing blocks included in the three position information coding units shown in FIGS. 62 to 64 can be shared, so that the function of the configuration shown in FIGS. 62 to 64 can be realized with a small configuration. There is a possibility that a possible position information coding unit can be realized.
- the switching of the processes shown in FIGS. 62 to 64 is indicated by the combination of gps_alt_coordinates_flag and gps_coordinate_trans_enable_flag.
- these information may be shown in any form.
- the bit stream contains information indicating the coordinate system of the position information output (decoded) by the decoding device among the orthogonal coordinate system and the polar coordinate system.
- the bit stream contains information indicating a coordinate system used for encoding or decoding among the orthogonal coordinate system and the polar coordinate system.
- the bitstream also contains information indicating whether or not coordinate transformation is performed.
- the point cloud data acquired by a sensor such as LiDAR is data composed of, for example, an angle and distance information from the sensor and a reflectance, and includes position information in a polar coordinate system.
- the point cloud data is obtained in advance. It is necessary to convert the position information of. From the polar coordinate system to the Cartesian coordinate system. Since this conversion causes a conversion error in the position information, a part of the information is lost when the polar coordinate system is converted to the orthogonal coordinate system. Therefore, it is not possible to convert from a polar coordinate system to a Cartesian coordinate system and perform reversible and inverse conversion.
- (x, y, z) in the block indicates that processing using the Cartesian coordinate system is performed, and (r, q, f) in the block uses the polar coordinate system. Indicates that the processing that was performed is performed.
- the signal with (x, y, z) indicates that the signal uses the Cartesian coordinate system, and the signal with (r, q, f) indicates that the signal uses the polar coordinate system.
- the position information decoding unit includes a decoding unit 13631, an inverse quantization unit 13632, and a reconstruction unit 13633.
- the decoding unit 13631 generates a residual (residual after quantization) by decoding a bit stream (for example, entropy decoding or arithmetic decoding).
- the dequantization unit 13632 dequantizes the residual obtained by the decoding unit 13631.
- the reconstruction unit 13633 calculates the predicted value and adds the predicted value to the residual after dequantization to generate the position information of the Cartesian coordinate system.
- the predicted value and the residual calculated here are represented by a Cartesian coordinate system. As described above, in the position information decoding unit shown in FIG. 65, all the processing is performed in the Cartesian coordinate system.
- the position information decoding unit includes a separation unit 13641, a decoding unit 13642, a reconstruction unit 13643, a conversion unit 13644, a decoding unit 13645, an inverse quantization unit 13646, and an addition unit 13647. include.
- the separation unit 13641 acquires the coded data of the residual 1 and the coded data of the residual 2 from the bit stream.
- the decoding unit 13642 generates the residual 1 by decoding the coded data of the residual 1 (for example, entropy decoding or arithmetic decoding).
- the reconstruction unit 13643 calculates the predicted value and adds the predicted value to the residual 1 after the inverse quantization to generate the position information of the polar coordinate system.
- the predicted value and the residual 1 calculated here are represented by a polar coordinate system.
- the conversion unit 13644 converts the position information of the polar coordinate system into the position information of the orthogonal coordinate system.
- the decoding unit 13645 generates a residual 2 (residual 2 after quantization) by decoding the coded data of the residual 2 (for example, entropy decoding or arithmetic decoding).
- the dequantization unit 13646 dequantizes the residual 2 obtained by the decoding unit 13645.
- the predicted value and the residual 2 calculated here are represented by a Cartesian coordinate system.
- the addition unit 13647 generates the final position information of the orthogonal coordinate system by adding the residual 2 to the position information of the orthogonal coordinate system obtained by the conversion unit 13644.
- the position information decoding unit shown in FIG. 66 the position information of the polar coordinate system is decoded (predicted and decoded), and the obtained position information of the polar coordinate system is converted into the position information of the orthogonal coordinate system.
- the position information decoding unit includes a decoding unit 13651, an inverse quantization unit 13652, and a reconstruction unit 13653.
- the decoding unit 13651 generates a residual (residual after quantization) by decoding a bit stream (for example, entropy decoding or arithmetic decoding).
- the dequantization unit 13652 dequantizes the residual obtained by the decoding unit 13651.
- the reconstruction unit 13653 calculates the predicted value and adds the predicted value to the residual after dequantization to generate the position information of the polar coordinate system.
- the predicted value and the residual calculated here are expressed in a polar coordinate system. As described above, in the position information decoding unit shown in FIG. 67, all the processing is performed in the polar coordinate system.
- the configuration shown in FIG. 65 and the configuration shown in FIG. 67 are similar, the coordinate systems of the data handled in the prediction, dequantization, and decoding for calculating the residual are different.
- the data processing content may differ between the configuration shown in FIG. 65 and the configuration shown in FIG. 67.
- the three-dimensional data decoding device may switch the function of the position information decoding unit to any of FIGS. 65 to 67 by using gps_alt_coordinates_flag and gps_coordinate_trans_enabled_flag.
- the three-dimensional data coding apparatus has three position information decoding units shown in FIGS. 65 to 67, and the position information decoding unit to be used may be switched.
- the three-dimensional data decoding apparatus may switch the presence / absence and content of processing in units of processing blocks by using gps_alt_coordinates_flag and gps_coordinate_trans_enabled_flag.
- FIG. 68 is a block diagram showing a configuration of a three-dimensional data coding device that encodes position information and attribute information included in the point cloud data.
- the three-dimensional data coding apparatus shown in FIG. 68 includes an overlap point coupling unit 13661, a position information coding unit 13662, an attribute information conversion unit 13663, an attribute information coding unit 13664, and a coupling unit 13665.
- the overlap point coupling unit 13661 sets a plurality of points having the same position information into one point when a plurality of points have the same position information, that is, when there are overlap points. Merge.
- the case where the overlapping points exist is the case where the overlapping points originally exist in the input point cloud, or the case where the overlapping points are generated by the quantization process.
- the position information coding unit 13662 generates position information coding data by encoding the position information after merging.
- the position information coding unit 13662 includes at least one of the three position information coding units shown in FIGS. 62 to 64.
- the attribute information conversion unit 13663 When the overlapping points are merged, the attribute information conversion unit 13663 generates the attribute information for one point after the merge from the attribute information for the overlapping plurality of points.
- the attribute information conversion unit 13663 may generate the attribute information of one point after merging by using any one of the plurality of overlapping points, or may generate the attribute information of the plurality of overlapping points by a predetermined method. It may be converted into one point of attribute information.
- the attribute information conversion unit 13663 uses the position information (data A) before merging and the position information (data B) after merging, and weights addition based on the distance between the points after merging and the points before merging.
- the value of the attribute information may be determined by.
- the attribute information coding unit 13664 generates attribute information coding data by encoding the attribute information obtained by the attribute information conversion unit 13663 based on the position information (data C). Specifically, when the attribute information coding unit 13664 uses LoD (Level of Detail) to encode the attribute information, the attribute information coding unit 13664 generates a LoD hierarchy using the position information.
- LoD classifies each 3D point into a plurality of layers using the position information of the 3D point, generates a predicted value of the attribute information of the 3D point based on the set layer, and predicts the attribute information. It is a method of encoding the predicted residual with the value. That is, the position information is used, for example, to generate a predicted value of attribute information.
- the attribute information coding unit 13664 uses the position information when encoding the attribute information by using RAHT (Region Adaptive Hierarchical Transfer) or Haar conversion. In these methods, the attribute information coding unit 13664 generates high-frequency components and low-frequency components of each layer, and quantizes and entropy-codes those values. Further, the position information is used for setting two three-dimensional points used as a pair of operations in the lowest layer.
- RAHT Restion Adaptive Hierarchical Transfer
- the position information coding unit 13662 and the attribute information coding unit 13664 perform processing using the position information of the orthogonal coordinate system. That is, in this case, the data B and the data C are Cartesian coordinate systems. As described above, there is a possibility that the conversion of the attribute information and the coding efficiency of the attribute information can be improved by using the Cartesian coordinate system.
- the position information coding unit 13662 and the attribute information coding unit 13664 perform processing using the position information of the polar coordinate system. That is, the data B and the data C are polar coordinate systems. This may improve the coding efficiency. Further, since the coordinate conversion processing is not required, the processing amount and the processing delay can be reduced.
- the three-dimensional data coding device has both a configuration for performing processing corresponding to the Cartesian coordinate system and the polar coordinate system, and based on the input position information coordinate system, the processing of the Cartesian coordinate system and the polar coordinate system are provided. You may switch between the processing of.
- the three-dimensional data coding device may perform coding in a coordinate system that has a high possibility of improving the coding efficiency. That is, the three-dimensional data coding device may transform the coordinate system of the position information. For example, the three-dimensional data coding apparatus may perform coding using a polar coordinate system regardless of the input coordinate system when the order of the input data is arranged in the order of angles.
- the three-dimensional data coding apparatus includes a configuration for processing one of the orthogonal coordinate system and the polar coordinate system
- the coordinates of the configuration included in the input position information coordinate system are provided. If it is different from the system, the coordinate system of the position information may be converted into a coordinate system having a configuration.
- the three-dimensional data coding device when the position information coding unit 13662 and the attribute information coding unit 13664 correspond to a Cartesian coordinate system, and the coordinate system of the data A is a polar coordinate system, the data B and Data C is converted from a polar coordinate system to a Cartesian coordinate system.
- the three-dimensional data coding device can encode the data A of both coordinate systems when the configuration of one coordinate system is provided.
- the attribute information coding unit 13664 uses the attribute information of one three-dimensional point to be encoded in the first coordinate system, which is the coordinate system of the position information output in decoding, among the Cartesian coordinate system and the polar coordinate system. , Attribute information coding data is generated by encoding using the position information of one three-dimensional point to be encoded.
- the coupling unit 13665 generates a bit stream including position information coded data and attribute information coded data.
- FIG. 69 is a block diagram showing a configuration of a three-dimensional data decoding device that decodes position information and attribute information included in the point cloud data.
- the three-dimensional data decoding device shown in FIG. 69 includes a separation unit 13671, a position information decoding unit 13672, and an attribute information decoding unit 13673.
- the separation unit 13671 acquires the position information coded data and the attribute information coded data from the input bit stream.
- the position information decoding unit 13672 generates position information (data D) by decoding the position information coded data.
- the position information decoding unit 13672 includes at least one of the three position information decoding units shown in FIGS. 65 to 67.
- the attribute information decoding unit 13673 generates attribute information by decoding the attribute information coded data using the decoded position information (data D). Specifically, when the attribute information decoding unit 13673 decodes the attribute information using LoD, the attribute information decoding unit 13673 generates the LoD hierarchy using the position information. That is, the position information is used, for example, to generate a predicted value of attribute information. Alternatively, the attribute information decoding unit 13673 uses the position information when encoding the attribute information by using RAHT or Haar conversion.
- the coordinate system of the decoded position information is either an orthogonal coordinate system or a polar coordinate system.
- the data D is a Cartesian coordinate system
- the data D is a polar coordinate system.
- the attribute information decoding unit 13673 performs processing using the position information of the orthogonal coordinate system.
- the attribute information decoding unit 13673 may be able to improve the conversion of the attribute information and the coding efficiency of the attribute information by using the position information of the orthogonal coordinate system.
- the attribute information decoding unit 13673 performs processing using the position information of the polar coordinate system.
- the attribute information decoding unit 13673 may be able to improve the coding efficiency by using the position information of the polar coordinate system. Further, since the coordinate conversion processing is not required, the processing amount and the processing delay can be reduced.
- the three-dimensional data decoding device has both a configuration for performing processing corresponding to the Cartesian coordinate system and the polar coordinate system, and processes the Cartesian coordinate system based on the input coordinate system of the position information coded data. You may switch between processing in the polar coordinate system.
- the coordinate system of the position information (data D) from the position information decoding unit 13672 is provided.
- the coordinate system of the position information may be converted into the coordinate system of the provided configuration.
- the three-dimensional data decoding device obtains the data D from the polar coordinate system to Cartesian coordinates. Convert to a system.
- the three-dimensional data decoding device can decode the attribute information based on the data D of the polar coordinate system and the data D of the orthogonal coordinate system when the configuration of one of the coordinate systems is provided.
- the attribute information decoding unit 13673 is one of the decoding targets of the first coordinate system which is the coordinate system of the position information of the one three-dimensional point of the calculation target among the orthogonal coordinate system and the polar coordinate system.
- the data D input to the attribute information decoding unit 13673 may be normalized so that the value of the data falls within a certain range.
- the three-dimensional data decoding device has position information based on the coordinates (x, y, z) of the points constituting the point cloud or the information of the bounding box including the point cloud.
- the maximum value of the value of is derived, and the value of the position information of the data D may be normalized based on the derived maximum value.
- the three-dimensional data decoding device derives the maximum value of the value based on the distance r from the origin to the points constituting the point cloud, and the data is based on the derived maximum value.
- the value of the position information of D may be normalized.
- the three-dimensional data decoding device may divide the value of the position information of the data D by the derived maximum value.
- the position information decoding unit 13672 derives the above-mentioned maximum value or bounding box information and outputs it to the attribute information decoding unit 13673, and the attribute information decoding unit 13673 uses the maximum value or the bounding box information for data D. May be normalized. In this way, the attribute information decoding unit 13673 performs normalization based on the information output from the position information decoding unit 13672, thereby reducing the processing amount and processing delay of the processing for deriving the maximum value in the attribute information decoding unit 13673. It may be possible to reduce it.
- the position information coding unit 13662 derives the maximum value or the bounding box information as in the position information decoding unit 13672, outputs the information to the attribute information coding unit 13664, and outputs the maximum value in the attribute information coding unit 13664.
- the data C may be normalized using the information in the bounding box.
- the coordinate system whose position information is indicated by (x, y, z) has been described as an orthogonal coordinate system, but it may also be called a Cartesian coordinate system.
- the coordinate system in which the position information is indicated by (r, q, f) has been described as a polar coordinate system, it may also be called a spherical coordinate system.
- FIG. 70 is a flowchart of the three-dimensional data decoding process according to the present embodiment.
- the three-dimensional data decoding device decodes the position information from the bit stream (S13601).
- the three-dimensional data decoding device determines the coordinate system of the position information used for decoding the attribute information as the process 1 (S13602). Specifically, the three-dimensional data decoding device determines that when the position information is decoded in the polar coordinate system (Yes in S13611), the attribute information is decoded using the position information in the polar coordinate system (S13612).
- the three-dimensional data decoding device converts the attribute information into Cartesian coordinates when the position information is not decoded in the polar coordinate system (No in S13611), that is, when the position information is decoded in the Cartesian coordinate system. It is determined to decode using the position information of the system (S13613).
- the three-dimensional data decoding device normalizes the position information used for decoding the attribute information as the process 2 (S13603). Specifically, the three-dimensional data decoding device normalizes the position information of the polar coordinate system when it is determined that the position information of the polar coordinate system is used for decoding the attribute information (Yes in S13621). For example, as described above, the three-dimensional data decoding device performs normalization based on the distance r from the origin to the points constituting the point cloud. For example, the three-dimensional data decoding device divides the value of the position information of the data D by the maximum value of the distance r.
- the position information of the polar coordinate system is not used for decoding the attribute information (No in S13621), that is, the position information of the orthogonal coordinate system is used for decoding the attribute information.
- the position information of the Cartesian coordinate system is converted into the position information of the polar coordinate system (S13622), and the position information of the obtained polar coordinate system is normalized (S13623).
- the three-dimensional data decoding device encodes the attribute information using the normalized position information.
- the three-dimensional data decoding device decodes the attribute information using the position information of the Cartesian coordinate system
- the three-dimensional data decoding device converts the normalized position information into the Cartesian coordinate system and uses the obtained position information.
- the attribute information may be decrypted.
- the position information of the orthogonal coordinate system may be normalized without performing the coordinate conversion in step S13622.
- the three-dimensional data coding apparatus performs the processing shown in FIG. 71.
- the three-dimensional data coding device encodes a plurality of three-dimensional points.
- the three-dimensional data coding device calculates a predicted value based on the position information of one or more candidate points among a plurality of coded three-dimensional points (S13631), and encodes the plurality of three-dimensional points.
- the first residual which is the difference between the position information of one three-dimensional point of the target and the predicted value, is calculated (S13632), and the position information coding data is generated by encoding the first residual (S13333).
- the first identification information for example, gps_alt_coordinates_flag
- the three-dimensional data coding device inputs the attribute information of one three-dimensional point to be encoded by the code of the first coordinate system, which is the coordinate system of the position information output in decoding, among the Cartesian coordinate system and the polar coordinate system. Attribute information coding data is generated by encoding using the position information of one three-dimensional point to be converted (S13635). The three-dimensional data coding apparatus generates a bit stream including the position information coding data, the first identification information, and the attribute information coding data (S13636).
- the three-dimensional data coding device encodes the attribute information using the first coordinate which is the coordinate system of the position information output in the decoding.
- the coding efficiency can be improved.
- the amount of processing can be reduced because the coordinate conversion processing and the like are not required.
- the three-dimensional data coding device normalizes the position information of the polar coordinate system of one three-dimensional point to be encoded, and the three-dimensional data coding device normalizes the position information of one three-dimensional point to be encoded. Attribute information is encoded using the normalized polar coordinate system position information. According to this, the three-dimensional data coding apparatus can limit the range of the value of the position information used for decoding the attribute information, so that the processing amount can be reduced.
- a three-dimensional data encoding device generates and generates information indicating a maximum value of a plurality of three-dimensional coordinates or a bounding box including a plurality of three-dimensional points in the generation of position information coding data.
- the position information of the first coordinate system of one three-dimensional point to be encoded is normalized, and the attribute information of one three-dimensional point to be encoded is normalized to the first coordinate system. It is encoded using the position information of.
- the three-dimensional data coding apparatus can reduce the processing amount of the decoding process of the attribute information.
- the position information of one or more candidate points used for calculating the predicted value and the position information of one three-dimensional point to be encoded used for calculating the first residual are the position information of the polar coordinate system.
- the first identification information indicates that the position information coded data includes the first position information coded data, and the bit stream further outputs the position information of the polar coordinate system in decoding or the position of the Cartesian coordinate system.
- the second identification information (gps_coordinate_trans_enabled_flag) indicating whether to output the information is included.
- the bitstream does not include the second identification information.
- the second identification information indicates that the position information of the polar coordinate system is output in decoding.
- the three-dimensional data coding device further converts the position information of the polar coordinate system by converting the coordinate system of the position information of the Cartesian coordinate system of one three-dimensional point to be encoded.
- the three-dimensional data encoding device further obtains the coordinate system of the position information of the converted Cartesian coordinate system.
- the position information of the Cartesian coordinate system is generated by the inverse conversion of, the second residual, which is the difference between the position information of the Cartesian coordinate system and the position information of the Cartesian coordinate system after the inverse conversion, is calculated, and the position information code.
- the position information coded data is generated by encoding the first residual and the second residual, and as the first identification information, the position information coded data is the first position information coded data.
- the second identification information indicates that the position information of the Cartesian coordinate system is output in the decoding.
- the three-dimensional data encoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the three-dimensional data decoding device performs the process shown in FIG. 72.
- the three-dimensional data decoding device decodes a plurality of three-dimensional points.
- the three-dimensional data decoder indicates whether or not the position information coded data in which the first residual is encoded and the position information coded data include the first position information coded data calculated in the polar coordinate system. 1
- the three-dimensional data decoding device calculates a predicted value based on the position information of one or more candidate points among a plurality of decoded three-dimensional points (S13642), and decodes the encoded first residual.
- the first residual is calculated in (S13643), and the predicted value and the first residual are added to calculate the position information of one three-dimensional point to be decoded (S13644).
- the first coordinate system which is the coordinate system of the position information of one three-dimensional point to be decoded, include the first position information coding data indicated by the first identification information? It is a coordinate system depending on whether or not it is.
- the three-dimensional data decoding device generates attribute information of one three-dimensional point to be decoded by decoding the attribute information coded data using the position information of the first coordinate system of one three-dimensional point to be decoded. (S13645).
- the three-dimensional data decoding device decodes the attribute information using the position information of the first coordinate.
- the coding efficiency can be improved.
- the amount of processing can be reduced because the coordinate conversion processing and the like are not required.
- the three-dimensional data decoding device normalizes the position information of the polar coordinate system of one three-dimensional point to be decoded, and normalizes the attribute information coding data to the normalized polar coordinates. Decrypt using the position information of the system. According to this, the three-dimensional data decoding apparatus can limit the range of the value of the position information used for decoding the attribute information, so that the processing amount can be reduced.
- the three-dimensional data decoding device is information indicating the maximum value of a plurality of three-dimensional coordinates or a bounding box including a plurality of three-dimensional points in the calculation of the position information of one three-dimensional point to be decoded. Is generated, and the generated information is used to normalize the position information of the first coordinate system of one three-dimensional point to be decoded, and the attribute information coding data is the position information of the normalized first coordinate system. Decrypt using. According to this, the three-dimensional data decoding apparatus can reduce the processing amount of the attribute information decoding process.
- the bit stream further includes a second identification information (gps_coordinate_trans_enable_flag) indicating whether to output the position information of the polar coordinate system or the position information of the Cartesian coordinate system in decoding, and the first identification information is the position information.
- a second identification information gps_coordinate_trans_enable_flag
- the coded data includes the first position information coded data
- the position information of one three-dimensional point is the position information of the polar coordinate system.
- the bitstream does not include the second identification information.
- the coordinate system of the position information of one three-dimensional point to be decoded is the polar coordinate system.
- the first identification information indicates that the position information coding data includes the first position information coding data
- the second identification information is the position information of the Cartesian coordinate system in decoding.
- the coordinate system of the position information of the polar coordinate system obtained by adding the predicted value and the first residual is converted.
- the position information of the Cartesian coordinate system obtained by the conversion is calculated as the position information of one three-dimensional point to be decoded.
- the first identification information indicates that the position information coded data includes the first position information coded data
- the second identification information indicates that the position information of the Cartesian coordinate system is output in decoding.
- the position information coded data further includes a coded second residual
- the three-dimensional data decoder further calculates the second residual by decoding the encoded second residual.
- the position information of the Cartesian coordinate system obtained by transforming the coordinate system and the second residual are added and the position obtained by adding them.
- the information is calculated as the position information of one three-dimensional point to be decoded.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- FIG. 73 is a block diagram showing the configuration of the position information coding unit 13700 when the coordinate system of the position information of the input three-dimensional point cloud is an orthogonal coordinate system.
- the position information coding unit 13700 is included in the three-dimensional data coding device, and includes a shift unit 13701 and a coding unit 13702.
- the information with (x, y, z) indicates that the information is in the Cartesian coordinate system
- the information with (r, ⁇ , ⁇ ) is the information in which the polar coordinate system is used.
- r is the distance from the origin to the point forming the point group
- ⁇ is the horizontal angle with respect to the point forming the point group in the horizontal plane including the origin
- ⁇ is the elevation angle with respect to the point forming the point group from the origin.
- the shift unit 13701 generates post-shifted position information in the Cartesian coordinate system by shifting the position information in the Cartesian coordinate system.
- the coding unit 13702 generates a bit stream by coding the post-shift position information.
- FIG. 74 is a diagram showing an example of shift processing when the input position information is a Cartesian coordinate system and the position information of the Cartesian coordinate system is encoded.
- the shift unit 13701 shifts the coordinates (position information) of the point cloud before the position information is coded. ..
- the shift unit 13701 is a point so that the coordinates of the bounding box of the point cloud (for example, the coordinates of the lower left corner) become the origin when the coding is performed using the Cartesian coordinate system. Shift (subtract) the coordinates of the group.
- the shift unit 13701 may shift the coordinates of the point cloud so that the center of the coordinates of the bounding box of the point cloud is the origin.
- a shift is a movement of a position along at least one axis.
- FIG. 75 is a diagram showing an example of shift processing when the input position information is a Cartesian coordinate system and the position information of the polar coordinate system is encoded.
- the example shown in FIG. 75 is a case where the position information of the orthogonal coordinate system is converted into the position information of the polar coordinate system and the position information of the polar coordinate system is encoded.
- the shift unit 13701 shifts the coordinates of the orthogonal coordinate system of the point cloud so that the position of the sensor such as LiDAR that acquires the point cloud becomes the origin.
- the conversion unit (not shown in FIG. 73) converts the position information of the Cartesian coordinate system into the position information of the polar coordinate system.
- the conversion unit is arranged between the shift unit 13701 and the coding unit 13702.
- the coordinates after the shift are not limited to the above example, and may be set to coordinates that can improve the coding efficiency.
- the amount of coding can be reduced by reducing the value of the position information, that is, the absolute value by shifting the position information.
- by shifting the position information it is possible to obtain the position information having a value close to the already encoded position information, and the coding efficiency can be improved.
- the coding unit 13702 may include coordinate information regarding the shifted coordinates (for example, information indicating the origin before the shift or information indicating the shift amount) in the bitstream as metadata.
- the shift amount may be indicated by one value common to each component in the coordinate system, may be indicated by a value for each component, the value for each component may be the same, or each other. It may be different.
- the metadata may or may not be encoded.
- FIG. 76 is a block diagram showing the configuration of the position information coding unit 13710 when the coordinate system of the position information of the input three-dimensional point cloud is the polar coordinate system.
- the position information coding unit 13710 is included in the three-dimensional data coding device, and includes a coding unit 13711.
- FIG. 77 is a diagram showing an example of processing when the input position information is a polar coordinate system and the position information of the polar coordinate system is encoded.
- the position information coding unit 13710 is the coordinates of the position information. Do not shift.
- the position of a sensor such as LiDAR that acquires a point cloud does not have to be the origin. If the position of the sensor does not match the origin, the position information in the polar coordinate system may be shifted, for example, so that the position of the sensor coincides with the origin.
- the shift of the position information in the polar coordinate system is not limited to this example.
- the coding unit 13711 generates a bit stream by encoding the input position information of the polar coordinate system as it is.
- the coding unit 13711 may include the sensor position information indicating the coordinates of the sensor position in the bit stream as metadata.
- the three-dimensional data coding apparatus may include both the position information coding unit 13700 shown in FIG. 73 and the position information coding unit 13710 shown in FIG. 76, or may include one of them.
- FIG. 78 is a block diagram showing a configuration of a position information decoding unit 13720 that decodes a bit stream generated by encoding the position information of the Cartesian coordinate system.
- the position information decoding unit 13720 outputs the position information of the Cartesian coordinate system.
- the position information decoding unit 13720 is included in the three-dimensional data decoding device, and includes a decoding unit 13721 and a reverse shift unit 13722.
- the bit stream generated by encoding the shifted position information in the Cartesian coordinate system is decoded, and the obtained position information is subjected to reverse shift processing based on the coordinate information. Is the case where the position information of the Cartesian coordinate system is restored.
- the decoding unit 13721 acquires the post-shift position information of the Cartesian coordinate system by decoding the bit stream. Further, the decoding unit 13721 acquires coordinate information (for example, information indicating the origin before shift or information indicating the shift amount) which is metadata from the bit stream.
- coordinate information for example, information indicating the origin before shift or information indicating the shift amount
- the reverse shift unit 13722 reverse shifts (adds) the post-shift position information after decoding by the shift amount of the shift information shown in the coordinate information which is the metadata.
- the shift amount is a value obtained based on the difference between the origin coordinates before the shift and the origin coordinates after the shift. This makes it possible to restore the point cloud input to the three-dimensional data coding device in the three-dimensional data decoding device.
- FIG. 79 is a block diagram showing a configuration of a position information decoding unit 13730 that decodes a bit stream generated by encoding the position information of the polar coordinate system.
- the position information decoding unit 13730 outputs the position information of the polar coordinate system.
- the position information decoding unit 13730 is included in the three-dimensional data decoding device, and includes a decoding unit 13731.
- the decoding unit 13731 acquires the position information of the polar coordinate system by decoding the bit stream. Further, the decoding unit 13731 acquires sensor position information indicating the coordinates of the sensor position, which is metadata, from the bit stream. The position information decoding unit 13730 outputs the decoded position information of the polar coordinate system as it is without shifting.
- the polar coordinate system may be indicated by another parameter different from (r, ⁇ , ⁇ ).
- (r, ⁇ , ⁇ ) may be used.
- r is the radius when the point is projected onto the xy plane
- ⁇ is the index expressing the height or ⁇ .
- the three-dimensional data decoding device may include both the position information decoding unit 13720 shown in FIG. 78 and the position information decoding unit 13730 shown in FIG. 79, or may include one of them.
- the shift unit 13701 may be shared between the configuration shown in FIG. 73 and the configuration shown in FIG. 76.
- the three-dimensional data coding device sets the shift amount in the shift process of the shift unit 13701 to 0. This makes it possible to reduce the mounting cost.
- FIG. 80 is a block diagram showing the configuration of the position information coding unit 13740 in this case.
- the position information coding unit 13740 is included in the three-dimensional data coding device, and includes a switching unit 13741, a shift unit 13742, and a coding unit 13743.
- the switching unit 13741 When the input position information is the position information of the Cartesian coordinate system, the switching unit 13741 outputs the position information to the shift unit 13742. Further, when the input position information is the position information of the polar coordinate system, the switching unit 13741 outputs the position information to the coding unit 13743.
- the shift unit 13742 generates post-shifted position information in the Cartesian coordinate system by shifting the position information in the Cartesian coordinate system.
- the coding unit 13743 generates a bit stream by encoding the position information after the shift. Further, the coding unit 13743 generates a bit stream by encoding the position information of the polar coordinate system. Further, the coding unit 13743 stores the sensor position information in the bit stream. The coding unit 13743 may store the sensor position information in the bit stream only when the position information is represented by the polar coordinate system.
- the position information coding unit 13740 can reduce the processing amount by not performing the shift process when the position information is in the polar coordinate system.
- the configuration shown in FIG. 78 and the configuration shown in FIG. 79 may be provided, and the post-shift position information of the orthogonal coordinate system or the polar coordinate system may be output from each decoding unit to the reverse shift unit 13722.
- the reverse shift unit 13722 sets the shift amount to 0 regardless of the value of the sensor position information when the output position information is in the polar coordinate system. That is, the reverse shift portion 13722 does not shift.
- the three-dimensional data decoding device may determine that the bitstream is a stream that violates the standard when the sensor position information is not 0. This makes it possible to reduce the mounting cost.
- FIG. 81 is a block diagram showing the configuration of the position information decoding unit 13750 in this case.
- the position information decoding unit 13750 is included in the three-dimensional data decoding device, and includes a decoding unit 13751, a reverse shift unit 13752, and a switching unit 13753.
- the decoding unit 13751 generates the post-shift position information of the orthogonal coordinate system or the position information of the polar coordinate system by decoding the bit stream. Further, the decoding unit 13751 acquires the sensor position information from the bit stream when the position information of the polar coordinate system is decoded.
- the decoding unit 13751 may use gps_alt_coordinates_flag and gps_coordinate_trans_enable_flag shown in the sixth embodiment.
- decoding processing is performed in the decoding unit 13751, and the post-shift position information of the orthogonal coordinate system or the position information of the polar coordinate system is output.
- the reverse shift unit 13752 generates the position information of the Cartesian coordinate system by reversely shifting the position information after the shift of the Cartesian coordinate system.
- the switching unit 13753 outputs the position information when the decoded position information is the position information of the orthogonal coordinate system, and outputs the position information when the decoded position information is the position information of the polar coordinate system. Further, the switching unit 13753 may perform switching based on the information of gps_coordinate_trans_enabled_flag.
- the above-mentioned operation example of the decoding unit 13751 and the switching unit 13753 was based on gps_alt_coordinates_flag and gps_coordinate_trans_enabled_flag, but the decoding unit 13751 and the switching unit 13753 may operate based on other information.
- the decoding unit 13751 and the switching unit 13753 operate based on the information (for example, mode information) indicating the combination of the input coordinate system, the presence / absence of transformation of the coordinate system, and the output coordinate system included in the bitstream. May be good.
- the position information decoding unit 13750 can reduce the processing amount by not performing the reverse shift process when the position information is in the polar coordinate system.
- the coordinate system of the position information input to the three-dimensional data coding device and the coordinate system of the position information output from the three-dimensional data decoding device match.
- the coordinate system of the position information input to the three-dimensional data coding device for example, the position information shown in FIG. 80
- the coordinate system output from the three-dimensional data decoding device is also a Cartesian coordinate system.
- the coordinate system output from the three-dimensional data decoding device is also a polar coordinate system.
- FIG. 82 is a block diagram showing the configuration of the position information decoding unit 13760 in this case.
- the position information decoding unit 13760 is included in the three-dimensional data decoding device, and includes a decoding unit 13761, a coordinate conversion unit 13762, a shift unit 13763, and a switching unit 13764.
- the shift unit 13763 is not limited to the reverse shift according to the shift on the coding side, but performs an arbitrary shift.
- the coordinate system of the position information output from the switching unit 13764 is not limited to the one specified from the coding side, and is an arbitrary coordinate system. Any shift and any coordinate system can be determined, for example, by user instructions or settings.
- the decoding unit 13761 includes, for example, the position information decoding unit 13750 shown in FIG. 81.
- the decoding unit 13761 generates position information in a Cartesian coordinate system or position information in a polar coordinate system by decoding a bit stream. Further, the decoding unit 13761 acquires the sensor position information from the bit stream when the position information of the polar coordinate system is decoded.
- the coordinate conversion unit 13762 converts the position information of the polar coordinate system into the position information of the orthogonal coordinate system.
- the shift unit 13763 shifts the position information of the Cartesian coordinate system obtained by the coordinate conversion unit 13762 using the sensor position information. For example, the shift unit 13763 adds the sensor position (coordinates) indicated by the sensor position information to the position information of the point cloud.
- the switching unit 13764 When the decoded position information is the position information of the Cartesian coordinate system, the switching unit 13764 outputs the position information, and when the decoded position information is the position information of the polar coordinate system and no coordinate conversion is performed. Outputs the position information, and outputs the position information of the polar coordinate system after the shift obtained by the shift unit 13763 when the decoded position information is the position information of the polar coordinate system and the coordinate conversion is performed. ..
- the coordinate system of the position information of the point group input to the 3D data coding device is a Cartesian coordinate system or an polar coordinate system
- the 3D data decoding device It is possible to realize a three-dimensional data coding method and a three-dimensional data decoding method that can correspond to an arbitrary combination with the case where the coordinate system of the position information of the point group output from is an orthogonal coordinate system or an polar coordinate system.
- FIG. 83 is a flowchart of the three-dimensional data decoding process. For example, it is a flowchart of the three-dimensional data decoding process in the position information decoding unit 13750 shown in FIG. 81.
- the three-dimensional data decoding device decodes the position information from the bit stream (S13701).
- the three-dimensional data decoding device determines whether to decode the position information in the polar coordinate system or the orthogonal coordinate system (S13702). That is, the three-dimensional data decoder determines whether the bitstream is generated by encoding the position information in the polar coordinate system or by encoding the position information in the Cartesian coordinate system. ..
- the three-dimensional data decoding device makes these determinations based on the gps_alt_coordinates_flag contained in the bitstream.
- the three-dimensional data decoding device determines that the position information is decoded in the polar coordinate system (Yes in S13702).
- the three-dimensional data decoding device decodes the position information in the polar coordinate system (S13703).
- the three-dimensional data decoding device determines whether to output the position information of the polar coordinate system or the position information of the orthogonal coordinate system (S13705). For example, this determination may be made based on gps_coordinate_trans_enabled_flag input from the outside of the three-dimensional data decoding device, or may be made based on the information contained in the bitstream.
- the three-dimensional data decoding device When the three-dimensional data decoding device outputs the position information of the polar coordinate system (Yes in S13705), the three-dimensional data decoding device outputs the position information of the polar coordinate system obtained in step S13703 (S13708).
- the three-dimensional data decoding device when the three-dimensional data decoding device outputs the position information of the Cartesian coordinate system (No in S13705), the position information of the polar coordinate system obtained in step S13703 is converted into the position information of the Cartesian coordinate system (S13706). Next, the three-dimensional data decoding device reverse-shifts the position information of the converted orthogonal coordinate system using the shift amount (S13707), and outputs the position information of the shifted orthogonal coordinate system (S13708).
- step S13702 when the three-dimensional data decoding apparatus determines that the position information is decoded in the Cartesian coordinate system (No in S13702), the three-dimensional data decoding apparatus decodes the position information in the Cartesian coordinate system (S13704). Next, the three-dimensional data decoding device shifts the obtained position information of the orthogonal coordinate system using the coordinate information (S13707), and outputs the position information of the shifted orthogonal coordinate system (S13708).
- 84 and 85 are diagrams showing the syntax regarding the shift information (the above-mentioned sensor position coordinates or coordinate information (for example, information indicating the origin before the shift or information indicating the shift amount)).
- the bit stream is Includes shift information.
- the coordinate system of the point cloud input to the three-dimensional data coding device or the point cloud output from the three-dimensional data decoding device is a polar coordinate system
- the bit stream does not include shift information. As a result, the amount of information can be reduced, and the coding efficiency can be improved.
- FIG. 84 is a diagram showing an example of the syntax of GPS (geometry_parameter_set).
- the coded data of the position information of the point cloud is divided into a plurality of GDUs (geometry data unit) which are divided data units and stored in the bit stream.
- the divided data unit is, for example, a slice, a tile, or another subspace.
- GPS position information parameter set: geometry parameter set
- GPS includes gps_alt_coordinates_flag, gps_coordinate_trans_enabled_flag, and shift information (origin_x, origin_y, origin_z).
- the shift information is, for example, the sensor position coordinates or coordinate information (for example, information indicating the origin before the shift or information indicating the shift amount) described above, and is, for example, the origin when the position information is shifted in the three-dimensional data decoding device. Indicates the coordinates of the shift destination (that is, the shift amount). Note that FIG. 84 shows the shift amount in the Cartesian coordinate system, but the shift amount may be represented in the polar coordinate system.
- Gps_alt_cordinates_flag indicates whether the coded position information is a polar coordinate system or an orthogonal coordinate system. For example, if the coded position information is in a polar coordinate system, gps_alt_coordinates_flag is set to a value of 1, and if the coded position information is in a Cartesian coordinate system, gps_alt_coordinates_flag is set to a value of 0.
- the gps_coordinate_trans_enabled_flag is included in the GPS when the encoded position information is in a polar coordinate system, and is not included in the GPS when the encoded position information is in a Cartesian coordinate system.
- the coded position information is in the Cartesian coordinate system and the value of gps_alt_coordinates_flag is 0, it is estimated that gps_coordinate_trans_enable_flag is 0. That is, if gps_coordinate_trans_enabled_flag is not encoded, the value of gps_coordinate_trans_enabled_flag is estimated to be 0.
- gps_coordinate_trans_enabled_flag indicates whether or not to perform coordinate conversion for converting the position information of the polar coordinate system decoded by the three-dimensional data decoding device into the orthogonal coordinate system. For example, when coordinate transformation is performed, gps_coordinate_trans_enabled_flag is set to a value 1, and when coordinate transformation is not performed, gps_coordinate_trans_enable_flag is set to a value 0.
- the GPS shifts when the encoded position information is in the polar coordinate system and the coordinate conversion is not performed (that is, when the position information of the polar coordinate system is output in the three-dimensional data decoding device).
- Information (orign_x, coordinate_y, coordinate_z) is not included, and shift information is included in other cases. That is, the GPS includes shift information when the encoded position information is in a Cartesian coordinate system. Further, the GPS includes shift information when the encoded position information is in a polar coordinate system and coordinate conversion is performed. That is, the GPS includes shift information when the position information of the Cartesian coordinate system is output in the three-dimensional data decoding device.
- FIG. 85 is a diagram showing an example of the syntax of the GDU header (geometry_dataunit_set).
- the GDU header is a header (control information) for each GDU.
- the GDU header contains shift information (origin_x, origin_y, origin_z) and is encoded.
- the GDU header when the encoded position information is in the polar coordinate system and the coordinate conversion is not performed (that is, when the position information of the polar coordinate system is output in the three-dimensional data decoding device), the GDU header is displayed.
- the shift information (origin_x, coordinate_y, coordinate_z) is not included, and the shift information is included in other cases. That is, the GDU header contains shift information when the encoded position information is in a Cartesian coordinate system.
- the GDU header includes shift information when the encoded position information is in a polar coordinate system and coordinate conversion is performed. That is, the GDU header includes shift information when the position information of the Cartesian coordinate system is output in the three-dimensional data decoding device. As a result, the amount of information can be reduced, and the coding efficiency can be improved.
- the shift information may be included in one of the GPS and the GDU header, or may be included in both.
- the three-dimensional data decoding device may give priority to the shift information included in the GDU header. Further, when the bit stream does not include the shift information, the three-dimensional data decoding device may consider the values of the coordinates (x, y, z) indicated by the shift information to be 0 on all three axes.
- the coordinate system of the position information of the point group input to the three-dimensional data coding device or the position information of the point group decoded by the three-dimensional data decoding device is a polar coordinate system.
- the bit stream contains shift information, and the 3D data decoder converts the decoded position information of the polar coordinate system into the position information of the Cartesian coordinate system, and even if the position information of the Cartesian coordinate system is shifted using the shift information. good.
- the shift information may be stored in either the GPS or GDU header as described above, or stored in a parameter set (for example, SPS) for each sequence other than the GPS and GDU headers. May be done.
- the shift information is stored in the GDU header and may not be stored in the GPS.
- the shift information may be stored in both the GPS and GDU headers, or may be stored in at least one of the GPS and GDU headers and one or more parameter sets or headers other than the GPS and GDU headers.
- the bitstream always displays the shift information. It may be included.
- the three-dimensional data decoding apparatus performs the process shown in FIG. 86.
- the three-dimensional data decoding device acquires a bit stream including the coded position information in which the position information of the three-dimensional point is encoded (S13711), and generates the position information by decoding the coded position information (S13712). ..
- the three-dimensional data decoding device shifts the position information when the position information is represented in the Cartesian coordinate system (Yes in S13713), and when the position information is represented in the polar coordinate system (No in S13713), the position. Do not shift information.
- the three-dimensional data decoding device can switch whether or not to perform shift processing on the position information depending on whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. ..
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding device can appropriately decode a bit stream having improved coding efficiency by performing shift processing.
- the three-dimensional data decoding device can reduce the processing amount by not performing the shift processing.
- the error generated when converting the position information of the polar coordinates to the position information of the orthogonal coordinates can be eliminated by not performing the shift processing. As a result, it is possible to code three-dimensional points without error.
- the three-dimensional data decoding device derives the position information of the three-dimensional point from the bit stream, and when the position information is represented by Cartesian coordinates, shifts the first position indicated by the position information, and the shift is the position information. If is represented in a polar coordinate system, it does not have to be implemented.
- the three-dimensional data decoding device may further determine whether the position information is represented in the Cartesian coordinate system or the polar coordinate system based on the shift information included in the bitstream.
- the first flag information for example, gps_alt_tabledinates_flag
- the second flag information for example, gps_coordinate_trans_enabled_flag
- the shift may not be performed.
- not shifting the position information means that the position information is not substantially shifted, and may include, for example, performing a shift process in which the shift amount is zero.
- a three-dimensional data decoding device acquires shift information (for example, sensor position coordinates or coordinate information) indicating a shift amount from a bit stream, and the position information is represented by an orthogonal coordinate system or a polar coordinate system. Regardless of this, if the position information is shifted based on the shift amount indicated by the shift information and the position information is the position information represented by the polar coordinate system, the shift amount indicated by the shift information is set to zero. That is, the three-dimensional data decoder acquires shift information indicating the amount of shift from the bit stream, and when the position information is represented in the polar coordinate system, the quantity represented by the shift information is zero and is represented in the polar coordinate system. By shifting the position information based on the amount indicated by the shift information, the position information represented by the polar coordinate system is not shifted.
- shift information for example, sensor position coordinates or coordinate information
- the three-dimensional data decoding device can apply the shift processing to the position information regardless of whether the position information is in the Cartesian coordinate system or the polar coordinate system, and can control whether or not the shift processing is performed. Since it is unnecessary, the process can be simplified.
- a three-dimensional data decoder acquires shift information (for example, sensor position coordinates or coordinate information) indicating the amount of shift from a bit stream, and when the position information is represented by an orthogonal coordinate system, the quantity indicated by the shift information. If the position information is shifted based on, and the position information is represented in the polar coordinate system, the quantity is considered to be zero regardless of the quantity indicated by the shift information.
- shift information for example, sensor position coordinates or coordinate information
- the three-dimensional data decoding device when the position information is a polar coordinate system, the three-dimensional data decoding device considers that the amount of shift is zero regardless of the amount of shift indicated by the shift information. As a result, the processing amount of the three-dimensional data coding device that generates the bit stream can be reduced. Further, the three-dimensional data decoding device may be able to correctly decode the bitstream even if the bitstream contains an error.
- the three-dimensional data decoder determines that the position information is represented by the orthogonal coordinate system, and the position information is based on the shift amount indicated by the shift information. If the bit stream does not include the shift information, it is determined that the position information is represented by the polar coordinate system, and the position information is not shifted.
- the bitstream when the position information is in a polar coordinate system, the bitstream does not include the shift information. Therefore, the amount of bitstream data can be reduced.
- the coded position information includes a plurality of unit data (for example, GDU) in which the position information for each division unit obtained by dividing a plurality of three-dimensional points is encoded, and the shift information includes a plurality of unit data included in the bit stream. It is included in a parameter set common to unit data (eg GPS). That is, the bit stream contains coded information in which the position information of the plurality of three-dimensional points including the three-dimensional points is encoded, and the coded information is divided into a plurality of division units obtained by dividing the plurality of three-dimensional points.
- the shift information is included in a parameter set common to a plurality of division units.
- the coding information includes the coding position information.
- the coded position information includes a plurality of unit data (for example, GDU) in which the position information for each division unit obtained by dividing a plurality of three-dimensional points is encoded, and the shift information includes a plurality of unit data included in the bit stream. It is included in the header for each unit data (for example, GDU header). That is, the bit stream contains coded information in which the position information of the plurality of three-dimensional points including the three-dimensional points is encoded, and the coded information is divided into a plurality of division units obtained by dividing the plurality of three-dimensional points.
- the shift information is included in the header for each of a plurality of division units.
- the coding information includes the coding position information.
- the three-dimensional data decoding device converts the position information represented by the polar coordinate system into the converted position information represented by the orthogonal coordinate system, and shifts the converted position information. do.
- the three-dimensional data decoding device converts the position information of the polar coordinate system into the position information of the orthogonal coordinate system even when the encoded position information is the polar coordinate system, and the position information of the orthogonal coordinate system. Can be output.
- the three-dimensional data decoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the three-dimensional data coding apparatus performs the processing shown in FIG. 87.
- the three-dimensional data coding device generates coded position information by encoding the position information of the three-dimensional point (S13721), and the coded position information and the decoding position information decoded by the three-dimensional data decoding device are tertiary.
- a bit stream including shift information indicating whether or not the original data decoding device shifts (for example, sensor position coordinates, coordinate information, gps_alt_codeinites_flag, or gps_coordinate_trans_enabled_flag) is generated (S13722).
- the 3D data decoder Based on the shift information, the 3D data decoder shifts the decoding position information when the decoding position information is represented in the Cartesian coordinate system, and does not shift the decoding position information when the decoding position information is represented in the polar coordinate system. ..
- the three-dimensional data coding apparatus determines whether or not the position information is shifted according to whether the encoded position information is a Cartesian coordinate system or a polar coordinate system. It is possible to generate a bit stream that can be switched in the decoder.
- the coding efficiency can be improved by performing the shift processing in the three-dimensional data coding device and then performing the coding.
- the three-dimensional data decoding device can appropriately decode the bit stream with improved coding efficiency by performing the shift process. Further, the three-dimensional data decoding device can reduce the processing amount by not performing the shift processing when the position information is in the polar coordinate system.
- a three-dimensional data coding device generates coded position information by encoding the position information of a three-dimensional point, generates a bit stream including the coded position information, and the position information is represented by Cartesian coordinates. If so, the first position indicated by the position information is shifted, and the shift may not be performed if the position information is represented in a polar coordinate system.
- the bitstream may include shift information indicating whether the position information is represented in a Cartesian coordinate system or a polar coordinate system.
- the first flag information for example, gps_alt_tabledinates_flag
- the second flag information for example, gps_coordinate_trans_enabled_flag
- the shift may not be performed.
- the shift information indicates the amount of the shift at the time of shifting the decoding position information, and when the position information is expressed in a polar coordinate system, the amount indicated by the shift information is zero, and the three-dimensional data decoding device has a three-dimensional data decoding device.
- the position information represented by the polar coordinate system is not shifted.
- the shift process can be applied to the position information, and control of whether or not the shift process is performed is performed. Is not required, so that the processing in the three-dimensional data decoding device can be simplified.
- the shift information indicates the amount of shift when the decoded position information is shifted, and when the position information is represented in a polar coordinate system, the three-dimensional data coding device is used. Do not store shift information in the bitstream.
- the bitstream when the position information is in a polar coordinate system, the bitstream does not include the shift information. Therefore, the amount of bitstream data can be reduced.
- the coded position information includes a plurality of unit data (for example, GDU) in which the position information for each division unit obtained by dividing a plurality of three-dimensional points is encoded, and the shift information includes a plurality of unit data included in the bit stream. It is included in a parameter set common to unit data (eg GPS). That is, the bit stream contains coded information in which the position information of the plurality of three-dimensional points including the three-dimensional points is encoded, and the coded information is divided into a plurality of division units obtained by dividing the plurality of three-dimensional points.
- the shift information is included in a parameter set common to a plurality of division units.
- the coded position information includes a plurality of unit data (for example, GDU) in which the position information for each division unit obtained by dividing a plurality of three-dimensional points is encoded, and the shift information includes a plurality of unit data included in the bit stream. It is included in the header for each unit data (for example, GDU header). That is, the bit stream contains coded information in which the position information of the plurality of three-dimensional points including the three-dimensional points is encoded, and the coded information is divided into a plurality of division units obtained by dividing the plurality of three-dimensional points.
- the shift information is included in the header for each of a plurality of division units.
- the three-dimensional data encoding device includes a processor and a memory, and the processor uses the memory to perform the above processing.
- FIG. 88 is a block diagram showing a configuration example of the three-dimensional data creation device 810 according to the present embodiment.
- the three-dimensional data creation device 810 is mounted on a vehicle, for example.
- the three-dimensional data creation device 810 transmits and receives three-dimensional data to and from an external traffic monitoring cloud, a vehicle in front or a vehicle following, and creates and stores three-dimensional data.
- the three-dimensional data creation device 810 includes a data reception unit 811, a communication unit 812, a reception control unit 813, a format conversion unit 814, a plurality of sensors 815, a three-dimensional data creation unit 816, and a three-dimensional data synthesis unit. It includes an 817, a three-dimensional data storage unit 818, a communication unit 819, a transmission control unit 820, a format conversion unit 821, and a data transmission unit 822.
- the data receiving unit 811 receives the three-dimensional data 831 from the traffic monitoring cloud or the vehicle in front.
- the three-dimensional data 831 includes information such as a point cloud, a visible light image, depth information, sensor position information, or speed information, which includes a region that cannot be detected by the sensor 815 of the own vehicle.
- the communication unit 812 communicates with the traffic monitoring cloud or the vehicle in front, and transmits a data transmission request or the like to the traffic monitoring cloud or the vehicle in front.
- the reception control unit 813 exchanges information such as the corresponding format with the communication destination via the communication unit 812, and establishes communication with the communication destination.
- the format conversion unit 814 generates the three-dimensional data 832 by performing format conversion or the like on the three-dimensional data 831 received by the data receiving unit 811. Further, the format conversion unit 814 performs decompression or decoding processing when the three-dimensional data 831 is compressed or encoded.
- the plurality of sensors 815 are a group of sensors that acquire information outside the vehicle, such as a LiDAR, a visible light camera, or an infrared camera, and generate sensor information 833.
- the sensor information 833 is three-dimensional data such as a point cloud (point cloud data) when the sensor 815 is a laser sensor such as LiDAR.
- the number of sensors 815 does not have to be plural.
- the 3D data creation unit 816 generates 3D data 834 from the sensor information 833.
- the three-dimensional data 834 includes information such as point cloud, visible light image, depth information, sensor position information, speed information, and the like.
- the three-dimensional data synthesizing unit 817 synthesizes the three-dimensional data 834 created based on the sensor information 833 of the own vehicle with the three-dimensional data 832 created by the traffic monitoring cloud or the vehicle in front of the vehicle, thereby synthesizing the three-dimensional data 832 of the own vehicle.
- the three-dimensional data storage unit 818 stores the generated three-dimensional data 835 and the like.
- the communication unit 819 communicates with the traffic monitoring cloud or the following vehicle, and transmits a data transmission request or the like to the traffic monitoring cloud or the following vehicle.
- the transmission control unit 820 exchanges information such as compatible formats with the communication destination via the communication unit 819, and establishes communication with the communication destination. Further, the transmission control unit 820 is in the space of the three-dimensional data to be transmitted based on the three-dimensional data construction information of the three-dimensional data 832 generated by the three-dimensional data synthesis unit 817 and the data transmission request from the communication destination. Determine a transmission area.
- the transmission control unit 820 determines a transmission area including a space in front of the own vehicle that cannot be detected by the sensor of the following vehicle in response to a data transmission request from the traffic monitoring cloud or the following vehicle. Further, the transmission control unit 820 determines the transmission area by determining whether or not the space that can be transmitted or the transmitted space has been updated based on the three-dimensional data construction information. For example, the transmission control unit 820 determines an area designated by the data transmission request and in which the corresponding three-dimensional data 835 exists as the transmission area. Then, the transmission control unit 820 notifies the format conversion unit 821 of the format corresponding to the communication destination and the transmission area.
- the format conversion unit 821 converts the 3D data 836 in the transmission area out of the 3D data 835 stored in the 3D data storage unit 818 into a format supported by the receiving side to convert the 3D data 837. Generate.
- the format conversion unit 821 may reduce the amount of data by compressing or encoding the three-dimensional data 837.
- the data transmission unit 822 transmits the three-dimensional data 837 to the traffic monitoring cloud or the following vehicle.
- the three-dimensional data 837 includes information such as a point cloud in front of the own vehicle, visible light images, depth information, or sensor position information, including a region that becomes a blind spot of the following vehicle.
- the format conversion may not be performed.
- the three-dimensional data creation device 810 acquires the three-dimensional data 831 in the area that cannot be detected by the sensor 815 of the own vehicle from the outside, and the sensor information 833 detected by the three-dimensional data 831 and the sensor 815 of the own vehicle.
- the three-dimensional data 835 is generated by synthesizing the three-dimensional data 834 based on the above.
- the three-dimensional data creation device 810 can generate three-dimensional data in a range that cannot be detected by the sensor 815 of the own vehicle.
- the three-dimensional data creation device 810 obtains three-dimensional data including the space in front of the own vehicle, which cannot be detected by the sensor of the following vehicle, in the traffic monitoring cloud or the following in response to the data transmission request from the traffic monitoring cloud or the following vehicle. Can be sent to vehicles, etc.
- FIG. 89 is a flowchart showing an example of a procedure for transmitting three-dimensional data to a traffic monitoring cloud or a following vehicle by the three-dimensional data creation device 810.
- the three-dimensional data creation device 810 generates and updates three-dimensional data 835 of the space including the space on the road ahead of the own vehicle (S801). Specifically, the three-dimensional data creation device 810 synthesizes the three-dimensional data 834 created based on the sensor information 833 of the own vehicle with the three-dimensional data 831 created by the traffic monitoring cloud or the vehicle in front. Therefore, the three-dimensional data 835 including the space in front of the vehicle in front, which cannot be detected by the sensor 815 of the own vehicle, is constructed.
- the three-dimensional data creation device 810 determines whether the three-dimensional data 835 included in the transmitted space has changed (S802).
- the 3D data creation device 810 changes.
- the three-dimensional data including the three-dimensional data 835 of the generated space is transmitted to the traffic monitoring cloud or the following vehicle (S803).
- the three-dimensional data creation device 810 may transmit the three-dimensional data in the space where the change has occurred at the transmission timing of the three-dimensional data to be transmitted at predetermined intervals, but transmit immediately after detecting the change. You may. That is, the three-dimensional data creation device 810 may transmit the three-dimensional data in the space where the change has occurred with priority over the three-dimensional data transmitted at predetermined intervals.
- the three-dimensional data creation device 810 may transmit all the three-dimensional data of the changed space as the three-dimensional data of the changed space, or the difference (for example, appearance or disappearance) of the three-dimensional data. Only the information of the three-dimensional point, the displacement information of the three-dimensional point, etc.) may be transmitted.
- the three-dimensional data creation device 810 may transmit metadata related to the danger avoidance operation of the own vehicle such as a sudden braking warning to the following vehicle prior to the three-dimensional data of the space where the change has occurred.
- the following vehicle can recognize the sudden braking of the vehicle in front at an early stage, and can start the danger avoidance operation such as deceleration at an earlier stage.
- the three-dimensional data creation device 810 When the three-dimensional data 835 included in the transmitted space has not changed (No in S802), or after step S803, the three-dimensional data creation device 810 has a predetermined shape at a distance L in front of the own vehicle.
- the three-dimensional data contained in the space of is transmitted to the traffic monitoring cloud or the following vehicle (S804).
- steps S801 to S804 are repeatedly performed at predetermined time intervals.
- the three-dimensional data creation device 810 does not have to transmit the three-dimensional data 837 of the space if there is no difference between the three-dimensional data 835 of the space currently to be transmitted and the three-dimensional map.
- the client device transmits the sensor information obtained by the sensor to the server or another client device.
- FIG. 90 is a diagram showing a configuration of a three-dimensional map and a sensor information transmission / reception system according to the present embodiment.
- the system includes a server 901 and client devices 902A and 902B.
- client devices 902A and 902B are not particularly distinguished, they are also referred to as the client devices 902.
- the client device 902 is, for example, an in-vehicle device mounted on a moving body such as a vehicle.
- the server 901 is, for example, a traffic monitoring cloud or the like, and can communicate with a plurality of client devices 902.
- the server 901 transmits a three-dimensional map composed of a point cloud to the client device 902.
- the configuration of the three-dimensional map is not limited to the point cloud, and may represent other three-dimensional data such as a mesh structure.
- the client device 902 transmits the sensor information acquired by the client device 902 to the server 901.
- the sensor information includes, for example, at least one of LiDAR acquisition information, visible light image, infrared image, depth image, sensor position information, and velocity information.
- the data sent and received between the server 901 and the client device 902 may be compressed to reduce the data, or may remain uncompressed to maintain the accuracy of the data.
- a three-dimensional compression method based on an octa-tree structure can be used for the point cloud.
- a two-dimensional image compression method can be used for visible light images, infrared images, and depth images.
- the two-dimensional image compression method is, for example, MPEG-4 AVC or HEVC standardized by MPEG.
- the server 901 transmits the three-dimensional map managed by the server 901 to the client device 902 in response to the transmission request of the three-dimensional map from the client device 902.
- the server 901 may transmit the three-dimensional map without waiting for the transmission request of the three-dimensional map from the client device 902.
- the server 901 may broadcast a three-dimensional map to one or more client devices 902 in a predetermined space.
- the server 901 may transmit a three-dimensional map suitable for the position of the client device 902 to the client device 902 once receiving the transmission request at regular intervals.
- the server 901 may transmit the three-dimensional map to the client device 902 every time the three-dimensional map managed by the server 901 is updated.
- the client device 902 issues a three-dimensional map transmission request to the server 901. For example, when the client device 902 wants to perform self-position estimation during traveling, the client device 902 transmits a transmission request for a three-dimensional map to the server 901.
- the client device 902 may issue a three-dimensional map transmission request to the server 901.
- the client device 902 may issue a transmission request for the three-dimensional map to the server 901.
- the client device 902 may issue a three-dimensional map transmission request to the server 901.
- the client device 902 may issue a three-dimensional map transmission request to the server 901 before a certain time when the client device 902 goes out. For example, when the client device 902 exists within a predetermined distance from the boundary of the space indicated by the three-dimensional map held by the client device 902, the client device 902 issues a three-dimensional map transmission request to the server 901. You may. If the movement route and movement speed of the client device 902 are known, the time when the client device 902 goes out is predicted from the space shown by the three-dimensional map held by the client device 902. You may.
- the client device 902 may issue a three-dimensional map transmission request to the server 901.
- the client device 902 transmits the sensor information to the server 901 in response to the transmission request for the sensor information transmitted from the server 901.
- the client device 902 may send the sensor information to the server 901 without waiting for the sensor information transmission request from the server 901. For example, once the client device 902 receives the sensor information transmission request from the server 901, the client device 902 may periodically transmit the sensor information to the server 901 for a certain period of time. Further, when the error at the time of alignment between the three-dimensional data created by the client device 902 based on the sensor information and the three-dimensional map obtained from the server 901 is equal to or more than a certain value, the client device 902 is located around the client device 902. It may be determined that the three-dimensional map may have changed, and that fact and the sensor information may be transmitted to the server 901.
- the server 901 issues a sensor information transmission request to the client device 902.
- the server 901 receives the position information of the client device 902 such as GPS from the client device 902.
- the server 901 determines that the client device 902 is approaching a space with little information in the three-dimensional map managed by the server 901 based on the position information of the client device 902
- the server 901 determines that the client device 902 is approaching the space where the information is small.
- a request for transmission of sensor information is sent to the device 902.
- the server 901 issues a sensor information transmission request when it wants to update the three-dimensional map, when it wants to check the road condition such as when it snows or when there is a disaster, when it wants to check the traffic jam situation, or when it wants to check the incident accident situation. May be good.
- the client device 902 may set the data amount of the sensor information to be transmitted to the server 901 according to the communication state or the band at the time of receiving the transmission request of the sensor information received from the server 901. Setting the amount of sensor information to be transmitted to the server 901 means, for example, increasing or decreasing the data itself, or appropriately selecting a compression method.
- FIG. 91 is a block diagram showing a configuration example of the client device 902.
- the client device 902 receives a three-dimensional map composed of a point cloud or the like from the server 901, and estimates the self-position of the client device 902 from the three-dimensional data created based on the sensor information of the client device 902. Further, the client device 902 transmits the acquired sensor information to the server 901.
- the client device 902 includes a data reception unit 1011, a communication unit 1012, a reception control unit 1013, a format conversion unit 1014, a plurality of sensors 1015, a three-dimensional data creation unit 1016, and a three-dimensional image processing unit 1017. It includes a three-dimensional data storage unit 1018, a format conversion unit 1019, a communication unit 1020, a transmission control unit 1021, and a data transmission unit 1022.
- the data receiving unit 1011 receives the three-dimensional map 1031 from the server 901.
- the three-dimensional map 1031 is data including a point cloud such as WLD or SWLD.
- the three-dimensional map 1031 may include either compressed data or uncompressed data.
- the communication unit 1012 communicates with the server 901 and transmits a data transmission request (for example, a three-dimensional map transmission request) or the like to the server 901.
- a data transmission request for example, a three-dimensional map transmission request
- the reception control unit 1013 exchanges information such as the corresponding format with the communication destination via the communication unit 1012, and establishes communication with the communication destination.
- the format conversion unit 1014 generates the three-dimensional map 1032 by performing format conversion or the like on the three-dimensional map 1031 received by the data receiving unit 1011. Further, the format conversion unit 1014 performs decompression or decoding processing when the three-dimensional map 1031 is compressed or encoded. If the three-dimensional map 1031 is uncompressed data, the format conversion unit 1014 does not perform decompression or decoding processing.
- the plurality of sensors 1015 are a group of sensors that acquire information outside the vehicle on which the client device 902 is mounted, such as a LiDAR, a visible light camera, an infrared camera, or a depth sensor, and generate sensor information 1033.
- the sensor information 1033 is three-dimensional data such as a point cloud (point cloud data) when the sensor 1015 is a laser sensor such as LiDAR.
- the number of sensors 1015 does not have to be plural.
- the 3D data creation unit 1016 creates 3D data 1034 around the own vehicle based on the sensor information 1033.
- the three-dimensional data creation unit 1016 creates point cloud data with color information around the own vehicle using the information acquired by LiDAR and the visible light image obtained by the visible light camera.
- the three-dimensional image processing unit 1017 performs self-position estimation processing of the own vehicle using the received three-dimensional map 1032 such as a point cloud and the three-dimensional data 1034 around the own vehicle generated from the sensor information 1033. ..
- the three-dimensional image processing unit 1017 creates three-dimensional data 1035 around the own vehicle by synthesizing the three-dimensional map 1032 and the three-dimensional data 1034, and estimates the self-position using the created three-dimensional data 1035. Processing may be performed.
- the three-dimensional data storage unit 1018 stores the three-dimensional map 1032, the three-dimensional data 1034, the three-dimensional data 1035, and the like.
- the format conversion unit 1019 generates the sensor information 1037 by converting the sensor information 1033 into a format supported by the receiving side.
- the format conversion unit 1019 may reduce the amount of data by compressing or encoding the sensor information 1037. Further, the format conversion unit 1019 may omit the process when it is not necessary to perform the format conversion. Further, the format conversion unit 1019 may control the amount of data to be transmitted according to the designation of the transmission range.
- the communication unit 1020 communicates with the server 901 and receives a data transmission request (sensor information transmission request) or the like from the server 901.
- the transmission control unit 1021 exchanges information such as compatible formats with the communication destination via the communication unit 1020 to establish communication.
- the data transmission unit 1022 transmits the sensor information 1037 to the server 901.
- the sensor information 1037 includes a plurality of sensors such as information acquired by LiDAR, a brightness image acquired by a visible light camera, an infrared image acquired by an infrared camera, a depth image acquired by a depth sensor, sensor position information, and speed information. Contains information acquired by 1015.
- FIG. 92 is a block diagram showing a configuration example of the server 901.
- the server 901 receives the sensor information transmitted from the client device 902, and creates three-dimensional data based on the received sensor information.
- the server 901 updates the three-dimensional map managed by the server 901 by using the created three-dimensional data. Further, the server 901 transmits the updated three-dimensional map to the client device 902 in response to the transmission request of the three-dimensional map from the client device 902.
- the server 901 includes a data reception unit 1111, a communication unit 1112, a reception control unit 1113, a format conversion unit 1114, a three-dimensional data creation unit 1116, a three-dimensional data synthesis unit 1117, and a three-dimensional data storage unit 1118. , A format conversion unit 1119, a communication unit 1120, a transmission control unit 1121, and a data transmission unit 1122.
- the data receiving unit 1111 receives the sensor information 1037 from the client device 902.
- the sensor information 1037 includes, for example, information acquired by LiDAR, a brightness image acquired by a visible light camera, an infrared image acquired by an infrared camera, a depth image acquired by a depth sensor, sensor position information, speed information, and the like.
- the communication unit 1112 communicates with the client device 902 and transmits a data transmission request (for example, a sensor information transmission request) or the like to the client device 902.
- a data transmission request for example, a sensor information transmission request
- the reception control unit 1113 exchanges information such as the corresponding format with the communication destination via the communication unit 1112 to establish communication.
- the format conversion unit 1114 When the received sensor information 1037 is compressed or encoded, the format conversion unit 1114 generates sensor information 1132 by performing decompression or decoding processing. If the sensor information 1037 is uncompressed data, the format conversion unit 1114 does not perform decompression or decoding processing.
- the three-dimensional data creation unit 1116 creates three-dimensional data 1134 around the client device 902 based on the sensor information 1132. For example, the three-dimensional data creation unit 1116 creates point cloud data with color information around the client device 902 using the information acquired by LiDAR and the visible light image obtained by the visible light camera.
- the 3D data synthesis unit 1117 updates the 3D map 1135 by synthesizing the 3D data 1134 created based on the sensor information 1132 with the 3D map 1135 managed by the server 901.
- the 3D data storage unit 1118 stores the 3D map 1135 and the like.
- the format conversion unit 1119 generates the 3D map 1031 by converting the 3D map 1135 into a format supported by the receiving side.
- the format conversion unit 1119 may reduce the amount of data by compressing or encoding the three-dimensional map 1135. Further, the format conversion unit 1119 may omit the process when it is not necessary to perform the format conversion. Further, the format conversion unit 1119 may control the amount of data to be transmitted according to the designation of the transmission range.
- the communication unit 1120 communicates with the client device 902 and receives a data transmission request (three-dimensional map transmission request) or the like from the client device 902.
- the transmission control unit 1121 exchanges information such as the corresponding format with the communication destination via the communication unit 1120 to establish communication.
- the data transmission unit 1122 transmits the three-dimensional map 1031 to the client device 902.
- the three-dimensional map 1031 is data including a point cloud such as WLD or SWLD.
- the three-dimensional map 1031 may include either compressed data or uncompressed data.
- FIG. 93 is a flowchart showing an operation when the client device 902 acquires a three-dimensional map.
- the client device 902 requests the server 901 to transmit a three-dimensional map (point cloud, etc.) (S1001). At this time, the client device 902 may request the server 901 to transmit a three-dimensional map related to the position information by transmitting the position information of the client device 902 obtained by GPS or the like together.
- a three-dimensional map point cloud, etc.
- the client device 902 receives the three-dimensional map from the server 901 (S1002). If the received 3D map is compressed data, the client device 902 decodes the received 3D map to generate an uncompressed 3D map (S1003).
- the client device 902 creates three-dimensional data 1034 around the client device 902 from the sensor information 1033 obtained by the plurality of sensors 1015 (S1004).
- the client device 902 estimates the self-position of the client device 902 using the three-dimensional map 1032 received from the server 901 and the three-dimensional data 1034 created from the sensor information 1033 (S1005).
- FIG. 94 is a flowchart showing the operation when the sensor information is transmitted by the client device 902.
- the client device 902 receives the sensor information transmission request from the server 901 (S1011).
- the client device 902 transmits the sensor information 1037 to the server 901 (S1012).
- the sensor information 1033 includes a plurality of information obtained by the plurality of sensors 1015
- the client device 902 may generate the sensor information 1037 by compressing each information by a compression method suitable for each information. good.
- FIG. 95 is a flowchart showing an operation when the server 901 acquires sensor information.
- the server 901 requests the client device 902 to transmit the sensor information (S1021).
- the server 901 receives the sensor information 1037 transmitted from the client device 902 in response to the request (S1022).
- the server 901 creates three-dimensional data 1134 using the received sensor information 1037 (S1023).
- the server 901 reflects the created three-dimensional data 1134 in the three-dimensional map 1135 (S1024).
- FIG. 96 is a flowchart showing the operation at the time of transmission of the three-dimensional map by the server 901.
- the server 901 receives the transmission request of the three-dimensional map from the client device 902 (S1031).
- the server 901 that has received the three-dimensional map transmission request transmits the three-dimensional map 1031 to the client device 902 (S1032).
- the server 901 may extract a three-dimensional map in the vicinity thereof according to the position information of the client device 902 and transmit the extracted three-dimensional map.
- the server 901 may compress the three-dimensional map configured by the point cloud by using, for example, a compression method based on an ocree structure, and transmit the compressed three-dimensional map.
- the server 901 creates three-dimensional data 1134 near the position of the client device 902 using the sensor information 1037 received from the client device 902. Next, the server 901 calculates the difference between the three-dimensional data 1134 and the three-dimensional map 1135 by matching the created three-dimensional data 1134 with the three-dimensional map 1135 in the same area managed by the server 901. .. When the difference is equal to or greater than a predetermined threshold value, the server 901 determines that some abnormality has occurred in the vicinity of the client device 902. For example, when land subsidence occurs due to a natural disaster such as an earthquake, a large difference occurs between the 3D map 1135 managed by the server 901 and the 3D data 1134 created based on the sensor information 1037. Is possible.
- the sensor information 1037 may include information indicating at least one of the sensor type, the sensor performance, and the sensor model number. Further, a class ID or the like corresponding to the performance of the sensor may be added to the sensor information 1037. For example, when the sensor information 1037 is the information acquired by LiDAR, the sensor capable of acquiring information with an accuracy of several mm is class 1, the sensor capable of acquiring information with an accuracy of several cm is class 2, and the sensor is united with several m. As in class 3, it is conceivable to assign an identifier to the performance of a sensor that can acquire information with accuracy. Further, the server 901 may estimate the performance information of the sensor and the like from the model number of the client device 902.
- the server 901 may determine the sensor spec information from the vehicle model of the vehicle. In this case, the server 901 may acquire information on the vehicle type of the vehicle in advance, or the sensor information may include the information. Further, the server 901 may switch the degree of correction for the three-dimensional data 1134 created by using the sensor information 1037 by using the acquired sensor information 1037. For example, if the sensor performance is high accuracy (class 1), the server 901 does not make corrections to the 3D data 1134. When the sensor performance is low accuracy (class 3), the server 901 applies a correction to the three-dimensional data 1134 according to the accuracy of the sensor. For example, in the server 901, the lower the accuracy of the sensor, the stronger the degree (strength) of the correction.
- the server 901 may issue a sensor information transmission request to a plurality of client devices 902 in a certain space at the same time.
- the server 901 receives a plurality of sensor information from the plurality of client devices 902, it is not necessary to use all the sensor information for creating the three-dimensional data 1134.
- the sensor to be used depends on the performance of the sensor. You may select the information.
- the server 901 selects highly accurate sensor information (class 1) from a plurality of received sensor information, and creates 3D data 1134 using the selected sensor information. You may.
- the server 901 is not limited to a server such as a traffic monitoring cloud, and may be another client device (vehicle-mounted).
- FIG. 97 is a diagram showing a system configuration in this case.
- the client device 902C issues a sensor information transmission request to the nearby client device 902A, and acquires the sensor information from the client device 902A. Then, the client device 902C creates three-dimensional data using the acquired sensor information of the client device 902A, and updates the three-dimensional map of the client device 902C. As a result, the client device 902C can generate a three-dimensional map of the space that can be acquired from the client device 902A by taking advantage of the performance of the client device 902C. For example, it is considered that such a case occurs when the performance of the client device 902C is high.
- the client device 902A that provided the sensor information is given the right to acquire the highly accurate three-dimensional map generated by the client device 902C.
- the client device 902A receives a highly accurate 3D map from the client device 902C in accordance with its rights.
- the client device 902C may issue a request for transmission of sensor information to a plurality of nearby client devices 902 (client device 902A and client device 902B).
- client device 902A and client device 902B client devices 902
- the client device 902C can create three-dimensional data using the sensor information obtained by this high-performance sensor.
- FIG. 98 is a block diagram showing a functional configuration of the server 901 and the client device 902.
- the server 901 includes, for example, a three-dimensional map compression / decoding processing unit 1201 that compresses and decodes a three-dimensional map, and a sensor information compression / decoding processing unit 1202 that compresses and decodes sensor information.
- the client device 902 includes a three-dimensional map decoding processing unit 1211 and a sensor information compression processing unit 1212.
- the three-dimensional map decoding processing unit 1211 receives the encoded data of the compressed three-dimensional map, decodes the encoded data, and acquires the three-dimensional map.
- the sensor information compression processing unit 1212 compresses the sensor information itself instead of the three-dimensional data created from the acquired sensor information, and transmits the compressed sensor information encoded data to the server 901.
- the client device 902 may internally hold a processing unit (device or LSI) that performs a process of decoding a three-dimensional map (point cloud, etc.), and the three-dimensional data of the three-dimensional map (point cloud, etc.). It is not necessary to hold a processing unit that performs processing for compressing. As a result, the cost and power consumption of the client device 902 can be suppressed.
- the client device 902 is mounted on the moving body, and is obtained from the sensor information 1033 indicating the surrounding condition of the moving body obtained by the sensor 1015 mounted on the moving body. Create peripheral three-dimensional data 1034.
- the client device 902 estimates the self-position of the moving body using the created three-dimensional data 1034.
- the client device 902 transmits the acquired sensor information 1033 to the server 901 or another client device 902.
- the client device 902 transmits the sensor information 1033 to the server 901 and the like.
- the amount of transmitted data can be reduced as compared with the case of transmitting three-dimensional data.
- the processing amount of the client device 902 can be reduced. Therefore, the client device 902 can reduce the amount of data to be transmitted or simplify the configuration of the device.
- the client device 902 further transmits a transmission request for the three-dimensional map to the server 901, and receives the three-dimensional map 1031 from the server 901.
- the client device 902 estimates the self-position using the three-dimensional data 1034 and the three-dimensional map 1032 in the estimation of the self-position.
- the sensor information 1033 includes at least one of the information obtained by the laser sensor, the brightness image, the infrared image, the depth image, the position information of the sensor, and the speed information of the sensor.
- the sensor information 1033 includes information indicating the performance of the sensor.
- the client device 902 encodes or compresses the sensor information 1033, and in transmitting the sensor information, the encoded or compressed sensor information 1037 is transmitted to the server 901 or another client device 902. According to this, the client device 902 can reduce the amount of data to be transmitted.
- the client device 902 includes a processor and a memory, and the processor uses the memory to perform the above processing.
- the server 901 can communicate with the client device 902 mounted on the moving body, and the sensor information 1037 indicating the peripheral situation of the moving body obtained by the sensor 1015 mounted on the moving body is obtained. Is received from the client device 902. The server 901 creates three-dimensional data 1134 around the moving body from the received sensor information 1037.
- the server 901 creates the three-dimensional data 1134 using the sensor information 1037 transmitted from the client device 902. As a result, there is a possibility that the amount of data to be transmitted can be reduced as compared with the case where the client device 902 transmits three-dimensional data. Further, since it is not necessary to perform processing such as compression or coding of three-dimensional data on the client device 902, the processing amount of the client device 902 can be reduced. Therefore, the server 901 can reduce the amount of data to be transmitted or simplify the configuration of the device.
- the server 901 further transmits a transmission request for sensor information to the client device 902.
- the server 901 updates the 3D map 1135 using the created 3D data 1134, and sends the 3D map 1135 to the client device 902 in response to the transmission request of the 3D map 1135 from the client device 902. Send.
- the sensor information 1037 includes at least one of information obtained by the laser sensor, a brightness image, an infrared image, a depth image, a sensor position information, and a sensor speed information.
- the sensor information 1037 includes information indicating the performance of the sensor.
- the server 901 further corrects the three-dimensional data according to the performance of the sensor. According to this, the three-dimensional data creation method can improve the quality of the three-dimensional data.
- the server 901 when receiving sensor information, receives a plurality of sensor information 1037 from a plurality of client devices 902, and based on a plurality of information indicating the performance of the sensor included in the plurality of sensor information 1037, the server 901 receives three-dimensional data 1134. Select the sensor information 1037 used to create. According to this, the server 901 can improve the quality of the three-dimensional data 1134.
- the server 901 decodes or decompresses the received sensor information 1037, and creates three-dimensional data 1134 from the decoded or decompressed sensor information 1132. According to this, the server 901 can reduce the amount of data to be transmitted.
- the server 901 includes a processor and a memory, and the processor uses the memory to perform the above processing.
- FIG. 99 is a diagram showing a configuration of a system according to the present embodiment.
- the system shown in FIG. 99 includes a server 2001, a client device 2002A, and a client device 2002B.
- the client device 2002A and the client device 2002B are mounted on a moving body such as a vehicle, and transmit sensor information to the server 2001.
- the server 2001 transmits a three-dimensional map (point cloud) to the client device 2002A and the client device 2002B.
- the client device 2002A includes a sensor information acquisition unit 2011, a storage unit 2012, and a data transmission availability determination unit 2013.
- the configuration of the client device 2002B is also the same. Further, in the following, when the client device 2002A and the client device 2002B are not particularly distinguished, they are also described as the client device 2002.
- FIG. 100 is a flowchart showing the operation of the client device 2002 according to the present embodiment.
- the sensor information acquisition unit 2011 acquires various sensor information using a sensor (sensor group) mounted on the moving body. That is, the sensor information acquisition unit 2011 acquires sensor information indicating the surrounding condition of the moving body, which is obtained by the sensor (sensor group) mounted on the moving body. Further, the sensor information acquisition unit 2011 stores the acquired sensor information in the storage unit 2012.
- This sensor information includes at least one of LiDAR acquisition information, visible light image, infrared image and depth image. Further, the sensor information may include at least one of sensor position information, speed information, acquisition time information, and acquisition location information.
- the sensor position information indicates the position of the sensor from which the sensor information has been acquired.
- the velocity information indicates the velocity of the moving body when the sensor acquires the sensor information.
- the acquisition time information indicates the time when the sensor information is acquired by the sensor.
- the acquisition location information indicates the position of the moving object or the sensor when the sensor information is acquired by the sensor.
- the data transmission availability determination unit 2013 determines whether the mobile body (client device 2002) exists in an environment in which the sensor information can be transmitted to the server 2001 (S2002). For example, the data transmission availability determination unit 2013 may specify the location and time of the client device 2002 using information such as GPS, and determine whether or not the data can be transmitted. Further, the data transmission availability determination unit 2013 may determine whether or not data can be transmitted depending on whether or not it can be connected to a specific access point.
- the client device 2002 determines that the mobile body exists in an environment where the sensor information can be transmitted to the server 2001 (Yes in S2002), the client device 2002 transmits the sensor information to the server 2001 (S2003). That is, when the client device 2002 is in a situation where the sensor information can be transmitted to the server 2001, the client device 2002 transmits the held sensor information to the server 2001.
- a millimeter-wave access point capable of high-speed communication is installed at an intersection or the like.
- the sensor information held by the client device 2002 is transmitted to the server 2001 at high speed by using millimeter wave communication.
- the client device 2002 deletes the sensor information transmitted to the server 2001 from the storage unit 2012 (S2004).
- the client device 2002 may delete the sensor information when the sensor information not transmitted to the server 2001 satisfies a predetermined condition.
- the client device 2002 may delete the sensor information from the storage unit 2012 when the acquisition time of the sensor information to be held is older than a certain time before the current time. That is, the client device 2002 may delete the sensor information from the storage unit 2012 when the difference between the time when the sensor information is acquired by the sensor and the current time exceeds a predetermined time. Further, the client device 2002 may delete the sensor information from the storage unit 2012 when the acquisition location of the sensor information to be held is more than a certain distance from the current position.
- the sensor information is obtained when the difference between the position of the moving body or the sensor when the sensor information is acquired by the sensor and the position of the current moving body or the sensor exceeds a predetermined distance. May be deleted from the storage unit 2012. As a result, the capacity of the storage unit 2012 of the client device 2002 can be suppressed.
- the client device 2002 performs the processing after step S2001 again. Further, when the acquisition of the sensor information by the client device 2002 is completed (Yes in S2005), the client device 2002 ends the process.
- the client device 2002 may select the sensor information to be transmitted to the server 2001 according to the communication status. For example, when high-speed communication is possible, the client device 2002 preferentially transmits sensor information (for example, LiDAR acquisition information) having a large size held in the storage unit 2012. Further, when high-speed communication is difficult, the client device 2002 transmits sensor information (for example, a visible light image) having a small size and a high priority held in the storage unit 2012. As a result, the client device 2002 can efficiently transmit the sensor information held in the storage unit 2012 to the server 2001 according to the network conditions.
- sensor information for example, LiDAR acquisition information
- sensor information for example, a visible light image
- the client device 2002 may acquire the time information indicating the current time and the location information indicating the current location from the server 2001. Further, the client device 2002 may determine the acquisition time and acquisition location of the sensor information based on the acquired time information and location information. That is, the client device 2002 may acquire the time information from the server 2001 and generate the acquisition time information using the acquired time information. Further, the client device 2002 may acquire the location information from the server 2001 and generate the acquisition location information using the acquired location information.
- the server 2001 and the client device 2002 synchronize the time using a mechanism such as NTP (Network Time Protocol) or PTP (Precision Time Protocol).
- NTP Network Time Protocol
- PTP Precision Time Protocol
- the client device 2002 can acquire accurate time information.
- the server 2001 can handle the sensor information indicating the synchronized time.
- the time synchronization mechanism may be any method other than NTP or PTP.
- GPS information may be used as the time information and location information.
- the server 2001 may acquire sensor information from a plurality of client devices 2002 by designating a time or place. For example, in the event of an accident, the server 2001 broadcasts a sensor information transmission request to a plurality of client devices 2002 by designating the time and place of the accident in order to search for a client in the vicinity thereof. Then, the client device 2002 having the sensor information of the corresponding time and place transmits the sensor information to the server 2001. That is, the client device 2002 receives the sensor information transmission request including the designated information for designating the place and time from the server 2001. The client device 2002 determines that the storage unit 2012 stores the sensor information obtained at the place and time indicated by the designated information, and that the moving body exists in an environment in which the sensor information can be transmitted to the server 2001.
- the sensor information obtained at the place and time indicated by the designated information is transmitted to the server 2001.
- the server 2001 can acquire sensor information related to the occurrence of an accident from a plurality of client devices 2002 and use it for accident analysis and the like.
- the client device 2002 may refuse to transmit the sensor information when it receives the sensor information transmission request from the server 2001. Further, the client device 2002 may set in advance which sensor information among the plurality of sensor information can be transmitted. Alternatively, the server 2001 may inquire of the client device 2002 whether or not the sensor information can be transmitted each time.
- points may be given to the client device 2002 that has transmitted the sensor information to the server 2001.
- This point can be used, for example, to pay for gasoline purchase costs, EV (Electric Vehicle) charging costs, highway tolls, car rental costs, and the like.
- the server 2001 may delete the information for identifying the client device 2002 from which the sensor information is transmitted after the sensor information is acquired.
- this information is information such as the network address of the client device 2002.
- the sensor information can be anonymized, so that the user of the client device 2002 can transmit the sensor information from the client device 2002 to the server 2001 with peace of mind.
- the server 2001 may be composed of a plurality of servers. For example, by sharing sensor information among a plurality of servers, even if one server fails, another server can communicate with the client device 2002. This makes it possible to avoid stopping the service due to a server failure.
- the designated place specified by the sensor information transmission request indicates the position where the accident occurred, and may be different from the position of the client device 2002 at the designated time specified by the sensor information transmission request. Therefore, the server 2001 can request the client device 2002 existing in the range to acquire information by designating a range such as within XXm in the vicinity as the designated place. Similarly, for the designated time, the server 2001 may specify a range such as within N seconds before and after a certain time. As a result, the server 2001 can acquire the sensor information from the client device 2002 that existed at "time: t-N to t + N, location: within XXm from the absolute position S". When transmitting three-dimensional data such as LiDAR, the client device 2002 may transmit the data generated immediately after the time t.
- the server 2001 may separately specify, as the designated location, the information indicating the location of the client device 2002 for which the sensor information is to be acquired and the location where the sensor information is desired. For example, the server 2001 specifies that the sensor information including at least the range from the absolute position S to YYm is acquired from the client device 2002 existing within XXm from the absolute position S.
- the client device 2002 selects the 3D data in one or more randomly accessible units so as to include at least the sensor information in the specified range.
- the client device 2002 may transmit a plurality of temporally continuous image data including at least a frame immediately before or after time t.
- the client device 2002 uses the network according to the priority notified from the server 2001. You may choose. Alternatively, the client device 2002 itself may select a network that can secure an appropriate bandwidth based on the size of the transmitted data. Alternatively, the client device 2002 may select a network to be used based on the cost for data transmission and the like. Further, the transmission request from the server 2001 may include information indicating a transmission deadline, such as transmission when the client device 2002 can start transmission by time T. The server 2001 may issue a transmission request again if sufficient sensor information cannot be acquired within the deadline.
- a transmission deadline such as transmission when the client device 2002 can start transmission by time T.
- the sensor information may include header information indicating the characteristics of the sensor data together with the compressed or uncompressed sensor data.
- the client device 2002 may transmit the header information to the server 2001 via a physical network or communication protocol different from the sensor data. For example, the client device 2002 transmits the header information to the server 2001 prior to the transmission of the sensor data.
- the server 2001 determines whether or not to acquire the sensor data of the client device 2002 based on the analysis result of the header information.
- the header information may include information indicating the point cloud acquisition density, elevation angle, or frame rate of LiDAR, or the resolution, signal-to-noise ratio, or frame rate of the visible light image. As a result, the server 2001 can acquire the sensor information from the client device 2002 having the sensor data of the determined quality.
- the client device 2002 acquires the sensor information indicating the peripheral condition of the moving body, which is mounted on the moving body and obtained by the sensor mounted on the moving body, and stores the sensor information in the storage unit 2012. ..
- the client device 2002 determines whether the mobile body exists in an environment capable of transmitting sensor information to the server 2001, and if it determines that the mobile body exists in an environment capable of transmitting sensor information to the server, the client device 2002 transmits the sensor information to the server 2001. Send to.
- the client device 2002 further creates three-dimensional data around the moving body from the sensor information, and estimates the self-position of the moving body using the created three-dimensional data.
- the client device 2002 further transmits a transmission request for the three-dimensional map to the server 2001, and receives the three-dimensional map from the server 2001.
- the client device 2002 estimates the self-position using the three-dimensional data and the three-dimensional map.
- processing by the client device 2002 may be realized as an information transmission method in the client device 2002.
- the client device 2002 includes a processor and a memory, and the processor may perform the above processing using the memory.
- FIG. 101 is a diagram showing a configuration of a sensor information collection system according to the present embodiment.
- the sensor information collection system according to the present embodiment includes a terminal 2021A, a terminal 2021B, a communication device 2022A, a communication device 2022B, a network 2023, a data collection server 2024, and a map server 2025.
- the client device 2026 and the like.
- the terminal 2021A and the terminal 2021B are not particularly distinguished, they are also described as the terminal 2021.
- the communication device 2022A and the communication device 2022B are not particularly distinguished, they are also described as the communication device 2022.
- the data collection server 2024 collects data such as sensor data obtained by the sensor included in the terminal 2021 as position-related data associated with the position in the three-dimensional space.
- the sensor data is, for example, data acquired by using a sensor included in the terminal 2021 such as a state around the terminal 2021 or an internal state of the terminal 2021.
- the terminal 2021 transmits sensor data collected from one or more sensor devices in a position capable of directly communicating with the terminal 2021 or relaying one or more relay devices by the same communication method to the data collection server 2024. Send.
- the data included in the position-related data may include, for example, information indicating the operating state of the terminal itself or the device included in the terminal, the operation log, the usage status of the service, and the like. Further, the data included in the position-related data may include information in which the identifier of the terminal 2021 is associated with the position or the movement route of the terminal 2021.
- the information indicating the position included in the position-related data is associated with the information indicating the position in the three-dimensional data such as the three-dimensional map data.
- the details of the information indicating the position will be described later.
- the position-related data includes, in addition to the position information which is information indicating the position, the time information described above, the attributes of the data included in the position-related data, or the information indicating the type of the sensor (for example, model number) that generated the data. It may contain at least one of.
- the position information and the time information may be stored in the header area of the position-related data or the header area of the frame for storing the position-related data. Further, the position information and the time information may be transmitted and / or stored separately from the position-related data as metadata associated with the position-related data.
- the map server 2025 is connected to the network 2023, for example, and transmits three-dimensional data such as three-dimensional map data in response to a request from another device such as a terminal 2021. Further, as described in each of the above-described embodiments, the map server 2025 may have a function of updating three-dimensional data by using the sensor information transmitted from the terminal 2021.
- the data collection server 2024 is connected to the network 2023, for example, collects position-related data from other devices such as the terminal 2021, and stores the collected position-related data in a storage device inside or in another server. Further, the data collection server 2024 transmits the collected position-related data or the metadata of the three-dimensional map data generated based on the position-related data to the terminal 2021 in response to the request from the terminal 2021.
- Network 2023 is a communication network such as the Internet.
- the terminal 2021 is connected to the network 2023 via the communication device 2022.
- the communication device 2022 communicates with the terminal 2021 while switching between one communication method or a plurality of communication methods.
- the communication device 2022 is, for example, (1) a base station such as LTE (Long Term Evolution), (2) an access point (AP) such as WiFi or millimeter wave communication, and (3) LPWA such as SIGFOX, LoRaWAN or Wi-SUN. (Low Power Wide Area)
- a communication satellite that communicates using a gateway of Network or (4) a satellite communication method such as DVB-S2.
- the base station may communicate with the terminal 2021 by a method classified into LPWA such as NB-IoT (Narrow Band-IoT) or LTE-M, and may communicate with the terminal 2021 while switching between these methods. Communication may be performed.
- LPWA Low Band-IoT
- LTE-M Long Term Evolution
- the terminal 2021 has a function of communicating with a communication device 2022 using two types of communication methods, and a communication device using any of these communication methods or a plurality of these communication methods and a direct communication partner.
- An example is given in which communication is performed with the map server 2025 or the data collection server 2024 while switching 2022, but the configuration of the sensor information collection system and the terminal 2021 is not limited to this.
- the terminal 2021 may not have a communication function in a plurality of communication methods, but may have a function to perform communication in any one communication method.
- the terminal 2021 may support three or more communication methods. Further, the corresponding communication method may be different for each terminal 2021.
- the terminal 2021 includes, for example, the configuration of the client device 902 shown in FIG. 91.
- the terminal 2021 estimates a position such as a self-position using the received three-dimensional data. Further, the terminal 2021 generates position-related data by associating the sensor data acquired from the sensor with the position information obtained by the position estimation process.
- the position information added to the position-related data indicates, for example, the position in the coordinate system used in the three-dimensional data.
- the position information is a coordinate value represented by a value of latitude and longitude.
- the terminal 2021 may include the coordinate value as well as the information indicating the coordinate system that is the reference of the coordinate value and the three-dimensional data used for the position estimation in the position information.
- the coordinate values may include altitude information.
- the position information may be associated with a unit of data or a unit of space that can be used for encoding the above-mentioned three-dimensional data.
- This unit is, for example, WLD, GOS, SPC, VLM, VXL, or the like.
- the position information is represented by an identifier for specifying a data unit such as an SPC corresponding to the position-related data.
- the position information is information indicating three-dimensional data in which the three-dimensional space including the data unit such as SPC is encoded, or the details in the SPC. It may contain information indicating a different position.
- the information indicating the three-dimensional data is, for example, the file name of the three-dimensional data.
- the system generates the position-related data associated with the position information based on the position estimation using the three-dimensional data, so that the self-position of the client device (terminal 2021) acquired by GPS can be used. It is possible to add position information to the sensor information with higher accuracy than when the based position information is added to the sensor information. As a result, even when the position-related data is used by other devices in other services, the position corresponding to the position-related data can be specified more accurately in the real space by performing the position estimation based on the same three-dimensional data. There is a possibility that it can be done.
- the data transmitted from the terminal 2021 is position-related data
- the data transmitted from the terminal 2021 may be data not associated with the position information. good. That is, the transmission / reception of the three-dimensional data or the sensor data described in the other embodiment may be performed via the network 2023 described in the present embodiment.
- the position information added to the position-related data may be information indicating a position relative to a feature point in the three-dimensional data.
- the feature point that serves as a reference for the position information is, for example, a feature point encoded as SWLD and notified to the terminal 2021 as three-dimensional data.
- the information indicating the relative position with respect to the feature point is represented by, for example, a vector from the feature point to the point indicated by the position information, and may be information indicating the direction and distance from the feature point to the point indicated by the position information.
- the information indicating the relative position with respect to the feature point may be information indicating the displacement amount of each of the X-axis, the Y-axis, and the Z-axis from the feature point to the point indicated by the position information.
- the information indicating the relative position with respect to the feature point may be information indicating the distance from each of the three or more feature points to the point indicated by the position information.
- the relative position may not be the relative position of the point indicated by the position information expressed with respect to each feature point, but may be the relative position of each feature point expressed with reference to the point indicated by the position information.
- An example of position information based on a relative position with respect to a feature point includes information for specifying a reference feature point and information indicating a relative position of a point indicated by the position information with respect to the feature point.
- the information indicating the relative position with respect to the feature point is provided separately from the three-dimensional data
- the information indicating the relative position with respect to the feature point is the coordinate axis used for deriving the relative position, the information indicating the type of the three-dimensional data, and the information indicating the type of the three-dimensional data.
- it may include information indicating the magnitude (scale, etc.) of the value of the information indicating the relative position per unit amount.
- the position information may include information indicating a relative position with respect to each feature point for a plurality of feature points.
- the terminal 2021 that tries to specify the position indicated by the position information in the real space has the position information from the position of the feature point estimated from the sensor data for each feature point.
- the candidate points of the positions indicated by may be calculated, and the points obtained by averaging the calculated plurality of candidate points may be determined to be the points indicated by the position information. According to this configuration, the influence of an error in estimating the position of the feature point from the sensor data can be reduced, so that the estimation accuracy of the point indicated by the position information in the real space can be improved.
- the position information includes information indicating a relative position with respect to a plurality of feature points, even if there is a feature point that cannot be detected due to restrictions such as the type or performance of the sensor included in the terminal 2021, any of the plurality of feature points. If even one of them can be detected, it is possible to estimate the value of the point indicated by the position information.
- a point that can be identified from the sensor data can be used.
- the points that can be identified from the sensor data are, for example, points within a region or points that satisfy predetermined conditions for feature point detection, such as the above-mentioned three-dimensional feature amount or feature amount of visible light data being equal to or greater than a threshold value.
- a marker installed in a real space may be used as a feature point.
- the marker may be detected and its position can be specified from the data acquired by using a sensor such as LiDER or a camera.
- the marker is represented by a change in color or luminance value (reflectance), or a three-dimensional shape (unevenness, etc.).
- a coordinate value indicating the position of the marker, a two-dimensional code or a barcode generated from the identifier of the marker, or the like may be used.
- a light source that transmits an optical signal may be used as a marker.
- a light source of an optical signal When a light source of an optical signal is used as a marker, not only information for acquiring a position such as a coordinate value or an identifier but also other data may be transmitted by the optical signal.
- the optical signal connects to the wireless communication device with the content of the service according to the position of the marker, the address such as ur for acquiring the content, or the identifier of the wireless communication device for receiving the provision of the service. It may include information indicating a wireless communication method for the purpose.
- the terminal 2021 grasps the correspondence between the feature points between different data by using, for example, an identifier commonly used between the data, or information or a table showing the correspondence between the feature points between the data. Further, when there is no information indicating the correspondence between the feature points, the terminal 2021 is the feature at the closest distance when the coordinates of the feature points in one three-dimensional data are converted to the positions in the other three-dimensional data space. A point may be determined to be a corresponding feature point.
- the position information based on the relative position described above is used, it is included in each 3D data or associated with each 3D data even between terminals 2021 or services that use different 3D data.
- the position indicated by the position information can be specified or estimated based on the common feature point. As a result, it becomes possible to identify or estimate the same position with higher accuracy between terminals 2021 or services that use different three-dimensional data.
- the data collection server 2024 may transfer the received position-related data to another data server.
- the data collection server 2024 determines to which data server the received position-related data is to be transferred, and transfers the position-related data to the data server determined as the transfer destination.
- the data collection server 2024 determines the transfer destination based on, for example, the determination rule of the transfer destination server preset in the data collection server 2024.
- the determination rule of the transfer destination server is set, for example, in the transfer destination table in which the identifier associated with each terminal 2021 and the data server of the transfer destination are associated with each other.
- the terminal 2021 adds an identifier associated with the terminal 2021 to the position-related data to be transmitted and transmits the data to the data collection server 2024.
- the data collection server 2024 specified the transfer destination data server corresponding to the identifier attached to the position-related data based on the determination rule of the transfer destination server using the transfer destination table or the like, and specified the position-related data. Send to the data server. Further, the determination rule of the transfer destination server may be specified by the determination condition using the time or place where the position-related data is acquired.
- the identifier associated with the above-mentioned transmission source terminal 2021 is, for example, an identifier unique to each terminal 2021 or an identifier indicating a group to which the terminal 2021 belongs.
- the transfer destination table does not have to be a direct association between the identifier associated with the source terminal and the transfer destination data server.
- the data collection server 2024 holds a management table that stores tag information assigned to each terminal 2021 for each unique identifier, and a transfer destination table that associates the tag information with the transfer destination data server.
- the data collection server 2024 may determine the transfer destination data server based on the tag information by using the management table and the transfer destination table.
- the tag information is, for example, management control information or service provision control information given to the type, model number, owner, group to which the terminal 2021 corresponds to the identifier, or other identifier.
- an identifier unique to each sensor may be used instead of the identifier associated with the transmission source terminal 2021.
- the determination rule of the transfer destination server may be set from the client device 2026.
- the data collection server 2024 may determine a plurality of data servers as transfer destinations and transfer the received position-related data to the plurality of data servers. According to this configuration, for example, when the location-related data is automatically backed up, or in order to share the location-related data with different services, the location-related data is transmitted to the data server for providing each service. If it is necessary to do so, the data can be transferred as intended by changing the setting for the data collection server 2024. As a result, the man-hours required for constructing and changing the system can be reduced as compared with the case where the transmission destination of the position-related data is set in the individual terminal 2021.
- the data collection server 2024 registers the data server specified by the transfer request signal as a new transfer destination in response to the transfer request signal received from the data server, and transfers the position-related data received thereafter to the data server. You may.
- the data collection server 2024 stores the position-related data received from the terminal 2021 in the recording device, and requests the position-related data specified by the transmission request signal according to the transmission request signal received from the terminal 2021 or the data server. It may be transmitted to the terminal 2021 or the data server of.
- the data collection server 2024 determines whether or not the location-related data can be provided to the requesting data server or terminal 2021, and if it is determined that the location-related data can be provided, the data collection server 2024 transfers or transmits the location-related data to the requesting data server or terminal 2021. May be done.
- the data collection server 2024 When the request for the current position-related data is received from the client device 2026, the data collection server 2024 requests the terminal 2021 to transmit the position-related data even if the terminal 2021 does not send the position-related data. 2021 may transmit position-related data in response to the transmission request.
- the terminal 2021 transmits the position information data to the data collection server 2024, but the data collection server 2024 collects the position-related data from the terminal 2021, such as a function for managing the terminal 2021. It may be provided with a function necessary for the terminal 2021 or a function used when collecting position-related data from the terminal 2021.
- the data collection server 2024 may have a function of transmitting a data request signal requesting the transmission of position information data to the terminal 2021 and collecting position-related data.
- Management information such as an address for communicating with the terminal 2021 to be collected data or an identifier unique to the terminal 2021 is registered in the data collection server 2024 in advance.
- the data collection server 2024 collects position-related data from the terminal 2021 based on the registered management information.
- the management information may include information such as the type of sensor included in the terminal 2021, the number of sensors included in the terminal 2021, and the communication method supported by the terminal 2021.
- the data collection server 2024 may collect information such as the operating status or the current position of the terminal 2021 from the terminal 2021.
- the registration of the management information may be performed from the client device 2026, or the process for registration may be started by the terminal 2021 transmitting the registration request to the data collection server 2024.
- the data acquisition server 2024 may have a function of controlling communication with the terminal 2021.
- the communication connecting the data collection server 2024 and the terminal 2021 is configured by a dedicated line provided by a service provider such as MNO (Mobile Network Operator) or MVNO (Mobile Virtual Network Operator), or VPN (Virtual Private Network). It may be a virtual dedicated line or the like. According to this configuration, communication between the terminal 2021 and the data collection server 2024 can be performed safely.
- MNO Mobile Network Operator
- MVNO Mobile Virtual Network Operator
- VPN Virtual Private Network
- the data collection server 2024 may have a function of authenticating the terminal 2021 or a function of encrypting data transmitted to and received from the terminal 2021.
- the authentication process of the terminal 2021 or the data encryption process is a terminal group including an identifier unique to the terminal 2021 or a plurality of terminals 2021 shared in advance between the data collection server 2024 and the terminal 2021. It is done using a unique identifier or the like.
- This identifier is, for example, an IMSI (International Mobile Subscriber Identity), which is a unique number stored in a SIM (Subscriber Identity Module) card.
- IMSI International Mobile Subscriber Identity
- SIM Subscriber Identity Module
- the process of authentication or data encryption between the data collection server 2024 and the terminal 2021 can be provided as long as both the data collection server 2024 and the terminal 2021 have a function to perform the process, and can be relayed. It does not depend on the communication method used by the communication device 2022. Therefore, since the common authentication or encryption process can be used without considering whether the terminal 2021 uses the communication method, the convenience of the user's system construction is improved. However, the fact that the communication device 2022 for relaying does not depend on the communication method means that it is not essential to change the communication method according to the communication method. That is, for the purpose of improving transmission efficiency or ensuring safety, the authentication or data encryption process between the data collection server 2024 and the terminal 2021 may be switched according to the communication method used by the relay device.
- the data collection server 2024 may provide the client device 2026 with a UI that manages data collection rules such as the type of position-related data collected from the terminal 2021 and the data collection schedule. As a result, the user can specify the terminal 2021 for collecting data using the client device 2026, the data collection time and frequency, and the like. Further, the data collection server 2024 may specify an area on the map on which data is to be collected and collect position-related data from the terminal 2021 included in the area.
- the client device 2026 When the data collection rule is managed for each terminal 2021, the client device 2026 presents, for example, a list of terminals 2021 or sensors to be managed on the screen. The user sets the necessity of data collection or the collection schedule for each item in the list.
- the client device 2026 When designating an area on a map for which data is to be collected, the client device 2026 presents, for example, a two-dimensional or three-dimensional map of the area to be managed on the screen. The user selects an area on the displayed map to collect data.
- the area selected on the map may be a circular or rectangular area centered on a point specified on the map, or may be a circular or rectangular area that can be specified by a drag operation. Further, the client device 2026 may select an area in a preset unit such as a city, an area in the city, a block, or a main road.
- the area may be set by inputting the numerical values of latitude and longitude, or the area is selected from the list of candidate areas derived based on the input text information. May be done.
- the textual information may be, for example, the name of a region, city, or landmark.
- an area on the map may be designated based on the position of the client device 2026 in real space obtained from the sensor data. For example, the client device 2026 estimates its own position using sensor data, and data a region within a predetermined distance from a point on the map corresponding to the estimated position or a distance specified by the user. May be specified as the area to collect. Further, the client device 2026 may designate the sensing area of the sensor, that is, the area corresponding to the acquired sensor data as the area for collecting the data. Alternatively, the client device 2026 may designate an area based on the position corresponding to the sensor data specified by the user as an area for collecting data. The estimation of the area or position on the map corresponding to the sensor data may be performed by the client device 2026 or may be performed by the data acquisition server 2024.
- the data collection server 2024 When specifying in the area on the map, the data collection server 2024 identifies the terminal 2021 in the specified area by collecting the current position information of each terminal 2021, and positions the terminal 2021 with respect to the specified terminal 2021. You may request the transmission of relevant data. Further, the data collection server 2024 does not specify the terminal 2021 in the area, but the data collection server 2024 transmits information indicating the designated area to the terminal 2021, and the terminal 2021 itself is in the designated area. It may be determined whether or not it is, and if it is determined that it is within the specified area, the position-related data may be transmitted.
- the data collection server 2024 transmits data such as a list or a map for providing the above-mentioned UI (User Interface) in the application executed by the client device 2026 to the client device 2026.
- the data collection server 2024 may transmit the application program to the client device 2026 as well as data such as a list or a map.
- the above-mentioned UI may be provided as content created by HTML or the like that can be displayed by a browser.
- Some data such as map data may be provided from a server other than the data collection server 2024 such as the map server 2025.
- the client device 2026 transmits the input information to the data collection server 2024 as the setting information when the input for notifying the completion of the input is performed, such as the user pressing the setting button.
- the data collection server 2024 transmits a signal notifying the request for the position-related data or the collection rule of the position-related data to each terminal 2021 based on the setting information received from the client device 2026, and collects the position-related data. conduct.
- object information indicating the position of a feeding unit such as a feeding antenna or a feeding coil of wireless feeding buried in a road or a parking lot is included in the three-dimensional data or associated with the three-dimensional data.
- terminal 2021 such as a car or drone.
- the vehicle or drone that has acquired the object information for charging automatically drives the vehicle itself so that the position of the charging part such as the charging antenna or charging coil of the vehicle faces the area indicated by the object information. Move the position of and start charging.
- the driver or operator is presented with the direction to move or the operation to be performed using the image or sound displayed on the screen. To. Then, when it is determined that the position of the charging unit calculated based on the estimated self-position is within the area indicated by the object information or within a predetermined distance from the area, the operation or maneuvering is stopped. The image or sound presented to is switched, and charging is started.
- the object information may not be information indicating the position of the feeding unit, but may be information indicating an area where charging efficiency equal to or higher than a predetermined threshold value can be obtained by arranging the charging unit in the area.
- the position of the object information may be represented by a point at the center of the region indicated by the object information, a region or line in a two-dimensional plane, or a region, line or plane in a three-dimensional space. good.
- the antenna for wireless charging provided in the terminal 2021 such as a car and the wireless embedded in the road etc.
- the alignment with the feeding antenna can be performed with higher accuracy. As a result, the charging speed at the time of wireless charging can be shortened and the charging efficiency can be improved.
- the object information may be an object other than the feeding antenna.
- the three-dimensional data includes the position of the AP of millimeter-wave wireless communication as object information.
- the terminal 2021 can grasp the position of the AP in advance, so that the directivity of the beam can be directed in the direction of the object information and the communication can be started.
- the communication quality such as improving the transmission speed, shortening the time until the start of communication, and extending the communicable period.
- the object information may include information indicating the type of the object corresponding to the object information. Further, the object information should be executed by the terminal 2021 when the terminal 2021 is included in the area in the real space corresponding to the position of the object information on the three-dimensional data or within a range of a predetermined distance from the area. Information indicating the process may be included.
- the object information may be provided from a server different from the server that provides the three-dimensional data.
- the object group in which the object information used in the same service is stored may be provided as different data depending on the type of the target service or the target device. ..
- the three-dimensional data used in combination with the object information may be WLD point cloud data or SWLD feature point data.
- the three-dimensional data decoding device when the attribute information of the target three-dimensional point, which is the three-dimensional point to be encoded, is hierarchically coded using LoD (Level of Datail), the three-dimensional data decoding device is the three-dimensional. It is not necessary to decode the attribute information up to the required LoD hierarchy in the data decoding device and not to decode the attribute information of the unnecessary hierarchy. For example, when the total number of LoDs of the attribute information in the bit stream encoded by the three-dimensional data encoding device is N, the three-dimensional data decoding device is M from LoD0 to LoD (M-1) of the uppermost layer. It is not necessary to decode the LoDs (M ⁇ N) and the remaining LoDs (N-1). As a result, the three-dimensional data decoding device can decode the attribute information from LoD0 to LoD (M-1) required by the three-dimensional data decoding device while suppressing the processing load.
- LoD Level of Datail
- FIG. 102 is a diagram showing the above use case.
- the server holds a three-dimensional map obtained by encoding the three-dimensional position information and the attribute information.
- the server (three-dimensional data coding device) broadcasts a three-dimensional map to a client device (three-dimensional data decoding device: for example, a vehicle or a drone) in an area managed by the server, and the client device receives from the server.
- a process of specifying the self-position of the client device using a three-dimensional map, or a process of displaying map information to a user or the like who operates the client device is performed.
- the server encodes the position information of the three-dimensional map by using an octree configuration or the like. Then, the server hierarchically encodes the attribute information of the three-dimensional map using N LoDs constructed based on the position information. The server stores a bitstream of the 3D map obtained by hierarchical coding.
- the server transmits a coded three-dimensional map bitstream to the client device in response to a transmission request for map information transmitted from the client device in the area managed by the server.
- the client device receives the bitstream of the 3D map transmitted from the server, and decodes the position information and attribute information of the 3D map according to the purpose of the client device. For example, when the client device performs highly accurate self-position estimation using the position information and the attribute information of N LoDs, the client device determines that the decoding result up to a dense three-dimensional point is required as the attribute information. And decode all the information in the bitstream.
- the client device determines that the decoding result up to the sparse three-dimensional point is necessary as the attribute information, and the position information and the upper layer of LoD are used.
- Decoding attribute information of LoD from a certain LoD0 to M (M ⁇ N).
- the three-dimensional point map includes position information and attribute information.
- the position information is coded by an octree.
- the attribute information is encoded by N LoDs.
- Client device A performs highly accurate self-position estimation. In this case, the client device A determines that all the position information and the attribute information are necessary, and decodes all the position information in the bit stream and the attribute information composed of N LoDs.
- Client device B displays a three-dimensional map to the user.
- the client device B determines that the position information and the attribute information of M LoDs (M ⁇ N) are necessary, and decodes the position information in the bit stream and the attribute information composed of M LoDs. do.
- the server may broadcast the three-dimensional map to the client device, multicast transmission, or unicast transmission.
- the three-dimensional data coding device when the attribute information of the target three-dimensional point, which is the target three-dimensional point to be coded, is hierarchically coded using LoD, the three-dimensional data coding device is the three-dimensional data decoding device. It is not necessary to encode the attribute information up to the required LoD hierarchy and not to encode the attribute information of the unnecessary hierarchy. For example, when the total number of LoDs is N, the three-dimensional data coding device encodes M (M ⁇ N) LoDs from the uppermost layer LoD0 to LoD (M-1), and the remaining LoD (N). A bit stream may be generated by not encoding LoD up to -1).
- the 3D data encoding device can obtain a bitstream in which the attribute information from LoD0 to LoD (M-1) required by the 3D data decoding device is encoded in response to the request from the 3D data decoding device. Can be provided.
- FIG. 103 is a diagram showing the above use case.
- the server holds a three-dimensional map obtained by encoding the three-dimensional position information and the attribute information.
- the server (three-dimensional data coding device) unicasts a three-dimensional map to the client device (three-dimensional data decoding device: for example, a vehicle or a drone) in the area managed by the server according to the request of the client device.
- the client device performs a process of specifying the self-position of the client device using a three-dimensional map received from the server, or a process of displaying map information to a user or the like who operates the client device.
- the server encodes the position information of the three-dimensional map by using an octree configuration or the like. Then, the server generates a bitstream of the 3D map A by hierarchically coding the attribute information of the 3D map using N LoDs constructed based on the position information, and generates the generated bitstream. Save to the server. Further, the server generates a bitstream of the three-dimensional map B by hierarchically coding the attribute information of the three-dimensional map using M (M ⁇ N) LoDs constructed based on the position information. Save the generated bitstream in the server.
- the client device requests the server to send a three-dimensional map according to the purpose of the client device. For example, when the client device performs highly accurate self-position estimation using the position information and the attribute information of N LoDs, the client device determines that the decoding result up to a dense three-dimensional point is necessary as the attribute information, and is tertiary. Requests the server to send the bitstream of the original map A. Further, when displaying the information of the 3D map to the user or the like, the client device determines that the decoding result up to the sparse 3D point is necessary as the attribute information, and M pieces from the position information and the upper layer LoD0 of LoD.
- the server Requests the server to transmit a bit stream of the three-dimensional map B including LoD attribute information up to (M ⁇ N). Then, the server transmits the encoded bitstream of the three-dimensional map A or the three-dimensional map B to the client device in response to the request for transmission of the map information from the client device.
- the client device receives the bitstream of the three-dimensional map A or the three-dimensional map B transmitted from the server according to the use of the client device, and decodes the bitstream. In this way, the server switches the bit stream to be transmitted according to the usage of the client device. As a result, the processing load of the client device can be reduced.
- the server holds the three-dimensional map A and the three-dimensional map B.
- the server encodes the position information of the three-dimensional map with, for example, an ocree, and encodes the attribute information of the three-dimensional map with N LoDs to generate the three-dimensional map A. That is, NumLoD included in the bitstream of the three-dimensional map A indicates N.
- the server encodes the position information of the three-dimensional map with, for example, an ocree, and encodes the attribute information of the three-dimensional map with M LoDs to generate the three-dimensional map B. That is, NumLoD included in the bitstream of the three-dimensional map B indicates M.
- Client device A performs highly accurate self-position estimation.
- the client device A determines that all the position information and the attribute information are necessary, and sends a transmission request of the three-dimensional map A including all the position information and the attribute information composed of N LoDs to the server. ..
- the client device A receives the three-dimensional map A and decodes all the position information and the attribute information composed of N LoDs.
- Client device B displays a three-dimensional map to the user.
- the client device B determines that the position information and the attribute information of M (M ⁇ N) LoDs are necessary, and includes all the position information and the attribute information composed of M LoDs in three dimensions.
- the client device B receives the three-dimensional map B and decodes all the position information and the attribute information composed of M LoDs.
- the server (three-dimensional data coding device) encodes the three-dimensional map C in which the remaining NM attribute information of LoD is encoded in addition to the three-dimensional map B, and the request of the client device B.
- the three-dimensional map C may be transmitted to the client device B according to the above. Further, the client device B may obtain decoding results of N LoDs by using the bitstream of the three-dimensional map B and the three-dimensional map C.
- FIG. 104 is a flowchart showing an example of application processing.
- the three-dimensional data demultiplexing device acquires an ISOBMFF file including point cloud data and a plurality of coded data (S7301).
- the three-dimensional data demultiplexing device may acquire the ISOBMFF file by communication or may read it from the stored data.
- the three-dimensional data demultiplexing device analyzes the entire configuration information in the ISOBMFF file and identifies the data to be used for the application (S7302). For example, the three-dimensional data demultiplexing device acquires data used for processing and does not acquire data not used for processing.
- the three-dimensional data demultiplexing device extracts one or more data used for the application and analyzes the configuration information of the data (S7303).
- the three-dimensional data demultiplexing device converts the ISOBMFF into a coded stream and extracts a time stamp (S7305). Further, the three-dimensional data demultiplexing device determines whether or not the data are synchronized, for example, by referring to a flag indicating whether or not the data are synchronized, and if they are not synchronized, the synchronization is performed. Processing may be performed.
- the three-dimensional data demultiplexing device decodes the data by a predetermined method according to the time stamp and other instructions, and processes the decoded data (S7306).
- the three-dimensional data demultiplexing device extracts the data and the time stamp (S7307). Further, the three-dimensional data demultiplexing device determines whether or not the data are synchronized, for example, by referring to a flag indicating whether or not the data are synchronized, and if they are not synchronized, the synchronization is performed. Processing may be performed. The three-dimensional data demultiplexing device then processes the data according to the time stamp and other instructions (S7308).
- FIG. 105 is a diagram showing an example of the sensor range of the beam LiDAR, FLASH LiDAR, and the camera.
- the beam LiDAR detects all directions around the vehicle (sensor), and the FLASH LiDAR and the camera detect a range in one direction (for example, forward) of the vehicle.
- the three-dimensional data demultiplexing device extracts and decodes the coded data of the beam LiDAR and FLASH LiDAR with reference to the overall configuration information. Further, the three-dimensional data demultiplexing device does not extract the camera image.
- the three-dimensional data demultiplexing device simultaneously processes the coded data of the time of the same time stamp according to the time stamps of LiDAR and FLASH LiDAR.
- the three-dimensional data demultiplexing device may present the processed data on the presenting device, synthesize the point cloud data of the beam LiDAR and the FLASH LiDAR, perform processing such as rendering.
- the three-dimensional data demultiplexing device may extract sensor position information and use it in the application.
- the three-dimensional data demultiplexing device may select whether to use beam LiDAR information or FLASH LiDAR in the application, and switch the processing according to the selection result.
- FIG. 106 is a diagram showing a configuration example of an automated driving system.
- This automated driving system includes a cloud server 7350 and an edge 7360 such as an in-vehicle device or a mobile device.
- the cloud server 7350 includes a demultiplexing unit 7351, a decoding unit 7352A, 7352B and 7355, a point cloud data synthesis unit 7353, a large-scale data storage unit 7354, a comparison unit 7356, and a coding unit 7357.
- the edge 7360 includes sensors 7361A and 7361B, point cloud data generation units 7362A and 7362B, synchronization units 7363, coding units 7364A and 7364B, multiplexing unit 7365, update data storage unit 7366, and demultiplexing unit. It includes a 7637, a decoding unit 7368, a filter 7369, a self-position estimation unit 7370, and an operation control unit 7371.
- the edge 7360 downloads a large-scale data which is a large-scale point cloud map data stored in the cloud server 7350.
- the edge 7360 performs self-position estimation processing of the edge 7360 (vehicle or terminal) by matching the large-scale data with the sensor information obtained by the edge 7360. Further, the edge 7360 uploads the acquired sensor information to the cloud server 7350, and updates the large-scale data with the latest map data.
- point cloud data with different coding methods are handled in various applications that handle point cloud data in the system.
- the cloud server 7350 encodes and multiplexes large-scale data. Specifically, the coding unit 7357 performs coding by using a third coding method suitable for coding a large-scale point cloud. Further, the coding unit 7357 multiplexes the coded data.
- the large-scale data storage unit 7354 stores data encoded and multiplexed by the coding unit 7357.
- Edge 7360 performs sensing.
- the point cloud data generation unit 7362A generates the first point cloud data (position information (geometry) and attribute information) by using the sensing information acquired by the sensor 7361A.
- the point cloud data generation unit 7362B generates the second point cloud data (position information and attribute information) by using the sensing information acquired by the sensor 7361B.
- the generated first point cloud data and second point cloud data are used for self-position estimation or vehicle control of automatic driving, or map update. In each process, some information of the first point cloud data and the second point cloud data may be used.
- Edge 7360 performs self-position estimation. Specifically, Edge 7360 downloads large-scale data from the cloud server 7350.
- the demultiplexing unit 7637 acquires the coded data by demultiplexing the large-scale data in the file format.
- the decoding unit 7368 acquires large-scale data, which is large-scale point cloud map data, by decoding the acquired coded data.
- the self-position estimation unit 7370 matches the acquired large-scale data with the first point cloud data and the second point cloud data generated by the point cloud data generation units 7362A and 7362B to map the vehicle. Estimate the self-position in. Further, the operation control unit 7371 uses the matching result or the self-position estimation result for the operation control.
- the self-position estimation unit 7370 and the operation control unit 7371 may extract specific information such as position information from the large-scale data and perform processing using the extracted information. Further, the filter 7369 performs processing such as correction or thinning on the first point cloud data and the second point cloud data. The self-position estimation unit 7370 and the operation control unit 7371 may use the first point cloud data and the second point cloud data after the processing is performed. Further, the self-position estimation unit 7370 and the operation control unit 7371 may use the sensor signals obtained by the sensors 7361A and 7361B.
- the synchronization unit 7363 performs time synchronization and position correction between data of a plurality of sensor signals or a plurality of point cloud data. Further, the synchronization unit 7363 corrects the position information of the sensor signal or the point cloud data so as to match the large-scale data based on the position correction information of the large-scale data and the sensor data generated by the self-position estimation process. May be good.
- synchronization and position correction may be performed on the cloud server 7350 instead of the edge 7360.
- the edge 7360 may multiplex the synchronization information and the position information and transmit them to the cloud server 7350.
- Edge 7360 is. Encode and multiplex sensor signals or point cloud data.
- the sensor signal or point cloud data is encoded using a first or second coding method suitable for encoding each signal.
- the coding unit 7364A generates the first coded data by coding the first point cloud data using the first coding method.
- the coding unit 7364B generates the second coded data by coding the second point cloud data using the second coding method.
- the multiplexing unit 7365 generates a multiplexed signal by multiplexing the first coded data, the second coded data, the synchronization information, and the like.
- the update data storage unit 7366 stores the generated multiplexed signal. Further, the update data storage unit 7366 uploads the multiplexed signal to the cloud server 7350.
- the cloud server 7350 synthesizes the point cloud data. Specifically, the demultiplexing unit 7351 acquires the first coded data and the second coded data by demultiplexing the multiplexing signal uploaded to the cloud server 7350.
- the decoding unit 7352A acquires the first point cloud data (or sensor signal) by decoding the first coded data.
- the decoding unit 7352B acquires the second point cloud data (or sensor signal) by decoding the second coded data.
- the point cloud data synthesis unit 7353 synthesizes the first point cloud data and the second point cloud data by a predetermined method.
- the point cloud data synthesis unit 7353 may perform the synthesis using the information.
- the decoding unit 7355 demultiplexes and decodes the large-scale data stored in the large-scale data storage unit 7354.
- the comparison unit 7356 compares the point cloud data generated based on the sensor signal obtained at the edge 7360 with the large-scale data possessed by the cloud server 7350, and determines the point cloud data that needs to be updated.
- the comparison unit 7356 updates the point cloud data determined to be necessary to be updated among the large-scale data to the point cloud data obtained from the edge 7360.
- the coding unit 7357 encodes and multiplexes the updated large-scale data, and stores the obtained data in the large-scale data storage unit 7354.
- the signals to be handled may differ depending on the intended use or application, and the signal to be multiplexed or the coding method may differ. Even in such a case, flexible decoding and application processing can be performed by multiplexing data of various coding methods using the present embodiment. In addition, even if the signal coding method is different, various applications and systems can be constructed by converting a coding method suitable for demultiplexing, decoding, data conversion, coding, and multiplexing processing. , Flexible service can be provided.
- FIG. 107 is a diagram showing a configuration example of a bit stream.
- the whole information of the divided data indicates the sensor ID (sensor_id) and the data ID (data_id) of the divided data for each divided data.
- the data ID is also shown in the header of each coded data.
- the entire information of the divided data shown in FIG. 107 includes the sensor information (Sensor), the sensor version (Version), the sensor manufacturer name (Maker), and the sensor, in addition to the sensor ID. It may include at least one of the installation information (Mount Info.) And the position coordinates (World Coordinate) of the sensor.
- the three-dimensional data decoding device can acquire information on various sensors from the configuration information.
- the entire information of the divided data may be stored in the metadata SPS, GPS or APS, or may be stored in the SEI which is the metadata not essential for encoding. Further, the three-dimensional data encoding device stores the SEI in the ISOBMFF file at the time of multiplexing. The three-dimensional data decoding device can acquire desired divided data based on the metadata.
- SPS is the metadata of the entire coded data
- GPS is the metadata of the position information
- APS is the metadata of each attribute information
- G is the coded data of the position information of each divided data. Yes, A1 and the like are coded data of attribute information for each divided data.
- FIG. 108 is a flowchart of the point group selection process executed by this application.
- FIGS. 109 to 111 are diagrams showing screen examples of point group selection processing.
- a three-dimensional data decoding device that executes an application has, for example, a UI unit that displays an input UI (user interface) 8661 for selecting an arbitrary point cloud.
- the input UI8661 has a presentation unit 8662 that presents the selected point cloud, and an operation unit (buttons 8663 and 8664) that accepts the user's operation.
- the three-dimensional data decoding device acquires desired data from the storage unit 8665 after the point cloud is selected by UI8661.
- the point cloud information that the user wants to display is selected based on the operation for the user's input UI8661 (S8631). Specifically, when the button 8663 is selected, the point cloud based on the sensor 1 is selected. When the button 8664 is selected, the point cloud based on the sensor 2 is selected. Alternatively, by selecting both the button 8663 and the button 8664, both the point cloud based on the sensor 1 and the point cloud based on the sensor 2 are selected.
- the point cloud selection method is an example and is not limited to this.
- the three-dimensional data decoding device analyzes the entire information of the divided data contained in the multiplexed signal (bit stream) or the coded data, and selects a point group from the sensor ID (sensor_id) of the selected sensor.
- the data ID (data_id) of the divided data constituting the above is specified (S8632).
- the three-dimensional data decoding device extracts coded data including the specified desired data ID from the multiplexed signal, and decodes the extracted coded data to obtain a point cloud based on the selected sensor. Is decoded (S8633).
- the three-dimensional data decoding device does not decode other coded data.
- the three-dimensional data decoding device presents (for example, displays) the decoded point cloud (S8634).
- FIG. 110 shows an example when the button 8663 of the sensor 1 is pressed, and a point cloud of the sensor 1 is presented.
- FIG. 111 shows an example in which both the button 8663 of the sensor 1 and the button 8664 of the sensor 2 are pressed, and the point cloud of the sensor 1 and the sensor 2 is presented.
- the present disclosure is not limited to this embodiment.
- each processing unit included in the three-dimensional data coding device, the three-dimensional data decoding device, and the like according to the above embodiment is typically realized as an LSI which is an integrated circuit. These may be individually integrated into one chip, or may be integrated into one chip so as to include a part or all of them.
- the integrated circuit is not limited to the LSI, and may be realized by a dedicated circuit or a general-purpose processor.
- An FPGA Field Programmable Gate Array
- a reconfigurable processor that can reconfigure the connection and settings of the circuit cells inside the LSI may be used.
- each component may be configured by dedicated hardware or may be realized by executing a software program suitable for each component.
- Each component may be realized by a program execution unit such as a CPU or a processor reading and executing a software program recorded on a recording medium such as a hard disk or a semiconductor memory.
- the present disclosure may be realized as a three-dimensional data coding method, a three-dimensional data decoding method, or the like executed by a three-dimensional data coding device, a three-dimensional data decoding device, or the like.
- the division of functional blocks in the block diagram is an example, and multiple functional blocks can be realized as one functional block, one functional block can be divided into multiple, and some functions can be transferred to other functional blocks. You may. Further, the functions of a plurality of functional blocks having similar functions may be processed by a single hardware or software in parallel or in a time division manner.
- each step in the flowchart is executed is for exemplifying in order to specifically explain the present disclosure, and may be an order other than the above. Further, a part of the above steps may be executed simultaneously with other steps (parallel).
- the three-dimensional data coding device, the three-dimensional data decoding device, and the like according to one or more embodiments have been described above based on the embodiment, but the present disclosure is not limited to this embodiment. .. As long as it does not deviate from the gist of the present disclosure, various modifications that can be conceived by those skilled in the art are applied to this embodiment, and a form constructed by combining components in different embodiments is also within the scope of one or more embodiments. May be included within.
- the present disclosure is applicable to a three-dimensional data coding device and a three-dimensional data decoding device.
- Three-dimensional data creation device 811 Data reception unit 812, 819 Communication unit 813 Reception control unit 814, 821 Format conversion unit 815
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Compression Or Coding Systems Of Tv Signals (AREA)
Abstract
Description
ポイントクラウドの符号化データを実際の装置又はサービスにおいて使用する際には、ネットワーク帯域を抑制するために用途に応じて必要な情報を送受信することが望ましい。しかしながら、これまで、三次元データの符号化構造にはそのような機能が存在せず、そのための符号化方法も存在しなかった。
本実施の形態では、上述した第1の符号化部4630、又は第2の符号化部4650で生成される符号化データ(位置情報(Geometry)、属性情報(Attribute)、付加情報(Metadata))の種別、及び付加情報(メタデータ)の生成方法、及び多重化部における多重処理について説明する。なお、付加情報(メタデータ)は、パラメータセット、又は制御情報と表記することもある。
実施の形態3に係る三次元データ符号化方法では、複数の三次元点の位置情報を、当該位置情報に基づいて生成した予測木を用いて符号化する。
式T1において、p0は点p0の位置情報を示し、p1は点p1の位置情報を示す。
本実施の形態では、点群(ポイントクラウド)の位置情報(8分木)に対するインター予測について説明する。図39は、本実施の形態に係る三次元データ符号化装置12800のブロック図である。なお、図39では、点群の位置情報(ジオメトリ)の符号化に関する処理部を記載しているが、三次元データ符号化装置12800は、点群の属性情報の符号化等を行う処理部等の他の処理部を備えてもよい。インター予測では、符号化済みの点群を参照しつつ符号化対象の点群が符号化される。
本実施の形態では、点群(ポイントクラウド)の位置情報に対してインター予測及びイントラ予測のいずれかを切り替えて実行する場合について説明する。
点群データに含まれる三次元点の位置情報を符号化する位置情報符号化部の構成を説明する。図62は、入力される位置情報の座標系と、符号化に用いられる位置情報の座標系とが共に直交座標系である場合の位置情報符号化部の構成を示すブロック図である。つまり、この構成は、gps_alt_coordinates_flag=0の場合の位置情報符号化部の構成である。ここで、図62~図64において、ブロック内の(x,y,z)は直交座標系を用いた処理が行われることを示し、ブロック内の(r,q,f)は極座標系を用いた処理が行われることを示す。(x,y,z)を付与した信号は直交座標系が用いられる信号であることを示し、(r,q,f)を付与した信号は極座標系が用いられる信号であることを示す。
本実施の形態では、三次元点群の位置情報の座標系が直交座標系と極座標系との場合のそれぞれにおける位置情報の符号化処理及び復号処理について説明する。まず、符号化処理について説明する。
次に、本実施の形態に係る三次元データ作成装置810の構成を説明する。図88は、本実施の形態に係る三次元データ作成装置810の構成例を示すブロック図である。この三次元データ作成装置810は、例えば、車両に搭載される。三次元データ作成装置810は、外部の交通監視クラウド、前走車両又は後続車両と三次元データの送受信を行うとともに、三次元データを作成及び蓄積する。
811 データ受信部
812、819 通信部
813 受信制御部
814、821 フォーマット変換部
815 センサ
816 三次元データ作成部
817 三次元データ合成部
818 三次元データ蓄積部
820 送信制御部
822 データ送信部
831、832、834、835、836、837 三次元データ
833 センサ情報
901 サーバ
902、902A、902B、902C クライアント装置
1011、1111 データ受信部
1012、1020、1112、1120 通信部
1013、1113 受信制御部
1014、1019、1114、1119 フォーマット変換部
1015 センサ
1016、1116 三次元データ作成部
1017 三次元画像処理部
1018、1118 三次元データ蓄積部
1021、1121 送信制御部
1022、1122 データ送信部
1031、1032、1135 三次元マップ
1033、1037、1132 センサ情報
1034、1035、1134 三次元データ
1117 三次元データ合成部
1201 三次元マップ圧縮/復号処理部
1202 センサ情報圧縮/復号処理部
1211 三次元マップ復号処理部
1212 センサ情報圧縮処理部
2001 サーバ
2002、2002A、2002B クライアント装置
2011 センサ情報取得部
2012 記憶部
2013 データ送信可否判定部
2021、2021A、2021B 端末
2022、2022A、2022B 通信装置
2023 ネットワーク
2024 データ収集サーバ
2025 地図サーバ
2026 クライアント装置
2700 位置情報符号化部
2701、2711 8分木生成部
2702、2712 幾何情報算出部
2703、2713 符号化テーブル選択部
2704 エントロピー符号化部
2710 位置情報復号部
2714 エントロピー復号部
3140 属性情報符号化部
3141、3151 LoD生成部
3142、3152 周囲探索部
3143、3153 予測部
3144 予測残差算出部
3145 量子化部
3146 算術符号化部
3147、3155 逆量子化部
3148、3156 復号値生成部
3149、3157 メモリ
3150 属性情報復号部
3154 算術復号部
4601 三次元データ符号化システム
4602 三次元データ復号システム
4603 センサ端末
4604 外部接続部
4611 点群データ生成システム
4612 提示部
4613 符号化部
4614 多重化部
4615 入出力部
4616 制御部
4617 センサ情報取得部
4618 点群データ生成部
4621 センサ情報取得部
4622 入出力部
4623 逆多重化部
4624 復号部
4625 提示部
4626 ユーザインタフェース
4627 制御部
4630 第1の符号化部
4631 位置情報符号化部
4632 属性情報符号化部
4633 付加情報符号化部
4634 多重化部
4640 第1の復号部
4641 逆多重化部
4642 位置情報復号部
4643 属性情報復号部
4644 付加情報復号部
4650 第2の符号化部
4651 付加情報生成部
4652 位置画像生成部
4653 属性画像生成部
4654 映像符号化部
4655 付加情報符号化部
4656 多重化部
4660 第2の復号部
4661 逆多重化部
4662 映像復号部
4663 付加情報復号部
4664 位置情報生成部
4665 属性情報生成部
4801 符号化部
4802 多重化部
6600 属性情報符号化部
6601 ソート部
6602 Haar変換部
6603 量子化部
6604、6612 逆量子化部
6605、6613 逆Haar変換部
6606、6614 メモリ
6607 算術符号化部
6610 属性情報復号部
6611 算術復号部
7350 クラウドサーバ
7351 逆多重化部
7352A、7352B 復号部
7353 点群データ合成部
7354 大規模データ蓄積部
7355 復号部
7356 比較部
7357 符号化部
7360 エッジ
7361A、7361B センサ
7362A、7362B 点群データ生成部
7363 同期部
7364A、7364B 符号化部
7365 多重化部
7366 更新データ蓄積部
7367 逆多重化部
7368 復号部
7369 フィルタ
7370 自己位置推定部
7371 運転制御部
8661 入力UI
8662 提示部
8663、8664 ボタン
8665 蓄積部
12800、12800A 三次元データ符号化装置
12801、12809 8分木化部
12802 バッファ
12803 エントロピー符号化部
12804、12805、12807、12810 バッファ
12806 点群化部
12808 動き検出補償部
12811 制御部
12812 動き補償部
12820、12820A 三次元データ復号装置
12821 エントロピー復号部
12822、12823、12825、12828 バッファ
12824 点群化部
12826 動き補償部
12827 8分木化部
12829 制御部
12830 動き補償部
12900、12930 三次元データ符号化装置
12901、12932 グループ化部
12902、12905、12907、12923、12925、12933、12934、12936、12941、12952、12954 バッファ
12903、12942 量子化部
12904、12922、12959 逆量子化部
12906、12924、12935、12953 イントラ予測部
12908、12937 動き検出補償部
12909、12927、12938、12956 インター予測部
12910、12928、12939、12957 切替部
12911、12943 エントロピー符号化部
12920、12950 三次元データ復号装置
12921、12951 エントロピー復号部
12926、12955 動き補償部
12931、12940、12958 座標変換部
13601、13612、13621 予測部
13602、13616、13622 量子化部
13603、13613、13617、13623 符号化部
13611、13614、13644 変換部
13615 減算部
13618、13665 結合部
13631、13642、13645、13651 復号部
13632、13646、13652 逆量子化部
13633、13643、13653 再構成部
13641、13671 分離部
13647 加算部
13661 重複点結合部
13662 位置情報符号化部
13663 属性情報変換部
13664 属性情報符号化部
13672 位置情報復号部
13673 属性情報復号部
13700、13710、13740 位置情報符号化部
13701、13742、13763 シフト部
13702、13711、13743 符号化部
13720、13730、13750、13760 位置情報復号部
13721、13731、13751、13761 復号部
13722、13752 逆シフト部
13741、13753、13764 切替部
13762 座標変換部
A100 属性情報符号化部
A101 LoD属性情報符号化部
A102 変換属性情報符号化部
A110 属性情報復号部
A111 LoD属性情報復号部
A112 変換属性情報復号部
Claims (18)
- 三次元点の位置情報が符号化された符号化位置情報を含むビットストリームを取得し、
前記符号化位置情報を復号することで前記位置情報を生成し、
前記位置情報が直交座標系で表される場合、前記位置情報をシフトし、
前記位置情報が極座標系で表される場合、前記位置情報をシフトしない、
三次元データ復号方法。 - 前記ビットストリームは、
前記位置情報が、前記極座標系で表されるか否かを示す第一フラグ情報と、
前記極座標系で表される前記位置情報が、前記直交座標系で表される変換位置情報に変換されるか否かを示す第二フラグ情報とを含む、
請求項1記載の三次元データ復号方法。 - 前記位置情報が、前記極座標系で表され、前記三次元点を生成するセンサの位置が前記極座標系の原点である場合、前記シフトは実施されない、
請求項1記載の三次元データ復号方法。 - 前記ビットストリームから前記シフトの量を示すシフト情報を取得し、
前記位置情報が前記極座標系で表される場合、前記シフト情報で示される前記量はゼロであり、
前記極座標系で表される前記位置情報を、前記シフト情報で示される前記量に基づき前記位置情報をシフトすることで、前記極座標系で表される位置情報をシフトしない、
請求項1記載の三次元データ復号方法。 - 前記ビットストリームから前記シフトの量を示すシフト情報を取得し、
前記位置情報が前記直交座標系で表される場合、前記シフト情報で示される前記量に基づき前記位置情報をシフトし、
前記位置情報が前記極座標系で表される場合、前記シフト情報で示される前記量に関わらず、前記量がゼロであるとみなす、
請求項1記載の三次元データ復号方法。 - 前記ビットストリームに、前記シフトの量を示すシフト情報が含まれる場合、前記位置情報が前記直交座標系で表されると判定し、前記シフト情報で示される前記量に基づき前記位置情報をシフトし、
前記ビットストリームに前記シフト情報が含まれない場合、前記位置情報が前記極座標系で表されると判定し、前記位置情報をシフトしない、
請求項1記載の三次元データ復号方法。 - 前記ビットストリームは、前記三次元点を含む複数の三次元点の位置情報が符号化された符号化情報を含み、
前記符号化情報は、前記複数の三次元点を分割した複数の分割単位に分けられており、
前記シフト情報は、前記複数の分割単位に共通のパラメータセットに含まれる、
請求項4~6のいずれか1項に記載の三次元データ復号方法。 - 前記ビットストリームは、前記三次元点を含む複数の三次元点の位置情報が符号化された符号化情報を含み、
前記符号化情報は、前記複数の三次元点を分割した複数の分割単位に分けられており、
前記シフト情報は、前記複数の分割単位毎のヘッダに含まれる、
請求項4~6のいずれか1項に記載の三次元データ復号方法。 - 前記位置情報が前記極座標系で表される場合、前記位置情報を前記直交座標系で表される変換後位置情報に変換し、前記変換後位置情報をシフトする、
請求項1~8のいずれか1項に記載の三次元データ復号方法。 - 三次元点の位置情報を符号化することで符号化位置情報を生成し、
前記符号化位置情報と、三次元データ復号装置が復号した復号位置情報を前記三次元データ復号装置がシフトするか否かを示すシフト情報と、を含むビットストリームを生成し、
前記シフト情報に基づき、前記三次元データ復号装置は、
前記復号位置情報が直交座標系で表される場合、前記復号位置情報をシフトし、
前記復号位置情報が極座標系で表される場合、前記復号位置情報をシフトしない、
三次元データ符号化方法。 - 前記ビットストリームは、
前記位置情報が、前記極座標系で表されるか否かを示す第一フラグ情報と、
前記極座標系で表される前記位置情報が、前記直交座標系で表される変換位置情報に変換されるか否かを示す第二フラグ情報とを含む、
請求項10記載の三次元データ符号化方法。 - 前記位置情報が、前記極座標系で表され、前記三次元点を生成するセンサの位置が前記極座標系の原点である場合、前記シフトは実施されない、
請求項10記載の三次元データ符号化方法。 - 前記シフト情報は、前記復号位置情報のシフトの際の当該シフトの量を示し、
前記位置情報が前記極座標系で表される場合、前記シフト情報で示される前記量はゼロであり、
前記三次元データ復号装置は、前記極座標系で表される前記位置情報を、前記シフト情報で示される前記量に基づき前記位置情報をシフトすることで、前記極座標系で表される位置情報をシフトしない、
請求項10記載の三次元データ符号化方法。 - 前記位置情報が前記直交座標系で表される場合、前記シフト情報は、前記復号位置情報のシフトの際の当該シフトの量を示し、
前記位置情報が前記極座標系で表される場合、前記シフト情報を前記ビットストリームに格納しない
請求項10記載の三次元データ符号化方法。 - 前記ビットストリームは、前記三次元点を含む複数の三次元点の位置情報が符号化された符号化情報を含み、
前記符号化情報は、前記複数の三次元点を分割した複数の分割単位に分けられており、
前記シフト情報は、前記複数の分割単位に共通のパラメータセットに含まれる、
請求項10~14のいずれか1項に記載の三次元データ符号化方法。 - 前記ビットストリームは、前記三次元点を含む複数の三次元点の位置情報が符号化された符号化情報を含み、
前記符号化情報は、前記複数の三次元点を分割した複数の分割単位に分けられており、
前記シフト情報は、前記複数の分割単位毎のヘッダに含まれる、
請求項10~14のいずれか1項に記載の三次元データ符号化方法。 - プロセッサと、
メモリと、を備え、
前記プロセッサは、前記メモリを用いて、
三次元点の位置情報が符号化された符号化位置情報を含むビットストリームを取得し、
前記符号化位置情報を復号することで位置情報を生成し、
前記位置情報が直交座標系で表される場合、前記位置情報をシフトし、
前記位置情報が極座標系で表される場合、前記位置情報をシフトしない、
三次元データ復号装置。 - プロセッサと、
メモリと、を備え、
前記プロセッサは、前記メモリを用いて、
三次元点の位置情報位置情報を符号化することで符号化位置情報を生成し、
前記符号化位置情報と、三次元データ復号装置が復号した復号位置情報を前記三次元データ復号装置がシフトするか否かを示すシフト情報と、を含むビットストリームを生成し、
前記シフト情報に基づき、前記三次元データ復号装置は、
前記復号位置情報が直交座標系で表される場合、前記復号位置情報をシフトし、
前記復号位置情報が極座標系で表される場合、前記復号位置情報をシフトしない、
三次元データ符号化装置。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2022574067A JPWO2022149589A1 (ja) | 2021-01-07 | 2022-01-06 |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US202163134665P | 2021-01-07 | 2021-01-07 | |
US63/134,665 | 2021-01-07 |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2022149589A1 true WO2022149589A1 (ja) | 2022-07-14 |
Family
ID=82357969
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/JP2022/000172 WO2022149589A1 (ja) | 2021-01-07 | 2022-01-06 | 三次元データ復号方法、三次元データ符号化方法、三次元データ復号装置、及び三次元データ符号化装置 |
Country Status (2)
Country | Link |
---|---|
JP (1) | JPWO2022149589A1 (ja) |
WO (1) | WO2022149589A1 (ja) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024120324A1 (zh) * | 2022-12-09 | 2024-06-13 | 维沃移动通信有限公司 | 属性变换解码方法、属性变换编码方法及终端 |
Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019012975A1 (ja) * | 2017-07-10 | 2019-01-17 | ソニー株式会社 | 情報処理装置および方法 |
WO2020013249A1 (ja) * | 2018-07-13 | 2020-01-16 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 |
WO2020012968A1 (ja) * | 2018-07-11 | 2020-01-16 | ソニー株式会社 | 画像処理装置および方法 |
WO2020138463A1 (ja) * | 2018-12-28 | 2020-07-02 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 |
-
2022
- 2022-01-06 WO PCT/JP2022/000172 patent/WO2022149589A1/ja active Application Filing
- 2022-01-06 JP JP2022574067A patent/JPWO2022149589A1/ja active Pending
Patent Citations (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2019012975A1 (ja) * | 2017-07-10 | 2019-01-17 | ソニー株式会社 | 情報処理装置および方法 |
WO2020012968A1 (ja) * | 2018-07-11 | 2020-01-16 | ソニー株式会社 | 画像処理装置および方法 |
WO2020013249A1 (ja) * | 2018-07-13 | 2020-01-16 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 |
WO2020138463A1 (ja) * | 2018-12-28 | 2020-07-02 | パナソニック インテレクチュアル プロパティ コーポレーション オブ アメリカ | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024120324A1 (zh) * | 2022-12-09 | 2024-06-13 | 维沃移动通信有限公司 | 属性变换解码方法、属性变换编码方法及终端 |
Also Published As
Publication number | Publication date |
---|---|
JPWO2022149589A1 (ja) | 2022-07-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
WO2021261516A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022075428A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021066163A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021141090A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021256559A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022075326A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021187561A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021141117A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
US20230024374A1 (en) | Three-dimensional data encoding method, three-dimensional data decoding method, three-dimensional data encoding device, and three-dimensional data decoding device | |
WO2021261458A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021193899A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021210549A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022149589A1 (ja) | 三次元データ復号方法、三次元データ符号化方法、三次元データ復号装置、及び三次元データ符号化装置 | |
WO2022080283A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022075234A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
US20230162405A1 (en) | Three-dimensional data encoding method, three-dimensional data decoding method, three-dimensional data encoding device, and three-dimensional data decoding device | |
US20230123146A1 (en) | Three-dimensional data encoding method and three-dimensional data encoding device | |
WO2022163805A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022025280A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2021095879A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022071506A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022071505A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022075319A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022059697A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 | |
WO2022025275A1 (ja) | 三次元データ符号化方法、三次元データ復号方法、三次元データ符号化装置、及び三次元データ復号装置 |
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: 22736757 Country of ref document: EP Kind code of ref document: A1 |
|
ENP | Entry into the national phase |
Ref document number: 2022574067 Country of ref document: JP Kind code of ref document: A |
|
WWE | Wipo information: entry into national phase |
Ref document number: 202347042656 Country of ref document: IN |
|
NENP | Non-entry into the national phase |
Ref country code: DE |
|
122 | Ep: pct application non-entry in european phase |
Ref document number: 22736757 Country of ref document: EP Kind code of ref document: A1 |