Next Article in Journal
Fiber-Optic Skew Ray Sensors
Next Article in Special Issue
A Two-Stage Service Migration Algorithm in Parked Vehicle Edge Computing for Internet of Things
Previous Article in Journal
FilterNet: A Many-to-Many Deep Learning Architecture for Time Series Classification
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

A Novel Point Cloud Encoding Method Based on Local Information for 3D Classification and Segmentation

State Key Lab. of Digital Manufacturing Equipment & Technology, Huazhong University of Science and Technology, Wuhan 430074, China
*
Author to whom correspondence should be addressed.
Sensors 2020, 20(9), 2501; https://doi.org/10.3390/s20092501
Submission received: 29 March 2020 / Revised: 24 April 2020 / Accepted: 27 April 2020 / Published: 28 April 2020
(This article belongs to the Special Issue Internet of Things, Big Data and Smart Systems)

Abstract

:
Deep learning is robust to the perturbation of a point cloud, which is an important data form in the Internet of Things. However, it cannot effectively capture the local information of the point cloud and recognize the fine-grained features of an object. Different levels of features in the deep learning network are integrated to obtain local information, but this strategy increases network complexity. This paper proposes an effective point cloud encoding method that facilitates the deep learning network to utilize the local information. An axis-aligned cube is used to search for a local region that represents the local information. All of the points in the local region are available to construct the feature representation of each point. These feature representations are then input to a deep learning network. Two well-known datasets, ModelNet40 shape classification benchmark and Stanford 3D Indoor Semantics Dataset, are used to test the performance of the proposed method. Compared with other methods with complicated structures, the proposed method with only a simple deep learning network, can achieve a higher accuracy in 3D object classification and semantic segmentation.

1. Introduction

Big data from different sensors are the basis for the Internet of Things (IoT) to play its own advantages. Point cloud is an important 3D data format that is widely used in 3D semantic segmentation [1,2] and 3D object detection [3,4]. Moreover, point cloud is a raw output format of many 3D capturing devices such as depth cameras and LiDAR sensors. They are all important components in IoT-based smart systems. However, point cloud is usually unordered and unstructured, which makes it difficult to use these points effectively. Deep learning has been successfully used to process multiple data such as fault signals [5,6] and images [7,8]. However, it is not easy to use deep learning to directly process the point cloud because of its irregular format.
To utilize the deep learning method, some researchers converted raw point cloud data to regular formats such as 3D voxel grids [9] and multi-view renderings [10]. However, this conversion not only increases the network complexity, but also loses some useful information of the data. PointNet [11] was a pioneer that used the point cloud as the direct input of the deep learning network. PointNet first extracts features of each point independently, and then, the extracted features are integrated together to obtain the global information of the point cloud. Because PointNet extracts the features separately from individual points, it does not capture the local information of the point cloud.
Generally speaking, context awareness is conducive to improving the performance of the algorithm [12]. Utilizing local information has an important impact on the success of the deep learning method that often chooses convolutional neural networks (CNN) as the framework. The local information of the data facilitates the deep learning network to identify fine-grained features. The lower level of the deep learning network generally provides a smaller receptive field, while the higher level provides a larger receptive field. This gives the deep learning network an ability to capture the low level location information and the high level semantic information. Therefore, it is very important to utilize the local information when designing an algorithm based on the deep learning network.
To address this requirement, PointNet++ [13] introduced the local information of the point cloud into the deep learning network. The method partitioned the point cloud into overlapping local regions. The local features were extracted by applying PointNet recursively to these local regions. Landrieu and Simonovsky [14] designed a superpoint graph structure to effectively represent the relationship between different object parts. Li et al. [15] proposed a SO-Net structure to utilize the spatial distribution of the point cloud. Although these methods can make use of the local information, the models become very complicated compared with PointNet.
This paper proposes an effective method to encode each point into a feature representation with local information. This method facilitates a deep learning network to utilize the local information. An axis-aligned cube is first applied to the point cloud to search for a local spatial region that represents the local information. Second, some points are randomly selected from these points in the local region to construct the feature representation of a point. Each point is then encoded into a two-dimensional vector by randomly arranging those selected points. A simple deep learning network is finally designed to directly process the feature representation of all points. The well-known datasets ModelNet40 [16] shape classification benchmark and Stanford 3D Indoor Semantics Dataset (S3DIS) [17] are respectively used to test the proposed method for 3D object classification and semantic segmentation. Experimental results show that the proposed method achieves high accuracies on these two tasks even if only a simple deep learning network is used.
In the remainder of this paper, previous studies are summarized in Section 2. Details about the proposed method are introduced in Section 3. Experiments based on ModelNet40 and S3DIS are provided in Section 4. Conclusions and future work are discussed in Section 5.

2. Related Work

