Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
ENHANCED EDGE NEIGHBORHOOD FOR CODING VERTEX INFORMATION
Document Type and Number:
WIPO Patent Application WO/2024/086276
Kind Code:
A1
Abstract:
One or more methods, apparatuses, computer-readable storage mediums, and systems for entropy coding vertex information of an edge in a voxelized space of a point cloud are disclosed. Symbols of a neighborhood configuration of a current edge may be determined based on one or more already coded edges. The already coded edges may be selected from a spatial topology of edges or its subset. A lookup table may be used to retrieve an index for a given occupancy configuration for a neighborhood of a current edge. The index may indicate an appropriate context or probability model. Based on the coding of the current edge, the lookup table may be updated.

Inventors:
LASSERRE SÉBASTIEN (US)
Application Number:
PCT/US2023/035507
Publication Date:
April 25, 2024
Filing Date:
October 19, 2023
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
COMCAST CABLE COMM LLC (US)
International Classes:
G06T9/00; H04N19/597; H04N19/91
Foreign References:
EP3553745A12019-10-16
Other References:
LASSERRE (XIAOMI) S: "[GPCC][TriSoup] Part 6 Compression of vertex presence flag and vertex position", no. m59293, 12 April 2022 (2022-04-12), XP030301452, Retrieved from the Internet [retrieved on 20220412]
Attorney, Agent or Firm:
JOO, Jihan (US)
Download PDF:
Claims:
Docket No.: 007412.06305 CLAIMS 1. A method comprising: determining, based on vertex information of a spatial topology of edges, one or more symbols of a neighborhood configuration of a current edge, wherein each edge of the spatial topology of edges is available for coding the current edge independent of a direction of the current edge; determining, based on the one or more symbols of the neighborhood configuration, a probability model; and entropy coding, based on the determined probability model, vertex information of the current edge. 2. The method of claim 1, wherein the determining the one or more symbols of the neighborhood configuration comprises: selecting, based on the direction of the current edge, one of a plurality of different configurations of the spatial topology of edges. 3. The method of claim 2, wherein the plurality of different configurations comprises at least one of: a rotated configuration of the spatial topology of edges, or a mirrored configuration of the spatial topology of edges. 4. The method of any one of claims 1-3, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags associated with the spatial topology of edges. 5. The method of any one of claims 1-4, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex positions associated with the spatial topology of edges. Docket No.: 007412.06305 6. The method of any one of claims 1-5, wherein the vertex information of the current edge comprises at least one of: a vertex presence flag associated with the current edge, or a vertex position associated with the current edge. 7. The method of any one of claims 1-6, wherein the determining the probability model comprises determining the probability model based on a lookup table that maps, to the probability model, at least one of: the neighborhood configuration, or a subset of the one or more symbols of the neighborhood configuration. 8. The method of claim 7, further comprising: increasing a quantity of symbols in the subset, based on a quantity of coded edges, with neighborhood information, comprising the symbols in the subset. 9. The method of any one of claims7-8, further comprising: updating, based on the vertex information of the current edge, the lookup table to map the subset to a different probability model. 10. The method of any one of claims 1-9, wherein the spatial topology of edges comprises at least one of: an edge that does not intersect a start point of the current edge, an edge belonging to a same cuboid as the current edge, an edge parallel to the current edge, and an edge perpendicular to the current edge and intersecting an end point of the current edge. 11. The method of any one of claims 1-10, wherein the neighborhood configuration further comprises: a second set of one or more symbols indicating the direction of the current edge; and a third set of one or more symbols determined based on at least one edge that is not available for coding the current edge independent of the direction of the current edge. Docket No.: 007412.06305 12. The method of any one of claims 1-11, wherein the current edge belongs to a cuboid comprising at least one point of a point cloud. 13. A computing device comprising: one or more processors; and memory storing instructions that, when executed, cause the computing device to perform the method of any one of claims 1–12. 14. A system comprising: a first computing device configured to perform the method of any one of claims 1–12; and a second computing device configured to decode the entropy coded vertex information of the current edge. 15. A computer-readable medium storing instructions that, when executed, cause performance of the method of any one of claims 1–12.
Description:
Docket No.: 007412.06305 Enhanced Edge Neighborhood for Coding Vertex Information CROSS-REFERENCE TO RELATED APPLICATIONS [0001] This application claims the benefit of U.S. Provisional Application No. 63/417,613 filed on October 19, 2022. The above referenced application is hereby incorporated by reference in its entirety. BACKGROUND [0002] An object or scene may be described using volumetric visual data consisting of a series of points. The points may be stored as a point cloud format that includes a collection of points in three-dimensional space. As point clouds can get quite large in data size, transmitting and processing point cloud data may need a data compression scheme that is specifically designed with respect to the unique characteristics of point clod data. SUMMARY [0003] The following summary presents a simplified summary of certain features. The summary is not an extensive overview and is not intended to identify key or critical elements. [0004] Coding (e.g., encoding, decoding) may be used to compress and decompress a point cloud frame or sequence for efficient storage and transmission. A point cloud coding system may comprise a source device that encodes a point cloud sequence into a bitstream. The point cloud coding system may also comprise a transmission medium that transmits the encoded bitstream. The point cloud coding system may further comprise a destination device that obtains a decoded point cloud sequence based on the encoded bitstream and store, display, or otherwise process the decoded point cloud sequences. The encoder may code the point cloud using an occupancy tree by recursively splitting the initial volume of the point cloud into cuboids and sub-cuboids. To entropy code a current cuboid, the encoder may use a spatial neighborhood of cuboids relative to the current cuboid. Occupancy configurations for a neighborhood relative to a current cuboid may be reduced by using a mechanism such as Optimal Binary Coders with Update on the Fly (OBUF). Dynamic OBUF may further reduce the number of occupancy configurations for the neighborhood of the current cuboid by a dynamic adaptation to the statistics of already-processed occupancy configurations. The Docket No.: 007412.06305 dynamic OBUF may reduce the number of occupancy configurations by using a lookup table of context indices. A point cloud geometry may be set such that the maximum depth of the occupancy tree does not reach the smallest volume size of one voxel. A Triangle Soup (TriSoup) scheme may be used, for such point cloud geometries, to represent a vertex with a vertex information made of a presence flag and its position on a TriSoup edge. Vertex information of a TriSoup edge may be entropy coded based on already-coded presence flags and positions of TriSoup edges that neighbor the TriSoup edge that is currently being coded. A topology of edges or a subset of the topology of edges may be selected and used for entropy coding the vertex information of the current TriSoup edge. [0005] These and other features and advantages are described in greater detail below. BRIEF DESCRIPTION OF THE DRAWINGS [0006] Some features are shown by way of example, and not by limitation, in the accompanying drawings. In the drawings, like numerals reference similar elements. [0007] FIG.1 shows an example point cloud coding system. [0008] FIG.2 shows a Morton order of eight sub-cuboids split from a cuboid. [0009] FIG.3 shows an example of a scanning order for an occupancy tree. [0010] FIG. 4 shows an example neighborhood of cuboids for entropy coding the occupancy of a child cuboid. [0011] FIG. 5 shows an example of a dynamic reduction function (DR) that may be used in dynamic OBUF. [0012] FIG.6 shows an example method for coding occupancy of a cuboid using dynamic OBUF. [0013] FIG.7 shows an example of an occupied cuboid that corresponds to a TriSoup node of an occupancy tree. [0014] FIG. 8A shows an example cuboid corresponding to a TriSoup node. [0015] FIG. 8B shows an example refinement to a TriSoup model. [0016] FIG. 9 shows an example of voxelization. Docket No.: 007412.06305 [0017] FIG.10A and FIG.10B show cuboids with volumes that intersect a current TriSoup edge being entropy coded. [0018] FIG.11A, FIG.11B, and FIG.11C show TriSoup edges that may be used to entropy code a current TriSoup edge. [0019] FIG.12A, FIG.12B, and FIG.12C show already-coded TriSoup edges that neighbor and do not intersect a start point of a current TriSoup edge. [0020] FIG.13A, FIG.13B, and FIG.13C show already-coded TriSoup edges that neighbor and do not intersect a start point of a current TriSoup edge. [0021] FIG. 14A, FIG. 14B, and FIG. 14C show neighboring already coded edges of a current TriSoup edge. [0022] FIG.15A, FIG.15B, and FIG.15C show an example of a sub-spatial topology of TriSoup edges. [0023] FIG.16A, FIG.16B, and FIG.16C show neighboring already coded edges. [0024] FIG.17A, FIG.17B, and FIG.17C show an example of a sub-spatial topology of TriSoup edges. [0025] FIG. 18A, FIG. 18B, and FIG. 18C show a spatial topology comprising TriSoup edges and TriSoup nodes. [0026] FIG.19 shows an example method for coding vertex information of a current edge. [0027] FIG.20 shows an example method for coding vertex information of a current edge. [0028] FIG. 21 shows an example computer system in which examples of the present disclosure may be implemented. [0029] FIG. 22 shows example elements of a computing device that may be used to implement any of the various devices described herein. DETAILED DESCRIPTION [0030] The accompanying drawings and descriptions provide examples. It is to be understood that the examples shown in the drawings and/or described are non-exclusive, and that features Docket No.: 007412.06305 shown and described may be practiced in other examples. Examples are provided for operation of point cloud or point cloud sequence encoding or decoding systems. More particularly, the technology disclosed herein may relate to point cloud compression as used in encoding and/or decoding devices and/or systems. [0031] Visual data may describe an object or scene using a series of points. Each point may comprise a position in two dimensions (x and y) and one or more optional attributes like color. Volumetric visual data may add another positional dimension to this visual data. Volumetric visual data may describe an object or scene using a series of points that each comprise a position in three dimensions (x, y, and z) and one or more optional attributes like color, reflectance, time stamp, etc. Volumetric visual data may provide a more immersive way to experience visual data, for example, than traditional visual data. [0032] For example, an object or scene described by volumetric visual data may be viewed from any (or multiple) angles, whereas traditional visual data may generally only be viewed from the angle in which it was captured or rendered. Volumetric visual data may be used in many applications, including augmented reality (AR), virtual reality (VR), and mixed reality (MR). Sparse volumetric visual data may be used in the automotive industry for the representation of three-dimensional (3D) maps (e.g., cartography) or as input to assisted driving systems. In the case of assisted driving systems, volumetric visual data may be typically input to driving decision algorithms. Volumetric visual data may be used to store valuable objects in digital form. In applications for preserving cultural heritage, the goal may be to keep a representation of objects that may be threatened by natural disasters. For example, statues, vases, and temples may be entirely scanned and stored as volumetric visual data having several billions of samples. This use-case for volumetric visual data may be particularly relevant for valuable objects in locations where earthquakes, tsunamis, and typhoons are frequent. Volumetric visual data may take the form of a volumetric frame. The volumetric frame may describe an object or scene captured at a particular time instance. Volumetric visual data may take the form of a sequence of volumetric frames (referred to as a volumetric sequence or volumetric video). The sequence of volumetric frames may describe an object or scene captured at multiple different time instances. [0033] Point clouds are one format for storing volumetric visual data. A point cloud may comprise a collection of points in 3D space. Each point in a point cloud may comprise geometry information that indicates the point’s position in 3D space. The geometry Docket No.: 007412.06305 information may indicate the point’s position in 3D space, for example, using three Cartesian coordinates (x, y, and z) or using spherical coordinates (r, phi, theta) (e.g., if acquired by a rotating sensor). The positions of points in a point cloud may be quantized according to a space precision. The space precision may be the same or different in each dimension. The quantization process may create a grid in 3D space. One or more points residing within each sub-grid volume may be mapped to the sub-grid center coordinates, referred to as voxels. A voxel may be considered as a 3D extension of pixels corresponding to the 2D image grid coordinates. A point in a point cloud may further comprise one or more types of attribute information. Attribute information may indicate a property of a point’s visual appearance. Attribute information may indicate, for example, a texture (e.g., color) of the point, a material type of the point, transparency information of the point, reflectance information of the point, a normal vector to a surface of the point, a velocity at the point, an acceleration at the point, a time stamp indicating when the point was captured, or a modality indicating how the point was captured (e.g., running, walking, or flying). A point in a point cloud may comprise light field data in the form of multiple view-dependent texture information. Light field data may be another type of optional attribute information. [0034] The points in a point cloud may describe an object or a scene. The points in a point cloud may describe, for example, the external surface and/or the internal structure of an object or scene. The object or scene may be synthetically generated by a computer. The object or scene may be generated from the capture of a real-world object or scene. The geometry information of a real-world object or a scene may be obtained by 3D scanning and/or photogrammetry. 3D scanning may include different types of scanning, for example, laser scanning, structured light scanning, and/or modulated light scanning. 3D scanning may obtain geometry information. 3D scanning may obtain geometry information, for example, by moving one or more laser heads, structured light cameras, and/or modulated light cameras relative to an object or scene being scanned. Photogrammetry may obtain geometry information. Photogrammetry may obtain geometry information, for example, by triangulating the same feature or point in different spatially shifted 2D photographs. Point cloud data may take the form of a point cloud frame. The point cloud frame may describe an object or scene captured at a particular time instance. Point cloud data may take the form of a sequence of point cloud frames. The sequence of point cloud frames may be referred to as a point cloud sequence or point cloud video. The sequence of point cloud frames may describe an object or scene captured at multiple different time instances. Docket No.: 007412.06305 [0035] The data size of a point cloud frame or point cloud sequence may be too large for storage and/or transmission in many applications. A single point cloud may comprise, for example, over a million points or even a billions of points. Each point may comprise geometry information and one or more optional types of attribute information. The geometry information of each point may comprise three Cartesian coordinates (x, y, and z) or spherical coordinates (r, phi, theta) that are each represented, for example, using at least 10 bits per component or 30 bits in total. The attribute information of each point may comprise a texture corresponding to three color components (e.g., R, G, and B color components). Each color component may be represented, for example, using 8-10 bits per component or 24-30 bits in total. A single point therefore may comprise at least 54 bits of information in this example, with at least 30 bits of geometry information and at least 24 bits of texture. If a point cloud frame includes a million such points, each point cloud frame may require 54 million bits or 54 megabits to represent. For dynamic point clouds that change over time, at a frame rate of 30 frames per second, a data rate of 1.32 gigabits per second may be required to send (e.g., transmit) the points of the point cloud sequence. Therefore, raw representations of point clouds may require a large amount of data and the practical deployment of point-cloud-based technologies may need compression technologies that enable the storage and distribution of point clouds with reasonable cost. [0036] Encoding may be used to compress and/or reduce the data size of a point cloud frame or point cloud sequence to provide for more efficient storage and/or transmission. Decoding may be used to decompress a compressed point cloud frame or point cloud sequence for display and/or other forms of consumption (e.g., by a machine learning based device, neural network- based device, artificial intelligence-based device, or other forms of consumption by other types of machine-based processing algorithms and/or devices). Compression of point clouds may be lossy (introducing differences relative to the original data) for the distribution to and visualization by an end-user, for example, on AR or VR glasses or any other 3D-capable device. Lossy compression may allow for a high ratio of compression but may imply a trade- off between compression and visual quality perceived by an end-user. Other frameworks, for example, frameworks for medical applications or autonomous driving, may require lossless compression to avoid altering the results of a decision obtained based on the analysis of the sent (e.g., transmitted) and decompressed point cloud frame. Docket No.: 007412.06305 [0037] FIG.1 shows an example point cloud coding (e.g., encoding and/or decoding) system 100. Point cloud coding system 100 may comprise a source device 102, a transmission medium 104, and a destination device 106. Source device 102 may encode a point cloud sequence 108 into a bitstream 110 for more efficient storage and/or transmission. Source device 102 may store and/or send (e.g., transmit) bitstream 110 to destination device 106 via transmission medium 104. Destination device 106 may decode bitstream 110 to display point cloud sequence 108 or for other forms of consumption (e.g., further analysis, storage, etc.). Destination device 106 may receive bitstream 110 from source device 102 via a storage medium or transmission medium 104. Source device 102 and destination device 106 may include any number of different devices. Source device 102 and destination device 106 may include, for example, cluster of interconnected computer systems acting as a pool of seamless resources (also referred to as a cloud of computers or cloud computer), a server, a desktop computer, a laptop computer, a tablet computer, a smart phone, a wearable device, a television, a camera, a video gaming console, a set-top box, a video streaming device, a vehicle (e.g., an autonomous vehicle), or a head-mounted display. A head-mounted display may allow a user to view a VR, AR, or MR scene and adjust the view of the scene based on movement of the user’s head. A head-mounted display may be tethered to a processing device (e.g., a server, a desktop computer, a set-top box, or a video gaming counsel) or may be fully self-contained. [0038] Source device 102 may comprise a point cloud source 112, an encoder 114, and an output interface 116. To encode point cloud sequence 108 into bitstream 110, source device 102 may comprise a point cloud source 112, an encoder 114, and an output interface 116. Point cloud source 112 may provide or generate point cloud sequence 108 from a capture of a natural scene and/or a synthetically generated scene. A synthetically generated scene may be a scene comprising computer generated graphics. Point cloud source 112 may comprise one or more point cloud capture devices , a point cloud archive comprising previously captured natural scenes and/or synthetically generated scenes, a point cloud feed interface to receive captured natural scenes and/or synthetically generated scenes from a point cloud content provider, and/or a processor(s) to generate synthetic point cloud scenes. The point cloud capture devices may include, for example, one or more laser scanning devices, structured light scanning devices, modulated light scanning devices, and/or passive scanning devices. Docket No.: 007412.06305 [0039] As shown in FIG. 1, a point cloud sequence 108 may comprise a series of point cloud frames 124. A point cloud frame may describe an object or scene captured at a particular time instance. Point cloud sequence 108 may achieve the impression of motion by using a constant or variable time to successively present point cloud frames 124 of point cloud sequence 108. A point cloud frame may comprise a collection of points (e.g., voxels) 126 in 3D space. Each point 126 may comprise geometry information that indicates the point’s position in 3D space. The geometry information may indicate, for example, the point’s position in 3D space using three Cartesian coordinates (x, y, and z). One or more of points 126 may further comprise one or more types of attribute information. Attribute information may indicate a property of a point’s visual appearance. Attribute information may indicate, for example, a texture (e.g., color) of a point, a material type of a point, transparency information of a point, reflectance information of a point, a normal vector to a surface of a point, a velocity at a point, an acceleration at a point, a time stamp indicating when a point was captured, a modality indicating how a point was captured (e.g., running, walking, or flying). One or more of points 126 may comprise, for example, light field data in the form of multiple view-dependent texture information. Light field data may be another type of optional attribute information. Color attribute information of one or more of points 126 may comprise a luminance value and two chrominance values. The luminance value may represent the brightness (e.g., luma component, Y) of the point. The chrominance values may respectively represent the blue and red components of the point (e.g., chroma components, Cb and Cr) separate from the brightness. Other color attribute values may be represented based on different color schemes (e.g., an RGB or monochrome color scheme). [0040] Encoder 114 may encode point cloud sequence 108 into bitstream 110. To encode point cloud sequence 108, encoder 114 may use one or more lossless or lossy compression techniques to reduce redundant information in point cloud sequence 108. To encode point cloud sequence 108, encoder 114 may use one or more prediction techniques to reduce redundant information in point cloud sequence 108. Redundant information is information that may be predicted at a decoder 120 and therefore may not be needed to be sent (e.g., transmitted) to decoder 120 for accurate decoding of point cloud sequence 108. For example, Motion Picture Expert Group (MPEG) introduced a geometry-based point cloud compression (G-PCC) standard (ISO/IEC standard 23090-9: Geometry-based point cloud compression). G-PCC specifies the encoded bitstream syntax and semantics for transmission and/or storage of a compressed point cloud frame and the decoder operation for reconstructing the Docket No.: 007412.06305 compressed point cloud frame from the bitstream. During standardization of G-PCC, a reference software (ISO/IEC standard 23090-21: Reference Software for G-PCC) was developed to encode the geometry and attribute information of a point cloud frame. To encode geometry information of a point cloud frame, the G-PCC reference software encoder may perform voxelization. The G-PCC reference software encoder may perform voxelization, for example, by quantizing positions of points in a point cloud. Quantizing positions of points in a point cloud may create a grid in 3D space. The G-PCC reference software encoder may map the points to the center coordinates of the sub-grid volume (e.g., voxel) that their quantized locations reside in. The G-PCC reference software encoder may perform geometry analysis using an occupancy tree to compress the geometry information. The G-PCC reference software encoder may entropy encode the result of the geometry analysis to further compress the geometry information. To encode attribute information of a point cloud, the G-PCC reference software encoder may use a transform tool, such as Region Adaptive Hierarchical Transform (RAHT), the Predicting Transform, and/or the Lifting Transform. The Lifting Transform may be built on top of the Predicting Transform. The Lifting Transform may include an extra update/lifting step. The Lifting Transform and the Predicting Transform may be referred to as Predicting/Lifting Transform or pred lift. Encoder 114 may operate in a same or similar manner to an encoder provided by the G-PCC reference software. [0041] Output interface 116 may be configured to write and/or store bitstream 110 onto transmission medium 104. The bitstream 110 may be sent (e.g., transmitted) to destination device 106. In addition or alternatively, output interface 116 may be configured to send (e.g., transmit), upload, and/or stream bitstream 110 to destination device 106 via transmission medium 104. Output interface 116 may comprise a wired and/or wireless transmitter configured to send (e.g., transmit), upload, and/or stream bitstream 110 according to one or more proprietary and/or standardized communication protocols. The one or more proprietary and/or standardized communication protocols may include, for example, Digital Video Broadcasting (DVB) standards, Advanced Television Systems Committee (ATSC) standards, Integrated Services Digital Broadcasting (ISDB) standards, Data Over Cable Service Interface Specification (DOCSIS) standards, 3rd Generation Partnership Project (3GPP) standards, Institute of Electrical and Electronics Engineers (IEEE) standards, Internet Protocol (IP) standards, and Wireless Application Protocol (WAP) standards. Docket No.: 007412.06305 [0042] Transmission medium 104 may comprise a wireless, wired, and/or computer readable medium. Transmission medium 104 may comprise, for example, one or more wires, cables, air interfaces, optical discs, flash memory, and/or magnetic memory. In addition, or alternatively, transmission medium 104 may comprise one or more networks (e.g., the Internet) or file server(s) configured to store and/or send (e.g., transmit) encoded video data (e.g., bitstream 110). [0043] Destination device 106 may comprise an input interface 118, a decoder 120, and a point cloud display 122. To decode bitstream 110 into point cloud sequence 108 for display or other forms of consumption, destination device 106 may comprise an input interface 118, a decoder 120, and a point cloud display 122. Input interface 118 may be configured to read bitstream 110 stored on transmission medium 104. Bitstream 110 may be stored on transmission medium 104 by source device 102. In addition or alternatively, input interface 118 may be configured to receive, download, and/or stream bitstream 110 from source device 102 via transmission medium 104. Input interface 118 may comprise a wired and/or wireless receiver configured to receive, download, and/or stream bitstream 110 according to one or more proprietary and/or standardized communication protocols, such as Digital Video Broadcasting (DVB) standards, Advanced Television Systems Committee (ATSC) standards, Integrated Services Digital Broadcasting (ISDB) standards, Data Over Cable Service Interface Specification (DOCSIS) standards, 3rd Generation Partnership Project (3GPP) standards, Institute of Electrical and Electronics Engineers (IEEE) standards, Internet Protocol (IP) standards, and Wireless Application Protocol (WAP) standards. [0044] Decoder 120 may decode point cloud sequence 108 from encoded bitstream 110. Decoder 120 may operate, for example, in a same or similar manner as a decoder provided by G-PCC reference software . Decoder 120 may decode a point cloud sequence that approximates point cloud sequence 108. Decoder 120 may decode a point cloud sequence that approximates point cloud sequence 108 due to, for example, lossy compression of point cloud sequence 108 by encoder 114 and/or errors introduced into encoded bitstream 110, for example, if transmission to destination device 106 occurs. [0045] Point cloud display 122 may display point cloud sequence 108 to a user. Point cloud display 122 may comprise, for example, a cathode rate tube (CRT) display, a liquid crystal display (LCD), a plasma display, a light emitting diode (LED) display, a 3D display, a Docket No.: 007412.06305 holographic display, a head-mounted display, or any other display device suitable for displaying point cloud sequence 108. [0046] Point cloud coding/decoding system 100 is presented by way of example and not limitation. In the example of FIG.1, point cloud coding/decoding system 100 may have other components and/or arrangements. Point cloud source 112 may, for example, be external to source device 102. Point cloud display device 122 may, for example, be external to destination device 106 or omitted altogether where point cloud sequence is intended for consumption by a machine and/or storage device. Source device 102 may further comprise, for example, a point cloud decoder. Destination device 104 may comprise, for example, a point cloud encoder. Source device 102 may be configured to further receive an encoded bit stream from destination device 106. Receiving an encoded bit stream from destination device 106 may support two-way point cloud transmission between the devices. [0047] As described herein, an encoder may quantize the positions of points in a point cloud according to a space precision, which may be the same or different in each dimension of the points. The quantization process may create a grid in 3D space. The encoder may map any points residing within each sub-grid volume to the sub-grid center coordinates, referred to as a voxel. A voxel may be considered as a 3D extension of pixels corresponding to 2D image grid coordinates. [0048] The encoder may represent or code the voxelized point cloud. The encoder may represent or code the voxelized point cloud, for example, using an occupancy tree. The encoder may split the initial volume or cuboid containing the voxelized point cloud into sub-cuboids. The initial volume or cuboid may be referred to as a bounding box. A cuboid may be, for example, a cube. The encoder may recursively split each sub-cuboid that contains at least one point of the point cloud. The encoder may not further split sub-cuboids that do not contain at least one point of the point cloud. A sub-cuboid that contains at least one point of the point cloud may be referred to as an occupied sub-cuboid. A sub-cuboid that does not contain at least one point of the point cloud may be referred to as an unoccupied sub-cuboid. The encoder may split an occupied cuboid into, for example, two sub-cuboids (to form a binary tree), four sub-cuboids (to form a quadtree), or eight sub-cuboids (to form an octree). The encoder may split an occupied cuboid to obtain sub-cuboids. The sub-cuboids may have the same size and shape at a given depth level of the occupancy tree. The sub-cuboids may have the same size and shape Docket No.: 007412.06305 at a given depth level of the occupancy tree, for example, if the encoder splits the occupied cuboid along a plane passing through the middle of edges of the cuboid. [0049] The initial volume or cuboid containing the voxelized point cloud may correspond to the root node of the occupancy tree. Each occupied sub-cuboid, split from the initial volume, may correspond to a node (of the root node) in a second level of the occupancy tree. Each occupied sub-cuboid, split from an occupied sub-cuboid in the second level, may correspond to a node (off the occupied sub-cuboid in the second level from which it was split) in a third level of the occupancy tree. The occupancy tree structure may continue to form in this manner for each recursive split iteration until, for example, some maximum depth level of the occupancy tree is reached or each occupied sub-cuboid has a volume corresponding to one voxel. [0050] Each non-leaf node of the occupancy tree may comprise or be associated with an occupancy word representing the occupancy state of the cuboid corresponding to the node. A node of the occupancy tree corresponding to a cuboid that is split into 8 sub-cuboids may comprise or be associated with a 1-byte occupancy word. Each bit (referred to as an occupancy bit) of the 1-byte occupancy word may represent or indicate the occupancy of a different one of the eight sub-cuboids. Occupied sub-cuboids may be each represented or indicated by a binary “1” in the 1-byte occupancy word. Unoccupied sub-cuboids may be each represented or indicated by a binary “0” in the 1-byte occupancy word. Occupied and un-occupied sub- cuboids may be represented or indicated by opposite 1-bit binary values (e.g., a binary “0” representing or indicating an occupied sub-cuboid and a binary “1” representing or indicating an unoccupied sub-cuboid) in the 1-byte occupancy word. [0051] Each bit of an occupancy word may represent or indicate the occupancy of a different one of the eight sub-cuboids. Each bit of an occupancy word may represent or indicate the occupancy of a different one of the eight sub-cuboids, for example, following the so-called Morton order. The least significant bit of an occupancy word may represent or indicate, for example, the occupancy of a first one of the eight sub-cuboids following the Morton order. The second least significant bit of an occupancy word may represent or indicate, for example, the occupancy of a second one of the eight sub-cuboids following the Morton order, etc. [0052] FIG. 2 shows the Morton order of eight sub-cuboids 202-216 split from a cuboid 200. Sub-cuboids 202-216 are labeled based on their Morton order, with child node 202 being the Docket No.: 007412.06305 first in Morton order and child node 216 being the last in Morton order. The Morton order for sub-cuboids 202-216 is a local lexicographic order in xyz. [0053] The geometry of the voxelized point cloud is represented by, and may be determined from, the initial volume and the occupancy words of the nodes in the occupancy tree. The encoder may send (e.g., transmit) the initial volume and the occupancy words of the nodes in the occupancy tree in a bitstream to a decoder for reconstructing the point cloud. The encoder may entropy encode the occupancy words. The encoder may entropy encode the occupancy words, for example, before sending the initial volume and the occupancy words of the nodes in the occupancy tree. The encoder may encode an occupancy bit of an occupancy word of a node corresponding to a cuboid. The encoder may encode an occupancy bit of an occupancy word of a node corresponding to a cuboid, for example, based on one or more occupancy bits of occupancy words of other nodes corresponding to cuboids that are adjacent or spatially close to the cuboid of the occupancy bit being encoded. [0054] An encoder and/or decoder may code occupancy bits of occupancy words in sequence of a scan order. The scan order may also be referred to as a scanning order. An encoder and/or decoder may scan an occupancy tree in breadth-first order. All the occupancy words of the nodes of a given depth (e.g., level) within the occupancy tree may be scanned. All the occupancy words of the nodes of a given depth (e.g., level) within the occupancy tree may be scanned, for example, before scanning the occupancy words of the nodes of the next depth (e.g., level). Within a given depth, the encoder and/or decoder may scan the occupancy words of nodes in the Morton order. Within a given node, the encoder and/or decoder may scan the occupancy bits of the occupancy word of the node further in the Morton order. [0055] FIG.3 shows an example of a scanning order (e.g., breadth-first order as described herein) for an occupancy tree 300. FIG.3 shows a scanning order for the first three example levels of occupancy tree 300. In FIG.3, a cuboid 302 corresponding to the root node of occupancy tree 300 may be divided into eight sub-cuboids. Two sub-cuboids 304 and 306 of the eight sub- cuboids may be occupied. The other six sub-cuboids of the eight sub-cuboids may be unoccupied. Following the Morton order, a first eight-bit occupancy word occW 1,1 is constructed to represent the occupancy word of the root node. The least significant occupancy bit of the first eight-bit occupancy word occW1,1 represents or indicates the occupancy of the first sub-cuboid of the eight sub-cuboids in Morton order. The second least significant Docket No.: 007412.06305 occupancy bit of the first eight-bit occupancy word occW1,1 represents or indicates the occupancy of the second sub-cuboid of the eight sub-cuboids in Morton order, etc. [0056] Each of the two occupied sub-cuboids 304 and 306 corresponds to a node off the root node in a second level of occupancy tree 300. The two occupied sub-cuboids 304 and 306 are each further split into eight sub-cuboids. One of the sub-cuboids 308 of the eight sub-cuboids split from sub-cuboid 304 may be occupied. The other seven sub-cuboids of the eight sub-cuboids split from sub-cuboid 304 may be unoccupied. Three of the sub-cuboids 310, 312, and 314 of the eight sub-cuboids split from sub-cuboid 306 may be occupied. The other five sub-cuboids of the eight sub-cuboids split from sub-cuboid 306 may be unoccupied. Two second eight-bit occupancy words occW 2,1 and occW 2,2 are constructed in this order to respectively represent the occupancy word of the node corresponding to sub-cuboid 304 and the occupancy word of the node corresponding to sub-cuboid 306. [0057] Each of the four occupied sub-cuboids 308, 310, 312, and 314 corresponds to a node in a third level of occupancy tree 300. The four occupied sub-cuboids 308, 310, 312, and 314 are each further split into eight sub-cuboids or 32 sub-cuboids in total. Four third level eight-bit occupancy words occW 3,1 , occW 3,2 , occW 3,3 and occW 3,4 are constructed in this order to respectively represent the occupancy word of the node corresponding to sub-cuboid 308, the occupancy word of the node corresponding to sub-cuboid 310, the occupancy word of the node corresponding to sub-cuboid 312, and the occupancy word of the node corresponding to sub-cuboid 314. [0058] The occupancy words of occupancy tree 300 may be entropy coded (e.g., entropy encoded by an encoder and entropy decoded by a decoder) as the succession of the seven occupancy words occW1,1 to occW3,4, for example, following the scanning order (e.g., breadth-first order) as described herein. As a consequence of the breadth-first scanning order, the occupancy word(s) of all node(s) having the same depth (e.g., level) as a current parent node may have already been entropy coded, for example, if the occupancy word of a current child node belonging to the current parent node is being entropy coded. The occupancy word(s) of all node(s) having the same depth (e.g., level) as the current child node and having a lower Morton order than the current child node may have also already been entropy coded, for example, if the occupancy word for the current child node is being entropy coded. Part of the already coded occupancy word(s) may be used to entropy code the occupancy word of the current child node. The already coded occupancy word(s) of neighboring parent and/or child Docket No.: 007412.06305 node(s) may be used, for example, to entropy code the occupancy word of the current child node. The occupancy bit(s) of the occupancy word having a lower Morton order than a particular occupancy bit of the occupancy word of the current child node may have also already been entropy coded. The occupancy bit(s) of the occupancy word having a lower Morton order than a particular occupancy bit may be used to code the occupancy bit of the occupancy word of the current child node, for example, if the particular occupancy bit is being coded. [0059] FIG. 4 shows an example neighborhood of cuboids for entropy coding the occupancy of a child cuboid. A neighborhood of cuboids with already-coded occupancy bits may be used to entropy code the occupancy bit of a current child cuboid 400. The neighborhood of cuboids with already-coded occupancy bits may be determined. The neighborhood of cuboids with already-coded occupancy bits may be determined, for example, based on the scanning order of an occupancy tree representing the geometry of the cuboids in FIG.4 as described herein. The neighborhood of cuboids, of a current child cuboid, may include one or more of: a cuboid adjacent to the current child cuboid, a cuboid sharing a vertex with the current child cuboid, a cuboid sharing an edge with the current child cuboid, a cuboid sharing a face with the current child cuboid, a parent cuboid adjacent to the current child cuboid, a parent cuboid sharing a vertex with the current child cuboid, a parent cuboid sharing an edge with the current child cuboid, a parent cuboid sharing a face with the current child cuboid, a parent cuboid adjacent to the current parent cuboid, a parent cuboid sharing a vertex with the current parent cuboid, a parent cuboid sharing an edge with the current parent cuboid, a parent cuboid sharing a face with the current parent cuboid, etc. As shown in FIG.4, current child cuboid 400 may belong to a current parent cuboid 402. Following the scanning order of the occupancy words and occupancy bits of nodes of the occupancy tree, the occupancy bits of four child cuboids 404, 406, 408, and 410, belonging to the same current parent cuboid 402, have already been coded. The occupancy bits of child cuboids 412 of preceding parent cuboids have already been coded. The occupancy bits of parent cuboids 414, for which the occupancy bits of child cuboids have not already been coded, have already been coded. Therefore, the already-coded occupancy bits of cuboids 404, 406, 408, 410, 412, and 414 may be used to code the occupancy bit of the current child cuboid 400. [0060] The number (e.g., quantity) of possible occupancy configurations (e.g., sets of one or more occupancy words and/or occupancy bits) for a neighborhood of a current child cuboid may be Docket No.: 007412.06305 2 N , where N is the number (e.g., quantity) of cuboids in the neighborhood of the current child cuboid with already-coded occupancy bits. The neighborhood of the current child cuboid may comprise several dozens of cuboids. The neighborhood of the current child cuboid may comprise the 26 adjacent parent cuboids sharing a face, an, edge, and/or a vertex with the parent cuboid of the current child cuboid and also several adjacent child cuboids sharing a face, an edge, and/or a vertex with the current child cuboid. The occupancy configuration for a neighborhood of the current child cuboid may have billions of possible occupancy configurations, even limited to a subset of the adjacent cuboids, making its direct use impractical. An encoder and/or decoder may use the occupancy configuration for a neighborhood of the current child cuboid to select the context (e.g., a probability model), among a set of contexts, of a binary entropy coder (e.g., binary arithmetic coder) that codes the occupancy bit of the current child cuboid. The context-based binary entropy coding may be similar to the Context Adaptive Binary Arithmetic Coder (CABAC) used in MPEG-H Part 2 (also known as High Efficiency Video Coding (HEVC)). [0061] An encoder and/or decoder may use several methods to reduce the occupancy configurations for a neighborhood of a current child cuboid being coded to a practical number (e.g., quantity) of reduced occupancy configurations. The 2 6 or 64 occupancy configurations of the six adjacent parent cuboids sharing a face with the parent cuboid of the current child cuboid may be reduced to nine occupancy configurations. The occupancy configurations may be reduced by using geometry invariance. An occupancy score for the current child cuboid may be obtained from the 2 26 occupancy configurations of the 26 adjacent parent cuboids. The score may be further reduced into a ternary occupancy prediction (e.g., “predicted occupied,” “unsure,” or “predicted unoccupied”) by using score thresholds. The number (e.g., quantity) of occupied adjacent child cuboids and the number (e.g., quantity) of unoccupied adjacent child cuboids may be used instead of the individual occupancies of these child cuboids. [0062] An encoder and/or decoder may reduce the number (e.g., quantity) of possible occupancy configurations for a neighborhood of a current child cuboid to a more manageable number (e.g., a few thousands). It has been observed that instead of associating a reduced number (e.g., quantity) of contexts (e.g., probability models) directly to the reduced occupancy configurations, another mechanism may be used, namely Optimal Binary Coders with Update Docket No.: 007412.06305 on the Fly (OBUF). An encoder and/or decoder may implement OBUF to limit the number (e.g., quantity) of contexts to a lower number (e.g., 32 contexts). [0063] OBUF may use a limited number (e.g., 32) of contexts (e.g., probability models). The number (e.g., quantity) of contexts in OBUF may be a fixed number (e.g., fixed quantity). The contexts used by OBUF may be ordered, referred to by a context index (e.g., a context index in the range of 0 to 31), and associated from a lowest virtual probability to a highest virtual probability to code a “1.” A Look-Up Table (LUT) of context indices may be initialized at the beginning of a point cloud coding process. The LUT may initially point to a context with the median virtual probability to code a “1” for all input. The LUT may initially point to a context with the median virtual probability to code a “1,” among the limited number (e.g., quantity) of contexts, for all input. This LUT may take an occupancy configuration for a neighborhood of current child cuboid as input and output the context index associated with the occupancy configuration. The LUT may have as many entries as reduced occupancy configurations (e.g., around a few thousand entries). The coding of the occupancy bit of a current child cuboid may comprise the steps of determining the reduced occupancy configuration of the current child node, obtaining a context index by using the reduced occupancy configuration as an entry to the LUT, coding the occupancy bit of the current child cuboid by using the context pointed to (e.g., indicated) by the context index, and updating the LUT entry corresponding to the reduced occupancy configuration. The LUT entry may be updated, for example, based on the value of the coded occupancy bit of the current child cuboid. For a binary “0” (e.g., indicating the current child cuboid is unoccupied) being coded, the LUT entry may be decreased to a lower context index value (e.g., associated with a lower virtual probability). For a binary “1” (e.g., indicating the current child cuboid is occupied) being coded, the LUT entry may be increased to a higher context index value (e.g., associated with a higher virtual probability). The update process of the context index may be based on a theoretical model of optimal distribution for virtual probabilities associated with the limited number (e.g., quantity) of contexts. This virtual probability may be fixed by a model. This virtual probability may be different from the internal probability of the context that evolves during the coding of bits of data. The evolution of the internal context may follow a well- known process similar to the process in CABAC. [0064] An encoder and/or decoder may implement a “dynamic OBUF” scheme. The “dynamic OBUF” scheme may handle a much larger number (e.g., quantity) of occupancy Docket No.: 007412.06305 configurations for a neighborhood of a current child cuboid than general OBUF. The use of a larger number (e.g., quantity) of occupancy configurations for a neighborhood of a current child cuboid may lead to improved compression capabilities. The use of a larger number (e.g., quantity) of occupancy configurations for a neighborhood of a current child cuboid may also maintain complexity within reasonable bounds. By using an occupancy tree compressed by OBUF, an encoder and/or decoder may reach a lossless compression performance as good as 1 bit per point (bpp) for coding the geometry of dense point clouds. An encoder and/or decoder may implement dynamic OBUF to potentially further reduce the bit rate by more than 25% to 0.7 bpp. [0065] OBUF may not take as input a large variety of reduced occupancy configurations for a neighborhood of a current child cuboid. This may potentially lead to a loss of useful correlation. With OBUF, the size of the LUT of context indices may be increased to handle more various occupancy configurations for a neighborhood of a current child cuboid as input. By doing so, statistics may be diluted, and compression performance may be worsened. For example, if the LUT has millions of entries and the point cloud has a hundred thousand points, then most of the entries are never visited (e.g., looked up, accessed, etc.). In some instances, many entries may be visited only a few times and their associated context index may not be updated enough times to reflect any meaningful correlation between the occupancy configuration value and the probability of occupancy of the current child cuboid. Dynamic OBUF may be implemented to mitigate the dilution of statistics due to the increase of the number (e.g., quantity) of occupancy configurations for a neighborhood of a current child cuboid. This mitigation is performed by a “dynamic reduction” of occupancy configurations in dynamic OBUF. [0066] Dynamic OBUF may add an extra step of reduction of occupancy configurations for a neighborhood of a current child cuboid. Dynamic OBUF may add an extra step of reduction of occupancy configurations for a neighborhood of a current child cuboid, for example, before using the LUT of context indices. This step may be called a dynamic reduction because it evolves based on the progress of the coding of the point cloud or, more precisely, based on already visited (e.g., looked up in the LUT) occupancy configurations. [0067] As described herein, many possible occupancy configurations for a neighborhood of a current child cuboid are potentially involved but only a subset may be visited, for example, if the coding of a point cloud occurs. This subset of visited occupancy configurations may Docket No.: 007412.06305 characterize the type of the point cloud. For example, most of the visited occupancy configurations may exhibit occupied adjacent cuboids of a current child cuboid, for example, if AR or VR dense point clouds are being coded. On the other hand, most of the visited occupancy configurations may exhibit only a few occupied adjacent cuboids of a current child cuboid, for example, if sensor-acquired sparse point clouds are being coded. The role of the dynamic reduction may be to obtain a more precise correlation based on the most visited occupancy configuration, for example, by putting aside (e.g., reducing aggressively) other occupancy configurations that are much less visited. The dynamic reduction may be updated on-the-fly. The dynamic reduction may be updated on-the-fly. The dynamic reduction may be updated on-the-fly, for example, after each visit (e.g., a lookup in the LUT) of an occupancy configuration. A visit (e.g., a lookup in the LUT) of an occupancy configuration may occur, for example, if the coding of occupancy data occurs. [0068] FIG. 5 shows an example of a dynamic reduction function (DR) that may be used in dynamic OBUF. The dynamic reduction function (DR) may be obtained by masking bits β j of occupancy configurations 500, β = β 1 … β K , made of K bits. The size of the mask may decrease, for example, if occupancy configurations are visited (e.g., looked up in the LUT) a certain number (e.g., quantity) of times. The initial dynamic reduction function DR 0 may mask all bits for all occupancy configurations such that it is a constant function DR 0 (β) = 0 for all occupancy configurations β. The dynamic reduction function may evolve from a function DR n to an updated function DR n+1 . The dynamic reduction function may evolve from a function DR n to an updated function DR n+1 , for example, after each coding of an occupancy bit. The function may be defined by β’ = DR n (β) = β 1 … β kn(β) , where k n (β) 510 is the number (e.g., quantity) of non-masked bits. The initialization of DR 0 may correspond to k 0 (β)=0, and the natural evolution of the reduction function toward finer statistics may lead to an increasing number (e.g., quantity) of non-masked bits kn(β) ≤ kn+1(β). The dynamic reduction function may be entirely determined by the values of k n for all occupancy configurations β. [0069] The visits (e.g., instances of a lookup in the LUT) to occupancy configurations may be tracked by a variable NV(β’) for all dynamically reduced occupancy configurations β’= Docket No.: 007412.06305 DR n (β). The corresponding number (e.g., quantity) of visits NV(β V ’) may be increased by one. The corresponding number (e.g., quantity) of visits NV(β V ’) may be increased by one, for example, after each instance of coding of an occupancy bit based on an occupancy configuration β V . If this number (e.g., quantity) of visits NV(β V ’) is greater than a threshold thV, NV(β V ’) > th V , then the number (e.g., quantity) of unmasked bits kn(β) may be increased by one for all occupancy configurations β being dynamically reduced to β V ’. This corresponds to replacing the dynamically reduced occupancy configuration β V ’ by the two new dynamically reduced occupancy configurations β 0 ’ and β 1 ’ defined by β 0 ’ = β V ’0 = β V 1 … β V kn(β) 0, and β 1 ’ = β V ’1 = β V 1 … β V kn(β) 1. [0070] In other increased by one k n+1 (β) = k n (β) + 1 for all occupancy configurations β such that DR n (β) = β V ’. The number (e.g., quantity) of visits of the two new dynamically reduced occupancy configurations may be initialized to zero, NV(β 0 ’) = NV(β 1 ’) = 0. (I) [0071] At the start of the coding, the initial number (e.g., quantity) of visits for the initial dynamic reduction function DR 0 may be set to NV(DR 0 (β)) = NV(0) = 0, and the evolution of NV on dynamically reduced occupancy configurations may be entirely defined. [0072] The corresponding LUT entry LUT[β V ’] may be replaced by the two new entries LUT[β 0 ’] and LUT[β 1 ’] that are initialized by the coder index associated with β V ’. The corresponding LUT entry LUT[β V ’] may be replaced by the two new entries LUT[β 0 ’] and LUT[β 1 ’] that are initialized by the coder index associated with β V ’, for example, if a dynamically reduced occupancy configuration β V ’ is replaced by the two new dynamically reduced occupancy configurations β 0 ’ and β 1 ’, Docket No.: 007412.06305 and then evolve separately. The evolution of the LUT of coder indices on dynamically reduced occupancy configurations may be entirely defined. [0073] The reduction function DR n may be modeled by a series of growing binary trees T n 520 whose leaf nodes 530 are the reduced occupancy configurations β’ = DR n (β). The initial tree may be the single root node associated with 0 = DR 0 (β). The replacement of the dynamically reduced to β V ’ by β 0 ’ and β 1 ’ corresponds to growing the tree T n from the leaf node associated with β V ’. The of the dynamically reduced to β V ’ by β 0 ’ and β 1 ’ corresponds to growing the tree T n from the leaf node associated with β V ’, for example, by attaching to it two new nodes associated with β 0 ’ and β 1 ’. The tree T n+1 may be obtained by this growth. The number (e.g., quantity) of visits NV and the LUT of context indices may be defined on the leaf nodes and evolve with the growth of the tree through equations (I) and (II). [0074] The practical implementation of dynamic OBUF may be made by the storage of the array NV[β’] and the LUT[β’] of context indices, as well as the trees T n 520. An alternative to the storage of the trees may be to store the array kn[β] 510 of the number (e.g., quantity) of non- masked bits. [0075] A limitation for implementing dynamic OBUF may be its memory footprint. In some instances, a few million occupancy configurations may be practically handled, leading to about 20 bits βi constituting an entry configuration β to the reduction function DR. Each bit βi may correspond to the occupancy status of a neighboring cuboid of a current child cuboid or a set of neighboring cuboids of a current child cuboid. [0076] Higher (e.g., more significant) bits β i (e.g., β 0 , β 1 , etc.) may be the first bits to be unmasked. Higher (e.g., more significant) bits βi (e.g., β0, β1, etc.) may be the first bits to be unmasked, for example, during the evolution of the dynamic reduction function DR. The order of neighbor-based information put in the bits βi may impact the compression performance. Neighboring information may be ordered from higher priority to lower priority and put, in this order, into the bits β i , e.g., from higher to lower weight. The priority may be, from the most important to the least important, occupancy of sets of adjacent neighboring child cuboids, then occupancy of adjacent neighboring child cuboids, then occupancy of adjacent neighboring parent cuboids, then occupancy of non-adjacent neighboring child nodes, and finally occupancy of non-adjacent neighboring parent nodes. Adjacent nodes sharing a face with the current child node may also have higher priority than adjacent nodes sharing an edge Docket No.: 007412.06305 (but not sharing a face) with the current child node. Adjacent nodes sharing an edge with the current child node may have higher priority than adjacent nodes sharing only a vertex with the current child node. [0077] FIG.6 shows an example method for coding occupancy of a cuboid using dynamic OBUF. More specifically, FIG. 6 shows a flowchart of an example method for coding occupancy (e.g., as indicated by a single bit) of a current child cuboid using dynamic OBUF. More specifically, FIG.6 shows a flowchart of example method steps coding occupancy of a current child cuboid using dynamic OBUF. The example method, or one or more operations of the method, may be performed by one or more computing devices or entities. For example, all or portions of the flowchart may be implemented by a coder (e.g., encoder 114 in FIG.1 and/or decoder 120 in FIG. 1), an example computer system 2100 in FIG. 21, and/or an example computing device 2230 in FIG.22. [0078] At step 602, an encoder and/or decoder may determine the occupancy configuration β of the current child cuboid. The encoder and/or decoder may determine the occupancy configuration β of the current child cuboid, for example, based on occupancy bits of already- coded cuboids in a neighborhood of the current child cuboid. At step 604, the encoder and/or decoder may dynamically reduce the occupancy configuration β into a reduced occupancy configuration using DR n (e.g., β’ = DR n (β)). At step 606, the encoder and/or decoder may lookup context index LUT[β’] in the LUT of the dynamic OBUF. At step 608, the encoder and/or decoder may select the context (e.g., probability model) pointed to by the context index. At step 610, the encoder and/or decoder may entropy code (e.g., arithmetic code) the occupancy bit of the current child cuboid based on the context. [0079] Although not shown in FIG. 6, the encoder and/or decoder may further update the reduction function DR n into DR n+1 and/or update the context index LUT[β’] based on the occupancy bit of the current child cuboid. The method of FIG. 6 may be repeated for additional or all child cuboids of parent cuboids corresponding to nodes of the occupancy tree in a scan order, such as the scan order described herein with respect to FIG.3. [0080] The occupancy tree is a lossless compression technique. The occupancy tree may be adapted to provide lossy compression, for example, by modifying the point cloud on the encoder side (e.g., down-sampling, removing points, moving points, etc.) but compression Docket No.: 007412.06305 performance of the lossy compression may be weak. It may be a useful lossless compression technique for dense point clouds. [0081] An approach to lossy compression for point cloud geometry may be to set the maximum depth of the occupancy tree to not reach the smallest volume size of one voxel. Instead, the maximum depth of the occupancy tree may be set to stop at a bigger volume size (e.g., N×N×N cuboids, where N > 1). The geometry of the points belonging to each occupied leaf node associated with the bigger volumes may then be modeled. This approach may be particularly suited for dense and smooth point clouds that may be locally modeled by smooth functions, for example, planes or polynomials. The coding cost may become the cost of the occupancy tree plus the cost of the local model in each of the occupied leaf nodes. [0082] A scheme for modeling the geometry of the points belonging to each occupied leaf node associated with a volume size larger than one voxel may use sets of triangles as local models. The scheme may be referred to as the “TriSoup” scheme. TriSoup is short for “Triangle Soup” because the connectivity between triangles may not be part of the models. An occupied leaf node of an occupancy tree that corresponds to a cuboid with a volume greater than one voxel may be referred to as a TriSoup node. An edge belonging to at least one cuboid corresponding to a TriSoup node may be referred to as a TriSoup edge. A TriSoup node may comprise a presence flag (s k ) for each TriSoup edge of its corresponding occupied cuboid. A presence flag (sk) of a TriSoup edge may indicate whether a TriSoup vertex (Vk) is present or not on the TriSoup edge. At most one TriSoup vertex (V k ) may be present on a TriSoup edge. For each vertex (Vk) present on a TriSoup edge of an occupied cuboid, the TriSoup node corresponding to the occupied cuboid may further comprise a position (p k ) of the vertex (V k ) along the TriSoup edge. [0083] In addition to the occupancy words of an occupancy tree, an encoder may entropy encode the TriSoup vertex presence flags and positions of each TriSoup edge belonging to TriSoup nodes of the occupancy tree. A decoder may similarly entropy decode the TriSoup vertex presence flags and positions of each TriSoup edge belonging to a TriSoup node of the occupancy tree, in addition to the occupancy words of the occupancy tree. [0084] FIG. 7 shows an example of an occupied cuboid 700 that corresponds to a TriSoup node of an occupancy tree. Cuboid 700 may be of size N×N×N (where N > 1). Occupied cuboid 700 may comprise TriSoup edges 710–-721. The TriSoup node, corresponding to occupied Docket No.: 007412.06305 cuboid 700, may comprise a presence flag (sk) for each TriSoup edge of TriSoup edges 710- 721. The presence flag of TriSoup edge 714 may indicate that a TriSoup vertex V 1 is present on TriSoup edge 714. The presence flag of TriSoup edge 715 may indicate that a TriSoup vertex V 2 is present on TriSoup edge 715. The presence flag of TriSoup edge 716 may indicate that a TriSoup vertex V3 is present on TriSoup edge 716. The presence flag of TriSoup edge 717 may indicate that a TriSoup vertex V 4 is present on TriSoup edge 717. The presence flags of the remaining TriSoup edges may each indicate that a TriSoup vertex is not present on their corresponding TriSoup edge. The TriSoup node, corresponding to occupied cuboid 700, may further comprise a position for each TriSoup vertex present along one of its TriSoup edges 710-721. More specifically, the TriSoup node, corresponding to occupied cuboid 700, may further comprise a position p1 for TriSoup vertex V1, a position p2 for TriSoup vertex V2, a position p3 for TriSoup vertex V3, and a position p4 for TriSoup vertex V4. [0085] FIG.8A shows an example cuboid corresponding to a TriSoup node. A cuboid 800 may correspond to a TriSoup node with a number K of TriSoup vertices V k . Within cuboid 800, TriSoup triangles may be constructed from the TriSoup vertices Vk. TriSoup triangles may be constructed from the TriSoup vertices V k , for example, if at least three (K≥3) TriSoup vertices are present on the TriSoup edges of cuboid 800. In the example of FIG.8A, 4 TriSoup vertices are present and TriSoup triangles are constructed. The TriSoup triangles may be constructed around the centroid vertex C. The centroid vertex C may be defined as the mean of the TriSoup vertices Vk. A dominant direction may be determined, vertices Vk may be ordered by turning around this direction, and the following K TriSoup triangles may be constructed: V 1 V 2 C, V2V3C, …, VKV1C. The dominant direction may be chosen among the three directions respectively parallel to the axes of the 3D space to increase or maximize the 2D surface of the triangles, for example, if the triangles are projected along the dominant direction. The dominant direction may be somewhat perpendicular to a local surface defined by the points of the point cloud belonging to the TriSoup node. [0086] FIG.8B shows an example refinement to the TriSoup model. The TriSoup model may be refined by coding a centroid residual value. A centroid residual value Cres may be coded into the bitstream. A centroid residual value C res may be coded into the bitstream, for example, to use C+Cres instead of C as a pivoting vertex for the triangles. By using C+Cres as the pivoting vertex for the triangles, the vertex C+C res may be closer to the points of the point cloud than Docket No.: 007412.06305 the centroid C, the reconstruction error may be lowered, thereby leading to lower distortion at the cost of a small increase in bitrate needed for coding C res . [0087] FIG. 9 shows an example of voxelization. Voxelization may refer to reconstruction of a decoded point cloud from the set of TriSoup triangles. Voxelization may be performed by ray tracing for each triangle individually. Voxelization may be performed by ray tracing for each triangle individually, for example, before removing duplicated points between voxelized triangles. As shown in Fig. 9, rays 900 may be launched parallel to one of the three axes of the 3D space. Rays 900 may be launched starting from integer coordinates P start . The intersection Pint (if any) of the rays 900 with a TriSoup triangle 901 belonging to a cuboid 902 corresponding to a TriSoup node may be rounded to obtain a decoded point. This intersection Pint may be found, for example, using the Möller-Trumbore algorithm. [0088] A presence flag (sk) and, if the presence flag (sk) indicates the presence of a vertex, a position (pk) of a current TriSoup edge may be entropy coded. The presence flag (sk) and position (pk) may be individually or collectively referred to as vertex information. A presence flag (sk) and, if the presence flag (sk) indicates the presence of a vertex, a position (pk) of a current TriSoup edge may be entropy coded, for example, based on already-coded presence flags and positions of TriSoup edges that neighbor the current TriSoup edge. A presence flag (s k ) and, if the presence flag (s k ) indicates the presence of a vertex, a position (p k ) of a current TriSoup edge may be additionally or alternatively entropy coded. The presence flag (sk) and the position (p k ) of a current TriSoup edge may be additionally or alternatively entropy coded, for example, based on occupancies of cuboids that neighbor the current TriSoup edge. Similar to the entropy coding of the occupancy bits of the occupancy tree, a configuration β TS for a neighborhood (also referred to as a neighborhood configuration βTS) of a current TriSoup edge may be obtained and dynamically reduced into a reduced configuration βTS’ = DR n (βTS). The configuration β TS for a neighborhood of a current TriSoup edge may be obtained and dynamically reduced into a reduced configuration βTS’ = DR n (βTS), for example, by using a dynamic OBUF scheme for TriSoup. A context index LUT[β TS ’] may be obtained from the OBUF LUT. At least a part of the vertex information of the current TriSoup edge may be entropy coded using the context (e.g., probability model) pointed to by the context index. [0089] The TriSoup vertex position (pk) (if present) along its TriSoup edge may be binarized. The TriSoup vertex position (pk) (if present) along its TriSoup edge may be binarized, for example, to use a binary entropy coder to entropy code at least part of the vertex information of the Docket No.: 007412.06305 current TriSoup edge. A number (e.g., quantity) of bits Nb may be set for the quantization of the TriSoup vertex position (p k ) along the TriSoup edge of length N. The TriSoup edge of length N may be uniformly divided into 2 Nb quantization intervals. By doing so, the TriSoup vertex position (p k ) may be represented by N b bits (p k j , j=1, ... , N b ) that may be individually coded by the dynamic OBUF scheme as well as the bit corresponding to the presence flag (sk). The neighborhood configuration β TS, the OBUF reduction function DR n , and thus the context index may depend on the nature of the coded bit (e.g., presence flag (sk), highest position bit (p k 1 ), second highest position bit (p k 2 ), etc.). There may be several dynamic OBUF schemes, each dedicated to a specific bit of information (e.g., presence flag (sk) or position bit (pk j )) of the vertex information. [0090] FIG. 10A and FIG. 10B show 12 cuboids 1000-1003, 1010-1013, and 1020-1023 with volumes that intersect a current TriSoup edge E being entropy coded. Current TriSoup edge E is an edge of cuboids 1000-1003. The start point of current TriSoup edge E intersects cuboids 1010-1013. The end point of current TriSoup edge E intersects cuboids 1020-1023. The occupancy bits of one or more of the 12 cuboids 1000-1003, 1010-1013, and 1020-1023 may be used to determine the neighborhood configuration β TS for current TriSoup edge E. [0091] TriSoup edges may be oriented from a start point to an end point following the orientation of one of the three axes of the 3D space they are parallel to. A global ordering of the TriSoup edges may be defined as the lexicographic order over the couple (e.g., start point, end point). Vertex information related to the TriSoup edges may be coded following the TriSoup edge ordering. A causal neighborhood of a current TriSoup edge may be obtained from the neighboring already-coded TriSoup edges of the current TriSoup edge. [0092] FIG. 11A, FIG.11B, and FIG.11C show TriSoup edges (E’ and E’’) that may be used to entropy code a current edge E. In some instances, at most five TriSoup edges (E’ and E’’) may be used to entropy code a current edge E. The five TriSoup edges may include, - the edge E’ parallel to the current TriSoup edge E and having an end point equal to the start point of the current TriSoup edge E, and - the four edges E’’ perpendicular to the current TriSoup edge E and having a start or end point equal to the start point of the current TriSoup edge E. Depending on the direction of current TriSoup edge E, either two (FIG. 11C for direction z), three (FIG.11B for direction y), or four (FIG.11A for direction x) of the four perpendicular Docket No.: 007412.06305 TriSoup edges may have been already coded and their vertex information may be used to construct the neighborhood configuration β TS for current TriSoup edge E. The TriSoup edge E’ may have already been coded for each direction of the current TriSoup edge E and its vertex information may be used to construct the neighborhood configuration β TS for current TriSoup edge E independent of its direction. [0093] As described herein, the neighborhood configuration βTS for a current TriSoup edge E may be obtained from one or more occupancy bits of cuboids and from the vertex information of neighboring already-coded TriSoup edges. The neighborhood configuration β TS for a current TriSoup edge E may be obtained from one or more of the 12 occupancy bits of the 12 cuboids shown in FIG. 10A and FIG. 10B and from the vertex information of the at most five neighboring already-coded TriSoup edges (E’ and E’’) shown in FIG.11A, 11B, and 11C. [0094] As described herein with respect to FIG.11A, 11B, and 11C, the vertex information of at most five TriSoup edges may be used to entropy code a current TriSoup edge E. More particularly, as described herein with respect to FIG. 11A, 11B, and 11C, the vertex information of at most five TriSoup edges may be used to determine the neighborhood configuration β TS of the current TriSoup edge E. The neighborhood configuration β TS may be dynamically reduced into a reduced configuration βTS’ = DR n (βTS). The neighborhood configuration β TS may be dynamically reduced into a reduced configuration β TS ’ = DR n TS ), for example, by using a dynamic OBUF scheme as described herein. A context index LUT[β TS ’] may be obtained from the OBUF LUT and at least a part of the vertex information of the current TriSoup edge E may be entropy coded using the context (e.g., probability model) pointed to by the context index. [0095] Using the vertex information of the at most five TriSoup edges to entropy code the current TriSoup edge E may result in a weak correlation between the neighborhood configuration β TS and the vertex information of current TriSoup edge E. The dynamic OBUF scheme may provide a context index for entropy coding the current TriSoup edge E with coding probabilities that are weakly correlated with the vertex information of the current TriSoup edge E. Because of this weak correlation, the vertex information of the current TriSoup edge E may not be effectively compressed. [0096] The disclosures provided herein improve the correlation between the neighborhood configuration βTS of a current TriSoup edge E and the vertex information of the current Docket No.: 007412.06305 TriSoup edge E. The improved correlation may allow the vertex information of the current TriSoup edge E to be more effectively compressed using entropy coding. The improved compression using entropy coding may lead to smaller storage requirement, faster and more efficient transmission of point cloud data, and faster and more efficient processing of the point cloud data. This can result in a better experience in and wider adoption of volumetric visual data applications such as AR, VR, MR, and many others, as well as advancement in any hardware implementation of such technologies. As described herein, an encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of the current TriSoup edge E. The encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of the current TriSoup edge E, for example, based on at least one TriSoup edge that, unlike the at most five TriSoup edges shown in FIG. 11A, FIG. 11B, and 11C, does not intersect a start point of the current TriSoup edge E. The vertex information of this at least one TriSoup edge may be used to determine (e.g., in conjunction with one or more of the at least five TriSoup edges shown in FIG. 11A, FIG. 11B, and 11C) one or more symbols of the neighborhood configuration β TS with the improved correlation. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration β TS with the improved correlation. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration β TS ’ = DR n TS ) representing a subset of the symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context based on an OBUF LUT that maps the neighborhood configuration β TS or the reduced configuration β TS ’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E, for example, based on the context. [0097] FIG. 12A, FIG. 12B, and FIG. 12C show neighboring already-coded TriSoup edges that neighbor and do not intersect a start point of a current TriSoup edge E. The current TriSoup edge E may be a TriSoup edge being entropy coded. The neighboring already-coded TriSoup edges shown in FIG. 12A, FIG. 12B, and FIG. 12C do not intersect a start point of a current TriSoup edge E being entropy coded, unlike the at most five TriSoup edges shown in FIG. 11A, FIG. 11B, and 11C. More particularly, FIG. 12A, FIG. 12B, and FIG. 12C show Docket No.: 007412.06305 neighboring already-coded TriSoup edges Epar that are parallel to the current TriSoup edge E and belong to a same TriSoup node as the current TriSoup edge E. [0098] FIG. 12A shows already-coded parallel edges E par that are available for coding a current TriSoup edge E. The already-coded parallel edges Epar may be available for coding a current TriSoup edge E, for example, based on the current TriSoup edge E being parallel to the x direction. FIG. 12B shows already-coded parallel edges Epar that are available for coding a current TriSoup edge E. The already-coded parallel edges Epar may be available for coding a current TriSoup edge E, for example, based on the current TriSoup edge E being parallel to the y direction. FIG.12C shows already-coded parallel edges Epar that are available for coding a current TriSoup edge E. The already-coded parallel edges E par may be available for coding a current TriSoup edge E, for example, based on the current TriSoup edge E being parallel to the z direction. These parallel edges E par may already be coded according to the lexicographic order, as described herein, that globally orders the set of TriSoup edges. [0099] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E. The encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of a current TriSoup edge E, for example, based on one or more of the already-coded four parallel edges Epar shown in FIG. 12A, FIG. 12B, and FIG. 12C that may be available for coding the current TriSoup edge E. The specific set of already-coded four parallel edges Epar shown in FIG. 12A, FIG. 12B, and FIG.12C that may be available for coding the current TriSoup edge E may be determined, for example, based on the direction to which the current TriSoup edge E is parallel as described herein. The vertex information of the one or more of the already-coded four parallel edges Epar may be used to determine (e.g., in conjunction with one or more of the at least five TriSoup edges shown in FIG. 11A, FIG. 11B, and 11C) one or more symbols of a neighborhood configuration β TS of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration β TS . The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration βTS’ = DR n (βTS) representing a subset of the Docket No.: 007412.06305 symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context, for example, based on an OBUF LUT that maps the neighborhood configuration β TS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E, for example, based on the context. [0100] FIG.13A, FIG.13B, and FIG.13C show already-coded TriSoup edges that neighbor and do not intersect a start point of a current TriSoup edge. The neighboring already-coded TriSoup edges shown in FIG. 13A, FIG.13B, and FIG.13C do not intersect a start point of a current TriSoup edge E being entropy coded, unlike the at most five TriSoup edges shown in FIG. 11A, FIG. 11B, and 11C. More particularly, FIG. 13A, FIG. 13B, and FIG. 13C show neighboring already-coded TriSoup edges Eperp that may be perpendicular to the current TriSoup edge E and intersect the end point of the current TriSoup edge E. [0101] FIG. 13A shows that no already-coded perpendicular edges Eperp may be available for coding a current TriSoup edge E based on the current TriSoup edge E being parallel to the x axis. FIG. 13B shows that one already-coded perpendicular edge Eperp may be available for coding a current TriSoup edge E based on the current TriSoup edge E being parallel to the y axis. FIG. 13C shows that two already-coded perpendicular edges Eperp may be available for coding a current TriSoup edge E based on the current TriSoup edge E being parallel to the z axis. These perpendicular edges Eperp may already be coded according to the lexicographic order, as described here, that globally orders the set of TriSoup edges. [0102] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of a current TriSoup edge E. An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E, for example, based on one or more of the already-coded perpendicular edges E perp shown in FIG. 13A, FIG. 13B, and FIG. 13C that are available for coding the current TriSoup edge E. The specific set of already-coded perpendicular edges E perp shown in FIG. 13A, FIG. 13B, and FIG.13C that may be available for coding the current TriSoup edge E may be determined, for example, based on the direction to which the current TriSoup edge E is parallel as described herein. The vertex information of the one or more of the already-coded perpendicular edges Eperp may be used to determine (e.g., in conjunction with one or more of the at least five TriSoup edges shown in FIG.11A, FIG.11B, and 11C and/or in conjunction with one or more of the already-coded four parallel edges Epar shown in FIG. 12A, FIG. 12B, and FIG. 12C) Docket No.: 007412.06305 one or more symbols of a neighborhood configuration βTS of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration βTS. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration β TS ’ = DR n TS ) representing a subset of the symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context based on an OBUF LUT. The OBUF LUT may map the neighborhood configuration βTS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E based on the context. [0103] FIG. 14A, FIG. 14B, and FIG. 14C show neighboring already coded edges of a current TriSoup edge E. The neighboring already coded edges may be taken from a spatial topology, of a current TriSoup edge E. The neighboring already coded edges may be taken from a spatial topology of 18 edges (e.g., labeled from 0 to 17). The current TriSoup edge E may be parallel: to the x direction (FIG. 14A), to the y direction (FIG. 14B), or to the z direction (FIG. 14C). Edge 0 may correspond to the unique edge (E’ in Fig 11) parallel to the current TriSoup edge E and having its end point equal to (e.g., coinciding with) the start point of the current TriSoup edge E. Edges 1, 2, 3, 4 may correspond to the at most four edges (E’’ in FIG.11A, FIG.11B, and 11C) perpendicular to the current TriSoup edge E and having a start or end point equal to (e.g., coinciding with) the start point of the current TriSoup edge E. Edges 14, 15, 16, 17 may be edges (Epar in FIG. 12A, FIG.12B, and FIG. 12C) that are parallel to the current TriSoup edge E and belong to a same TriSoup node as the current TriSoup edge E. Edges 9, 10 may be edges (Eperp in FIG. 13A, FIG. 13B, and FIG. 13C) that are perpendicular to the current TriSoup edge E and intersect the end point of the current TriSoup edge E. Edges 1, 2, 3, 4, 5, 6, 7, 8 may belong to a same TriSoup node as the current TriSoup edge E and may belong to the plane: perpendicular to the current TriSoup edge E, and comprising the start point of the current TriSoup edge E. Edges 9, 10, 11, 12, 13 may belong to a same TriSoup node as the current TriSoup edge E and belong to the plane: perpendicular to the current TriSoup edge E, and comprising the end point of the current TriSoup edge E. Docket No.: 007412.06305 [0104] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of a current TriSoup edge E. encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E, for example, based on one or more of the already-coded edges 0 to 17 shown in FIG. 14A, FIG. 14B, and FIG. 14C that are available for coding the current TriSoup edge E. The specific set of the already-coded edges 0 to 17 shown in FIG. 14A, FIG. 14B, and FIG. 14C that may be available for coding the current TriSoup edge E may be determined, for example, based on the direction to which the current TriSoup edge E is parallel. The vertex information of the one or more of the already-coded edges 0 to 17 may be used to determine one or more symbols of a neighborhood configuration β TS of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration βTS. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration β TS ’ = DR n TS ) representing a subset of the symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context. The encoder and/or decoder may select the context, for example, based on an OBUF LUT that maps the neighborhood configuration βTS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E, for example, based on the context. [0105] The spatial topology of 18 edges shown in FIG.14A, FIG.14B, and FIG.14C may include sub-spatial topologies of edges. Each edge of the sub-spatial topologies of edges may be available (e.g., already coded) for coding a current TriSoup edge E independent of a direction to which the current TriSoup edge E is parallel. FIG. 15A, FIG.15B, and FIG. 15C show an example of a sub-spatial topology of TriSoup edges. The sub-spatial topology of TriSoup edges may be, for example, an 18-edge spatial topology as shown in FIG.14A, FIG.14B, and FIG.14C. The sub-spatial topology of edges may comprise the 11 edges 0, 1, 2, 5, 6, 7, 8, 14, 15, 16, 17. FIG. 15A, FIG. 15B, and FIG. 15C show that, for each of the three possible directions of the current TriSoup edge E, each of the 11 edges of the sub-spatial topology of Docket No.: 007412.06305 edges may be available for coding the current TriSoup edge E. FIG. 15A shows that each of the 11 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E, for example, if current TriSoup edge E is parallel to the x axis. FIG. 15B shows that each of the 11 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E parallel to the y axis. FIG. 15C shows that each of the 11 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E parallel to the z axis. [0106] A different configuration of the sub-spatial topology may be used for each direction of current TriSoup edge E. The different configurations may comprise different rotated and/or mirrored configurations of the sub-spatial topology of edges. The sub-spatial topology of edges in FIG. 15A may be rotated by 90 degrees in two different directions (e.g., rotated around the y axis and rotated around the z axis) relative to the sub-spatial topology of edges in FIG. 15C. The sub-spatial topology of edges in FIG. 15A may be rotated by 90 degrees (e.g., around the z axis) and mirrored (e.g., over the x-z plane) relative to the sub-spatial topology of edges in FIG.15B. [0107] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E. An encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of a current TriSoup edge E, for example, based on edges only belonging to the sub-spatial topology of edges shown in FIG. 15A, FIG. 15B, and FIG. 15C that are available for coding the current TriSoup edge E independent of its direction (e.g., independent of a direction to which the current TriSoup edge E is parallel). The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration β TS . The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration βTS’ = DR n (βTS). The reduced configuration β TS ’ = DR n TS ) may represent a subset of the symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context based on an OBUF LUT that maps the neighborhood configuration β TS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic Docket No.: 007412.06305 code) the vertex information of the current TriSoup edge E. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E, for example, based on the context. [0108] A spatial topology of edges may be referred to as a direction-independent spatial-topology of edges. Each edge of the spatial topology of edges may be available (e.g., already coded) for coding a current TriSoup edge E independent of a direction of the current TriSoup edge E. [0109] Dilution of the dynamic OBUF statistics by having a unique set of statistics for all three directions of a current TriSoup edge E may be reduced or avoided. Dilution of the dynamic OBUF statistics by having a unique set of statistics for all three directions of a current TriSoup edge E may be reduced or avoided, for example, by determining one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E based on edges only belonging to a direction-independent spatial-topology of edges. The one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E may be determined based on edges only belonging to a direction-independent spatial-topology of edges, for example, like the sub-spatial topology of edges shown in FIG.15A, FIG.15B, and FIG.15C. This may lead to faster convergence of the OBUF LUT of context indices, and result in more efficient compression of the vertex information of the current TriSoup edge E. [0110] An encoder and/or decoder implementation may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E based on edges only belonging to a direction-independent spatial-topology of edges. In this implementation, the encoder and/or decoder may split the neighborhood configuration β TS into at least three series of bits βTS = (βind, dir, βdep) βind is the one or more symbols of the neighborhood configuration βTS determined based on edges only belonging to a direction-independent spatial-topology of edges, dir is the direction of the current edge, and β dep is one or more symbols of the neighborhood configuration β TS determined based on at least one edge that is not available to code the current TriSoup edge E independent of a direction of the current TriSoup edge E. The one or more symbols β ind may be determined, for example, based on edges only belonging to the sub-spatial topology of edges shown in FIG. 15A, FIG. 15B, and FIG. 15C. β dep may be determined, for example, based on edges belonging to the spatial topology of edges shown in FIG.14A, FIG.14B, and Docket No.: 007412.06305 FIG. 14C that do not belong to the sub-spatial topology of edges shown in FIG. 15A, FIG. 15B, and FIG.15C. The direction dir may be made of two bits, for example: 00 for x, 01 for y, 10 for z, and 11 may be unused. The encoder and/or decoder may start coding information by dynamic OBUF. The encoder and/or decoder may start coding information by dynamic OBUF, for example, by using the leftmost bits βind of the neighborhood configuration βTS that shares the same statistics independent of the direction of the current TriSoup edge E. This may help dynamic OBUF converge faster in its early phase. More bits of the neighborhood configuration β TS may be unmasked. More bits of the neighborhood configuration β TS may be unmasked, for example, during the evolution of the coding. The statistics may be distributed, for example, if the two bits of dir are unmasked, through the OBUF tree, among the three directions of the current TriSoup edge E to take into account the direction-dependent topology of the remaining neighborhood that has been used to construct βdep. [0111] The advantage of the direction-independent spatial-topology of edges may be realized, for example, if the geometry of the point cloud is spatially isotropic at the scale of the spatial- topology. Sharing statistics among directions may not be desirable because the statistics may not fundamentally depend on the direction. This condition may be fulfilled because the local (e.g., at the scale of the size of a TriSoup node) geometry of a point cloud may be generally isotropic for reasonable TriSoup node sizes. [0112] FIG. 16A, FIG. 16B, and FIG. 16C show neighboring already coded edges. The neighboring already coded edges may be taken from a spatial topology of 9 edges of a current TriSoup edge E. The 9 edges of the spatial topology may be labeled a to i. The current TriSoup edge E may be parallel: to the x direction (FIG.16A), to the y direction (FIG.16B), or to the z direction (FIG. 16C). The spatial topology of 9 edges shown in FIG. 16A, FIG. 16B, and FIG. 16C may be used as an alternative to the spatial topology of 18 edges shown in FIG. 14A, FIG.14B, and FIG.14C. By being smaller than the spatial topology of 18 edges shown in FIG. 14A, FIG. 14B, and FIG. 14C, the spatial topology of 9 edges shown in FIG. 16A, FIG. 16B, and FIG. 16C may be easier to compute but offer less correlations and thus worse compression performance. [0113] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E. An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E, for example, based on one or more of the already-coded edges a to i shown in FIG. 16A, FIG. Docket No.: 007412.06305 16B, and FIG.16C that may be available for coding the current TriSoup edge E. The specific set of the already-coded edges a to i shown in FIG. 16A, FIG. 16B, and FIG. 16C that may be available for coding the current TriSoup edge E may be determined. The specific set of the already-coded edges a to i shown in FIG.16A, FIG.16B, and FIG.16C that may be available for coding the current TriSoup edge E may be determined, for example, based on the direction to which the current TriSoup edge E is parallel. The vertex information of the one or more of the already-coded edges a to i may be used to determine one or more symbols of a neighborhood configuration β TS of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration βTS. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration β TS ’ = DR n TS ) representing a subset of the symbols of the neighborhood configuration βTS. The encoder and/or decoder may select the context based on an OBUF LUT that maps the neighborhood configuration β TS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E based on the context. [0114] The spatial topology of 9 edges shown in FIG.16A, FIG.16B, and FIG.16C may include sub-spatial topologies of edges. Each edge of the sub-spatial topologies of edges may be available (e.g., already coded) for coding a current TriSoup edge E independent of a direction to which the current TriSoup edge E is parallel. FIG. 17A, FIG. 17B, and FIG. 17C show an example of a sub-spatial topology of TriSoup edges. The sub-spatial topology of TriSoup edges may comprise 5 edges a, b, c, f, g of the 9-edge spatial topology shown in FIG. 16A, FIG. 16B, and FIG.16C. FIG. 17A, FIG.17B, and FIG.17C show that, for each of the three possible directions of the current TriSoup edge E, each of the 5 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E. FIG. 17A shows that each of the 5 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E, for example, if current TriSoup edge E is parallel to the x axis. FIG. 17B shows that each of the 5 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E parallel to the y axis. FIG. 17C shows that each of the 5 Docket No.: 007412.06305 edges of the sub-spatial topology of edges may be available for coding the current TriSoup edge E parallel to the z axis. [0115] An encoder and/or decoder may determine one or more symbols of a neighborhood configuration βTS of a current TriSoup edge E. An encoder and/or decoder may determine one or more symbols of a neighborhood configuration β TS of a current TriSoup edge E, for example, based on edges only belonging to the sub-spatial topology of edges shown in FIG. 17A, FIG. 17B, and FIG. 17C that may be available for coding the current TriSoup edge E independent of its direction (e.g., independent of a direction to which the current TriSoup edge E is parallel). The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select a context (e.g., probability model) for coding the vertex information of the current TriSoup edge E, for example, based on the neighborhood configuration β TS . The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E. The encoder and/or decoder may select the context for coding the vertex information of the current TriSoup edge E, for example, based on a reduced configuration βTS’ = DR n (βTS) representing a subset of the symbols of the neighborhood configuration β TS . The encoder and/or decoder may select the context based on an OBUF LUT that maps the neighborhood configuration βTS or the reduced configuration βTS’ to an index of the context. The encoder and/or decoder may entropy code (e.g., arithmetic code) the vertex information of the current TriSoup edge E based on the context. [0116] FIG. 18A, FIG. 18B, and FIG. 18C show a spatial topology comprising TriSoup edges and TriSoup nodes. The spatial topology may be a direction-independent spatial topology made of a combination of TriSoup edges and TriSoup nodes. FIG. 18A, FIG. 18B, and FIG. 18C show an addition to the edge-only direction-independent spatial-topology of FIG. 17A, FIG. 17B, and FIG. 17C. The four TriSoup nodes, labeled A, B, C, D, intersecting the end point of the current TriSoup edge E have been added. These four nodes are not drawn to scale for sake of clarity of the figures. These four nodes may correspond to nodes 1020 to 1023 in FIG. 10B. The labeling of the four nodes has been made for each direction such as to obtain direction independence of the topology of the spatial topology made up of the five edges a, b, c, f, g and of the four nodes A to D. By doing so, one or more symbols of the neighborhood configuration β TS may be constructed from the direction-independent spatial topology made up of a combination of edges and nodes. Docket No.: 007412.06305 [0117] FIG.19 shows an example method for coding vertex information of a current edge. More specifically, FIG. 19 shows a flowchart 1900 of example method steps for coding vertex information of a current edge. The example method, or one or more operations of the method, may be performed by one or more computing devices or entities. One or more steps of the example flowchart 1900 may be performed by a coder (e.g., an encoder, such as encoder 114 as shown in FIG.1, or a decoder such as the decoder 120 as shown in FIG.1). The method or one or more steps thereof may be embodied in computer-executable instructions that are stored in a computer-readable medium, such as a non-transitory computer readable medium. The steps in flowchart 1900 need not all be performed in the order specified and may be performed in any order. One or more steps in this example flowchart may be omitted. [0118] At step 1902, the coder (e.g., encoder or decoder) may determine one or more symbols of a neighborhood configuration of a current edge. The coder (e.g., encoder or decoder) may determine one or more symbols of a neighborhood configuration of a current edge, for example, based on vertex information of at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge. An edge may be oriented from a start point to an end point following the orientation of one of the three axes of the 3D space in which it is parallel to. [0119] The current edge may be an edge of a cuboid comprising part of a point cloud. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge and may be parallel to the current edge. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge and may intersect an end point of the current edge. [0120] The coder may determine the one or more symbols of the neighborhood configuration. The coder may determine the one or more symbols of the neighborhood configuration, for example, based on one or more vertex presence flags of the at least one edge. The coder may determine the one or more symbols of the neighborhood configuration, for example, based on one or more vertex positions of the at least one edge. Docket No.: 007412.06305 [0121] The vertex information of the current edge may comprise a vertex presence flag of the current edge. The vertex information of the current edge may comprise a vertex position of the current edge. [0122] At step1904, the coder may select a context for coding vertex information of the current edge. The coder may select a context for coding vertex information of the current edge, for example, based on the neighborhood configuration. [0123] The coder may select the context (e.g., probability model) for coding the vertex information of the current edge. The coder may select the context (e.g., probability model) for coding the vertex information of the current edge, for example, based on a lookup table (e.g., OBUF lookup table) that maps the neighborhood configuration to the context (e.g., probability model). [0124] The coder may select the context (e.g., probability model) for coding the vertex information of the current edge. The coder may select the context (e.g., probability model) for coding the vertex information of the current edge, for example, based on a lookup table that maps only a subset of the symbols of the neighborhood configuration to the context (e.g., probability model). The subset of the symbols of the neighborhood configuration may be determined, for example, by using on an OBUF dynamic reduction function with respect to the symbols of the neighborhood configuration. A number (e.g., quantity) of symbols in the subset may be increased. A number (e.g., quantity) of symbols in the subset may be increased, for example based on a number (e.g., quantity) of coded edges with neighborhood information comprising the same subset of symbols. The coder (e.g., encoder or decoder) may update the lookup table to map the subset of symbols of the neighborhood configuration to a different context (e.g., probability model). The coder (e.g., encoder or decoder) may update the lookup table to map the subset of symbols of the neighborhood configuration to a different context (e.g., probability model), for example, based on the vertex information of the current edge. [0125] At step 1906, the coder (e.g., encoder or decoder) may entropy code (e.g., arithmetic code) the vertex information of the current edge. The coder (e.g., encoder or decoder) may entropy code (e.g., arithmetic code) the vertex information of the current edge, for example, based on the context. [0126] FIG.20 shows an example method for coding vertex information of a current edge. More specifically, FIG. 20 shows a flowchart 2000 of example method steps of coding vertex Docket No.: 007412.06305 information of a current edge. One or more steps of the example flowchart 200 may be performed by a coder (e.g., an encoder such as the encoder 114 as shown in FIG. 1, or a decoder such as the decoder 120 as shown in FIG.1). The method or one or more steps thereof may be embodied in computer-executable instructions that are stored in a computer-readable medium, such as a non-transitory computer readable medium. The steps in flowchart 2000 need not all be performed in the order specified and may be performed in any order. One or more steps in this flowchart may be omitted. [0127] At step 2002, the coder (e.g., encoder or decoder) may determine one or more symbols of a neighborhood configuration of a current edge. The coder (e.g., encoder or decoder) may determine one or more symbols of a neighborhood configuration of a current edge, for example, based on vertex information of edges only belonging to a spatial topology of edges. Each edge of the spatial topology of edges may be available for coding the current edge independent of a direction of the current edge. [0128] The current edge may be an edge of a cuboid comprising part of a point cloud. The edges belonging to the spatial topology of edges may comprise at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge. An edge may be oriented from a start point to an end point following the orientation of one of the three axes of the 3D space in which it is parallel to. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge and may be parallel to the current edge. The at least one edge that does not intersect (e.g., fails to intersect) a start point of the current edge may belong to a same cuboid as the current edge and may intersect an end point of the current edge. [0129] One of a plurality of different configurations of the spatial topology of edges may be selected to determine the one or more symbols of the neighborhood information. One of a plurality of different configurations of the spatial topology of edges may be selected to determine the one or more symbols of the neighborhood information, for example, based on the direction of the current edge. The plurality of different configurations may comprise different rotated and/or mirrored configurations of the spatial topology of edges. Docket No.: 007412.06305 [0130] The coder (e.g., encoder or decoder) may determine the one or more symbols of the neighborhood configuration. The coder (e.g., encoder or decoder) may determine the one or more symbols of the neighborhood configuration, for example, based on one or more vertex presence flags of the edges only belonging to the spatial topology of edges. The coder may determine the one or more symbols of the neighborhood configuration based, for example, on one or more vertex positions of the edges only belonging to the spatial topology of edges. [0131] The vertex information of the current edge may comprise a vertex presence flag of the current edge. The vertex information of the current edge may comprise a vertex position of the current edge. [0132] At step 2004, the coder (e.g., encoder or decoder) may select a context for coding vertex information of the current edge. The coder (e.g., encoder or decoder) may select a context for coding vertex information of the current edge, for example. based on the neighborhood configuration. The coder may select the context (e.g., probability model) for coding the vertex information of the current edge, for example, based on a lookup table (e.g., OBUF lookup table) that maps the neighborhood configuration to the context (e.g., probability model). [0133] The coder may select the context (e.g., probability model) for coding the vertex information of the current edge based, for example, on a lookup table that maps only a subset of the symbols of the neighborhood configuration to the context (e.g., probability model). The subset of the symbols of the neighborhood configuration may be determined, for example, by using an OBUF dynamic reduction function to the symbols of the neighborhood configuration. A number (e.g., quantity) of symbols in the subset may be increased, for example, based on a number (e.g., quantity) of coded edges with neighborhood information comprising the same subset of symbols. The coder (e.g., encoder or decoder) may update the lookup table to map the subset of symbols of the neighborhood configuration to a different context (e.g., probability model). The coder (e.g., encoder or decoder) may update the lookup table to map the subset of symbols of the neighborhood configuration to a different context (e.g., probability model), for example, based on the vertex information of the current edge. [0134] At step 2006, the coder (e.g., encoder or decoder) may entropy code (e.g., arithmetic code) the vertex information of the current edge. the coder (e.g., encoder or decoder) may entropy code (e.g., arithmetic code) the vertex information of the current edge, for example, based on the context. Docket No.: 007412.06305 [0135] FIG. 21 shows an example computer system in which examples of the present disclosure may be implemented. For example, the example computer system 2100 shown in FIG.21 may implement one or more of the methods described herein. For example, various devices and/or systems described herein (e.g., in FIGS. 1, 2, and 3) may be implemented in the form of one or more computer systems 2100. Furthermore, each of the steps of the flowcharts depicted in this disclosure may be implemented on one or more computer systems 2100. [0136] Computer system 2100 may comprise one or more processors, such as a processor 2104. Processor 2104 may be a special purpose processor, a general purpose processor, a microprocessor, and/or a digital signal processor. Processor 2104 may be connected to a communication infrastructure 2102 (e.g., a bus or network). Computer system 2100 may also comprise a main memory 2106 (e.g., a random access memory (RAM)) and/or a secondary memory 2108. [0137] Secondary memory 2108 may comprise a hard disk drive 2110 and/or a removable storage drive 2112 (e.g., a magnetic tape drive, an optical disc drive, and/or the like). Removable storage drive 2112 may read from and/or write to a removable storage unit 2116. Removable storage unit 2116 may comprise a magnetic tape, optical disc, and/or the like. Removable storage unit 2116 may be read by and/or may be written to removable storage drive 2112. Removable storage unit 2116 may comprise a computer usable storage medium having stored therein computer software and/or data. [0138] Secondary memory 2108 may comprise other similar means for allowing computer programs or other instructions to be loaded into computer system 2100. Such means may include a removable storage unit 2118 and/or an interface 2114. Examples of such means may comprise a program cartridge and/or cartridge interface (such as in video game devices), a removable memory chip (e.g., an erasable programmable read-only memory (EPROM) or a programmable read-only memory (PROM)) and associated socket, a thumb drive and Universal Serial Bus (USB) port, and/or other removable storage units 2118 and interfaces 2114, which may allow software/or and data to be transferred from removable storage unit 2118 to computer system 2100. [0139] Computer system 2100 may comprise a communications interface 2120. Communications interface 2120 may allow software and data to be transferred between computer system 2100 and external device(s). Examples of communications interface 2120 may include a modem, a Docket No.: 007412.06305 network interface (e.g., an Ethernet card), a communications port, etc. Software and/or data transferred via communications interface 2120 may be in the form of signals which may be electronic, electromagnetic, optical, and/or other signals capable of being received by communications interface 2120. The signals may be provided to communications interface 2120 via a communications path 2122. Communications path 2122 may carry signals and may be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, a radio frequency (RF) link, and/or other communications channels. [0140] Computer system 2100 may include one or more sensor(s) 2124. Sensor(s) 2124 may measure and/or detect one or more physical quantities. Sensor(s) 2124 may convert the measured or detected physical quantities into an electrical signal in digital and/or analog form. For example, sensor(s) 2124 may include an eye tracking sensor to track the eye movement of a user. Based on the eye movement of a user, a display of a point cloud may be updated. In another example, sensor(s) 2124 may include a head tracking sensor (e.g., a gyroscope) to track the head movement of a user. Based on the head movement of a user, a display of a point cloud may be updated. In yet another example, sensor(s) 2124 may include a camera sensor for taking photographs and/or a 3D scanning device (e.g., a laser scanning, structured light scanning, and/or modulated light scanning device).3D scanning devices may obtain geometry information by moving one or more laser heads, structured light, and/or modulated light cameras relative to the object or scene being scanned. The geometry information may be used to construct a point cloud. [0141] A computer program medium and/or a computer-readable medium may be used to refer to tangible (e.g., non-transitory) storage media, such as removable storage units 2116 and 2118 or a hard disk installed in hard disk drive 2110. These computer program products may be means for providing software to computer system 2100. Computer programs (also referred to as computer control logic) may be stored in main memory 2106 and/or secondary memory 2108. The computer programs may be received via communications interface 2120. Such computer programs, when executed, may enable the computer system 2100 to implement one or more example embodiments of the present disclosure as discussed herein. In particular, the computer programs, when executed, may enable processor 2104 to implement the processes of the present disclosure, such as any of the methods described herein. Accordingly, such computer programs may represent controllers of computer system 2100. Docket No.: 007412.06305 [0142] FIG. 22 shows example elements of a computing device that may be used to implement any of the various devices described herein, including, for example, a source device (e.g., 102), an encoder (e.g., 114), a destination device (e.g., 106), a decoder (e.g., 120), and/or any computing device described herein. The computing device 2230 may include one or more processors 2231, which may execute instructions stored in the random-access memory (RAM) 2233, the removable media 2234 (e.g., a Universal Serial Bus (USB) drive, compact disc (CD) or digital versatile disc (DVD), or floppy disk drive), or any other desired storage medium. Instructions may also be stored in an attached (or internal) hard drive 2235. The computing device 2230 may also include a security processor (not shown), which may execute instructions of one or more computer programs to monitor the processes executing on the processor 2231 and any process that requests access to any hardware and/or software components of the computing device 2230 (e.g., ROM 2232, RAM 2233, the removable media 2234, the hard drive 2235, the device controller 2237, a network interface 2239, a GPS 2241, a Bluetooth interface 2242, a Wi-Fi interface 2243, etc.). The computing device 2230 may include one or more output devices, such as the display 2236 (e.g., a screen, a display device, a monitor, a television, etc.), and may include one or more output device controllers 2237, such as a video processor. There may also be one or more user input devices 2238, such as a remote control, keyboard, mouse, touch screen, microphone, etc. The computing device 2230 may also include one or more network interfaces, such as a network interface 2239, which may be a wired interface, a wireless interface, or a combination of the two. The network interface 2239 may provide an interface for the computing device 2230 to communicate with a network 2240 (e.g., a RAN, or any other network). The network interface 2239 may include a modem (e.g., a cable modem), and the external network 2240 may include communication links, an external network, an in-home network, a provider’s wireless, coaxial, fiber, or hybrid fiber/coaxial distribution system (e.g., a DOCSIS network), or any other desired network. Additionally, the computing device 2230 may include a location-detecting device, such as a global positioning system (GPS) microprocessor 2241, which may be configured to receive and process global positioning signals and determine, with possible assistance from an external server and antenna, a geographic position of the computing device 2230. [0143] The example in FIG. 22 may be a hardware configuration, although the components shown may be implemented as software as well. Modifications may be made to add, remove, combine, divide, etc. components of the computing device 2230 as desired. Additionally, the components may be implemented using basic computing devices and components, and the Docket No.: 007412.06305 same components (e.g., processor 2231, ROM storage 2232, display 2236, etc.) may be used to implement any of the other computing devices and components described herein. For example, the various components described herein may be implemented using computing devices having components such as a processor executing computer-executable instructions stored on a computer-readable medium, as shown in FIG. 22. Some or all of the entities described herein may be software based, and may co-exist in a common physical platform (e.g., a requesting entity may be a separate software process and program from a dependent entity, both of which may be executed as software on a common computing device). [0144] Hereinafter, various characteristics will be highlighted in a set of numbered clauses or paragraphs. These characteristics are not to be interpreted as being limiting on the invention or inventive concept, but are provided merely as a highlighting of some characteristics as described herein, without suggesting a particular order of importance or relevancy of such characteristics. [0145] Clause 1. A method comprising determining, based on vertex information of a spatial topology of edges, one or more symbols of a neighborhood configuration of a current edge. [0146] Clause 2. The method of clause 1, wherein each edge of the spatial topology of edges is available for coding the current edge independent of a direction of the current edge. [0147] Clause 3. The method of any one of clauses 1-2, further comprising determining, based on the one or more symbols of the neighborhood configuration, a probability model. [0148] Clause 4. The method of any one of clauses 1-3, further comprising entropy coding, based on the determined probability model, vertex information of the current edge. [0149] Clause 5. The method of any one of clauses 1-4, wherein the determining the one or more symbols of the neighborhood configuration comprises: selecting, based on the direction of the current edge, one of a plurality of different configurations of the spatial topology of edges. [0150] Clause 6. The method of clause 5, wherein the plurality of different configurations comprises a rotated configuration of the spatial topology of edges. [0151] Clause 7. The method of any one of clauses 5-6, wherein the plurality of different configurations comprises a mirrored configuration of the spatial topology of edges. Docket No.: 007412.06305 [0152] Clause 8. The method of any one of clauses 1-7, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags associated with the spatial topology of edges. [0153] Clause 9. The method of any one of clauses 1-8, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex positions associated with the spatial topology of edges. [0154] Clause 10. The method of any one of clauses 1-9, wherein the vertex information of the current edge comprises a vertex presence flag associated with the current edge. [0155] Clause 11. The method of any one of clauses 1-10, wherein the vertex information of the current edge comprises a vertex position associated with the current edge. [0156] Clause 12. The method of any one of clauses 1-11, wherein the determining the probability model comprises determining the probability model based on a lookup table that maps, to the probability model, the neighborhood configuration. [0157] Clause 13. The method of any one of clauses 1-12, wherein the determining the probability model comprises determining the probability model based on a lookup table that maps, to the probability model, a subset of the one or more symbols of the neighborhood configuration. [0158] Clause 14. The method of any one of clauses 12-13, further comprising: increasing a quantity of symbols in the subset, based on a quantity of coded edges, with neighborhood information, comprising the symbols in the subset. [0159] Clause 15. The method of any one of clauses 12-14, further comprising: updating, based on the vertex information of the current edge, the lookup table to map the subset to a different probability model. [0160] Clause 16. The method of any one of clauses 1-15, wherein the spatial topology of edges comprises an edge that does not intersect a start point of the current edge. [0161] Clause 17. The method of any one of clauses 1-16, wherein the spatial topology of edges comprises an edge belonging to a same cuboid as the current edge. Docket No.: 007412.06305 [0162] Clause 18. The method of any one of clauses 1-17, wherein the spatial topology of edges comprises an edge parallel to the current edge. [0163] Clause 19. The method of any one of clauses 1-16, wherein the spatial topology of edges comprises an edge perpendicular to the current edge and intersecting an end point of the current edge. [0164] Clause 20. The method of any one of clauses 1-19, wherein the neighborhood configuration further comprises: a second set of one or more symbols indicating the direction of the current edge. [0165] Clause 21. The method of any one of clauses 1-20, wherein the neighborhood configuration further comprises: a third set of one or more symbols determined based on at least one edge that is not available for coding the current edge independent of the direction of the current edge. [0166] Clause 22. The method of any one of clauses 1-21, wherein the current edge belongs to a cuboid comprising at least one point of a point cloud. [0167] Clause 23. A computing device comprising one or more processors and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the method of any one of clauses 1-22. [0168] Clause 24. A system comprising: a first computing device configured to perform the method of any one of clauses 1-22, and a second computing configured to decode the entropy coded vertex information of the current edge. [0169] Clause 25. A computer-readable medium storing instructions that, when executed, cause performance of the method any one of clauses 1-22. [0170] Clause 26. A method comprising, based on vertex information of at least one edge that fails to intersect a start point of a current edge, determining one or more symbols of a neighborhood configuration of the current edge. [0171] Clause 27. The method of clause 26, further comprising determining, based on the one or more symbols of the neighborhood configuration, a probability model. Docket No.: 007412.06305 [0172] Clause 28. The method of any one of clauses 26-27, further comprising entropy coding, based on the determined probability model, vertex information of the current edge. [0173] Clause 29. The method of any one of clauses 26-28, wherein the at least one edge comprises an edge belonging to a same cuboid as the current edge. [0174] Clause 30. The method of any one of clauses 26-29, wherein the at least one edge comprises an edge parallel to the current edge. [0175] Clause 31. The method of any one of clauses 26-30, wherein the at least one edge comprises an edge perpendicular to the current edge and intersecting an end point of the current edge. [0176] Clause 32. The method of any one of clauses 26-31, wherein the vertex information of the current edge comprises: a first vertex presence flag associated with the current edge. [0177] Clause 33. The method of any one of clauses 26-32, wherein the vertex information of the current edge comprises: a first vertex position associated with the current edge. [0178] Clause 34. The method of any one of clauses 26-33, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on a second vertex presence flag associated with the at least one edge. [0179] Clause 35. The method of any one of clauses 26-34, wherein the determining the one or more symbols of the neighborhood configuration comprises determining the one or more symbols of the neighborhood configuration based on a second vertex position associated with the at least one edge. [0180] Clause 36. The method of any one of clauses 26-35, wherein the determining the probability model comprises determining the probability model based on a lookup table that maps, to the probability model, the neighborhood configuration. [0181] Clause 37. The method of any one of clauses 26-36, wherein the determining the probability model comprises determining the probability model based on a lookup table that maps, to the probability model, a subset of the one or more symbols of the neighborhood configuration. Docket No.: 007412.06305 [0182] Clause 38. The method of any one of clauses 36-37, further comprising: increasing a quantity of symbols in the subset, based on a quantity of coded edges, with neighborhood information, comprising the symbols in the subset. [0183] Clause 39. The method of any one of clauses 36-38, further comprising: updating, based on the vertex information of the current edge, the lookup table to map the subset to a different probability model. [0184] Clause 40. The method of any one of clauses 26-39, wherein the current edge belongs to a cuboid comprising at least one point of a point cloud. [0185] Clause 41. A computing device comprising one or more processors and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the method of any one of clauses 26-40. [0186] Clause 42. A system comprising: a first computing device configured to perform the method of any one of clauses 26-40, and a second computing configured to decode the entropy coded vertex information of the current edge. [0187] Clause 43. A computer-readable medium storing instructions that, when executed, cause performance of the method any one of clauses 26-40. [0188] Clause 44. A method comprising, based on vertex information of a subset of a spatial topology of edges, determining one or more symbols of a neighborhood configuration of a current edge. [0189] Clause 45. The method of clause 44, further comprising determining, based on the one or more symbols of the neighborhood configuration, a probability model. [0190] Clause 46. The method of any one of clauses 44-45, further comprising entropy coding, based on the determined probability model, vertex information of the current edge. [0191] Clause 47. The method of any one of clauses 44-46, wherein the spatial topology of edges comprises a first edge parallel to the current edge. [0192] Clause 48. The method of clause 47, wherein an end point of the first edge coincides with a start point of the current edge. Docket No.: 007412.06305 [0193] Clause 49. The method of any one of clauses 44-48, wherein the spatial topology of edges comprises a second edge perpendicular to the current edge. [0194] Clause 50. The method of clause 49, wherein a start point of the second edge coincides with the start point of the current edge. [0195] Clause 51. The method of any one of clauses 44-50, wherein the spatial topology of edges comprises a third edge perpendicular to the current edge. [0196] Clause 52. The method of clause 51, wherein an end point of the third edge coincides with the start point of the current edge. [0197] Clause 53. The method of any one of clauses 44-52, wherein the spatial topology of edges comprises a fourth edge parallel to the current edge and belonging to a first cuboid that comprises the current edge. [0198] Clause 54. The method of any one of clauses 44-53, wherein the spatial topology of edges comprises a fifth edge perpendicular to the current edge and intersecting an end point of the current edge. [0199] Clause 55. The method of any one of clauses 44-54, wherein the spatial topology of edges comprises a sixth edge belonging to a second cuboid that comprises the current edge. [0200] Clause 56. The method of clause 55, wherein the sixth edge belongs to a first plane that is perpendicular to the current edge. [0201] Clause 57. The method of any one of clauses 55-56, wherein the first plane comprises the start point of the current edge. [0202] Clause 58. The method of any one of clauses 44-57, wherein the spatial topology of edges comprises a seventh edge belonging to a third cuboid that comprises the current edge. [0203] Clause 59. The method of clause 58, wherein the seventh edge belongs to a second plane that is perpendicular to the current edge. [0204] Clause 60. The method of any one of clauses 58-59, wherein the second plane comprises the end point of the current edge. Docket No.: 007412.06305 [0205] Clause 61. A computing device comprising one or more processors and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the method of any one of clauses 44-60. [0206] Clause 62. A system comprising: a first computing device configured to perform the method of any one of clauses 44-60, and a second computing configured to decode the entropy coded vertex information of the current edge. [0207] Clause 63. A computer-readable medium storing instructions that, when executed, cause performance of the method any one of clauses 44-60. [0208] Clause 64. A method comprising determining one or more symbols of a neighborhood configuration of a current edge based on vertex information of edges only belonging to a spatial topology of edges. [0209] Clause 65. The method of clause 64, wherein each edge of the spatial topology of edges is available for coding the current edge independent of a direction of the current edge. [0210] Clause 66. The method of any one of clauses 64-65, further comprising selecting a context/probability model for coding vertex information of the current edge based on the neighborhood configuration. [0211] Clause 67. The method of any one of clauses 64-66, further comprising entropy coding the vertex information of the current edge based on the context/probability model. [0212] Clause 68. The method of any one of clauses 64-67, wherein one of a plurality of different configurations of the spatial topology of edges is selected to determine the one or more symbols of the neighborhood information based on the direction of the current edge. [0213] Clause 69. The method of clause 68, wherein the plurality of different configurations comprises different rotated and/or mirrored configurations of the spatial topology of edges. [0214] Clause 70. The method of any one of clauses 64-69, wherein the determining further comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags of the edges only belonging to the spatial topology of edges. Docket No.: 007412.06305 [0215] Clause 71. The method of any one of clauses 64-70, wherein the determining further comprises determining the one or more symbols of the neighborhood configuration based on one or more vertex positions of the edges only belonging to the spatial topology of edges. [0216] Clause 72. The method of any one of clauses 64-71, wherein the vertex information of the current edge comprises a vertex presence flag of the current edge. [0217] Clause 73. The method of any one of clauses 64-72, wherein the vertex information of the current edge comprises a vertex position of the current edge. [0218] Clause 74. The method of any one of clauses 64-73, wherein the selecting further comprises selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps the neighborhood configuration to the context/probability model. [0219] Clause 75. The method of any one of clauses 64-74, wherein the selecting further comprises selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps only a subset of the symbols of the neighborhood configuration to the context/probability model. [0220] Clause 76. The method of clause 75, wherein a number of symbols in the subset is increased based on a number of coded edges with neighborhood information comprising the same subset of symbols. [0221] Clause 77. The method of any one of clauses 75-76, further comprising updating the look up table to map the subset of symbols of the neighborhood configuration to a different context/probability model based on the vertex information of the current edge. [0222] Clause 78. The method of any one of clauses 64-77, wherein the edges only belonging to the spatial topology of edges comprise at least one edge that does not intersect a start point of the current edge. [0223] Clause 79. The method of clause 78, wherein the at least one edge further belongs to a same cuboid as the current edge. [0224] Clause 80. The method of clause 79, wherein the at least one edge is further parallel to the current edge. Docket No.: 007412.06305 [0225] Clause 81. The method of any one of clauses 79-80, wherein the at least one edge is further perpendicular to the current edge and intersects an end point of the current edge. [0226] Clause 82. The method of any one of clauses 64-81, wherein the neighborhood configuration further comprises a second set of one or more symbols indicating the direction of the current edge. [0227] Clause 83. The method of any one of clauses 64-82, wherein the neighborhood configuration further comprises a third set of one or more symbols determined based on at least one edge that is not available for coding the current edge independent of the direction of the current edge. [0228] Clause 84. The method of any one of clauses 64-83, wherein the current edge is of a cuboid comprising part of a point cloud. [0229] Clause 85. A computing device comprising one or more processors and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the method of any one of clauses 64-84. [0230] Clause 86. A system comprising: a first computing device configured to perform the method of any one of clauses 64-84, and a second computing configured to decode the entropy coded vertex information of the current edge. [0231] Clause 87. A computer-readable medium storing instructions that, when executed, cause performance of the method any one of clauses 64-84. [0232] A computing device may perform a method comprising multiple operations. Based on vertex information of a spatial topology of edges, one or more symbols of a neighborhood configuration of a current edge may be determined. Each edge of the spatial topology of edges may be available for coding the current edge independent of a direction of the current edge. Based on the one or more symbols of the neighborhood configuration, a probability model may be determined. Based on the determined probability model, vertex information of the current edge may be entropy coded. The determining the one or more symbols of the neighborhood configuration may comprises selecting, based on the direction of the current edge, one of a plurality of different configurations of the spatial topology of edges. The plurality of different configurations may comprise a rotated configuration of the spatial Docket No.: 007412.06305 topology of edges. The plurality of different configurations may comprise a rotated configuration of the spatial topology of edges a mirrored configuration of the spatial topology of edges. The determining the one or more symbols of the neighborhood configuration may comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags associated with the spatial topology of edges. The determining the one or more symbols of the neighborhood configuration may comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex positions associated with the spatial topology of edges. The vertex information of the current edge may include a vertex presence flag associated with the current edge. The vertex information of the current edge may include a vertex position associated with the current edge. The determining the probability model may comprise determining the probability model based on a lookup table that maps, to the probability model, the neighborhood configuration. The determining the probability model may comprise determining the probability model based on a lookup table that maps, to the probability model, a subset of the one or more symbols of the neighborhood configuration. A quantity of symbols in the subset may be increased, based on a quantity of coded edges, with neighborhood information, comprising the symbols in the subset. Based on the vertex information of the current edge, the lookup table may be updated to map the subset to a different probability model. The spatial topology of edges may comprise an edge that does not intersect a start point of the current edge. The spatial topology of edges may comprise an edge belonging to a same cuboid as the current edge. The spatial topology of edges may comprise an edge parallel to the current edge. The spatial topology of edges may comprise an edge perpendicular to the current edge and intersecting an end point of the current edge. The neighborhood configuration may further comprise a second set of one or more symbols indicating the direction of the current edge. The neighborhood configuration may further comprise a third set of one or more symbols determined based on at least one edge that is not available for coding the current edge independent of the direction of the current edge. The current edge may belong to a cuboid comprising at least one point of a point cloud. The computing device may comprise one or more processors; and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the described method, additional operations and/or include the additional elements. A system may comprise a first computing device configured to perform the described method, additional operations and/or include the additional elements; and a second computing device configured to decode the entropy coded vertex information of the current edge. A computer-readable medium may store instructions Docket No.: 007412.06305 that, when executed, cause performance of the described method, additional operations and/or include the additional elements. [0233] A computing device may perform a method comprising multiple operations. Based on vertex information of at least one edge that fails to intersect a start point of a current edge, one or more symbols of a neighborhood configuration of the current edge may be determined. Based on the one or more symbols of the neighborhood configuration, a probability model may be determined. Based on the determined probability model, vertex information of the current edge may be entropy coded. The at least one edge may include an edge belonging to a same cuboid as the current edge. The at least one edge may include an edge parallel to the current edge. The at least one edge may include an edge perpendicular to the current edge and intersecting an end point of the current edge. The vertex information of the current edge may comprise a first vertex presence flag associated with the current edge. The vertex information of the current edge may comprise a first vertex position associated with the current edge. The determining the one or more symbols of the neighborhood configuration may comprise determining the one or more symbols of the neighborhood configuration based on a second vertex presence flag associated with the at least one edge. The determining the one or more symbols of the neighborhood configuration may comprise determining the one or more symbols of the neighborhood configuration based on a second vertex position associated with the at least one edge. The determining the probability model may comprise determining the probability model based on a lookup table that maps, to the probability model, the neighborhood configuration. The determining the probability model may comprise determining the probability model based on a lookup table that maps, to the probability model, a subset of the one or more symbols of the neighborhood configuration. A quantity of symbols in the subset may be increased, based on a quantity of coded edges, with neighborhood information, comprising the symbols in the subset. Based on the vertex information of the current edge, the lookup table may be updated to map the subset to a different probability model. The current edge may belong to a cuboid comprising at least one point of a point cloud. The computing device may comprise one or more processors; and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the described method, additional operations and/or include the additional elements. A system may comprise a first computing device configured to perform the described method, additional operations and/or include the additional elements; and a second computing device configured to decode the entropy coded vertex information of the current edge. A computer- Docket No.: 007412.06305 readable medium may store instructions that, when executed, cause performance of the described method, additional operations and/or include the additional elements. [0234] A computing device may perform a method comprising multiple operations. Based on vertex information of a subset of a spatial topology of edges, one or more symbols of a neighborhood configuration of a current edge may be determined. Based on the one or more symbols of the neighborhood configuration, a probability model may be determined. Based on the determined probability model, vertex information of the current edge may be entropy coded. The spatial topology of edges may comprise a first edge parallel to the current edge. An end point of the first edge may coincide with a start point of the current edge. The spatial topology of edges may comprise a second edge perpendicular to the current edge. A start point of the second edge may coincide with the start point of the current edge. The spatial topology of edges may comprise a third edge perpendicular to the current edge. An end point of the third edge may coincide with the start point of the current edge. The spatial topology of edges may comprise a fourth edge parallel to the current edge and belonging to a first cuboid that comprises the current edge. The spatial topology of edges may comprise a fifth edge perpendicular to the current edge and intersecting an end point of the current edge. The spatial topology of edges may comprise a sixth edge belonging to a second cuboid that comprises the current edge. The sixth edge may belong to a first plane that is perpendicular to the current edge. The first plane may comprise the start point of the current edge. The spatial topology of edges may comprise a seventh edge belonging to a third cuboid that comprises the current edge. The seventh edge may belong to a second plane that is perpendicular to the current edge. The second plane may comprise the end point of the current edge. The computing device may comprise one or more processors; and memory storing instructions that, when executed by the one or more processors, cause the computing device to perform the described method, additional operations and/or include the additional elements. A system may comprise a first computing device configured to perform the described method, additional operations and/or include the additional elements; and a second computing device configured to decode the entropy coded vertex information of the current edge. A computer-readable medium may store instructions that, when executed, cause performance of the described method, additional operations and/or include the additional elements. [0235] A computing device may perform a method comprising multiple operations. One or more symbols of a neighborhood configuration of a current edge may be determined based on vertex Docket No.: 007412.06305 information of edges only belonging to a spatial topology of edges. Each edge of the spatial topology of edges may be available for coding the current edge independent of a direction of the current edge. A context/probability model for coding vertex information of the current edge may be selected based on the neighborhood configuration. The vertex information of the current edge may be entropy coded based on the context/probability model. One of a plurality of different configurations of the spatial topology of edges may be selected to determine the one or more symbols of the neighborhood information based on the direction of the current edge. The plurality of different configurations may comprise different rotated and/or mirrored configurations of the spatial topology of edges. The determining may further comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags of the edges only belonging to the spatial topology of edges. The determining may further comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex positions of the edges only belonging to the spatial topology of edges. The vertex information of the current edge may comprise a vertex presence flag of the current edge. The vertex information of the current edge may comprise a vertex position of the current edge. The selecting may further comprise selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps the neighborhood configuration to the context/probability model. The selecting may further comprise selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps only a subset of the symbols of the neighborhood configuration to the context/probability model. A number of symbols in the subset may be increased based on a number of coded edges with neighborhood information comprising the same subset of symbols. The look up table may be updated to map the subset of symbols of the neighborhood configuration to a different context/probability model based on the vertex information of the current edge. The edges only belonging to the spatial topology of edges may comprise at least one edge that does not intersect a start point of the current edge. The at least one edge may further belong to a same cuboid as the current edge. The at least one edge may be further parallel to the current edge. The at least one edge may further be perpendicular to the current edge and intersect an end point of the current edge. The neighborhood configuration may further comprise a second set of one or more symbols indicating the direction of the current edge. The neighborhood configuration may further comprise a third set of one or more symbols determined based on at least one edge that is not available for coding the current edge independent of the direction of the current edge. The current edge may be of a cuboid comprising part of a point cloud. A system may comprise a Docket No.: 007412.06305 first computing device configured to perform the described method, additional operations and/or include the additional elements; and a second computing device configured to decode the entropy coded vertex information of the current edge. A computer-readable medium may store instructions that, when executed, cause performance of the described method, additional operations and/or include the additional elements. [0236] A computing device may perform a method comprising multiple operations. One or more symbols of a neighborhood configuration of a current edge may be determined based on vertex information of at least one edge that does not intersect a start point of the current edge. A context/probability model for coding vertex information of the current edge may be selected based on the neighborhood configuration. The vertex information of the current edge may be entropy coded based on the context/probability model. The at least one edge may further belong to a same cuboid as the current edge. The at least one edge may be further parallel to the current edge. The at least one edge may be further perpendicular to the current edge and intersect an end point of the current edge. The determining may further comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex presence flags of the at least one edge. The determining may further comprise determining the one or more symbols of the neighborhood configuration based on one or more vertex positions of the at least one edge. The vertex information of the current edge may comprise a vertex presence flag of the current edge. The vertex information of the current edge may comprise a vertex position of the current edge. The selecting may further comprise selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps the neighborhood configuration to the context/probability model. The selecting may further comprise selecting the context/probability model for coding the vertex information of the current edge based on a look up table that maps only a subset of symbols of the neighborhood configuration to the context/probability model. A number of symbols in the subset may be increased based on a number of coded edges with neighborhood information comprising the same subset of symbols. The look up table may be updated to map the subset of symbols of the neighborhood configuration to a different context/probability model based on the vertex information of the current edge. The current edge may be an edge of a cuboid comprising part of a point cloud. A system may comprise a first computing device configured to perform the described method, additional operations and/or include the additional elements; and a second computing device configured to decode the entropy coded vertex information of the current edge. A computer-readable medium may store instructions Docket No.: 007412.06305 that, when executed, cause performance of the described method, additional operations and/or include the additional elements. [0237] One or more examples herein may be described as a process which may be depicted as a flowchart, a flow diagram, a data flow diagram, a structure diagram, and/or a block diagram. Although a flowchart may describe operations as a sequential process, one or more of the operations may be performed in parallel or concurrently. The order of the operations shown may be re-arranged. A process may be terminated if its operations are completed, but could have additional steps not shown in a figure. A process may correspond to a method, a function, a procedure, a subroutine, a subprogram, etc. If a process corresponds to a function, its termination may correspond to a return of the function to the calling function or the main function. [0238] Operations described herein may be implemented by hardware, software, firmware, middleware, microcode, hardware description languages, or any combination thereof. If implemented in software, firmware, middleware or microcode, the program code or code segments to perform the necessary tasks (e.g., a computer-program product) may be stored in a computer-readable or machine-readable medium. A processor(s) may perform the necessary tasks. Features of the present disclosure may be implemented in hardware using, for example, hardware components such as application-specific integrated circuits (ASICs) and gate arrays. Implementation of a hardware state machine to perform the functions described herein will also be apparent to persons skilled in the art. [0239] One or more features described herein may be implemented in a computer-usable data and/or computer-executable instructions, such as in one or more program modules, executed by one or more computers or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types when executed by a processor in a computer or other data processing device. The computer executable instructions may be stored on one or more computer readable media such as a hard disk, optical disc, removable storage media, solid state memory, RAM, etc. The functionality of the program modules may be combined or distributed as desired. The functionality may be implemented in whole or in part in firmware or hardware equivalents such as integrated circuits, field programmable gate arrays (FPGA), and the like. Particular data structures may be used to more effectively implement one or more features described herein, and such data structures are contemplated within the scope of Docket No.: 007412.06305 computer executable instructions and computer-usable data described herein. Computer- readable medium may comprise, but is not limited to, portable or non-portable storage devices, optical storage devices, and various other mediums capable of storing, containing, or carrying instruction(s) and/or data. A computer-readable medium may include a non- transitory medium in which data can be stored and that does not include carrier waves and/or transitory electronic signals propagating wirelessly or over wired connections. Examples of a non-transitory medium may include, but are not limited to, a magnetic disk or tape, optical storage media such as compact disk (CD) or digital versatile disk (DVD), flash memory, memory or memory devices. A computer-readable medium may have stored thereon code and/or machine-executable instructions that may represent a procedure, a function, a subprogram, a program, a routine, a subroutine, a module, a software package, a class, or any combination of instructions, data structures, or program statements. A code segment may be coupled to another code segment or a hardware circuit by passing and/or receiving information, data, arguments, parameters, or memory contents. Information, arguments, parameters, data, etc. may be passed, forwarded, or transmitted via any suitable means including memory sharing, message passing, token passing, network transmission, or the like. [0240] A non-transitory tangible computer readable media may comprise instructions executable by one or more processors configured to cause operations described herein. An article of manufacture may comprise a non-transitory tangible computer readable machine-accessible medium having instructions encoded thereon for enabling programmable hardware to cause a device (e.g., an encoder, a decoder, a transmitter, a receiver, and the like) to allow operations described herein. The device, or one or more devices such as in a system, may include one or more processors, memory, interfaces, and/or the like. [0241] Communications described herein may be determined, generated, sent, and/or received using any quantity of messages, information elements, fields, parameters, values, indications, information, bits, and/or the like. While one or more examples may be described herein using any of the terms/phrases message, information element, field, parameter, value, indication, information, bit(s), and/or the like, one skilled in the art understands that such communications may be performed using any one or more of these terms, including other such terms. For example, one or more parameters, fields, and/or information elements (IEs), may comprise one or more information objects, values, and/or any other information. An information object may comprise one or more other objects. At least some (or all) parameters, Docket No.: 007412.06305 fields, IEs, and/or the like may be used and can be interchangeable depending on the context. If a meaning or definition is given, such meaning or definition controls. [0242] One or more elements in examples described herein may be implemented as modules. A module may be an element that performs a defined function and/or that has a defined interface to other elements. The modules may be implemented in hardware, software in combination with hardware, firmware, wetware (e.g., hardware with a biological element) or a combination thereof, all of which may be behaviorally equivalent. For example, modules may be implemented as a software routine written in a computer language configured to be executed by a hardware machine (such as C, C++, Fortran, Java, Basic, Matlab or the like) or a modeling/simulation program such as Simulink, Stateflow, GNU Octave, or LabVIEWMathScript. Additionally or alternatively, it may be possible to implement modules using physical hardware that incorporates discrete or programmable analog, digital and/or quantum hardware. Examples of programmable hardware may comprise: computers, microcontrollers, microprocessors, application-specific integrated circuits (ASICs); field programmable gate arrays (FPGAs); and/or complex programmable logic devices (CPLDs). Computers, microcontrollers and/or microprocessors may be programmed using languages such as assembly, C, C++ or the like. FPGAs, ASICs and CPLDs are often programmed using hardware description languages (HDL), such as VHSIC hardware description language (VHDL) or Verilog, which may configure connections between internal hardware modules with lesser functionality on a programmable device. The above-mentioned technologies may be used in combination to achieve the result of a functional module. [0243] One or more of the operations described herein may be conditional. For example, one or more operations may be performed if certain criteria are met, such as in computing device, a communication device, an encoder, a decoder, a network, a combination of the above, and/or the like. Example criteria may be based on one or more conditions such as device configurations, traffic load, initial system set up, packet sizes, traffic characteristics, a combination of the above, and/or the like. If the one or more criteria are met, various examples may be used. It may be possible to implement any portion of the examples described herein in any order and based on any condition. [0244] Although examples are described above, features and/or steps of those examples may be combined, divided, omitted, rearranged, revised, and/or augmented in any desired manner. Various alterations, modifications, and improvements will readily occur to those skilled in the Docket No.: 007412.06305 art. Such alterations, modifications, and improvements are intended to be part of this description, though not expressly stated herein, and are intended to be within the spirit and scope of the descriptions herein. Accordingly, the foregoing description is by way of example only, and is not limiting.