supporting_plane_extraction.cpp
Go to the documentation of this file.
00001 /****************************************************************
00002  *
00003  * Copyright (c) 2011
00004  *
00005  * Fraunhofer Institute for Manufacturing Engineering
00006  * and Automation (IPA)
00007  *
00008  * +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
00009  *
00010  * Project name: care-o-bot
00011  * ROS stack name: cob_environment_perception
00012  * ROS package name: cob_3d_mapping_semantics
00013  * Description:
00014  *
00015  * +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
00016  *
00017  * Author: Georg Arbeiter, email:georg.arbeiter@ipa.fhg.de
00018  * Supervised by: Georg Arbeiter, email:georg.arbeiter@ipa.fhg.de
00019  *
00020  * Date of creation: 11/2012
00021  * ToDo:
00022  *
00023  *
00024  *
00025  * +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
00026  *
00027  * Redistribution and use in source and binary forms, with or without
00028  * modification, are permitted provided that the following conditions are met:
00029  *
00030  *     * Redistributions of source code must retain the above copyright
00031  *       notice, this list of conditions and the following disclaimer.
00032  *     * Redistributions in binary form must reproduce the above copyright
00033  *       notice, this list of conditions and the following disclaimer in the
00034  *       documentation and/or other materials provided with the distribution.
00035  *     * Neither the name of the Fraunhofer Institute for Manufacturing
00036  *       Engineering and Automation (IPA) nor the names of its
00037  *       contributors may be used to endorse or promote products derived from
00038  *       this software without specific prior written permission.
00039  *
00040  * This program is free software: you can redistribute it and/or modify
00041  * it under the terms of the GNU Lesser General Public License LGPL as
00042  * published by the Free Software Foundation, either version 3 of the
00043  * License, or (at your option) any later version.
00044  *
00045  * This program is distributed in the hope that it will be useful,
00046  * but WITHOUT ANY WARRANTY; without even the implied warranty of
00047  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00048  * GNU Lesser General Public License LGPL for more details.
00049  *
00050  * You should have received a copy of the GNU Lesser General Public
00051  * License LGPL along with this program.
00052  * If not, see <http://www.gnu.org/licenses/>.
00053  *
00054  ****************************************************************/
00055 
00056 #include "cob_3d_mapping_semantics/supporting_plane_extraction.h"
00057 
00058 using namespace cob_3d_mapping;
00059 
00060 bool
00061 SupportingPlaneExtraction::getSupportingPlane (std::vector<Polygon::Ptr>& polys, Polygon& sp)
00062 {
00063   if (polys.size () == 0)
00064   {
00065     std::cerr << "Input polygons not set, aborting..." << std::endl;
00066     return false;
00067   }
00068   std::vector<Polygon::Ptr> cands;
00069   for (unsigned int i = 0; i < polys.size (); i++)
00070   {
00071     double a = polys[i]->computeArea3d ();
00072     if (a > area_min_ && a < area_max_)
00073     {
00074       std::cout << "\tadding" << std::endl;
00075       cands.push_back (polys[i]);
00076     }
00077   }
00078   if (cands.size () == 0)
00079     return false;
00080   int index = -1;
00081   double dist_min = distance_max_;
00082   for (unsigned int i = 0; i < cands.size (); i++)
00083   {
00084     double d = cands[i]->computeDistanceFromViewpoint ();
00085     if (d < distance_max_ && d > distance_min_ && d < dist_min)
00086     {
00087       dist_min = d;
00088       index = i;
00089     }
00090   }
00091   if (index == -1)
00092     return false;
00093   sp = *cands[index];
00094   return true;
00095 }
00096 


cob_3d_mapping_semantics
Author(s): Georg Arbeiter
autogenerated on Wed Aug 26 2015 11:03:34