xcoll 0.5.12__py3-none-any.whl → 0.6.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of xcoll might be problematic. Click here for more details.

Files changed (333) hide show
  1. xcoll/__init__.py +5 -18
  2. xcoll/beam_elements/__init__.py +1 -0
  3. xcoll/beam_elements/absorber.py +12 -2
  4. xcoll/beam_elements/base.py +162 -62
  5. xcoll/beam_elements/blowup.py +1 -0
  6. xcoll/beam_elements/elements_src/black_absorber.h +57 -58
  7. xcoll/beam_elements/elements_src/black_crystal.h +49 -50
  8. xcoll/beam_elements/elements_src/everest_block.h +21 -11
  9. xcoll/beam_elements/elements_src/everest_collimator.h +100 -91
  10. xcoll/beam_elements/elements_src/everest_crystal.h +145 -140
  11. xcoll/beam_elements/elements_src/transparent_collimator.h +126 -0
  12. xcoll/beam_elements/elements_src/transparent_crystal.h +118 -0
  13. xcoll/beam_elements/everest.py +16 -5
  14. xcoll/beam_elements/monitor.py +1 -0
  15. xcoll/beam_elements/transparent.py +83 -0
  16. xcoll/colldb.py +15 -6
  17. xcoll/general.py +1 -1
  18. xcoll/headers/particle_states.py +51 -0
  19. xcoll/initial_distribution.py +121 -91
  20. xcoll/interaction_record/interaction_record.py +2 -1
  21. xcoll/interaction_record/interaction_types.py +2 -2
  22. xcoll/line_tools.py +163 -73
  23. xcoll/lossmap.py +519 -127
  24. xcoll/plot.py +109 -0
  25. xcoll/rf_sweep.py +6 -0
  26. xcoll/scattering_routines/engine.py +414 -217
  27. xcoll/scattering_routines/environment.py +297 -0
  28. xcoll/scattering_routines/everest/amorphous.h +95 -71
  29. xcoll/scattering_routines/everest/{channeling.h → channelling.h} +121 -112
  30. xcoll/scattering_routines/everest/constants.h +1 -1
  31. xcoll/scattering_routines/everest/crystal_parameters.h +9 -9
  32. xcoll/scattering_routines/everest/everest.h +8 -3
  33. xcoll/scattering_routines/everest/everest.py +2 -1
  34. xcoll/scattering_routines/everest/ionisation_loss.h +141 -0
  35. xcoll/scattering_routines/everest/jaw.h +19 -24
  36. xcoll/scattering_routines/everest/materials.py +2 -0
  37. xcoll/scattering_routines/everest/multiple_coulomb_scattering.h +2 -2
  38. xcoll/scattering_routines/everest/nuclear_interaction.h +35 -19
  39. xcoll/scattering_routines/everest/properties.h +3 -72
  40. xcoll/xaux.py +65 -109
  41. {xcoll-0.5.12.dist-info → xcoll-0.6.0.dist-info}/METADATA +5 -5
  42. xcoll-0.6.0.dist-info/RECORD +135 -0
  43. xcoll/_manager.py +0 -22
  44. xcoll/headers/particle_states.h +0 -25
  45. xcoll/install.py +0 -35
  46. xcoll/scattering_routines/geant4/collimasim/.git +0 -1
  47. xcoll/scattering_routines/geant4/collimasim/.gitignore +0 -12
  48. xcoll/scattering_routines/geant4/collimasim/.gitmodules +0 -3
  49. xcoll/scattering_routines/geant4/collimasim/CMakeLists.txt +0 -26
  50. xcoll/scattering_routines/geant4/collimasim/README.md +0 -21
  51. xcoll/scattering_routines/geant4/collimasim/docs/Makefile +0 -20
  52. xcoll/scattering_routines/geant4/collimasim/docs/make.bat +0 -35
  53. xcoll/scattering_routines/geant4/collimasim/docs/source/collimasim.rst +0 -10
  54. xcoll/scattering_routines/geant4/collimasim/docs/source/conf.py +0 -59
  55. xcoll/scattering_routines/geant4/collimasim/docs/source/index.rst +0 -26
  56. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.appveyor.yml +0 -37
  57. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-format +0 -19
  58. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-tidy +0 -65
  59. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.cmake-format.yaml +0 -73
  60. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.git +0 -1
  61. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CODEOWNERS +0 -9
  62. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CONTRIBUTING.md +0 -386
  63. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/bug-report.yml +0 -45
  64. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/config.yml +0 -8
  65. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/dependabot.yml +0 -16
  66. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler.yml +0 -8
  67. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler_merged.yml +0 -3
  68. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/pull_request_template.md +0 -19
  69. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/ci.yml +0 -969
  70. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/configure.yml +0 -84
  71. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/format.yml +0 -48
  72. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/labeler.yml +0 -16
  73. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/pip.yml +0 -103
  74. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.gitignore +0 -45
  75. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.pre-commit-config.yaml +0 -151
  76. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.readthedocs.yml +0 -3
  77. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/CMakeLists.txt +0 -297
  78. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/LICENSE +0 -29
  79. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/MANIFEST.in +0 -6
  80. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/README.rst +0 -180
  81. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Doxyfile +0 -23
  82. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Makefile +0 -192
  83. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/_static/theme_overrides.css +0 -11
  84. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/chrono.rst +0 -81
  85. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/custom.rst +0 -93
  86. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/eigen.rst +0 -310
  87. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/functional.rst +0 -109
  88. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/index.rst +0 -43
  89. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/overview.rst +0 -171
  90. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/stl.rst +0 -251
  91. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/strings.rst +0 -305
  92. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/classes.rst +0 -1297
  93. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/embedding.rst +0 -262
  94. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/exceptions.rst +0 -396
  95. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/functions.rst +0 -568
  96. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/misc.rst +0 -337
  97. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/index.rst +0 -13
  98. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/numpy.rst +0 -463
  99. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/object.rst +0 -286
  100. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/utilities.rst +0 -155
  101. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/smart_ptrs.rst +0 -174
  102. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/basics.rst +0 -308
  103. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.py +0 -91
  104. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.rst +0 -95
  105. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/changelog.rst +0 -2050
  106. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/classes.rst +0 -542
  107. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/cmake/index.rst +0 -8
  108. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/compiling.rst +0 -648
  109. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/conf.py +0 -381
  110. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/faq.rst +0 -343
  111. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/index.rst +0 -48
  112. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/installing.rst +0 -105
  113. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/limitations.rst +0 -72
  114. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11-logo.png +0 -0
  115. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.png +0 -0
  116. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.svg +0 -427
  117. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.png +0 -0
  118. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.svg +0 -427
  119. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/reference.rst +0 -130
  120. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/release.rst +0 -96
  121. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/requirements.txt +0 -8
  122. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/upgrade.rst +0 -548
  123. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/attr.h +0 -605
  124. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/buffer_info.h +0 -144
  125. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/cast.h +0 -1432
  126. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/chrono.h +0 -213
  127. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/common.h +0 -2
  128. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/complex.h +0 -65
  129. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/class.h +0 -709
  130. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/common.h +0 -1021
  131. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/descr.h +0 -104
  132. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/init.h +0 -346
  133. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/internals.h +0 -467
  134. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/type_caster_base.h +0 -978
  135. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/typeid.h +0 -55
  136. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eigen.h +0 -606
  137. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/embed.h +0 -284
  138. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eval.h +0 -163
  139. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/functional.h +0 -121
  140. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/gil.h +0 -193
  141. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/iostream.h +0 -275
  142. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/numpy.h +0 -1741
  143. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/operators.h +0 -163
  144. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/options.h +0 -65
  145. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pybind11.h +0 -2497
  146. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pytypes.h +0 -1879
  147. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl/filesystem.h +0 -103
  148. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl.h +0 -375
  149. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl_bind.h +0 -747
  150. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/noxfile.py +0 -88
  151. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__init__.py +0 -11
  152. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__main__.py +0 -52
  153. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.py +0 -12
  154. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.pyi +0 -6
  155. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/commands.py +0 -21
  156. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/py.typed +0 -0
  157. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.py +0 -482
  158. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.pyi +0 -63
  159. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pyproject.toml +0 -41
  160. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.cfg +0 -56
  161. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.py +0 -155
  162. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/CMakeLists.txt +0 -503
  163. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/conftest.py +0 -208
  164. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/constructor_stats.h +0 -275
  165. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/cross_module_gil_utils.cpp +0 -73
  166. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/env.py +0 -33
  167. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/pytest.ini +0 -0
  168. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/test_files.py +0 -279
  169. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/pytest.ini +0 -0
  170. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/test_setuphelper.py +0 -143
  171. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/local_bindings.h +0 -85
  172. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/object.h +0 -179
  173. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_cross_module_tests.cpp +0 -151
  174. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.cpp +0 -91
  175. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.h +0 -85
  176. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pytest.ini +0 -19
  177. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/requirements.txt +0 -12
  178. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.cpp +0 -26
  179. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.py +0 -25
  180. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.cpp +0 -216
  181. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.py +0 -163
  182. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.cpp +0 -286
  183. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.py +0 -536
  184. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.cpp +0 -107
  185. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.py +0 -248
  186. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.cpp +0 -227
  187. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.py +0 -202
  188. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.cpp +0 -84
  189. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.py +0 -210
  190. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.cpp +0 -550
  191. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.py +0 -473
  192. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/CMakeLists.txt +0 -84
  193. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/embed.cpp +0 -21
  194. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt +0 -28
  195. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt +0 -39
  196. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt +0 -46
  197. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/main.cpp +0 -6
  198. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt +0 -41
  199. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt +0 -35
  200. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt +0 -41
  201. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/test.py +0 -10
  202. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.cpp +0 -165
  203. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.py +0 -53
  204. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.cpp +0 -238
  205. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.py +0 -126
  206. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.cpp +0 -141
  207. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.py +0 -117
  208. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.cpp +0 -41
  209. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.py +0 -50
  210. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.cpp +0 -69
  211. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.py +0 -42
  212. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.cpp +0 -348
  213. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.py +0 -771
  214. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/CMakeLists.txt +0 -47
  215. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/catch.cpp +0 -22
  216. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/external_module.cpp +0 -23
  217. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.cpp +0 -326
  218. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.py +0 -15
  219. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.cpp +0 -148
  220. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.py +0 -272
  221. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.cpp +0 -119
  222. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.py +0 -51
  223. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval_call.py +0 -5
  224. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.cpp +0 -285
  225. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.h +0 -12
  226. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.py +0 -265
  227. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.cpp +0 -397
  228. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.py +0 -520
  229. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.cpp +0 -49
  230. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.py +0 -94
  231. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.cpp +0 -125
  232. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.py +0 -331
  233. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.cpp +0 -153
  234. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.py +0 -284
  235. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.cpp +0 -107
  236. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.py +0 -257
  237. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.cpp +0 -412
  238. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.py +0 -517
  239. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.cpp +0 -102
  240. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.py +0 -92
  241. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.cpp +0 -233
  242. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.py +0 -360
  243. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.cpp +0 -472
  244. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.py +0 -593
  245. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.cpp +0 -524
  246. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.py +0 -441
  247. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.cpp +0 -103
  248. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.py +0 -267
  249. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.cpp +0 -73
  250. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.py +0 -59
  251. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.cpp +0 -235
  252. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.py +0 -146
  253. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.cpp +0 -189
  254. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.py +0 -82
  255. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.cpp +0 -560
  256. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.py +0 -651
  257. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.cpp +0 -500
  258. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.py +0 -253
  259. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.cpp +0 -452
  260. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.py +0 -318
  261. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.cpp +0 -342
  262. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.py +0 -291
  263. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.cpp +0 -131
  264. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.py +0 -318
  265. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.cpp +0 -144
  266. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.py +0 -29
  267. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.cpp +0 -66
  268. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.py +0 -44
  269. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.cpp +0 -22
  270. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.py +0 -9
  271. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.cpp +0 -510
  272. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.py +0 -408
  273. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-numpy-scipy.supp +0 -140
  274. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-python.supp +0 -117
  275. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindCatch.cmake +0 -70
  276. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindEigen3.cmake +0 -86
  277. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindPythonLibsNew.cmake +0 -257
  278. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/check-style.sh +0 -44
  279. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/cmake_uninstall.cmake.in +0 -23
  280. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/libsize.py +0 -39
  281. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/make_changelog.py +0 -64
  282. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Common.cmake +0 -402
  283. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Config.cmake.in +0 -233
  284. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11NewTools.cmake +0 -276
  285. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Tools.cmake +0 -214
  286. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pyproject.toml +0 -3
  287. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_global.py.in +0 -65
  288. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_main.py.in +0 -41
  289. xcoll/scattering_routines/geant4/collimasim/pyproject.toml +0 -8
  290. xcoll/scattering_routines/geant4/collimasim/setup.py +0 -144
  291. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.cpp +0 -403
  292. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.hh +0 -100
  293. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.cpp +0 -763
  294. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.hh +0 -118
  295. xcoll/scattering_routines/geant4/collimasim/src/collimasim/__init__.py +0 -8
  296. xcoll/scattering_routines/geant4/collimasim/src/collimasim/bindings.cpp +0 -63
  297. xcoll/scattering_routines/geant4/collimasim/src/collimasim/pyCollimatorPass.py +0 -142
  298. xcoll/scattering_routines/geant4/collimasim/src/collimasim/xtrack_collimator.py +0 -556
  299. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/PKG-INFO +0 -6
  300. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/SOURCES.txt +0 -24
  301. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/dependency_links.txt +0 -1
  302. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/not-zip-safe +0 -1
  303. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/top_level.txt +0 -1
  304. xcoll/scattering_routines/geant4/collimasim/tests/README.md +0 -25
  305. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_forions.dat +0 -25
  306. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_new_example.dat +0 -18
  307. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_old_example.dat +0 -68
  308. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_testing.dat +0 -15
  309. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_yaml_example.yaml +0 -110
  310. xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps.dat +0 -7
  311. xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps_pyat_test.dat +0 -3
  312. xcoll/scattering_routines/geant4/collimasim/tests/resources/collonly_twiss_file_example.tfs +0 -54
  313. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings.gmad +0 -3
  314. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_black_absorber.gmad +0 -3
  315. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_ions.gmad +0 -5
  316. xcoll/scattering_routines/geant4/collimasim/tests/resources/twiss_file_testing.tfs +0 -51
  317. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat.py +0 -65
  318. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_passmethod.py +0 -59
  319. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_tracking.py +0 -102
  320. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack.py +0 -75
  321. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_angle.py +0 -74
  322. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_colldb_load.py +0 -84
  323. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction.py +0 -159
  324. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction_ion.py +0 -99
  325. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_ions.py +0 -78
  326. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_lost_energy.py +0 -88
  327. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tilt.py +0 -80
  328. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking.py +0 -97
  329. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking_ions.py +0 -96
  330. xcoll-0.5.12.dist-info/RECORD +0 -415
  331. {xcoll-0.5.12.dist-info → xcoll-0.6.0.dist-info}/LICENSE +0 -0
  332. {xcoll-0.5.12.dist-info → xcoll-0.6.0.dist-info}/NOTICE +0 -0
  333. {xcoll-0.5.12.dist-info → xcoll-0.6.0.dist-info}/WHEEL +0 -0
