dlpack Python support for cuda_GpuMat and cuda_GpuMatND#27581
dlpack Python support for cuda_GpuMat and cuda_GpuMatND#27581asmorkalov merged 10 commits intoopencv:4.xfrom
Conversation
|
DLpack available as deb package on Ubuntu. It'll be great to support external instances via find_package too just i case of compatibility issues. |
|
cc @cudawarped |
|
Windows build warnings: |
|
@dkurt Thanks a lot for the contribution! Several questions and proposals:
|
Yes, but as we already work with OpenCV memory as numpy array, we can use numpy's dlpack.
CUDA is required so actual for build from source.
Do you mean opencv_contrib? |
No. test_cuda.py is not triggered by CI now. |
|
@asmorkalov I see only dnn tests here: https://github.com/opencv/opencv/actions/runs/16773287951/job/47493324938?pr=27581 . Shall I extend the test scope to include Python tests to CUDA runner? |
|
Most probably you need to push something to refresh CI branch. |
c88371f to
052b79f
Compare
### Pull Request Readiness Checklist resolves opencv#16295 ``` docker run --gpus 0 -v ~/opencv:/opencv -v ~/opencv_contrib:/opencv_contrib -it nvidia/cuda:12.8.1-cudnn-devel-ubuntu22.04 apt-get update && apt-get install -y cmake python3-dev python3-pip python3-venv && python3 -m venv .venv && source .venv/bin/activate && pip install -U pip && pip install -U numpy && pip install torch --index-url https://download.pytorch.org/whl/cu128 && cmake \ -DWITH_OPENCL=OFF \ -DCMAKE_BUILD_TYPE=Release \ -DBUILD_DOCS=OFF \ -DWITH_CUDA=ON \ -DOPENCV_DNN_CUDA=ON \ -DOPENCV_EXTRA_MODULES_PATH=/opencv_contrib/modules \ -DBUILD_LIST=ts,cudev,python3 \ -S /opencv -B /opencv_build && cmake --build /opencv_build -j16 export PYTHONPATH=/opencv_build/lib/python3/:$PYTHONPATH ``` See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [x] The PR is proposed to the proper branch - [x] There is a reference to the original bug report and related work - [x] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [x] The feature is well documented and sample code can be built with the project CMake
|
Win32 warnings: |
Add 5.x types for DLPack. Keep uint32/int64/uint64 data type for conversion to Numpy. More types support for GpuMat::convertTo #27779 ### Pull Request Readiness Checklist **Merge with contrib**: opencv/opencv_contrib#4000 related: #27581 See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request - [x] I agree to contribute to the project under Apache 2 License. - [x] To the best of my knowledge, the proposed patch is not based on a code under GPL or another license that is incompatible with OpenCV - [x] The PR is proposed to the proper branch - [x] There is a reference to the original bug report and related work - [x] There is accuracy test, performance test and test data in opencv_extra repository, if applicable Patch to opencv_extra has the same branch name. - [x] The feature is well documented and sample code can be built with the project CMake
Pull Request Readiness Checklist
resolves #16295
See details at https://github.com/opencv/opencv/wiki/How_to_contribute#making-a-good-pull-request
Patch to opencv_extra has the same branch name.