μHAL (v2.8.17)
Part of the IPbus software repository
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
benchmark.py
Go to the documentation of this file.
1# -*- coding: utf-8 -*-
2import datetime as dt
3import os
4import random
5
6nfns = 4 # Functions per class
7nargs = 4 # Arguments per function
8
9
11 decl = ""
12 bindings = ""
13
14 for cl in range(nclasses):
15 decl += "class cl%03i;\n" % cl
16 decl += "\n"
17
18 for cl in range(nclasses):
19 decl += "class cl%03i {\n" % cl
20 decl += "public:\n"
21 bindings += ' py::class_<cl%03i>(m, "cl%03i")\n' % (cl, cl)
22 for fn in range(nfns):
23 ret = random.randint(0, nclasses - 1)
24 params = [random.randint(0, nclasses - 1) for i in range(nargs)]
25 decl += " cl%03i *fn_%03i(" % (ret, fn)
26 decl += ", ".join("cl%03i *" % p for p in params)
27 decl += ");\n"
28 bindings += ' .def("fn_%03i", &cl%03i::fn_%03i)\n' % (fn, cl, fn)
29 decl += "};\n\n"
30 bindings += " ;\n"
31
32 result = "#include <pybind11/pybind11.h>\n\n"
33 result += "namespace py = pybind11;\n\n"
34 result += decl + "\n"
35 result += "PYBIND11_MODULE(example, m) {\n"
36 result += bindings
37 result += "}"
38 return result
39
40
42 decl = ""
43 bindings = ""
44
45 for cl in range(nclasses):
46 decl += "class cl%03i;\n" % cl
47 decl += "\n"
48
49 for cl in range(nclasses):
50 decl += "class cl%03i {\n" % cl
51 decl += "public:\n"
52 bindings += ' py::class_<cl%03i>("cl%03i")\n' % (cl, cl)
53 for fn in range(nfns):
54 ret = random.randint(0, nclasses - 1)
55 params = [random.randint(0, nclasses - 1) for i in range(nargs)]
56 decl += " cl%03i *fn_%03i(" % (ret, fn)
57 decl += ", ".join("cl%03i *" % p for p in params)
58 decl += ");\n"
59 bindings += (
60 ' .def("fn_%03i", &cl%03i::fn_%03i, py::return_value_policy<py::manage_new_object>())\n'
61 % (fn, cl, fn)
62 )
63 decl += "};\n\n"
64 bindings += " ;\n"
65
66 result = "#include <boost/python.hpp>\n\n"
67 result += "namespace py = boost::python;\n\n"
68 result += decl + "\n"
69 result += "BOOST_PYTHON_MODULE(example) {\n"
70 result += bindings
71 result += "}"
72 return result
73
74
75for codegen in [generate_dummy_code_pybind11, generate_dummy_code_boost]:
76 print("{")
77 for i in range(0, 10):
78 nclasses = 2 ** i
79 with open("test.cpp", "w") as f:
80 f.write(codegen(nclasses))
81 n1 = dt.datetime.now()
82 os.system(
83 "g++ -Os -shared -rdynamic -undefined dynamic_lookup "
84 "-fvisibility=hidden -std=c++14 test.cpp -I include "
85 "-I /System/Library/Frameworks/Python.framework/Headers -o test.so"
86 )
87 n2 = dt.datetime.now()
88 elapsed = (n2 - n1).total_seconds()
89 size = os.stat("test.so").st_size
90 print(" {%i, %f, %i}," % (nclasses * nfns, elapsed, size))
91 print("}")
def generate_dummy_code_boost(nclasses=10)
Definition: benchmark.py:41
def generate_dummy_code_pybind11(nclasses=10)
Definition: benchmark.py:10