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
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
3d291a58
Commit
3d291a58
authored
Jun 16, 2018
by
Stefan Behnel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Minor docs cleanup.
parent
4800ae9d
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
6 additions
and
2 deletions
+6
-2
docs/examples/tutorial/numpy/convolve2.pyx
docs/examples/tutorial/numpy/convolve2.pyx
+6
-1
docs/examples/tutorial/numpy/convolve_py.py
docs/examples/tutorial/numpy/convolve_py.py
+0
-1
No files found.
docs/examples/tutorial/numpy/convolve2.pyx
View file @
3d291a58
...
@@ -2,8 +2,8 @@
...
@@ -2,8 +2,8 @@
# You can ignore the previous line.
# You can ignore the previous line.
# It's for internal testing of the cython documentation.
# It's for internal testing of the cython documentation.
from
__future__
import
division
import
numpy
as
np
import
numpy
as
np
# "cimport" is used to import special compile-time information
# "cimport" is used to import special compile-time information
# about the numpy module (this is stored in a file numpy.pxd which is
# about the numpy module (this is stored in a file numpy.pxd which is
# currently part of the Cython distribution).
# currently part of the Cython distribution).
...
@@ -13,10 +13,12 @@ cimport numpy as np
...
@@ -13,10 +13,12 @@ cimport numpy as np
# DTYPE for this, which is assigned to the usual NumPy runtime
# DTYPE for this, which is assigned to the usual NumPy runtime
# type info object.
# type info object.
DTYPE
=
np
.
int
DTYPE
=
np
.
int
# "ctypedef" assigns a corresponding compile-time type to DTYPE_t. For
# "ctypedef" assigns a corresponding compile-time type to DTYPE_t. For
# every type in the numpy module there's a corresponding compile-time
# every type in the numpy module there's a corresponding compile-time
# type with a _t-suffix.
# type with a _t-suffix.
ctypedef
np
.
int_t
DTYPE_t
ctypedef
np
.
int_t
DTYPE_t
# "def" can type its arguments but not have a return type. The type of the
# "def" can type its arguments but not have a return type. The type of the
# arguments for a "def" function is checked at run-time when entering the
# arguments for a "def" function is checked at run-time when entering the
# function.
# function.
...
@@ -29,6 +31,7 @@ def naive_convolve(np.ndarray f, np.ndarray g):
...
@@ -29,6 +31,7 @@ def naive_convolve(np.ndarray f, np.ndarray g):
if
g
.
shape
[
0
]
%
2
!=
1
or
g
.
shape
[
1
]
%
2
!=
1
:
if
g
.
shape
[
0
]
%
2
!=
1
or
g
.
shape
[
1
]
%
2
!=
1
:
raise
ValueError
(
"Only odd dimensions on filter supported"
)
raise
ValueError
(
"Only odd dimensions on filter supported"
)
assert
f
.
dtype
==
DTYPE
and
g
.
dtype
==
DTYPE
assert
f
.
dtype
==
DTYPE
and
g
.
dtype
==
DTYPE
# The "cdef" keyword is also used within functions to type variables. It
# The "cdef" keyword is also used within functions to type variables. It
# can only be used at the top indentation level (there are non-trivial
# can only be used at the top indentation level (there are non-trivial
# problems with allowing them in other places, though we'd love to see
# problems with allowing them in other places, though we'd love to see
...
@@ -48,10 +51,12 @@ def naive_convolve(np.ndarray f, np.ndarray g):
...
@@ -48,10 +51,12 @@ def naive_convolve(np.ndarray f, np.ndarray g):
cdef
int
ymax
=
wmax
+
2
*
tmid
cdef
int
ymax
=
wmax
+
2
*
tmid
cdef
np
.
ndarray
h
=
np
.
zeros
([
xmax
,
ymax
],
dtype
=
DTYPE
)
cdef
np
.
ndarray
h
=
np
.
zeros
([
xmax
,
ymax
],
dtype
=
DTYPE
)
cdef
int
x
,
y
,
s
,
t
,
v
,
w
cdef
int
x
,
y
,
s
,
t
,
v
,
w
# It is very important to type ALL your variables. You do not get any
# It is very important to type ALL your variables. You do not get any
# warnings if not, only much slower code (they are implicitly typed as
# warnings if not, only much slower code (they are implicitly typed as
# Python objects).
# Python objects).
cdef
int
s_from
,
s_to
,
t_from
,
t_to
cdef
int
s_from
,
s_to
,
t_from
,
t_to
# For the value variable, we want to use the same data type as is
# For the value variable, we want to use the same data type as is
# stored in the array, so we use "DTYPE_t" as defined above.
# stored in the array, so we use "DTYPE_t" as defined above.
# NB! An important side-effect of this is that if "value" overflows its
# NB! An important side-effect of this is that if "value" overflows its
...
...
docs/examples/tutorial/numpy/convolve_py.py
View file @
3d291a58
from
__future__
import
division
import
numpy
as
np
import
numpy
as
np
...
...
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