Skip to content

Commit

Permalink
Merge pull request #57 from ecmwf/bug/fix_traj_coords
Browse files Browse the repository at this point in the history
Bug/fix traj coords
  • Loading branch information
awarde96 authored Jan 15, 2025
2 parents 5cb9d1b + e7afe22 commit 73af20c
Show file tree
Hide file tree
Showing 4 changed files with 24 additions and 34 deletions.
6 changes: 3 additions & 3 deletions covjsonkit/decoder/BoundingBox.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,9 +84,9 @@ def to_xarray(self):
coverage["mars:metadata"]["step"]
] = coverage["ranges"][parameter]["values"]

datetimes = list(set(datetimes))
numbers = list(set(numbers))
steps = list(set(steps))
datetimes = sorted(list(set(datetimes)))
numbers = sorted(list(set(numbers)))
steps = sorted(list(set(steps)))

new_values = {}
for parameter in values.keys():
Expand Down
6 changes: 3 additions & 3 deletions covjsonkit/decoder/Path.py
Original file line number Diff line number Diff line change
Expand Up @@ -42,10 +42,12 @@ def to_xarray(self):
# Get coordinates
x = []
y = []
z = []
t = []
for coord in self.get_coordinates()["composite"]["values"]:
x.append(float(coord[1]))
y.append(float(coord[2]))
z.append(float(coord[3]))
t.append(coord[0])

values = {}
Expand Down Expand Up @@ -108,13 +110,11 @@ def to_xarray(self):
points=(["points"], list(range(0, len(x)))),
x=(["points"], x),
y=(["points"], y),
z=(["points"], z),
t=(["points"], t),
),
)
for mars_metadata in self.mars_metadata[0]:
ds.attrs[mars_metadata] = self.mars_metadata[0][mars_metadata]

# Add date attribute
# ds.attrs["date"] = self.get_coordinates()["t"]["values"][0]

return ds
44 changes: 17 additions & 27 deletions covjsonkit/encoder/Path.py
Original file line number Diff line number Diff line change
Expand Up @@ -109,6 +109,20 @@ def from_polytope(self, result):
}
)

for date in coords.keys():
coord = coords[date]["composite"]
coords[date]["composite"] = []
start = 0
for level in set(fields["l"]):
for s in set(fields["s"]):
if (date, level, fields["number"][0], fields["param"][0], s) in range_dict:
cor_len = len(range_dict[(date, level, fields["number"][0], fields["param"][0], s)])
end = start + cor_len
for cor in coord[int(start) : int(end)]:
coords[date]["composite"].append([s, cor[0], cor[1], level])
start = end
logging.debug("The coordinates returned from walking tree: %s", coords) # noqa: E501

combined_dict = {}

for date in fields["dates"]:
Expand All @@ -122,7 +136,7 @@ def from_polytope(self, result):
if para not in combined_dict[date][num]:
combined_dict[date][num][para] = {}
# for s, value in range_dict[date][level][num][para].items():
for s in fields["s"]:
for s in set(fields["s"]):
key = (date, level, num, para, s)
# for k, v in range_dict.items():
# if k == key:
Expand All @@ -138,50 +152,26 @@ def from_polytope(self, result):

logging.debug("The values returned from combined dicts: %s", combined_dict) # noqa: E501

levels = fields["levels"]
if fields["param"] == 0:
raise ValueError("No parameters were returned, date requested may be out of range")
for para in fields["param"]:
self.add_parameter(para)

logging.debug("The parameters added were: %s", self.parameters) # noqa: E501

for date in coords.keys():
coord = coords[date]["composite"]
coords[date]["composite"] = []
for level in levels:
start = 0
for i, s in enumerate(fields["s"]):
end = start + len(coord) / len(fields["s"])
for cor in coord[int(start) : int(end)]:
if len(fields["l"]) == 1:
coords[date]["composite"].append([s, cor[0], cor[1], fields["l"][0]])
elif len(fields["l"]) == 0:
coords[date]["composite"].append([s, cor[0], cor[1], level])
else:
coords[date]["composite"].append([s, cor[0], cor[1], fields["l"][i]])
start = end
logging.debug("The coordinates returned from walking tree: %s", coords) # noqa: E501

for date in combined_dict.keys():
for num in combined_dict[date].keys():
val_dict = {}
# for step in combined_dict[date][num][self.parameters[0]].keys():
# val_dict[step] = {}
for para in combined_dict[date][num].keys():
if para not in val_dict:
val_dict[para] = []
for step in combined_dict[date][num][para].keys():
val_dict[para].extend(combined_dict[date][num][para][step])
# for step in val_dict.keys():
mm = mars_metadata.copy()
mm["number"] = num
# mm["step"] = step
# temp = []
# for coord in coords[date]["composite"]:
# temp.append([step] + coord)
# coords[date]["composite"] = temp
mm["Forecast date"] = date
if "levelist" in mm:
del mm["levelist"]
self.add_coverage(mm, coords[date], val_dict)

return self.covjson
2 changes: 1 addition & 1 deletion covjsonkit/version.py
Original file line number Diff line number Diff line change
@@ -1 +1 @@
__version__ = "0.0.29"
__version__ = "0.1.0"

0 comments on commit 73af20c

Please sign in to comment.