ROS2ImuSensorComponent.h 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * Copyright (c) Contributors to the Open 3D Engine Project.
  3. * For complete copyright and license terms please see the LICENSE at the root of this distribution.
  4. *
  5. * SPDX-License-Identifier: Apache-2.0 OR MIT
  6. *
  7. */
  8. #pragma once
  9. #include <AzCore/Math/Matrix3x3.h>
  10. #include <AzCore/Math/Transform.h>
  11. #include <AzCore/Serialization/SerializeContext.h>
  12. #include <AzFramework/Physics/Common/PhysicsEvents.h>
  13. #include <AzFramework/Physics/PhysicsSystem.h>
  14. #include <ROS2/Sensor/Events/PhysicsBasedSource.h>
  15. #include <ROS2Sensors/Imu/ImuConfigurationRequestBus.h>
  16. #include <ROS2Sensors/Imu/ImuSensorConfiguration.h>
  17. #include <ROS2Sensors/Sensor/ROS2SensorComponentBase.h>
  18. #include <rclcpp/publisher.hpp>
  19. #include <sensor_msgs/msg/imu.hpp>
  20. namespace ROS2Sensors
  21. {
  22. //! An IMU (Inertial Measurement Unit) sensor Component.
  23. //! IMUs typically include gyroscopes, accelerometers and magnetometers. This component encapsulates data
  24. //! acquisition and its publishing to ROS2 ecosystem. IMU Component requires ROS2FrameComponent.
  25. class ROS2ImuSensorComponent
  26. : public ROS2SensorComponentBase<ROS2::PhysicsBasedSource>
  27. , protected ImuConfigurationRequestBus::Handler
  28. {
  29. public:
  30. AZ_COMPONENT(ROS2ImuSensorComponent, ROS2Sensors::ROS2ImuSensorComponentTypeId, SensorBaseType);
  31. ROS2ImuSensorComponent();
  32. ROS2ImuSensorComponent(const SensorConfiguration& sensorConfiguration, const ImuSensorConfiguration& imuConfiguration);
  33. ~ROS2ImuSensorComponent() = default;
  34. static void GetRequiredServices(AZ::ComponentDescriptor::DependencyArrayType& required);
  35. static void Reflect(AZ::ReflectContext* context);
  36. //////////////////////////////////////////////////////////////////////////
  37. // Component overrides
  38. void Activate() override;
  39. void Deactivate() override;
  40. //////////////////////////////////////////////////////////////////////////
  41. private:
  42. //////////////////////////////////////////////////////////////////////////
  43. // ImuConfigurationRequestBus::Handler overrides
  44. void SetConfiguration(const ImuSensorConfiguration& configuration) override;
  45. const ImuSensorConfiguration GetConfiguration() override;
  46. int GetFilterSize() override;
  47. void SetFilterSize(int filterSize) override;
  48. bool GetIncludeGravity() override;
  49. void SetIncludeGravity(bool includeGravity) override;
  50. bool GetAbsoluteRotation() override;
  51. void SetAbsoluteRotation(bool absoluteRotation) override;
  52. AZ::Vector3 GetOrientationVariance() override;
  53. void SetOrientationVariance(const AZ::Vector3& orientationVariance) override;
  54. AZ::Vector3 GetAngularVelocityVariance() override;
  55. void SetAngularVelocityVariance(const AZ::Vector3& angularVelocityVariance) override;
  56. AZ::Vector3 GetLinearAccelerationVariance() override;
  57. void SetLinearAccelerationVariance(const AZ::Vector3& linearAccelerationVariance) override;
  58. //////////////////////////////////////////////////////////////////////////
  59. void ConfigureSensor();
  60. ImuSensorConfiguration m_imuConfiguration;
  61. std::shared_ptr<rclcpp::Publisher<sensor_msgs::msg::Imu>> m_imuPublisher;
  62. sensor_msgs::msg::Imu m_imuMsg;
  63. AZ::Vector3 m_previousLinearVelocity = AZ::Vector3::CreateZero();
  64. AZ::Vector3 m_acceleration{ 0 };
  65. AZStd::deque<AZ::Vector3> m_filterAcceleration;
  66. AZStd::deque<AZ::Vector3> m_filterAngularVelocity;
  67. AZ::Matrix3x3 m_orientationCovariance = AZ::Matrix3x3::CreateZero();
  68. AZ::Matrix3x3 m_angularVelocityCovariance = AZ::Matrix3x3::CreateZero();
  69. AZ::Matrix3x3 m_linearAccelerationCovariance = AZ::Matrix3x3::CreateZero();
  70. void OnPhysicsEvent(AzPhysics::SceneHandle sceneHandle);
  71. void OnImuEvent(float imuDeltaTime, AzPhysics::SceneHandle sceneHandle, float physicsDeltaTime);
  72. AZ::Matrix3x3 ToDiagonalCovarianceMatrix(const AZ::Vector3& variance);
  73. // Handle to the simulated physical body
  74. AzPhysics::SimulatedBodyHandle m_bodyHandle = AzPhysics::InvalidSimulatedBodyHandle;
  75. };
  76. } // namespace ROS2Sensors