ray_trace.h
Go to the documentation of this file.
00001 /*
00002  * Software License Agreement (BSD License)
00003  *
00004  *  Copyright (c) 2018, Locus Robotics
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 the copyright holder 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 HOLDER 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 NAV_GRID_ITERATORS_LINE_RAY_TRACE_H
00036 #define NAV_GRID_ITERATORS_LINE_RAY_TRACE_H
00037 
00038 #include <nav_grid_iterators/line/abstract_line_iterator.h>
00039 
00040 namespace nav_grid_iterators
00041 {
00046 class RayTrace : public AbstractLineIterator
00047 {
00048 public:
00057   RayTrace(double x0, double y0, double x1, double y1, bool include_last_index = true);
00058 
00062   bool operator==(const RayTrace& other)
00063   {
00064     return x0_ == other.x0_ && y0_ == other.y0_ && x1_ == other.x1_ && y1_ == other.y1_ && index_ == other.index_;
00065   }
00066 
00070   bool operator!=(const RayTrace& other) { return !(*this == other); }
00071 
00076   RayTrace begin() const;
00077 
00082   RayTrace end() const;
00083 
00084   nav_grid::SignedIndex getFinalIndex() const override;
00085   void increment() override;
00086 
00091   RayTrace& operator++()
00092   {
00093     increment();
00094     return *this;
00095   }
00096 
00097   using self_type = RayTrace;
00098   using value_type = nav_grid::SignedIndex;
00099   using reference = nav_grid::SignedIndex&;
00100   using pointer = nav_grid::SignedIndex*;
00101   using iterator_category = std::input_iterator_tag;
00102   using difference_type = int;
00103 
00104 protected:
00119   RayTrace(const nav_grid::SignedIndex& index,
00120        double x0, double y0, double x1, double y1, bool include_last_index,
00121        double dx, double dy, double initial_error, int loop_inc_x, int loop_inc_y);
00122 
00123 
00124   double x0_, y0_, x1_, y1_;
00125   bool include_last_index_;
00126   double dx_, dy_, error_, initial_error_;
00127   int loop_inc_x_, loop_inc_y_;
00128 };
00129 
00130 }  // namespace nav_grid_iterators
00131 
00132 #endif  // NAV_GRID_ITERATORS_LINE_RAY_TRACE_H


nav_grid_iterators
Author(s):
autogenerated on Wed Jun 26 2019 20:09:45