From f715feee4f00eec9ed20d36ef6c898f4b42084c7 Mon Sep 17 00:00:00 2001
From: Lionel GUEZ <guez@lmd.ens.fr>
Date: Sat, 27 Apr 2024 00:35:27 +0200
Subject: [PATCH] Compute `i_slice` in `comp_ishape`

Compute `i_slice` in `comp_ishape` if `i_slice` is None. Add default
value of None for dummy argument `i_slice`.
---
 Common/util_eddies.py                  | 18 +++++++++++-------
 Inst_eddies/Analysis/eddy_dump.py      |  2 +-
 Overlap/Analysis/plot_edge_contours.py |  4 ++--
 Overlap/Analysis/report_graph.py       |  2 +-
 Trajectories/Analysis/plot_traj.py     |  2 +-
 Trajectories/cost_function.py          |  2 +-
 6 files changed, 17 insertions(+), 13 deletions(-)

diff --git a/Common/util_eddies.py b/Common/util_eddies.py
index e6d23f1f..760bd343 100644
--- a/Common/util_eddies.py
+++ b/Common/util_eddies.py
@@ -199,14 +199,18 @@ class SHPC_class:
         assert i_slice >= 0
         return i_slice
 
-    def comp_ishape(self, date, eddy_index, orientation, i_slice):
-        """Compute the location in the shapefiles. Returns None if ishape_last
-        was not found and could not be created. Crashes if date is not
-        in i_slice. Returns None if eddy_index is greater than the
+    def comp_ishape(self, date, eddy_index, orientation, i_slice = None):
+        """Compute the location in the shapefiles: return `(i_slice, ishape)`.
+        Compute i_slice if i_slice is None.
+
+        Returns None if ishape_last was not found and could not be
+        created. Crashes if i_slice is not None and date is not in
+        i_slice. Returns None if eddy_index is greater than the
         maximum value.
 
         """
 
+        if i_slice is None: i_slice = self.get_slice(date)
         ishape_last = self.get_ishape_last(i_slice, orientation)
 
         if ishape_last is None:
@@ -225,15 +229,15 @@ class SHPC_class:
             else:
                 ishape = None
 
-        return ishape
+        return i_slice, ishape
 
     def ishape_range(self, date, i_slice, orientation):
         """Returns an empty list if ishape_last was not found and could not be
-        created. Crashes if date is not in i_slice.
+        created. Crashes if i_slice is not None and date is not in i_slice.
 
         """
 
-        ishape_start = self.comp_ishape(date, 1, orientation, i_slice)
+        i_slice, ishape_start = self.comp_ishape(date, 1, orientation, i_slice)
 
         if ishape_start is None:
             return []
diff --git a/Inst_eddies/Analysis/eddy_dump.py b/Inst_eddies/Analysis/eddy_dump.py
index d2c8de0c..98df7a05 100755
--- a/Inst_eddies/Analysis/eddy_dump.py
+++ b/Inst_eddies/Analysis/eddy_dump.py
@@ -40,7 +40,7 @@ else:
         assert eddy_index >= 1
 
     i_slice = SHPC.get_slice(date)
-    ishape = SHPC.comp_ishape(date, eddy_index, args.orientation, i_slice)
+    i_slice, ishape = SHPC.comp_ishape(date, eddy_index, args.orientation, i_slice)
 
 print("ishape =", ishape)
 
diff --git a/Overlap/Analysis/plot_edge_contours.py b/Overlap/Analysis/plot_edge_contours.py
index f95dee84..c389bd9a 100755
--- a/Overlap/Analysis/plot_edge_contours.py
+++ b/Overlap/Analysis/plot_edge_contours.py
@@ -24,8 +24,8 @@ print(f"{date_head=}")
 print(f"{date_tail=}")
 i_slice_head = SHPC.get_slice(date_head)
 i_slice_tail = SHPC.get_slice(date_tail)
-ishape_head = SHPC.comp_ishape(date_head,eddy_i_head,orientation,i_slice_head)
-ishape_tail = SHPC.comp_ishape(date_tail,eddy_i_tail,orientation,i_slice_tail)
+i_slice_head, ishape_head = SHPC.comp_ishape(date_head,eddy_i_head,orientation,i_slice_head)
+i_slice_tail, ishape_tail = SHPC.comp_ishape(date_tail,eddy_i_tail,orientation,i_slice_tail)
 fig = plt.figure()
 projection = ccrs.PlateCarree()
 ax = plt.axes(projection = projection)
diff --git a/Overlap/Analysis/report_graph.py b/Overlap/Analysis/report_graph.py
index 72fcf3f4..ed5c3ac8 100755
--- a/Overlap/Analysis/report_graph.py
+++ b/Overlap/Analysis/report_graph.py
@@ -46,7 +46,7 @@ def set_attribute(G, SHPC, orientation):
                 n, G.graph["e_overestim"]
             )
             i_slice = SHPC.get_slice(date_index)
-            ishape = SHPC.comp_ishape(
+            i_slice, ishape = SHPC.comp_ishape(
                 date_index, eddy_index, orientation, i_slice
             )
             reader = SHPC.get_reader(i_slice, orientation, "extremum")
diff --git a/Trajectories/Analysis/plot_traj.py b/Trajectories/Analysis/plot_traj.py
index 4b05e93e..499fc6c3 100755
--- a/Trajectories/Analysis/plot_traj.py
+++ b/Trajectories/Analysis/plot_traj.py
@@ -26,7 +26,7 @@ def get_extr_coord(traj, e_overestim, SHPC, orientation):
             node, e_overestim
         )
         i_slice = SHPC.get_slice(date_index)
-        ishape = SHPC.comp_ishape(date_index, eddy_index, orientation, i_slice)
+        i_slice, ishape = SHPC.comp_ishape(date_index, eddy_index, orientation, i_slice)
         shape = SHPC.get_reader(i_slice, orientation, layer="extremum").shape(
             ishape
         )
diff --git a/Trajectories/cost_function.py b/Trajectories/cost_function.py
index 5f131ed5..c6f88061 100755
--- a/Trajectories/cost_function.py
+++ b/Trajectories/cost_function.py
@@ -78,7 +78,7 @@ def node_to_prop(node_list, e_overestim, SHPC, orientation):
     for n in node_list:
         date_index, eddy_index = util_eddies.node_to_date_eddy(n, e_overestim)
         i_slice = SHPC.get_slice(date_index)
-        ishape = SHPC.comp_ishape(date_index, eddy_index, orientation, i_slice)
+        i_slice, ishape = SHPC.comp_ishape(date_index, eddy_index, orientation, i_slice)
         shapeRec = SHPC.get_reader(
             i_slice, orientation, "extremum"
         ).shapeRecord(ishape)
-- 
GitLab