faq.rst 14.3 KB
Newer Older
Wenzel Jakob's avatar
Wenzel Jakob committed
1
2
3
Frequently asked questions
##########################

Wenzel Jakob's avatar
Wenzel Jakob committed
4
5
"ImportError: dynamic module does not define init function"
===========================================================
6

Ahuva Kroizer's avatar
Ahuva Kroizer committed
7
1. Make sure that the name specified in PYBIND11_MODULE is identical to the
Lin Hsu's avatar
Typo  
Lin Hsu committed
8
filename of the extension library (without suffixes such as .so)
Ahuva Kroizer's avatar
Ahuva Kroizer committed
9
10
11
12
13

2. If the above did not fix the issue, you are likely using an incompatible
version of Python (for instance, the extension library was compiled against
Python 2, while the interpreter is running on top of some version of Python
3, or vice versa).
Wenzel Jakob's avatar
Wenzel Jakob committed
14
15
16
17

"Symbol not found: ``__Py_ZeroStruct`` / ``_PyInstanceMethod_Type``"
========================================================================

18
See the first answer.
Wenzel Jakob's avatar
Wenzel Jakob committed
19

20
21
22
"SystemError: dynamic module not initialized properly"
======================================================

23
See the first answer.
24

Wenzel Jakob's avatar
Wenzel Jakob committed
25
26
27
The Python interpreter immediately crashes when importing my module
===================================================================

28
See the first answer.
29

30
31
.. _faq_reference_arguments:

Wenzel Jakob's avatar
Wenzel Jakob committed
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
Limitations involving reference arguments
=========================================

In C++, it's fairly common to pass arguments using mutable references or
mutable pointers, which allows both read and write access to the value
supplied by the caller. This is sometimes done for efficiency reasons, or to
realize functions that have multiple return values. Here are two very basic
examples:

.. code-block:: cpp

    void increment(int &i) { i++; }
    void increment_ptr(int *i) { (*i)++; }

In Python, all arguments are passed by reference, so there is no general
issue in binding such code from Python.

However, certain basic Python types (like ``str``, ``int``, ``bool``,
``float``, etc.) are **immutable**. This means that the following attempt
to port the function to Python doesn't have the same effect on the value
provided by the caller -- in fact, it does nothing at all.

.. code-block:: python

    def increment(i):
        i += 1 # nope..

Wenzel Jakob's avatar
Wenzel Jakob committed
59
60
61
62
63
pybind11 is also affected by such language-level conventions, which means that
binding ``increment`` or ``increment_ptr`` will also create Python functions
that don't modify their arguments.

Although inconvenient, one workaround is to encapsulate the immutable types in
64
a custom type that does allow modifications.
Wenzel Jakob's avatar
Wenzel Jakob committed
65
66
67
68
69
70
71
72
73
74
75
76
77
78

An other alternative involves binding a small wrapper lambda function that
returns a tuple with all output arguments (see the remainder of the
documentation for examples on binding lambda functions). An example:

.. code-block:: cpp

    int foo(int &i) { i++; return 123; }

and the binding code

.. code-block:: cpp

   m.def("foo", [](int i) { int rv = foo(i); return std::make_tuple(rv, i); });
Wenzel Jakob's avatar
Wenzel Jakob committed
79

80

Wenzel Jakob's avatar
Wenzel Jakob committed
81
82
83
How can I reduce the build time?
================================

84
85
86
87
It's good practice to split binding code over multiple files, as in the
following example:

:file:`example.cpp`:
Wenzel Jakob's avatar
Wenzel Jakob committed
88
89
90

.. code-block:: cpp

91
92
    void init_ex1(py::module_ &);
    void init_ex2(py::module_ &);
Wenzel Jakob's avatar
Wenzel Jakob committed
93
94
    /* ... */

95
    PYBIND11_MODULE(example, m) {
Wenzel Jakob's avatar
Wenzel Jakob committed
96
97
98
99
100
        init_ex1(m);
        init_ex2(m);
        /* ... */
    }

101
102
103
104
:file:`ex1.cpp`:

.. code-block:: cpp

105
    void init_ex1(py::module_ &m) {
106
107
108
109
110
111
112
        m.def("add", [](int a, int b) { return a + b; });
    }

