pointcloud_model_generator.h
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2015, JSK Lab
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/o2r other materials provided
17  * with the distribution.
18  * * Neither the name of the JSK Lab nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *********************************************************************/
35 
36 
37 #ifndef JSK_FOOTSTEP_PLANNER_POINTCLOUD_MODEL_GENERATOR_H_
38 #define JSK_FOOTSTEP_PLANNER_POINTCLOUD_MODEL_GENERATOR_H_
39 
40 #include <pcl/point_types.h>
41 #include <pcl/point_cloud.h>
42 
43 
44 namespace jsk_footstep_planner
45 {
46 
52  class PointCloudModelGenerator
53  {
54  public:
56  typedef pcl::PointNormal PointT;
57  virtual void generate(const std::string& model_name,
58  pcl::PointCloud<PointT>& output,
59  double hole_rate = 0.0);
60 
61  static std::vector<std::string> supportedModels() {
62  std::vector<std::string> ret;
63  ret.push_back("flat");
64  ret.push_back("stairs");
65  ret.push_back("flat");
66  ret.push_back("gaussian");
67  return ret;
68  }
69  protected:
70  virtual void flat(pcl::PointCloud<PointT>& output,
71  double hole_rate);
72  virtual void stairs(pcl::PointCloud<PointT>& output,
73  double hole_rate);
74  virtual void hills(pcl::PointCloud<PointT>& output,
75  double hole_rate);
76  virtual void gaussian(pcl::PointCloud<PointT>& output,
77  double hole_rate);
78  virtual void flatPole(pcl::PointCloud<PointT>& output,
79  double hole_rate);
80  virtual void addPole(pcl::PointCloud<PointT>& output,
81  const Eigen::Vector3f& center,
82  const double width,
83  const double height);
84  private:
85 
86  };
87 }
88 
89 #endif
jsk_footstep_planner::PointCloudModelGenerator::addPole
virtual void addPole(pcl::PointCloud< PointT > &output, const Eigen::Vector3f &center, const double width, const double height)
Definition: pointcloud_model_generator.cpp:116
boost::shared_ptr
jsk_footstep_planner::PointCloudModelGenerator::Ptr
boost::shared_ptr< PointCloudModelGenerator > Ptr
Definition: pointcloud_model_generator.h:119
jsk_footstep_planner::PointCloudModelGenerator::supportedModels
static std::vector< std::string > supportedModels()
Definition: pointcloud_model_generator.h:125
jsk_footstep_planner::PointCloudModelGenerator::generate
virtual void generate(const std::string &model_name, pcl::PointCloud< PointT > &output, double hole_rate=0.0)
Definition: pointcloud_model_generator.cpp:73
jsk_footstep_planner::PointCloudModelGenerator::flatPole
virtual void flatPole(pcl::PointCloud< PointT > &output, double hole_rate)
Definition: pointcloud_model_generator.cpp:163
jsk_footstep_planner
Definition: ann_grid.h:50
jsk_footstep_planner::PointCloudModelGenerator::PointT
pcl::PointNormal PointT
Definition: pointcloud_model_generator.h:120
jsk_footstep_planner::PointCloudModelGenerator::flat
virtual void flat(pcl::PointCloud< PointT > &output, double hole_rate)
Definition: pointcloud_model_generator.cpp:96
hole_rate
double hole_rate
Definition: pointcloud_model_generator_node.cpp:44
jsk_footstep_planner::PointCloudModelGenerator::gaussian
virtual void gaussian(pcl::PointCloud< PointT > &output, double hole_rate)
Definition: pointcloud_model_generator.cpp:212
jsk_footstep_planner::PointCloudModelGenerator::stairs
virtual void stairs(pcl::PointCloud< PointT > &output, double hole_rate)
Definition: pointcloud_model_generator.cpp:235
jsk_footstep_planner::PointCloudModelGenerator::hills
virtual void hills(pcl::PointCloud< PointT > &output, double hole_rate)
Definition: pointcloud_model_generator.cpp:190


jsk_footstep_planner
Author(s): Ryohei Ueda
autogenerated on Mon Dec 9 2024 04:11:03