aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLudovic Courtès <ludovic.courtes@inria.fr>2020-02-10 22:56:23 +0100
committerLudovic Courtès <ludo@gnu.org>2020-02-10 23:31:59 +0100
commit01dce79fa400e7e41024567c9fc7614b0cf8eddf (patch)
tree98ebe0083d9c68e42ce5e2f90f775911f5403b69
parent3f1a0f1684538466d4a157d7a39fca205a3be196 (diff)
downloadpatches-01dce79fa400e7e41024567c9fc7614b0cf8eddf.tar
patches-01dce79fa400e7e41024567c9fc7614b0cf8eddf.tar.gz
gnu: Add python-pyopencl.
* gnu/packages/opencl.scm (python-pyopencl): New variable.
-rw-r--r--gnu/packages/opencl.scm49
1 files changed, 49 insertions, 0 deletions
diff --git a/gnu/packages/opencl.scm b/gnu/packages/opencl.scm
index dc90d9166a..04b3cb0524 100644
--- a/gnu/packages/opencl.scm
+++ b/gnu/packages/opencl.scm
@@ -384,3 +384,52 @@ Batch job submission, @code{pytools.batchjob}.
A lexer, @code{pytools.lex}.
@end itemize\n")
(license license:expat)))
+
+(define-public python-pyopencl
+ (package
+ (name "python-pyopencl")
+ (version "2019.1.1")
+ (source
+ (origin
+ ;; The tarball on PyPI lacks test programs such as
+ ;; 'pygpu_language_opencl.cpp' so fetch it from Git.
+ ;; XXX: The server at git.tiker.net is unreliable.
+ (method git-fetch)
+ (uri (git-reference
+ (url "http://git.tiker.net/trees/pyopencl.git")
+ (commit (string-append "v" version))
+ (recursive? #t)))
+ (file-name (git-file-name name version))
+ (sha256
+ (base32
+ "12q0rs8yla571vcfpsh0mfrjbdiayv0hi8r1rq0f178m3i3qjz80"))))
+ (build-system python-build-system)
+ (arguments
+ '(#:phases (modify-phases %standard-phases
+ (add-before 'build 'set-home
+ (lambda _
+ ;; Some of the Python build scripts expect 'HOME' to be
+ ;; set.
+ (setenv "HOME" (getcwd))
+ #t)))
+
+ ;; Tests in 'compyte/ndarray/setup_opencl.py' appear to rely on
+ ;; 'nvcc', which is not an option.
+ #:tests? #f))
+ (inputs
+ `(("opencl-headers" ,opencl-headers-1.2) ;POCL only supports OpenCL 1.2
+ ("pybind11" ,pybind11)
+ ("ocl-icd" ,ocl-icd))) ;libOpenCL
+ (propagated-inputs
+ `(("python-appdirs" ,python-appdirs)
+ ("python-decorator" ,python-decorator)
+ ("python-numpy" ,python-numpy)
+ ("python-pytools" ,python-pytools)
+ ("python-six" ,python-six)
+ ("python-mako" ,python-mako)))
+ (home-page "http://mathema.tician.de/software/pyopencl")
+ (synopsis "Python wrapper for OpenCL")
+ (description
+ "PyOpenCL lets you access parallel computing devices such as GPUs from
+Python @i{via} OpenCL.")
+ (license license:expat)))