NASA Astrobee Robot Software  Astrobee Version:
Flight software for the Astrobee robots operating inside the International Space Station.
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
utilities.h
Go to the documentation of this file.
1 /* Copyright (c) 2017, United States Government, as represented by the
2  * Administrator of the National Aeronautics and Space Administration.
3  *
4  * All rights reserved.
5  *
6  * The Astrobee platform is licensed under the Apache License, Version 2.0
7  * (the "License"); you may not use this file except in compliance with the
8  * License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15  * License for the specific language governing permissions and limitations
16  * under the License.
17  */
18 
19 #ifndef IMU_INTEGRATION_UTILITIES_H_
20 #define IMU_INTEGRATION_UTILITIES_H_
21 
22 #include <imu_integration/filter.h>
25 
26 #include <gtsam/inference/Symbol.h>
27 #include <gtsam/navigation/ImuBias.h>
28 
29 #include <Eigen/Core>
30 
31 #include <vector>
32 
33 namespace imu_integration {
34 namespace sym = gtsam::symbol_shorthand;
35 boost::optional<localization_measurements::ImuMeasurement> Interpolate(
36  const localization_measurements::ImuMeasurement& imu_measurement_a,
37  const localization_measurements::ImuMeasurement& imu_measurement_b, const localization_common::Time timestamp);
38 
39 gtsam::PreintegratedCombinedMeasurements Pim(
40  const gtsam::imuBias::ConstantBias& bias,
41  const boost::shared_ptr<gtsam::PreintegratedCombinedMeasurements::Params>& params);
42 
44  localization_common::Time& last_added_imu_measurement_time,
45  gtsam::PreintegratedCombinedMeasurements& pim);
46 
48  const gtsam::PreintegratedCombinedMeasurements& pim);
49 } // namespace imu_integration
50 
51 #endif // IMU_INTEGRATION_UTILITIES_H_
localization_measurements::ImuMeasurement
Definition: imu_measurement.h:30
filter.h
imu_integration::PimPredict
localization_common::CombinedNavState PimPredict(const localization_common::CombinedNavState &combined_nav_state, const gtsam::PreintegratedCombinedMeasurements &pim)
Definition: utilities.cc:66
localization_common::CombinedNavState
Definition: combined_nav_state.h:48
imu_integration::Interpolate
boost::optional< localization_measurements::ImuMeasurement > Interpolate(const localization_measurements::ImuMeasurement &imu_measurement_a, const localization_measurements::ImuMeasurement &imu_measurement_b, const localization_common::Time timestamp)
Definition: utilities.cc:27
imu_integration
Definition: butterO1.h:26
imu_integration::Pim
gtsam::PreintegratedCombinedMeasurements Pim(const gtsam::imuBias::ConstantBias &bias, const boost::shared_ptr< gtsam::PreintegratedCombinedMeasurements::Params > &params)
Definition: utilities.cc:46
combined_nav_state.h
imu_integration::AddMeasurement
void AddMeasurement(const localization_measurements::ImuMeasurement &imu_measurement, localization_common::Time &last_added_imu_measurement_time, gtsam::PreintegratedCombinedMeasurements &pim)
Definition: utilities.cc:54
imu_measurement.h
localization_common::Time
double Time
Definition: time.h:23