Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Implement module in_focus process cache #18195

Merged
merged 1 commit into from
Jan 22, 2025

Conversation

jenshannoschwalm
Copy link
Collaborator

@jenshannoschwalm jenshannoschwalm commented Jan 12, 2025

Updated:

The standard pixelpipe cache offers input data for a module to be fully processed if all parameters including blending stuff match.

This commit implements a single line cache per pixelpipe only effective for a module being in focus and doing some blending.

Data are possibly read from this cache instead of the possibly costly module->process/_cl.
Reading from this cache is reported in logs with -d pipe
Possibly write to that cache if data were not valid before.

While being here some cosmetic code simplifications.

Fixes #18180

@jenshannoschwalm jenshannoschwalm added scope: UI user interface and interactions scope: performance doing everything the same but faster release notes: pending OpenCL Related to darktable OpenCL code labels Jan 12, 2025
@jenshannoschwalm jenshannoschwalm marked this pull request as draft January 12, 2025 09:02
@jenshannoschwalm
Copy link
Collaborator Author

For simplicity using the commit from #18071

@jenshannoschwalm
Copy link
Collaborator Author

Some OpenCL related fixes, some refactoring and removed dependency other commit

@jenshannoschwalm jenshannoschwalm marked this pull request as ready for review January 14, 2025 05:35
@jenshannoschwalm
Copy link
Collaborator Author

@ralfbrown you might want to have a look now.

A simple reproducer would be:

  1. Add a diffuse&sharpen instance with heavy processing
  2. Apply any mask/blending
  3. Modify any of the blending parameters
  4. Watch out for "from focus cache" in -d pipe logs and/or enjoy UI responsiveness

@jenshannoschwalm jenshannoschwalm added this to the 5.2 milestone Jan 14, 2025
@jenshannoschwalm
Copy link
Collaborator Author

Release note: Improved user interface responsiveness for blending operations

The standard pixelpipe cache offers *input* data for a module to be fully processed if all parameters including
blending stuff match.

This commit implements a single line cache per pixelpipe only effective for a module being in focus *and* doing
some blending.

Data are possibly read from this cache instead of the possibly costly module->process/_cl.
Possibly write to that cache if data were not valid before.

Avoid some dereferencing

Fixes darktable-org#18180
Copy link
Member

@TurboGit TurboGit left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! I can reproduce the speed-up, nice!

@TurboGit TurboGit merged commit f8335b1 into darktable-org:master Jan 22, 2025
6 checks passed
@TurboGit
Copy link
Member

@jenshannoschwalm : Just a gentle side note, do not remove the [release notes: pending] tag. This is the way for me to list the needed notes and I remove the tag when I have integrated the note into RELEASE_NOTES.md.

@ralfbrown
Copy link
Collaborator

Maybe have a label such as "release notes: proposed" so you can see at a glance whether the thread for a PR includes release-note text?

@jenshannoschwalm jenshannoschwalm deleted the blending_cache branch January 22, 2025 18:12
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
OpenCL Related to darktable OpenCL code scope: performance doing everything the same but faster scope: UI user interface and interactions
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[FR] improve responsiveness of mask manipulation
3 participants