15 #ifndef NAV2_SMAC_PLANNER__NODE_LATTICE_HPP_
16 #define NAV2_SMAC_PLANNER__NODE_LATTICE_HPP_
23 #include "ompl/base/StateSpace.h"
25 #include "nav2_smac_planner/constants.hpp"
26 #include "nav2_smac_planner/types.hpp"
27 #include "nav2_smac_planner/collision_checker.hpp"
28 #include "nav2_smac_planner/node_hybrid.hpp"
29 #include "nav2_smac_planner/utils.hpp"
30 #include "nav2_smac_planner/nav2_smac_planner_common_visibility_control.hpp"
32 namespace nav2_smac_planner
56 unsigned int & size_x_in,
67 unsigned int & direction_change_index);
97 double getAngle(
const double & theta);
100 unsigned int num_angle_quantization;
101 float change_penalty;
102 float non_straight_penalty;
104 float reverse_penalty;
105 float travel_distance_reward;
106 float rotation_penalty;
107 float min_turning_radius;
108 bool allow_reverse_expansion;
109 std::vector<std::vector<MotionPrimitive>> motion_primitives;
110 ompl::base::StateSpacePtr state_space;
111 std::vector<TrigValues> trig_values;
112 std::string current_lattice_filepath;
114 MotionModel motion_model = MotionModel::UNKNOWN;
125 typedef std::unique_ptr<std::vector<NodeLattice>> Graph;
126 typedef std::vector<NodePtr> NodeVector;
128 typedef NodeHybrid::CoordinateVector CoordinateVector;
148 return this->_index == rhs._index;
171 _motion_primitive = prim;
180 return _motion_primitive;
189 return _accumulated_cost;
198 _accumulated_cost = cost_in;
264 const bool & traverse_unknown,
267 bool is_backwards =
false);
284 const unsigned int & x,
const unsigned int & y,
const unsigned int & angle)
288 x, y, angle, motion_table.size_x,
289 motion_table.num_angle_quantization);
300 const uint64_t & index,
301 const unsigned int & width,
const unsigned int & angle_quantization)
305 (index / angle_quantization) % width,
306 index / (angle_quantization * width),
307 index % angle_quantization);
317 const Coordinates & node_coords,
318 const CoordinateVector & goals_coords);
329 const MotionModel & motion_model,
330 unsigned int & size_x,
331 unsigned int & size_y,
332 unsigned int & angle_quantization,
344 const float & lookup_table_dim,
345 const MotionModel & motion_model,
346 const unsigned int & dim_3_size,
355 std::shared_ptr<nav2_costmap_2d::Costmap2DROS> costmap_ros,
356 const unsigned int & start_x,
const unsigned int & start_y,
357 const unsigned int & goal_x,
const unsigned int & goal_y)
372 const double & cost_penalty)
386 const Coordinates & node_coords,
387 const Coordinates & goal_coords,
388 const float & obstacle_heuristic);
398 std::function<
bool(
const uint64_t &,
401 const bool & traverse_unknown,
402 NodeVector & neighbors);
415 void addNodeToPath(NodePtr current_node, CoordinateVector & path);
421 NAV2_SMAC_PLANNER_COMMON_EXPORT
static LookupTable dist_heuristic_lookup_table;
422 NAV2_SMAC_PLANNER_COMMON_EXPORT
static float size_lookup;
426 float _accumulated_cost;
431 bool _is_node_valid{
false};
A costmap grid collision checker.
uint64_t getIndex()
Gets cell index.
static float getObstacleHeuristic(const Coordinates &node_coords, const Coordinates &goal_coords, const float &cost_penalty)
Compute the Obstacle heuristic.
static void resetObstacleHeuristic(std::shared_ptr< nav2_costmap_2d::Costmap2DROS > costmap_ros, const unsigned int &start_x, const unsigned int &start_y, const unsigned int &goal_x, const unsigned int &goal_y)
reset the obstacle heuristic state
NodeLattice implementation for graph, Hybrid-A*.
void getNeighbors(std::function< bool(const uint64_t &, nav2_smac_planner::NodeLattice *&)> &validity_checker, GridCollisionChecker *collision_checker, const bool &traverse_unknown, NodeVector &neighbors)
Retrieve all valid neighbors of a node.
void backwards(bool back=true)
Sets that this primitive is moving in reverse.
static Coordinates getCoords(const uint64_t &index, const unsigned int &width, const unsigned int &angle_quantization)
Get coordinates at index.
void setAccumulatedCost(const float &cost_in)
Sets the accumulated cost at this node.
uint64_t getIndex()
Gets cell index.
~NodeLattice()
A destructor for nav2_smac_planner::NodeLattice.
float getCost()
Gets the costmap cost at this node.
void reset()
Reset method for new search.
bool backtracePath(CoordinateVector &path)
Set the starting pose for planning, as a node index.
float getTraversalCost(const NodePtr &child)
Get traversal cost of parent node to child node.
void visited()
Sets if cell has been visited in search.
bool isNodeValid(const bool &traverse_unknown, GridCollisionChecker *collision_checker, MotionPrimitive *primitive=nullptr, bool is_backwards=false)
Check if this node is valid.
static float getHeuristicCost(const Coordinates &node_coords, const CoordinateVector &goals_coords)
Get cost of heuristic of node.
void addNodeToPath(NodePtr current_node, CoordinateVector &path)
add node to the path
bool isBackward()
Gets if this primitive is moving in reverse.
bool wasVisited()
Gets if cell has been visited in search.
static void initMotionModel(const MotionModel &motion_model, unsigned int &size_x, unsigned int &size_y, unsigned int &angle_quantization, SearchInfo &search_info)
Initialize motion models.
MotionPrimitive *& getMotionPrimitive()
Gets the motion primitive used to achieve node in search.
static void precomputeDistanceHeuristic(const float &lookup_table_dim, const MotionModel &motion_model, const unsigned int &dim_3_size, const SearchInfo &search_info)
Compute the SE2 distance heuristic.
bool operator==(const NodeLattice &rhs)
operator== for comparisons
static void resetObstacleHeuristic(std::shared_ptr< nav2_costmap_2d::Costmap2DROS > costmap_ros, const unsigned int &start_x, const unsigned int &start_y, const unsigned int &goal_x, const unsigned int &goal_y)
Compute the wavefront heuristic.
static float getObstacleHeuristic(const Coordinates &node_coords, const Coordinates &goal_coords, const double &cost_penalty)
Compute the Obstacle heuristic.
void setMotionPrimitive(MotionPrimitive *prim)
Sets the motion primitive used to achieve node in search.
static uint64_t getIndex(const unsigned int &x, const unsigned int &y, const unsigned int &angle)
Get index at coordinates.
NodeLattice(const uint64_t index)
A constructor for nav2_smac_planner::NodeLattice.
static float getDistanceHeuristic(const Coordinates &node_coords, const Coordinates &goal_coords, const float &obstacle_heuristic)
Compute the Distance heuristic.
float getAccumulatedCost()
Gets the accumulated cost at this node.
void setPose(const Coordinates &pose_in)
setting continuous coordinate search poses (in partial-cells)
A table of motion primitives and related functions.
static LatticeMetadata getLatticeMetadata(const std::string &lattice_filepath)
Get file metadata needed.
unsigned int getClosestAngularBin(const double &theta)
Get the angular bin to use from a raw orientation.
void initMotionModel(unsigned int &size_x_in, SearchInfo &search_info)
Initializing state lattice planner's motion model.
MotionPrimitivePtrs getMotionPrimitives(const NodeLattice *node, unsigned int &direction_change_index)
Get projections of motion models.
float & getAngleFromBin(const unsigned int &bin_idx)
Get the raw orientation from an angular bin.
double getAngle(const double &theta)
Get the angular bin to use from a raw orientation.
LatticeMotionTable()
A constructor for nav2_smac_planner::LatticeMotionTable.
A struct of all motion primitive data.
NodeHybrid implementation of coordinate structure.
Search properties and penalties.