From a59d547ebab00d385e254f66411356b6af5d5cc4 Mon Sep 17 00:00:00 2001 From: tomsail Date: Sun, 28 Jul 2024 15:42:08 +0200 Subject: [PATCH 1/3] fix: fix bug for 3D data inversion --- pyproject.toml | 4 ++++ xarray_selafin/xarray_backend.py | 21 ++++++++++----------- 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/pyproject.toml b/pyproject.toml index 6ecb370..9da99bf 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -26,3 +26,7 @@ xarray = {version = "*", extras = ["io"]} [build-system] requires = ["poetry-core"] build-backend = "poetry.core.masonry.api" + +[tool.black] +target-version = ['py37'] +line-length = 107 diff --git a/xarray_selafin/xarray_backend.py b/xarray_selafin/xarray_backend.py index 92890d8..c74e102 100644 --- a/xarray_selafin/xarray_backend.py +++ b/xarray_selafin/xarray_backend.py @@ -69,7 +69,7 @@ def write_serafin(fout, ds): first_date_str = first_time.values.astype(str) # "1900-01-01T00:00:00.000000000" first_date_str = first_date_str.rstrip("0") + "0" # "1900-01-01T00:00:00.0" try: - date = datetime.strptime(first_date_str, '%Y-%m-%dT%H:%M:%S.%f') + date = datetime.strptime(first_date_str, "%Y-%m-%dT%H:%M:%S.%f") slf_header.date = attrgetter("year", "month", "day", "hour", "minute", "second")(date) except ValueError: slf_header.date = DEFAULT_DATE_START @@ -165,6 +165,8 @@ def write_serafin(fout, ds): temp[iv] = ds[var] else: temp[iv] = ds.isel(time=it)[var] + if slf_header.nb_planes > 1: + temp[iv] = np.reshape(np.ravel(temp[iv]), (slf_header.nb_nodes_2d, slf_header.nb_planes)) resout.write_entire_frame( slf_header, t_, @@ -233,15 +235,14 @@ def _raw_indexing_method(self, key): for it, t in enumerate(time_indices): temp = self.slf_reader.read_var_in_frame(t, self.var) # shape = (nb_nodes,) temp = np.reshape(temp, self.shape[1:]) # shape = (nb_nodes_2d, nb_planes) - if node_key == slice(None) and plan_key == slice( - None - ): # speedup if not selection + if node_key == slice(None) and plan_key == slice(None): # speedup if not selection data[it] = temp else: if plan_key is None: data[it] = temp[node_indices] else: - data[it] = temp[node_indices][:, plan_indices] + values = temp[node_indices][:, plan_indices] + data[it] = np.reshape(values, (len(plan_indices), len(node_indices))).T # Remove dimension if key was an integer if isinstance(node_key, int): @@ -305,14 +306,15 @@ def open_dataset( if is_2d: data[time_index, :] = values else: - data[time_index, :, :] = values.reshape(npoin2, nplan) + data[time_index, :, :] = np.reshape(values, (nplan, npoin2)).T data_vars[var] = xr.Variable(dims=dims, data=data) coords = { "x": ("node", x[:npoin2]), "y": ("node", y[:npoin2]), "time": times, - # Consider how to include IPOBO (with node and plan dimensions?) if it's essential for your analysis + # Consider how to include IPOBO (with node and plan dimensions?) + # if it's essential for your analysis } ds = xr.Dataset(data_vars=data_vars, coords=coords) @@ -327,10 +329,7 @@ def open_dataset( if not is_2d: ds.attrs["ikle3"] = np.reshape(slf.header.ikle, (slf.header.nb_elements, ndp3)) ds.attrs["variables"] = { - var_ID: ( - name.decode(Serafin.SLF_EIT).rstrip(), - unit.decode(Serafin.SLF_EIT).rstrip() - ) + var_ID: (name.decode(Serafin.SLF_EIT).rstrip(), unit.decode(Serafin.SLF_EIT).rstrip()) for var_ID, name, unit in slf.header.iter_on_all_variables() } ds.attrs["date_start"] = slf.header.date From 5045a98255248ee6459877974d517a46d021647b Mon Sep 17 00:00:00 2001 From: tomsail Date: Tue, 15 Oct 2024 18:14:57 +0200 Subject: [PATCH 2/3] fix: transposed plan and nodes --- xarray_selafin/xarray_backend.py | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/xarray_selafin/xarray_backend.py b/xarray_selafin/xarray_backend.py index c74e102..41beaea 100644 --- a/xarray_selafin/xarray_backend.py +++ b/xarray_selafin/xarray_backend.py @@ -133,7 +133,7 @@ def write_serafin(fout, ds): if "plan" in ds.dims: # 3D slf_header.nb_planes = len(ds.plan) slf_header.is_2d = False - shape = (slf_header.nb_var, slf_header.nb_nodes_2d, slf_header.nb_planes) + shape = (slf_header.nb_var, slf_header.nb_planes, slf_header.nb_nodes_2d) else: # 2D (converted if required) # if ds.attrs["type"] == "3D": # slf_header.is_2d = False # to enable conversion from 3D @@ -166,7 +166,7 @@ def write_serafin(fout, ds): else: temp[iv] = ds.isel(time=it)[var] if slf_header.nb_planes > 1: - temp[iv] = np.reshape(np.ravel(temp[iv]), (slf_header.nb_nodes_2d, slf_header.nb_planes)) + temp[iv] = np.reshape(np.ravel(temp[iv]), (slf_header.nb_planes, slf_header.nb_nodes_2d)) resout.write_entire_frame( slf_header, t_, @@ -291,8 +291,8 @@ def open_dataset( shape = (len(times), npoin2) dims = ["time", "node"] else: - shape = (len(times), npoin2, nplan) - dims = ["time", "node", "plan"] + shape = (len(times), nplan, npoin2) + dims = ["time", "plan", "node"] for var in vars: if lazy_loading: @@ -306,7 +306,7 @@ def open_dataset( if is_2d: data[time_index, :] = values else: - data[time_index, :, :] = np.reshape(values, (nplan, npoin2)).T + data[time_index, :, :] = np.reshape(values, (nplan, npoin2)) data_vars[var] = xr.Variable(dims=dims, data=data) coords = { From eca55c97804bb2210b079112aeeaa6d0488fcdfb Mon Sep 17 00:00:00 2001 From: tomsail Date: Wed, 16 Oct 2024 09:37:00 +0200 Subject: [PATCH 3/3] bump version number to 0.1.9 --- pyproject.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pyproject.toml b/pyproject.toml index 9da99bf..439a69f 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "xarray-selafin" -version = "0.1.8" +version = "0.1.9" description = "" authors = ["tomsail ", "lucduron "] readme = "README.md"