.. _program_listing_file_include_coal_shape_convex.h: Program Listing for File convex.h ================================= |exhale_lsh| :ref:`Return to documentation for file ` (``include/coal/shape/convex.h``) .. |exhale_lsh| unicode:: U+021B0 .. UPWARDS ARROW WITH TIP LEFTWARDS .. code-block:: cpp /* * Software License Agreement (BSD License) * * Copyright (c) 2011-2014, Willow Garage, Inc. * Copyright (c) 2014-2015, Open Source Robotics Foundation * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * * Neither the name of Open Source Robotics Foundation nor the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #ifndef COAL_SHAPE_CONVEX_H #define COAL_SHAPE_CONVEX_H #include "coal/shape/geometric_shapes.h" #include namespace coal { template class ConvexTpl : public ConvexBaseTpl { public: typedef typename PolygonT::IndexType IndexType; typedef ConvexBaseTpl Base; typedef typename Base::Neighbors Neighbors; using Base::neighbors; using Base::num_points; using Base::points; ConvexTpl() : Base(), num_polygons(0) {} ~ConvexTpl() {} ConvexTpl(std::shared_ptr> points_, unsigned int num_points_, std::shared_ptr> polygons_, unsigned int num_polygons_); Base &base() { return static_cast(*this); } const Base &base() const { return static_cast(*this); } ConvexTpl(const ConvexTpl &other) { *this = other; } ConvexTpl &operator=(const ConvexTpl &other); // Clone (deep copy). COAL_DEPRECATED_MESSAGE(Use deepcopy instead.) ConvexTpl *clone() const override { return this->deepcopy(); }; // Deep copy of a Convex. // This method deep copies every field of the class. ConvexTpl *deepcopy() const override { ConvexTpl *copy = new ConvexTpl(); deepcopy(this, copy); return copy; } template ConvexTpl cast() const { ConvexTpl res; deepcopy(this, &res); return res; } virtual Matrix3s computeMomentofInertia() const override; virtual Vec3s computeCOM() const override; virtual Scalar computeVolume() const override; void set(std::shared_ptr> points, unsigned int num_points, std::shared_ptr> polygons, unsigned int num_polygons); std::shared_ptr> polygons; unsigned int num_polygons; protected: void fillNeighbors(); // Deep copy of a Convex. // This method deep copies every field of the class. template static void deepcopy(const ConvexTpl *source, ConvexTpl *copy); using Base::nneighbors_; }; typedef ConvexTpl Convex16; typedef ConvexTpl Convex32; } // namespace coal #include "coal/shape/convex.hxx" #endif