24 #include "nav2_amcl/angleutils.hpp"
25 #include "nav2_amcl/motion_model/differential_motion_model.hpp"
26 #include "nav2_amcl/pf/pf_pdf.hpp"
33 double alpha1,
double alpha2,
double alpha3,
double alpha4,
51 set = pf->sets + pf->current_set;
55 double delta_rot1, delta_trans, delta_rot2;
56 double delta_rot1_hat, delta_trans_hat, delta_rot2_hat;
57 double delta_rot1_noise, delta_rot2_noise;
62 delta.v[1] * delta.v[1] +
63 delta.v[0] * delta.v[0]) < 0.01)
67 delta_rot1 = angleutils::angle_diff(
68 atan2(delta.v[1], delta.v[0]),
72 delta.v[0] * delta.v[0] +
73 delta.v[1] * delta.v[1]);
74 delta_rot2 = angleutils::angle_diff(delta.v[2], delta_rot1);
79 delta_rot1_noise = std::min(
80 fabs(angleutils::angle_diff(delta_rot1, 0.0)),
81 fabs(angleutils::angle_diff(delta_rot1, M_PI)));
82 delta_rot2_noise = std::min(
83 fabs(angleutils::angle_diff(delta_rot2, 0.0)),
84 fabs(angleutils::angle_diff(delta_rot2, M_PI)));
86 for (
int i = 0; i < set->sample_count; i++) {
90 delta_rot1_hat = angleutils::angle_diff(
94 alpha1_ * delta_rot1_noise * delta_rot1_noise +
95 alpha2_ * delta_trans * delta_trans)));
96 delta_trans_hat = delta_trans -
99 alpha3_ * delta_trans * delta_trans +
100 alpha4_ * delta_rot1_noise * delta_rot1_noise +
101 alpha4_ * delta_rot2_noise * delta_rot2_noise));
102 delta_rot2_hat = angleutils::angle_diff(
106 alpha1_ * delta_rot2_noise * delta_rot2_noise +
107 alpha2_ * delta_trans * delta_trans)));
110 sample->pose.v[0] += delta_trans_hat *
111 cos(sample->pose.v[2] + delta_rot1_hat);
112 sample->pose.v[1] += delta_trans_hat *
113 sin(sample->pose.v[2] + delta_rot1_hat);
114 sample->pose.v[2] += delta_rot1_hat + delta_rot2_hat;
120 #include <pluginlib/class_list_macros.hpp>
virtual void initialize(double alpha1, double alpha2, double alpha3, double alpha4, double alpha5)
An factory to create motion models.
virtual void odometryUpdate(pf_t *pf, const pf_vector_t &pose, const pf_vector_t &delta)
Update on new odometry data.
An abstract motion model class.