ROS2OdometryCovariance.cpp 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  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. #include "ROS2OdometryCovariance.h"
  9. #include <AzCore/RTTI/RTTIMacros.h>
  10. #include <AzCore/Serialization/EditContext.h>
  11. #include <AzCore/Serialization/EditContextConstants.inl>
  12. #include <AzCore/base.h>
  13. #include <array>
  14. namespace ROS2Sensors
  15. {
  16. void ROS2OdometryCovariance::Reflect(AZ::ReflectContext* context)
  17. {
  18. if (AZ::SerializeContext* serialize = azrtti_cast<AZ::SerializeContext*>(context))
  19. {
  20. serialize->Class<ROS2OdometryCovariance>()
  21. ->Version(1)
  22. ->Field("Linear covariance", &ROS2OdometryCovariance::m_linearCovariance)
  23. ->Field("Angular covariance", &ROS2OdometryCovariance::m_angularCovariance);
  24. if (AZ::EditContext* ec = serialize->GetEditContext())
  25. {
  26. ec->Class<ROS2OdometryCovariance>("ROS2 Odometry Covariance", "Define Odometry covariance")
  27. ->DataElement(
  28. AZ::Edit::UIHandlers::Default,
  29. &ROS2OdometryCovariance::m_linearCovariance,
  30. "Linear covariance",
  31. "Set the ROS linear covariance")
  32. ->DataElement(
  33. AZ::Edit::UIHandlers::Default,
  34. &ROS2OdometryCovariance::m_angularCovariance,
  35. "Angular covariance",
  36. "Set the ROS angular covariance");
  37. }
  38. }
  39. }
  40. std::array<double, 36> ROS2OdometryCovariance::GetRosCovariance() const
  41. {
  42. const AZ::Vector3& lin = m_linearCovariance;
  43. const AZ::Vector3& ang = m_angularCovariance;
  44. // clang-format off
  45. return {
  46. lin.GetX(), 0.0L, 0.0L, 0.0L, 0.0L, 0.0L,
  47. 0.0L, lin.GetY(), 0.0L, 0.0L, 0.0L, 0.0L,
  48. 0.0L, 0.0L, lin.GetZ(), 0.0L, 0.0L, 0.0L,
  49. 0.0L, 0.0L, 0.0L, ang.GetX(), 0.0L, 0.0L,
  50. 0.0L, 0.0L, 0.0L, 0.0L, ang.GetY(), 0.0L,
  51. 0.0L, 0.0L, 0.0L, 0.0L, 0.0L, ang.GetZ()
  52. };
  53. // clang-format on
  54. }
  55. } // namespace ROS2Sensors