The methods for processing 3D data can be divided into two categories based on the feature representation. The traditional methods rely on hand-designed features. Deep learning is a new method to learn the feature representation directly from raw data.
Most traditional methods for 3D data are designed according to the handcrafted features. The Light Field descriptor (LFD) [18] extracted from 4D light fields was the representation of 3D objects, and it was used to measure the similarity between 3D models. The Spherical Harmonic descriptor (SPH) [19] was used to improve the matching performance of orientation dependent descriptors. The fast point feature histogram was used to retrieve three-dimensional objects by using fisher encodings [20]. For most application scenarios, the feature representation of the point cloud was often encoded by using statistical properties [21]. However, the optimal feature representation is often different on specific tasks, and it is not easy to choose the optimal feature for a specific task.
Recently, the end-to-end learning algorithms have been proposed for 3D data analysis. The early approaches that processed 3D data using deep learning were found in the literature [22,23], which handled 3D shape recognition task. The 3D ShapeNets [16] learned a probability distribution of binary variables of 3D shapes from multiple categories and arbitrary poses. Qi et al. [24] used an auxiliary task that predicted object classes from partial sub-volumes to improve the performance of the volumetric CNN. In these methods, 3D CNN is the main network frame that requires the voxel grids. These voxels are obtained by transforming the format of the raw point cloud. Unfortunately, these methods consume a large amount of computer memory. The size of the volumetric representation and the depth of the CNN are limited.
Researchers have proposed various methods to address this problem. Li et al. [25] proposed a field probing filter to extract features from volumetric fields. Riegler et al. [26] proposed an OctNet to hierarchically partition the 3D input space using a set of unbalanced octrees. The computational resources were dynamically focused based on the input 3D structure. Engelcke et al. [27] designed a sparse convolutional layer based on a voting strategy. Their method can efficiently process full 3D point clouds. However, the advantages of these methods are reduced when the point clouds are very large.
Other research efforts to ease the computational intensity are to render the 3D data into 2D images. The 3D point clouds were projected into 2D images by Pang and Neumann [28], and the point cloud detection was completed in a 2D space using CNN. A cylinder projection around its principle axis was operated by Shi et al. [29] for each 3D shape. A 2D CNN was designed by Su et al. [30] to recognize the rendered views, and the information from different views was integrated to form a single compact shape descriptor. Although these methods using multi-view CNN require less computational memory, some information is lost in the process of converting the point cloud into 2D images. Moreover, these methods perform poorly in some tasks such as scene understanding.
To avoid complex network structures and data rendering, the methods that directly process unordered point clouds are also proposed. PointNet [11] independently extracts the features of each point, and all of the features from the point cloud are then aggregated into a global feature by max pooling. PointNet is highly efficient and effective for many 3D data analysis tasks such as classification and segmentation. However, this method focuses on a single point and ignores the use of local geometric contexts of points. The improved PointNet was called as PointNet++, which was used to solve this problem [13]. PointNet++ was a hierarchical neural network that processed the point cloud in a hierarchical fashion. It first extracted the local features from the small neighborhoods, and these features were then grouped into larger units. Although local geometric contexts are considered in PointNet++, it requires extra computations. Other methods that directly process point clouds are studied based on PointNet. Huang et al. [31] projected the features of unordered points into an ordered sequence of feature vectors by using a slice pooling layer, and the traditional recurrent neural networks were then applied to these features. Wang et al. [32] proposed a similarity group proposal network to directly learn 3D instance-aware semantic segmentation from the point cloud. Although these methods can directly handle point clouds, they require novel models that are complicated compared with the PointNet.
Different from the methods mentioned above, the proposed method only uses a simple network whose complexity is lower than that of the PointNet. The proposed method processes the raw point cloud independently of the network structure. It can handle large-scale point clouds effectively and adapt to most point cloud data analysis tasks. Moreover, the local information of a point cloud is captured by utilizing the neighborhood points, which facilitates the network to recognize the fine-grained features of the objects.

3. Proposed Method for 3D Classification and Segmentation

A point cloud is a set of points, and each point interacts with its surrounding points. It is reasonable to consider the spatial location information and the influence of the surrounding points when constructing the feature representation of a point. In addition, the deep learning network requires a regular input format, and it is necessary to keep the feature dimensions of each point the same.
Taking into account the above factors, a point cloud encoding method is proposed to build the feature representation with the local information. The local information is represented using a local region that is an axis-aligned cube. The feature representation of each point is a two-dimensional vector. The vector is obtained using some points that are randomly chosen from the local region.
PointNet is a pioneer in directly processing point clouds. To verify the effectiveness of the proposed point cloud encoding strategy, only a simple deep learning network is designed on the basis of PointNet. The network is used to process the feature representation of each point. The overall framework of the proposed method is shown in Figure 1, which consists of a point cloud encoding block and a classification/segmentation networks block. Details of the proposed method are provided separately in the following sub-sections.
Different from the PointNet, the input transformation, feature transformation, and regularization loss are removed in the proposed deep learning architectures. The complexity of the proposed structure is much lower than PointNet. In addition, the data input to the network is the encoded feature representation, not the point coordinates used by PointNet. The feature representation contains abundant local information, which is helpful to improve the recognition accuracy.

3.1. Search for Local Region

