Skip to content

Conversation

@vchuravy
Copy link
Member

@vchuravy vchuravy commented Feb 4, 2025

The goal is to allow for kernels to be written without relying on KernelAbstractions macros

cc: @maleadt @pxl-th

github-actions[bot]

This comment was marked as outdated.

github-actions[bot]

This comment was marked as outdated.

@codecov
Copy link

codecov bot commented Feb 4, 2025

Codecov Report

❌ Patch coverage is 0% with 18 lines in your changes missing coverage. Please review.
✅ Project coverage is 0.00%. Comparing base (9741962) to head (8ea6ad2).
⚠️ Report is 37 commits behind head on main.

Files with missing lines Patch % Lines
src/KernelAbstractions.jl 0.00% 12 Missing ⚠️
src/pocl/backend.jl 0.00% 6 Missing ⚠️
Additional details and impacted files
@@          Coverage Diff          @@
##            main    #562   +/-   ##
=====================================
  Coverage   0.00%   0.00%           
=====================================
  Files         21      21           
  Lines       1575    1581    +6     
=====================================
- Misses      1575    1581    +6     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.

Returns the unique local work-item ID.
"""
function get_local_id end
Copy link
Member

Choose a reason for hiding this comment

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

So IIUC, backends should implement these like below, right?

function get_local_id()
    return (threadIdx().x, threadIdx().y, threadIdx().z)
end

Copy link
Member Author

Choose a reason for hiding this comment

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

Yeah basically, and my goal is to replace the old internal functions the people had to override with definitions based on these functions.

Copy link
Member Author

vchuravy commented Feb 5, 2025

This stack of pull requests is managed by Graphite. Learn more about stacking.

github-actions[bot]

This comment was marked as outdated.

@github-actions
Copy link
Contributor

github-actions bot commented Feb 5, 2025

Benchmark Results

main 8ea6ad2... main/8ea6ad2457a1cf...
saxpy/default/Float16/1024 0.0496 ± 0.026 ms 0.0612 ± 0.026 ms 0.811
saxpy/default/Float16/1048576 0.896 ± 0.024 ms 0.899 ± 0.023 ms 0.997
saxpy/default/Float16/16384 0.0639 ± 0.028 ms 0.0658 ± 0.028 ms 0.971
saxpy/default/Float16/2048 0.05 ± 0.023 ms 0.0583 ± 0.024 ms 0.858
saxpy/default/Float16/256 0.0603 ± 0.027 ms 0.064 ± 0.027 ms 0.943
saxpy/default/Float16/262144 0.273 ± 0.026 ms 0.273 ± 0.026 ms 0.998
saxpy/default/Float16/32768 0.0772 ± 0.028 ms 0.0779 ± 0.028 ms 0.991
saxpy/default/Float16/4096 0.0619 ± 0.025 ms 0.0642 ± 0.024 ms 0.964
saxpy/default/Float16/512 0.0597 ± 0.027 ms 0.0599 ± 0.026 ms 0.997
saxpy/default/Float16/64 0.062 ± 0.027 ms 0.063 ± 0.026 ms 0.984
saxpy/default/Float16/65536 0.108 ± 0.028 ms 0.11 ± 0.028 ms 0.98
saxpy/default/Float32/1024 0.0574 ± 0.026 ms 0.0585 ± 0.026 ms 0.982
saxpy/default/Float32/1048576 0.484 ± 0.035 ms 0.481 ± 0.031 ms 1.01
saxpy/default/Float32/16384 0.0563 ± 0.026 ms 0.0576 ± 0.026 ms 0.978
saxpy/default/Float32/2048 0.0502 ± 0.024 ms 0.0545 ± 0.024 ms 0.921
saxpy/default/Float32/256 0.0572 ± 0.026 ms 0.0616 ± 0.026 ms 0.927
saxpy/default/Float32/262144 0.167 ± 0.035 ms 0.168 ± 0.034 ms 0.994
saxpy/default/Float32/32768 0.0622 ± 0.027 ms 0.0636 ± 0.027 ms 0.977
saxpy/default/Float32/4096 0.0594 ± 0.025 ms 0.0625 ± 0.025 ms 0.95
saxpy/default/Float32/512 0.0573 ± 0.027 ms 0.0638 ± 0.026 ms 0.898
saxpy/default/Float32/64 0.0591 ± 0.026 ms 0.0635 ± 0.026 ms 0.93
saxpy/default/Float32/65536 0.0827 ± 0.029 ms 0.0821 ± 0.028 ms 1.01
saxpy/default/Float64/1024 0.0509 ± 0.026 ms 0.0607 ± 0.026 ms 0.838
saxpy/default/Float64/1048576 0.516 ± 0.042 ms 0.517 ± 0.038 ms 0.998
saxpy/default/Float64/16384 0.0582 ± 0.026 ms 0.0583 ± 0.026 ms 1
saxpy/default/Float64/2048 0.048 ± 0.023 ms 0.0519 ± 0.024 ms 0.925
saxpy/default/Float64/256 0.061 ± 0.027 ms 0.061 ± 0.026 ms 1
saxpy/default/Float64/262144 0.176 ± 0.028 ms 0.177 ± 0.029 ms 0.99
saxpy/default/Float64/32768 0.0666 ± 0.026 ms 0.0666 ± 0.026 ms 1
saxpy/default/Float64/4096 0.0537 ± 0.025 ms 0.0629 ± 0.025 ms 0.854
saxpy/default/Float64/512 0.0551 ± 0.027 ms 0.0611 ± 0.027 ms 0.901
saxpy/default/Float64/64 0.0566 ± 0.027 ms 0.0644 ± 0.027 ms 0.878
saxpy/default/Float64/65536 0.0897 ± 0.027 ms 0.0915 ± 0.027 ms 0.981
saxpy/static workgroup=(1024,)/Float16/1024 0.0482 ± 0.026 ms 0.0549 ± 0.026 ms 0.877
saxpy/static workgroup=(1024,)/Float16/1048576 0.913 ± 0.027 ms 0.904 ± 0.028 ms 1.01
saxpy/static workgroup=(1024,)/Float16/16384 0.0626 ± 0.026 ms 0.0616 ± 0.026 ms 1.02
saxpy/static workgroup=(1024,)/Float16/2048 0.0515 ± 0.024 ms 0.0577 ± 0.024 ms 0.892
saxpy/static workgroup=(1024,)/Float16/256 0.0594 ± 0.026 ms 0.0598 ± 0.026 ms 0.993
saxpy/static workgroup=(1024,)/Float16/262144 0.274 ± 0.028 ms 0.272 ± 0.027 ms 1.01
saxpy/static workgroup=(1024,)/Float16/32768 0.0771 ± 0.026 ms 0.0761 ± 0.026 ms 1.01
saxpy/static workgroup=(1024,)/Float16/4096 0.0565 ± 0.027 ms 0.0587 ± 0.026 ms 0.962
saxpy/static workgroup=(1024,)/Float16/512 0.0569 ± 0.026 ms 0.0586 ± 0.026 ms 0.971
saxpy/static workgroup=(1024,)/Float16/64 0.0592 ± 0.026 ms 0.062 ± 0.025 ms 0.956
saxpy/static workgroup=(1024,)/Float16/65536 0.108 ± 0.027 ms 0.106 ± 0.026 ms 1.02
saxpy/static workgroup=(1024,)/Float32/1024 0.0538 ± 0.026 ms 0.0586 ± 0.027 ms 0.919
saxpy/static workgroup=(1024,)/Float32/1048576 0.472 ± 0.043 ms 0.472 ± 0.038 ms 1
saxpy/static workgroup=(1024,)/Float32/16384 0.0551 ± 0.025 ms 0.0561 ± 0.026 ms 0.98
saxpy/static workgroup=(1024,)/Float32/2048 0.0481 ± 0.023 ms 0.0548 ± 0.023 ms 0.878
saxpy/static workgroup=(1024,)/Float32/256 0.0615 ± 0.026 ms 0.0634 ± 0.026 ms 0.97
saxpy/static workgroup=(1024,)/Float32/262144 0.162 ± 0.035 ms 0.164 ± 0.035 ms 0.986
saxpy/static workgroup=(1024,)/Float32/32768 0.0595 ± 0.026 ms 0.0614 ± 0.026 ms 0.969
saxpy/static workgroup=(1024,)/Float32/4096 0.0584 ± 0.026 ms 0.0602 ± 0.026 ms 0.971
saxpy/static workgroup=(1024,)/Float32/512 0.0581 ± 0.026 ms 0.0601 ± 0.026 ms 0.968
saxpy/static workgroup=(1024,)/Float32/64 0.0576 ± 0.026 ms 0.0599 ± 0.025 ms 0.961
saxpy/static workgroup=(1024,)/Float32/65536 0.0806 ± 0.029 ms 0.0827 ± 0.028 ms 0.975
saxpy/static workgroup=(1024,)/Float64/1024 0.057 ± 0.026 ms 0.0536 ± 0.026 ms 1.06
saxpy/static workgroup=(1024,)/Float64/1048576 0.501 ± 0.04 ms 0.517 ± 0.041 ms 0.969
saxpy/static workgroup=(1024,)/Float64/16384 0.0572 ± 0.026 ms 0.0595 ± 0.025 ms 0.962
saxpy/static workgroup=(1024,)/Float64/2048 0.0486 ± 0.023 ms 0.0539 ± 0.023 ms 0.901
saxpy/static workgroup=(1024,)/Float64/256 0.0575 ± 0.026 ms 0.0608 ± 0.026 ms 0.946
saxpy/static workgroup=(1024,)/Float64/262144 0.175 ± 0.031 ms 0.174 ± 0.029 ms 1.01
saxpy/static workgroup=(1024,)/Float64/32768 0.0665 ± 0.026 ms 0.0665 ± 0.025 ms 1
saxpy/static workgroup=(1024,)/Float64/4096 0.0546 ± 0.026 ms 0.0589 ± 0.026 ms 0.927
saxpy/static workgroup=(1024,)/Float64/512 0.0527 ± 0.026 ms 0.0593 ± 0.026 ms 0.889
saxpy/static workgroup=(1024,)/Float64/64 0.0584 ± 0.026 ms 0.0585 ± 0.026 ms 0.998
saxpy/static workgroup=(1024,)/Float64/65536 0.0883 ± 0.027 ms 0.0888 ± 0.027 ms 0.994
time_to_load 1.19 ± 0.003 s 1.15 ± 0.01 s 1.04

Benchmark Plots

A plot of the benchmark results have been uploaded as an artifact to the workflow run for this PR.
Go to "Actions"->"Benchmark a pull request"->[the most recent run]->"Artifacts" (at the bottom).

function get_global_size end

"""
get_global_id()::@NamedTuple{x::Int32, y::Int32, z::Int32}
Copy link
Member Author

