pxd files
In addition to the .pyx
source files, Cython uses .pxd
files which work like C header files – they contain Cython declarations (and sometimes code sections) which are only meant for inclusion by Cython modules. A pxd
file is imported into a pyx
module by using the cimport
keyword.
pxd
files have many use-cases:
They can be used for sharing external C declarations.
They can contain functions which are well suited for inlining by the C compiler. Such functions should be marked
inline
, example:
cdef inline int int_min(int a, int b):
return b if b < a else a
When accompanying an equally named
pyx
file, they provide a Cython interface to the Cython module so that other Cython modules can communicate with it using a more efficient protocol than the Python one.
In our integration example, we might break it up into pxd
files like this:
Add a
cmath.pxd
function which defines the C functions available from the Cmath.h
header file, likesin
. Then one would simply dofrom cmath cimport sin
inintegrate.pyx
.Add a
integrate.pxd
so that other modules written in Cython can define fast custom functions to integrate.
cdef class Function:
cpdef evaluate(self, double x)
cpdef integrate(Function f, double a,
double b, int N)
Note that if you have a cdef class with attributes, the attributes must be declared in the class declaration
pxd
file (if you use one), not thepyx
file. The compiler will tell you about this.