AckermannDriveModel.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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/Serialization/SerializeContext.h>
  10. #include <ROS2Controllers/Controllers/PidConfiguration.h>
  11. #include <ROS2Controllers/VehicleDynamics/VehicleConfiguration.h>
  12. #include <VehicleDynamics/ModelLimits/AckermannModelLimits.h>
  13. #include <VehicleDynamics/DriveModel.h>
  14. #include <VehicleDynamics/VehicleInputs.h>
  15. #include <VehicleDynamics/WheelDynamicsData.h>
  16. namespace ROS2Controllers::VehicleDynamics
  17. {
  18. //! A simple Ackermann system implementation converting speed and steering inputs into wheel impulse and steering element torque
  19. class AckermannDriveModel : public DriveModel
  20. {
  21. public:
  22. AZ_RTTI(AckermannDriveModel, "{104AC31D-E30B-4454-BF42-4FB37B8CFD9B}", DriveModel);
  23. AckermannDriveModel() = default;
  24. AckermannDriveModel(const AckermannModelLimits& limits, const PidConfiguration& steeringPid);
  25. // DriveModel overrides
  26. void Activate(const VehicleConfiguration& vehicleConfig) override;
  27. static void Reflect(AZ::ReflectContext* context);
  28. protected:
  29. // DriveModel overrides
  30. void ApplyState(const VehicleInputs& inputs, AZ::u64 deltaTimeNs) override;
  31. const VehicleModelLimits* GetVehicleLimitPtr() const override;
  32. AZStd::pair<AZ::Vector3, AZ::Vector3> GetVelocityFromModel() override;
  33. private:
  34. void ApplySteering(float steering, AZ::u64 deltaTimeNs);
  35. void ApplySpeed(float speed, AZ::u64 deltaTimeNs);
  36. void ApplyWheelSteering(SteeringDynamicsData& wheelData, float steering, double deltaTimeNs);
  37. VehicleConfiguration m_vehicleConfiguration;
  38. AZStd::vector<WheelDynamicsData> m_driveWheelsData;
  39. AZStd::vector<SteeringDynamicsData> m_steeringData;
  40. PidConfiguration m_steeringPid;
  41. float m_speedCommand = 0.0f;
  42. AckermannModelLimits m_limits;
  43. };
  44. } // namespace ROS2Controllers::VehicleDynamics