xcoll 0.5.12__py3-none-any.whl → 0.6.1__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 (336) hide show
  1. xcoll/__init__.py +5 -18
  2. xcoll/__init__.py.orig +26 -0
  3. xcoll/beam_elements/__init__.py +1 -0
  4. xcoll/beam_elements/absorber.py +12 -2
  5. xcoll/beam_elements/base.py +162 -62
  6. xcoll/beam_elements/blowup.py +1 -0
  7. xcoll/beam_elements/elements_src/black_absorber.h +57 -58
  8. xcoll/beam_elements/elements_src/black_crystal.h +49 -50
  9. xcoll/beam_elements/elements_src/everest_block.h +21 -11
  10. xcoll/beam_elements/elements_src/everest_collimator.h +100 -91
  11. xcoll/beam_elements/elements_src/everest_crystal.h +145 -140
  12. xcoll/beam_elements/elements_src/transparent_collimator.h +126 -0
  13. xcoll/beam_elements/elements_src/transparent_crystal.h +118 -0
  14. xcoll/beam_elements/everest.py +16 -5
  15. xcoll/beam_elements/monitor.py +1 -0
  16. xcoll/beam_elements/transparent.py +83 -0
  17. xcoll/colldb.py +15 -6
  18. xcoll/general.py +1 -1
  19. xcoll/general.py.orig +20 -0
  20. xcoll/headers/particle_states.py +51 -0
  21. xcoll/initial_distribution.py +121 -91
  22. xcoll/initial_distribution.py.orig +256 -0
  23. xcoll/interaction_record/interaction_record.py +2 -1
  24. xcoll/interaction_record/interaction_types.py +2 -2
  25. xcoll/line_tools.py +163 -73
  26. xcoll/lossmap.py +519 -127
  27. xcoll/plot.py +109 -0
  28. xcoll/rf_sweep.py +6 -0
  29. xcoll/scattering_routines/engine.py +414 -217
  30. xcoll/scattering_routines/environment.py +297 -0
  31. xcoll/scattering_routines/everest/amorphous.h +95 -71
  32. xcoll/scattering_routines/everest/{channeling.h → channelling.h} +121 -112
  33. xcoll/scattering_routines/everest/constants.h +1 -1
  34. xcoll/scattering_routines/everest/crystal_parameters.h +9 -9
  35. xcoll/scattering_routines/everest/everest.h +8 -3
  36. xcoll/scattering_routines/everest/everest.py +2 -1
  37. xcoll/scattering_routines/everest/ionisation_loss.h +141 -0
  38. xcoll/scattering_routines/everest/jaw.h +19 -24
  39. xcoll/scattering_routines/everest/materials.py +2 -0
  40. xcoll/scattering_routines/everest/multiple_coulomb_scattering.h +2 -2
  41. xcoll/scattering_routines/everest/nuclear_interaction.h +35 -19
  42. xcoll/scattering_routines/everest/properties.h +3 -72
  43. xcoll/xaux.py +65 -109
  44. {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/METADATA +5 -5
  45. xcoll-0.6.1.dist-info/RECORD +138 -0
  46. xcoll/_manager.py +0 -22
  47. xcoll/headers/particle_states.h +0 -25
  48. xcoll/install.py +0 -35
  49. xcoll/scattering_routines/geant4/collimasim/.git +0 -1
  50. xcoll/scattering_routines/geant4/collimasim/.gitignore +0 -12
  51. xcoll/scattering_routines/geant4/collimasim/.gitmodules +0 -3
  52. xcoll/scattering_routines/geant4/collimasim/CMakeLists.txt +0 -26
  53. xcoll/scattering_routines/geant4/collimasim/README.md +0 -21
  54. xcoll/scattering_routines/geant4/collimasim/docs/Makefile +0 -20
  55. xcoll/scattering_routines/geant4/collimasim/docs/make.bat +0 -35
  56. xcoll/scattering_routines/geant4/collimasim/docs/source/collimasim.rst +0 -10
  57. xcoll/scattering_routines/geant4/collimasim/docs/source/conf.py +0 -59
  58. xcoll/scattering_routines/geant4/collimasim/docs/source/index.rst +0 -26
  59. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.appveyor.yml +0 -37
  60. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-format +0 -19
  61. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.clang-tidy +0 -65
  62. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.cmake-format.yaml +0 -73
  63. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.git +0 -1
  64. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CODEOWNERS +0 -9
  65. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/CONTRIBUTING.md +0 -386
  66. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/bug-report.yml +0 -45
  67. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/ISSUE_TEMPLATE/config.yml +0 -8
  68. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/dependabot.yml +0 -16
  69. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler.yml +0 -8
  70. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/labeler_merged.yml +0 -3
  71. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/pull_request_template.md +0 -19
  72. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/ci.yml +0 -969
  73. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/configure.yml +0 -84
  74. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/format.yml +0 -48
  75. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/labeler.yml +0 -16
  76. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.github/workflows/pip.yml +0 -103
  77. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.gitignore +0 -45
  78. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.pre-commit-config.yaml +0 -151
  79. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/.readthedocs.yml +0 -3
  80. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/CMakeLists.txt +0 -297
  81. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/LICENSE +0 -29
  82. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/MANIFEST.in +0 -6
  83. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/README.rst +0 -180
  84. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Doxyfile +0 -23
  85. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/Makefile +0 -192
  86. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/_static/theme_overrides.css +0 -11
  87. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/chrono.rst +0 -81
  88. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/custom.rst +0 -93
  89. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/eigen.rst +0 -310
  90. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/functional.rst +0 -109
  91. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/index.rst +0 -43
  92. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/overview.rst +0 -171
  93. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/stl.rst +0 -251
  94. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/cast/strings.rst +0 -305
  95. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/classes.rst +0 -1297
  96. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/embedding.rst +0 -262
  97. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/exceptions.rst +0 -396
  98. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/functions.rst +0 -568
  99. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/misc.rst +0 -337
  100. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/index.rst +0 -13
  101. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/numpy.rst +0 -463
  102. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/object.rst +0 -286
  103. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/pycpp/utilities.rst +0 -155
  104. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/advanced/smart_ptrs.rst +0 -174
  105. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/basics.rst +0 -308
  106. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.py +0 -91
  107. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/benchmark.rst +0 -95
  108. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/changelog.rst +0 -2050
  109. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/classes.rst +0 -542
  110. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/cmake/index.rst +0 -8
  111. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/compiling.rst +0 -648
  112. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/conf.py +0 -381
  113. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/faq.rst +0 -343
  114. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/index.rst +0 -48
  115. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/installing.rst +0 -105
  116. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/limitations.rst +0 -72
  117. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11-logo.png +0 -0
  118. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.png +0 -0
  119. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python1.svg +0 -427
  120. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.png +0 -0
  121. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/pybind11_vs_boost_python2.svg +0 -427
  122. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/reference.rst +0 -130
  123. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/release.rst +0 -96
  124. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/requirements.txt +0 -8
  125. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/docs/upgrade.rst +0 -548
  126. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/attr.h +0 -605
  127. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/buffer_info.h +0 -144
  128. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/cast.h +0 -1432
  129. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/chrono.h +0 -213
  130. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/common.h +0 -2
  131. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/complex.h +0 -65
  132. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/class.h +0 -709
  133. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/common.h +0 -1021
  134. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/descr.h +0 -104
  135. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/init.h +0 -346
  136. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/internals.h +0 -467
  137. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/type_caster_base.h +0 -978
  138. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/detail/typeid.h +0 -55
  139. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eigen.h +0 -606
  140. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/embed.h +0 -284
  141. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/eval.h +0 -163
  142. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/functional.h +0 -121
  143. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/gil.h +0 -193
  144. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/iostream.h +0 -275
  145. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/numpy.h +0 -1741
  146. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/operators.h +0 -163
  147. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/options.h +0 -65
  148. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pybind11.h +0 -2497
  149. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/pytypes.h +0 -1879
  150. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl/filesystem.h +0 -103
  151. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl.h +0 -375
  152. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/include/pybind11/stl_bind.h +0 -747
  153. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/noxfile.py +0 -88
  154. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__init__.py +0 -11
  155. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/__main__.py +0 -52
  156. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.py +0 -12
  157. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/_version.pyi +0 -6
  158. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/commands.py +0 -21
  159. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/py.typed +0 -0
  160. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.py +0 -482
  161. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pybind11/setup_helpers.pyi +0 -63
  162. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/pyproject.toml +0 -41
  163. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.cfg +0 -56
  164. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/setup.py +0 -155
  165. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/CMakeLists.txt +0 -503
  166. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/conftest.py +0 -208
  167. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/constructor_stats.h +0 -275
  168. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/cross_module_gil_utils.cpp +0 -73
  169. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/env.py +0 -33
  170. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/pytest.ini +0 -0
  171. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_python_package/test_files.py +0 -279
  172. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/pytest.ini +0 -0
  173. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/extra_setuptools/test_setuphelper.py +0 -143
  174. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/local_bindings.h +0 -85
  175. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/object.h +0 -179
  176. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_cross_module_tests.cpp +0 -151
  177. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.cpp +0 -91
  178. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pybind11_tests.h +0 -85
  179. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/pytest.ini +0 -19
  180. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/requirements.txt +0 -12
  181. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.cpp +0 -26
  182. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_async.py +0 -25
  183. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.cpp +0 -216
  184. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_buffers.py +0 -163
  185. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.cpp +0 -286
  186. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_builtin_casters.py +0 -536
  187. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.cpp +0 -107
  188. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_call_policies.py +0 -248
  189. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.cpp +0 -227
  190. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_callbacks.py +0 -202
  191. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.cpp +0 -84
  192. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_chrono.py +0 -210
  193. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.cpp +0 -550
  194. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_class.py +0 -473
  195. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/CMakeLists.txt +0 -84
  196. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/embed.cpp +0 -21
  197. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_embed/CMakeLists.txt +0 -28
  198. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_function/CMakeLists.txt +0 -39
  199. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/installed_target/CMakeLists.txt +0 -46
  200. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/main.cpp +0 -6
  201. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_embed/CMakeLists.txt +0 -41
  202. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_function/CMakeLists.txt +0 -35
  203. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/subdirectory_target/CMakeLists.txt +0 -41
  204. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_cmake_build/test.py +0 -10
  205. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.cpp +0 -165
  206. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_constants_and_functions.py +0 -53
  207. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.cpp +0 -238
  208. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_copy_move.py +0 -126
  209. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.cpp +0 -141
  210. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_casters.py +0 -117
  211. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.cpp +0 -41
  212. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_custom_type_setup.py +0 -50
  213. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.cpp +0 -69
  214. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_docstring_options.py +0 -42
  215. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.cpp +0 -348
  216. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eigen.py +0 -771
  217. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/CMakeLists.txt +0 -47
  218. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/catch.cpp +0 -22
  219. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/external_module.cpp +0 -23
  220. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.cpp +0 -326
  221. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_embed/test_interpreter.py +0 -15
  222. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.cpp +0 -148
  223. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_enum.py +0 -272
  224. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.cpp +0 -119
  225. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval.py +0 -51
  226. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_eval_call.py +0 -5
  227. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.cpp +0 -285
  228. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.h +0 -12
  229. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_exceptions.py +0 -265
  230. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.cpp +0 -397
  231. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_factory_constructors.py +0 -520
  232. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.cpp +0 -49
  233. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_gil_scoped.py +0 -94
  234. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.cpp +0 -125
  235. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_iostream.py +0 -331
  236. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.cpp +0 -153
  237. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_kwargs_and_defaults.py +0 -284
  238. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.cpp +0 -107
  239. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_local_bindings.py +0 -257
  240. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.cpp +0 -412
  241. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_methods_and_attributes.py +0 -517
  242. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.cpp +0 -102
  243. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_modules.py +0 -92
  244. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.cpp +0 -233
  245. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_multiple_inheritance.py +0 -360
  246. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.cpp +0 -472
  247. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_array.py +0 -593
  248. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.cpp +0 -524
  249. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_dtypes.py +0 -441
  250. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.cpp +0 -103
  251. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_numpy_vectorize.py +0 -267
  252. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.cpp +0 -73
  253. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_opaque_types.py +0 -59
  254. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.cpp +0 -235
  255. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_operator_overloading.py +0 -146
  256. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.cpp +0 -189
  257. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pickling.py +0 -82
  258. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.cpp +0 -560
  259. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_pytypes.py +0 -651
  260. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.cpp +0 -500
  261. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_sequences_and_iterators.py +0 -253
  262. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.cpp +0 -452
  263. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_smart_ptr.py +0 -318
  264. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.cpp +0 -342
  265. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl.py +0 -291
  266. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.cpp +0 -131
  267. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_stl_binders.py +0 -318
  268. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.cpp +0 -144
  269. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_tagbased_polymorphic.py +0 -29
  270. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.cpp +0 -66
  271. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_thread.py +0 -44
  272. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.cpp +0 -22
  273. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_union.py +0 -9
  274. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.cpp +0 -510
  275. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/test_virtual_functions.py +0 -408
  276. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-numpy-scipy.supp +0 -140
  277. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tests/valgrind-python.supp +0 -117
  278. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindCatch.cmake +0 -70
  279. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindEigen3.cmake +0 -86
  280. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/FindPythonLibsNew.cmake +0 -257
  281. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/check-style.sh +0 -44
  282. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/cmake_uninstall.cmake.in +0 -23
  283. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/libsize.py +0 -39
  284. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/make_changelog.py +0 -64
  285. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Common.cmake +0 -402
  286. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Config.cmake.in +0 -233
  287. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11NewTools.cmake +0 -276
  288. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pybind11Tools.cmake +0 -214
  289. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/pyproject.toml +0 -3
  290. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_global.py.in +0 -65
  291. xcoll/scattering_routines/geant4/collimasim/lib/pybind11/tools/setup_main.py.in +0 -41
  292. xcoll/scattering_routines/geant4/collimasim/pyproject.toml +0 -8
  293. xcoll/scattering_routines/geant4/collimasim/setup.py +0 -144
  294. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.cpp +0 -403
  295. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSPyATInterface.hh +0 -100
  296. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.cpp +0 -763
  297. xcoll/scattering_routines/geant4/collimasim/src/collimasim/BDSXtrackInterface.hh +0 -118
  298. xcoll/scattering_routines/geant4/collimasim/src/collimasim/__init__.py +0 -8
  299. xcoll/scattering_routines/geant4/collimasim/src/collimasim/bindings.cpp +0 -63
  300. xcoll/scattering_routines/geant4/collimasim/src/collimasim/pyCollimatorPass.py +0 -142
  301. xcoll/scattering_routines/geant4/collimasim/src/collimasim/xtrack_collimator.py +0 -556
  302. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/PKG-INFO +0 -6
  303. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/SOURCES.txt +0 -24
  304. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/dependency_links.txt +0 -1
  305. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/not-zip-safe +0 -1
  306. xcoll/scattering_routines/geant4/collimasim/src/collimasim.egg-info/top_level.txt +0 -1
  307. xcoll/scattering_routines/geant4/collimasim/tests/README.md +0 -25
  308. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_forions.dat +0 -25
  309. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_new_example.dat +0 -18
  310. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_old_example.dat +0 -68
  311. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_testing.dat +0 -15
  312. xcoll/scattering_routines/geant4/collimasim/tests/resources/CollDB_yaml_example.yaml +0 -110
  313. xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps.dat +0 -7
  314. xcoll/scattering_routines/geant4/collimasim/tests/resources/collgaps_pyat_test.dat +0 -3
  315. xcoll/scattering_routines/geant4/collimasim/tests/resources/collonly_twiss_file_example.tfs +0 -54
  316. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings.gmad +0 -3
  317. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_black_absorber.gmad +0 -3
  318. xcoll/scattering_routines/geant4/collimasim/tests/resources/settings_ions.gmad +0 -5
  319. xcoll/scattering_routines/geant4/collimasim/tests/resources/twiss_file_testing.tfs +0 -51
  320. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat.py +0 -65
  321. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_passmethod.py +0 -59
  322. xcoll/scattering_routines/geant4/collimasim/tests/test_pyat_tracking.py +0 -102
  323. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack.py +0 -75
  324. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_angle.py +0 -74
  325. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_colldb_load.py +0 -84
  326. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction.py +0 -159
  327. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_interaction_ion.py +0 -99
  328. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_ions.py +0 -78
  329. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_lost_energy.py +0 -88
  330. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tilt.py +0 -80
  331. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking.py +0 -97
  332. xcoll/scattering_routines/geant4/collimasim/tests/test_xtrack_tracking_ions.py +0 -96
  333. xcoll-0.5.12.dist-info/RECORD +0 -415
  334. {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/LICENSE +0 -0
  335. {xcoll-0.5.12.dist-info → xcoll-0.6.1.dist-info}/NOTICE +0 -0
  336. {xcoll-0.5.12.dist-info → xcoll-0.6.1.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
- }