resqpy 4.18.2__tar.gz → 4.18.4__tar.gz

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 (200) hide show
  1. {resqpy-4.18.2 → resqpy-4.18.4}/PKG-INFO +1 -1
  2. {resqpy-4.18.2 → resqpy-4.18.4}/pyproject.toml +1 -1
  3. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/__init__.py +1 -1
  4. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/_find_faces.py +64 -38
  5. {resqpy-4.18.2 → resqpy-4.18.4}/LICENSE +0 -0
  6. {resqpy-4.18.2 → resqpy-4.18.4}/README.md +0 -0
  7. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/crs.py +0 -0
  8. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/__init__.py +0 -0
  9. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_edges_per_column_property_array.py +0 -0
  10. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_faults.py +0 -0
  11. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_one_blocked_well_property.py +0 -0
  12. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_one_grid_property_array.py +0 -0
  13. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_single_cell_grid.py +0 -0
  14. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_wells_from_ascii_file.py +0 -0
  15. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_add_zone_by_layer_property.py +0 -0
  16. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_coarsened_grid.py +0 -0
  17. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_common.py +0 -0
  18. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_copy_grid.py +0 -0
  19. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_drape_to_surface.py +0 -0
  20. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_extract_box.py +0 -0
  21. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_extract_box_for_well.py +0 -0
  22. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_fault_throw_scaling.py +0 -0
  23. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_gather_ensemble.py +0 -0
  24. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_interpolated_grid.py +0 -0
  25. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_local_depth_adjustment.py +0 -0
  26. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_refined_grid.py +0 -0
  27. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_tilted_grid.py +0 -0
  28. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_unsplit_grid.py +0 -0
  29. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_zonal_grid.py +0 -0
  30. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/derived_model/_zone_layer_ranges_from_array.py +0 -0
  31. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/fault/__init__.py +0 -0
  32. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/fault/_gcs_functions.py +0 -0
  33. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/fault/_grid_connection_set.py +0 -0
  34. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/__init__.py +0 -0
  35. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_cell_properties.py +0 -0
  36. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_connection_sets.py +0 -0
  37. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_create_grid_xml.py +0 -0
  38. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_defined_geometry.py +0 -0
  39. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_extract_functions.py +0 -0
  40. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_face_functions.py +0 -0
  41. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_faults.py +0 -0
  42. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_grid.py +0 -0
  43. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_grid_types.py +0 -0
  44. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_intervals_info.py +0 -0
  45. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_moved_functions.py +0 -0
  46. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_pillars.py +0 -0
  47. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_pixel_maps.py +0 -0
  48. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_points_functions.py +0 -0
  49. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_regular_grid.py +0 -0
  50. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_transmissibility.py +0 -0
  51. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_write_hdf5_from_caches.py +0 -0
  52. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_write_nexus_corp.py +0 -0
  53. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid/_xyz.py +0 -0
  54. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/__init__.py +0 -0
  55. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/_blocked_well_populate.py +0 -0
  56. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/_grid_skin.py +0 -0
  57. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/_grid_surface.py +0 -0
  58. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/_trajectory_intersects.py +0 -0
  59. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/grid_surface/grid_surface_cuda.py +0 -0
  60. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/lines/__init__.py +0 -0
  61. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/lines/_common.py +0 -0
  62. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/lines/_polyline.py +0 -0
  63. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/lines/_polyline_set.py +0 -0
  64. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/__init__.py +0 -0
  65. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_catalogue.py +0 -0
  66. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_context.py +0 -0
  67. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_forestry.py +0 -0
  68. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_grids.py +0 -0
  69. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_hdf5.py +0 -0
  70. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_model.py +0 -0
  71. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/model/_xml.py +0 -0
  72. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/__init__.py +0 -0
  73. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/_multiprocessing.py +0 -0
  74. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/wrappers/__init__.py +0 -0
  75. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/wrappers/blocked_well_mp.py +0 -0
  76. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/wrappers/grid_surface_mp.py +0 -0
  77. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/multi_processing/wrappers/mesh_mp.py +0 -0
  78. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/__init__.py +0 -0
  79. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/ab_toolbox.py +0 -0
  80. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/base.py +0 -0
  81. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/box_utilities.py +0 -0
  82. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/class_dict.py +0 -0
  83. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/consolidation.py +0 -0
  84. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/data/build.py +0 -0
  85. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/data/properties.json +0 -0
  86. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/dataframe.py +0 -0
  87. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/exceptions.py +0 -0
  88. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/factors.py +0 -0
  89. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/fine_coarse.py +0 -0
  90. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/grid_functions.py +0 -0
  91. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/intersection.py +0 -0
  92. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/keyword_files.py +0 -0
  93. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/load_data.py +0 -0
  94. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/point_inclusion.py +0 -0
  95. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/random_seed.py +0 -0
  96. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/read_nexus_fault.py +0 -0
  97. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/relperm.py +0 -0
  98. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/simple_lines.py +0 -0
  99. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/time.py +0 -0
  100. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/trademark.py +0 -0
  101. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/transmission.py +0 -0
  102. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/triangulation.py +0 -0
  103. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/uuid.py +0 -0
  104. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/vdb.py +0 -0
  105. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/vector_utilities.py +0 -0
  106. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/volume.py +0 -0
  107. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/wellspec_keywords.py +0 -0
  108. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/write_data.py +0 -0
  109. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/write_hdf5.py +0 -0
  110. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/xml_et.py +0 -0
  111. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/xml_namespaces.py +0 -0
  112. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/olio/zmap_reader.py +0 -0
  113. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/__init__.py +0 -0
  114. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/_utils.py +0 -0
  115. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/boundary_feature.py +0 -0
  116. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/boundary_feature_interpretation.py +0 -0
  117. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/earth_model_interpretation.py +0 -0
  118. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/fault_interpretation.py +0 -0
  119. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/fluid_boundary_feature.py +0 -0
  120. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/frontier_feature.py +0 -0
  121. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/generic_interpretation.py +0 -0
  122. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/genetic_boundary_feature.py +0 -0
  123. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/geobody_boundary_interpretation.py +0 -0
  124. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/geobody_feature.py +0 -0
  125. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/geobody_interpretation.py +0 -0
  126. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/geologic_unit_feature.py +0 -0
  127. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/horizon_interpretation.py +0 -0
  128. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/organization_feature.py +0 -0
  129. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/rock_fluid_unit_feature.py +0 -0
  130. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/structural_organization_interpretation.py +0 -0
  131. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/tectonic_boundary_feature.py +0 -0
  132. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/wellbore_feature.py +0 -0
  133. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/organize/wellbore_interpretation.py +0 -0
  134. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/__init__.py +0 -0
  135. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/_collection_add_part.py +0 -0
  136. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/_collection_create_xml.py +0 -0
  137. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/_collection_get_attributes.py +0 -0
  138. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/_collection_support.py +0 -0
  139. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/_property.py +0 -0
  140. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/attribute_property_set.py +0 -0
  141. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/grid_property_collection.py +0 -0
  142. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/property_collection.py +0 -0
  143. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/property_common.py +0 -0
  144. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/property_kind.py +0 -0
  145. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/string_lookup.py +0 -0
  146. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/well_interval_property.py +0 -0
  147. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/well_interval_property_collection.py +0 -0
  148. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/well_log.py +0 -0
  149. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/property/well_log_collection.py +0 -0
  150. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/__init__.py +0 -0
  151. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_add_ab_properties.py +0 -0
  152. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_add_surfaces.py +0 -0
  153. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_grid_from_cp.py +0 -0
  154. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_import_nexus.py +0 -0
  155. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_import_vdb_all_grids.py +0 -0
  156. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/rq_import/_import_vdb_ensemble.py +0 -0
  157. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/__init__.py +0 -0
  158. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_binary_contact_interpretation.py +0 -0
  159. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_geologic_unit_interpretation.py +0 -0
  160. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_strata_common.py +0 -0
  161. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_stratigraphic_column.py +0 -0
  162. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_stratigraphic_column_rank.py +0 -0
  163. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_stratigraphic_unit_feature.py +0 -0
  164. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/strata/_stratigraphic_unit_interpretation.py +0 -0
  165. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/__init__.py +0 -0
  166. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_base_surface.py +0 -0
  167. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_combined_surface.py +0 -0
  168. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_mesh.py +0 -0
  169. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_pointset.py +0 -0
  170. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_surface.py +0 -0
  171. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_tri_mesh.py +0 -0
  172. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_tri_mesh_stencil.py +0 -0
  173. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/surface/_triangulated_patch.py +0 -0
  174. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/__init__.py +0 -0
  175. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_any_time_series.py +0 -0
  176. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_from_nexus_summary.py +0 -0
  177. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_functions.py +0 -0
  178. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_geologic_time_series.py +0 -0
  179. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_time_duration.py +0 -0
  180. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/time_series/_time_series.py +0 -0
  181. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/__init__.py +0 -0
  182. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/_hexa_grid.py +0 -0
  183. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/_prism_grid.py +0 -0
  184. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/_pyramid_grid.py +0 -0
  185. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/_tetra_grid.py +0 -0
  186. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/unstructured/_unstructured_grid.py +0 -0
  187. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/weights_and_measures/__init__.py +0 -0
  188. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/weights_and_measures/nexus_units.py +0 -0
  189. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/weights_and_measures/weights_and_measures.py +0 -0
  190. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/__init__.py +0 -0
  191. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_blocked_well.py +0 -0
  192. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_deviation_survey.py +0 -0
  193. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_md_datum.py +0 -0
  194. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_trajectory.py +0 -0
  195. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_wellbore_frame.py +0 -0
  196. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_wellbore_marker.py +0 -0
  197. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/_wellbore_marker_frame.py +0 -0
  198. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/blocked_well_frame.py +0 -0
  199. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/well_object_funcs.py +0 -0
  200. {resqpy-4.18.2 → resqpy-4.18.4}/resqpy/well/well_utils.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: resqpy
