NASA Astrobee Robot Software  0.19.1
Flight software for the Astrobee robots operating inside the International Space Station.
dynamic_imu_filter.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_DYNAMIC_IMU_FILTER_H_
20 #define IMU_INTEGRATION_DYNAMIC_IMU_FILTER_H_
21 
22 #include <imu_integration/filter.h>
27 
28 #include <boost/optional.hpp>
29 
30 #include <memory>
31 
32 namespace imu_integration {
34  public:
35  DynamicImuFilter(const ImuFilterParams& params, const localization_measurements::FanSpeedMode initial_fan_speed_mode =
37  // Returns filtered measurement if one is available
38  boost::optional<localization_measurements::ImuMeasurement> AddMeasurement(
39  const localization_measurements::ImuMeasurement& imu_measurement);
40 
41  // Notch filter depends on fan speed, change filter as fan speed changes
43  const bool ignore_saved_fan_speed_mode = false);
44 
46 
47  private:
48  // Acceleration Filters
49  std::unique_ptr<Filter> acceleration_x_filter_;
50  std::unique_ptr<Filter> acceleration_y_filter_;
51  std::unique_ptr<Filter> acceleration_z_filter_;
52  // Angular Velocity Filters
53  std::unique_ptr<Filter> angular_velocity_x_filter_;
54  std::unique_ptr<Filter> angular_velocity_y_filter_;
55  std::unique_ptr<Filter> angular_velocity_z_filter_;
56  ImuFilterParams params_;
58 };
59 } // namespace imu_integration
60 
61 #endif // IMU_INTEGRATION_DYNAMIC_IMU_FILTER_H_
localization_measurements::ImuMeasurement
Definition: imu_measurement.h:30
filter.h
imu_integration::DynamicImuFilter
Definition: dynamic_imu_filter.h:33
imu_filter_params.h
imu_integration::DynamicImuFilter::SetFanSpeedMode
void SetFanSpeedMode(const localization_measurements::FanSpeedMode fan_speed_mode, const bool ignore_saved_fan_speed_mode=false)
Definition: dynamic_imu_filter.cc:46
imu_filter.h
imu_integration::DynamicImuFilter::fan_speed_mode
localization_measurements::FanSpeedMode fan_speed_mode() const
Definition: dynamic_imu_filter.cc:93
imu_integration
Definition: butterO1.h:26
imu_integration::ImuFilterParams
Definition: imu_filter_params.h:24
imu_integration::DynamicImuFilter::AddMeasurement
boost::optional< localization_measurements::ImuMeasurement > AddMeasurement(const localization_measurements::ImuMeasurement &imu_measurement)
Definition: dynamic_imu_filter.cc:30
localization_measurements::FanSpeedMode
FanSpeedMode
Definition: fan_speed_mode.h:23
localization_measurements::FanSpeedMode::kNominal
@ kNominal
imu_measurement.h
fan_speed_mode.h
imu_integration::DynamicImuFilter::DynamicImuFilter
DynamicImuFilter(const ImuFilterParams &params, const localization_measurements::FanSpeedMode initial_fan_speed_mode=localization_measurements::FanSpeedMode::kNominal)
Definition: dynamic_imu_filter.cc:25