AckermannModelLimits.cpp 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  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 "AckermannModelLimits.h"
  9. #include <AzCore/Serialization/EditContext.h>
  10. #include <AzCore/Serialization/EditContextConstants.inl>
  11. #include <AzCore/Serialization/SerializeContext.h>
  12. namespace ROS2Controllers::VehicleDynamics
  13. {
  14. void AckermannModelLimits::Reflect(AZ::ReflectContext* context)
  15. {
  16. if (AZ::SerializeContext* serialize = azrtti_cast<AZ::SerializeContext*>(context))
  17. {
  18. serialize->Class<AckermannModelLimits>()
  19. ->Version(1)
  20. ->Field("SpeedLimit", &AckermannModelLimits::m_speedLimit)
  21. ->Field("SteeringLimit", &AckermannModelLimits::m_steeringLimit)
  22. ->Field("Acceleration", &AckermannModelLimits::m_acceleration);
  23. if (AZ::EditContext* ec = serialize->GetEditContext())
  24. {
  25. ec->Class<AckermannModelLimits>("Skid steering Model Limits", "Limitations of speed, steering angles and other values")
  26. ->ClassElement(AZ::Edit::ClassElements::EditorData, "")
  27. ->Attribute(AZ::Edit::Attributes::Category, "ROS2")
  28. ->DataElement(
  29. AZ::Edit::UIHandlers::Default, &AckermannModelLimits::m_speedLimit, "Speed Limit", "Max linear speed (meters/sec)")
  30. ->Attribute(AZ::Edit::Attributes::Min, 0.0f)
  31. ->Attribute(AZ::Edit::Attributes::Max, 100.0f)
  32. ->DataElement(
  33. AZ::Edit::UIHandlers::Default, &AckermannModelLimits::m_steeringLimit, "Steering Limit", "Max steering angle (rad)")
  34. ->Attribute(AZ::Edit::Attributes::Min, 0.0f)
  35. ->Attribute(AZ::Edit::Attributes::Max, 1.57f)
  36. ->DataElement(
  37. AZ::Edit::UIHandlers::Default, &AckermannModelLimits::m_acceleration, "Acceleration", "Acceleration in m/s²")
  38. ->Attribute(AZ::Edit::Attributes::Min, 0.0f)
  39. ->Attribute(AZ::Edit::Attributes::Max, 100.0f);
  40. }
  41. }
  42. }
  43. AckermannModelLimits::AckermannModelLimits(const float speedLimit, const float steeringLimit, const float acceleration)
  44. {
  45. m_speedLimit = AZStd::clamp(speedLimit, 0.0f, 100.0f);
  46. m_steeringLimit = AZStd::clamp(steeringLimit, 0.0f, 1.57f);
  47. m_acceleration = AZStd::clamp(acceleration, 0.0f, 100.0f);
  48. }
  49. VehicleInputs AckermannModelLimits::LimitState(const VehicleInputs& inputState) const
  50. {
  51. VehicleInputs ret = inputState;
  52. ret.m_angularRates = AZ::Vector3{ 0.0f };
  53. ret.m_speed = AZ::Vector3{ LimitValue(ret.m_speed.GetX(), m_speedLimit), 0.0f, 0.0f };
  54. if (!ret.m_jointRequestedPosition.empty())
  55. {
  56. ret.m_jointRequestedPosition.front() = LimitValue(ret.m_jointRequestedPosition.front(), m_steeringLimit);
  57. }
  58. return ret;
  59. }
  60. VehicleInputs AckermannModelLimits::GetMaximumState() const
  61. {
  62. VehicleInputs ret;
  63. ret.m_speed = { m_speedLimit, 0.0f, 0.0f };
  64. ret.m_jointRequestedPosition = { m_steeringLimit };
  65. return ret;
  66. }
  67. float AckermannModelLimits::GetLinearSpeedLimit() const
  68. {
  69. return m_speedLimit;
  70. }
  71. float AckermannModelLimits::GetLinearAcceleration() const
  72. {
  73. return m_acceleration;
  74. }
  75. } // namespace ROS2Controllers::VehicleDynamics