Skip to content

Commit

Permalink
RFC: simplify array transformation logic in GasField.map
Browse files Browse the repository at this point in the history
  • Loading branch information
neutrinoceros committed May 6, 2024
1 parent 43aded1 commit 7bbfb74
Showing 1 changed file with 15 additions and 21 deletions.
36 changes: 15 additions & 21 deletions nonos/api/analysis.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import dataclasses
import json
import warnings
from collections import deque
from collections.abc import ItemsView, KeysView, ValuesView
from functools import cached_property
from pathlib import Path
Expand Down Expand Up @@ -543,15 +544,11 @@ def map(
else:
data_view = self.data.view()

datamoved_tmp = np.moveaxis(data_view, self.shape.index(1), 0)
datamoved = np.moveaxis(
datamoved_tmp[0], datamoved_tmp[0].shape.index(1), 0
)
dict_plotable = {
"abscissa": abscissa_key,
"field": data_key,
abscissa_key: abscissa_value,
data_key: datamoved[0],
data_key: data_view.squeeze(),
}
elif dimension == 2:
# meshgrid in polar coordinates P, R (if "R", "phi") or R, P (if "phi", "R")
Expand Down Expand Up @@ -583,29 +580,26 @@ def map(
else:
data_view = self.data.view()

ordered = meshgrid_conversion["ordered"]
# move the axis of reduction in the front in order to
# perform the operation 3D(i,j,1) -> 2D(i,j) in a general way,
# whatever the position of (i,j,1)
# for that we must be careful to change the order ("ordered") if the data is reversed
# in practice, this is tricky only if the "1" is in the middle:
# 3D(i,1,k) -> 2D(i,k) is not a direct triedre anymore, we need to do 2D(i,k).T = 2D(k,i)
position_of_3d_dimension = self.shape.index(1)
datamoved = np.moveaxis(data_view, position_of_3d_dimension, 0)
if position_of_3d_dimension == 1:
ordered = not ordered
if ordered:
data_value = datamoved[0].T
else:
data_value = datamoved[0]
def rotate_axes(arr, shift: int):
axes_in = tuple(range(arr.ndim))
axes_out = deque(axes_in)
axes_out.rotate(shift)
return np.moveaxis(arr, axes_in, axes_out)

# make reduction axis the first axis then drop (squeeze) it,
# while preserving the original (cyclic) order in the other two axes
data_view = rotate_axes(data_view, shift=self.shape.index(1)).squeeze()

if meshgrid_conversion["ordered"]:
data_view = data_view.T

dict_plotable = {
"abscissa": abscissa_key,
"ordinate": ordinate_key,
"field": data_key,
abscissa_key: abscissa_value,
ordinate_key: ordinate_value,
data_key: data_value,
data_key: data_view,
}
else:
raise RuntimeError
Expand Down

0 comments on commit 7bbfb74

Please sign in to comment.