@@ -1,472 +0,0 @@
1
- /*
2
- tests/test_numpy_array.cpp -- test core array functionality
3
-
4
- Copyright (c) 2016 Ivan Smirnov <i.s.smirnov@gmail.com>
5
-
6
- All rights reserved. Use of this source code is governed by a
7
- BSD-style license that can be found in the LICENSE file.
8
- */
9
-
10
- #include "pybind11_tests.h"
11
-
12
- #include <pybind11/numpy.h>
13
- #include <pybind11/stl.h>
14
-
15
- #include <cstdint>
16
- #include <utility>
17
-
18
- // Size / dtype checks.
19
- struct DtypeCheck {
20
- py::dtype numpy{};
21
- py::dtype pybind11{};
22
- };
23
-
24
- template <typename T>
25
- DtypeCheck get_dtype_check(const char* name) {
26
- py::module_ np = py::module_::import("numpy");
27
- DtypeCheck check{};
28
- check.numpy = np.attr("dtype")(np.attr(name));
29
- check.pybind11 = py::dtype::of<T>();
30
- return check;
31
- }
32
-
33
- std::vector<DtypeCheck> get_concrete_dtype_checks() {
34
- return {
35
- // Normalization
36
- get_dtype_check<std::int8_t>("int8"),
37
- get_dtype_check<std::uint8_t>("uint8"),
38
- get_dtype_check<std::int16_t>("int16"),
39
- get_dtype_check<std::uint16_t>("uint16"),
40
- get_dtype_check<std::int32_t>("int32"),
41
- get_dtype_check<std::uint32_t>("uint32"),
42
- get_dtype_check<std::int64_t>("int64"),
43
- get_dtype_check<std::uint64_t>("uint64")
44
- };
45
- }
46
-
47
- struct DtypeSizeCheck {
48
- std::string name{};
49
- int size_cpp{};
50
- int size_numpy{};
51
- // For debugging.
52
- py::dtype dtype{};
53
- };
54
-
55
- template <typename T>
56
- DtypeSizeCheck get_dtype_size_check() {
57
- DtypeSizeCheck check{};
58
- check.name = py::type_id<T>();
59
- check.size_cpp = sizeof(T);
60
- check.dtype = py::dtype::of<T>();
61
- check.size_numpy = check.dtype.attr("itemsize").template cast<int>();
62
- return check;
63
- }
64
-
65
- std::vector<DtypeSizeCheck> get_platform_dtype_size_checks() {
66
- return {
67
- get_dtype_size_check<short>(),
68
- get_dtype_size_check<unsigned short>(),
69
- get_dtype_size_check<int>(),
70
- get_dtype_size_check<unsigned int>(),
71
- get_dtype_size_check<long>(),
72
- get_dtype_size_check<unsigned long>(),
73
- get_dtype_size_check<long long>(),
74
- get_dtype_size_check<unsigned long long>(),
75
- };
76
- }
77
-
78
- // Arrays.
79
- using arr = py::array;
80
- using arr_t = py::array_t<uint16_t, 0>;
81
- static_assert(std::is_same<arr_t::value_type, uint16_t>::value, "");
82
-
83
- template<typename... Ix> arr data(const arr& a, Ix... index) {
84
- return arr(a.nbytes() - a.offset_at(index...), (const uint8_t *) a.data(index...));
85
- }
86
-
87
- template<typename... Ix> arr data_t(const arr_t& a, Ix... index) {
88
- return arr(a.size() - a.index_at(index...), a.data(index...));
89
- }
90
-
91
- template<typename... Ix> arr& mutate_data(arr& a, Ix... index) {
92
- auto ptr = (uint8_t *) a.mutable_data(index...);
93
- for (py::ssize_t i = 0; i < a.nbytes() - a.offset_at(index...); i++)
94
- ptr[i] = (uint8_t) (ptr[i] * 2);
95
- return a;
96
- }
97
-
98
- template<typename... Ix> arr_t& mutate_data_t(arr_t& a, Ix... index) {
99
- auto ptr = a.mutable_data(index...);
100
- for (py::ssize_t i = 0; i < a.size() - a.index_at(index...); i++)
101
- ptr[i]++;
102
- return a;
103
- }
104
-
105
- template<typename... Ix> py::ssize_t index_at(const arr& a, Ix... idx) { return a.index_at(idx...); }
106
- template<typename... Ix> py::ssize_t index_at_t(const arr_t& a, Ix... idx) { return a.index_at(idx...); }
107
- template<typename... Ix> py::ssize_t offset_at(const arr& a, Ix... idx) { return a.offset_at(idx...); }
108
- template<typename... Ix> py::ssize_t offset_at_t(const arr_t& a, Ix... idx) { return a.offset_at(idx...); }
109
- template<typename... Ix> py::ssize_t at_t(const arr_t& a, Ix... idx) { return a.at(idx...); }
110
- template<typename... Ix> arr_t& mutate_at_t(arr_t& a, Ix... idx) { a.mutable_at(idx...)++; return a; }
111
-
112
- #define def_index_fn(name, type) \
113
- sm.def(#name, [](type a) { return name(a); }); \
114
- sm.def(#name, [](type a, int i) { return name(a, i); }); \
115
- sm.def(#name, [](type a, int i, int j) { return name(a, i, j); }); \
116
- sm.def(#name, [](type a, int i, int j, int k) { return name(a, i, j, k); });
117
-
118
- template <typename T, typename T2> py::handle auxiliaries(T &&r, T2 &&r2) {
119
- if (r.ndim() != 2) throw std::domain_error("error: ndim != 2");
120
- py::list l;
121
- l.append(*r.data(0, 0));
122
- l.append(*r2.mutable_data(0, 0));
123
- l.append(r.data(0, 1) == r2.mutable_data(0, 1));
124
- l.append(r.ndim());
125
- l.append(r.itemsize());
126
- l.append(r.shape(0));
127
- l.append(r.shape(1));
128
- l.append(r.size());
129
- l.append(r.nbytes());
130
- return l.release();
131
- }
132
-
133
- // note: declaration at local scope would create a dangling reference!
134
- static int data_i = 42;
135
-
136
- TEST_SUBMODULE(numpy_array, sm) {
137
- try { py::module_::import("numpy"); }
138
- catch (...) { return; }
139
-
140
- // test_dtypes
141
- py::class_<DtypeCheck>(sm, "DtypeCheck")
142
- .def_readonly("numpy", &DtypeCheck::numpy)
143
- .def_readonly("pybind11", &DtypeCheck::pybind11)
144
- .def("__repr__", [](const DtypeCheck& self) {
145
- return py::str("<DtypeCheck numpy={} pybind11={}>").format(
146
- self.numpy, self.pybind11);
147
- });
148
- sm.def("get_concrete_dtype_checks", &get_concrete_dtype_checks);
149
-
150
- py::class_<DtypeSizeCheck>(sm, "DtypeSizeCheck")
151
- .def_readonly("name", &DtypeSizeCheck::name)
152
- .def_readonly("size_cpp", &DtypeSizeCheck::size_cpp)
153
- .def_readonly("size_numpy", &DtypeSizeCheck::size_numpy)
154
- .def("__repr__", [](const DtypeSizeCheck& self) {
155
- return py::str("<DtypeSizeCheck name='{}' size_cpp={} size_numpy={} dtype={}>").format(
156
- self.name, self.size_cpp, self.size_numpy, self.dtype);
157
- });
158
- sm.def("get_platform_dtype_size_checks", &get_platform_dtype_size_checks);
159
-
160
- // test_array_attributes
161
- sm.def("ndim", [](const arr& a) { return a.ndim(); });
162
- sm.def("shape", [](const arr& a) { return arr(a.ndim(), a.shape()); });
163
- sm.def("shape", [](const arr& a, py::ssize_t dim) { return a.shape(dim); });
164
- sm.def("strides", [](const arr& a) { return arr(a.ndim(), a.strides()); });
165
- sm.def("strides", [](const arr& a, py::ssize_t dim) { return a.strides(dim); });
166
- sm.def("writeable", [](const arr& a) { return a.writeable(); });
167
- sm.def("size", [](const arr& a) { return a.size(); });
168
- sm.def("itemsize", [](const arr& a) { return a.itemsize(); });
169
- sm.def("nbytes", [](const arr& a) { return a.nbytes(); });
170
- sm.def("owndata", [](const arr& a) { return a.owndata(); });
171
-
172
- // test_index_offset
173
- def_index_fn(index_at, const arr&);
174
- def_index_fn(index_at_t, const arr_t&);
175
- def_index_fn(offset_at, const arr&);
176
- def_index_fn(offset_at_t, const arr_t&);
177
- // test_data
178
- def_index_fn(data, const arr&);
179
- def_index_fn(data_t, const arr_t&);
180
- // test_mutate_data, test_mutate_readonly
181
- def_index_fn(mutate_data, arr&);
182
- def_index_fn(mutate_data_t, arr_t&);
183
- def_index_fn(at_t, const arr_t&);
184
- def_index_fn(mutate_at_t, arr_t&);
185
-
186
- // test_make_c_f_array
187
- sm.def("make_f_array", [] { return py::array_t<float>({ 2, 2 }, { 4, 8 }); });
188
- sm.def("make_c_array", [] { return py::array_t<float>({ 2, 2 }, { 8, 4 }); });
189
-
190
- // test_empty_shaped_array
191
- sm.def("make_empty_shaped_array", [] { return py::array(py::dtype("f"), {}, {}); });
192
- // test numpy scalars (empty shape, ndim==0)
193
- sm.def("scalar_int", []() { return py::array(py::dtype("i"), {}, {}, &data_i); });
194
-
195
- // test_wrap
196
- sm.def("wrap", [](const py::array &a) {
197
- return py::array(
198
- a.dtype(),
199
- {a.shape(), a.shape() + a.ndim()},
200
- {a.strides(), a.strides() + a.ndim()},
201
- a.data(),
202
- a
203
- );
204
- });
205
-
206
- // test_numpy_view
207
- struct ArrayClass {
208
- int data[2] = { 1, 2 };
209
- ArrayClass() { py::print("ArrayClass()"); }
210
- ~ArrayClass() { py::print("~ArrayClass()"); }
211
- };
212
- py::class_<ArrayClass>(sm, "ArrayClass")
213
- .def(py::init<>())
214
- .def("numpy_view", [](py::object &obj) {
215
- py::print("ArrayClass::numpy_view()");
216
- auto &a = obj.cast<ArrayClass&>();
217
- return py::array_t<int>({2}, {4}, a.data, obj);
218
- }
219
- );
220
-
221
- // test_cast_numpy_int64_to_uint64
222
- sm.def("function_taking_uint64", [](uint64_t) { });
223
-
224
- // test_isinstance
225
- sm.def("isinstance_untyped", [](py::object yes, py::object no) {
226
- return py::isinstance<py::array>(std::move(yes))
227
- && !py::isinstance<py::array>(std::move(no));
228
- });
229
- sm.def("isinstance_typed", [](const py::object &o) {
230
- return py::isinstance<py::array_t<double>>(o) && !py::isinstance<py::array_t<int>>(o);
231
- });
232
-
233
- // test_constructors
234
- sm.def("default_constructors", []() {
235
- return py::dict(
236
- "array"_a=py::array(),
237
- "array_t<int32>"_a=py::array_t<std::int32_t>(),
238
- "array_t<double>"_a=py::array_t<double>()
239
- );
240
- });
241
- sm.def("converting_constructors", [](const py::object &o) {
242
- return py::dict(
243
- "array"_a=py::array(o),
244
- "array_t<int32>"_a=py::array_t<std::int32_t>(o),
245
- "array_t<double>"_a=py::array_t<double>(o)
246
- );
247
- });
248
-
249
- // test_overload_resolution
250
- sm.def("overloaded", [](const py::array_t<double> &) { return "double"; });
251
- sm.def("overloaded", [](const py::array_t<float> &) { return "float"; });
252
- sm.def("overloaded", [](const py::array_t<int> &) { return "int"; });
253
- sm.def("overloaded", [](const py::array_t<unsigned short> &) { return "unsigned short"; });
254
- sm.def("overloaded", [](const py::array_t<long long> &) { return "long long"; });
255
- sm.def("overloaded",
256
- [](const py::array_t<std::complex<double>> &) { return "double complex"; });
257
- sm.def("overloaded", [](const py::array_t<std::complex<float>> &) { return "float complex"; });
258
-
259
- sm.def("overloaded2",
260
- [](const py::array_t<std::complex<double>> &) { return "double complex"; });
261
- sm.def("overloaded2", [](const py::array_t<double> &) { return "double"; });
262
- sm.def("overloaded2",
263
- [](const py::array_t<std::complex<float>> &) { return "float complex"; });
264
- sm.def("overloaded2", [](const py::array_t<float> &) { return "float"; });
265
-
266
- // [workaround(intel)] ICC 20/21 breaks with py::arg().stuff, using py::arg{}.stuff works.
267
-
268
- // Only accept the exact types:
269
- sm.def(
270
- "overloaded3", [](const py::array_t<int> &) { return "int"; }, py::arg{}.noconvert());
271
- sm.def(
272
- "overloaded3",
273
- [](const py::array_t<double> &) { return "double"; },
274
- py::arg{}.noconvert());
275
-
276
- // Make sure we don't do unsafe coercion (e.g. float to int) when not using forcecast, but
277
- // rather that float gets converted via the safe (conversion to double) overload:
278
- sm.def("overloaded4", [](const py::array_t<long long, 0> &) { return "long long"; });
279
- sm.def("overloaded4", [](const py::array_t<double, 0> &) { return "double"; });
280
-
281
- // But we do allow conversion to int if forcecast is enabled (but only if no overload matches
282
- // without conversion)
283
- sm.def("overloaded5", [](const py::array_t<unsigned int> &) { return "unsigned int"; });
284
- sm.def("overloaded5", [](const py::array_t<double> &) { return "double"; });
285
-
286
- // test_greedy_string_overload
287
- // Issue 685: ndarray shouldn't go to std::string overload
288
- sm.def("issue685", [](const std::string &) { return "string"; });
289
- sm.def("issue685", [](const py::array &) { return "array"; });
290
- sm.def("issue685", [](const py::object &) { return "other"; });
291
-
292
- // test_array_unchecked_fixed_dims
293
- sm.def("proxy_add2", [](py::array_t<double> a, double v) {
294
- auto r = a.mutable_unchecked<2>();
295
- for (py::ssize_t i = 0; i < r.shape(0); i++)
296
- for (py::ssize_t j = 0; j < r.shape(1); j++)
297
- r(i, j) += v;
298
- }, py::arg{}.noconvert(), py::arg());
299
-
300
- sm.def("proxy_init3", [](double start) {
301
- py::array_t<double, py::array::c_style> a({ 3, 3, 3 });
302
- auto r = a.mutable_unchecked<3>();
303
- for (py::ssize_t i = 0; i < r.shape(0); i++)
304
- for (py::ssize_t j = 0; j < r.shape(1); j++)
305
- for (py::ssize_t k = 0; k < r.shape(2); k++)
306
- r(i, j, k) = start++;
307
- return a;
308
- });
309
- sm.def("proxy_init3F", [](double start) {
310
- py::array_t<double, py::array::f_style> a({ 3, 3, 3 });
311
- auto r = a.mutable_unchecked<3>();
312
- for (py::ssize_t k = 0; k < r.shape(2); k++)
313
- for (py::ssize_t j = 0; j < r.shape(1); j++)
314
- for (py::ssize_t i = 0; i < r.shape(0); i++)
315
- r(i, j, k) = start++;
316
- return a;
317
- });
318
- sm.def("proxy_squared_L2_norm", [](const py::array_t<double> &a) {
319
- auto r = a.unchecked<1>();
320
- double sumsq = 0;
321
- for (py::ssize_t i = 0; i < r.shape(0); i++)
322
- sumsq += r[i] * r(i); // Either notation works for a 1D array
323
- return sumsq;
324
- });
325
-
326
- sm.def("proxy_auxiliaries2", [](py::array_t<double> a) {
327
- auto r = a.unchecked<2>();
328
- auto r2 = a.mutable_unchecked<2>();
329
- return auxiliaries(r, r2);
330
- });
331
-
332
- sm.def("proxy_auxiliaries1_const_ref", [](py::array_t<double> a) {
333
- const auto &r = a.unchecked<1>();
334
- const auto &r2 = a.mutable_unchecked<1>();
335
- return r(0) == r2(0) && r[0] == r2[0];
336
- });
337
-
338
- sm.def("proxy_auxiliaries2_const_ref", [](py::array_t<double> a) {
339
- const auto &r = a.unchecked<2>();
340
- const auto &r2 = a.mutable_unchecked<2>();
341
- return r(0, 0) == r2(0, 0);
342
- });
343
-
344
- // test_array_unchecked_dyn_dims
345
- // Same as the above, but without a compile-time dimensions specification:
346
- sm.def("proxy_add2_dyn", [](py::array_t<double> a, double v) {
347
- auto r = a.mutable_unchecked();
348
- if (r.ndim() != 2) throw std::domain_error("error: ndim != 2");
349
- for (py::ssize_t i = 0; i < r.shape(0); i++)
350
- for (py::ssize_t j = 0; j < r.shape(1); j++)
351
- r(i, j) += v;
352
- }, py::arg{}.noconvert(), py::arg());
353
- sm.def("proxy_init3_dyn", [](double start) {
354
- py::array_t<double, py::array::c_style> a({ 3, 3, 3 });
355
- auto r = a.mutable_unchecked();
356
- if (r.ndim() != 3) throw std::domain_error("error: ndim != 3");
357
- for (py::ssize_t i = 0; i < r.shape(0); i++)
358
- for (py::ssize_t j = 0; j < r.shape(1); j++)
359
- for (py::ssize_t k = 0; k < r.shape(2); k++)
360
- r(i, j, k) = start++;
361
- return a;
362
- });
363
- sm.def("proxy_auxiliaries2_dyn", [](py::array_t<double> a) {
364
- return auxiliaries(a.unchecked(), a.mutable_unchecked());
365
- });
366
-
367
- sm.def("array_auxiliaries2", [](py::array_t<double> a) {
368
- return auxiliaries(a, a);
369
- });
370
-
371
- // test_array_failures
372
- // Issue #785: Uninformative "Unknown internal error" exception when constructing array from empty object:
373
- sm.def("array_fail_test", []() { return py::array(py::object()); });
374
- sm.def("array_t_fail_test", []() { return py::array_t<double>(py::object()); });
375
- // Make sure the error from numpy is being passed through:
376
- sm.def("array_fail_test_negative_size", []() { int c = 0; return py::array(-1, &c); });
377
-
378
- // test_initializer_list
379
- // Issue (unnumbered; reported in #788): regression: initializer lists can be ambiguous
380
- sm.def("array_initializer_list1", []() { return py::array_t<float>(1); }); // { 1 } also works, but clang warns about it
381
- sm.def("array_initializer_list2", []() { return py::array_t<float>({ 1, 2 }); });
382
- sm.def("array_initializer_list3", []() { return py::array_t<float>({ 1, 2, 3 }); });
383
- sm.def("array_initializer_list4", []() { return py::array_t<float>({ 1, 2, 3, 4 }); });
384
-
385
- // test_array_resize
386
- // reshape array to 2D without changing size
387
- sm.def("array_reshape2", [](py::array_t<double> a) {
388
- const auto dim_sz = (py::ssize_t)std::sqrt(a.size());
389
- if (dim_sz * dim_sz != a.size())
390
- throw std::domain_error("array_reshape2: input array total size is not a squared integer");
391
- a.resize({dim_sz, dim_sz});
392
- });
393
-
394
- // resize to 3D array with each dimension = N
395
- sm.def("array_resize3", [](py::array_t<double> a, size_t N, bool refcheck) {
396
- a.resize({N, N, N}, refcheck);
397
- });
398
-
399
- // test_array_create_and_resize
400
- // return 2D array with Nrows = Ncols = N
401
- sm.def("create_and_resize", [](size_t N) {
402
- py::array_t<double> a;
403
- a.resize({N, N});
404
- std::fill(a.mutable_data(), a.mutable_data() + a.size(), 42.);
405
- return a;
406
- });
407
-
408
- sm.def("array_view",
409
- [](py::array_t<uint8_t> a, const std::string &dtype) { return a.view(dtype); });
410
-
411
- sm.def("reshape_initializer_list", [](py::array_t<int> a, size_t N, size_t M, size_t O) {
412
- return a.reshape({N, M, O});
413
- });
414
- sm.def("reshape_tuple", [](py::array_t<int> a, const std::vector<int> &new_shape) {
415
- return a.reshape(new_shape);
416
- });
417
-
418
- sm.def("index_using_ellipsis",
419
- [](const py::array &a) { return a[py::make_tuple(0, py::ellipsis(), 0)]; });
420
-
421
- // test_argument_conversions
422
- sm.def(
423
- "accept_double", [](const py::array_t<double, 0> &) {}, py::arg("a"));
424
- sm.def(
425
- "accept_double_forcecast",
426
- [](const py::array_t<double, py::array::forcecast> &) {},
427
- py::arg("a"));
428
- sm.def(
429
- "accept_double_c_style",
430
- [](const py::array_t<double, py::array::c_style> &) {},
431
- py::arg("a"));
432
- sm.def(
433
- "accept_double_c_style_forcecast",
434
- [](const py::array_t<double, py::array::forcecast | py::array::c_style> &) {},
435
- py::arg("a"));
436
- sm.def(
437
- "accept_double_f_style",
438
- [](const py::array_t<double, py::array::f_style> &) {},
439
- py::arg("a"));
440
- sm.def(
441
- "accept_double_f_style_forcecast",
442
- [](const py::array_t<double, py::array::forcecast | py::array::f_style> &) {},
443
- py::arg("a"));
444
- sm.def(
445
- "accept_double_noconvert", [](const py::array_t<double, 0> &) {}, "a"_a.noconvert());
446
- sm.def(
447
- "accept_double_forcecast_noconvert",
448
- [](const py::array_t<double, py::array::forcecast> &) {},
449
- "a"_a.noconvert());
450
- sm.def(
451
- "accept_double_c_style_noconvert",
452
- [](const py::array_t<double, py::array::c_style> &) {},
453
- "a"_a.noconvert());
454
- sm.def(
455
- "accept_double_c_style_forcecast_noconvert",
456
- [](const py::array_t<double, py::array::forcecast | py::array::c_style> &) {},
457
- "a"_a.noconvert());
458
- sm.def(
459
- "accept_double_f_style_noconvert",
460
- [](const py::array_t<double, py::array::f_style> &) {},
461
- "a"_a.noconvert());
462
- sm.def(
463
- "accept_double_f_style_forcecast_noconvert",
464
- [](const py::array_t<double, py::array::forcecast | py::array::f_style> &) {},
465
- "a"_a.noconvert());
466
-
467
- // Check that types returns correct npy format descriptor
468
- sm.def("test_fmt_desc_float", [](const py::array_t<float> &) {});
469
- sm.def("test_fmt_desc_double", [](const py::array_t<double> &) {});
470
- sm.def("test_fmt_desc_const_float", [](const py::array_t<const float> &) {});
471
- sm.def("test_fmt_desc_const_double", [](const py::array_t<const double> &) {});
472
- }