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

Integrate Profile-Guided Optimization (PGO) #124

Open
zamazan4ik opened this issue Oct 23, 2023 · 1 comment
Open

Integrate Profile-Guided Optimization (PGO) #124

zamazan4ik opened this issue Oct 23, 2023 · 1 comment
Assignees
Labels
enhancement New feature or request help wanted Extra attention is needed

Comments

@zamazan4ik
Copy link

Description

Recently I checked Profile-Guided Optimization (PGO) improvements on many projects. All current results are available here. E.g. ClickHouse PGO results can be checked here, ClickHouse documentation about building with PGO - https://clickhouse.com/docs/en/operations/optimizing-performance/profile-guided-optimization . According to the multiple tests, PGO can help with improving performance in many cases (including databases). That's why I think trying to optimize chdb with PGO can be a good idea.

I can suggest the following action points:

  • Perform PGO benchmarks on chdb. And if it shows improvements - add a note about possible improvements in chdb performance with PGO.
  • Providing an easier way (e.g. a build option) to build scripts with PGO can be helpful for the end-users and maintainers since they will be able to optimize chdb according to their own workloads.
  • Optimize pre-built binaries

Since the chdb native part is the library, I think the Pydantic-core experience can be reused here. Also, Clang supports PGO for shared libraries.

Maybe testing Post-Link Optimization techniques (like LLVM BOLT) would be interesting too (Clang and Rustc already use BOLT as an addition to PGO) but I recommend starting from the usual PGO.

Here are some examples of how PGO optimization is integrated in other projects:

@lmangani lmangani added enhancement New feature or request help wanted Extra attention is needed labels Oct 23, 2023
@auxten
Copy link
Member

auxten commented Oct 24, 2023

Thanks for all these infos, I'll have a try.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

3 participants