resqpy 4.17.7__py3-none-any.whl → 4.17.9__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.
resqpy/__init__.py CHANGED
@@ -28,6 +28,6 @@
28
28
 
29
29
  import logging
30
30
 
31
- __version__ = "4.17.7" # Set at build time
31
+ __version__ = "4.17.9" # Set at build time
32
32
  log = logging.getLogger(__name__)
33
33
  log.info(f"Imported resqpy version {__version__}")
@@ -1145,8 +1145,12 @@ def find_faces_to_represent_surface_regular_optimised(grid,
1145
1145
  if progress_fn is not None:
1146
1146
  progress_fn(0.9)
1147
1147
 
1148
- assert k_faces_kji0 is not None or j_faces_kji0 is not None or i_faces_kji0 is not None, \
1149
- f'did not find any faces to represent {name}: surface does not intersect grid?'
1148
+ if k_faces_kji0 is None and j_faces_kji0 is None and i_faces_kji0 is None:
1149
+ log.error(f'did not find any faces to represent {name}: surface does not intersect grid?')
1150
+ if return_properties:
1151
+ return (None, {})
1152
+ else:
1153
+ return None
1150
1154
 
1151
1155
  log.debug("converting face sets into grid connection set")
1152
1156
  # NB: kji0 arrays in internal face protocol: used as cell_kji0 with polarity of 1
@@ -1210,14 +1214,27 @@ def find_faces_to_represent_surface_regular_optimised(grid,
1210
1214
  if return_bisector:
1211
1215
  if is_curtain:
1212
1216
  log.debug("preparing columns bisector")
1213
- bisector = column_bisector_from_face_indices((grid.nj, grid.ni), j_faces_kji0[:, 1:], i_faces_kji0[:, 1:])
1217
+ if j_faces_kji0 is None:
1218
+ j_faces_ji0 = np.empty((0, 2), dtype = np.int32)
1219
+ else:
1220
+ j_faces_ji0 = j_faces_kji0[:, 1:]
1221
+ if i_faces_kji0 is None:
1222
+ i_faces_ji0 = np.empty((0, 2), dtype = np.int32)
1223
+ else:
1224
+ i_faces_ji0 = i_faces_kji0[:, 1:]
1225
+ bisector = column_bisector_from_face_indices((grid.nj, grid.ni), j_faces_ji0, i_faces_ji0)
1214
1226
  # log.debug('finished preparing columns bisector')
1215
1227
  else:
1216
1228
  log.debug("preparing cells bisector")
1217
- bisector, is_curtain = bisector_from_face_indices(tuple(grid.extent_kji), k_faces_kji0, j_faces_kji0,
1218
- i_faces_kji0, raw_bisector)
1219
- if is_curtain:
1220
- bisector = bisector[0] # reduce to a columns property
1229
+ if ((k_faces_kji0 is None or len(k_faces_kji0) == 0) and
1230
+ (j_faces_kji0 is None or len(j_faces_kji0) == 0) and (i_faces_kji0 is None or len(i_faces_kji0) == 0)):
1231
+ bisector = np.ones((grid.nj, grid.ni), dtype = bool)
1232
+ is_curtain = True
1233
+ else:
1234
+ bisector, is_curtain = bisector_from_face_indices(tuple(grid.extent_kji), k_faces_kji0, j_faces_kji0,
1235
+ i_faces_kji0, raw_bisector)
1236
+ if is_curtain:
1237
+ bisector = bisector[0] # reduce to a columns property
1221
1238
 
1222
1239
  # note: following is a grid cells property, not a gcs property
1223
1240
  if return_shadow:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: resqpy
3
- Version: 4.17.7
3
+ Version: 4.17.9
4
4
  Summary: Python API for working with RESQML models
5
5
  Home-page: https://github.com/bp/resqpy
6
6
  License: MIT
@@ -1,4 +1,4 @@
1
- resqpy/__init__.py,sha256=OlYoKC9ueXWhExYM6jvqFLHUT0iCU89_PEglpF43lg0,556
1
+ resqpy/__init__.py,sha256=KWjboTTFsXPLF8Wav48XzHpgmQ-HK1vi0ieJnnT4pjY,556
2
2
  resqpy/crs.py,sha256=R7DfcTP5xGv5pu9Y8RHA2WVM9DjBCSVMoHcz4RmQ7Yw,27646
3
3
  resqpy/derived_model/__init__.py,sha256=NFvMSOKI3cxmH7lAbddV43JjoUj-r2G7ExEfOqinD1I,1982
4
4
  resqpy/derived_model/_add_edges_per_column_property_array.py,sha256=cpW3gwp6MSYIrtvFmCjoJXcyUsgGuCDbgmwlJCJebUs,6410
@@ -48,7 +48,7 @@ resqpy/grid/_write_nexus_corp.py,sha256=yEVfiObsedEAXX6UG6ZTf56kZnQVkd3lLqE2NpL-
48
48
  resqpy/grid/_xyz.py,sha256=RLQWOdM_DRoCj4JypwB5gUJ78HTdk5JnZHSeAzuU634,13087
49
49
  resqpy/grid_surface/__init__.py,sha256=rPr5zFFRmUDbMEhnCYsweSC3xugtQ8LnhZOf8JLIqIc,2765
50
50
  resqpy/grid_surface/_blocked_well_populate.py,sha256=Lme1AR-nLWOUlNnmHMVThk6jEg_lAZxWWtL82Yksppw,35867
51
- resqpy/grid_surface/_find_faces.py,sha256=630GeACc3Rx0kg7udie0TbPKIMIozqf1znPTYRCGTug,93063
51
+ resqpy/grid_surface/_find_faces.py,sha256=YK4gYEZnn-qBggE89OJnNy3meciFYKkzUl6M-hz7SAY,93805
52
52
  resqpy/grid_surface/_grid_skin.py,sha256=D0cjHkcuT5KCKb-8EZfXgh0GgJj3kzOBS2wVNXg4bfY,26056
53
53
  resqpy/grid_surface/_grid_surface.py,sha256=l2NJo7Kiucolbb_TlLPC7NGdksg_JahkihfsrJVq99w,14379
54
54
  resqpy/grid_surface/_trajectory_intersects.py,sha256=Och9cZYU9Y7ofovhPzsLyIblRUl2xj9_5nHH3fMZp-A,22498
@@ -194,7 +194,7 @@ resqpy/well/_wellbore_marker_frame.py,sha256=xvYH2_2Ie3a18LReFymbUrZboOx7Rhv5DOD
194
194
  resqpy/well/blocked_well_frame.py,sha256=eK7Ca6PcqI3pK-XurZIcXAV5Z4B9PFe6H8a7DqVkmBo,22560
195
195
  resqpy/well/well_object_funcs.py,sha256=tWufc8wahihzMEO-Ou1dncIttrf4bNo1qmLgh3I2pOM,24717
196
196
  resqpy/well/well_utils.py,sha256=zwpYjT85nXAwWBhYB1Pygu2SgouZ-44k6hEOnpoMfBI,5969
197
- resqpy-4.17.7.dist-info/LICENSE,sha256=2duHPIkKQyESMdQ4hKjL8CYEsYRHXaYxt0YQkzsUYE4,1059
198
- resqpy-4.17.7.dist-info/METADATA,sha256=eeVIiA5U6Mt3ff4dEh1mw3zzV437kF1igPn7sLPppB0,4028
199
- resqpy-4.17.7.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
200
- resqpy-4.17.7.dist-info/RECORD,,
197
+ resqpy-4.17.9.dist-info/LICENSE,sha256=2duHPIkKQyESMdQ4hKjL8CYEsYRHXaYxt0YQkzsUYE4,1059
198
+ resqpy-4.17.9.dist-info/METADATA,sha256=wpR64JX027ldisPJr1D5F5Rujkug4HrV0dAh6jZOfBU,4028
199
+ resqpy-4.17.9.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
200
+ resqpy-4.17.9.dist-info/RECORD,,