37 #ifndef TRAJECTORY_ROLLOUT_WORLD_MODEL_H_
38 #define TRAJECTORY_ROLLOUT_WORLD_MODEL_H_
43 #include <geometry_msgs/Point.h>
66 double inscribed_radius,
double circumscribed_radius) = 0;
70 double cos_th =
cos(theta);
71 double sin_th =
sin(theta);
73 for(
unsigned int i = 0; i < footprint_spec.
size(); ++i){
74 geometry_msgs::Point new_pt;
75 new_pt.x = x + (footprint_spec[i].x * cos_th - footprint_spec[i].y * sin_th);
76 new_pt.y = y + (footprint_spec[i].x * sin_th + footprint_spec[i].y * cos_th);
80 geometry_msgs::Point robot_position;
84 if(inscribed_radius==0.0){
88 return footprintCost(robot_position, oriented_footprint, inscribed_radius, circumscribed_radius);
100 double inscribed_radius,
double circumscribed_radius,
double extra) {
101 return footprintCost(position, footprint, inscribed_radius, circumscribed_radius);