1 ///
2 /// Copyright (c) 2012, Texas A&M University
3 /// All rights reserved.
4 ///
5 /// Redistribution and use in source and binary forms, with or without
6 /// modification, are permitted provided that the following conditions
7 /// are met:
8 ///
9 ///  * Redistributions of source code must retain the above copyright
10 ///    notice, this list of conditions and the following disclaimer.
11 ///  * Redistributions in binary form must reproduce the above
12 ///    copyright notice, this list of conditions and the following
13 ///    disclaimer in the documentation and/or other materials provided
14 ///    with the distribution.
15 ///  * Neither the name of Texas A&M University nor the names of its
16 ///    contributors may be used to endorse or promote products derived
17 ///    from this software without specific prior written permission.
18 ///
19 /// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 /// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21 /// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22 /// FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23 /// COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24 /// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25 /// BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
26 /// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27 /// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28 /// LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29 /// ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30 /// POSSIBILITY OF SUCH DAMAGE.
31 ///
32 /// The following software was written as part of a collaboration with the
33 /// University of South Carolina, Interdisciplinary Mathematics Institute.
34 ///
35 
36 /// @file denoiseCommand.cpp
37 /// @details the implementation of the class DenoiseCommand
38 /// @author Yue Li and Matthew Hielsberg
39 
40 #include <pcl/point_types.h>
41 #include <pcl/filters/statistical_outlier_removal.h>
42 #include <pcl/apps/point_cloud_editor/denoiseCommand.h>
43 #include <pcl/apps/point_cloud_editor/selection.h>
44 #include <pcl/apps/point_cloud_editor/cloud.h>
45 
46 void
execute()47 DenoiseCommand::execute ()
48 {
49   Cloud3D temp_cloud;
50   // denoise
51   // uses point neighborhood statistics to filter outlier data.
52   // For a more detailed explanation, see PCL's tutorial on denoising:
53   // http://pointclouds.org/documentation/tutorials/statistical_outlier.php
54   pcl::StatisticalOutlierRemoval<Point3D> filter(true);
55   filter.setInputCloud(cloud_ptr_->getInternalCloud().makeShared());
56   filter.setMeanK(mean_);
57   filter.setStddevMulThresh (threshold_);
58   // filtering and back up
59   filter.setNegative(false);
60   filter.filter(temp_cloud);
61   // back up the removed indices.
62   pcl::IndicesConstPtr indices_ptr = filter.getRemovedIndices();
63   for(const auto &it : *indices_ptr)
64     removed_indices_.addIndex(static_cast<unsigned int>(it));
65   // back up the removed points.
66   removed_points_.set(cloud_ptr_, removed_indices_);
67   // remove the noisy points.
68   cloud_ptr_->remove(removed_indices_);
69   selection_ptr_->clear();
70 }
71 
72 void
undo()73 DenoiseCommand::undo ()
74 {
75   cloud_ptr_->restore(removed_points_, removed_indices_);
76 }
77