:file:`ex2.cpp`:

.. code-block:: cpp

113
    void init_ex2(py::module_ &m) {
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
        m.def("sub", [](int a, int b) { return a - b; });
    }

:command:`python`:

.. code-block:: pycon

    >>> import example
    >>> example.add(1, 2)
    3
    >>> example.sub(1, 1)
    0

As shown above, the various ``init_ex`` functions should be contained in
separate files that can be compiled independently from one another, and then
linked together into the same final shared object.  Following this approach
will:
Wenzel Jakob's avatar
Wenzel Jakob committed
131

Wenzel Jakob's avatar
Wenzel Jakob committed
132
1. reduce memory requirements per compilation unit.
Wenzel Jakob's avatar
Wenzel Jakob committed
133

Wenzel Jakob's avatar
Wenzel Jakob committed
134
2. enable parallel builds (if desired).
Wenzel Jakob's avatar
Wenzel Jakob committed
135

Wenzel Jakob's avatar
Wenzel Jakob committed
136
3. allow for faster incremental builds. For instance, when a single class
137
   definition is changed, only a subset of the binding code will generally need
Wenzel Jakob's avatar
Wenzel Jakob committed
138
   to be recompiled.
Wenzel Jakob's avatar
Wenzel Jakob committed
139

140
141
142
143
144
145
146
147
"recursive template instantiation exceeded maximum depth of 256"
================================================================

If you receive an error about excessive recursive template evaluation, try
specifying a larger value, e.g. ``-ftemplate-depth=1024`` on GCC/Clang. The
culprit is generally the generation of function signatures at compile time
using C++14 template metaprogramming.

148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
.. _`faq:hidden_visibility`:

"‘SomeClass’ declared with greater visibility than the type of its field ‘SomeClass::member’ [-Wattributes]"
============================================================================================================

This error typically indicates that you are compiling without the required
``-fvisibility`` flag.  pybind11 code internally forces hidden visibility on
all internal code, but if non-hidden (and thus *exported*) code attempts to
include a pybind type (for example, ``py::object`` or ``py::list``) you can run
into this warning.

To avoid it, make sure you are specifying ``-fvisibility=hidden`` when
compiling pybind code.

As to why ``-fvisibility=hidden`` is necessary, because pybind modules could
have been compiled under different versions of pybind itself, it is also
important that the symbols defined in one module do not clash with the
potentially-incompatible symbols defined in another.  While Python extension
modules are usually loaded with localized symbols (under POSIX systems
typically using ``dlopen`` with the ``RTLD_LOCAL`` flag), this Python default
can be changed, but even if it isn't it is not always enough to guarantee
complete independence of the symbols involved when not using
``-fvisibility=hidden``.

Additionally, ``-fvisiblity=hidden`` can deliver considerably binary size
savings.  (See the following section for more details).

175

176
177
.. _`faq:symhidden`:

Wenzel Jakob's avatar
Wenzel Jakob committed
178
179
180
181
182
183
184
How can I create smaller binaries?
==================================

To do its job, pybind11 extensively relies on a programming technique known as
*template metaprogramming*, which is a way of performing computation at compile
time using type information. Template metaprogamming usually instantiates code
involving significant numbers of deeply nested types that are either completely
185
removed or reduced to just a few instructions during the compiler's optimization
Wenzel Jakob's avatar
Wenzel Jakob committed
186
187
188
189
phase. However, due to the nested nature of these types, the resulting symbol
names in the compiled extension library can be extremely long. For instance,
the included test suite contains the following symbol:

Wenzel Jakob's avatar
Wenzel Jakob committed
190
191
192
193
.. only:: html

    .. code-block:: none