3
- Version: 4.18.2
3
+ Version: 4.18.4
4
4
  Summary: Python API for working with RESQML models
5
5
  Home-page: https://github.com/bp/resqpy
6
6
  License: MIT
@@ -9,7 +9,7 @@ build-backend = "poetry.masonry.api"
9
9
 
10
10
  [tool.poetry]
11
11
  name = "resqpy"
12
- version = "4.18.2" # Set at build time
12
+ version = "4.18.4" # Set at build time
13
13
  description = "Python API for working with RESQML models"
14
14
  authors = ["BP"]
15
15
  license = "MIT"
@@ -28,6 +28,6 @@
28
28
 
29
29
  import logging
30
30
 
31
- __version__ = "4.18.2" # Set at build time
31
+ __version__ = "4.18.4" # Set at build time
32
32
  log = logging.getLogger(__name__)
33
33
  log.info(f"Imported resqpy version {__version__}")
@@ -24,27 +24,6 @@ import resqpy.olio.vector_utilities as vec
24
24
  # note: resqpy.grid_surface._grid_surface_cuda will be imported by the find_faces_to_represent_surface() function if needed
25
25
 
26
26
 
27
- @njit # pragma: no cover
28
- def _bitwise_count_njit(a: np.ndarray) -> int:
29
- """Deprecated: only needed till numpy versions < 2.0.0 are dropped."""
30
- c: int = 0
31
- c += np.count_nonzero(np.bitwise_and(a, 0x01))
32
- c += np.count_nonzero(np.bitwise_and(a, 0x02))
33
- c += np.count_nonzero(np.bitwise_and(a, 0x04))
34
- c += np.count_nonzero(np.bitwise_and(a, 0x08))
35
- c += np.count_nonzero(np.bitwise_and(a, 0x10))
36
- c += np.count_nonzero(np.bitwise_and(a, 0x20))
37
- c += np.count_nonzero(np.bitwise_and(a, 0x40))
38
- c += np.count_nonzero(np.bitwise_and(a, 0x80))
39
- return c
40
-
41
-
42
- if hasattr(np, 'bitwise_count'):
43
- bitwise_count = np.bitwise_count
44
- else:
45
- bitwise_count = _bitwise_count_njit
46
-
47
-
48
27
  def find_faces_to_represent_surface_staffa(grid, surface, name, feature_type = "fault", progress_fn = None):
49
28
  """Returns a grid connection set containing those cell faces which are deemed to represent the surface.
50
29
 
@@ -1585,12 +1564,18 @@ def packed_bisector_from_face_indices( # type: ignore
1585
1564
  _set_packed_bisector_outside_box(array, box, box_array, grid_extent_kji[2] % 8)
1586
1565
 
1587
1566
  # check all array elements are not the same
1588
- true_count = np.sum(bitwise_count(array)) # note: will usually include some padding bits, so not so true!
1567
+ if hasattr(np, 'bitwise_count'):
1568
+ true_count = np.sum(np.bitwise_count(array))
1569
+ else:
1570
+ true_count = _bitwise_count_njit(array) # note: will usually include some padding bits, so not so true!
1589
1571
  cell_count = np.prod(grid_extent_kji)
1590
1572
  assert (0 < true_count < cell_count), "face set for surface is leaky or empty (surface does not intersect grid)"
1591
1573
 
1592
1574
  # negate the array if it minimises the mean k and determine if the surface is a curtain
1593
- is_curtain = _packed_shallow_or_curtain(array, true_count, raw_bisector)
1575
+ is_curtain = _packed_shallow_or_curtain_temp_bitwise_count(array, true_count, raw_bisector)
1576
+ # todo: switch to numpy bitwise_count when numba supports it and resqpy has dropped older numpy versions
1577
+ # is_curtain = _packed_shallow_or_curtain(array, true_count, raw_bisector)
1578
+ print(f'**** array shape: {array.shape}; dtype: {array.dtype}')
1594
1579
 
1595
1580
  return array, is_curtain
1596
1581
 
@@ -2028,20 +2013,22 @@ def _fill_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.ndarray, o
2028
2013
  going = True
2029
2014
 
2030
2015
 
2031
- # TODO: uncomment njit
2032
- #@njit # pragma: no cover
2016
+ @njit # pragma: no cover
2033
2017
  def _fill_packed_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.ndarray, open_i: np.ndarray):
2034
2018
  nk: int = bisect.shape[0]
2035
2019
  nj: int = bisect.shape[1]
2036
2020
  ni: int = bisect.shape[2]
2037
2021
  going: bool = True
2022
+ m: np.uint8 = np.uint8(0)
2023
+ om: np.uint8 = np.uint8(0)
2024
+ oi: np.uint8 = np.uint8(0)
2038
2025
  while going:
2039
2026
  going = False
2040
2027
  for k in range(nk):
2041
2028
  for j in range(nj):
2042
2029
  for i in range(ni):
2043
- m = bisect[k, j, i] # 8 bools packed into a uint8
2044
- if bisect[k, j, i] == 255: # all 8 values already set
2030
+ m = np.uint8(bisect[k, j, i]) # 8 bools packed into a uint8
2031
+ if bisect[k, j, i] == np.uint8(0xFF): # all 8 values already set
2045
2032
  continue
2046
2033
  om = m # copy to check for changes later
2047
2034
  if k:
@@ -2052,14 +2039,14 @@ def _fill_packed_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.nda
2052
2039
  m |= (bisect[k, j - 1, i] & open_j[k, j - 1, i])
2053
2040
  if j < nj - 1:
2054
2041
  m |= (bisect[k, j + 1, i] & open_j[k, j, i])
2055
- oi = open_i[k, j, i]
2056
- m |= (m >> 1) & (oi >> 1)
2057
- m |= (m << 1) & oi
2042
+ oi = np.uint8(open_i[k, j, i]) # type: ignore
2043
+ m |= (m >> 1) & (oi >> 1) # type: ignore
2044
+ m |= (m << 1) & oi # type: ignore
2058
2045
  # handle rollover bits for I
2059
- if i and (bisect[k, j, i - 1] & open_i[k, j, i - 1] & 1):
2060
- m |= 0x80
2046
+ if i and (bisect[k, j, i - 1] & open_i[k, j, i - 1] & np.uint8(0x01)):
2047
+ m |= np.uint8(0x80)
2061
2048
  if (i < ni - 1) and (oi & 1) and (bisect[k, j, i + 1] & 0x80):
2062
- m |= 1
2049
+ m |= np.uint8(0x01)
2063
2050
  if m != om:
2064
2051
  bisect[k, j, i] = m
2065
2052
  going = True
@@ -2088,8 +2075,7 @@ def _shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> bool:
2088
2075
  return is_curtain
2089
2076
 
2090
2077
 
2091
- # TODO: uncomment njit
2092
- #@njit # pragma: no cover
2078
+ @njit # pragma: no cover
2093
2079
  def _packed_shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> bool:
2094
2080
  # negate the packed bool array if it minimises the mean k and determine if the bisector indicates a curtain
2095
2081
  assert a.ndim == 3
@@ -2099,13 +2085,38 @@ def _packed_shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> boo
2099
2085
  is_curtain: bool = False
2100
2086
  layer_count: int = 0
2101
2087
  for k in range(a.shape[0]):
2102
- layer_count = np.sum(bitwise_count(a[k]))
2088
+ # np.bitwise_count() not yet supported by numba
2089
+ layer_count = np.sum(np.bitwise_count(a[k]), dtype = np.int64) # type: ignore
2090
+ k_sum += (k + 1) * layer_count
2091
+ opposite_k_sum += (k + 1) * (layer_cell_count - layer_count)
2092
+ mean_k: float = float(k_sum) / float(true_count)
2093
+ opposite_mean_k: float = float(opposite_k_sum) / float(8 * a.size - true_count)
2094
+ if mean_k > opposite_mean_k and not raw:
2095
+ a[:] = np.invert(a)
2096
+ if abs(mean_k - opposite_mean_k) <= 0.001:
2097
+ # log.warning('unable to determine which side of surface is shallower')
2098
+ is_curtain = True
2099
+ return is_curtain
2100
+
2101
+
2102
+ @njit # pragma: no cover
2103
+ def _packed_shallow_or_curtain_temp_bitwise_count(a: np.ndarray, true_count: int, raw: bool) -> bool:
2104
+ # negate the packed bool array if it minimises the mean k and determine if the bisector indicates a curtain
2105
+ assert a.ndim == 3
2106
+ # note: following 'cell count' includes padding bits
2107
+ layer_cell_count: np.int64 = 8 * a.shape[1] * a.shape[2] # type: ignore
2108
+ k_sum: np.int64 = 0 # type: ignore
2109
+ opposite_k_sum: np.int64 = 0 # type: ignore
2110
+ is_curtain: bool = False
2111
+ layer_count: np.int64 = 0 # type: ignore
2112
+ for k in range(a.shape[0]):
2113
+ layer_count = _bitwise_count_njit(a[k])
2103
2114
  k_sum += (k + 1) * layer_count
2104
2115
  opposite_k_sum += (k + 1) * (layer_cell_count - layer_count)
2105
2116
  mean_k: float = float(k_sum) / float(true_count)
2106
2117
  opposite_mean_k: float = float(opposite_k_sum) / float(8 * a.size - true_count)
2107
2118
  if mean_k > opposite_mean_k and not raw:
2108
- a[:] = np.invert(a, dtype = np.uint8)
2119
+ a[:] = np.invert(a)
2109
2120
  if abs(mean_k - opposite_mean_k) <= 0.001:
2110
2121
  # log.warning('unable to determine which side of surface is shallower')
2111
2122
  is_curtain = True
@@ -2175,7 +2186,7 @@ def _packed_box_face_arrays_from_indices( # type: ignore
2175
2186
  i_a = np.zeros(tuple(box_shape), dtype = np.uint8)
2176
2187
  ko = box[0, 0]
2177
2188
  jo = box[0, 1]
2178
- io = box[0, 2]
2189
+ io = box[0, 2] * 8
2179
2190
  if k_faces_kji0 is not None:
2180
2191
  _set_packed_face_array(k_a, k_faces_kji0, ko, jo, io)
2181
2192
  if j_faces_kji0 is not None:
@@ -2274,3 +2285,18 @@ def _shape_packed(unpacked_shape):
2274
2285
  head = list(unpacked_shape[:-1])
2275
2286
  head.append(shrunken)
2276
2287
  return tuple(head)
2288
+
2289
+
2290
+ @njit # pragma: no cover
2291
+ def _bitwise_count_njit(a: np.ndarray) -> np.int64:
2292
+ """Deprecated: only needed till numpy versions < 2.0.0 are dropped."""
2293
+ c: np.int64 = 0 # type: ignore
2294
+ c += np.count_nonzero(np.bitwise_and(a, 0x01))
2295
+ c += np.count_nonzero(np.bitwise_and(a, 0x02))
2296
+ c += np.count_nonzero(np.bitwise_and(a, 0x04))
2297
+ c += np.count_nonzero(np.bitwise_and(a, 0x08))
2298
+ c += np.count_nonzero(np.bitwise_and(a, 0x10))
2299
+ c += np.count_nonzero(np.bitwise_and(a, 0x20))
2300
+ c += np.count_nonzero(np.bitwise_and(a, 0x40))
2301
+ c += np.count_nonzero(np.bitwise_and(a, 0x80))
2302
+ return c
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes