adaptive_oc_tree.h
Go to the documentation of this file.
00001 /*
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2010, AASS Research Center, Orebro University.
00005  *  All rights reserved.
00006  *
00007  *  Redistribution and use in source and binary forms, with or without
00008  *  modification, are permitted provided that the following conditions
00009  *  are met:
00010  *
00011  *   * Redistributions of source code must retain the above copyright
00012  *     notice, this list of conditions and the following disclaimer.
00013  *   * Redistributions in binary form must reproduce the above
00014  *     copyright notice, this list of conditions and the following
00015  *     disclaimer in the documentation and/or other materials provided
00016  *     with the distribution.
00017  *   * Neither the name of AASS Research Center nor the names of its
00018  *     contributors may be used to endorse or promote products derived
00019  *     from this software without specific prior written permission.
00020  *
00021  *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022  *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023  *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024  *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025  *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026  *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027  *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028  *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029  *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030  *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031  *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032  *  POSSIBILITY OF SUCH DAMAGE.
00033  *
00034  */
00035 #ifndef ADAPTIVE_OCT_TREE_HH
00036 #define ADAPTIVE_OCT_TREE_HH
00037 
00038 #include <ndt_map/oc_tree.h>
00039 #include <ndt_map/ndt_cell.h>
00040 #include <vector>
00041 
00042 namespace lslgeneric
00043 {
00044 
00052 template<typename PointT>
00053 class AdaptiveOctTree : public OctTree<PointT>
00054 {
00055 protected:
00056     std::vector<OctTree<PointT>*> splitTree(OctTree<PointT> *leaf);
00057     std::vector<OctTree<PointT>*> myTreeLeafs;
00058     virtual void computeTreeLeafs();
00059 
00060     double computeResidualSquare(NDTCell<PointT> *cell);
00061     double computeDornikHansen(NDTCell<PointT> *cell);
00062 
00063     bool useDornikHansen;
00064     bool useFlatness;
00065     double RSS_THRESHOLD, DH_SIGNIFICANCE_LVL, FLAT_FACTOR;
00066     bool parametersSet;
00067 
00068 public:
00069 
00071     AdaptiveOctTree();
00073     AdaptiveOctTree(pcl::PointXYZ center, double xsize, double ysize,
00074                     double zsize, NDTCell<PointT>* type, OctTree<PointT> *_parent=NULL, unsigned int _depth=0);
00075     virtual ~AdaptiveOctTree();
00076 
00077     virtual void postProcessPoints();
00078     virtual SpatialIndex<PointT>* clone();
00079 
00082     void setParameters(bool _useDornikHansen = false,
00083                        bool _useFlatness = true,
00084                        double _RSS_THRESHOLD = 1000,
00085                        double _DH_SIGNIFICANCE_LVL = 0.5,
00086                        double _MIN_CELL_SIZE = 1,
00087                        double _FLAT_FACTOR = 10,
00088                        double _BIG_CELL_SIZE = 5,
00089                        double _SMALL_CELL_SIZE = 5
00090                       );
00091     double MIN_CELL_SIZE;
00092 
00093 };
00094 
00095 } //end namespace
00096 
00097 #include<ndt_map/impl/adaptive_oc_tree.hpp>
00098 #endif


ndt_map
Author(s): Todor Stoyanov, Jari Saarinen, Henrik Andreasson
autogenerated on Wed Aug 26 2015 15:24:40