Searching for a local region is actually a process that indexes spatial points from the point cloud. A cube region is often used in the Octree method [33]. The method partitions the point cloud by recursively subdividing it into eight regions, which improves the speed of indexing 3D data. The cube is also used to search for local regions of the point cloud in the proposed method.
It is assumed that a point cloud is represented as a set G = {Pi| i =1, 2, …, n}, Pi is represented using (xi, yi, zi) coordinates and other extra channels such as color and normalized location. The process of searching for a local region is shown in Figure 2. The local region of a point Po (xo, yo, zo) is searched using a cube with side length d. The point Po is located at the center of the cube and is called the center point. The range of the local region for Po is determined based on (1). The cube is aligned with the coordinate axis. The axis-aligned cube helps determine whether a point is in the local region. If the three coordinate values of a point satisfy (1) at the same time, then the point is considered to belong to the local region.
{ [ x o d / 2 ,   x o + d / 2 ] [ y o d / 2 ,   y o + d / 2 ] [ z o d / 2 ,   z o + d / 2 ]
The local region is only used to search for the points around an encoded point, and it provides the local information for the encoding features. The coordinate values are used to determine whether a point is in the local region. It is unnecessary to calculate the distances between points during the process of searching for the local region. Compared with other methods that depend on the distance information [34], the proposed method based on the axis-aligned cube improves the speed of searching for the local region.

3.2. Generate Feature Representation

The feature representation of a point is obtained using an effective encoding strategy that can take advantage of the local structure information. The encoding process for a point Po is described in detail. The process for other points is similar.
After the local region of the encoded point Po is determined, all of the points Pi located in the region constitute a point set S. It is obvious that the encoded point Po is located at the center of the local region. All of the points in the set S are from the point cloud, and they are called original points.
S = { P i | x o d / 2 x i x o + d / 2 , y o d / 2 y i y o + d / 2 , z o d / 2 z i z o + d / 2 }
Each point in the set S has an effect on the center point Po. To reduce the data size, only N points are randomly selected from these points to encode the center point. The center point is encoded into a two-dimensional feature vector. The process of encoding the center point is shown in Figure 3. c is the number of the channels used to represent the original point cloud. Each row represents an original point from the local region, and is an element of the feature vector. It is pointed out that the relative positions of the original points in the feature vector are randomly arranged.
For example, four original points are used to construct the feature representation F, and each point is represented using XYZ channels. The positions of these four points in the feature representation are random. The F is shown in mathematical form in (3).
F = [ x 3 y 3 z 3 x 2 y 2 z 2 x 1 y 1 z 1 x 4 y 4 z 4 ]
Because the density of the points may be different across different locations, the point cloud may contain many points in some areas, while it only contains a small number of points in other areas. The number of points included in a local region may be less than N if the side length of the cube is too small. In response to this situation, the zero vector with c-dimension is added to ensure that the dimension of the feature representation is N × c.
The virtual zero vector can ensure that there is a big difference between itself and the points in the point cloud. This difference is easy to be recognized by the network and can reduce the impact of the virtual zero vector on the recognition accuracy. In fact, the feature representation is composed of multiple points. A small number of virtual zero vectors have little influence on the recognition accuracy. On the contrary, the virtual zero vectors can increase the diversity of the input data and improve the adaptability of the network to noisy environments.

3.3. Deep Learning Architecture for Processing Feature Representation

To demonstrate the preponderance of the proposed point cloud encoding method, only a simple deep learning architecture is used in this paper. The deep learning architectures for different tasks are designed based on the PointNet architectures. The structure is marked with a red dotted frame in Figure 4 and Figure 5. The PointNet architectures are different for different tasks. Therefore, the deep learning architectures used in the proposed method are also different for different tasks. For a detailed description of the PointNet, please refer to the literature [11].
The full network architecture for a 3D object classification task is visualized in Figure 4. The input to the network is these feature representations, with dimensions of n × N × c, where n is the number of the points entered into the network in one iteration; N is the number of the points that are chosen from a local region to construct the feature representation; and c indicates the number of the channels of each point. These feature representations are first processed by a simple one-dimensional convolutional neural network block (ConvNet). A new feature vector with dimensions of n × 1 × C is then obtained. C is the channels of the new feature vectors that are input to the simplified PointNet. The shared multilayer perceptron with four layers is then applied to the new feature vector. The max pooling is used to extract the global information. The final classification scores for k classes are returned at the end of the network with a fully connected layer.
The full network architecture for a 3D semantic segmentation is given in Figure 5. The architecture is drawn based on the code provided in the literature [11]. It should be noted that a convolutional layer is removed to reduce the model complexity in this paper. These feature representations, with dimensions of n × N × c, are input to the one-dimensional ConvNet. The new features obtained from the ConvNet are entered to the shared multilayer perceptron with three layers. The max pooling is used to obtain a global feature. The global feature is the input of two fully connected layers. The output of the fully connected layer is concatenated with the local feature, with dimensions of n × 1 × 1024. Finally, a shared multilayer perceptron with three layers outputs n × m scores for n points and m semantic categories.
In these network architectures, mlp represents multilayer perceptron networks, and the numbers following it are layer size. The other network settings are exactly the same as those of the PointNet.
The simplified PointNet can be regarded as a set function.
f ( P 1 ,   P 2 ,   ,   P n ) = g ( M A X i = 1 , 2 , , n { h ( P i ) } )
where the g and h are the mlp networks.
The simplified PointNet directly processes the points. For example, given a point P0 (x0, y0, z0), the mlp can be shown in the following style:
y = f m l p ( W P 0 + b )
where fmlp represents the activation function, W is a weight matrix, and b is a bias. The Rectified Linear Unit (Relu) is used as the activation function in the simplified PointNet.
f m l p ( x ) = max ( 0 , x )
The function MAX is a symmetry function to extract the global feature. The function takes n vectors generated by the mlp networks h, and returns a new vector m of the element wise maximum.
m = M A X P i S { h ( P i ) }

4. Experimental Studies

The experiments are conducted based on two datasets, namely ModelNet40 and S3DIS. To compare fairly with other methods, the preprocessing of these datasets is consistent with that in Charles et al. [11].
There are 12,311 CAD models in ModelNet40 that contains 40 man-made object categories. These models are split into training sets including 9843 models and test sets including 2468 models. Each point is represented using XYZ channels. Each object contains 1024 points that are uniformly sampled on mesh faces based on face areas. These points are normalized into a unit sphere.
S3DIS contains 3D scans in six areas involving 271 rooms. The complete point cloud is generated from multiple views. Each point has semantic labels from 13 categories including clutter, such as chair, table, and floor. Each point is represented by a 9D vector that includes XYZ, RGB and normalized location as to the room. These points are split by room, which is then sampled into blocks of 1 m × 1 m. In total, 4096 points are randomly sampled in each block during training, and all of the points in each block are used during the test.
The designed network is implemented based on Tensorflow, and the experiments are conducted on Ubuntu 16.04 with a single Nvidia TITAN Xp GPU.

4.1. Experimental Setup

To explore the performance of the proposed method on different 3D data analysis tasks, it is respectively applied to 3D object classification and semantic segmentation tasks. The standard PointNet is selected as the baseline. The accuracy is selected as the primary performance metric. The experiments for the classification are completed based on ModelNet40 dataset. The experiments for the semantic segmentation are conducted by using the S3DIS dataset.
To study the effects of these parameters on the proposed method, sensitivity experiments are performed by varying the parameter values. The variation of accuracy with parameters is analyzed in these experiments. The proposed method contains two parameters d and N. d is the side length of the axis-aligned cube. It determines the range of the local region. N is the number of points that are used to encode the feature representation. It determines the dimension of the feature representation.
In the Tensorflow framework, the operation of the multilayer perceptron is completed by using one-dimensional convolution. Therefore, the data shape is organized according to the requirements of the convolution. For example, the data shape corresponds to the height, width, and channel in the image data. It is assumed that each point is expressed using XYZ channels. As shown in Figure 6, the one-dimensional convolution performs a convolution operation on the feature representation by row.

4.2. Experiments for 3D Object Classification

In these experiments, the proposed method directly acts on the data provided by Charles et al. [11]. It is fair to compare our experimental results with their results.

4.2.1. Experimental Results for Classification

In these experiments, the side length of the local axis-aligned cube d is set to 0.2. The encoded point is located at the center of the axis-aligned cube. The parameter N is set to 2. Two points are randomly selected from all of the points in the local region to encode the center point. If the number of points in the local region is less than two, the zero vector is used to guarantee the consistency of the feature dimensions. Each point is represented using XYZ channels for object classification. Therefore, the dimension of the feature representation is 2 × 3 here.
Because only 1024 points are used in each object, the ConvNet takes as input the feature representation with dimensions of 1024 × 2 × 3. The block only contains one convolution layer with 64 output channels. It outputs a new feature with dimensions of 1024 × 1 × 64. The detailed structure for the block is shown in Table 1.
During the training, the batch size is set to 64 to improve the training speed. The maximum epoch is set to 500. The data are augmented on-the-fly by randomly setting the coordinates of some points to 0. To prevent overfitting, the training model is evaluated in each epoch, and only the best training model is saved. Other parameter settings in PointNet are not changed.
The experimental results are shown in Table 2. The overall accuracy (acc_cla) is the classification accuracy for all of the objects. The accuracy avg. class (acc_avg_cla) represents the average class accuracy that is obtained by averaging the accuracy of all categories. Note that all results are presented as a percentage in this paper. The calculation process of overall accuracy and accuracy avg. class is also given in the following equations:
a c c _ c l a = T A
where T indicates the number of the objects that are correctly classified, and A represents the total number of the objects.
a c c _ a v g _ c l a = 1 M i = 1 M T i A i
where Ti indicates the number of the category i that are correctly classified, and Ai represents the total number of the category i. M is the number of the categories.
As shown in Table 2, the proposed method is compared with other traditional methods and deep learning methods. It is obvious that the proposed method obtains a better classification accuracy than traditional methods where a point is not the input format. Moreover, the proposed method performs better than PointNet which uses points as the input. However, the input and feature transformation already exist in the PointNet. PointNet also includes a regularization term in its loss. These additional items make the network very complex. The proposed method without these items is very simple compared with PointNet, but it achieves an enhancement in accuracy. This shows that the proposed point cloud encoding method plays an important role in improving the classification accuracy of the network. The proposed method encodes more local spatial information into the feature representation of each point. These features have stronger ability to represent the point cloud structure of an object. They give the simple networks an opportunity to achieve high accuracy.

4.2.2. Classification Details for Each Category

To show the classification accuracy of each category, the accuracies for individual categories are given in Table 3. The proposed method performs better for some categories such as airplane, bowl, and laptop, while it encounters difficulties in handling some categories such as cup and flowerpot. The quality of the point cloud depends on various factors such as shape, size, and transparency of the objects. The classification performance of the proposed method is related to the specific categories. Therefore, the classification accuracies of the proposed method on different categories are different. However, excluding the flowerpot, the classification accuracies of all categories are greater than or equal to 65%. Among the 40 categories, only 9 categories have classification accuracies below 80%. This shows that the proposed method can effectively identify most object categories.

4.3. Experiments for 3D Semantic Segmentation

For a fair comparison, the proposed method is evaluated directly on the S3DIS dataset provided by Charles et al. [11]. Six-fold cross validation is used in the experiments that train six models. For example, to obtain model 1, areas 2−6 are chosen as the training set and area 1 is used as the test set. Six models are evaluated on their corresponding test areas. The overall segmentation accuracy is obtained based on these six models. The overall accuracy (acc_seg) is the point classification accuracy. The intersection over union (IoU) is used to define the average IoU (mIoU). mIoU is the average point classification accuracy across 13 classes, including clutter.
a c c _ s e g = T C / A C
where TC is the number of points that are correctly classified, and AC is the total number of points that are predicted.
{ I o U i = T C i G T i + A C i T C i m I o U = 1 M i = 1 M I o U i
where TCi is the number of the points belonging to the category i and correctly classified, and ACi is the total number of the points predicted to belong to the category i. GTi is the ground truth number for the category i, and M is the total number of the categories. IoUi is the IoU value for the category i.
In these experiments, the side length of the local axis-aligned cube d is set to 0.1 m. The parameter N is set to 4. Four points in the local region are randomly selected to encode the center point. Each point is represented using XYZ, RGB and normalized location as to the room. Therefore, the feature representation dimension of each point is 4 × 9.
Because each room block contains 4096 points, these feature representations with dimensions of 4096 × 4 × 9 are input to the ConvNet. The ConvNet block outputs a new feature with dimensions of 4096 × 1 × 64. The detailed structure for the block is shown in Table 4.
During the training, the maximum epoch is set to 40. To prevent overfitting, the training model is evaluated for every epoch, and only the best model is saved. Other parameter settings are identical to those in PointNet. The experimental results are shown in Table 5. The semantic segmentation results of some rooms are visualized in Figure 7. Some walls are removed in order to clearly show the indoor objects.
It is clear that the proposed method performs better than PointNet. It is worth noting that the proposed method is combined with a simplified PointNet. The complexity of the simplified PointNet is lower than that of PointNet. However, the proposed method outperforms the PointNet in accuracy and average IoU. It shows that the proposed method effectively utilizes the local structure information of the point cloud. These encoded features provide more discriminative semantic information for the deep learning network. They make it easier for the simple network to recognize the fine-grained features of the objects.

4.4. Sensitivity Experiments and Analyses

The proposed method contains two parameters d and N. The axis-aligned cube side length d determines the size of the local region. The feature representation dimension N determines the number of the points that are used to build the corresponding feature representation. These experiments are completed for two 3D data analysis tasks based on two different datasets.

4.4.1. Sensitivity Analyses for 3D Object Classification

Sensitivity experiments are conducted based on the ModelNet40 dataset for 3D object classification. The overall accuracy is chosen as the metric in these experiments. Because all of the points are normalized to a unit sphere for ModelNet40, the axis-aligned cube side length is less than one. The parameter d is set to 0.1, 0.2, 0.3, and 0.4. The parameter N is set to 1, 2, 3, 4, and 5. A total of 20 experiments are conducted in this section.
It should be pointed out that the ConvNet block is slightly different for the feature representations with different dimensions. The specific structure is shown in Table 6. The ConvNet has only one convolution layer when the N value is less than three. There are two convolution layers in this block when the N value is larger than three. Moreover, only small convolution kernels are used in this block, which guarantees lower network complexity. The moving step size of the convolution kernel is 1 × 1, and the corresponding number of the output channels is 64 for each convolution layer.
Each value of the parameter d corresponds to multiple values of parameter N. Similarly, each N also corresponds to different d values. Therefore, each parameter corresponds to multiple experimental results. The average for all of these results are used to display the effects of the corresponding parameter. These experimental results are shown in Figure 8and Figure 9. The scale on the left indicates the classification accuracy corresponding to each pair of parameter combinations. The scale on the right indicates the average classification accuracy that is represented using a polyline. The average classification accuracy is selected as the primary analysis result for convenience.
As shown in Figure 8, the average classification accuracy increases when d varies from 0.1 to 0.2, and then decreases as d varies from 0.2 to 0.4. The local region used to encode a point is very small when d is too small. The small local region contains less local spatial information. The local structure information of the point cloud cannot be fully utilized. Therefore, the average classification accuracy is low when d is small. However, the accuracy is still low when d is very big. The big d value means that the local region of the point is big. Therefore, the overlap of the local regions between different points will become large. This makes the feature representations of the different points become similar. The similarity is not conducive to the deep learning network to classify the point cloud objects.
As can be seen from Figure 9, the average classification accuracy increases as N varies from 1 to 2 and drops as N varies from 2 to 5. N is the number of points that are used to encode a point. The feature representation of the point cannot fully take advantage of the local information when N is too small. Therefore, the accuracy is low when N is small. However, the average classification accuracy drops when more points are used to encode the point. There are two reasons for this situation. On the one hand, more points usually correspond to a large local space. The large local space reduces the difference in feature representations between points. On the other hand, if the local space is small and only contains few points, more zero vectors will be added to the feature representation based on the proposed method. The feature representations become sparse, which is also not beneficial for the deep learning network to classify the objects. Therefore, the average classification accuracy is also low when the N value is big.
Comparing Figure 8 and Figure 9, the average classification accuracy shows a similar trend with changes in parameters d and N. It reflects that there is a strong correlation between these two parameters. The big cube side length d builds a large local region. More points are contained in the large local region, which guarantees the density of the feature representation even if N is big. However, the large local space and high feature dimension reduce the difference of the feature representations between different points. Similarly, the small local region and low feature dimension cannot make full use of the local spatial information of the point cloud. Therefore, the average classification accuracy drops if these two parameters are too large or too small.
The relationship between these two parameters is further explored based on classification accuracy. If the local region is large but the feature dimension is low, more points are available to construct the feature representation. However, these features utilize a larger space that may reduce the difference between feature representations. Therefore, the classification accuracy is low when the local region is large and the feature dimension is low. In addition, if the local region is small but the feature dimension is high, a small number of points are available and the feature representation may be sparse. This situation is also not conducive to improvement in classification accuracy.
It is clear that these two parameters interact with each other. It is important to ensure that the feature representation is not only dense but also can make proper use of local spatial information. Based on the above analyses, the d value is recommended in the interval of [0.2, 0.3] and the N value is recommended in the set of {2, 3, 4}.

4.4.2. Sensitivity Analyses for Semantic Segmentation

Several experiments are conducted based on the S3DIS dataset for 3D semantic segmentation. The overall accuracy is selected as the main metric. The rooms are sampled into blocks with 1 m × 1 m for the S3DIS dataset, and the cube side length is less than 1 m. It is noted that semantic segmentation is essentially the classification of the points. It may be disadvantageous to build a large local region. Therefore, the parameter d is set to 0.1, 0.2 and 0.3. In addition, the point in S3DIS is represented using a vector with nine dimensions, and the data will take up a lot of computer memory if the N is set to very big. The parameter N is set to 1, 2, 3, and 4. A total of 12 experiments are completed in this section. These results are not averaged, but are directly shown in Figure 10.
The specific structure of the ConvNet is shown in Table 7. The ConvNet only contains one convolution layer. The convolution kernel size is consistent with the feature dimension, and the size increases as the dimension increases. The convolution stride is 1 × 1, and the corresponding number of the output channels is 64 for each convolution layer.
As shown in Figure 10, semantic segmentation accuracy increases as the N varies from 1 to 4 for each fixed d value. More points are used to encode the center point when N is larger. The feature representation of the center point contains rich local information. The local information is beneficial for the deep learning network to learn the distinguishing semantic information. Therefore, the semantic segmentation accuracy is high when N is set a large value.
The semantic segmentation accuracy drops as the d value increases when the N value is fixed. A Large d value means large local region. The feature representation of each point can make use of a large local space. However, the large local space reduces the difference between point features. It is difficult for the deep learning network to distinguish each point when the difference is small. Therefore, the large local region is not conducive to improvement in semantic segmentation accuracy.
The semantic segmentation accuracy obtains the best result when the d is set to 0.1 and the N is set to 4. It reflects that more points belonging to a small local region can build more distinctive semantic features. The small local space guarantees the spatial difference between point features, and more points ensure the richness of the local information. Therefore, setting smaller local region and bigger feature dimension is beneficial for improving the semantic segmentation accuracy.

4.5. Discussions

Local information is critical to improving the performance of deep learning networks. However, the deep learning methods that directly process points cannot effectively use the local information of the point cloud. The proposed method encodes the local information into the new feature representation of each point. Experimental results show that the proposed method obtains high accuracy on 3D classification and semantic segmentation tasks. It is worth noting that the proposed method only uses the simplified PointNet. This suggests that the proposed method can effectively utilize the local information of the point cloud and improve network performance. The proposed method achieves higher accuracy based on ModelNet40 and S3DIS datasets. It suggests that the proposed method has good generalization performance for different datasets on different tasks. The sensitivity experiments suggest that the large local region reduces the difference between point features. The dense point features help improve the accuracy of the deep learning networks.
The axis-aligned cube side length and the feature dimension are two important parameters. They can significantly affect the performance of the proposed method. Moreover, the two parameters interact with each other. It is difficult to choose the optimal combination of these two parameters. Evolutionary algorithms [35] are good at finding the optimal solution of a problem. In the future, the authors will design a suitable objective function to search for the optimal combination of the two parameters.

5. Conclusions and Future Work

This paper proposed an effective point cloud encoding method, which enhances the ability of the deep learning network to utilize the local structural information. Two datasets, ModelNet40 and S3DIS, were respectively used for object classification and semantic segmentation. Experimental results shown that the proposed method with the simplified PointNet remained high in accuracy compared with other methods based on complex networks. The main contributions of this paper are summarized as follows:
  • The raw point cloud is encoded into the corresponding feature representations with local information. The point cloud encoding method facilitates the deep leaning network to extract more discriminative features.
  • The axis-aligned cube that can improve the search speed is used to search for a local region. Partial points in the local region are selected to construct the feature representation of a point with low computation complexity.
  • The proposed method reduces the complexity of the network while remaining high in accuracy in classification and segmentation tasks.
The feature dimensions of each point remain the same to meet the requirements of the convolutional networks. The zero vectors are introduced into the feature representation when the number of points in the local region is not enough to construct the feature representation. This may result in sparse features that are not conducive to accuracy improvement. In future work, we will improve the convolutional networks to handle the input data with different dimensions. In addition, the parameters in the proposed method are set manually, and it is also an interesting work to search for the optimal value using evolutionary algorithms.

Author Contributions

Conceptualization, Y.S., X.L. and W.S.; methodology, Y.S., L.G. and W.S.; software, L.G. and W.S.; validation, Y.S., L.G. and W.S.; formal analysis, Y.S. and X.L.; investigation, Y.S. and L.G.; resources, Y.S. and X.L.; data curation, Y.S. and X.L.; writing—original draft preparation, Y.S.; writing—review and editing, L.G., X.L. and W.S.; visualization, Y.S.; supervision, L.G., X.L. and W.S.; project administration, X.L.; funding acquisition, X.L. and L.G. All authors have read and agreed to the published version of the manuscript.

Funding

This work was supported by the National Key Research and Development Project (Grant Numbers 2018AAA0101704 and 2019YFB1704603) and Program for HUST Academic Frontier Youth Team (Grant Number 2017QYTD04).

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Wang, S.J.; Liu, B.; Chen, Z.; Li, H.P.; Jiang, S. The Segmentation Method of Target Point Cloud for Polarization-Modulated 3D Imaging. Sensors 2020, 20, 179. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  2. Cai, G.R.; Jiang, Z.N.; Wang, Z.Y.; Huang, S.F.; Chen, K.; Ge, X.Y.; Wu, Y.D. Spatial Aggregation Net: Point Cloud Semantic Segmentation Based on Multi-Directional Convolution. Sensors 2019, 19, 4329. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  3. Hu, F.C.; Yang, D.; Li, Y.G. Combined Edge- and Stixel-based Object Detection in 3D Point Cloud. Sensors 2019, 19, 4423. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  4. Xu, J.; Ma, Y.X.; He, S.H.; Zhu, J.H. 3D-GIoU: 3D Generalized Intersection over Union for Object Detection in Point Cloud. Sensors 2019, 19, 4093. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  5. Wen, L.; Gao, L.; Li, X.Y. A New Deep Transfer Learning Based on Sparse Auto-Encoder for Fault Diagnosis. IEEE Trans. Syst. Man Cybern. Syst. 2019, 49, 136–144. [Google Scholar] [CrossRef]
  6. Zhang, Y.Y.; Li, X.Y.; Gao, L.; Li, P.G. A new subset based deep feature learning method for intelligent fault diagnosis of bearing. Expert Syst. Appl. 2018, 110, 125–142. [Google Scholar] [CrossRef]
  7. Makkie, M.; Huang, H.; Zhao, Y.; Vasilakos, A.V.; Liu, T.M. Fast and scalable distributed deep convolutional autoencoder for fMRI big data analytics. Neurocomputing 2019, 325, 20–30. [Google Scholar] [CrossRef] [PubMed]
  8. Song, Y.; Gao, L.; Li, X.; Shen, W. A novel robotic grasp detection method based on region proposal networks. Robot. Comput.-Integr. Manuf. 2020, 65, 101963. [Google Scholar] [CrossRef]
  9. Maturana, D.; Scherer, S. Voxnet: A 3d convolutional neural network for real-time object recognition. In Proceedings of the International Conference on Intelligent Robots and Systems, Hamburg, Germany, 28 September–2 October 2015; pp. 922–928. [Google Scholar]
  10. Zhang, L.; Sun, J.; Zheng, Q. 3D Point Cloud Recognition Based on a Multi-View Convolutional Neural Network. Sensors 2018, 18, 3681. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  11. Charles, R.Q.; Su, H.; Mo, K.; Guibas, L.J. PointNet: Deep Learning on Point Sets for 3D Classification and Segmentation. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Honolulu, HI, USA, 21–26 July 2017; pp. 77–85. [Google Scholar]
  12. Cao, L.; Wang, Y.F.; Zhang, B.; Jin, Q.; Vasilakos, A.V. GCHAR: An efficient Group-based Context-aware human activity recognition on smartphone. J. Parallel Distrib. Comput. 2018, 118, 67–80. [Google Scholar] [CrossRef]
  13. Qi, C.R.; Yi, L.; Su, H.; Guibas, L.J. Pointnet++: Deep hierarchical feature learning on point sets in a metric space. In Proceedings of the Advances in Neural Information Processing Systems, Long Beach, CA, USA, 4–9 December 2017; pp. 5099–5108. [Google Scholar]
  14. Landrieu, L.; Simonovsky, M. Large-Scale Point Cloud Semantic Segmentation with Superpoint Graphs. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Salt Lake City, UT, USA, 18–22 June 2018; pp. 4558–4567. [Google Scholar]
  15. Li, J.; Chen, B.M.; Hee Lee, G. SO-Net: Self-organizing network for point cloud analysis. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Salt Lake City, UT, USA, 18–22 June 2018; pp. 9397–9406. [Google Scholar]
  16. Wu, Z.; Song, S.; Khosla, A.; Yu, F.; Zhang, L.; Tang, X.; Xiao, J. 3D ShapeNets: A deep representation for volumetric shapes. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Boston, MA, USA, 7–12 June 2015; pp. 1912–1920. [Google Scholar]
  17. Armeni, I.; Sener, O.; Zamir, A.R.; Jiang, H.; Brilakis, I.; Fischer, M.; Savarese, S. 3D Semantic Parsing of Large-Scale Indoor Spaces. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Las Vegas, NV, USA, 26 June–1 July 2016; pp. 1534–1543. [Google Scholar]
  18. Chen, D.Y.; Tian, X.P.; Shen, Y.T.; Ouhyoung, M. On visual similarity based 3D model retrieval. Comput. Graph. Forum 2003, 22, 223–232. [Google Scholar] [CrossRef]
  19. Kazhdan, M.; Funkhouser, T.; Rusinkiewicz, S. Rotation invariant spherical harmonic representation of 3D shape descriptors. In Proceedings of the Symposium on geometry processing, Aachen, Germany, 23–25 June 2003; pp. 156–164. [Google Scholar]
  20. Savelonas, M.A.; Pratikakis, I.; Sfikas, K. Fisher encoding of differential fast point feature histograms for partial 3D object retrieval. Pattern Recognit. 2016, 55, 114–124. [Google Scholar] [CrossRef]
  21. Aubry, M.; Schlickewei, U.; Cremers, D. The wave kernel signature: A quantum mechanical approach to shape analysis. In Proceedings of the IEEE International Conference on Computer Vision Workshops, Barcelona, Spain, 6–13 November 2011; pp. 1626–1633. [Google Scholar]
  22. Ji, S.W.; Xu, W.; Yang, M.; Yu, K. 3D Convolutional Neural Networks for Human Action Recognition. IEEE Trans. Pattern Anal. Mach. Intell. 2013, 35, 221–231. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  23. Dou, Q.; Chen, H.; Yu, L.Q.; Zhao, L.; Qin, J.; Wang, D.F.; Mok, V.C.T.; Shi, L.; Heng, P.A. Automatic Detection of Cerebral Microbleeds From MR Images via 3D Convolutional Neural Networks. IEEE Trans. Med. Imaging 2016, 35, 1182–1195. [Google Scholar] [CrossRef] [PubMed]
  24. Qi, C.R.; Su, H.; Nießner, M.; Dai, A.; Yan, M.; Guibas, L.J. Volumetric and Multi-view CNNs for Object Classification on 3D Data. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Las Vegas, NV, USA, 26 June–1 July 2016; pp. 5648–5656. [Google Scholar]
  25. Li, Y.; Pirk, S.; Su, H.; Qi, C.R.; Guibas, L.J. FPNN: Field Probing Neural Networks for 3D Data. In Proceedings of the Advances in Neural Information Processing Systems, Barcelona, Spain, 5–10 December 2016; pp. 307–315. [Google Scholar]
  26. Riegler, G.; Ulusoy, A.O.; Geiger, A. Octnet: Learning deep 3D representations at high resolutions. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Honolulu, HI, USA, 21–26 July 2017; pp. 3577–3586. [Google Scholar]
  27. Engelcke, M.; Rao, D.; Wang, D.Z.; Tong, C.H.; Posner, I. Vote3deep: Fast object detection in 3d point clouds using efficient convolutional neural networks. In Proceedings of the IEEE International Conference on Robotics and Automation, Marina Bay, Singapore, 29 May–3 June 2017; pp. 1355–1361. [Google Scholar]
  28. Pang, G.; Neumann, U. 3d point cloud object detection with multi-view convolutional neural network. In Proceedings of the International Conference on Pattern Recognition, Cancun, Mexico, 4–8 December 2016; pp. 585–590. [Google Scholar]
  29. Shi, B.; Bai, S.; Zhou, Z.; Bai, X. Deeppano: Deep panoramic representation for 3-D shape recognition. IEEE Signal Process. Lett. 2015, 22, 2339–2343. [Google Scholar] [CrossRef]
  30. Su, H.; Maji, S.; Kalogerakis, E.; Learned-Miller, E. Multi-view convolutional neural networks for 3d shape recognition. In Proceedings of the IEEE International Conference on Computer Vision, Santiago, Chile, 11–18 December 2015; pp. 945–953. [Google Scholar]
  31. Huang, Q.; Wang, W.; Neumann, U. Recurrent Slice Networks for 3D Segmentation of Point Clouds. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Salt Lake City, UT, USA, 18–22 June 2018; pp. 2626–2635. [Google Scholar]
  32. Wang, W.Y.; Yu, R.; Huang, Q.G.; Neumann, U. SGPN: Similarity Group Proposal Network for 3D Point Cloud Instance Segmentation. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition, Salt Lake City, UT, USA, 18–22 June 2018; pp. 2569–2578. [Google Scholar]
  33. Meagher, D. Geometric modeling using octree encoding. Comput. Graph. Image Process. 1982, 19, 129–147. [Google Scholar] [CrossRef]
  34. Xia, Z.H.; Xiong, N.N.; Vasilakos, A.V.; Sun, X.M. EPCBIR: An efficient and privacy-preserving content-based image retrieval scheme in cloud computing. Inf. Sci. 2017, 387, 195–204. [Google Scholar] [CrossRef]
  35. Song, Y.N.; Pan, Q.K.; Gao, L.; Zhang, B. Improved non-maximum suppression for object detection using harmony search algorithm. Appl. Soft Comput. 2019, 81, 105478. [Google Scholar] [CrossRef]
Figure 1. The overall framework of the proposed method.
Figure 1. The overall framework of the proposed method.
Sensors 20 02501 g001
Figure 2. The local region searched by an axis-aligned cube.
Figure 2. The local region searched by an axis-aligned cube.
Sensors 20 02501 g002
Figure 3. The process of encoding the center point.
Figure 3. The process of encoding the center point.
Sensors 20 02501 g003
Figure 4. The network architecture for 3D object classification.
Figure 4. The network architecture for 3D object classification.
Sensors 20 02501 g004
Figure 5. The network architecture for 3D semantic segmentation.
Figure 5. The network architecture for 3D semantic segmentation.
Sensors 20 02501 g005
Figure 6. The feature representations are operated by one-dimensional convolution.
Figure 6. The feature representations are operated by one-dimensional convolution.
Sensors 20 02501 g006
Figure 7. Qualitative results for semantic segmentation.
Figure 7. Qualitative results for semantic segmentation.
Sensors 20 02501 g007
Figure 8. The effects of d on classification accuracy.
Figure 8. The effects of d on classification accuracy.
Sensors 20 02501 g008
Figure 9. The effects of N on classification accuracy.
Figure 9. The effects of N on classification accuracy.
Sensors 20 02501 g009
Figure 10. The effects of d and N on semantic segmentation accuracy.
Figure 10. The effects of d and N on semantic segmentation accuracy.
Sensors 20 02501 g010
Table 1. The detailed structure of the ConvNet for features with dimensions of 1024 × 2 × 3.
Table 1. The detailed structure of the ConvNet for features with dimensions of 1024 × 2 × 3.
TypeKernel SizeStrideChannel
conv1 × 21 × 164
Table 2. The classification results on ModelNet40.
Table 2. The classification results on ModelNet40.
MethodInputViewsAccuracy Avg. ClassOverall Accuracy
SPH [19]mesh-68.2-
3DShapeNets [16]volume177.384.7
VoxNet [9]volume1283.085.9
Subvolume [24]volume2086.089.2
LFD [16]image1075.5-
PointNet [11]point186.289.2
Proposed methodpoint185.589.4
Table 3. The classification accuracy of each category.
Table 3. The classification accuracy of each category.
ClassAccuracyClassAccuracyClassAccuracy
airplane100.0dresser87.2range_hood93.0
bathtub92.0flower_pot15.0sink65.0
bed99.0glass_box97.0sofa97.0
bench80.0guitar96.0stairs85.0
bookshelf97.0keyboard95.0stool75.0
bottle96.0lamp85.0table78.0
bowl100.0laptop100.0tent95.0
car97.0mantel94.0toilet98.0
chair96.0monitor95.0tv_stand88.0
cone95.0night_stand70.9vase80.0
cup65.0person80.0wardrobe65.0
curtain80.0piano88.0xbox85.0
desk88.4plant76.0
door85.0radio65.0
Table 4. The detailed structure of the ConvNet for feature with dimensions of 4096 × 4 × 9.
Table 4. The detailed structure of the ConvNet for feature with dimensions of 4096 × 4 × 9.
TypeKernel SizeStrideChannel
conv1 × 41 × 164
Table 5. The semantic segmentation results on S3DIS dataset.
Table 5. The semantic segmentation results on S3DIS dataset.
MethodAverage IoUOverall Accuracy
PointNet [11]47.7178.62
Proposed method49.0479.57
Table 6. The detailed structure of the ConvNet for different feature dimensions in object classification.
Table 6. The detailed structure of the ConvNet for different feature dimensions in object classification.
Feature DimensionTypeKernel SizeStrideChannel
1024 × 1 × 3conv1 × 11 × 164
1024 × 2 × 3conv1 × 21 × 164
1024 × 3 × 3conv1 × 31 × 164
1024 × 4 × 3conv1 × 3
1 × 2
1 × 1
1 × 1
64
64
1024 × 5 × 3conv1 × 3
1 × 3
1 × 1
1 × 1
64
64
Table 7. The detailed structure of the ConvNet for different feature dimensions in semantic segmentation.
Table 7. The detailed structure of the ConvNet for different feature dimensions in semantic segmentation.
Feature DimensionTypeKernel SizeStrideChannel
4096 × 1 × 9conv1 × 11 × 164
4096 × 2 × 9conv1 × 21 × 164
4096 × 3 × 9conv1 × 31 × 164
4096 × 4 × 9conv1 × 41 × 164

Share and Cite

MDPI and ACS Style

Song, Y.; Gao, L.; Li, X.; Shen, W. A Novel Point Cloud Encoding Method Based on Local Information for 3D Classification and Segmentation. Sensors 2020, 20, 2501. https://doi.org/10.3390/s20092501

AMA Style

Song Y, Gao L, Li X, Shen W. A Novel Point Cloud Encoding Method Based on Local Information for 3D Classification and Segmentation. Sensors. 2020; 20(9):2501. https://doi.org/10.3390/s20092501

Chicago/Turabian Style

Song, Yanan, Liang Gao, Xinyu Li, and Weiming Shen. 2020. "A Novel Point Cloud Encoding Method Based on Local Information for 3D Classification and Segmentation" Sensors 20, no. 9: 2501. https://doi.org/10.3390/s20092501

APA Style

Song, Y., Gao, L., Li, X., & Shen, W. (2020). A Novel Point Cloud Encoding Method Based on Local Information for 3D Classification and Segmentation. Sensors, 20(9), 2501. https://doi.org/10.3390/s20092501

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop