docs: Limiting max_smoothing for input shaper autocalibration

Signed-off-by: Dmitry Butyugin <dmbutyugin@google.com>
This commit is contained in:
Dmitry Butyugin 2020-12-19 22:36:37 +01:00 committed by KevinOConnor
parent 1b1a97e8bd
commit ab93ee9293
6 changed files with 108 additions and 22 deletions

View File

@ -1414,7 +1414,9 @@ In order to use most of the functionality of this module, additional
software dependencies must be installed; refer to software dependencies must be installed; refer to
[Measuring Resonances](Measuring_Resonances.md) and the [Measuring Resonances](Measuring_Resonances.md) and the
[command reference](G-Codes.md#resonance-testing-commands) for more [command reference](G-Codes.md#resonance-testing-commands) for more
information. information. See the [Max smoothing](Measuring_Resonances.md#max-smoothing)
section of the measuring resonances guide for more information on
`max_smoothing` parameter and its use.
``` ```
[resonance_tester] [resonance_tester]
@ -1438,6 +1440,11 @@ information.
# and on the toolhead (for X axis). These parameters have the same # and on the toolhead (for X axis). These parameters have the same
# format as 'accel_chip' parameter. Only 'accel_chip' or these two # format as 'accel_chip' parameter. Only 'accel_chip' or these two
# parameters must be provided. # parameters must be provided.
#max_smoothing:
# Maximum input shaper smoothing to allow for each axis during shaper
# auto-calibration (with 'SHAPER_CALIBRATE' command). By default no
# maximum smoothing is specified. Refer to Measuring_Resonances guide
# for more details on using this feature.
#min_freq: 5 #min_freq: 5
# Minimum frequency to test for resonances. The default is 5 Hz. # Minimum frequency to test for resonances. The default is 5 Hz.
#max_freq: 120 #max_freq: 120

View File

@ -739,13 +739,17 @@ is enabled (also see the
"YYYYMMDD_HHMMSS" format. "YYYYMMDD_HHMMSS" format.
- `SHAPER_CALIBRATE [AXIS=<axis>] [NAME=<name>] - `SHAPER_CALIBRATE [AXIS=<axis>] [NAME=<name>]
[FREQ_START=<min_freq>] [FREQ_END=<max_freq>] [FREQ_START=<min_freq>] [FREQ_END=<max_freq>]
[HZ_PER_SEC=<hz_per_sec>]`: Similarly to `TEST_RESONANCES`, runs the [HZ_PER_SEC=<hz_per_sec>] [MAX_SMOOTHING=<max_smoothing>]`:
resonance test as configured, and tries to find the optimal Similarly to `TEST_RESONANCES`, runs the resonance test as configured,
parameters for the input shaper for the requested axis (or both X and tries to find the optimal parameters for the input shaper for the
and Y axes if `AXIS` parameter is unset). The results of the tuning requested axis (or both X and Y axes if `AXIS` parameter is unset).
are printed to the console, and the frequency responses and the If `MAX_SMOOTHING` is unset, its value is taken from `[resonance_tester]`
different input shapers values are written to a CSV file(s) section, with the default being unset. See the
`/tmp/calibration_data_<axis>_<name>.csv`. Unless specified, NAME [Max smoothing](Measuring_Resonances.md#max-smoothing) of the measuring
resonances guide for more information on the use of this feature.
The results of the tuning are printed to the console, and the frequency
responses and the different input shapers values are written to a CSV
file(s) `/tmp/calibration_data_<axis>_<name>.csv`. Unless specified, NAME
defaults to the current time in "YYYYMMDD_HHMMSS" format. Note that defaults to the current time in "YYYYMMDD_HHMMSS" format. Note that
the suggested input shaper parameters can be persisted in the config the suggested input shaper parameters can be persisted in the config
by issuing `SAVE_CONFIG` command. by issuing `SAVE_CONFIG` command.

View File

@ -168,22 +168,22 @@ recommended for your setup. For example:
![Resonances](img/calibrate-y.png) ![Resonances](img/calibrate-y.png)
``` ```
Fitted shaper 'zv' frequency = 56.7 Hz (vibrations = 23.2%) Fitted shaper 'zv' frequency = 37.0 Hz (vibrations = 29.1%, smoothing ~= 0.115)
Fitted shaper 'mzv' frequency = 52.9 Hz (vibrations = 10.9%) Fitted shaper 'mzv' frequency = 35.4 Hz (vibrations = 15.9%, smoothing ~= 0.163)
Fitted shaper 'ei' frequency = 62.0 Hz (vibrations = 8.9%) Fitted shaper 'ei' frequency = 42.0 Hz (vibrations = 15.1%, smoothing ~= 0.183)
Fitted shaper '2hump_ei' frequency = 59.0 Hz (vibrations = 4.9%) Fitted shaper '2hump_ei' frequency = 45.6 Hz (vibrations = 9.7%, smoothing ~= 0.260)
Fitted shaper '3hump_ei' frequency = 65.0 Hz (vibrations = 3.3%) Fitted shaper '3hump_ei' frequency = 59.0 Hz (vibrations = 7.5%, smoothing ~= 0.235)
Recommended shaper is 2hump_ei @ 59.0 Hz Recommended shaper is 3hump_ei @ 59.0 Hz
``` ```
The suggested configuration can be added to `[input_shaper]` section of The suggested configuration can be added to `[input_shaper]` section of
`printer.cfg`: `printer.cfg`, e.g.:
``` ```
[input_shaper] [input_shaper]
shaper_freq_x: 59.0 shaper_freq_x: ...
shaper_type_x: 2hump_ei shaper_type_x: ...
shaper_freq_y: ... shaper_freq_y: 59.0
shaper_type_y: ... shaper_type_y: 3hump_ei
``` ```
or you can choose some other configuration yourself based on the generated or you can choose some other configuration yourself based on the generated
charts: peaks in the power spectral density on the charts correspond to charts: peaks in the power spectral density on the charts correspond to
@ -223,11 +223,82 @@ probe_points: ...
Then the commands `TEST_RESONANCES AXIS=X` and `TEST_RESONANCES AXIS=Y` Then the commands `TEST_RESONANCES AXIS=X` and `TEST_RESONANCES AXIS=Y`
will use the correct accelerometer for each axis. will use the correct accelerometer for each axis.
## Max smoothing
Keep in mind that the input shaper can create some smoothing in parts.
Automatic tuning of the input shaper performed by `calibrate_shaper.py`
script or `SHAPER_CALIBRATE` command tries not to exacerbate the smoothing,
but at the same time they try to minimize the resulting vibrations.
Sometimes they can make a sub-optimal choice of the shaper frequency, or
maybe you simply prefer to have less smoothing in parts at the expense of
a larger remaining vibrations. In these cases, you can request to limit
the maximum smoothing from the input shaper.
Let's consider the following results from the automatic tuning:
![Resonances](img/calibrate-x.png)
```
Fitted shaper 'zv' frequency = 62.2 Hz (vibrations = 36.9%, smoothing ~= 0.046)
Fitted shaper 'mzv' frequency = 35.6 Hz (vibrations = 18.1%, smoothing ~= 0.161)
Fitted shaper 'ei' frequency = 54.6 Hz (vibrations = 19.3%, smoothing ~= 0.108)
Fitted shaper '2hump_ei' frequency = 46.2 Hz (vibrations = 9.2%, smoothing ~= 0.253)
Fitted shaper '3hump_ei' frequency = 50.0 Hz (vibrations = 7.2%, smoothing ~= 0.328)
Recommended shaper is 2hump_ei @ 46.2 Hz
```
Note that the reported `smoothing` values are some abstract projected values.
These values can be used to compare different configurations: the higher the
value, the more smoothing a shaper will create. However, these smoothing scores
do not represent any real measure of smoothing, because the actual smoothing
depends on [`max_accel`](#selecting-max-accel) and `square_corner_velocity`
parameters. Therefore, you should print some test prints to see how much
smoothing exactly a chosen configuration creates.
In the example above the suggested shaper parameters are not bad, but what if
you want to get less smoothing on the X axis? You can try to limit the maximum
shaper smoothing using the following command:
```
~/klipper/scripts/calibrate_shaper.py /tmp/resonances_x_*.csv -o /tmp/shaper_calibrate_x.png --max_smoothing=0.2
```
which limits the smoothing to 0.2 score. Now you can get the following result:
![Resonances](img/calibrate-x-max-smoothing.png)
```
Fitted shaper 'zv' frequency = 55.2 Hz (vibrations = 34.2%, smoothing ~= 0.057)
Fitted shaper 'mzv' frequency = 33.8 Hz (vibrations = 17.4%, smoothing ~= 0.178)
Fitted shaper 'ei' frequency = 47.4 Hz (vibrations = 17.6%, smoothing ~= 0.143)
Fitted shaper '2hump_ei' frequency = 52.0 Hz (vibrations = 11.9%, smoothing ~= 0.200)
Fitted shaper '3hump_ei' frequency = 75.0 Hz (vibrations = 9.7%, smoothing ~= 0.146)
Recommended shaper is 3hump_ei @ 75.0 Hz
```
If you compare to the previously suggested parameters, the vibrations are a bit
larger, but the smoothing is significantly smaller than previously.
When deciding which `max_smoothing` parameter to choose, you can use a
trial-and-error approach. Try a few different values and see which results
you get. Note however that if you request the script to find a configuration
for your printer with an unrealistically small smoothing, it will be unable
to find a reasonable configuration. The suggested parameters will have a poor
performance in this case and you can get too much remaining ringing as a result.
So, always double-check the projected remaining vibrations and make sure they
are not too high.
Note that if you chose a good `max_smoothing` value for both of your axes, you
can store it in the `printer.cfg` as
```
[resonance_tester]
accel_chip: ...
probe_points: ...
max_smoothing: 0.25 # an example
```
Then, if you [rerun](#input-shaper-re-calibration) the input shaper auto-tuning
using `SHAPER_CALIBRATE` Klipper command in the future, it will use the stored
`max_smoothing` value as a reference.
## Selecting max_accel ## Selecting max_accel
Keep in mind that the input shaper can create some smoothing in parts, Since the input shaper can create some smoothing in parts, especially at high
especially at high accelerations. Therefore, after the calibration accelerations, you will still need to choose the `max_accel` value that
is finished, you will still need to choose the `max_accel` value that
does not create too much smoothing in the printed parts. Follow does not create too much smoothing in the printed parts. Follow
[this](Resonance_Compensation.md#selecting-max_accel) part of [this](Resonance_Compensation.md#selecting-max_accel) part of
the input shaper tuning guide and print the test model. the input shaper tuning guide and print the test model.
@ -237,6 +308,10 @@ The same notice applies to the input shaper
`SHAPER_CALIBRATE` command: it is still necessary to choose the right `SHAPER_CALIBRATE` command: it is still necessary to choose the right
`max_accel` value after the auto-calibration. `max_accel` value after the auto-calibration.
If you are doing a shaper re-calibration and the reported smoothing for the
suggested shaper configuration is almost the same as what you got during the
previous calibration, this step can be skipped.
# Input Shaper auto-calibration # Input Shaper auto-calibration

Binary file not shown.

After

Width:  |  Height:  |  Size: 151 KiB

BIN
docs/img/calibrate-x.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 156 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 134 KiB

After

Width:  |  Height:  |  Size: 144 KiB