-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathidm_planner.cc
52 lines (40 loc) · 1.58 KB
/
idm_planner.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include "drake/automotive/idm_planner.h"
#include <cmath>
#include "drake/common/autodiff_overloads.h"
#include "drake/common/drake_assert.h"
#include "drake/common/symbolic_formula.h"
namespace drake {
namespace automotive {
template <typename T>
const T IdmPlanner<T>::Evaluate(const IdmPlannerParameters<T>& params,
const T& ego_velocity, const T& target_distance,
const T& target_distance_dot) {
DRAKE_DEMAND(params.IsValid());
using std::pow;
using std::sqrt;
const T& v_ref = params.v_ref();
const T& a = params.a();
const T& b = params.b();
const T& s_0 = params.s_0();
const T& time_headway = params.time_headway();
const T& delta = params.delta();
DRAKE_DEMAND(a > 0.);
DRAKE_DEMAND(b > 0.);
DRAKE_DEMAND(target_distance > 0.);
// Compute the interaction acceleration terms.
const T& closing_term =
ego_velocity * target_distance_dot / (2 * sqrt(a * b));
const T& too_close_term = s_0 + ego_velocity * time_headway;
const T& accel_interaction =
pow((closing_term + too_close_term) / target_distance, 2.);
// Compute the free-road acceleration term.
const T& accel_free_road = pow(ego_velocity / v_ref, delta);
// Compute the resultant acceleration (IDM equation).
return a * (1. - accel_free_road - accel_interaction);
}
// These instantiations must match the API documentation in idm_planner.h.
template class IdmPlanner<double>;
template class IdmPlanner<drake::AutoDiffXd>;
template class IdmPlanner<drake::symbolic::Expression>;
} // namespace automotive
} // namespace drake