uniform_sample_filter.h
Go to the documentation of this file.
00001 /*
00002 * Software License Agreement (BSD License)
00003 *
00004 * Copyright (c) 2013, Southwest Research Institute
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 are met:
00009 *
00010 *       * Redistributions of source code must retain the above copyright
00011 *       notice, this list of conditions and the following disclaimer.
00012 *       * Redistributions in binary form must reproduce the above copyright
00013 *       notice, this list of conditions and the following disclaimer in the
00014 *       documentation and/or other materials provided with the distribution.
00015 *       * Neither the name of the Southwest Research Institute, nor the names
00016 *       of its contributors may be used to endorse or promote products derived
00017 *       from this software without specific prior written permission.
00018 *
00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00029 * POSSIBILITY OF SUCH DAMAGE.
00030 */
00031 
00032 #ifndef UNIFORM_SAMPLE_FILTER_H_
00033 #define UNIFORM_SAMPLE_FILTER_H_
00034 
00035 #include <filters/filter_base.h>
00036 #include <pluginlib/class_list_macros.h>
00037 
00038 
00039 
00040 
00041 namespace industrial_trajectory_filters
00042 {
00043 
00044 // \brief This is a simple filter which performs a uniforming sampling of
00045 // a trajectory using linear interpolation.
00046 template <typename T>
00047 
00048 class UniformSampleFilter: public filters::FilterBase<T>
00049 {
00050 public:
00051         UniformSampleFilter();
00052   ~UniformSampleFilter();
00053 
00055   virtual bool configure();
00056 
00057   // \brief Reduces a trajectory to N points or less.  The resulting trajectory
00058   // contains only point within the original trajectory (no interpolation is done
00059   // between points).
00060   bool update(const T& trajectory_in, T& trajectory_out);
00061 
00062   // \brief Perform interpolation between p1 and p2.  Time from start must be
00063   // in between p1 and p2 times.
00064   bool interpolatePt(
00065                 trajectory_msgs::JointTrajectoryPoint & p1,
00066                 trajectory_msgs::JointTrajectoryPoint & p2,
00067                 double time_from_start, trajectory_msgs::JointTrajectoryPoint & interp_pt);
00068 
00069 
00070 private:
00071   double                        sample_duration_;                                       // @brief uniform sample duration (sec)
00072 };
00073 
00074 }
00075 
00076 #endif


industrial_trajectory_filters
Author(s): Shaun Edwards
autogenerated on Mon Oct 6 2014 00:58:45