Skip to content
README.rst 1.94 KiB
Newer Older
PyOpenCL lets you access GPUs and other massively parallel compute
devices from Python. It tries to offer computing goodness in the
spirit of its sister project `PyCUDA <http://mathema.tician.de/software/pycuda>`_:

* Object cleanup tied to lifetime of objects. This idiom, often
  called
  `RAII <http://en.wikipedia.org/wiki/Resource_Acquisition_Is_Initialization>`_
  in C++, makes it much easier to write correct, leak- and
  crash-free code.

* Completeness. PyOpenCL puts the full power of OpenCL's API at
  your disposal, if you wish.  Every obscure `get_info()` query and 
  all CL calls are accessible.

* Automatic Error Checking. All CL errors are automatically
  translated into Python exceptions.

* Speed. PyOpenCL's base layer is written in C++, so all the niceties
  above are virtually free.

* Helpful and complete `Documentation <http://documen.tician.de/pyopencl>`_
  as well as a `Wiki <http://wiki.tiker.net/PyOpenCL>`_.

* Liberal license. PyOpenCL is open-source under the 
  `MIT license <http://en.wikipedia.org/wiki/MIT_License>`_
  and free for commercial, academic, and private use.

* Broad support. PyOpenCL was tested and works with Apple's, AMD's, and Nvidia's 
  CL implementations.

Andreas Klöckner's avatar
Andreas Klöckner committed
To use PyOpenCL, you just need `numpy <http://numpy.org>`_ and an OpenCL
Andreas Klöckner's avatar
Andreas Klöckner committed
implementation.
(See this `howto <http://wiki.tiker.net/OpenCLHowTo>`_ for how to get one.)
Andreas Klöckner's avatar
Andreas Klöckner committed
Places on the web related to PyOpenCL:
Andreas Klöckner's avatar
Andreas Klöckner committed
* `Python package index <http://pypi.python.org/pypi/pyopencl>`_ (download releases)

  .. image:: https://badge.fury.io/py/pyopencl.png
      :target: http://pypi.python.org/pypi/pyopencl
* `C. Gohlke's Windows binaries <http://www.lfd.uci.edu/~gohlke/pythonlibs/#pyopencl>`_ (download Windows binaries)
* `Github <http://github.com/pyopencl/pyopencl>`_ (get latest source code, file bugs)
Andreas Klöckner's avatar
Andreas Klöckner committed
* `Documentation <http://documen.tician.de/pyopencl>`_ (read how things work)
Andreas Klöckner's avatar
Andreas Klöckner committed
* `Wiki <http://wiki.tiker.net/PyOpenCL>`_ (read installation tips, get examples, read FAQ)