Vote3Deep: Fast Object Detection in 3D Point Clouds Using Efficient Convolutional Neural Networks
This paper proposes a computationally efficient approach to detecting objects natively in 3D point clouds using convolutional neural networks (CNNs). In particular, this is achieved by leveraging a feature-centric voting scheme to implement novel convolutional layers which explicitly exploit the sparsity encountered in the input. To this end, we examine the trade-off between accuracy and speed for different architectures and additionally propose to use an penalty on the filter activations to further encourage sparsity in the intermediate representations. To the best of our knowledge, this is the first work to propose sparse convolutional layers and regularisation for efficient large-scale processing of 3D data. We demonstrate the efficacy of our approach on the KITTI object detection benchmark and show that Vote3Deep models with as few as three layers outperform the previous state of the art in both laser and laser-vision based approaches by margins of up to 40% while remaining highly competitive in terms of processing time.
3D point cloud data is ubiquitous in mobile robotics applications such as autonomous driving, where efficient and robust object detection is pivotal for planning and decision making. Recently, computer vision has been undergoing a transformation through the use of convolutional neural networks (CNNs) (e.g. [1, 2, 3, 4]). Methods which process 3D point clouds, however, have not yet experienced a comparable breakthrough. We attribute this lack of progress to the computational burden introduced by the third spatial dimension. The resulting increase in the size of the input and intermediate representations renders a naive transfer of CNNs from 2D vision applications to native 3D perception in point clouds infeasible for large-scale applications. As a result, previous approaches tend to convert the data into a 2D representation first, where nearby features are not necessarily adjacent in the physical 3D space – requiring models to recover these geometric relationships.
In contrast to image data, however, typical point clouds encountered in mobile robotics are spatially sparse, as most regions are unoccupied. This fact was exploited in , where the authors propose Vote3D, a feature-centric voting algorithm leveraging the sparsity inherent in these point clouds. The computational cost is proportional only to the number of occupied cells rather than the total number of cells in a 3D grid.  proves the equivalence of the voting scheme to a dense convolution operation and demonstrates its effectiveness by discretising point clouds into 3D grids and performing exhaustive 3D sliding window detection with a linear Support Vector Machine (SVM). Consequently,  achieves the previous state of the art in both performance and processing speed for detecting cars, pedestrians and cyclists in point clouds on the object detection task from the popular KITTI Vision Benchmark Suite .
Inspired by , we propose to exploit feature-centric voting to build efficient CNNs to detect objects in point clouds natively in 3D – that is to say without projecting the input into a lower-dimensional space first or constraining the search space of the detector (Fig. 1). This enables our approach, named Vote3Deep, to learn high-capacity, non-linear models while providing constant-time evaluation at test-time, in contrast to non-parametric methods. Furthermore, in order to enhance the computational benefits associated with sparse inputs throughout the entire CNN stack, we demonstrate the benefits of encouraging sparsity in the inputs to intermediate layers by imposing an model regulariser during training.
To the best of our knowledge, this is the first work to propose sparse convolutional layers based on voting and regularisation for efficient processing of full 3D point clouds with CNNs at scale. In particular, the contributions of this paper can be summarised as follows:
the construction of efficient convolutional layers as basic building blocks for CNN-based point cloud processing by leveraging a voting mechanism to exploit the inherent sparsity in the input data;
the use of rectified linear units and an sparsity penalty to specifically encourage data sparsity in the intermediate representations in order to exploit sparse convolutional layers throughout the entire CNN stack.
We demonstrate that Vote3Deep models with as few as three layers achieve state-of-the-art performance amongst purely laser-based approaches across all classes considered on the popular KITTI object detection benchmark. Vote3Deep models exceed the previous state of the art in 3D point cloud based object detection in average precision by a margin of up to 40% while only running slightly slower in terms of detection speed.
Ii Related Work
A number of works have attempted to apply CNNs in the context of 3D point cloud data. A CNN-based approach in  obtains comparable performance to  on KITTI for car detection by projecting the point cloud into a 2D depth map, with an additional channel for the height of a point from the ground. Their model predicts detection scores and regresses to bounding boxes. However, the projection to a specific viewpoint discards valuable information, which is particularly detrimental, for example, in crowded scenes. It also requires the network filters to learn local dependencies with regards to depth, information that is readily available in a 3D representation and which can be efficiently extracted with sparse convolutions.
Dense 3D occupancy grids obtained from point clouds are processed with CNNs in  and . With a minimum cell size of ,  reports a speed of on a GPU to classify a single crop with a grid-size of cells. Similarly, a processing time of per for landing zone detection is reported in . With 3D point clouds often being larger than , this would result in a processing time of per frame, which does not comply with speed requirements typically encountered in robotics applications.
An alternative approach that takes advantage of sparse representations can be found in  and , in which sparse convolutions are applied to comparatively small 2D and 3D crops respectively. While the convolutional kernels are only applied at sparse feature locations, the presented algorithm still has to consider neighbouring values which take a value of either zero or a constant bias, leading to unnecessary operations and memory consumption. Another method for performing sparse convolutions is introduced in  who make use of “permutohedral lattices”, but only consider comparatively small inputs, as opposed to our work.
CNNs have also been applied to dense 3D data in biomedical image analysis (e.g. [13, 14, 15]). A 3D equivalent of residual networks  is utilised in  for brain image segmentation. A cascaded model with two stages is proposed in  for detecting cerebral microbleeds. A combination of three CNNs is suggested in . Each CNN processes a different 2D plane and the three streams are joined in the last layer. These systems run on relatively small inputs and in some cases take more than a minute for processing a single frame with GPU acceleration.
This section describes the application of convolutional neural networks for the prediction of detection scores from sparse 3D input grids of variable sizes. As the input to the network, a point cloud is discretised into a sparse 3D grid as in . For each cell that contains a non-zero number of points, a feature vector is extracted based on the statistics of the points in the cell. The feature vector holds a binary occupancy value, the mean and variance of the reflectance values and three shape factors. Cells in empty space are not stored which leads to a sparse representation.
We employ the voting scheme from  to perform a sparse convolution across this native 3D representation, followed by a ReLU non-linearity, which returns a new sparse 3D representation. This process can be repeated and stacked as in a traditional CNN, with the output layer predicting the detection scores.
Similar to , a CNN is applied to a point cloud at N different angular orientations in N parallel threads to handle objects at different orientations at a minimal increase in computation time. Duplicate detections are pruned with non-maximum suppression (NMS) in 3D space. NMS in 3D is better able to handle objects that are behind each other as the 3D bounding boxes overlap less than their 2D projections.
Based on the premise that bounding boxes in 3D space are similar in size for object instances of the same class, we assume a fixed-size bounding box for each class, which eliminates the need to regress the size of a bounding box. We select 3D bounding box dimensions for each class of interest based on the percentile ground truth bounding box size over the training set.
The receptive field of a network should be at least as large as the bounding box of an object, but not excessively large which would waste computation time. We therefore employ several class-specific networks which can be run in parallel at test time, each with a different total receptive field size depending on the object class. In principle, it is possible to compute detection scores for multiple classes with a single network; a task left for future work.
Iii-a Sparse Convolutions via Voting
When running a dense 3D convolution across a discretised point cloud, most of the computation time is wasted as the majority of operations are multiplications by zero. The additional third spatial dimension makes this process even more computationally expensive compared to 2D convolutions, which form the basis of image-based CNNs.
Using the insight that meaningful computation only takes place where the 3D features are non-zero,  introduce a feature-centric voting scheme. The basis of this algorithm is the idea of letting each non-zero input feature vector cast a set of votes, weighted by the filter weights, to its surrounding cells in the output layer, as defined by the receptive field of the filter. The voting weights are obtained by flipping the convolutional filter kernel along each spatial dimension. The final convolution result is obtained by accumulating the votes falling into each cell of the output (Fig. 2).
This procedure can be formally stated as follows. Without loss of generality, assume we have one 3D convolutional filter with odd-valued kernel dimensions in network layer , operating on a single input feature, with the filter weights denoted by . Then, for an input grid , the convolution result at location is given by:
where is a bias value applied to all cells in the grid. This operation needs to be applied to all locations in the input grid for a regular dense convolution. In contrast to this, given the set of cell indices for all of the non-zero cells , the convolution can be recast as a feature-centric voting operation, with each input cell casting votes to increment the values in neighbouring cell locations according to:
which is repeated for all tuples and where .
The voting output is passed through a ReLU non-linearity which discards non-positive features as described in the next subsection. Crucially, the biases are constrained to be non-positive as a single positive bias would return an output grid in which almost every cell is occupied with a feature vector, hence eliminating sparsity. The bias therefore only needs to be added to each non-empty output cell.
With this sparse voting scheme, the filter only needs to be applied to the occupied cells in the input grid, rather than convolved over the entire grid. The algorithm is described in more detail in , including formal proof that feature-centric voting is equivalent to an exhaustive convolution.
Iii-B Maintaining Sparsity with ReLUs
The ability to perform fast voting in all layers is predicated on the assumption of sparsity in the input to each individual layer. While the input point cloud is sparse, the regions of non-empty cells are dilated by each successive convolutional layer, approximately by the receptive field size of the corresponding filters in the layer. It is therefore critical to select a non-linear activation function which helps to maintain sparsity in the inputs to each convolutional layer.
This is achieved by applying a rectified linear unit (ReLU) as advocated in  after a sparse convolutional layer. The ReLU activation can be written as:
with being the input to the ReLU non-linearity in layer as computed by a sparse convolution, and being the output, denoting the hidden activations in the subsequent sparse intermediate representation.
In this case, only features that have a value greater than zero will be allowed to cast votes in the next sparse convolution layer. In addition to enabling a network to learn non-linear function approximations and therefore increasing its representational capacity, ReLUs effectively perform a thresholding operation by discarding negative feature values which helps to maintain sparsity in the intermediate representations. Lastly, a further advantage of ReLUs compared to other non-linearities is that they are fast to compute.
Due to the use of fixed-size bounding boxes, networks can be directly trained on 3D crops of positive and negative examples whose dimensions equal the receptive field size specified by the architecture.
Negative training examples are obtained by performing hard negative mining periodically after a fixed number of training epochs. The class-specific networks are binary classifiers and we choose a linear hinge loss for training due to its maximum margin property.
Iv-a Linear Hinge Loss
Given an output detection score , a class label distinguishing between positive and negative samples, and the parameters of the network denoted as , the hinge loss is formulated as:
The loss in Eq. 4 is zero for positive samples that score over and negative samples that score below . As such, the hinge loss drives sample scores away from the margin given by the interval . As with standard CNNs, the hinge loss can be backpropagated through the network for training.
|Model||Layer 1||Layer 2||Layer 3|
Iv-B Sparsity Penalty
While the ReLU non-linearity helps to maintain sparsity in the intermediate representations, we propose to include an additional regulariser to incite the network to discard uninformative features and increase sparsity throughout the entire CNN stack.
The loss has been shown to result in sparse representations with values being exactly zero , which is precisely the requirement for this model. Whereas the sparsity of the output layer can be tuned with a detection threshold, we encourage sparsity in the intermediate layers by incorporating a penalty term using the norm of each feature activation.
We normalise this loss with respect to the spatial dimensions of the feature map in each layer. This renders the influence of the sparsity penalty less dependent on the size of the input for a given parameter setting.
We use the well-known KITTI Vision Benchmark Suite  for training and evaluating our detection models. The dataset consists of synchronised stereo camera and lidar frames recorded from a moving vehicle with annotations for eight different object classes, showing a wide variety of road scenes with different appearances. We only use the 3D point cloud data to train and test the models.
There are 7,518 frames in the KITTI test set whose labels are not publicly available. The labelled training data consist of 7,481 frames which we split into two sets for training and validation ( and respectively). The object detection benchmark considers three classes for evaluation: cars, pedestrians and cyclists with 28,742; 4,487; and 1,627 training labels, respectively.
The benchmark evaluation on the official KITTI test set is performed in 2D image space. We therefore project our 3D detections into the 2D image plane using the provided calibration files and discard any detections that fall outside of the image.
The KITTI benchmark differentiates between easy, moderate and hard test categories depending on the bounding box size, object truncation and occlusion. The hard test case considers the largest number of positives, whereas the most difficult examples are subsequently ignored for the moderate and easy test cases. The official rankings are based on the average precision (AP) for the moderate cases.
After describing the training procedure, we present results for three experiments. Firstly, we conduct a model comparison on the validation set (Section V-D). Secondly, based on the results of the model comparison, we select one model for each class and report results on the official KITTI test set (Section V-E). Lastly, we compare the timing results of models that were trained with and without the sparsity penalty (Section V-F).
The networks are trained on 3D crops of positive and negative examples. The number of positives and negatives is initially balanced with negatives being extracted randomly from the training data at locations that do not overlap with any of the positives.
In order to improve generalisation and to compensate for the fact that the input is discretised both spatially as well as in terms of angular resolution, the training data is augmented by translating the original front-facing positive training examples by a distance smaller than the size of the 3D grid cells and randomly rotating them by an angle that is smaller than the resolution of the angular bins.
Hard negative mining is performed every ten epochs by running the current model across the full point clouds in the training set. In each round of hard negative mining, the ten highest scoring false positives per frame are added to the training set.
The filter weights are initialised as in  and the networks are trained for 100 epochs with stochastic gradient descent with a momentum term of 0.9, a batchsize of 16, a constant learning rate of and weight decay of . The model from the epoch with the highest AP on the validation set is selected for the model comparison and the test submission.
For the timing experiments, we observed that selecting the models from the epoch with the highest AP on the validation set tends to favour models with a comparatively low sparsity in the intermediate representations. Thus, the models after the full 100 epochs of training are used for the timing experiments to enable a fair comparison.
We implemented a custom C++ library for training and testing. For the largest models, training takes about three days on a cluster CPU node with 16 cores where each example in a batch is processed in a separate thread.
V-D Model Comparison
|Vote3Deep||4-core 2.5GHz CPU||1.1s||76.79||68.24||63.23||68.39||55.37||52.59||79.92||67.88||62.98|
|Vote3D ||4-core 2.8GHz CPU||0.5s||56.80||47.99||42.56||44.48||35.74||33.72||41.43||31.24||28.60|
|VeloFCN ||2.5GHz GPU||1.0s||60.34||47.51||42.74||-||-||-||-||-||-|
|CSoR||4-core 3.5GHz CPU||3.5s||34.79||26.13||22.69||-||-||-||-||-||-|
|mBoW ||1-core 2.5GHz CPU||10s||36.02||23.76||18.44||44.28||31.37||30.62||28.00||21.62||20.93|
|Vote3Deep||4-core 2.5GHz CPU||1.1s||76.79||68.24||63.23||68.39||55.37||52.59||79.92||67.88||62.98|
|MV-RGBD-RF* ||4-core 2.5GHz CPU||4s||76.40||69.92||57.47||73.30||56.59||49.63||52.97||42.61||37.42|
|Fusion-DPM* ||1-core 3.5GHz CPU||30s||-||-||-||59.51||46.67||42.05||-||-||-|
Fast detection speeds are particularly important in the context of robotics. As larger, more expressive models come at a higher computational cost and consequently run at slower speeds, this section investigates the trade-off between model capacity and detection performance on the validation set. Five architectures as summarised in Table I with up to three layers and different filter configurations are benchmarked against each other. The “Model D” architecture is illustrated as an example in Figure 3.
Small and kernels are used in the lower layers, followed by a ReLU non-linearity. The architectures are designed so that the total receptive field is slightly larger than the class-specific bounding boxes. The network output is computed by a linear layer which is implemented as a convolutional filter whose kernel size gives the desired receptive field size for a given object class.
As can be seen in Fig. 4, the non-linear, multi-layer networks clearly outperform the linear baseline, which is comparable to . First and foremost, this demonstrates that increasing the complexity and expressiveness of the models is extremely helpful for detecting objects in point clouds.
The resulting gains when increasing the number of convolutional filters in the hidden layers are moderate compared to the large improvement over the baseline which is achieved with only eight filters. Similarly, increasing the receptive field of the filter kernels, while keeping the total receptive field of the networks the same, does not indicate a significant improvement in performance.
It is possible that these larger models are not sufficiently regularised. Another potential explanation is that the easy interpretability of 3D data enables even relatively small models to capture most of the variation in the input representation which is informative for solving the task.
V-E Test Results
As the model comparison shows, increasing the number of filters or the kernel size does not significantly improve accuracy, while inevitably deteriorating the detection speed. Consequently, we choose to limit ourselves to eight filters in each of the hidden layers for the test submission.
As the models can be run in parallel during deployment, they should ideally run at approximately the same detection speed. Due to the larger physical size of cars, compared to pedestrians and cyclists, the corresponding networks need a larger filter kernel in the output layer to achieve the required total receptive field, having a negative effect on detection speed. For the submission to the KITTI test server, we therefore select the “Model B” with two layers for cars, and the “Model D” with three layers for pedestrians and cyclists. The PR curves of these models on the KITTI test set are shown in Figure 5.
The performance of Vote3Deep is compared against the other leading approaches for object detection in point clouds at the time of writing in Table II. Vote3Deep establishes new state-of-the-art performance in this category for all three classes and all three difficulty levels. The performance boost is particularly significant for cyclists with a margin of almost 40% in the easy test case and more than doubling the AP in the other two test cases.
Vote3Deep currently runs on CPU and is about two times slower than  and almost as fast as , with the latter relying on GPU acceleration. We expect that a GPU implementation of the sparse convolution layers will further improve the detection speed.
We also compare Vote3Deep against methods that utilise both point cloud and image data at the time of writing in Table III. Despite only using point cloud data, Vote3Deep still performs better than these ([20, 21]) in the majority of test cases and only slightly worse in the remaining ones at a considerably faster detection speed. For all three object classes, Vote3Deep achieves the highest AP on the hard test cases, which considers the largest number of positive ground truth objects.
Overall, compared to the very deep networks used in vision (e.g. [2, 3, 4]), these relatively shallow networks trained without any of the recently developed tricks are expressive enough to achieve significant performance gains.
Interestingly, cyclist detection benefits the most from the expressiveness of CNNs even though this class has the least number of training examples. We conjecture that cyclists have a more distinctive shape in 3D compared to pedestrians and cars, which can be more easily confused with poles or vertical planes, respectively, and that Vote3Deep models can exploit this complexity particularly well, despite the small number of positive training examples.
V-F Timing and Sparsity
The three models from the test submission are also trained with different values for the sparsity penalty to examine the effect of the penalty on detection speed and accuracy on the moderate test cases of the validation set in Table IV. The mean and standard deviation of the detection time per frame are measured on 200 frames.
Independent of whether the sparsity penalty is employed or not, pedestrians have the fastest detection speed as the receptive field of the networks is smaller compared to the other two classes. The two-layer “Model B” for cars runs faster than the three-layer “Model D” for cyclists.
When imposing the sparsity penalty during training, the detection speed at test time is improved by almost 40% for cars at a negligible decrease in accuracy. When applying a large penalty of , the activations of the pedestrian and cyclists models collapse to zero during training. Yet, with a smaller penalty the detection speeds improve by about 15%.
For the fastest cyclist model, the average precision decreases by 5% compared to the baseline. For pedestrians, however, we noted that the model without a penalty starts to overfit when training for the full 100 epochs. In this case, the sparsity penalty helps to regularise the model and has a beneficial effect on the model’s accuracy.
Notably, the sparsity penalty proves to be most useful for increasing the detection speed for cars where a larger penalty can be applied. We conjecture that both the reduced number of intermediate layers as well as the larger receptive field help the model to learn significantly sparser, yet still highly informative, intermediate representations.
While the results clearly indicate that the L1 sparsity penalty has a beneficial effect on detection speed, a more rigorous investigation into the statistics of this gain would be useful, given the stochastic nature of the training algorithm. We leave this investigation for future work.
This work performs object detection in point clouds at fast speeds with CNNs constructed from sparse convolutional layers based on the voting scheme introduced in . With the ability to learn hierarchical representations and non-linear decision boundaries, a new state of the art is established on the KITTI benchmark for detecting objects in point clouds. Vote3Deep also outperforms other methods that utilise information from both point clouds and images in most test cases. Possible future directions include a more low-level input representation as well as a GPU implementation of the voting algorithm.
The authors would like to acknowledge the support of this work by the EPSRC through grant number DFR01420, a Leadership Fellowship, a grant for Intelligent Workspace Acquisition, and a DTA Studentship; by Google through a studentship; and by the Advanced Research Computing services at the University of Oxford.
-  A. Krizhevsky, I. Sutskever, and G. E. Hinton, “ImageNet Classification with Deep Convolutional Neural Networks,” Advances In Neural Information Processing Systems, pp. 1–9, 2012.
-  K. Simonyan and A. Zisserman, “Very deep convolutional networks for large-scale image recognition,” ICLR, pp. 1–14, 2015. [Online]. Available: http://arxiv.org/abs/1409.1556
-  C. Szegedy, W. Liu, Y. Jia, P. Sermanet, S. Reed, D. Anguelov, D. Erhan, V. Vanhoucke, and A. Rabinovich, “Going deeper with convolutions,” in Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition, vol. 07-12-June, 2015, pp. 1–9.
-  K. He, X. Zhang, S. Ren, and J. Sun, “Deep Residual Learning for Image Recognition,” arXiv preprint arXiv:1512.03385, vol. 7, no. 3, pp. 171–180, 2015. [Online]. Available: http://arxiv.org/pdf/1512.03385v1.pdf
-  D. Z. Wang and I. Posner, “Voting for Voting in Online Point Cloud Object Detection,” Robotics Science and Systems, 2015.
-  A. Geiger, P. Lenz, and R. Urtasun, “Are we ready for autonomous driving? the KITTI vision benchmark suite,” in Proceedings of the IEEE Computer Society Conference on Computer Vision and Pattern Recognition, 2012, pp. 3354–3361.
-  B. Li, T. Zhang, and T. Xia, “Vehicle Detection from 3D Lidar Using Fully Convolutional Network,” arXiv preprint arXiv:1608.07916, 2016. [Online]. Available: https://arxiv.org/abs/1608.07916
-  D. Maturana and S. Scherer, “VoxNet: A 3D Convolutional Neural Network for Real-Time Object Recognition,” IROS, pp. 922–928, 2015.
-  ——, “3D Convolutional Neural Networks for Landing Zone Detection from LiDAR,” International Conference on Robotics and Automation, no. Figure 1, pp. 3471–3478, 2015.
-  B. Graham, “Spatially-sparse convolutional neural networks,” arXiv Preprint arXiv:1409.6070, pp. 1–13, 2014. [Online]. Available: http://arxiv.org/abs/1409.6070
-  ——, “Sparse 3D convolutional neural networks,” arXiv preprint arXiv:1505.02890, pp. 1–10, 2015. [Online]. Available: http://arxiv.org/abs/1505.02890
-  V. Jampani, M. Kiefel, and P. V. Gehler, “Learning Sparse High Dimensional Filters: Image Filtering, Dense CRFs and Bilateral Neural Networks,” in IEEE Conf. on Computer Vision and Pattern Recognition (CVPR), 2016.
-  H. Chen, Q. Dou, L. Yu, and P.-A. Heng, “VoxResNet: Deep Voxelwise Residual Networks for Volumetric Brain Segmentation,” arXiv preprint arXiv:1608.05895, 2016. [Online]. Available: http://arxiv.org/abs/1608.05895
-  Q. Dou, H. Chen, L. Yu, L. Zhao, J. Qin, D. Wang, V. C. Mok, L. Shi, and P. A. Heng, “Automatic Detection of Cerebral Microbleeds From MR Images via 3D Convolutional Neural Networks,” IEEE Transactions on Medical Imaging, vol. 35, no. 5, pp. 1182–1195, 2016. [Online]. Available: http://ieeexplore.ieee.org
-  A. Prasoon, K. Petersen, C. Igel, F. Lauze, E. Dam, and M. Nielsen, “Deep feature learning for knee cartilage segmentation using a triplanar convolutional neural network,” in Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics), vol. 8150 LNCS, no. PART 2, 2013, pp. 246–253.
-  X. Glorot, A. Bordes, and Y. Bengio, “Deep Sparse Rectifier Neural Networks,” AISTATS, vol. 15, pp. 315–323, 2011.
-  K. P. Murphy, Machine Learning: A Probabilistic Perspective. MIT press, 2012, ch. 13, pp. 423–480.
-  K. He, X. Zhang, S. Ren, and J. Sun, “Delving Deep into Rectifiers: Surpassing Human-Level Performance on ImageNet Classification,” arXiv preprint arXiv:1502.01852, pp. 1–11, 2015. [Online]. Available: https://arxiv.org/abs/1502.01852
-  J. Behley, V. Steinhage, and A. B. Cremers, “Laser-based segment classification using a mixture of bag-of-words,” in IEEE International Conference on Intelligent Robots and Systems, 2013, pp. 4195–4200.
-  A. Gonzalez, G. Villalonga, J. Xu, D. Vazquez, J. Amores, and A. M. Lopez, “Multiview random forest of local experts combining RGB and LIDAR data for pedestrian detection,” in IEEE Intelligent Vehicles Symposium, Proceedings, vol. 2015-Augus, 2015, pp. 356–361.
-  C. Premebida, J. Carreira, J. Batista, and U. Nunes, “Pedestrian detection combining RGB and dense LIDAR data,” in IEEE International Conference on Intelligent Robots and Systems, 2014, pp. 4112–4117.