diff --git a/README.md b/README.md index 3f492a5835b..415d0d371ea 100644 --- a/README.md +++ b/README.md @@ -13,6 +13,12 @@ Orca Slicer is an open source slicer for FDM printers. - More granular controls - More features can be found in [change notes](https://github.com/SoftFever/OrcaSlicer/releases/) +# Wiki +The wiki below aims to provide a detailed explanation of the slicer settings, how to get the most out of them as well as how to calibrate and setup your printer. + +The wiki is work in progress so bear with us while we get it up and running! + +**[Access the wiki here](https://github.com/SoftFever/OrcaSlicer/wiki)** # Download diff --git a/doc/Home.md b/doc/Home.md index fce4bc34805..998edbe4090 100644 --- a/doc/Home.md +++ b/doc/Home.md @@ -8,13 +8,13 @@ The Wiki is work in progress so bear with us while we get it up and running! The below sections provide a detailed settings explanation as well as tips and tricks in setting these for optimal print results. ### Quality Settings -- [Layer Height Settings](print_settings/quality/quality_settings_layer_height) -- [Line Width Settings](print_settings/quality/quality_settings_line_width) -- [Seam Settings](print_settings/quality/quality_settings_seam) +- [Layer Height Settings](quality_settings_layer_height) +- [Line Width Settings](quality_settings_line_width) +- [Seam Settings](quality_settings_seam) - [Precise wall](Precise-wall) ### Speed Settings -- [Extrusion rate smoothing](print_settings/speed/extrusion-rate-smoothing) +- [Extrusion rate smoothing](extrusion-rate-smoothing) ### Multi material - [Single Extruder Multimaterial](semm) @@ -30,8 +30,9 @@ The below sections provide a detailed settings explanation as well as tips and t ## Printer Calibration The guide below takes you through the key calibration tests in Orca - flow rate, pressure advance, print temperature, retraction, tolerances and maximum volumetric speed - [Calibration Guide](./Calibration) +- [Adaptive Pressure Advance Guide](adaptive-pressure-advance) ## Developer Section - [How to build Orca Slicer](./How-to-build) - [Localization and translation guide](Localization_guide) -- [Developer Reference](./developer-reference/Home) +- [Developer Reference](https://github.com/SoftFever/OrcaSlicer/blob/main/doc/developer-reference/Home.md) diff --git a/doc/adaptive-pressure-advance.md b/doc/adaptive-pressure-advance.md new file mode 100644 index 00000000000..3528352b4a9 --- /dev/null +++ b/doc/adaptive-pressure-advance.md @@ -0,0 +1,176 @@ +# Adaptive Pressure Advance + +This feature aims to dynamically adjust the printer’s pressure advance to better match the conditions the toolhead is facing during a print. Specifically, to more closely align to the ideal values as flow rate, acceleration, and bridges are encountered. +This wiki page aims to explain how this feature works, the prerequisites required to get the most out of it as well as how to calibrate it and set it up. + +## Settings Overview + +This feature introduces the below options under the filament settings: + +1. **Enable adaptive pressure advance:** This is the on/off setting switch for adaptive pressure advance. +2. **Enable adaptive pressure advance for overhangs:** Enable adaptive PA for overhangs as well as when flow changes within the same feature. This is an experimental option because if the PA profile is not set accurately, it will cause uniformity issues on the external surfaces before and after overhangs. It is recommended to start with this option switched off and enable it after the core adaptive pressure advance feature is calibrated correctly. +3. **Pressure advance for bridges:** Sets the desired pressure advance value for bridges. Set it to 0 to disable this feature. Experiments have shown that a lower PA value when printing bridges helps reduce the appearance of slight under extrusion immediately after a bridge, which is caused by the pressure drop in the nozzle when printing in the air. Therefore, a lower pressure advance value helps counteract this. A good starting point is approximately half your usual PA value. +4. **Adaptive pressure advance measurements:** This field contains the calibration values used to generate the pressure advance profile for the nozzle/printer. Input sets of pressure advance (PA) values and the corresponding volumetric flow speeds and accelerations they were measured at, separated by a comma. Add one set of values per line. More information on how to calibrate the model follows in the sections below. +5. **Pressure advance:** The old field is still needed and is required to be populated with a PA value. A “good enough” median PA value should be entered here, as this will act as a fallback value when performing tool changes, printing a purge/wipe tower for multi-color prints as well as a fallback in case the model fails to identify an appropriate value (unlikely but it’s the ultimate backstop). + +Adaptive PA settings + + +## Pre-Requisites + +This feature has been tested with Klipper-based printers. While it may work with Marlin or Bambu lab printers, it is currently untested with them. It shouldn’t adversely affect the machine; however, the quality results from enabling it are not validated. + +**Older versions of Klipper used to stutter when pressure advance was changed while the toolhead was in motion. This has been fixed with the latest Klipper firmware releases. Therefore, make sure your Klipper installation is updated to the latest version before enabling this feature, in order to avoid any adverse quality impacts.** + +Klipper firmware released after July 11th, 2024 (version greater than approximately v0.12.0-267) contains the above fix and is compatible with adaptive pressure advance. If you are upgrading from an older version, make sure you update both your Klipper installation as well as reflash the printer MCU’s (main board and toolhead board if present). + +## Use case (what to expect) + +Following experimentation, it has been noticed that the optimal pressure advance value is less: + +1. The faster you print (hence the higher the volumetric flow rate requested from the toolhead). +2. The larger the layer height (hence the higher the volumetric flow rate requested from the toolhead). +3. The higher the print acceleration is. + +What this means is that we never get ideal PA values for each print feature, especially when they vary drastically in speed and acceleration. We can tune PA for a faster print speed (flow) but compromise on corner sharpness for slower speeds or tune PA for corner sharpness and deal with slight corner-perimeter separation in faster speeds. The same goes for accelerations as well as different layer heights. + +This compromise usually means that we settle for tuning an "in-between" PA value between slower external features and faster internal features so we don't get gaps, but also not get too much bulging in external perimeters. + +**However, what this also means is that if you are printing with a single layer height, single speed, and acceleration, there is no need to enable this feature.** + +Adaptive pressure advance aims to address this limitation by implementing a completely different method of setting pressure advance. **Following a set of PA calibration tests done at different flow rates (speeds and layer heights) and accelerations, a pressure advance model is calculated by the slicer.** Then that model is used to emit the best fit PA for any arbitrary feature flow rate (speed) and acceleration used in the print process. + +In addition, it means that you only need to tune this feature once and print across different layer heights with good PA performance. + +Finally, if during calibration you notice that there is little to no variance between the PA tests, this feature is redundant for you. **From experiments, high flow nozzles fitted on high-speed core XY printers appear to benefit the most from this feature as they print with a larger range of flow rates and at a larger range of accelerations.** + +### Expected results: + +With this feature enabled there should be absolutely no bulge in the corners, just the smooth rounding caused by the square corner velocity of your printer. +![337601149-cbd96b75-a49f-4dde-ab5a-9bbaf96eae9c](https://github.com/user-attachments/assets/01234996-0528-4462-90c6-43828a246e41) +In addition, seams should appear smooth with no bulging or under extrusion. +![337601500-95e2350f-cffd-4af5-9c7a-e8f60870db7b](https://github.com/user-attachments/assets/46e16f2a-cf52-4862-ab06-12883b909615) +Solid infill should have no gaps, pinholes, or separation from the perimeters. +![337616471-9d949a67-c8b3-477e-9f06-c429d4e40be0](https://github.com/user-attachments/assets/3b8ddbff-47e7-48b5-9576-3d9e7fb24a9d) +Compared to with this feature disabled, where the internal solid infill and external-internal perimeters show signs of separation and under extrusion, when PA is tuned for optimal external perimeter performance as shown below. +![337621601-eacc816d-cff0-42e4-965d-fb5c00d34205](https://github.com/user-attachments/assets/82edfd96-d870-48fe-91c7-012e8c0d9ed0) + + +## How to calibrate the adaptive pressure advance model + +### Defining the calibration sets + +Firstly, it is important to understand your printer speed and acceleration limits in order to set meaningful boundaries for the calibrations: + +1. **Upper acceleration range:** Do not attempt to calibrate adaptive PA for an acceleration that is larger than what the Klipper input shaper calibration tool recommends for your selected shaper. For example, if Klipper recommends an EI shaper with 4k maximum acceleration for your slowest axis (usually the Y axis), don’t calibrate adaptive PA beyond that value. This is because after 4k the input shaper smoothing is magnified and the perimeter separations that appear like PA issues are caused by the input shaper smoothing the shape of the corner. Basically, you’d be attempting to compensate for an input shaper artefact with PA. +2. **Upper print speed range:** The Ellis PA pattern test has been proven to be the most efficient and effective test to run to calibrate adaptive PA. It is fast and allows for a reasonably accurate and easy-to-read PA value. However, the size of the line segments is quite small, which means that for the faster print speeds and slower accelerations, the toolhead will not be able to reach the full flow rate that we are calibrating against. It is therefore generally not recommended to attempt calibration with a print speed of higher than ~200-250mm/sec and accelerations slower than 1k in the PA pattern test. If your lowest acceleration is higher than 1k, then proportionally higher maximum print speeds can be used. + +**Remember:** With the calibration process, we aim to create a PA – Flow Rate – Acceleration profile for the toolhead. As we cannot directly control flow rate, we use print speed as a proxy (higher speed -> higher flow). + +With the above in mind, let’s create a worked example to identify the optimal number of PA tests to calibrate the adaptive PA model. + +**The below starting points are recommended for the majority of Core XY printers:** + +1. **Accelerations:** 1k, 2k, 4k +2. **Print speeds:** 50mm/sec, 100mm/sec, 150mm/sec, 200mm/sec. + +**That means we need to run 3x4 = 12 PA tests and identify the optimal PA for them.** + +Finally, if the maximum acceleration given by input shaper is materially higher than 4k, run a set of tests with the higher accelerations. For example, if input shaper allows a 6k value, run PA tests as below: + +1. **Accelerations:** 1k, 2k, 4k, 6k +2. **Print speeds:** 50mm/sec, 100mm/sec, 150mm/sec, 200mm/sec. + +Similarly, if the maximum value recommended is 12k, run PA tests as below: + +1. **Accelerations:** 1k, 2k, 4k, 8k, 12k +2. **Print speeds:** 50mm/sec, 100mm/sec, 150mm/sec, 200mm/sec. + +So, at worst case you will need to run 5x4 = 20 PA tests if your printer acceleration is on the upper end! In essence, you want enough granularity of data points to create a meaningful model while also not overdoing it with the number of tests. So, doubling the speed and acceleration is a good compromise to arrive at the optimal number of tests. +For this example, let’s assume that the baseline number of tests is adequate for your printer: + +1. **Accelerations:** 1k, 2k, 4k +2. **Print speeds:** 50mm/sec, 100mm/sec, 150mm/sec, 200mm/sec. + +We, therefore, need to run 12 PA tests as below: + +**Speed – Acceleration** + 1. 50 – 1k + 2. 100 – 1k + 3. 150 – 1k + 4. 200 – 1k + 5. 50 – 2k + 6. 100 – 2k + 7. 150 – 2k + 8. 200 – 2k + 9. 50 – 4k + 10. 100 – 4k + 11. 150 – 4k + 12. 200 – 4k + +### Identifying the flow rates from the print speed + +As mentioned earlier, **the print speed is used as a proxy to vary the extrusion flow rate**. Once your PA test is set up, change the gcode preview to “flow” and move the horizontal slider over one of the herringbone patterns and take note of the flow rate for different speeds. +![337939815-e358b960-cf96-41b5-8c7e-addde927933f](https://github.com/user-attachments/assets/21290435-6f2a-4a21-bcf0-28cd6ae1912a) + + +### Running the tests + +Setup your PA test as usual from the calibration menu in Orca slicer. It is recommended that the PA step is set to a small value, to allow you to make meaningful distinctions between the different tests – **therefore a PA step value of 0.001 is recommended. ** + +**Set the end PA to a value high enough to start showing perimeter separation for the lowest flow (print speed) and acceleration test.** For example, for a Voron 350 using Revo HF, the maximum value was set to 0.05 as that was sufficient to show perimeter separation even at the slowest flow rates and accelerations. + +**If the test is too big to fit on the build plate, increase your starting PA value or the PA step value accordingly until the test can fit.** If the lowest value becomes too high and there is no ideal PA present in the test, focus on increasing the PA step value to reduce the number of herringbones printed (hence the size of the print). + +PA calibration parameters + +Once setup, your PA test should look like the below: + +PA calibration test 1 +Pa calibration test 2 + +Now input your identified print speeds and accelerations in the fields above and run the PA tests. + +**IMPORTANT:** Make sure your acceleration values are all the same in all text boxes. Same for the print speed values and Jerk (XY) values. Make sure your Jerk value is set to the external perimeter jerk used in your print profiles. +Now run the tests and note the optimal PA value, the flow, and the acceleration. You should produce a table like this: + +calibration table + +Concatenate the PA value, the flow value, and the acceleration value into the final comma-separated sets to create the values entered in the model as shown above. + +**You’re now done! The PA profile is created and calibrated!** + +Remember to paste the values in the adaptive pressure advance measurements text box as shown below, and save your filament profile. + +pa profile + + +### Tips + +#### Model input: + +The adaptive PA model built into the slicer is flexible enough to allow for as many or as few increments of flow and acceleration as you want. Ideally, you want at a minimum 3x data points for acceleration and flow in order to create a meaningful model. + +However, if you don’t want to calibrate for flow, just run the acceleration tests and leave flow the same for each test (in which case you’ll input only 3 rows in the model text box). In this case, flow will be ignored when the model is used. + +Similarly for acceleration – in the above example you’ll input only 4 rows in the model text box, in which case acceleration will be ignored when the model is used. + +**However, make sure a triplet of values is always provided – PA value, Flow, Acceleration.** + +#### Identifying the right PA: + +Higher acceleration and higher flow rate PA tests are easier to identify the optimal PA as the range of “good” values is much narrower. It’s evident where the PA is too large, as gaps start to appear in the corner and where PA is too low, as the corner starts bulging. + +However, the lower the flow rate and accelerations are, the range of good values is much wider. Having examined the PA tests even under a microscope, what is evident, is that if you can’t distinguish a value as being evidently better than another (i.e. sharper corner with no gaps) with the naked eye, then both values are correct. In which case, if you can’t find any meaningful difference, simply use the optimal values from the higher flow rates. + +- **Too high PA** + +![Too high PA](https://github.com/user-attachments/assets/ebc4e2d4-373e-42d5-af72-4d5bc81048ca) + +- **Too low PA** + +![Too low PA](https://github.com/user-attachments/assets/6a2b6f16-7d1c-46d0-91f3-def5ed560318) + +- **Optimal PA** + +![Optimal PA](https://github.com/user-attachments/assets/cd47cf2e-dd32-47b4-bbdd-1563de8849be) diff --git a/doc/developer-reference/Home.md b/doc/developer-reference/Home.md index bdbb65e07a2..ab08f2cbfea 100644 --- a/doc/developer-reference/Home.md +++ b/doc/developer-reference/Home.md @@ -2,5 +2,5 @@ This is a documentation from someone exploring the code and is by no means complete or even completely accurate. Please edit the parts you might find inaccurate. This is probably going to be helpful nonetheless. -- [Preset, PresetBundle and PresetCollection](./Preset-and-bundle) -- [Plater, Sidebar, Tab, ComboBox](./plater-sidebar-tab-combobox) +- [Preset, PresetBundle and PresetCollection](https://github.com/SoftFever/OrcaSlicer/blob/main/doc/developer-reference/Preset-and-bundle.md) +- [Plater, Sidebar, Tab, ComboBox](https://github.com/SoftFever/OrcaSlicer/blob/main/doc/developer-reference/plater-sidebar-tab-combobox.md) diff --git a/src/slic3r/GUI/Tab.cpp b/src/slic3r/GUI/Tab.cpp index 7fcc8eeacd6..aaee7380ec3 100644 --- a/src/slic3r/GUI/Tab.cpp +++ b/src/slic3r/GUI/Tab.cpp @@ -2003,23 +2003,23 @@ void TabPrint::build() auto page = add_options_page(L("Quality"), "custom-gcode_quality"); // ORCA: icon only visible on placeholders auto optgroup = page->new_optgroup(L("Layer height"), L"param_layer_height"); - optgroup->append_single_option_line("layer_height"); - optgroup->append_single_option_line("initial_layer_print_height"); + optgroup->append_single_option_line("layer_height","quality_settings_layer_height"); + optgroup->append_single_option_line("initial_layer_print_height","quality_settings_layer_height"); optgroup = page->new_optgroup(L("Line width"), L"param_line_width"); - optgroup->append_single_option_line("line_width"); - optgroup->append_single_option_line("initial_layer_line_width"); - optgroup->append_single_option_line("outer_wall_line_width"); - optgroup->append_single_option_line("inner_wall_line_width"); - optgroup->append_single_option_line("top_surface_line_width"); - optgroup->append_single_option_line("sparse_infill_line_width"); - optgroup->append_single_option_line("internal_solid_infill_line_width"); - optgroup->append_single_option_line("support_line_width"); + optgroup->append_single_option_line("line_width","quality_settings_line_width"); + optgroup->append_single_option_line("initial_layer_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("outer_wall_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("inner_wall_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("top_surface_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("sparse_infill_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("internal_solid_infill_line_width","quality_settings_line_width"); + optgroup->append_single_option_line("support_line_width","quality_settings_line_width"); optgroup = page->new_optgroup(L("Seam"), L"param_seam"); - optgroup->append_single_option_line("seam_position", "seam"); - optgroup->append_single_option_line("staggered_inner_seams", "seam"); - optgroup->append_single_option_line("seam_gap","seam"); + optgroup->append_single_option_line("seam_position", "quality_settings_seam"); + optgroup->append_single_option_line("staggered_inner_seams", "quality_settings_seam"); + optgroup->append_single_option_line("seam_gap","quality_settings_seam"); optgroup->append_single_option_line("seam_slope_type", "seam#scarf-joint-seam"); optgroup->append_single_option_line("seam_slope_conditional", "seam#scarf-joint-seam"); optgroup->append_single_option_line("scarf_angle_threshold", "seam#scarf-joint-seam"); @@ -2031,10 +2031,10 @@ void TabPrint::build() optgroup->append_single_option_line("seam_slope_steps", "seam#scarf-joint-seam"); optgroup->append_single_option_line("scarf_joint_flow_ratio", "seam#scarf-joint-seam"); optgroup->append_single_option_line("seam_slope_inner_walls", "seam#scarf-joint-seam"); - optgroup->append_single_option_line("role_based_wipe_speed","seam"); - optgroup->append_single_option_line("wipe_speed", "seam"); - optgroup->append_single_option_line("wipe_on_loops","seam"); - optgroup->append_single_option_line("wipe_before_external_loop","seam"); + optgroup->append_single_option_line("role_based_wipe_speed","quality_settings_seam"); + optgroup->append_single_option_line("wipe_speed", "quality_settings_seam"); + optgroup->append_single_option_line("wipe_on_loops","quality_settings_seam"); + optgroup->append_single_option_line("wipe_before_external_loop","quality_settings_seam"); optgroup = page->new_optgroup(L("Precision"), L"param_precision");