2
0

AckermannDriveModel.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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 <ROS2/VehicleDynamics/DriveModels/PidConfiguration.h>
  11. #include <VehicleDynamics/DriveModel.h>
  12. #include <VehicleDynamics/ModelLimits/AckermannModelLimits.h>
  13. #include <VehicleDynamics/VehicleConfiguration.h>
  14. #include <VehicleDynamics/VehicleInputs.h>
  15. #include <VehicleDynamics/WheelDynamicsData.h>
  16. namespace ROS2::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. // DriveModel overrides
  24. void Activate(const VehicleConfiguration& vehicleConfig) override;
  25. static void Reflect(AZ::ReflectContext* context);
  26. protected:
  27. // DriveModel overrides
  28. void ApplyState(const VehicleInputs& inputs, AZ::u64 deltaTimeNs) override;
  29. const VehicleModelLimits* GetVehicleLimitPtr() const override;
  30. private:
  31. void ApplySteering(float steering, AZ::u64 deltaTimeNs);
  32. void ApplySpeed(float speed, AZ::u64 deltaTimeNs);
  33. void ApplyWheelSteering(SteeringDynamicsData& wheelData, float steering, double deltaTimeNs);
  34. VehicleConfiguration m_vehicleConfiguration;
  35. AZStd::vector<WheelDynamicsData> m_driveWheelsData;
  36. AZStd::vector<SteeringDynamicsData> m_steeringData;
  37. PidConfiguration m_steeringPid;
  38. AckermannModelLimits m_limits;
  39. };
  40. } // namespace ROS2::VehicleDynamics