simple_neighbored_graph.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_SIMPLE_NEIGHBORED_GRAPH_
38 #define JSK_FOOTSTEP_PLANNER_SIMPLE_NEIGHBORED_GRAPH_
39 
40 #include <string>
42 
43 namespace jsk_footstep_planner
44 {
45  class SimpleNeighboredNode
46  {
47  public:
49 
50  SimpleNeighboredNode(const std::string& name): name_(name)
51  {
52 
53  }
54 
55  virtual void addNeighbor(SimpleNeighboredNode::Ptr node)
56  {
57  neighbors_.push_back(node);
58  }
59 
60  virtual
61  std::vector<SimpleNeighboredNode::Ptr>
62  getNeighbors()
63  {
64  return neighbors_;
65  }
66 
67  virtual std::string getName() { return name_; }
68  bool operator==(SimpleNeighboredNode& other)
69  {
70  return name_ == other.getName();
71  }
72 
73  protected:
74  std::string name_;
75  std::vector<SimpleNeighboredNode::Ptr> neighbors_;
76  private:
77 
78  };
79 
80  class SimpleNeighboredGraph: public Graph<SimpleNeighboredNode>
81  {
82  public:
84 
86  virtual std::vector<SimpleNeighboredGraph::StatePtr> successors(
87  StatePtr target_state)
88  {
89  return target_state->getNeighbors();
90  }
91 
92  virtual double pathCost(StatePtr from, StatePtr to, double prev_cost)
93  {
94  return prev_cost + 1;
95  }
96 
97  virtual bool isGoal(StatePtr state)
98  {
99  return *goal_state_ == *state;
100  }
101 
102  virtual StatePtr
103  findNode(const std::string& name)
104  {
105  for (size_t i = 0; i < nodes_.size(); i++) {
106  StatePtr s = nodes_[i];
107  if (s->getName() == name) {
108  return s;
109  }
110  }
111  return StatePtr();
112  }
113 
114  protected:
115  private:
116 
117  };
118 }
119 
120 #endif
jsk_footstep_planner::SimpleNeighboredNode::operator==
bool operator==(SimpleNeighboredNode &other)
Definition: simple_neighbored_graph.h:132
boost::shared_ptr
i
int i
jsk_footstep_planner::Graph< SimpleNeighboredNode >::goal_state_
StatePtr goal_state_
Definition: graph.h:135
jsk_footstep_planner::SimpleNeighboredGraph::Ptr
boost::shared_ptr< SimpleNeighboredGraph > Ptr
Definition: simple_neighbored_graph.h:115
jsk_footstep_planner::SimpleNeighboredGraph
Definition: simple_neighbored_graph.h:112
jsk_footstep_planner::SimpleNeighboredGraph::isGoal
virtual bool isGoal(StatePtr state)
Definition: simple_neighbored_graph.h:129
jsk_footstep_planner::Graph
Definition: graph.h:78
jsk_footstep_planner::SimpleNeighboredNode::name_
std::string name_
Definition: simple_neighbored_graph.h:138
jsk_footstep_planner::SimpleNeighboredGraph::findNode
virtual StatePtr findNode(const std::string &name)
Definition: simple_neighbored_graph.h:135
jsk_footstep_planner
Definition: ann_grid.h:50
jsk_footstep_planner::SimpleNeighboredGraph::SimpleNeighboredGraph
SimpleNeighboredGraph()
Definition: simple_neighbored_graph.h:117
jsk_footstep_planner::SimpleNeighboredNode::Ptr
boost::shared_ptr< SimpleNeighboredNode > Ptr
Definition: simple_neighbored_graph.h:112
name
std::string name
jsk_footstep_planner::SimpleNeighboredGraph::successors
virtual std::vector< SimpleNeighboredGraph::StatePtr > successors(StatePtr target_state)
Definition: simple_neighbored_graph.h:118
jsk_footstep_planner::SimpleNeighboredNode::neighbors_
std::vector< SimpleNeighboredNode::Ptr > neighbors_
Definition: simple_neighbored_graph.h:139
jsk_footstep_planner::Graph< SimpleNeighboredNode >::StatePtr
boost::shared_ptr< StateT > StatePtr
Definition: graph.h:115
jsk_footstep_planner::SimpleNeighboredGraph::pathCost
virtual double pathCost(StatePtr from, StatePtr to, double prev_cost)
Definition: simple_neighbored_graph.h:124
state
state
jsk_footstep_planner::SimpleNeighboredNode::addNeighbor
virtual void addNeighbor(SimpleNeighboredNode::Ptr node)
Definition: simple_neighbored_graph.h:119
graph.h
jsk_footstep_planner::SimpleNeighboredNode::SimpleNeighboredNode
SimpleNeighboredNode(const std::string &name)
Definition: simple_neighbored_graph.h:114
pose_array.s
s
Definition: pose_array.py:22
jsk_footstep_planner::SimpleNeighboredNode::getNeighbors
virtual std::vector< SimpleNeighboredNode::Ptr > getNeighbors()
Definition: simple_neighbored_graph.h:126
jsk_footstep_planner::Graph< SimpleNeighboredNode >::nodes_
std::vector< StatePtr > nodes_
Definition: graph.h:136
jsk_footstep_planner::SimpleNeighboredNode::getName
virtual std::string getName()
Definition: simple_neighbored_graph.h:131


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