Skip to content

Commit

Permalink
Reduce code duplication
Browse files Browse the repository at this point in the history
  • Loading branch information
rschaeuble committed Dec 24, 2024
1 parent 473631d commit b44e184
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 32 deletions.
14 changes: 2 additions & 12 deletions shaketune/commands/axes_shaper_calibration.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

from ..helpers.accelerometer import Accelerometer, MeasurementsManager
from ..helpers.common_func import AXIS_CONFIG
from ..helpers.compat import res_tester_config
from ..helpers.console_output import ConsoleOutput
from ..helpers.resonance_test import vibrate_axis
from ..shaketune_process import ShakeTuneProcess
Expand All @@ -24,18 +25,7 @@ def axes_shaper_calibration(gcmd, config, st_process: ShakeTuneProcess) -> None:
toolhead_info = toolhead.get_status(systime)

# Get the default values for the frequency range and the acceleration per Hz
if hasattr(res_tester, 'test'):
# Old Klipper code (before Dec 6, 2024: https://github.com/Klipper3d/klipper/commit/16b4b6b302ac3ffcd55006cd76265aad4e26ecc8)
default_min_freq = res_tester.test.min_freq
default_max_freq = res_tester.test.max_freq
default_accel_per_hz = res_tester.test.accel_per_hz
test_points = res_tester.test.get_start_test_points()
else:
# New Klipper code (after Dec 6, 2024) with the sweeping test
default_min_freq = res_tester.generator.vibration_generator.min_freq
default_max_freq = res_tester.generator.vibration_generator.max_freq
default_accel_per_hz = res_tester.generator.vibration_generator.accel_per_hz
test_points = res_tester.probe_points
default_min_freq, default_max_freq, default_accel_per_hz, test_points = res_tester_config(config)

min_freq = gcmd.get_float('FREQ_START', default=default_min_freq, minval=1)
max_freq = gcmd.get_float('FREQ_END', default=default_max_freq, minval=1)
Expand Down
14 changes: 2 additions & 12 deletions shaketune/commands/compare_belts_responses.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@

from ..helpers.accelerometer import Accelerometer, MeasurementsManager
from ..helpers.common_func import AXIS_CONFIG
from ..helpers.compat import res_tester_config
from ..helpers.console_output import ConsoleOutput
from ..helpers.motors_config_parser import MotorsConfigParser
from ..helpers.resonance_test import vibrate_axis
Expand All @@ -24,18 +25,7 @@ def compare_belts_responses(gcmd, config, st_process: ShakeTuneProcess) -> None:
systime = printer.get_reactor().monotonic()

# Get the default values for the frequency range and the acceleration per Hz
if hasattr(res_tester, 'test'):
# Old Klipper code (before Dec 6, 2024: https://github.com/Klipper3d/klipper/commit/16b4b6b302ac3ffcd55006cd76265aad4e26ecc8)
default_min_freq = res_tester.test.min_freq
default_max_freq = res_tester.test.max_freq
default_accel_per_hz = res_tester.test.accel_per_hz
test_points = res_tester.test.get_start_test_points()
else:
# New Klipper code (after Dec 6, 2024) with the sweeping test
default_min_freq = res_tester.generator.vibration_generator.min_freq
default_max_freq = res_tester.generator.vibration_generator.max_freq
default_accel_per_hz = res_tester.generator.vibration_generator.accel_per_hz
test_points = res_tester.probe_points
default_min_freq, default_max_freq, default_accel_per_hz, test_points = res_tester_config(config)

min_freq = gcmd.get_float('FREQ_START', default=default_min_freq, minval=1)
max_freq = gcmd.get_float('FREQ_END', default=default_max_freq, minval=1)
Expand Down
10 changes: 2 additions & 8 deletions shaketune/commands/excitate_axis_at_freq.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@

from ..helpers.accelerometer import Accelerometer, MeasurementsManager
from ..helpers.common_func import AXIS_CONFIG
from ..helpers.compat import res_tester_config
from ..helpers.console_output import ConsoleOutput
from ..helpers.resonance_test import vibrate_axis_at_static_freq
from ..shaketune_process import ShakeTuneProcess
Expand Down Expand Up @@ -53,14 +54,7 @@ def excitate_axis_at_freq(gcmd, config, st_process: ShakeTuneProcess) -> None:
systime = printer.get_reactor().monotonic()

# Get the default values for the acceleration per Hz and the test points
if hasattr(res_tester, 'test'):
# Old Klipper code (before Dec 6, 2024: https://github.com/Klipper3d/klipper/commit/16b4b6b302ac3ffcd55006cd76265aad4e26ecc8)
default_accel_per_hz = res_tester.test.accel_per_hz
test_points = res_tester.test.get_start_test_points()
else:
# New Klipper code (after Dec 6, 2024) with the sweeping test
default_accel_per_hz = res_tester.generator.vibration_generator.accel_per_hz
test_points = res_tester.probe_points
default_min_freq, default_max_freq, default_accel_per_hz, test_points = res_tester_config(config)

if accel_per_hz is None:
accel_per_hz = default_accel_per_hz
Expand Down
33 changes: 33 additions & 0 deletions shaketune/helpers/compat.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
# Shake&Tune: 3D printer analysis tools
#
# Copyright (C) 2024 Félix Boisselier <felix@fboisselier.fr> (Frix_x on Discord)
# Licensed under the GNU General Public License v3.0 (GPL-3.0)
#
# File: compare_belts_responses.py
# Description: Provides a command for comparing the frequency response of belts in CoreXY and CoreXZ kinematics 3D printers.
# The script performs resonance tests along specified axes, starts and stops measurements, and generates graphs
# for each axis to analyze the collected data.

from collections import namedtuple

ResTesterConfig = namedtuple('ResTesterConfig', ['default_min_freq', 'default_max_freq', 'default_accel_per_hz', 'test_points'])

def res_tester_config(config) -> ResTesterConfig:
printer = config.get_printer()
res_tester = printer.lookup_object('resonance_tester')

# Get the default values for the frequency range and the acceleration per Hz
if hasattr(res_tester, 'test'):
# Old Klipper code (before Dec 6, 2024: https://github.com/Klipper3d/klipper/commit/16b4b6b302ac3ffcd55006cd76265aad4e26ecc8)
default_min_freq = res_tester.test.min_freq
default_max_freq = res_tester.test.max_freq
default_accel_per_hz = res_tester.test.accel_per_hz
test_points = res_tester.test.get_start_test_points()
else:
# New Klipper code (after Dec 6, 2024) with the sweeping test
default_min_freq = res_tester.generator.vibration_generator.min_freq
default_max_freq = res_tester.generator.vibration_generator.max_freq
default_accel_per_hz = res_tester.generator.vibration_generator.accel_per_hz
test_points = res_tester.probe_points

return ResTesterConfig(default_min_freq, default_max_freq, default_accel_per_hz, test_points)

0 comments on commit b44e184

Please sign in to comment.