Nav2 Navigation Stack - humble  humble
ROS 2 Navigation Stack
state.hpp
1 // Copyright (c) 2022 Samsung Research America, @artofnothingness Alexey Budyakov
2 //
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
6 //
7 // http://www.apache.org/licenses/LICENSE-2.0
8 //
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
14 
15 #ifndef NAV2_MPPI_CONTROLLER__MODELS__STATE_HPP_
16 #define NAV2_MPPI_CONTROLLER__MODELS__STATE_HPP_
17 
18 #include <xtensor/xtensor.hpp>
19 
20 #include <geometry_msgs/msg/pose_stamped.hpp>
21 #include <geometry_msgs/msg/twist.hpp>
22 
23 namespace mppi::models
24 {
25 
30 struct State
31 {
32  xt::xtensor<float, 2> vx;
33  xt::xtensor<float, 2> vy;
34  xt::xtensor<float, 2> wz;
35 
36  xt::xtensor<float, 2> cvx;
37  xt::xtensor<float, 2> cvy;
38  xt::xtensor<float, 2> cwz;
39 
40  geometry_msgs::msg::PoseStamped pose;
41  geometry_msgs::msg::Twist speed;
42 
46  void reset(unsigned int batch_size, unsigned int time_steps)
47  {
48  vx = xt::zeros<float>({batch_size, time_steps});
49  vy = xt::zeros<float>({batch_size, time_steps});
50  wz = xt::zeros<float>({batch_size, time_steps});
51 
52  cvx = xt::zeros<float>({batch_size, time_steps});
53  cvy = xt::zeros<float>({batch_size, time_steps});
54  cwz = xt::zeros<float>({batch_size, time_steps});
55  }
56 };
57 } // namespace mppi::models
58 
59 #endif // NAV2_MPPI_CONTROLLER__MODELS__STATE_HPP_
State information: velocities, controls, poses, speed.
Definition: state.hpp:31
void reset(unsigned int batch_size, unsigned int time_steps)
Reset state data.
Definition: state.hpp:46