Choose a reason for hiding this comment

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

Should this be Int32 or Int64?

Copy link
Member Author

Choose a reason for hiding this comment

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

OpenCL defines these as Csize_t

Copy link
Member

Choose a reason for hiding this comment

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

Is there any way to allow the platform to define the specific <:Integer index type? Metal uses uint3 by default, which are three UInt32 values. I liked that CUDA Thrust allowed the indices to be templated, so I could use Int64 only when dealing with billions of datapoints.

Copy link
Member Author

Choose a reason for hiding this comment

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

GPU dev call: We should make these Int/size_t

@maleadt
Copy link
Member

maleadt commented Feb 6, 2025

So the idea is to decouple the back-ends from KA.jl, instead implementing KernelIntrinsics.jl? What's the advantage; do you envision packages other than KA.jl to build their kernel DSL on top of KernelIntrinsics.jl?

Copy link
Contributor

@github-actions github-actions bot left a comment

Choose a reason for hiding this comment

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

Some suggestions could not be made:

  • src/pocl/nanoOpenCL.jl
    • lines 670-674

@vchuravy vchuravy changed the base branch from 02-07-allow_opt-out_of_implicit_bounds-checking to vc/pocl February 7, 2025 13:52
@vchuravy vchuravy force-pushed the vc/pocl branch 2 times, most recently from 777c099 to 3bb80ac Compare February 12, 2025 15:23
@vchuravy vchuravy force-pushed the vc/intrinsics branch 2 times, most recently from 0d72b34 to 1f3b249 Compare February 12, 2025 15:25
@vchuravy vchuravy changed the base branch from vc/pocl to graphite-base/562 February 17, 2025 12:42
@vchuravy vchuravy changed the base branch from graphite-base/562 to main February 17, 2025 12:47
@vchuravy vchuravy added this to the 0.10.0 milestone Jun 10, 2025
Comment on lines +8 to +9
!!! note
1-based.
Copy link
Member

Choose a reason for hiding this comment

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

I'm sure sure I understand what a 1-based size means, is this supposed to be in the _id() docstrings instead?

@vchuravy
Copy link
Member Author

vchuravy commented Oct 6, 2025

Replaced by #635

@vchuravy vchuravy closed this Oct 6, 2025
@vchuravy vchuravy deleted the vc/intrinsics branch October 6, 2025 18:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants