nabu 2024.1.0rc3__py3-none-any.whl → 2024.1.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.
Files changed (2096) hide show
  1. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/conf.py +137 -0
  2. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  3. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  4. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  5. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  6. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  7. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  8. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  9. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  10. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  11. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  12. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  13. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  14. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  15. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  16. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  17. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  18. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  19. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  20. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  21. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  22. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  23. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  24. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  25. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  26. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  27. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  28. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  29. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  30. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  31. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  32. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  33. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  34. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  35. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  36. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  37. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  38. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  39. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  40. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  41. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  42. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  43. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  44. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  45. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  46. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  47. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  48. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  49. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  50. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  51. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  52. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  53. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  54. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  55. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  56. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  57. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  58. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  59. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  60. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  61. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  62. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  63. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  64. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  65. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  66. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  67. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  68. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  69. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  70. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  71. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  72. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  73. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  74. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  75. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  76. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  77. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  78. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  79. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  80. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  81. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  82. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  83. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  84. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  85. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  86. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  87. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  88. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  89. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  90. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  91. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  92. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  93. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  94. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  95. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  96. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  97. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  98. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  99. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  100. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  101. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  102. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  103. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  104. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  105. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  106. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  107. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  108. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  109. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  110. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  111. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  112. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  113. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  114. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  115. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  116. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  117. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  118. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  119. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  120. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  121. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  122. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  123. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  124. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  125. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  126. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  127. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  128. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  129. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  130. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  131. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  132. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  133. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  134. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  135. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  136. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  137. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  138. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  139. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  140. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  141. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  142. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  143. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  144. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  145. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  146. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  147. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  148. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  149. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  150. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  151. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  152. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  153. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  154. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  155. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  156. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  157. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  158. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  159. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  160. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  161. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  162. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  163. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  164. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  165. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  166. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  167. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  168. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  169. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  170. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  171. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  172. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  173. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  174. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  175. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  176. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  177. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  178. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  179. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  180. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  181. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  182. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  183. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  184. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  185. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  186. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  187. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  188. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  189. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  190. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  191. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  192. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  193. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  194. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  195. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  196. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  197. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  198. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  199. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  200. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  201. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  202. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  203. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  204. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  205. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  206. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  207. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  208. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  209. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  210. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  211. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  212. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  213. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  214. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  215. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  216. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  217. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  218. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  219. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  220. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  221. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  222. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  223. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  224. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  225. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  226. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  227. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  228. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  229. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  230. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  231. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  232. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  233. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  234. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  235. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  236. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  237. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  238. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  239. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  240. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  241. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  242. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  243. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  244. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  245. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  246. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  247. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  248. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  249. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  250. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  251. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  252. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  253. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  254. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  255. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  256. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  257. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  258. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  259. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  260. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  261. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/conf.py +137 -0
  262. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  263. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  264. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  265. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  266. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  267. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  268. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  269. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  270. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  271. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  272. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  273. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  274. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  275. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  276. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  277. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  278. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  279. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  280. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  281. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  282. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  283. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  284. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  285. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  286. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  287. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  288. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  289. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  290. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  291. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  292. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  293. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  294. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  295. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  296. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  297. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  298. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  299. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  300. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  301. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  302. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  303. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  304. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  305. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  306. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  307. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  308. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  309. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  310. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  311. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  312. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  313. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  314. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  315. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  316. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  317. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  318. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  319. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  320. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  321. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  322. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  323. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  324. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  325. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  326. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  327. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  328. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  329. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  330. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  331. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  332. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  333. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  334. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  335. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  336. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  337. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  338. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  339. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  340. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  341. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  342. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  343. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  344. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  345. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  346. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  347. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  348. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  349. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  350. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  351. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  352. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  353. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  354. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  355. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  356. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  357. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  358. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  359. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  360. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  361. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  362. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  363. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  364. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  365. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  366. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  367. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  368. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  369. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  370. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  371. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  372. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  373. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  374. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  375. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  376. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  377. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  378. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  379. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  380. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  381. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  382. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  383. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  384. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  385. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  386. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  387. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  388. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  389. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  390. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  391. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  392. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  393. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  394. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  395. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  396. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  397. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  398. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  399. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  400. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  401. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  402. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  403. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  404. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  405. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  406. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  407. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  408. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  409. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  410. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  411. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  412. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  413. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  414. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  415. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  416. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  417. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  418. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  419. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  420. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  421. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  422. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  423. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  424. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  425. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  426. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  427. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  428. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  429. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  430. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  431. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  432. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  433. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  434. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  435. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  436. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  437. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  438. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  439. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  440. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  441. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  442. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  443. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  444. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  445. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  446. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  447. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  448. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  449. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  450. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  451. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  452. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  453. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  454. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  455. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  456. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  457. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  458. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  459. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  460. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  461. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  462. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  463. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  464. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  465. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  466. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  467. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  468. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  469. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  470. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  471. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  472. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  473. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  474. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  475. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  476. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  477. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  478. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  479. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  480. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  481. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  482. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  483. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  484. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  485. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  486. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  487. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  488. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  489. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  490. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  491. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  492. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  493. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  494. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  495. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  496. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  497. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  498. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  499. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  500. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  501. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  502. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  503. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  504. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  505. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  506. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  507. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  508. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  509. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  510. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  511. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  512. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  513. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  514. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  515. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  516. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  517. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  518. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  519. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  520. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  521. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/conf.py +137 -0
  522. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  523. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  524. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  525. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  526. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  527. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  528. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  529. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  530. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  531. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  532. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  533. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  534. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  535. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  536. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  537. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  538. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  539. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  540. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  541. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  542. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  543. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  544. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  545. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  546. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  547. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  548. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  549. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  550. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  551. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  552. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  553. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  554. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  555. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  556. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  557. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  558. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  559. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  560. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  561. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  562. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  563. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  564. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  565. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  566. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  567. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  568. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  569. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  570. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  571. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  572. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  573. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  574. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  575. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  576. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  577. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  578. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  579. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  580. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  581. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  582. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  583. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  584. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  585. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  586. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  587. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  588. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  589. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  590. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  591. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  592. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  593. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  594. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  595. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  596. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  597. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  598. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  599. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  600. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  601. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  602. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  603. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  604. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  605. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  606. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  607. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  608. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  609. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  610. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  611. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  612. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  613. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  614. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  615. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  616. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  617. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  618. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  619. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  620. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  621. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  622. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  623. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  624. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  625. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  626. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  627. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  628. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  629. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  630. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  631. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  632. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  633. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  634. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  635. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  636. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  637. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  638. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  639. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  640. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  641. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  642. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  643. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  644. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  645. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  646. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  647. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  648. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  649. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  650. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  651. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  652. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  653. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  654. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  655. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  656. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  657. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  658. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  659. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  660. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  661. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  662. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  663. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  664. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  665. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  666. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  667. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  668. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  669. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  670. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  671. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  672. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  673. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  674. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  675. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  676. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  677. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  678. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  679. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  680. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  681. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  682. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  683. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  684. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  685. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  686. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  687. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  688. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  689. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  690. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  691. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  692. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  693. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  694. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  695. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  696. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  697. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  698. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  699. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  700. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  701. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  702. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  703. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  704. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  705. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  706. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  707. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  708. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  709. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  710. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  711. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  712. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  713. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  714. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  715. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  716. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  717. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  718. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  719. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  720. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  721. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  722. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  723. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  724. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  725. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  726. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  727. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  728. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  729. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  730. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  731. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  732. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  733. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  734. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  735. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  736. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  737. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  738. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  739. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  740. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  741. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  742. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  743. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  744. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  745. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  746. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  747. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  748. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  749. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  750. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  751. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  752. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  753. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  754. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  755. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  756. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  757. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  758. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  759. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  760. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  761. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  762. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  763. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  764. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  765. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  766. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  767. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  768. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  769. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  770. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  771. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  772. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  773. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  774. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  775. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  776. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  777. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  778. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  779. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  780. build/lib/build/lib/build/lib/build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  781. build/lib/build/lib/build/lib/build/lib/build/lib/doc/conf.py +137 -0
  782. build/lib/build/lib/build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  783. build/lib/build/lib/build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  784. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  785. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  786. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  787. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  788. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  789. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  790. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  791. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  792. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  793. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  794. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  795. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  796. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  797. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  798. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  799. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  800. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  801. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  802. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  803. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  804. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  805. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  806. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  807. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  808. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  809. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  810. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  811. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  812. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  813. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  814. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  815. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  816. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  817. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  818. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  819. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  820. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  821. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  822. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  823. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  824. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  825. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  826. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  827. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  828. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  829. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  830. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  831. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  832. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  833. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  834. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  835. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  836. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  837. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  838. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  839. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  840. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  841. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  842. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  843. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  844. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  845. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  846. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  847. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  848. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  849. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  850. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  851. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  852. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  853. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  854. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  855. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  856. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  857. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  858. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  859. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  860. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  861. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  862. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  863. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  864. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  865. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  866. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  867. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  868. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  869. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  870. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  871. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  872. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  873. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  874. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  875. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  876. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  877. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  878. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  879. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  880. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  881. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  882. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  883. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  884. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  885. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  886. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  887. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  888. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  889. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  890. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  891. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  892. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  893. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  894. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  895. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  896. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  897. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  898. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  899. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  900. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  901. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  902. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  903. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  904. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  905. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  906. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  907. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  908. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  909. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  910. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  911. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  912. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  913. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  914. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  915. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  916. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  917. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  918. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  919. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  920. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  921. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  922. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  923. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  924. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  925. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  926. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  927. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  928. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  929. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  930. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  931. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  932. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  933. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  934. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  935. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  936. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  937. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  938. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  939. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  940. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  941. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  942. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  943. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  944. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  945. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  946. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  947. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  948. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  949. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  950. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  951. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  952. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  953. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  954. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  955. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  956. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  957. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  958. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  959. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  960. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  961. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  962. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  963. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  964. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  965. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  966. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  967. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  968. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  969. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  970. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  971. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  972. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  973. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  974. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  975. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  976. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  977. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  978. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  979. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  980. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  981. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  982. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  983. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  984. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  985. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  986. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  987. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  988. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  989. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  990. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  991. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  992. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  993. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  994. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  995. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  996. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  997. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  998. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  999. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  1000. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  1001. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  1002. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  1003. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  1004. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  1005. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  1006. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  1007. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  1008. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  1009. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  1010. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  1011. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  1012. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  1013. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  1014. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  1015. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  1016. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  1017. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  1018. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  1019. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  1020. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  1021. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  1022. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  1023. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  1024. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  1025. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  1026. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  1027. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  1028. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  1029. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  1030. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  1031. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  1032. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  1033. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  1034. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  1035. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  1036. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  1037. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  1038. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  1039. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  1040. build/lib/build/lib/build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  1041. build/lib/build/lib/build/lib/build/lib/doc/conf.py +137 -0
  1042. build/lib/build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  1043. build/lib/build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  1044. build/lib/build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  1045. build/lib/build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  1046. build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  1047. build/lib/build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  1048. build/lib/build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  1049. build/lib/build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  1050. build/lib/build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  1051. build/lib/build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  1052. build/lib/build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  1053. build/lib/build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  1054. build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  1055. build/lib/build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  1056. build/lib/build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  1057. build/lib/build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  1058. build/lib/build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  1059. build/lib/build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  1060. build/lib/build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  1061. build/lib/build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  1062. build/lib/build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  1063. build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  1064. build/lib/build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  1065. build/lib/build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  1066. build/lib/build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  1067. build/lib/build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  1068. build/lib/build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  1069. build/lib/build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  1070. build/lib/build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  1071. build/lib/build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  1072. build/lib/build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  1073. build/lib/build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  1074. build/lib/build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  1075. build/lib/build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  1076. build/lib/build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  1077. build/lib/build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  1078. build/lib/build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  1079. build/lib/build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  1080. build/lib/build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  1081. build/lib/build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  1082. build/lib/build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  1083. build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  1084. build/lib/build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  1085. build/lib/build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  1086. build/lib/build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  1087. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  1088. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  1089. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  1090. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  1091. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  1092. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  1093. build/lib/build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  1094. build/lib/build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  1095. build/lib/build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  1096. build/lib/build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  1097. build/lib/build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  1098. build/lib/build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  1099. build/lib/build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  1100. build/lib/build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  1101. build/lib/build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  1102. build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  1103. build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  1104. build/lib/build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  1105. build/lib/build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  1106. build/lib/build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  1107. build/lib/build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  1108. build/lib/build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  1109. build/lib/build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  1110. build/lib/build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  1111. build/lib/build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  1112. build/lib/build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  1113. build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  1114. build/lib/build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  1115. build/lib/build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  1116. build/lib/build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  1117. build/lib/build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  1118. build/lib/build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  1119. build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  1120. build/lib/build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  1121. build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  1122. build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  1123. build/lib/build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  1124. build/lib/build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  1125. build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  1126. build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  1127. build/lib/build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  1128. build/lib/build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  1129. build/lib/build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  1130. build/lib/build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  1131. build/lib/build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  1132. build/lib/build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  1133. build/lib/build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  1134. build/lib/build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  1135. build/lib/build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  1136. build/lib/build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  1137. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  1138. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  1139. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  1140. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  1141. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  1142. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  1143. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  1144. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  1145. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  1146. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  1147. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  1148. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  1149. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  1150. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  1151. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  1152. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  1153. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  1154. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  1155. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  1156. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  1157. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  1158. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  1159. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  1160. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  1161. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  1162. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  1163. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  1164. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  1165. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  1166. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  1167. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  1168. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  1169. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  1170. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  1171. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  1172. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  1173. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  1174. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  1175. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  1176. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  1177. build/lib/build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  1178. build/lib/build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  1179. build/lib/build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  1180. build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  1181. build/lib/build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  1182. build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  1183. build/lib/build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  1184. build/lib/build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  1185. build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  1186. build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  1187. build/lib/build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  1188. build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  1189. build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  1190. build/lib/build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  1191. build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  1192. build/lib/build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  1193. build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  1194. build/lib/build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  1195. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  1196. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  1197. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  1198. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  1199. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  1200. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  1201. build/lib/build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  1202. build/lib/build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  1203. build/lib/build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  1204. build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  1205. build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  1206. build/lib/build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  1207. build/lib/build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  1208. build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  1209. build/lib/build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  1210. build/lib/build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  1211. build/lib/build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  1212. build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  1213. build/lib/build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  1214. build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  1215. build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  1216. build/lib/build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  1217. build/lib/build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  1218. build/lib/build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  1219. build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  1220. build/lib/build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  1221. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  1222. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  1223. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  1224. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  1225. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  1226. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  1227. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  1228. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  1229. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  1230. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  1231. build/lib/build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  1232. build/lib/build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  1233. build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  1234. build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  1235. build/lib/build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  1236. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  1237. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  1238. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  1239. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  1240. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  1241. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  1242. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  1243. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  1244. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  1245. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  1246. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  1247. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  1248. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  1249. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  1250. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  1251. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  1252. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  1253. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  1254. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  1255. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  1256. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  1257. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  1258. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  1259. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  1260. build/lib/build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  1261. build/lib/build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  1262. build/lib/build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  1263. build/lib/build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  1264. build/lib/build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  1265. build/lib/build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  1266. build/lib/build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  1267. build/lib/build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  1268. build/lib/build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  1269. build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  1270. build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  1271. build/lib/build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  1272. build/lib/build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  1273. build/lib/build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  1274. build/lib/build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  1275. build/lib/build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  1276. build/lib/build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  1277. build/lib/build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  1278. build/lib/build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  1279. build/lib/build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  1280. build/lib/build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  1281. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  1282. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  1283. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  1284. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  1285. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  1286. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  1287. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  1288. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  1289. build/lib/build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  1290. build/lib/build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  1291. build/lib/build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  1292. build/lib/build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  1293. build/lib/build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  1294. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  1295. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  1296. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  1297. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  1298. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  1299. build/lib/build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  1300. build/lib/build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  1301. build/lib/build/lib/build/lib/doc/conf.py +137 -0
  1302. build/lib/build/lib/build/lib/doc/create_conf_doc.py +38 -0
  1303. build/lib/build/lib/build/lib/doc/get_mathjax.py +34 -0
  1304. build/lib/build/lib/build/lib/nabu/__init__.py +17 -0
  1305. build/lib/build/lib/build/lib/nabu/app/__init__.py +0 -0
  1306. build/lib/build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  1307. build/lib/build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  1308. build/lib/build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  1309. build/lib/build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  1310. build/lib/build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  1311. build/lib/build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  1312. build/lib/build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  1313. build/lib/build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  1314. build/lib/build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  1315. build/lib/build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  1316. build/lib/build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  1317. build/lib/build/lib/build/lib/nabu/app/generate_header.py +261 -0
  1318. build/lib/build/lib/build/lib/nabu/app/histogram.py +197 -0
  1319. build/lib/build/lib/build/lib/nabu/app/multicor.py +90 -0
  1320. build/lib/build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  1321. build/lib/build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  1322. build/lib/build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  1323. build/lib/build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  1324. build/lib/build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  1325. build/lib/build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  1326. build/lib/build/lib/build/lib/nabu/app/rotate.py +162 -0
  1327. build/lib/build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  1328. build/lib/build/lib/build/lib/nabu/app/stitching.py +85 -0
  1329. build/lib/build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  1330. build/lib/build/lib/build/lib/nabu/app/utils.py +33 -0
  1331. build/lib/build/lib/build/lib/nabu/app/validator.py +110 -0
  1332. build/lib/build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  1333. build/lib/build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  1334. build/lib/build/lib/build/lib/nabu/cuda/fft.py +4 -0
  1335. build/lib/build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  1336. build/lib/build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  1337. build/lib/build/lib/build/lib/nabu/cuda/padding.py +6 -0
  1338. build/lib/build/lib/build/lib/nabu/cuda/processing.py +75 -0
  1339. build/lib/build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  1340. build/lib/build/lib/build/lib/nabu/cuda/utils.py +331 -0
  1341. build/lib/build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  1342. build/lib/build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  1343. build/lib/build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  1344. build/lib/build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  1345. build/lib/build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  1346. build/lib/build/lib/build/lib/nabu/estimation/focus.py +362 -0
  1347. build/lib/build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  1348. build/lib/build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  1349. build/lib/build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  1350. build/lib/build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  1351. build/lib/build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  1352. build/lib/build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  1353. build/lib/build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  1354. build/lib/build/lib/build/lib/nabu/estimation/translation.py +193 -0
  1355. build/lib/build/lib/build/lib/nabu/estimation/utils.py +39 -0
  1356. build/lib/build/lib/build/lib/nabu/io/__init__.py +2 -0
  1357. build/lib/build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  1358. build/lib/build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  1359. build/lib/build/lib/build/lib/nabu/io/reader.py +628 -0
  1360. build/lib/build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  1361. build/lib/build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  1362. build/lib/build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  1363. build/lib/build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  1364. build/lib/build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  1365. build/lib/build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  1366. build/lib/build/lib/build/lib/nabu/io/utils.py +263 -0
  1367. build/lib/build/lib/build/lib/nabu/io/writer.py +892 -0
  1368. build/lib/build/lib/build/lib/nabu/misc/__init__.py +0 -0
  1369. build/lib/build/lib/build/lib/nabu/misc/binning.py +98 -0
  1370. build/lib/build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  1371. build/lib/build/lib/build/lib/nabu/misc/filters.py +24 -0
  1372. build/lib/build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  1373. build/lib/build/lib/build/lib/nabu/misc/histogram.py +6 -0
  1374. build/lib/build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  1375. build/lib/build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  1376. build/lib/build/lib/build/lib/nabu/misc/padding.py +83 -0
  1377. build/lib/build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  1378. build/lib/build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  1379. build/lib/build/lib/build/lib/nabu/misc/rotation.py +6 -0
  1380. build/lib/build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  1381. build/lib/build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  1382. build/lib/build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  1383. build/lib/build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  1384. build/lib/build/lib/build/lib/nabu/misc/transpose.py +6 -0
  1385. build/lib/build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  1386. build/lib/build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  1387. build/lib/build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  1388. build/lib/build/lib/build/lib/nabu/misc/utils.py +117 -0
  1389. build/lib/build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  1390. build/lib/build/lib/build/lib/nabu/opencl/fft.py +6 -0
  1391. build/lib/build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  1392. build/lib/build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  1393. build/lib/build/lib/build/lib/nabu/opencl/padding.py +6 -0
  1394. build/lib/build/lib/build/lib/nabu/opencl/processing.py +62 -0
  1395. build/lib/build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  1396. build/lib/build/lib/build/lib/nabu/opencl/utils.py +292 -0
  1397. build/lib/build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  1398. build/lib/build/lib/build/lib/nabu/pipeline/config.py +265 -0
  1399. build/lib/build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  1400. build/lib/build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  1401. build/lib/build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  1402. build/lib/build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  1403. build/lib/build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  1404. build/lib/build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  1405. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  1406. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  1407. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  1408. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  1409. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  1410. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  1411. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  1412. build/lib/build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  1413. build/lib/build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  1414. build/lib/build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  1415. build/lib/build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  1416. build/lib/build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  1417. build/lib/build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  1418. build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  1419. build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  1420. build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  1421. build/lib/build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  1422. build/lib/build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  1423. build/lib/build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  1424. build/lib/build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  1425. build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  1426. build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  1427. build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  1428. build/lib/build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  1429. build/lib/build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  1430. build/lib/build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  1431. build/lib/build/lib/build/lib/nabu/pipeline/params.py +163 -0
  1432. build/lib/build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  1433. build/lib/build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  1434. build/lib/build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  1435. build/lib/build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  1436. build/lib/build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  1437. build/lib/build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  1438. build/lib/build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  1439. build/lib/build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  1440. build/lib/build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  1441. build/lib/build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  1442. build/lib/build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  1443. build/lib/build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  1444. build/lib/build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  1445. build/lib/build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  1446. build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  1447. build/lib/build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  1448. build/lib/build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  1449. build/lib/build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  1450. build/lib/build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  1451. build/lib/build/lib/build/lib/nabu/preproc/phase.py +425 -0
  1452. build/lib/build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  1453. build/lib/build/lib/build/lib/nabu/preproc/shift.py +95 -0
  1454. build/lib/build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  1455. build/lib/build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  1456. build/lib/build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  1457. build/lib/build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  1458. build/lib/build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  1459. build/lib/build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  1460. build/lib/build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  1461. build/lib/build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  1462. build/lib/build/lib/build/lib/nabu/processing/__init__.py +0 -0
  1463. build/lib/build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  1464. build/lib/build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  1465. build/lib/build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  1466. build/lib/build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  1467. build/lib/build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  1468. build/lib/build/lib/build/lib/nabu/processing/histogram.py +286 -0
  1469. build/lib/build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  1470. build/lib/build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  1471. build/lib/build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  1472. build/lib/build/lib/build/lib/nabu/processing/muladd.py +29 -0
  1473. build/lib/build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  1474. build/lib/build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  1475. build/lib/build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  1476. build/lib/build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  1477. build/lib/build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  1478. build/lib/build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  1479. build/lib/build/lib/build/lib/nabu/processing/rotation.py +63 -0
  1480. build/lib/build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  1481. build/lib/build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  1482. build/lib/build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  1483. build/lib/build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  1484. build/lib/build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  1485. build/lib/build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  1486. build/lib/build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  1487. build/lib/build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  1488. build/lib/build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  1489. build/lib/build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  1490. build/lib/build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  1491. build/lib/build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  1492. build/lib/build/lib/build/lib/nabu/processing/transpose.py +126 -0
  1493. build/lib/build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  1494. build/lib/build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  1495. build/lib/build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  1496. build/lib/build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  1497. build/lib/build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  1498. build/lib/build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  1499. build/lib/build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  1500. build/lib/build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  1501. build/lib/build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  1502. build/lib/build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  1503. build/lib/build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  1504. build/lib/build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  1505. build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  1506. build/lib/build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  1507. build/lib/build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  1508. build/lib/build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  1509. build/lib/build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  1510. build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  1511. build/lib/build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  1512. build/lib/build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  1513. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  1514. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  1515. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  1516. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  1517. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  1518. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  1519. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  1520. build/lib/build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  1521. build/lib/build/lib/build/lib/nabu/resources/__init__.py +0 -0
  1522. build/lib/build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  1523. build/lib/build/lib/build/lib/nabu/resources/cor.py +5 -0
  1524. build/lib/build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  1525. build/lib/build/lib/build/lib/nabu/resources/gpu.py +169 -0
  1526. build/lib/build/lib/build/lib/nabu/resources/logger.py +130 -0
  1527. build/lib/build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  1528. build/lib/build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  1529. build/lib/build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  1530. build/lib/build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  1531. build/lib/build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  1532. build/lib/build/lib/build/lib/nabu/resources/utils.py +174 -0
  1533. build/lib/build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  1534. build/lib/build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  1535. build/lib/build/lib/build/lib/nabu/stitching/config.py +1286 -0
  1536. build/lib/build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  1537. build/lib/build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  1538. build/lib/build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  1539. build/lib/build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  1540. build/lib/build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  1541. build/lib/build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  1542. build/lib/build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  1543. build/lib/build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  1544. build/lib/build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  1545. build/lib/build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  1546. build/lib/build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  1547. build/lib/build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  1548. build/lib/build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  1549. build/lib/build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  1550. build/lib/build/lib/build/lib/nabu/stitching/utils.py +563 -0
  1551. build/lib/build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  1552. build/lib/build/lib/build/lib/nabu/tests.py +51 -0
  1553. build/lib/build/lib/build/lib/nabu/testutils.py +375 -0
  1554. build/lib/build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  1555. build/lib/build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  1556. build/lib/build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  1557. build/lib/build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  1558. build/lib/build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  1559. build/lib/build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  1560. build/lib/build/lib/build/lib/nabu/utils.py +836 -0
  1561. build/lib/build/lib/doc/conf.py +137 -0
  1562. build/lib/build/lib/doc/create_conf_doc.py +38 -0
  1563. build/lib/build/lib/doc/get_mathjax.py +34 -0
  1564. build/lib/build/lib/nabu/__init__.py +17 -0
  1565. build/lib/build/lib/nabu/app/__init__.py +0 -0
  1566. build/lib/build/lib/nabu/app/bootstrap.py +88 -0
  1567. build/lib/build/lib/nabu/app/bootstrap_stitching.py +69 -0
  1568. build/lib/build/lib/nabu/app/cast_volume.py +272 -0
  1569. build/lib/build/lib/nabu/app/cli_configs.py +626 -0
  1570. build/lib/build/lib/nabu/app/compare_volumes.py +94 -0
  1571. build/lib/build/lib/nabu/app/composite_cor.py +144 -0
  1572. build/lib/build/lib/nabu/app/correct_rot.py +70 -0
  1573. build/lib/build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  1574. build/lib/build/lib/nabu/app/diag_to_pix.py +358 -0
  1575. build/lib/build/lib/nabu/app/diag_to_rot.py +449 -0
  1576. build/lib/build/lib/nabu/app/double_flatfield.py +143 -0
  1577. build/lib/build/lib/nabu/app/generate_header.py +261 -0
  1578. build/lib/build/lib/nabu/app/histogram.py +197 -0
  1579. build/lib/build/lib/nabu/app/multicor.py +90 -0
  1580. build/lib/build/lib/nabu/app/nx_z_splitter.py +125 -0
  1581. build/lib/build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  1582. build/lib/build/lib/nabu/app/prepare_weights_double.py +163 -0
  1583. build/lib/build/lib/nabu/app/reconstruct.py +120 -0
  1584. build/lib/build/lib/nabu/app/reconstruct_helical.py +116 -0
  1585. build/lib/build/lib/nabu/app/reduce_dark_flat.py +181 -0
  1586. build/lib/build/lib/nabu/app/rotate.py +162 -0
  1587. build/lib/build/lib/nabu/app/shrink_dataset.py +98 -0
  1588. build/lib/build/lib/nabu/app/stitching.py +85 -0
  1589. build/lib/build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  1590. build/lib/build/lib/nabu/app/utils.py +33 -0
  1591. build/lib/build/lib/nabu/app/validator.py +110 -0
  1592. build/lib/build/lib/nabu/cuda/__init__.py +0 -0
  1593. build/lib/build/lib/nabu/cuda/convolution.py +8 -0
  1594. build/lib/build/lib/nabu/cuda/fft.py +4 -0
  1595. build/lib/build/lib/nabu/cuda/kernel.py +97 -0
  1596. build/lib/build/lib/nabu/cuda/medfilt.py +6 -0
  1597. build/lib/build/lib/nabu/cuda/padding.py +6 -0
  1598. build/lib/build/lib/nabu/cuda/processing.py +75 -0
  1599. build/lib/build/lib/nabu/cuda/tests/__init__.py +1 -0
  1600. build/lib/build/lib/nabu/cuda/utils.py +331 -0
  1601. build/lib/build/lib/nabu/estimation/__init__.py +12 -0
  1602. build/lib/build/lib/nabu/estimation/alignment.py +578 -0
  1603. build/lib/build/lib/nabu/estimation/cor.py +1621 -0
  1604. build/lib/build/lib/nabu/estimation/cor_sino.py +183 -0
  1605. build/lib/build/lib/nabu/estimation/distortion.py +112 -0
  1606. build/lib/build/lib/nabu/estimation/focus.py +362 -0
  1607. build/lib/build/lib/nabu/estimation/tests/__init__.py +0 -0
  1608. build/lib/build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  1609. build/lib/build/lib/nabu/estimation/tests/test_cor.py +472 -0
  1610. build/lib/build/lib/nabu/estimation/tests/test_focus.py +105 -0
  1611. build/lib/build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  1612. build/lib/build/lib/nabu/estimation/tests/test_translation.py +78 -0
  1613. build/lib/build/lib/nabu/estimation/tilt.py +214 -0
  1614. build/lib/build/lib/nabu/estimation/translation.py +193 -0
  1615. build/lib/build/lib/nabu/estimation/utils.py +39 -0
  1616. build/lib/build/lib/nabu/io/__init__.py +2 -0
  1617. build/lib/build/lib/nabu/io/cast_volume.py +371 -0
  1618. build/lib/build/lib/nabu/io/detector_distortion.py +305 -0
  1619. build/lib/build/lib/nabu/io/reader.py +628 -0
  1620. build/lib/build/lib/nabu/io/reader_helical.py +114 -0
  1621. build/lib/build/lib/nabu/io/tests/__init__.py +0 -0
  1622. build/lib/build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  1623. build/lib/build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  1624. build/lib/build/lib/nabu/io/tests/test_writers.py +187 -0
  1625. build/lib/build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  1626. build/lib/build/lib/nabu/io/utils.py +263 -0
  1627. build/lib/build/lib/nabu/io/writer.py +892 -0
  1628. build/lib/build/lib/nabu/misc/__init__.py +0 -0
  1629. build/lib/build/lib/nabu/misc/binning.py +98 -0
  1630. build/lib/build/lib/nabu/misc/fftshift.py +6 -0
  1631. build/lib/build/lib/nabu/misc/filters.py +24 -0
  1632. build/lib/build/lib/nabu/misc/fourier_filters.py +152 -0
  1633. build/lib/build/lib/nabu/misc/histogram.py +6 -0
  1634. build/lib/build/lib/nabu/misc/histogram_cuda.py +8 -0
  1635. build/lib/build/lib/nabu/misc/kernel_base.py +4 -0
  1636. build/lib/build/lib/nabu/misc/padding.py +83 -0
  1637. build/lib/build/lib/nabu/misc/padding_base.py +6 -0
  1638. build/lib/build/lib/nabu/misc/processing_base.py +4 -0
  1639. build/lib/build/lib/nabu/misc/rotation.py +6 -0
  1640. build/lib/build/lib/nabu/misc/rotation_cuda.py +6 -0
  1641. build/lib/build/lib/nabu/misc/tests/__init__.py +1 -0
  1642. build/lib/build/lib/nabu/misc/tests/test_binning.py +48 -0
  1643. build/lib/build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  1644. build/lib/build/lib/nabu/misc/transpose.py +6 -0
  1645. build/lib/build/lib/nabu/misc/unsharp.py +4 -0
  1646. build/lib/build/lib/nabu/misc/unsharp_cuda.py +6 -0
  1647. build/lib/build/lib/nabu/misc/unsharp_opencl.py +8 -0
  1648. build/lib/build/lib/nabu/misc/utils.py +117 -0
  1649. build/lib/build/lib/nabu/opencl/__init__.py +0 -0
  1650. build/lib/build/lib/nabu/opencl/fft.py +6 -0
  1651. build/lib/build/lib/nabu/opencl/kernel.py +135 -0
  1652. build/lib/build/lib/nabu/opencl/memcpy.py +35 -0
  1653. build/lib/build/lib/nabu/opencl/padding.py +6 -0
  1654. build/lib/build/lib/nabu/opencl/processing.py +62 -0
  1655. build/lib/build/lib/nabu/opencl/tests/__init__.py +0 -0
  1656. build/lib/build/lib/nabu/opencl/utils.py +292 -0
  1657. build/lib/build/lib/nabu/pipeline/__init__.py +0 -0
  1658. build/lib/build/lib/nabu/pipeline/config.py +265 -0
  1659. build/lib/build/lib/nabu/pipeline/config_validators.py +589 -0
  1660. build/lib/build/lib/nabu/pipeline/datadump.py +164 -0
  1661. build/lib/build/lib/nabu/pipeline/dataset_validator.py +211 -0
  1662. build/lib/build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  1663. build/lib/build/lib/nabu/pipeline/estimators.py +1012 -0
  1664. build/lib/build/lib/nabu/pipeline/fallback_utils.py +149 -0
  1665. build/lib/build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  1666. build/lib/build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  1667. build/lib/build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  1668. build/lib/build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  1669. build/lib/build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  1670. build/lib/build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  1671. build/lib/build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  1672. build/lib/build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  1673. build/lib/build/lib/nabu/pipeline/helical/__init__.py +0 -0
  1674. build/lib/build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  1675. build/lib/build/lib/nabu/pipeline/helical/fbp.py +147 -0
  1676. build/lib/build/lib/nabu/pipeline/helical/filtering.py +246 -0
  1677. build/lib/build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  1678. build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  1679. build/lib/build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  1680. build/lib/build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  1681. build/lib/build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  1682. build/lib/build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  1683. build/lib/build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  1684. build/lib/build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  1685. build/lib/build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  1686. build/lib/build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  1687. build/lib/build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  1688. build/lib/build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  1689. build/lib/build/lib/nabu/pipeline/helical/utils.py +51 -0
  1690. build/lib/build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  1691. build/lib/build/lib/nabu/pipeline/params.py +163 -0
  1692. build/lib/build/lib/nabu/pipeline/processconfig.py +210 -0
  1693. build/lib/build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  1694. build/lib/build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  1695. build/lib/build/lib/nabu/pipeline/utils.py +116 -0
  1696. build/lib/build/lib/nabu/pipeline/writer.py +193 -0
  1697. build/lib/build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  1698. build/lib/build/lib/nabu/preproc/__init__.py +7 -0
  1699. build/lib/build/lib/nabu/preproc/alignment.py +11 -0
  1700. build/lib/build/lib/nabu/preproc/ccd.py +161 -0
  1701. build/lib/build/lib/nabu/preproc/ccd_cuda.py +169 -0
  1702. build/lib/build/lib/nabu/preproc/ctf.py +361 -0
  1703. build/lib/build/lib/nabu/preproc/ctf_cuda.py +142 -0
  1704. build/lib/build/lib/nabu/preproc/distortion.py +92 -0
  1705. build/lib/build/lib/nabu/preproc/double_flatfield.py +212 -0
  1706. build/lib/build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  1707. build/lib/build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  1708. build/lib/build/lib/nabu/preproc/flatfield.py +448 -0
  1709. build/lib/build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  1710. build/lib/build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  1711. build/lib/build/lib/nabu/preproc/phase.py +425 -0
  1712. build/lib/build/lib/nabu/preproc/phase_cuda.py +143 -0
  1713. build/lib/build/lib/nabu/preproc/shift.py +95 -0
  1714. build/lib/build/lib/nabu/preproc/shift_cuda.py +102 -0
  1715. build/lib/build/lib/nabu/preproc/tests/__init__.py +1 -0
  1716. build/lib/build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  1717. build/lib/build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  1718. build/lib/build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  1719. build/lib/build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  1720. build/lib/build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  1721. build/lib/build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  1722. build/lib/build/lib/nabu/processing/__init__.py +0 -0
  1723. build/lib/build/lib/nabu/processing/convolution_cuda.py +375 -0
  1724. build/lib/build/lib/nabu/processing/fft_base.py +163 -0
  1725. build/lib/build/lib/nabu/processing/fft_cuda.py +256 -0
  1726. build/lib/build/lib/nabu/processing/fft_opencl.py +54 -0
  1727. build/lib/build/lib/nabu/processing/fftshift.py +134 -0
  1728. build/lib/build/lib/nabu/processing/histogram.py +286 -0
  1729. build/lib/build/lib/nabu/processing/histogram_cuda.py +103 -0
  1730. build/lib/build/lib/nabu/processing/kernel_base.py +126 -0
  1731. build/lib/build/lib/nabu/processing/medfilt_cuda.py +159 -0
  1732. build/lib/build/lib/nabu/processing/muladd.py +29 -0
  1733. build/lib/build/lib/nabu/processing/muladd_cuda.py +68 -0
  1734. build/lib/build/lib/nabu/processing/padding_base.py +71 -0
  1735. build/lib/build/lib/nabu/processing/padding_cuda.py +75 -0
  1736. build/lib/build/lib/nabu/processing/padding_opencl.py +77 -0
  1737. build/lib/build/lib/nabu/processing/processing_base.py +123 -0
  1738. build/lib/build/lib/nabu/processing/roll_opencl.py +64 -0
  1739. build/lib/build/lib/nabu/processing/rotation.py +63 -0
  1740. build/lib/build/lib/nabu/processing/rotation_cuda.py +66 -0
  1741. build/lib/build/lib/nabu/processing/tests/__init__.py +0 -0
  1742. build/lib/build/lib/nabu/processing/tests/test_fft.py +268 -0
  1743. build/lib/build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  1744. build/lib/build/lib/nabu/processing/tests/test_histogram.py +55 -0
  1745. build/lib/build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  1746. build/lib/build/lib/nabu/processing/tests/test_muladd.py +54 -0
  1747. build/lib/build/lib/nabu/processing/tests/test_padding.py +247 -0
  1748. build/lib/build/lib/nabu/processing/tests/test_roll.py +63 -0
  1749. build/lib/build/lib/nabu/processing/tests/test_rotation.py +83 -0
  1750. build/lib/build/lib/nabu/processing/tests/test_transpose.py +72 -0
  1751. build/lib/build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  1752. build/lib/build/lib/nabu/processing/transpose.py +126 -0
  1753. build/lib/build/lib/nabu/processing/unsharp.py +79 -0
  1754. build/lib/build/lib/nabu/processing/unsharp_cuda.py +53 -0
  1755. build/lib/build/lib/nabu/processing/unsharp_opencl.py +75 -0
  1756. build/lib/build/lib/nabu/reconstruction/__init__.py +3 -0
  1757. build/lib/build/lib/nabu/reconstruction/cone.py +241 -0
  1758. build/lib/build/lib/nabu/reconstruction/fbp.py +124 -0
  1759. build/lib/build/lib/nabu/reconstruction/fbp_base.py +391 -0
  1760. build/lib/build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  1761. build/lib/build/lib/nabu/reconstruction/filtering.py +220 -0
  1762. build/lib/build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  1763. build/lib/build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  1764. build/lib/build/lib/nabu/reconstruction/projection.py +240 -0
  1765. build/lib/build/lib/nabu/reconstruction/reconstructor.py +174 -0
  1766. build/lib/build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  1767. build/lib/build/lib/nabu/reconstruction/rings.py +248 -0
  1768. build/lib/build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  1769. build/lib/build/lib/nabu/reconstruction/sinogram.py +467 -0
  1770. build/lib/build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  1771. build/lib/build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  1772. build/lib/build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  1773. build/lib/build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  1774. build/lib/build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  1775. build/lib/build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  1776. build/lib/build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  1777. build/lib/build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  1778. build/lib/build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  1779. build/lib/build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  1780. build/lib/build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  1781. build/lib/build/lib/nabu/resources/__init__.py +0 -0
  1782. build/lib/build/lib/nabu/resources/cli/__init__.py +0 -0
  1783. build/lib/build/lib/nabu/resources/cor.py +5 -0
  1784. build/lib/build/lib/nabu/resources/dataset_analyzer.py +469 -0
  1785. build/lib/build/lib/nabu/resources/gpu.py +169 -0
  1786. build/lib/build/lib/nabu/resources/logger.py +130 -0
  1787. build/lib/build/lib/nabu/resources/nxflatfield.py +217 -0
  1788. build/lib/build/lib/nabu/resources/templates/__init__.py +0 -0
  1789. build/lib/build/lib/nabu/resources/tests/__init__.py +0 -0
  1790. build/lib/build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  1791. build/lib/build/lib/nabu/resources/tests/test_units.py +47 -0
  1792. build/lib/build/lib/nabu/resources/utils.py +174 -0
  1793. build/lib/build/lib/nabu/stitching/__init__.py +0 -0
  1794. build/lib/build/lib/nabu/stitching/alignment.py +184 -0
  1795. build/lib/build/lib/nabu/stitching/config.py +1286 -0
  1796. build/lib/build/lib/nabu/stitching/definitions.py +6 -0
  1797. build/lib/build/lib/nabu/stitching/frame_composition.py +155 -0
  1798. build/lib/build/lib/nabu/stitching/overlap.py +373 -0
  1799. build/lib/build/lib/nabu/stitching/sample_normalization.py +60 -0
  1800. build/lib/build/lib/nabu/stitching/slurm_utils.py +204 -0
  1801. build/lib/build/lib/nabu/stitching/tests/__init__.py +0 -0
  1802. build/lib/build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  1803. build/lib/build/lib/nabu/stitching/tests/test_config.py +226 -0
  1804. build/lib/build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  1805. build/lib/build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  1806. build/lib/build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  1807. build/lib/build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  1808. build/lib/build/lib/nabu/stitching/tests/test_utils.py +21 -0
  1809. build/lib/build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  1810. build/lib/build/lib/nabu/stitching/utils.py +563 -0
  1811. build/lib/build/lib/nabu/stitching/z_stitching.py +2279 -0
  1812. build/lib/build/lib/nabu/tests.py +51 -0
  1813. build/lib/build/lib/nabu/testutils.py +375 -0
  1814. build/lib/build/lib/nabu/thirdparty/__init__.py +0 -0
  1815. build/lib/build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  1816. build/lib/build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  1817. build/lib/build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  1818. build/lib/build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  1819. build/lib/build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  1820. build/lib/build/lib/nabu/utils.py +836 -0
  1821. build/lib/doc/conf.py +137 -0
  1822. build/lib/doc/create_conf_doc.py +38 -0
  1823. build/lib/doc/get_mathjax.py +34 -0
  1824. build/lib/nabu/__init__.py +17 -0
  1825. build/lib/nabu/app/__init__.py +0 -0
  1826. build/lib/nabu/app/bootstrap.py +88 -0
  1827. build/lib/nabu/app/bootstrap_stitching.py +69 -0
  1828. build/lib/nabu/app/cast_volume.py +272 -0
  1829. build/lib/nabu/app/cli_configs.py +626 -0
  1830. build/lib/nabu/app/compare_volumes.py +94 -0
  1831. build/lib/nabu/app/composite_cor.py +144 -0
  1832. build/lib/nabu/app/correct_rot.py +70 -0
  1833. build/lib/nabu/app/create_distortion_map_from_poly.py +153 -0
  1834. build/lib/nabu/app/diag_to_pix.py +358 -0
  1835. build/lib/nabu/app/diag_to_rot.py +449 -0
  1836. build/lib/nabu/app/double_flatfield.py +143 -0
  1837. build/lib/nabu/app/generate_header.py +261 -0
  1838. build/lib/nabu/app/histogram.py +197 -0
  1839. build/lib/nabu/app/multicor.py +90 -0
  1840. build/lib/nabu/app/nx_z_splitter.py +125 -0
  1841. build/lib/nabu/app/parse_reconstruction_log.py +151 -0
  1842. build/lib/nabu/app/prepare_weights_double.py +163 -0
  1843. build/lib/nabu/app/reconstruct.py +120 -0
  1844. build/lib/nabu/app/reconstruct_helical.py +116 -0
  1845. build/lib/nabu/app/reduce_dark_flat.py +181 -0
  1846. build/lib/nabu/app/rotate.py +162 -0
  1847. build/lib/nabu/app/shrink_dataset.py +98 -0
  1848. build/lib/nabu/app/stitching.py +85 -0
  1849. build/lib/nabu/app/tests/test_reduce_dark_flat.py +78 -0
  1850. build/lib/nabu/app/utils.py +33 -0
  1851. build/lib/nabu/app/validator.py +110 -0
  1852. build/lib/nabu/cuda/__init__.py +0 -0
  1853. build/lib/nabu/cuda/convolution.py +8 -0
  1854. build/lib/nabu/cuda/fft.py +4 -0
  1855. build/lib/nabu/cuda/kernel.py +97 -0
  1856. build/lib/nabu/cuda/medfilt.py +6 -0
  1857. build/lib/nabu/cuda/padding.py +6 -0
  1858. build/lib/nabu/cuda/processing.py +75 -0
  1859. build/lib/nabu/cuda/tests/__init__.py +1 -0
  1860. build/lib/nabu/cuda/utils.py +331 -0
  1861. build/lib/nabu/estimation/__init__.py +12 -0
  1862. build/lib/nabu/estimation/alignment.py +578 -0
  1863. build/lib/nabu/estimation/cor.py +1621 -0
  1864. build/lib/nabu/estimation/cor_sino.py +183 -0
  1865. build/lib/nabu/estimation/distortion.py +112 -0
  1866. build/lib/nabu/estimation/focus.py +362 -0
  1867. build/lib/nabu/estimation/tests/__init__.py +0 -0
  1868. build/lib/nabu/estimation/tests/test_alignment.py +70 -0
  1869. build/lib/nabu/estimation/tests/test_cor.py +472 -0
  1870. build/lib/nabu/estimation/tests/test_focus.py +105 -0
  1871. build/lib/nabu/estimation/tests/test_tilt.py +41 -0
  1872. build/lib/nabu/estimation/tests/test_translation.py +78 -0
  1873. build/lib/nabu/estimation/tilt.py +214 -0
  1874. build/lib/nabu/estimation/translation.py +193 -0
  1875. build/lib/nabu/estimation/utils.py +39 -0
  1876. build/lib/nabu/io/__init__.py +2 -0
  1877. build/lib/nabu/io/cast_volume.py +371 -0
  1878. build/lib/nabu/io/detector_distortion.py +305 -0
  1879. build/lib/nabu/io/reader.py +628 -0
  1880. build/lib/nabu/io/reader_helical.py +114 -0
  1881. build/lib/nabu/io/tests/__init__.py +0 -0
  1882. build/lib/nabu/io/tests/test_cast_volume.py +339 -0
  1883. build/lib/nabu/io/tests/test_detector_distortion.py +178 -0
  1884. build/lib/nabu/io/tests/test_writers.py +187 -0
  1885. build/lib/nabu/io/tiffwriter_zmm.py +99 -0
  1886. build/lib/nabu/io/utils.py +263 -0
  1887. build/lib/nabu/io/writer.py +892 -0
  1888. build/lib/nabu/misc/__init__.py +0 -0
  1889. build/lib/nabu/misc/binning.py +98 -0
  1890. build/lib/nabu/misc/fftshift.py +6 -0
  1891. build/lib/nabu/misc/filters.py +24 -0
  1892. build/lib/nabu/misc/fourier_filters.py +152 -0
  1893. build/lib/nabu/misc/histogram.py +6 -0
  1894. build/lib/nabu/misc/histogram_cuda.py +8 -0
  1895. build/lib/nabu/misc/kernel_base.py +4 -0
  1896. build/lib/nabu/misc/padding.py +83 -0
  1897. build/lib/nabu/misc/padding_base.py +6 -0
  1898. build/lib/nabu/misc/processing_base.py +4 -0
  1899. build/lib/nabu/misc/rotation.py +6 -0
  1900. build/lib/nabu/misc/rotation_cuda.py +6 -0
  1901. build/lib/nabu/misc/tests/__init__.py +1 -0
  1902. build/lib/nabu/misc/tests/test_binning.py +48 -0
  1903. build/lib/nabu/misc/tests/test_interpolation.py +70 -0
  1904. build/lib/nabu/misc/transpose.py +6 -0
  1905. build/lib/nabu/misc/unsharp.py +4 -0
  1906. build/lib/nabu/misc/unsharp_cuda.py +6 -0
  1907. build/lib/nabu/misc/unsharp_opencl.py +8 -0
  1908. build/lib/nabu/misc/utils.py +117 -0
  1909. build/lib/nabu/opencl/__init__.py +0 -0
  1910. build/lib/nabu/opencl/fft.py +6 -0
  1911. build/lib/nabu/opencl/kernel.py +135 -0
  1912. build/lib/nabu/opencl/memcpy.py +35 -0
  1913. build/lib/nabu/opencl/padding.py +6 -0
  1914. build/lib/nabu/opencl/processing.py +62 -0
  1915. build/lib/nabu/opencl/tests/__init__.py +0 -0
  1916. build/lib/nabu/opencl/utils.py +292 -0
  1917. build/lib/nabu/pipeline/__init__.py +0 -0
  1918. build/lib/nabu/pipeline/config.py +265 -0
  1919. build/lib/nabu/pipeline/config_validators.py +589 -0
  1920. build/lib/nabu/pipeline/datadump.py +164 -0
  1921. build/lib/nabu/pipeline/dataset_validator.py +211 -0
  1922. build/lib/nabu/pipeline/detector_distortion_provider.py +20 -0
  1923. build/lib/nabu/pipeline/estimators.py +1012 -0
  1924. build/lib/nabu/pipeline/fallback_utils.py +149 -0
  1925. build/lib/nabu/pipeline/fullfield/__init__.py +0 -0
  1926. build/lib/nabu/pipeline/fullfield/chunked.py +849 -0
  1927. build/lib/nabu/pipeline/fullfield/chunked_cuda.py +152 -0
  1928. build/lib/nabu/pipeline/fullfield/computations.py +260 -0
  1929. build/lib/nabu/pipeline/fullfield/dataset_validator.py +63 -0
  1930. build/lib/nabu/pipeline/fullfield/nabu_config.py +590 -0
  1931. build/lib/nabu/pipeline/fullfield/processconfig.py +825 -0
  1932. build/lib/nabu/pipeline/fullfield/reconstruction.py +851 -0
  1933. build/lib/nabu/pipeline/helical/__init__.py +0 -0
  1934. build/lib/nabu/pipeline/helical/dataset_validator.py +19 -0
  1935. build/lib/nabu/pipeline/helical/fbp.py +147 -0
  1936. build/lib/nabu/pipeline/helical/filtering.py +246 -0
  1937. build/lib/nabu/pipeline/helical/gridded_accumulator.py +575 -0
  1938. build/lib/nabu/pipeline/helical/helical_chunked_regridded.py +1670 -0
  1939. build/lib/nabu/pipeline/helical/helical_chunked_regridded_cuda.py +119 -0
  1940. build/lib/nabu/pipeline/helical/helical_reconstruction.py +598 -0
  1941. build/lib/nabu/pipeline/helical/helical_utils.py +42 -0
  1942. build/lib/nabu/pipeline/helical/nabu_config.py +175 -0
  1943. build/lib/nabu/pipeline/helical/processconfig.py +62 -0
  1944. build/lib/nabu/pipeline/helical/span_strategy.py +483 -0
  1945. build/lib/nabu/pipeline/helical/tests/__init__.py +0 -0
  1946. build/lib/nabu/pipeline/helical/tests/test_accumulator.py +157 -0
  1947. build/lib/nabu/pipeline/helical/tests/test_pipeline_elements_full.py +355 -0
  1948. build/lib/nabu/pipeline/helical/tests/test_strategy.py +61 -0
  1949. build/lib/nabu/pipeline/helical/utils.py +51 -0
  1950. build/lib/nabu/pipeline/helical/weight_balancer.py +101 -0
  1951. build/lib/nabu/pipeline/params.py +163 -0
  1952. build/lib/nabu/pipeline/processconfig.py +210 -0
  1953. build/lib/nabu/pipeline/tests/test_chunk_reader.py +78 -0
  1954. build/lib/nabu/pipeline/tests/test_estimators.py +149 -0
  1955. build/lib/nabu/pipeline/utils.py +116 -0
  1956. build/lib/nabu/pipeline/writer.py +193 -0
  1957. build/lib/nabu/pipeline/xrdct/__init__.py +0 -0
  1958. build/lib/nabu/preproc/__init__.py +7 -0
  1959. build/lib/nabu/preproc/alignment.py +11 -0
  1960. build/lib/nabu/preproc/ccd.py +161 -0
  1961. build/lib/nabu/preproc/ccd_cuda.py +169 -0
  1962. build/lib/nabu/preproc/ctf.py +361 -0
  1963. build/lib/nabu/preproc/ctf_cuda.py +142 -0
  1964. build/lib/nabu/preproc/distortion.py +92 -0
  1965. build/lib/nabu/preproc/double_flatfield.py +212 -0
  1966. build/lib/nabu/preproc/double_flatfield_cuda.py +174 -0
  1967. build/lib/nabu/preproc/double_flatfield_variable_region.py +68 -0
  1968. build/lib/nabu/preproc/flatfield.py +448 -0
  1969. build/lib/nabu/preproc/flatfield_cuda.py +144 -0
  1970. build/lib/nabu/preproc/flatfield_variable_region.py +79 -0
  1971. build/lib/nabu/preproc/phase.py +425 -0
  1972. build/lib/nabu/preproc/phase_cuda.py +143 -0
  1973. build/lib/nabu/preproc/shift.py +95 -0
  1974. build/lib/nabu/preproc/shift_cuda.py +102 -0
  1975. build/lib/nabu/preproc/tests/__init__.py +1 -0
  1976. build/lib/nabu/preproc/tests/test_ccd_corr.py +59 -0
  1977. build/lib/nabu/preproc/tests/test_ctf.py +250 -0
  1978. build/lib/nabu/preproc/tests/test_double_flatfield.py +86 -0
  1979. build/lib/nabu/preproc/tests/test_flatfield.py +626 -0
  1980. build/lib/nabu/preproc/tests/test_paganin.py +67 -0
  1981. build/lib/nabu/preproc/tests/test_vshift.py +73 -0
  1982. build/lib/nabu/processing/__init__.py +0 -0
  1983. build/lib/nabu/processing/convolution_cuda.py +375 -0
  1984. build/lib/nabu/processing/fft_base.py +163 -0
  1985. build/lib/nabu/processing/fft_cuda.py +256 -0
  1986. build/lib/nabu/processing/fft_opencl.py +54 -0
  1987. build/lib/nabu/processing/fftshift.py +134 -0
  1988. build/lib/nabu/processing/histogram.py +286 -0
  1989. build/lib/nabu/processing/histogram_cuda.py +103 -0
  1990. build/lib/nabu/processing/kernel_base.py +126 -0
  1991. build/lib/nabu/processing/medfilt_cuda.py +159 -0
  1992. build/lib/nabu/processing/muladd.py +29 -0
  1993. build/lib/nabu/processing/muladd_cuda.py +68 -0
  1994. build/lib/nabu/processing/padding_base.py +71 -0
  1995. build/lib/nabu/processing/padding_cuda.py +75 -0
  1996. build/lib/nabu/processing/padding_opencl.py +77 -0
  1997. build/lib/nabu/processing/processing_base.py +123 -0
  1998. build/lib/nabu/processing/roll_opencl.py +64 -0
  1999. build/lib/nabu/processing/rotation.py +63 -0
  2000. build/lib/nabu/processing/rotation_cuda.py +66 -0
  2001. build/lib/nabu/processing/tests/__init__.py +0 -0
  2002. build/lib/nabu/processing/tests/test_fft.py +268 -0
  2003. build/lib/nabu/processing/tests/test_fftshift.py +71 -0
  2004. build/lib/nabu/processing/tests/test_histogram.py +55 -0
  2005. build/lib/nabu/processing/tests/test_medfilt.py +77 -0
  2006. build/lib/nabu/processing/tests/test_muladd.py +54 -0
  2007. build/lib/nabu/processing/tests/test_padding.py +247 -0
  2008. build/lib/nabu/processing/tests/test_roll.py +63 -0
  2009. build/lib/nabu/processing/tests/test_rotation.py +83 -0
  2010. build/lib/nabu/processing/tests/test_transpose.py +72 -0
  2011. build/lib/nabu/processing/tests/test_unsharp.py +106 -0
  2012. build/lib/nabu/processing/transpose.py +126 -0
  2013. build/lib/nabu/processing/unsharp.py +79 -0
  2014. build/lib/nabu/processing/unsharp_cuda.py +53 -0
  2015. build/lib/nabu/processing/unsharp_opencl.py +75 -0
  2016. build/lib/nabu/reconstruction/__init__.py +3 -0
  2017. build/lib/nabu/reconstruction/cone.py +241 -0
  2018. build/lib/nabu/reconstruction/fbp.py +124 -0
  2019. build/lib/nabu/reconstruction/fbp_base.py +391 -0
  2020. build/lib/nabu/reconstruction/fbp_opencl.py +78 -0
  2021. build/lib/nabu/reconstruction/filtering.py +220 -0
  2022. build/lib/nabu/reconstruction/filtering_cuda.py +103 -0
  2023. build/lib/nabu/reconstruction/filtering_opencl.py +111 -0
  2024. build/lib/nabu/reconstruction/projection.py +240 -0
  2025. build/lib/nabu/reconstruction/reconstructor.py +174 -0
  2026. build/lib/nabu/reconstruction/reconstructor_cuda.py +44 -0
  2027. build/lib/nabu/reconstruction/rings.py +248 -0
  2028. build/lib/nabu/reconstruction/rings_cuda.py +322 -0
  2029. build/lib/nabu/reconstruction/sinogram.py +467 -0
  2030. build/lib/nabu/reconstruction/sinogram_cuda.py +250 -0
  2031. build/lib/nabu/reconstruction/sinogram_opencl.py +40 -0
  2032. build/lib/nabu/reconstruction/tests/__init__.py +1 -0
  2033. build/lib/nabu/reconstruction/tests/test_cone.py +308 -0
  2034. build/lib/nabu/reconstruction/tests/test_deringer.py +220 -0
  2035. build/lib/nabu/reconstruction/tests/test_fbp.py +252 -0
  2036. build/lib/nabu/reconstruction/tests/test_filtering.py +133 -0
  2037. build/lib/nabu/reconstruction/tests/test_halftomo.py +100 -0
  2038. build/lib/nabu/reconstruction/tests/test_projector.py +164 -0
  2039. build/lib/nabu/reconstruction/tests/test_reconstructor.py +93 -0
  2040. build/lib/nabu/reconstruction/tests/test_sino_normalization.py +85 -0
  2041. build/lib/nabu/resources/__init__.py +0 -0
  2042. build/lib/nabu/resources/cli/__init__.py +0 -0
  2043. build/lib/nabu/resources/cor.py +5 -0
  2044. build/lib/nabu/resources/dataset_analyzer.py +469 -0
  2045. build/lib/nabu/resources/gpu.py +169 -0
  2046. build/lib/nabu/resources/logger.py +130 -0
  2047. build/lib/nabu/resources/nxflatfield.py +217 -0
  2048. build/lib/nabu/resources/templates/__init__.py +0 -0
  2049. build/lib/nabu/resources/tests/__init__.py +0 -0
  2050. build/lib/nabu/resources/tests/test_nxflatfield.py +104 -0
  2051. build/lib/nabu/resources/tests/test_units.py +47 -0
  2052. build/lib/nabu/resources/utils.py +174 -0
  2053. build/lib/nabu/stitching/__init__.py +0 -0
  2054. build/lib/nabu/stitching/alignment.py +184 -0
  2055. build/lib/nabu/stitching/config.py +1286 -0
  2056. build/lib/nabu/stitching/definitions.py +6 -0
  2057. build/lib/nabu/stitching/frame_composition.py +155 -0
  2058. build/lib/nabu/stitching/overlap.py +373 -0
  2059. build/lib/nabu/stitching/sample_normalization.py +60 -0
  2060. build/lib/nabu/stitching/slurm_utils.py +204 -0
  2061. build/lib/nabu/stitching/tests/__init__.py +0 -0
  2062. build/lib/nabu/stitching/tests/test_alignment.py +99 -0
  2063. build/lib/nabu/stitching/tests/test_config.py +226 -0
  2064. build/lib/nabu/stitching/tests/test_frame_composition.py +180 -0
  2065. build/lib/nabu/stitching/tests/test_overlap.py +98 -0
  2066. build/lib/nabu/stitching/tests/test_sample_normalization.py +49 -0
  2067. build/lib/nabu/stitching/tests/test_slurm_utils.py +146 -0
  2068. build/lib/nabu/stitching/tests/test_utils.py +21 -0
  2069. build/lib/nabu/stitching/tests/test_z_stitching.py +1183 -0
  2070. build/lib/nabu/stitching/utils.py +563 -0
  2071. build/lib/nabu/stitching/z_stitching.py +2279 -0
  2072. build/lib/nabu/tests.py +51 -0
  2073. build/lib/nabu/testutils.py +375 -0
  2074. build/lib/nabu/thirdparty/__init__.py +0 -0
  2075. build/lib/nabu/thirdparty/algotom_convert_sino.py +276 -0
  2076. build/lib/nabu/thirdparty/pore3d_deringer_munch.py +108 -0
  2077. build/lib/nabu/thirdparty/tomocupy_remove_stripe.py +586 -0
  2078. build/lib/nabu/thirdparty/tomopy_phase.py +239 -0
  2079. build/lib/nabu/thirdparty/tomwer_load_flats_darks.py +162 -0
  2080. build/lib/nabu/utils.py +836 -0
  2081. nabu/__init__.py +1 -1
  2082. nabu/estimation/cor.py +2 -2
  2083. nabu/io/cast_volume.py +10 -2
  2084. nabu/pipeline/estimators.py +13 -7
  2085. nabu/resources/dataset_analyzer.py +15 -6
  2086. nabu/stitching/config.py +2 -2
  2087. nabu/stitching/z_stitching.py +3 -1
  2088. {nabu-2024.1.0rc3.dist-info → nabu-2024.1.1.dist-info}/METADATA +1 -1
  2089. nabu-2024.1.1.dist-info/RECORD +2375 -0
  2090. nabu-2024.1.1.dist-info/top_level.txt +4 -0
  2091. doc/doc_config.py +0 -32
  2092. nabu-2024.1.0rc3.dist-info/RECORD +0 -296
  2093. nabu-2024.1.0rc3.dist-info/top_level.txt +0 -2
  2094. {nabu-2024.1.0rc3.dist-info → nabu-2024.1.1.dist-info}/LICENSE +0 -0
  2095. {nabu-2024.1.0rc3.dist-info → nabu-2024.1.1.dist-info}/WHEEL +0 -0
  2096. {nabu-2024.1.0rc3.dist-info → nabu-2024.1.1.dist-info}/entry_points.txt +0 -0
@@ -0,0 +1,849 @@
1
+ from os import path
2
+ from time import time
3
+ from math import ceil
4
+ import numpy as np
5
+ from silx.io.url import DataUrl
6
+ from ...utils import remove_items_from_list
7
+ from ...resources.logger import LoggerOrPrint
8
+ from ...resources.utils import extract_parameters
9
+ from ...io.reader import ChunkReader, HDF5Loader
10
+ from ...preproc.ccd import Log, CCDFilter
11
+ from ...preproc.flatfield import FlatFieldDataUrls
12
+ from ...preproc.distortion import DistortionCorrection
13
+ from ...preproc.shift import VerticalShift
14
+ from ...preproc.double_flatfield import DoubleFlatField
15
+ from ...preproc.phase import PaganinPhaseRetrieval
16
+ from ...preproc.ctf import CTFPhaseRetrieval, GeoPars
17
+ from ...reconstruction.sinogram import SinoNormalization
18
+ from ...reconstruction.filtering import SinoFilter
19
+ from ...processing.rotation import Rotation
20
+ from ...reconstruction.rings import MunchDeringer, SinoMeanDeringer, VoDeringer
21
+ from ...processing.unsharp import UnsharpMask
22
+ from ...processing.histogram import PartialHistogram, hist_as_2Darray
23
+ from ..utils import use_options, pipeline_step, get_subregion
24
+ from ..datadump import DataDumpManager
25
+ from ..writer import WriterManager
26
+ from ..detector_distortion_provider import DetectorDistortionProvider
27
+
28
+ # For now we don't have a plain python/numpy backend for reconstruction
29
+ try:
30
+ from ...reconstruction.fbp_opencl import OpenCLBackprojector as Backprojector
31
+ except:
32
+ Backprojector = None
33
+
34
+
35
+ class ChunkedPipeline:
36
+ """
37
+ Pipeline for "regular" full-field tomography.
38
+ Data is processed by chunks. A chunk consists in K contiguous lines of all the radios.
39
+ In parallel geometry, a chunk of K radios lines gives K sinograms,
40
+ and equivalently K reconstructed slices.
41
+ """
42
+
43
+ backend = "numpy"
44
+ FlatFieldClass = FlatFieldDataUrls
45
+ DoubleFlatFieldClass = DoubleFlatField
46
+ CCDCorrectionClass = CCDFilter
47
+ PaganinPhaseRetrievalClass = PaganinPhaseRetrieval
48
+ CTFPhaseRetrievalClass = CTFPhaseRetrieval
49
+ UnsharpMaskClass = UnsharpMask
50
+ ImageRotationClass = Rotation
51
+ VerticalShiftClass = VerticalShift
52
+ MunchDeringerClass = MunchDeringer
53
+ SinoMeanDeringerClass = SinoMeanDeringer
54
+ VoDeringerClass = VoDeringer
55
+ MLogClass = Log
56
+ SinoNormalizationClass = SinoNormalization
57
+ SinoFilterClass = SinoFilter
58
+ FBPClass = Backprojector
59
+ ConebeamClass = None # unsupported on CPU
60
+ HistogramClass = PartialHistogram
61
+
62
+ _default_extra_options = {}
63
+
64
+ # These steps are skipped if the reconstruction is done in two stages.
65
+ # The first stage will skip these steps, and the second stage will do these stages after merging sinograms.
66
+ _reconstruction_steps = ["sino_rings_correction", "reconstruction", "save", "histogram"]
67
+
68
+ def __init__(
69
+ self, process_config, chunk_shape, margin=None, logger=None, use_grouped_mode=False, extra_options=None
70
+ ):
71
+ """
72
+ Initialize a "Chunked" pipeline.
73
+
74
+ Parameters
75
+ ----------
76
+ processing_config: `ProcessConfig`
77
+ Process configuration.
78
+ chunk_shape: tuple
79
+ Shape of the chunk of data to process, in the form (n_angles, n_z, n_x).
80
+ It has to account for possible cropping of the data, eg. [:, start_z:end_z, start_x:end_x]
81
+ where start_xz and/or end_xz can be other than None.
82
+ margin: tuple, optional
83
+ Margin to use, in the form ((up, down), (left, right)).
84
+ It is used for example when performing phase retrieval or a convolution-like operation:
85
+ some extra data is kept to avoid boundaries issues.
86
+ These boundaries are then discarded: the data volume is eventually cropped as
87
+ `data[U:D, L:R]` where `((U, D), (L, R)) = margin`
88
+ If not provided, no margin is applied.
89
+ logger: `nabu.app.logger.Logger`, optional
90
+ Logger class
91
+ extra_options: dict, optional
92
+ Advanced extra options.
93
+
94
+
95
+ Notes
96
+ ------
97
+
98
+ Using `margin` results in a lesser number of reconstructed slices.
99
+ More specifically, if `margin = (V, H)`, then there will be `delta_z - 2*V`
100
+ reconstructed slices (if the sub-region is in the middle of the volume)
101
+ or `delta_z - V` reconstructed slices (if the sub-region is on top or bottom
102
+ of the volume).
103
+ """
104
+ self.logger = LoggerOrPrint(logger)
105
+ self._set_params(process_config, chunk_shape, extra_options, margin, use_grouped_mode)
106
+ self._init_pipeline()
107
+
108
+ def _set_params(self, process_config, chunk_shape, extra_options, margin, use_grouped_mode):
109
+ self.process_config = process_config
110
+ self.dataset_info = self.process_config.dataset_info
111
+ self.processing_steps = self.process_config.processing_steps.copy()
112
+ self.processing_options = self.process_config.processing_options
113
+ self._set_chunk_shape(chunk_shape, use_grouped_mode)
114
+ self.set_subregion(None)
115
+ self._set_margin(margin)
116
+ self._set_extra_options(extra_options)
117
+ self._callbacks = {}
118
+ self._steps_name2component = {}
119
+ self._steps_component2name = {}
120
+
121
+ def _set_chunk_shape(self, chunk_shape, use_grouped_mode):
122
+ if len(chunk_shape) != 3:
123
+ raise ValueError("Expected chunk_shape to be a tuple of length 3 in the form (n_z, n_y, n_x)")
124
+ self.chunk_shape = tuple(int(c) for c in chunk_shape) # cast to int, as numpy.int64 can make pycuda crash
125
+ # TODO: sanity check (eg. compare to size of radios in dataset_info) ?
126
+ # (n_a, n_z, n_x)
127
+ self.radios_shape = (
128
+ ceil(self.chunk_shape[0] / self.process_config.subsampling_factor),
129
+ self.chunk_shape[1] // self.process_config.binning[1],
130
+ self.chunk_shape[2] // self.process_config.binning[0],
131
+ )
132
+ self.n_angles = self.radios_shape[0]
133
+ self.n_slices = self.radios_shape[1]
134
+ self._grouped_processing = False
135
+ if use_grouped_mode or self.chunk_shape[0] < len(self.process_config.rotation_angles(subsampling=False)):
136
+ # TODO allow a certain tolerance in this case ?
137
+ # Reconstruction is still possible (albeit less accurate) if delta is small
138
+ self._grouped_processing = True
139
+ self.logger.debug("Only a subset of angles is processed - Reconstruction will be skipped")
140
+ self.processing_steps, _ = remove_items_from_list(self.processing_steps, self._reconstruction_steps)
141
+
142
+ def _set_margin(self, margin):
143
+ if margin is None:
144
+ U, D, L, R = None, None, None, None
145
+ else:
146
+ ((U, D), (L, R)) = get_subregion(margin, ndim=2)
147
+
148
+ # Replace "None" with zeros
149
+ U, D, L, R = U or 0, D or 0, L or 0, R or 0
150
+
151
+ self.margin = ((U, D), (L, R))
152
+ self._margin_up = U
153
+ self._margin_down = D
154
+ self._margin_left = L
155
+ self._margin_right = R
156
+ self.use_margin = (U + D + L + R) > 0
157
+ self.n_recs = self.chunk_shape[1] - sum(self.margin[0])
158
+ self.radios_cropped_shape = (self.radios_shape[0], self.radios_shape[1] - U - D, self.radios_shape[2] - L - R)
159
+ if self.use_margin:
160
+ self.n_slices -= sum(self.margin[0])
161
+
162
+ def set_subregion(self, sub_region):
163
+ """
164
+ Set the data volume sub-region to process.
165
+ Note that processing margin, if any, is contained within the sub-region.
166
+
167
+ Parameters
168
+ -----------
169
+ sub_region: tuple
170
+ Data volume sub-region, in the form ((start_a, end_a), (start_z, end_z), (start_x, end_x))
171
+ where the data volume has a layout (angles, Z, X)
172
+ """
173
+ n_angles = self.dataset_info.n_angles
174
+ n_x, n_z = self.dataset_info.radio_dims
175
+ c_a, c_z, c_x = self.chunk_shape
176
+ if sub_region is None:
177
+ # By default, take the sub-region around central slice
178
+ sub_region = (
179
+ (0, c_a),
180
+ (n_z // 2 - c_z // 2, n_z // 2 - c_z // 2 + c_z),
181
+ (n_x // 2 - c_x // 2, n_x // 2 - c_x // 2 + c_x),
182
+ )
183
+ else:
184
+ sub_region = get_subregion(sub_region, ndim=3)
185
+ # check sub-region
186
+ for i, start_end in enumerate(sub_region):
187
+ start, end = start_end
188
+ if start is not None and end is not None:
189
+ if end - start != self.chunk_shape[i]:
190
+ raise ValueError(
191
+ "Invalid (start, end)=(%d, %d) for sub-region (dimension %d): chunk shape is %s, but %d-%d=%d != %d"
192
+ % (start, end, i, str(self.chunk_shape), end, start, end - start, self.chunk_shape[i])
193
+ )
194
+ #
195
+ self.logger.debug("Set sub-region to %s" % (str(sub_region)))
196
+ self.sub_region = sub_region
197
+ self._sub_region_xz = sub_region[2] + sub_region[1]
198
+
199
+ def _set_extra_options(self, extra_options):
200
+ self.extra_options = self._default_extra_options.copy()
201
+ self.extra_options.update(extra_options or {})
202
+
203
+ #
204
+ # Callbacks
205
+ #
206
+
207
+ def register_callback(self, step_name, callback):
208
+ """
209
+ Register a callback for a pipeline processing step.
210
+
211
+ Parameters
212
+ ----------
213
+ step_name: str
214
+ processing step name
215
+ callback: callable
216
+ A function. It will be executed once the processing step `step_name`
217
+ is finished. The function takes only one argument: the class instance.
218
+ """
219
+ if step_name not in self.processing_steps:
220
+ raise ValueError("'%s' is not in processing steps %s" % (step_name, self.processing_steps))
221
+ if step_name in self._callbacks:
222
+ self._callbacks[step_name].append(callback)
223
+ else:
224
+ self._callbacks[step_name] = [callback]
225
+
226
+ #
227
+ # Memory management
228
+ #
229
+
230
+ def _allocate_array(self, shape, dtype, name=None):
231
+ return np.zeros(shape, dtype=dtype)
232
+
233
+ def _allocate_recs(self, ny, nx, n_slices=None):
234
+ n_slices = n_slices or self.n_slices
235
+ self.recs = self._allocate_array((n_slices, ny, nx), "f", name="recs")
236
+
237
+ #
238
+ # Runtime attributes
239
+ #
240
+
241
+ @property
242
+ def sub_region_xz(self):
243
+ """
244
+ Return the currently processed sub-region in the form
245
+ (start_x, end_x, start_z, end_z)
246
+ """
247
+ return self._sub_region_xz
248
+
249
+ @property
250
+ def z_min(self):
251
+ return self._sub_region_xz[2]
252
+
253
+ @property
254
+ def sino_shape(self):
255
+ return self.process_config.sino_shape(binning=True, subsampling=True)
256
+
257
+ @property
258
+ def sinos_shape(self):
259
+ return (self.n_slices,) + self.sino_shape
260
+
261
+ def get_slice_start_index(self):
262
+ return self.z_min + self._margin_up
263
+
264
+ #
265
+ # Pipeline initialization
266
+ #
267
+
268
+ def _init_pipeline(self):
269
+ self._allocate_radios()
270
+ self._init_data_dump()
271
+ self._init_reader()
272
+ self._init_flatfield()
273
+ self._init_double_flatfield()
274
+ self._init_ccd_corrections()
275
+ self._init_radios_rotation()
276
+ self._init_phase()
277
+ self._init_unsharp()
278
+ self._init_radios_movements()
279
+ self._init_mlog()
280
+ self._init_sino_normalization()
281
+ self._init_sino_rings_correction()
282
+ self._init_reconstruction()
283
+ self._init_histogram()
284
+ self._init_writer()
285
+
286
+ def _allocate_radios(self):
287
+ self.radios = np.zeros(self.radios_shape, dtype=np.float32)
288
+ self.data = self.radios # alias
289
+
290
+ def _init_data_dump(self):
291
+ self._resume_from_step = self.processing_options["read_chunk"].get("step_name", None)
292
+ self.datadump_manager = DataDumpManager(
293
+ self.process_config, self.sub_region, margin=self.margin, logger=self.logger
294
+ )
295
+ # When using "grouped processing", sinogram has to be dumped.
296
+ # If it was not specified by user, force sinogram dump
297
+ # Perhaps these lines should be moved directly to DataDumpManager.
298
+ if self._grouped_processing and not self.process_config.dump_sinogram:
299
+ sino_dump_fname = self.process_config.get_save_steps_file("sinogram")
300
+ self.datadump_manager._configure_dump("sinogram", force_dump_to_fname=sino_dump_fname)
301
+ self.logger.debug("Will dump sinogram to %s" % self.datadump_manager.data_dump["sinogram"].fname)
302
+
303
+ @use_options("read_chunk", "chunk_reader")
304
+ def _init_reader(self):
305
+ options = self.processing_options["read_chunk"]
306
+ self._update_reader_configuration()
307
+
308
+ process_file = options.get("process_file", None)
309
+ if process_file is None:
310
+ # Standard case - start pipeline from raw data
311
+ if self.process_config.nabu_config["preproc"]["detector_distortion_correction"] is None:
312
+ self.detector_corrector = None
313
+ else:
314
+ self.detector_corrector = DetectorDistortionProvider(
315
+ detector_full_shape_vh=self.process_config.dataset_info.radio_dims[::-1],
316
+ correction_type=self.process_config.nabu_config["preproc"]["detector_distortion_correction"],
317
+ options=self.process_config.nabu_config["preproc"]["detector_distortion_correction_options"],
318
+ )
319
+ # ChunkReader always take a non-subsampled dictionary "files".
320
+ self.chunk_reader = ChunkReader(
321
+ self._read_options["files"],
322
+ sub_region=self.sub_region_xz,
323
+ data_buffer=self.radios,
324
+ pre_allocate=False,
325
+ detector_corrector=self.detector_corrector,
326
+ convert_float=True,
327
+ binning=options["binning"],
328
+ dataset_subsampling=options["dataset_subsampling"],
329
+ )
330
+ else:
331
+ # Resume pipeline from dumped intermediate step
332
+ self.chunk_reader = HDF5Loader(
333
+ process_file,
334
+ options["process_h5_path"],
335
+ sub_region=self.datadump_manager.get_read_dump_subregion(),
336
+ data_buffer=self.radios,
337
+ pre_allocate=False,
338
+ )
339
+ self._resume_from_step = options["step_name"]
340
+ self.logger.debug(
341
+ "Load subregion %s from file %s" % (str(self.chunk_reader.sub_region), self.chunk_reader.fname)
342
+ )
343
+
344
+ def _update_reader_configuration(self):
345
+ """
346
+ Modify self.processing_options["read_chunk"] to select a subset of the files, if needed
347
+ (i.e when processing only a subset of the images stack)
348
+ """
349
+ self._read_options = self.processing_options["read_chunk"].copy()
350
+ if self.n_angles == self.process_config.n_angles(subsampling=True):
351
+ # Nothing to do if the full angular range is processed in one shot
352
+ return
353
+ if self._resume_from_step is not None:
354
+ if self._resume_from_step == "sinogram":
355
+ msg = "It makes no sense to use 'grouped processing' when resuming from sinogram"
356
+ self.logger.fatal(msg)
357
+ raise ValueError(msg)
358
+ # Nothing to do if we resume the processing from a given step
359
+ return
360
+ input_data_files = {}
361
+ files_indices = sorted(self._read_options["files"].keys())
362
+ angle_idx_start, angle_idx_end = self.sub_region[0]
363
+ for i in range(angle_idx_start, angle_idx_end):
364
+ idx = files_indices[i]
365
+ input_data_files[idx] = self._read_options["files"][idx]
366
+ self._read_options["files"] = input_data_files
367
+
368
+ @use_options("flatfield", "flatfield")
369
+ def _init_flatfield(self):
370
+ self._ff_options = self.processing_options["flatfield"].copy()
371
+ # Use chunk_reader.files instead of process_config.projs_indices(subsampling=True), because
372
+ # chunk_reader might read only a subset of the files (in "grouped mode")
373
+ self._ff_options["projs_indices"] = list(self.chunk_reader.files_subsampled.keys())
374
+ if self._ff_options.get("normalize_srcurrent", False):
375
+ a_start_idx, a_end_idx = self.sub_region[0]
376
+ subs = self.process_config.subsampling_factor
377
+ self._ff_options["radios_srcurrent"] = self._ff_options["radios_srcurrent"][a_start_idx:a_end_idx:subs]
378
+
379
+ distortion_correction = None
380
+ if self._ff_options["do_flat_distortion"]:
381
+ self.logger.info("Flats distortion correction will be applied")
382
+ self.FlatFieldClass = FlatFieldDataUrls # no GPU implementation available, force this backend
383
+ estimation_kwargs = {}
384
+ estimation_kwargs.update(self._ff_options["flat_distortion_params"])
385
+ estimation_kwargs["logger"] = self.logger
386
+ distortion_correction = DistortionCorrection(
387
+ estimation_method="fft-correlation", estimation_kwargs=estimation_kwargs, correction_method="interpn"
388
+ )
389
+
390
+ # FlatField parameter "radios_indices" must account for subsampling
391
+ self.flatfield = self.FlatFieldClass(
392
+ self.radios_shape,
393
+ flats=self.dataset_info.flats,
394
+ darks=self.dataset_info.darks,
395
+ radios_indices=self._ff_options["projs_indices"],
396
+ interpolation="linear",
397
+ distortion_correction=distortion_correction,
398
+ sub_region=self.sub_region_xz,
399
+ detector_corrector=self.detector_corrector,
400
+ binning=self._ff_options["binning"],
401
+ radios_srcurrent=self._ff_options["radios_srcurrent"],
402
+ flats_srcurrent=self._ff_options["flats_srcurrent"],
403
+ convert_float=True,
404
+ )
405
+
406
+ @use_options("double_flatfield", "double_flatfield")
407
+ def _init_double_flatfield(self):
408
+ options = self.processing_options["double_flatfield"]
409
+ avg_is_on_log = options["sigma"] is not None
410
+ result_url = None
411
+ if options["processes_file"] not in (None, ""):
412
+ result_url = DataUrl(
413
+ file_path=options["processes_file"],
414
+ data_path=(self.dataset_info.hdf5_entry or "entry") + "/double_flatfield/results/data",
415
+ )
416
+ self.logger.info("Loading double flatfield from %s" % result_url.file_path())
417
+ if (self.n_angles < self.process_config.n_angles(subsampling=True)) and result_url is None:
418
+ raise ValueError(
419
+ "Cannot use double-flatfield when processing subset of radios. Please use the 'nabu-double-flatfield' command"
420
+ )
421
+ self.double_flatfield = self.DoubleFlatFieldClass(
422
+ self.radios_shape,
423
+ result_url=result_url,
424
+ sub_region=self.sub_region_xz,
425
+ detector_corrector=self.detector_corrector,
426
+ input_is_mlog=False,
427
+ output_is_mlog=False,
428
+ average_is_on_log=avg_is_on_log,
429
+ sigma_filter=options["sigma"],
430
+ log_clip_min=options["log_min_clip"],
431
+ log_clip_max=options["log_max_clip"],
432
+ )
433
+
434
+ @use_options("ccd_correction", "ccd_correction")
435
+ def _init_ccd_corrections(self):
436
+ options = self.processing_options["ccd_correction"]
437
+ self.ccd_correction = self.CCDCorrectionClass(
438
+ self.radios_shape[1:], median_clip_thresh=options["median_clip_thresh"]
439
+ )
440
+
441
+ @use_options("rotate_projections", "projs_rot")
442
+ def _init_radios_rotation(self):
443
+ options = self.processing_options["rotate_projections"]
444
+ center = options["center"]
445
+ if center is None:
446
+ nx, ny = self.radios_shape[1:][::-1] # after binning
447
+ center = (nx / 2 - 0.5, ny / 2 - 0.5)
448
+ center = (center[0], center[1] - self.z_min)
449
+ self.projs_rot = self.ImageRotationClass(
450
+ self.radios_shape[1:], options["angle"], center=center, mode="edge", reshape=False
451
+ )
452
+ self._tmp_rotated_radio = self._allocate_array(self.radios_shape[1:], "f", name="tmp_rotated_radio")
453
+
454
+ @use_options("radios_movements", "radios_movements")
455
+ def _init_radios_movements(self):
456
+ options = self.processing_options["radios_movements"]
457
+ self._vertical_shifts = options["translation_movements"][:, 1]
458
+ self.radios_movements = self.VerticalShiftClass(self.radios.shape, self._vertical_shifts)
459
+
460
+ @use_options("phase", "phase_retrieval")
461
+ def _init_phase(self):
462
+ options = self.processing_options["phase"]
463
+ if options["method"] == "CTF":
464
+ translations_vh = getattr(self.dataset_info, "ctf_translations", None)
465
+ geo_pars_params = options["ctf_geo_pars"].copy()
466
+ geo_pars_params["logger"] = self.logger
467
+ geo_pars = GeoPars(**geo_pars_params)
468
+ self.phase_retrieval = self.CTFPhaseRetrievalClass(
469
+ self.radios_shape[1:],
470
+ geo_pars,
471
+ options["delta_beta"],
472
+ lim1=options["ctf_lim1"],
473
+ lim2=options["ctf_lim2"],
474
+ logger=self.logger,
475
+ fft_num_threads=None, # TODO tune in advanced params of nabu config file
476
+ use_rfft=True,
477
+ normalize_by_mean=options["ctf_normalize_by_mean"],
478
+ translation_vh=translations_vh,
479
+ )
480
+ else:
481
+ self.phase_retrieval = self.PaganinPhaseRetrievalClass(
482
+ self.radios_shape[1:],
483
+ distance=options["distance_m"],
484
+ energy=options["energy_kev"],
485
+ delta_beta=options["delta_beta"],
486
+ pixel_size=options["pixel_size_m"],
487
+ padding=options["padding_type"],
488
+ # TODO tune in advanced params of nabu config file
489
+ fft_num_threads=None,
490
+ )
491
+
492
+ @use_options("unsharp_mask", "unsharp_mask")
493
+ def _init_unsharp(self):
494
+ options = self.processing_options["unsharp_mask"]
495
+ self.unsharp_mask = self.UnsharpMaskClass(
496
+ self.radios_shape[1:],
497
+ options["unsharp_sigma"],
498
+ options["unsharp_coeff"],
499
+ mode="reflect",
500
+ method=options["unsharp_method"],
501
+ )
502
+
503
+ @use_options("take_log", "mlog")
504
+ def _init_mlog(self):
505
+ options = self.processing_options["take_log"]
506
+ self.mlog = self.MLogClass(
507
+ self.radios_shape, clip_min=options["log_min_clip"], clip_max=options["log_max_clip"]
508
+ )
509
+
510
+ @use_options("sino_normalization", "sino_normalization")
511
+ def _init_sino_normalization(self):
512
+ options = self.processing_options["sino_normalization"]
513
+ self.sino_normalization = self.SinoNormalizationClass(
514
+ kind=options["method"],
515
+ radios_shape=self.radios_cropped_shape,
516
+ normalization_array=options["normalization_array"],
517
+ )
518
+
519
+ @use_options("sino_rings_correction", "sino_deringer")
520
+ def _init_sino_rings_correction(self):
521
+ n_a, n_z, n_x = self.radios_cropped_shape
522
+ sinos_shape = (n_z, n_a, n_x)
523
+ options = self.processing_options["sino_rings_correction"]
524
+
525
+ destriper_params = extract_parameters(options["user_options"])
526
+ if options["method"] == "munch":
527
+ # TODO MunchDeringer does not have an API consistent with the other deringers
528
+ fw_sigma = destriper_params.pop("sigma", 1.0)
529
+ self.sino_deringer = self.MunchDeringerClass(fw_sigma, sinos_shape, **destriper_params)
530
+ elif options["method"] == "vo":
531
+ self.sino_deringer = self.VoDeringerClass(sinos_shape, **destriper_params)
532
+ elif options["method"] == "mean-subtraction":
533
+ self.sino_deringer = self.SinoMeanDeringerClass(
534
+ sinos_shape, mode="subtract", fft_num_threads=None, **destriper_params
535
+ )
536
+ elif options["method"] == "mean-division":
537
+ self.sino_deringer = self.SinoMeanDeringerClass(
538
+ sinos_shape, mode="divide", fft_num_threads=None, **destriper_params
539
+ )
540
+
541
+ @use_options("reconstruction", "reconstruction")
542
+ def _init_reconstruction(self):
543
+ options = self.processing_options["reconstruction"]
544
+ if options["method"] == "FBP" and self.FBPClass is None:
545
+ raise ValueError("No usable FBP module was found")
546
+ if options["method"] == "cone" and self.ConebeamClass is None:
547
+ raise ValueError("No usable cone-beam module was found")
548
+
549
+ if options["method"] == "FBP":
550
+ n_slices = self.n_slices
551
+ radios_shape_for_sino_builder = self.radios_cropped_shape
552
+ self.reconstruction = self.FBPClass(
553
+ self.sinos_shape[1:],
554
+ angles=options["angles"],
555
+ rot_center=options["rotation_axis_position"],
556
+ filter_name=options["fbp_filter_type"] or "none",
557
+ halftomo=options["enable_halftomo"],
558
+ slice_roi=self.process_config.rec_roi,
559
+ padding_mode=options["padding_type"],
560
+ extra_options={
561
+ "scale_factor": 1.0 / options["voxel_size_cm"][0],
562
+ "axis_correction": options["axis_correction"],
563
+ "centered_axis": options["centered_axis"],
564
+ "clip_outer_circle": options["clip_outer_circle"],
565
+ "filter_cutoff": options["fbp_filter_cutoff"],
566
+ },
567
+ )
568
+
569
+ if options["method"] == "cone":
570
+ radios_shape_for_sino_builder = self.radios_shape
571
+ n_slices = self.n_slices + sum(self.margin[0])
572
+ # For numerical stability, normalize all lengths with respect to detector pixel size
573
+ pixel_size_m = self.dataset_info.pixel_size * 1e-6
574
+ source_sample_dist = options["source_sample_dist"] / pixel_size_m
575
+ sample_detector_dist = options["sample_detector_dist"] / pixel_size_m
576
+ self.reconstruction = self.ConebeamClass( # pylint: disable=E1102
577
+ (self.radios_shape[1],) + self.sino_shape,
578
+ source_sample_dist,
579
+ sample_detector_dist,
580
+ angles=options["angles"],
581
+ # TODO one center for each angle to handle "x translations"
582
+ rot_center=options["rotation_axis_position"],
583
+ pixel_size=1,
584
+ )
585
+
586
+ self._allocate_recs(*self.process_config.rec_shape, n_slices=n_slices)
587
+ n_a, _, n_x = self.radios_cropped_shape
588
+ self._tmp_sino = self._allocate_array((n_a, n_x), "f", name="tmp_sino")
589
+ if options["method"] == "cone":
590
+ self.sinos = self._allocate_array(self.sino_builder.output_shape, "f", name="sinos")
591
+
592
+ @use_options("histogram", "histogram")
593
+ def _init_histogram(self):
594
+ options = self.processing_options["histogram"]
595
+ self.histogram = self.HistogramClass(method="fixed_bins_number", num_bins=options["histogram_bins"])
596
+
597
+ @use_options("save", "writer")
598
+ def _init_writer(self, **extra_options):
599
+ options = self.processing_options["save"]
600
+ metadata = {
601
+ "process_name": "reconstruction",
602
+ "processing_index": 0,
603
+ # TODO this one takes too much time to write, not useful for partial files
604
+ # "processing_options": self.processing_options,
605
+ #
606
+ "nabu_config": self.process_config.nabu_config,
607
+ "entry": getattr(self.dataset_info.dataset_scanner, "entry", "entry"),
608
+ }
609
+ writer_extra_options = {
610
+ "jpeg2000_compression_ratio": options["jpeg2000_compression_ratio"],
611
+ "float_clip_values": options["float_clip_values"],
612
+ "tiff_single_file": options.get("tiff_single_file", False),
613
+ "single_output_file_initialized": getattr(self.process_config, "single_output_file_initialized", False),
614
+ "raw_vol_metadata": {"voxelSize": self.dataset_info.pixel_size}, # legacy...
615
+ }
616
+ writer_extra_options.update(extra_options)
617
+ self.writer = WriterManager(
618
+ options["location"],
619
+ options["file_prefix"],
620
+ file_format=options["file_format"],
621
+ overwrite=options["overwrite"],
622
+ start_index=self.get_slice_start_index(),
623
+ logger=self.logger,
624
+ metadata=metadata,
625
+ histogram=("histogram" in self.processing_steps),
626
+ extra_options=writer_extra_options,
627
+ )
628
+
629
+ #
630
+ # Pipeline execution
631
+ #
632
+
633
+ @pipeline_step("chunk_reader", "Reading data")
634
+ def _read_data(self):
635
+ self.logger.debug("Region = %s" % str(self.sub_region))
636
+ t0 = time()
637
+ self.chunk_reader.load_data()
638
+ el = time() - t0
639
+ shp = self.chunk_reader.data.shape
640
+ self.logger.info("Read subvolume %s in %.2f s" % (str(shp), el))
641
+
642
+ @pipeline_step("flatfield", "Applying flat-field")
643
+ def _flatfield(self):
644
+ self.flatfield.normalize_radios(self.radios)
645
+
646
+ @pipeline_step("double_flatfield", "Applying double flat-field")
647
+ def _double_flatfield(self, radios=None):
648
+ if radios is None:
649
+ radios = self.radios
650
+ self.double_flatfield.apply_double_flatfield(radios)
651
+
652
+ @pipeline_step("ccd_correction", "Applying CCD corrections")
653
+ def _ccd_corrections(self, radios=None):
654
+ if radios is None:
655
+ radios = self.radios
656
+ _tmp_radio = self._allocate_array(radios.shape[1:], "f", name="tmp_ccdcorr_radio")
657
+ for i in range(radios.shape[0]):
658
+ self.ccd_correction.median_clip_correction(radios[i], output=_tmp_radio)
659
+ radios[i][:] = _tmp_radio[:]
660
+
661
+ @pipeline_step("projs_rot", "Rotating projections")
662
+ def _rotate_projections(self, radios=None):
663
+ if radios is None:
664
+ radios = self.radios
665
+ tmp_radio = self._tmp_rotated_radio
666
+ for i in range(radios.shape[0]):
667
+ self.projs_rot.rotate(radios[i], output=tmp_radio)
668
+ radios[i][:] = tmp_radio[:]
669
+
670
+ @pipeline_step("phase_retrieval", "Performing phase retrieval")
671
+ def _retrieve_phase(self):
672
+ for i in range(self.radios.shape[0]):
673
+ self.phase_retrieval.retrieve_phase(self.radios[i], output=self.radios[i])
674
+
675
+ @pipeline_step("unsharp_mask", "Performing unsharp mask")
676
+ def _apply_unsharp(self):
677
+ for i in range(self.radios.shape[0]):
678
+ self.radios[i] = self.unsharp_mask.unsharp(self.radios[i])
679
+
680
+ @pipeline_step("mlog", "Taking logarithm")
681
+ def _take_log(self):
682
+ self.mlog.take_logarithm(self.radios)
683
+
684
+ @pipeline_step("radios_movements", "Applying radios movements")
685
+ def _radios_movements(self, radios=None):
686
+ if radios is None:
687
+ radios = self.radios
688
+ self.radios_movements.apply_vertical_shifts(radios, list(range(radios.shape[0])))
689
+
690
+ def _crop_radios(self):
691
+ if self.use_margin:
692
+ self._orig_radios = self.radios
693
+ if self.processing_options.get("reconstruction", {}).get("method", None) == "cone":
694
+ return
695
+ ((U, D), (L, R)) = self.margin
696
+ self.logger.debug(
697
+ "Cropping radios from %s to %s" % (str(self.radios_shape), str(self.radios_cropped_shape))
698
+ )
699
+ U, D, L, R = U or None, -D or None, L or None, -R or None
700
+ self.radios = self.radios[:, U:D, L:R] # view
701
+
702
+ @pipeline_step("sino_normalization", "Normalizing sinograms")
703
+ def _normalize_sinos(self, radios=None):
704
+ if radios is None:
705
+ radios = self.radios
706
+ sinos = radios.transpose((1, 0, 2))
707
+ self.sino_normalization.normalize(sinos)
708
+
709
+ def _dump_sinogram(self):
710
+ if self.datadump_manager is not None:
711
+ self.datadump_manager.dump_data_to_file("sinogram", self.radios)
712
+
713
+ @pipeline_step("sino_deringer", "Removing rings on sinograms")
714
+ def _destripe_sinos(self):
715
+ sinos = np.rollaxis(self.radios, 1, 0) # view
716
+ self.sino_deringer.remove_rings(sinos) # TODO check it works with non-contiguous view
717
+
718
+ @pipeline_step("reconstruction", "Reconstruction")
719
+ def _reconstruct(self):
720
+ """
721
+ Reconstruction for parallel geometry.
722
+ For each target slice: get the corresponding sinogram, apply some processing, then reconstruct
723
+ """
724
+ options = self.processing_options["reconstruction"]
725
+ if options["method"] == "cone":
726
+ self._reconstruct_cone()
727
+ return
728
+
729
+ for i in range(self.n_slices):
730
+ self._tmp_sino[:] = self.radios[:, i, :] # copy into contiguous array
731
+ self.reconstruction.fbp(self._tmp_sino, output=self.recs[i])
732
+
733
+ def _reconstruct_cone(self):
734
+ """
735
+ This reconstructs the entire sinograms stack at once
736
+ """
737
+ self.sino_builder.get_sinos(self.radios, output=self.sinos)
738
+ z_min, z_max = self.sub_region_xz[2:]
739
+ n_z = self.process_config.radio_shape(binning=True)[0]
740
+
741
+ self.reconstruction.reconstruct( # pylint: disable=E1101
742
+ self.sinos,
743
+ output=self.recs,
744
+ relative_z_position=((z_min + z_max) / self.process_config.binning_z / 2) - n_z / 2,
745
+ )
746
+
747
+ @pipeline_step("histogram", "Computing histogram")
748
+ def _compute_histogram(self, data=None):
749
+ if data is None:
750
+ data = self.recs
751
+ self.recs_histogram = self.histogram.compute_histogram(data)
752
+
753
+ @pipeline_step("writer", "Saving data")
754
+ def _write_data(self, data=None):
755
+ if data is None and self.reconstruction is not None:
756
+ data = self.recs
757
+ if data is None:
758
+ self.logger.info("No data to write")
759
+ return
760
+ self.writer.write_data(data)
761
+ self.logger.info("Wrote %s" % self.writer.fname)
762
+ self._write_histogram()
763
+ self.process_config.single_output_file_initialized = True
764
+
765
+ def _write_histogram(self):
766
+ if "histogram" not in self.processing_steps:
767
+ return
768
+ self.logger.info("Saving histogram")
769
+ self.writer.write_histogram(
770
+ hist_as_2Darray(self.recs_histogram),
771
+ processing_index=1,
772
+ config={
773
+ "file": path.basename(self.writer.fname),
774
+ "bins": self.processing_options["histogram"]["histogram_bins"],
775
+ },
776
+ )
777
+
778
+ def _process_finalize(self):
779
+ if self.use_margin:
780
+ self.radios = self._orig_radios
781
+
782
+ def __repr__(self):
783
+ res = "%s(%s, margin=%s)" % (self.__class__.__name__, str(self.chunk_shape), str(self.margin))
784
+ binning = self.process_config.binning
785
+ subsampling = self.process_config.subsampling_factor
786
+
787
+ if binning != (1, 1) or subsampling > 1:
788
+ if binning != (1, 1):
789
+ res += "\nImages binning: %s" % (str(binning))
790
+ if subsampling:
791
+ res += "\nAngles subsampling: %d" % subsampling
792
+ res += "\nRadios chunk: %s ---> %s" % (self.chunk_shape, self.radios_shape)
793
+
794
+ if self.use_margin:
795
+ res += "\nMargin: %s" % (str(self.margin))
796
+ res += "\nRadios chunk: %s ---> %s" % (str(self.radios_shape), str(self.radios_cropped_shape))
797
+
798
+ res += "\nCurrent subregion: %s" % (str(self.sub_region))
799
+ for step_name in self.processing_steps:
800
+ res += "\n- %s" % (step_name)
801
+ return res
802
+
803
+ def _process_chunk(self):
804
+ self._flatfield()
805
+ self._double_flatfield()
806
+ self._ccd_corrections()
807
+ self._rotate_projections()
808
+ self._retrieve_phase()
809
+ self._apply_unsharp()
810
+ self._take_log()
811
+ self._radios_movements()
812
+ self._crop_radios()
813
+ self._normalize_sinos()
814
+ self._destripe_sinos()
815
+ self._dump_sinogram()
816
+ self._reconstruct()
817
+ self._compute_histogram()
818
+ self._write_data()
819
+ self._process_finalize()
820
+
821
+ def _reset_reader_subregion(self):
822
+ if self._resume_from_step is None:
823
+ # Normal mode - read data from raw radios
824
+ self.chunk_reader._set_subregion(self.sub_region_xz)
825
+ self.chunk_reader._init_reader()
826
+ self.chunk_reader._loaded = False
827
+ else:
828
+ # Resume from a checkpoint. In this case, we have to re-initialize "datadump manager"
829
+ # sooner to configure start_xyz, end_xyz
830
+ self._init_data_dump()
831
+ self.chunk_reader._set_subregion(self.datadump_manager.get_read_dump_subregion())
832
+ self.chunk_reader._loaded = False
833
+ if self._grouped_processing:
834
+ self._update_reader_configuration()
835
+ self.chunk_reader._set_files(self._read_options["files"])
836
+
837
+ def _reset_sub_region(self, sub_region):
838
+ self.set_subregion(sub_region)
839
+ # When sub_region is changed, all components involving files reading have to be updated
840
+ self._reset_reader_subregion()
841
+ self._init_flatfield() # reset flatfield
842
+ self._init_writer()
843
+ self._init_double_flatfield()
844
+ self._init_data_dump()
845
+
846
+ def process_chunk(self, sub_region):
847
+ self._reset_sub_region(sub_region)
848
+ self._read_data()
849
+ self._process_chunk()