Scalar functions pushdown to Duckdb#8303
Conversation
95fb3e5 to
dea4636
Compare
Merging this PR will not alter performance
|
| Mode | Benchmark | BASE |
HEAD |
Efficiency | |
|---|---|---|---|---|---|
| ❌ | Simulation | chunked_bool_canonical_into[(1000, 10)] |
20.2 µs | 35.5 µs | -42.93% |
| ❌ | Simulation | chunked_varbinview_into_canonical[(1000, 10)] |
177.2 µs | 213.6 µs | -17.04% |
| ❌ | Simulation | bitwise_not_vortex_buffer_mut[128] |
215.3 ns | 244.4 ns | -11.93% |
| ❌ | Simulation | chunked_varbinview_canonical_into[(100, 100)] |
274.4 µs | 309.5 µs | -11.33% |
| ⚡ | Simulation | encode_varbin[(1000, 8)] |
160.2 µs | 143.3 µs | +11.78% |
| ⚡ | Simulation | encode_varbin[(1000, 4)] |
159.4 µs | 142.6 µs | +11.76% |
| ⚡ | Simulation | encode_varbin[(1000, 32)] |
164.6 µs | 148.3 µs | +11.04% |
Tip
Investigate this regression by commenting @codspeedbot fix this regression on this PR, or directly use the CodSpeed MCP with your agent.
Comparing myrrc/scalar-fn-pushdown (9099587) with develop (3d7bbfb)
dea4636 to
2a987d9
Compare
Polar Signals Profiling ResultsLatest Run
Previous Runs (1)
Powered by Polar Signals Cloud |
Benchmarks: PolarSignals ProfilingVortex (geomean): 1.018x ➖ How to read Verdict and Engines
datafusion / vortex-file-compressed (1.018x ➖, 0↑ 0↓)
No file size changes detected. |
Benchmarks: FineWeb NVMeVerdict: No clear signal (low confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (1.102x ❌, 0↑ 3↓)
datafusion / vortex-compact (1.060x ➖, 0↑ 2↓)
datafusion / parquet (1.083x ➖, 0↑ 2↓)
duckdb / vortex-file-compressed (1.100x ➖, 0↑ 6↓)
duckdb / vortex-compact (1.039x ➖, 0↑ 1↓)
duckdb / parquet (1.072x ➖, 0↑ 1↓)
File Size Changes (1 files changed, -0.0% overall, 0↑ 1↓)
Totals:
|
Benchmarks: TPC-H SF=1 on NVMEVerdict: No clear signal (environment too noisy confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (1.107x ❌, 0↑ 6↓)
datafusion / vortex-compact (0.977x ➖, 6↑ 2↓)
datafusion / parquet (1.027x ➖, 2↑ 3↓)
datafusion / arrow (0.840x ✅, 14↑ 0↓)
duckdb / vortex-file-compressed (1.132x ❌, 2↑ 13↓)
duckdb / vortex-compact (1.011x ➖, 1↑ 1↓)
duckdb / parquet (1.048x ➖, 0↑ 4↓)
duckdb / duckdb (1.022x ➖, 0↑ 1↓)
File Size Changes (9 files changed, -0.1% overall, 4↑ 5↓)
Totals:
|
Benchmarks: TPC-DS SF=1 on NVMEVerdict: No clear signal (environment too noisy confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (1.037x ➖, 1↑ 15↓)
datafusion / vortex-compact (1.026x ➖, 0↑ 5↓)
datafusion / parquet (1.108x ❌, 1↑ 44↓)
duckdb / vortex-file-compressed (1.002x ➖, 1↑ 0↓)
duckdb / vortex-compact (0.997x ➖, 0↑ 1↓)
duckdb / parquet (0.997x ➖, 1↑ 0↓)
duckdb / duckdb (0.999x ➖, 0↑ 4↓)
File Size Changes (7 files changed, +0.0% overall, 4↑ 3↓)
Totals:
|
Benchmarks: FineWeb S3Verdict: No clear signal (environment too noisy confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (1.030x ➖, 1↑ 1↓)
datafusion / vortex-compact (0.992x ➖, 1↑ 2↓)
datafusion / parquet (0.991x ➖, 0↑ 0↓)
duckdb / vortex-file-compressed (0.969x ➖, 0↑ 1↓)
duckdb / vortex-compact (1.004x ➖, 1↑ 2↓)
duckdb / parquet (0.988x ➖, 0↑ 0↓)
|
Benchmarks: Statistical and Population GeneticsVerdict: No clear signal (low confidence) How to read Verdict and Engines
duckdb / vortex-file-compressed (1.018x ➖, 0↑ 0↓)
duckdb / vortex-compact (0.999x ➖, 0↑ 0↓)
duckdb / parquet (1.008x ➖, 0↑ 0↓)
File Size Changes (1 files changed, +0.0% overall, 1↑ 0↓)
Totals:
|
Benchmarks: Clickbench on NVMEVerdict: No clear signal (low confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (0.929x ➖, 13↑ 0↓)
datafusion / parquet (0.885x ✅, 25↑ 0↓)
duckdb / vortex-file-compressed (0.994x ➖, 4↑ 2↓)
duckdb / parquet (0.977x ➖, 0↑ 0↓)
duckdb / duckdb (1.006x ➖, 0↑ 1↓)
File Size Changes (105 files changed, +0.0% overall, 55↑ 50↓)
Totals:
|
Benchmarks: Random AccessVortex (geomean): 0.999x ➖ How to read Verdict and Engines
unknown / unknown (1.041x ➖, 0↑ 1↓)
|
Benchmarks: TPC-H SF=10 on NVMEVerdict: No clear signal (low confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (0.993x ➖, 0↑ 0↓)
datafusion / vortex-compact (1.004x ➖, 0↑ 0↓)
datafusion / parquet (0.996x ➖, 0↑ 0↓)
datafusion / arrow (0.929x ➖, 7↑ 0↓)
duckdb / vortex-file-compressed (1.004x ➖, 0↑ 0↓)
duckdb / vortex-compact (0.998x ➖, 0↑ 0↓)
duckdb / parquet (1.003x ➖, 0↑ 0↓)
duckdb / duckdb (1.004x ➖, 0↑ 0↓)
File Size Changes (26 files changed, -0.1% overall, 12↑ 14↓)
Totals:
|
Benchmarks: Appian on NVMEVerdict: No clear signal (low confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (1.009x ➖, 0↑ 0↓)
datafusion / parquet (1.002x ➖, 0↑ 0↓)
duckdb / vortex-file-compressed (1.013x ➖, 0↑ 0↓)
duckdb / parquet (1.005x ➖, 0↑ 0↓)
duckdb / duckdb (1.003x ➖, 0↑ 0↓)
File Size Changes (4 files changed, -0.0% overall, 2↑ 2↓)
Totals:
|
🚨🚨🚨❌❌❌ SQL BENCHMARK FAILED ❌❌❌🚨🚨🚨Benchmark |
Benchmarks: TPC-H SF=10 on S3Verdict: No clear signal (environment too noisy confidence) How to read Verdict and Engines
datafusion / vortex-file-compressed (0.945x ➖, 0↑ 2↓)
datafusion / vortex-compact (1.024x ➖, 1↑ 0↓)
datafusion / parquet (0.923x ➖, 3↑ 1↓)
duckdb / vortex-file-compressed (0.921x ➖, 0↑ 0↓)
duckdb / vortex-compact (1.015x ➖, 0↑ 1↓)
duckdb / parquet (0.934x ➖, 0↑ 0↓)
|
Benchmarks: CompressionVortex (geomean): 1.001x ➖ How to read Verdict and Engines
unknown / unknown (0.992x ➖, 8↑ 5↓)
|
dd609c2 to
f218dcf
Compare
f218dcf to
9099587
Compare
TODO