Wenzel Jakob's avatar
Wenzel Jakob committed
194
        _​_​Z​N​8​p​y​b​i​n​d​1​1​1​2​c​p​p​_​f​u​n​c​t​i​o​n​C​1​I​v​8​E​x​a​m​p​l​e​2​J​R​N​S​t​3​_​_​1​6​v​e​c​t​o​r​I​N​S​3​_​1​2​b​a​s​i​c​_​s​t​r​i​n​g​I​w​N​S​3​_​1​1​c​h​a​r​_​t​r​a​i​t​s​I​w​E​E​N​S​3​_​9​a​l​l​o​c​a​t​o​r​I​w​E​E​E​E​N​S​8​_​I​S​A​_​E​E​E​E​E​J​N​S​_​4​n​a​m​e​E​N​S​_​7​s​i​b​l​i​n​g​E​N​S​_​9​i​s​_​m​e​t​h​o​d​E​A​2​8​_​c​E​E​E​M​T​0​_​F​T​_​D​p​T​1​_​E​D​p​R​K​T​2​_
Wenzel Jakob's avatar
Wenzel Jakob committed
195
196
197
198

.. only:: not html

    .. code-block:: cpp
Wenzel Jakob's avatar
Wenzel Jakob committed
199

Wenzel Jakob's avatar
Wenzel Jakob committed
200
        __ZN8pybind1112cpp_functionC1Iv8Example2JRNSt3__16vectorINS3_12basic_stringIwNS3_11char_traitsIwEENS3_9allocatorIwEEEENS8_ISA_EEEEEJNS_4nameENS_7siblingENS_9is_methodEA28_cEEEMT0_FT_DpT1_EDpRKT2_
Wenzel Jakob's avatar
Wenzel Jakob committed
201
202
203
204
205
206
207

which is the mangled form of the following function type:

.. code-block:: cpp

    pybind11::cpp_function::cpp_function<void, Example2, std::__1::vector<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> >, std::__1::allocator<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> > > >&, pybind11::name, pybind11::sibling, pybind11::is_method, char [28]>(void (Example2::*)(std::__1::vector<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> >, std::__1::allocator<std::__1::basic_string<wchar_t, std::__1::char_traits<wchar_t>, std::__1::allocator<wchar_t> > > >&), pybind11::name const&, pybind11::sibling const&, pybind11::is_method const&, char const (&) [28])

Wenzel Jakob's avatar
Wenzel Jakob committed
208
209
210
211
212
213
The memory needed to store just the mangled name of this function (196 bytes)
is larger than the actual piece of code (111 bytes) it represents! On the other
hand, it's silly to even give this function a name -- after all, it's just a
tiny cog in a bigger piece of machinery that is not exposed to the outside
world. So we'll generally only want to export symbols for those functions which
are actually called from the outside.
Wenzel Jakob's avatar
Wenzel Jakob committed
214
215

This can be achieved by specifying the parameter ``-fvisibility=hidden`` to GCC
216
217
218
219
220
221
222
223
and Clang, which sets the default symbol visibility to *hidden*, which has a
tremendous impact on the final binary size of the resulting extension library.
(On Visual Studio, symbols are already hidden by default, so nothing needs to
be done there.)

In addition to decreasing binary size, ``-fvisibility=hidden`` also avoids
potential serious issues when loading multiple modules and is required for
proper pybind operation.  See the previous FAQ entry for more details.
Wenzel Jakob's avatar
Wenzel Jakob committed
224

Marc Schlaich's avatar
Marc Schlaich committed
225
Working with ancient Visual Studio 2008 builds on Windows
Wenzel Jakob's avatar
Wenzel Jakob committed
226
227
228
229
230
231
=========================================================

The official Windows distributions of Python are compiled using truly
ancient versions of Visual Studio that lack good C++11 support. Some users
implicitly assume that it would be impossible to load a plugin built with
Visual Studio 2015 into a Python distribution that was compiled using Visual
Marc Schlaich's avatar
Marc Schlaich committed
232
Studio 2008. However, no such issue exists: it's perfectly legitimate to
Wenzel Jakob's avatar
Wenzel Jakob committed
233
234
235
236
237
interface DLLs that are built with different compilers and/or C libraries.
Common gotchas to watch out for involve not ``free()``-ing memory region
that that were ``malloc()``-ed in another shared library, using data
structures with incompatible ABIs, and so on. pybind11 is very careful not
to make these types of mistakes.
238

239
240
241
242
243
244
245
246
247
How can I properly handle Ctrl-C in long-running functions?
===========================================================

Ctrl-C is received by the Python interpreter, and holds it until the GIL
is released, so a long-running function won't be interrupted.

