Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Gwenaël Samain
cython
Commits
107f76cc
Commit
107f76cc
authored
Jul 08, 2015
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add section on basic syntax and indexing to memoryview docs
parent
c76f1a8f
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
79 additions
and
9 deletions
+79
-9
docs/src/userguide/memoryviews.rst
docs/src/userguide/memoryviews.rst
+79
-9
No files found.
docs/src/userguide/memoryviews.rst
View file @
107f76cc
...
...
@@ -25,6 +25,9 @@ exposes writable buffer through the `PEP 3118`_ buffer interface.
Quickstart
==========
If you are used to working with NumPy, the following examples should get you
started with Cython memory views.
::
from cython.view cimport array as cvarray
...
...
@@ -88,28 +91,93 @@ This code should give the following output::
Memoryview sum of Cython array is 1351
Memoryview sum of C memoryview is 451
Using memoryviews
=================
Indexing and Slicing
--------------------
Syntax
------
Memory views use Python slicing syntax in a similar way as NumPy.
To create a complete view on a one-dimensional int buffer::
cdef int[:] view1D = exporting_object
A complete 3D view::
cdef int[:,:,:] view3D = exporting_object
A 2D view that restricts the first dimension of a buffer to 100 rows
starting at the second and then skipps every second (odd) row::
cdef int[1:102:2,:] partial_view = exporting_object
This also works conveniently as function arguments::
.. code-block:: cython
def process_3d_buffer(int[1:102:2,:] view not None):
...
The ``not None`` declaration for the argument automatically rejects
None values as input, which would otherwise be allowed. The reason why
None is allowed by default is that it is conveniently used for return
arguments::
Indexing and slicing can be done with or without the GIL. It basically works
like NumPy. If indices are specified for every dimension you will get an element
of the base type (e.g. `int`), otherwise you will get a new view. An Ellipsis
def process_buffer(int[:,:] input not None,
int[:,:] output = None):
if output is None:
output = ... # e.g. numpy.empty_like(input)
# process 'input' into 'output'
return output
Cython will reject incompatible buffers automatically, e.g. passing a
three dimensional buffer into a function that requires a two
dimensional buffer will raise a ``ValueError``.
Indexing
--------
In Cython, index access on memory views is automatically translated
into memory addresses. The following code requests a two-dimensional
memory view of C ``int`` typed items and indexes into it::
cdef int[:,:] buf = exporting_object
print(buf[1,2])
Negative indices work as well, counting from the end of the respective
dimension::
print(buf[-1,-2])
The following function loops over each dimension of a 2D array and
adds 1 to each item::
def add_one(int[:,:] buf):
for x in xrange(buf.shape[0]):
for y in xrange(buf.shape[1]):
buf[x,y] += 1
Indexing and slicing can be done with or without the GIL. It basically works
like NumPy. If indices are specified for every dimension you will get an element
of the base type (e.g. `int`). Otherwise, you will get a new view. An Ellipsis
means you get consecutive slices for every unspecified dimension::
cdef int[:, :, :] my_view =
...
cdef int[:, :, :] my_view =
exporting_object
# These are all equivalent
my_view[10]
my_view[10, :, :]
my_view[10, ...]
Copying
-------
Memory
views can be copied in
place::
Memory
views can be copied in
place::
cdef int[:, :, :] to_view, from_view
...
...
...
@@ -315,7 +383,9 @@ in memory. If you know you will have a 3D Fortran contiguous array::
cdef int[::1, :, :] f_contiguous = f_contig
If you try to do this kind of thing::
If you pass a non-contiguous buffer, for example
::
# This array is C contiguous
c_contig = np.arange(24).reshape((2,3,4))
...
...
@@ -324,7 +394,7 @@ If you try to do this kind of thing::
# But this isn't
c_contiguous = np.array(c_contig, order='F')
you will get a ``ValueError``
like this
at runtime::
you will get a ``ValueError`` at runtime::
/Users/mb312/dev_trees/minimal-cython/mincy.pyx in init mincy (mincy.c:17267)()
69
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment