resqpy 4.18.3__tar.gz → 4.18.5__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.3 → resqpy-4.18.5}/PKG-INFO +1 -1
  2. {resqpy-4.18.3 → resqpy-4.18.5}/pyproject.toml +1 -1
  3. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/__init__.py +1 -1
  4. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/_find_faces.py +62 -37
  5. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/wrappers/grid_surface_mp.py +1 -1
  6. {resqpy-4.18.3 → resqpy-4.18.5}/LICENSE +0 -0
  7. {resqpy-4.18.3 → resqpy-4.18.5}/README.md +0 -0
  8. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/crs.py +0 -0
  9. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/__init__.py +0 -0
  10. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_edges_per_column_property_array.py +0 -0
  11. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_faults.py +0 -0
  12. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_one_blocked_well_property.py +0 -0
  13. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_one_grid_property_array.py +0 -0
  14. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_single_cell_grid.py +0 -0
  15. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_wells_from_ascii_file.py +0 -0
  16. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_add_zone_by_layer_property.py +0 -0
  17. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_coarsened_grid.py +0 -0
  18. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_common.py +0 -0
  19. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_copy_grid.py +0 -0
  20. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_drape_to_surface.py +0 -0
  21. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_extract_box.py +0 -0
  22. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_extract_box_for_well.py +0 -0
  23. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_fault_throw_scaling.py +0 -0
  24. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_gather_ensemble.py +0 -0
  25. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_interpolated_grid.py +0 -0
  26. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_local_depth_adjustment.py +0 -0
  27. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_refined_grid.py +0 -0
  28. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_tilted_grid.py +0 -0
  29. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_unsplit_grid.py +0 -0
  30. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_zonal_grid.py +0 -0
  31. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/derived_model/_zone_layer_ranges_from_array.py +0 -0
  32. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/fault/__init__.py +0 -0
  33. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/fault/_gcs_functions.py +0 -0
  34. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/fault/_grid_connection_set.py +0 -0
  35. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/__init__.py +0 -0
  36. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_cell_properties.py +0 -0
  37. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_connection_sets.py +0 -0
  38. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_create_grid_xml.py +0 -0
  39. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_defined_geometry.py +0 -0
  40. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_extract_functions.py +0 -0
  41. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_face_functions.py +0 -0
  42. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_faults.py +0 -0
  43. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_grid.py +0 -0
  44. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_grid_types.py +0 -0
  45. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_intervals_info.py +0 -0
  46. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_moved_functions.py +0 -0
  47. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_pillars.py +0 -0
  48. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_pixel_maps.py +0 -0
  49. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_points_functions.py +0 -0
  50. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_regular_grid.py +0 -0
  51. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_transmissibility.py +0 -0
  52. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_write_hdf5_from_caches.py +0 -0
  53. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_write_nexus_corp.py +0 -0
  54. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid/_xyz.py +0 -0
  55. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/__init__.py +0 -0
  56. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/_blocked_well_populate.py +0 -0
  57. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/_grid_skin.py +0 -0
  58. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/_grid_surface.py +0 -0
  59. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/_trajectory_intersects.py +0 -0
  60. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/grid_surface/grid_surface_cuda.py +0 -0
  61. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/lines/__init__.py +0 -0
  62. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/lines/_common.py +0 -0
  63. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/lines/_polyline.py +0 -0
  64. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/lines/_polyline_set.py +0 -0
  65. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/__init__.py +0 -0
  66. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_catalogue.py +0 -0
  67. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_context.py +0 -0
  68. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_forestry.py +0 -0
  69. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_grids.py +0 -0
  70. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_hdf5.py +0 -0
  71. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_model.py +0 -0
  72. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/model/_xml.py +0 -0
  73. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/__init__.py +0 -0
  74. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/_multiprocessing.py +0 -0
  75. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/wrappers/__init__.py +0 -0
  76. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/wrappers/blocked_well_mp.py +0 -0
  77. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/multi_processing/wrappers/mesh_mp.py +0 -0
  78. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/__init__.py +0 -0
  79. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/ab_toolbox.py +0 -0
  80. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/base.py +0 -0
  81. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/box_utilities.py +0 -0
  82. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/class_dict.py +0 -0
  83. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/consolidation.py +0 -0
  84. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/data/build.py +0 -0
  85. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/data/properties.json +0 -0
  86. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/dataframe.py +0 -0
  87. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/exceptions.py +0 -0
  88. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/factors.py +0 -0
  89. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/fine_coarse.py +0 -0
  90. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/grid_functions.py +0 -0
  91. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/intersection.py +0 -0
  92. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/keyword_files.py +0 -0
  93. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/load_data.py +0 -0
  94. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/point_inclusion.py +0 -0
  95. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/random_seed.py +0 -0
  96. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/read_nexus_fault.py +0 -0
  97. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/relperm.py +0 -0
  98. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/simple_lines.py +0 -0
  99. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/time.py +0 -0
  100. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/trademark.py +0 -0
  101. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/transmission.py +0 -0
  102. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/triangulation.py +0 -0
  103. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/uuid.py +0 -0
  104. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/vdb.py +0 -0
  105. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/vector_utilities.py +0 -0
  106. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/volume.py +0 -0
  107. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/wellspec_keywords.py +0 -0
  108. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/write_data.py +0 -0
  109. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/write_hdf5.py +0 -0
  110. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/xml_et.py +0 -0
  111. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/xml_namespaces.py +0 -0
  112. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/olio/zmap_reader.py +0 -0
  113. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/__init__.py +0 -0
  114. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/_utils.py +0 -0
  115. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/boundary_feature.py +0 -0
  116. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/boundary_feature_interpretation.py +0 -0
  117. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/earth_model_interpretation.py +0 -0
  118. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/fault_interpretation.py +0 -0
  119. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/fluid_boundary_feature.py +0 -0
  120. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/frontier_feature.py +0 -0
  121. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/generic_interpretation.py +0 -0
  122. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/genetic_boundary_feature.py +0 -0
  123. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/geobody_boundary_interpretation.py +0 -0
  124. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/geobody_feature.py +0 -0
  125. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/geobody_interpretation.py +0 -0
  126. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/geologic_unit_feature.py +0 -0
  127. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/horizon_interpretation.py +0 -0
  128. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/organization_feature.py +0 -0
  129. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/rock_fluid_unit_feature.py +0 -0
  130. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/structural_organization_interpretation.py +0 -0
  131. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/tectonic_boundary_feature.py +0 -0
  132. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/wellbore_feature.py +0 -0
  133. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/organize/wellbore_interpretation.py +0 -0
  134. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/__init__.py +0 -0
  135. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/_collection_add_part.py +0 -0
  136. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/_collection_create_xml.py +0 -0
  137. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/_collection_get_attributes.py +0 -0
  138. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/_collection_support.py +0 -0
  139. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/_property.py +0 -0
  140. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/attribute_property_set.py +0 -0
  141. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/grid_property_collection.py +0 -0
  142. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/property_collection.py +0 -0
  143. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/property_common.py +0 -0
  144. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/property_kind.py +0 -0
  145. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/string_lookup.py +0 -0
  146. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/well_interval_property.py +0 -0
  147. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/well_interval_property_collection.py +0 -0
  148. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/well_log.py +0 -0
  149. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/property/well_log_collection.py +0 -0
  150. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/__init__.py +0 -0
  151. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_add_ab_properties.py +0 -0
  152. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_add_surfaces.py +0 -0
  153. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_grid_from_cp.py +0 -0
  154. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_import_nexus.py +0 -0
  155. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_import_vdb_all_grids.py +0 -0
  156. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/rq_import/_import_vdb_ensemble.py +0 -0
  157. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/__init__.py +0 -0
  158. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_binary_contact_interpretation.py +0 -0
  159. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_geologic_unit_interpretation.py +0 -0
  160. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_strata_common.py +0 -0
  161. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_stratigraphic_column.py +0 -0
  162. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_stratigraphic_column_rank.py +0 -0
  163. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_stratigraphic_unit_feature.py +0 -0
  164. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/strata/_stratigraphic_unit_interpretation.py +0 -0
  165. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/__init__.py +0 -0
  166. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_base_surface.py +0 -0
  167. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_combined_surface.py +0 -0
  168. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_mesh.py +0 -0
  169. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_pointset.py +0 -0
  170. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_surface.py +0 -0
  171. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_tri_mesh.py +0 -0
  172. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_tri_mesh_stencil.py +0 -0
  173. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/surface/_triangulated_patch.py +0 -0
  174. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/__init__.py +0 -0
  175. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_any_time_series.py +0 -0
  176. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_from_nexus_summary.py +0 -0
  177. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_functions.py +0 -0
  178. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_geologic_time_series.py +0 -0
  179. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_time_duration.py +0 -0
  180. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/time_series/_time_series.py +0 -0
  181. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/__init__.py +0 -0
  182. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/_hexa_grid.py +0 -0
  183. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/_prism_grid.py +0 -0
  184. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/_pyramid_grid.py +0 -0
  185. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/_tetra_grid.py +0 -0
  186. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/unstructured/_unstructured_grid.py +0 -0
  187. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/weights_and_measures/__init__.py +0 -0
  188. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/weights_and_measures/nexus_units.py +0 -0
  189. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/weights_and_measures/weights_and_measures.py +0 -0
  190. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/__init__.py +0 -0
  191. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_blocked_well.py +0 -0
  192. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_deviation_survey.py +0 -0
  193. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_md_datum.py +0 -0
  194. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_trajectory.py +0 -0
  195. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_wellbore_frame.py +0 -0
  196. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_wellbore_marker.py +0 -0
  197. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/_wellbore_marker_frame.py +0 -0
  198. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/blocked_well_frame.py +0 -0
  199. {resqpy-4.18.3 → resqpy-4.18.5}/resqpy/well/well_object_funcs.py +0 -0
  200. {resqpy-4.18.3 → resqpy-4.18.5}/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.3
3
+ Version: 4.18.5
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.3" # Set at build time
12
+ version = "4.18.5" # 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.3" # Set at build time
31
+ __version__ = "4.18.5" # 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,17 @@ 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)
1594
1578
 
1595
1579
  return array, is_curtain
1596
1580
 
@@ -2028,20 +2012,22 @@ def _fill_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.ndarray, o
2028
2012
  going = True
2029
2013
 
2030
2014
 
2031
- # TODO: uncomment njit
2032
- #@njit # pragma: no cover
2015
+ @njit # pragma: no cover
2033
2016
  def _fill_packed_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.ndarray, open_i: np.ndarray):
2034
2017
  nk: int = bisect.shape[0]
2035
2018
  nj: int = bisect.shape[1]
2036
2019
  ni: int = bisect.shape[2]
2037
2020
  going: bool = True
2021
+ m: np.uint8 = np.uint8(0)
2022
+ om: np.uint8 = np.uint8(0)
2023
+ oi: np.uint8 = np.uint8(0)
2038
2024
  while going:
2039
2025
  going = False
2040
2026
  for k in range(nk):
2041
2027
  for j in range(nj):
2042
2028
  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
2029
+ m = np.uint8(bisect[k, j, i]) # 8 bools packed into a uint8
2030
+ if bisect[k, j, i] == np.uint8(0xFF): # all 8 values already set
2045
2031
  continue
2046
2032
  om = m # copy to check for changes later
2047
2033
  if k:
@@ -2052,14 +2038,14 @@ def _fill_packed_bisector(bisect: np.ndarray, open_k: np.ndarray, open_j: np.nda
2052
2038
  m |= (bisect[k, j - 1, i] & open_j[k, j - 1, i])
2053
2039
  if j < nj - 1:
2054
2040
  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
2041
+ oi = np.uint8(open_i[k, j, i]) # type: ignore
2042
+ m |= (m >> 1) & (oi >> 1) # type: ignore
2043
+ m |= (m << 1) & oi # type: ignore
2058
2044
  # handle rollover bits for I
2059
- if i and (bisect[k, j, i - 1] & open_i[k, j, i - 1] & 1):
2060
- m |= 0x80
2045
+ if i and (bisect[k, j, i - 1] & open_i[k, j, i - 1] & np.uint8(0x01)):
2046
+ m |= np.uint8(0x80)
2061
2047
  if (i < ni - 1) and (oi & 1) and (bisect[k, j, i + 1] & 0x80):
2062
- m |= 1
2048
+ m |= np.uint8(0x01)
2063
2049
  if m != om:
2064
2050
  bisect[k, j, i] = m
2065
2051
  going = True
@@ -2088,8 +2074,7 @@ def _shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> bool:
2088
2074
  return is_curtain
2089
2075
 
2090
2076
 
2091
- # TODO: uncomment njit
2092
- #@njit # pragma: no cover
2077
+ @njit # pragma: no cover
2093
2078
  def _packed_shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> bool:
2094
2079
  # negate the packed bool array if it minimises the mean k and determine if the bisector indicates a curtain
2095
2080
  assert a.ndim == 3
@@ -2099,13 +2084,38 @@ def _packed_shallow_or_curtain(a: np.ndarray, true_count: int, raw: bool) -> boo
2099
2084
  is_curtain: bool = False
2100
2085
  layer_count: int = 0
2101
2086
  for k in range(a.shape[0]):
2102
- layer_count = np.sum(bitwise_count(a[k]))
2087
+ # np.bitwise_count() not yet supported by numba
2088
+ layer_count = np.sum(np.bitwise_count(a[k]), dtype = np.int64) # type: ignore
2103
2089
  k_sum += (k + 1) * layer_count
2104
2090
  opposite_k_sum += (k + 1) * (layer_cell_count - layer_count)
2105
2091
  mean_k: float = float(k_sum) / float(true_count)
2106
2092
  opposite_mean_k: float = float(opposite_k_sum) / float(8 * a.size - true_count)
2107
2093
  if mean_k > opposite_mean_k and not raw:
2108
- a[:] = np.invert(a, dtype = np.uint8)
2094
+ a[:] = np.invert(a)
2095
+ if abs(mean_k - opposite_mean_k) <= 0.001:
2096
+ # log.warning('unable to determine which side of surface is shallower')
2097
+ is_curtain = True
2098
+ return is_curtain
2099
+
2100
+
2101
+ @njit # pragma: no cover
2102
+ def _packed_shallow_or_curtain_temp_bitwise_count(a: np.ndarray, true_count: int, raw: bool) -> bool:
2103
+ # negate the packed bool array if it minimises the mean k and determine if the bisector indicates a curtain
2104
+ assert a.ndim == 3
2105
+ # note: following 'cell count' includes padding bits
2106
+ layer_cell_count: np.int64 = 8 * a.shape[1] * a.shape[2] # type: ignore
2107
+ k_sum: np.int64 = 0 # type: ignore
2108
+ opposite_k_sum: np.int64 = 0 # type: ignore
2109
+ is_curtain: bool = False
2110
+ layer_count: np.int64 = 0 # type: ignore
2111
+ for k in range(a.shape[0]):
2112
+ layer_count = _bitwise_count_njit(a[k])
2113
+ k_sum += (k + 1) * layer_count
2114
+ opposite_k_sum += (k + 1) * (layer_cell_count - layer_count)
2115
+ mean_k: float = float(k_sum) / float(true_count)
2116
+ opposite_mean_k: float = float(opposite_k_sum) / float(8 * a.size - true_count)
2117
+ if mean_k > opposite_mean_k and not raw:
2118
+ a[:] = np.invert(a)
2109
2119
  if abs(mean_k - opposite_mean_k) <= 0.001:
2110
2120
  # log.warning('unable to determine which side of surface is shallower')
2111
2121
  is_curtain = True
@@ -2274,3 +2284,18 @@ def _shape_packed(unpacked_shape):
2274
2284
  head = list(unpacked_shape[:-1])
2275
2285
  head.append(shrunken)
2276
2286
  return tuple(head)
2287
+
2288
+
2289
+ @njit # pragma: no cover
2290
+ def _bitwise_count_njit(a: np.ndarray) -> np.int64:
2291
+ """Deprecated: only needed till numpy versions < 2.0.0 are dropped."""
2292
+ c: np.int64 = 0 # type: ignore
2293
+ c += np.count_nonzero(np.bitwise_and(a, 0x01))
2294
+ c += np.count_nonzero(np.bitwise_and(a, 0x02))
2295
+ c += np.count_nonzero(np.bitwise_and(a, 0x04))
2296
+ c += np.count_nonzero(np.bitwise_and(a, 0x08))
2297
+ c += np.count_nonzero(np.bitwise_and(a, 0x10))
2298
+ c += np.count_nonzero(np.bitwise_and(a, 0x20))
2299
+ c += np.count_nonzero(np.bitwise_and(a, 0x40))
2300
+ c += np.count_nonzero(np.bitwise_and(a, 0x80))
2301
+ return c
@@ -353,7 +353,7 @@ def find_faces_to_represent_surface_regular_wrapper(index: int,
353
353
  ('vertical' if is_curtain else 'sloping'),
354
354
  realization = realisation,
355
355
  indexable_element = "columns" if is_curtain else "cells",
356
- pre_packed = use_pack)
356
+ pre_packed = False if is_curtain else use_pack)
357
357
  elif p_name == 'grid shadow':
358
358
  if grid_pc is None:
359
359
  grid_pc = rqp.PropertyCollection()
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