From 80c6d443484c9436698bf828e2fd901a3ae3f7e2 Mon Sep 17 00:00:00 2001 From: ahiuchingau <20424172+ahiuchingau@users.noreply.github.com> Date: Mon, 26 Aug 2024 11:50:18 -0400 Subject: [PATCH 01/10] PLAT-469 add linear motion system for stacker axes --- .../common/core/linear_motion_system.hpp | 66 +++++++++++++++++++ .../flex-stacker/flex-stacker/motor_task.hpp | 20 ++++++ 2 files changed, 86 insertions(+) create mode 100644 stm32-modules/include/common/core/linear_motion_system.hpp diff --git a/stm32-modules/include/common/core/linear_motion_system.hpp b/stm32-modules/include/common/core/linear_motion_system.hpp new file mode 100644 index 000000000..43f503947 --- /dev/null +++ b/stm32-modules/include/common/core/linear_motion_system.hpp @@ -0,0 +1,66 @@ +#pragma once + +#include +#include + +namespace lms { + +struct BeltConfig { + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float pulley_diameter; // mm + [[nodiscard]] constexpr auto get_mm_per_rev() const -> float { + return static_cast(pulley_diameter * std::numbers::pi); + } +}; + +struct LeadScrewConfig { + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float lead_screw_pitch; // mm/rev + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float gear_reduction_ratio; // large teeth / small teeth + [[nodiscard]] constexpr auto get_mm_per_rev() const -> float { + return lead_screw_pitch / gear_reduction_ratio; + } +}; + +struct GearBoxConfig { + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float gear_diameter; // mm + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float gear_reduction_ratio; // large teeth / small teeth + [[nodiscard]] constexpr auto get_mm_per_rev() const -> float { + return static_cast((gear_diameter * std::numbers::pi) / + gear_reduction_ratio); + } +}; + +template +concept MotorMechanicalConfig = requires { + std::is_same_v || std::is_same_v || + std::is_same_v; + }; + +template +struct LinearMotionSystemConfig { + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + MEConfig mech_config{}; + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float steps_per_rev{}; + // NOLINTNEXTLINE(misc-non-private-member-variables-in-classes) + float microstep{}; + [[nodiscard]] constexpr auto get_usteps_per_mm() const -> float { + return (steps_per_rev * microstep) / (mech_config.get_mm_per_rev()); + } + [[nodiscard]] constexpr auto get_usteps_per_um() const -> float { + return (steps_per_rev * microstep) / + // NOLINTNEXTLINE(cppcoreguidelines-avoid-magic-numbers) + (mech_config.get_mm_per_rev() * 1000.0); + } + [[nodiscard]] constexpr auto get_um_per_step() const -> float { + return (mech_config.get_mm_per_rev()) / (steps_per_rev * microstep) * + // NOLINTNEXTLINE(cppcoreguidelines-avoid-magic-numbers) + 1000; + } +}; + +} // namespace lms diff --git a/stm32-modules/include/flex-stacker/flex-stacker/motor_task.hpp b/stm32-modules/include/flex-stacker/flex-stacker/motor_task.hpp index 67cdaedb5..2aef57a09 100644 --- a/stm32-modules/include/flex-stacker/flex-stacker/motor_task.hpp +++ b/stm32-modules/include/flex-stacker/flex-stacker/motor_task.hpp @@ -6,6 +6,7 @@ #pragma once #include "core/ack_cache.hpp" +#include "core/linear_motion_system.hpp" #include "core/queue_aggregator.hpp" #include "core/version.hpp" #include "firmware/motor_interrupt.hpp" @@ -27,6 +28,25 @@ concept MotorControlPolicy = requires(P p, MotorID motor_id) { using Message = messages::MotorMessage; using Controller = motor_interrupt_controller::MotorInterruptController; +static constexpr struct lms::LinearMotionSystemConfig + motor_x_config = { + .mech_config = lms::LeadScrewConfig{.lead_screw_pitch = 9.7536, + .gear_reduction_ratio = 1.0}, + .steps_per_rev = 200, .microstep = 16, +}; +static constexpr struct lms::LinearMotionSystemConfig + motor_z_config = { + .mech_config = lms::LeadScrewConfig{.lead_screw_pitch = 9.7536, + .gear_reduction_ratio = 1.0}, + .steps_per_rev = 200, .microstep = 16, +}; +static constexpr struct lms::LinearMotionSystemConfig + motor_l_config = { + .mech_config = lms::GearBoxConfig{.gear_diameter = 16.0, + .gear_reduction_ratio = 16.0 / 30.0}, + .steps_per_rev = 200, .microstep = 16, +}; + template