Source code for yt.frontends.gdf.io
import numpy as np
from yt.funcs import mylog
from yt.geometry.selection_routines import GridSelector
from yt.utilities.io_handler import BaseParticleIOHandler
from yt.utilities.on_demand_imports import _h5py as h5py
def _grid_dname(grid_id):
return "/data/grid_%010i" % grid_id
def _field_dname(grid_id, field_name):
return f"{_grid_dname(grid_id)}/{field_name}"
# TODO all particle bits were removed
[docs]
class IOHandlerGDFHDF5(BaseParticleIOHandler):
_dataset_type = "grid_data_format"
_offset_string = "data:offsets=0"
_data_string = "data:datatype=0"
def _read_fluid_selection(self, chunks, selector, fields, size):
rv = {}
chunks = list(chunks)
if isinstance(selector, GridSelector):
if not (len(chunks) == len(chunks[0].objs) == 1):
raise RuntimeError
grid = chunks[0].objs[0]
h5f = h5py.File(grid.filename, mode="r")
gds = h5f.get(_grid_dname(grid.id))
for ftype, fname in fields:
if self.ds.field_ordering == 1:
rv[ftype, fname] = gds.get(fname)[()].swapaxes(0, 2)
else:
rv[ftype, fname] = gds.get(fname)[()]
h5f.close()
return rv
if size is None:
size = sum(grid.count(selector) for chunk in chunks for grid in chunk.objs)
if any((ftype != "gdf" for ftype, fname in fields)):
raise NotImplementedError
for field in fields:
ftype, fname = field
fsize = size
# check the dtype instead
rv[field] = np.empty(fsize, dtype="float64")
ngrids = sum(len(chunk.objs) for chunk in chunks)
mylog.debug(
"Reading %s cells of %s fields in %s blocks",
size,
[fn for ft, fn in fields],
ngrids,
)
ind = 0
for chunk in chunks:
fid = None
for grid in chunk.objs:
if grid.filename is None:
continue
if fid is None:
fid = h5py.h5f.open(
bytes(grid.filename, "utf-8"), h5py.h5f.ACC_RDONLY
)
if self.ds.field_ordering == 1:
# check the dtype instead
data = np.empty(grid.ActiveDimensions[::-1], dtype="float64")
data_view = data.swapaxes(0, 2)
else:
# check the dtype instead
data_view = data = np.empty(grid.ActiveDimensions, dtype="float64")
for field in fields:
ftype, fname = field
dg = h5py.h5d.open(
fid, bytes(_field_dname(grid.id, fname), "utf-8")
)
dg.read(h5py.h5s.ALL, h5py.h5s.ALL, data)
# caches
nd = grid.select(selector, data_view, rv[field], ind)
ind += nd # I don't get that part, only last nd is added
if fid is not None:
fid.close()
return rv