Skip to content

Commit

Permalink
update(_ptr_to_recarray): slice pointers prior to setting data to rec…
Browse files Browse the repository at this point in the history
…array

update(_ptr_to_recarray): slice pointers prior to setting data to recarray

Closes #26
  • Loading branch information
jlarsen-usgs authored Aug 8, 2023
2 parents 48af4d1 + 8f0ec2f commit 959fe31
Showing 1 changed file with 11 additions and 14 deletions.
25 changes: 11 additions & 14 deletions modflowapi/extensions/data.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,21 +108,19 @@ def _ptr_to_recarray(self):
return
recarray = np.recarray((self._nbound[0],), self._dtype)
for name, ptr in self._ptrs.items():
if name == "auxvar" and self._naux[0] == 0:
continue
values = np.copy(ptr)
if name in self._boundvars:
for ix, nm in enumerate(self.parent._bound_vars):
recarray[nm][0 : self._nbound[0]] = values[
0 : self._nbound[0], ix
]
bnd_values = values[0 : self._nbound[0], ix]
recarray[nm][0 : self._nbound[0]] = bnd_values
elif name == "auxvar":
if self._naux[0] == 0:
continue
else:
for ix in range(self._naux[0]):
nm = self._auxnames[ix]
recarray[nm][0 : self._nbound[0]] = values[
0 : self._nbound[0], ix
]
for ix in range(self._naux[0]):
nm = self._auxnames[ix]
aux_values = values[0 : self._nbound[0], ix]
recarray[nm][0 : self._nbound[0]] = aux_values

elif name == "auxname_cst":
pass

Expand All @@ -135,9 +133,8 @@ def _ptr_to_recarray(self):
zip(*np.unravel_index(values, self.parent.model.shape))
)

recarray[name][0 : self._nbound[0]] = values[
0 : self._nbound[0]
]
values = values[0 : self._nbound[0]]
recarray[name][0 : self._nbound[0]] = values

return recarray

Expand Down

0 comments on commit 959fe31

Please sign in to comment.