To interrupt from inside your function, you can use the ``PyErr_CheckSignals()``
function, that will tell if a signal has been raised on the Python side.  This
function merely checks a flag, so its impact is negligible. When a signal has
248
249
250
been received, you must either explicitly interrupt execution by throwing
``py::error_already_set`` (which will propagate the existing
``KeyboardInterrupt``), or clear the error (which you usually will not want):
251
252
253
254
255
256
257
258
259

.. code-block:: cpp

    PYBIND11_MODULE(example, m)
    {
        m.def("long running_func", []()
        {
            for (;;) {
                if (PyErr_CheckSignals() != 0)
260
                    throw py::error_already_set();
261
262
263
264
265
                // Long running iteration
            }
        });
    }

Henry Schreiner's avatar
Henry Schreiner committed
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
CMake doesn't detect the right Python version
=============================================

The CMake-based build system will try to automatically detect the installed
version of Python and link against that. When this fails, or when there are
multiple versions of Python and it finds the wrong one, delete
``CMakeCache.txt`` and then add ``-DPYTHON_EXECUTABLE=$(which python)`` to your
CMake configure line. (Replace ``$(which python)`` with a path to python if
your prefer.)

You can alternatively try ``-DPYBIND11_FINDPYTHON=ON``, which will activate the
new CMake FindPython support instead of pybind11's custom search. Requires
CMake 3.12+, and 3.15+ or 3.18.2+ are even better. You can set this in your
``CMakeLists.txt`` before adding or finding pybind11, as well.

281
282
283
Inconsistent detection of Python version in CMake and pybind11
==============================================================

Henry Schreiner's avatar
Henry Schreiner committed
284
285
286
287
288
289
The functions ``find_package(PythonInterp)`` and ``find_package(PythonLibs)``
provided by CMake for Python version detection are modified by pybind11 due to
unreliability and limitations that make them unsuitable for pybind11's needs.
Instead pybind11 provides its own, more reliable Python detection CMake code.
Conflicts can arise, however, when using pybind11 in a project that *also* uses
the CMake Python detection in a system with several Python versions installed.
290

Henry Schreiner's avatar
Henry Schreiner committed
291
292
293
This difference may cause inconsistencies and errors if *both* mechanisms are
used in the same project. Consider the following CMake code executed in a
system with Python 2.7 and 3.x installed:
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310

.. code-block:: cmake

    find_package(PythonInterp)
    find_package(PythonLibs)
    find_package(pybind11)

It will detect Python 2.7 and pybind11 will pick it as well.

In contrast this code:

.. code-block:: cmake

    find_package(pybind11)
    find_package(PythonInterp)
    find_package(PythonLibs)

Henry Schreiner's avatar
Henry Schreiner committed
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
will detect Python 3.x for pybind11 and may crash on
``find_package(PythonLibs)`` afterwards.

There are three possible solutions:

1. Avoid using ``find_package(PythonInterp)`` and ``find_package(PythonLibs)``
   from CMake and rely on pybind11 in detecting Python version. If this is not
   possible, the CMake machinery should be called *before* including pybind11.
2. Set ``PYBIND11_FINDPYTHON`` to ``True`` or use ``find_package(Python
   COMPONENTS Interpreter Development)`` on modern CMake (3.12+, 3.15+ better,
   3.18.2+ best). Pybind11 in these cases uses the new CMake FindPython instead
   of the old, deprecated search tools, and these modules are much better at
   finding the correct Python.
3. Set ``PYBIND11_NOPYTHON`` to ``TRUE``. Pybind11 will not search for Python.
   However, you will have to use the target-based system, and do more setup
   yourself, because it does not know about or include things that depend on
   Python, like ``pybind11_add_module``. This might be ideal for integrating
   into an existing system, like scikit-build's Python helpers.
329

330
331
332
333
334
335
336
337
338
339
340
341
342
343
How to cite this project?
=========================

We suggest the following BibTeX template to cite pybind11 in scientific
discourse:

.. code-block:: bash

    @misc{pybind11,
       author = {Wenzel Jakob and Jason Rhinelander and Dean Moldovan},
       year = {2017},
       note = {https://github.com/pybind/pybind11},
       title = {pybind11 -- Seamless operability between C++11 and Python}
    }