dist-s1-enumerator 1.0.5__tar.gz → 1.0.7__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/CHANGELOG.md +13 -0
  2. {dist_s1_enumerator-1.0.5/src/dist_s1_enumerator.egg-info → dist_s1_enumerator-1.0.7}/PKG-INFO +10 -1
  3. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/README.md +9 -0
  4. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/data/jpl_burst_geo.parquet +0 -0
  5. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/dist_enum.py +8 -2
  6. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7/src/dist_s1_enumerator.egg-info}/PKG-INFO +10 -1
  7. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_mgrs_burst_data.py +18 -1
  8. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/dependabot.yml +0 -0
  9. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/bump-tag-for-release.yml +0 -0
  10. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/changelog-updated.yml +0 -0
  11. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/github-release.yml +0 -0
  12. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/labeled-pr.yml +0 -0
  13. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/nb_tests.yml +0 -0
  14. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/pypi-release.yml +0 -0
  15. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/static_analysis.yml +0 -0
  16. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.github/workflows/tests.yml +0 -0
  17. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/.gitignore +0 -0
  18. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/LICENSE +0 -0
  19. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/environment.yml +0 -0
  20. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/notebooks/A__Staging_Inputs_for_One_MGRS_Tile.ipynb +0 -0
  21. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/notebooks/B__Enumerate_MGRS_tile.ipynb +0 -0
  22. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/pyproject.toml +0 -0
  23. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/setup.cfg +0 -0
  24. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/__init__.py +0 -0
  25. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/asf.py +0 -0
  26. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/data/mgrs.parquet +0 -0
  27. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/data/mgrs_burst_lookup_table.parquet +0 -0
  28. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/dist_enum_inputs.py +0 -0
  29. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/exceptions.py +0 -0
  30. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/mgrs_burst_data.py +0 -0
  31. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/param_models.py +0 -0
  32. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/py.typed +0 -0
  33. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/rtc_s1_io.py +0 -0
  34. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator/tabular_models.py +0 -0
  35. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator.egg-info/SOURCES.txt +0 -0
  36. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator.egg-info/dependency_links.txt +0 -0
  37. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator.egg-info/not-zip-safe +0 -0
  38. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator.egg-info/requires.txt +0 -0
  39. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/src/dist_s1_enumerator.egg-info/top_level.txt +0 -0
  40. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/conftest.py +0 -0
  41. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/mock_ts_data_for_enum.ipynb +0 -0
  42. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/rtc_s1_ts_metadata/chile_19HBD.parquet +0 -0
  43. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/rtc_s1_ts_metadata/mgrs01UBT.parquet +0 -0
  44. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/rtc_s1_ts_metadata/mgrs11SLT_11SLU_11SMT.parquet +0 -0
  45. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/rtc_s1_ts_metadata/mgrs15RXN__track63.parquet +0 -0
  46. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/rtc_s1_ts_metadata/mgrs22WFD.parquet +0 -0
  47. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/data/ts_data_for_workflow_inputs.ipynb +0 -0
  48. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_asf.py +0 -0
  49. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_dist_enum.py +0 -0
  50. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_dist_enum_inputs.py +0 -0
  51. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_notebooks.py +0 -0
  52. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_package.py +0 -0
  53. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_param_model.py +0 -0
  54. {dist_s1_enumerator-1.0.5 → dist_s1_enumerator-1.0.7}/tests/test_rtc_s1_io.py +0 -0
@@ -6,6 +6,19 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
6
6
  and this project adheres to [PEP 440](https://www.python.org/dev/peps/pep-0440/)
7
7
  and uses [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
8
8
 
9
+ ## [1.0.7] - 2025-10-24
10
+
11
+ ### Added
12
+ * Updated print statements for multi-window to show the max number of pre-images per year.
13
+
14
+
15
+ ## [1.0.6] - 2025-10-09
16
+
17
+ ### Added
18
+ * Tests for MGRS tiles and burst geometries ensuring they overlap the antimeridian if and only if they are multipolygons.
19
+ * Updated readme with information about these mgrs/burst geometries and the dateline.
20
+ * Updated burst geometries using geopackage geometry from opera_adt/burst_db. See this issue: https://github.com/opera-adt/burst_db/issues/120 - some dateline geometries were cut off. The new geometries are larger and the table went from 24 MB to 37 MB. See this notebook: https://github.com/OPERA-Cal-Val/dist-s1-research/blob/dev/marshak/Zb_update_burst_table/Update%20Burst%20Geometries%20Using%20Geopackage.ipynb
21
+
9
22
  ## [1.0.5] - 2025-09-29
10
23
 
11
24
  ### Fixed
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: dist-s1-enumerator
3
- Version: 1.0.5
3
+ Version: 1.0.7
4
4
  Summary: Enumeration and ops library for the OPERA DIST-S1 project
5
5
  Author-email: "Richard West, Charlie Marshak, Talib Oliver-Cabrera, and Jungkyo Jung" <charlie.z.marshak@jpl.nasa.gov>
6
6
  License: Apache-2.0
@@ -125,6 +125,15 @@ There are two category of tests: unit tests and integration tests. The former ca
125
125
  The integration tests that are the most time consuming are represented by the notebooks and are run only upon a release PR.
126
126
  These notebook tests are tagged with `notebooks` and can be excluded from the other tests with `pytest tests -m 'not notebooks'`.
127
127
 
128
+ # Remarks about the Dateline/Dateline and Geometry
129
+
130
+ The antimeridian (or dateline) is the line at the -180 longitude mark that global CRS tiles are wrapped by standard global reference systems.
131
+ The geometries of the bursts and the MGRS tiles in this package are all in `epsg:4326` (standard lon/lat).
132
+ The geometries are all between -180 and 180 so those geometries that cross the antimeridian/dateline are generally wrapped.
133
+ For MGRS tiles, the statement that a geometry overlaps the antimeridian occurs if and only if the geometry is a Polygon.
134
+ The same is true for burst geometries.
135
+ See `test_antimeridian_crossing` in [`tests/test_mgrs_burst_data.py`](tests/test_mgrs_burst_data.py).
136
+
128
137
  # Contributing
129
138
 
130
139
  We welcome contributions to this open-source package. To do so:
@@ -102,6 +102,15 @@ There are two category of tests: unit tests and integration tests. The former ca
102
102
  The integration tests that are the most time consuming are represented by the notebooks and are run only upon a release PR.
103
103
  These notebook tests are tagged with `notebooks` and can be excluded from the other tests with `pytest tests -m 'not notebooks'`.
104
104
 
105
+ # Remarks about the Dateline/Dateline and Geometry
106
+
107
+ The antimeridian (or dateline) is the line at the -180 longitude mark that global CRS tiles are wrapped by standard global reference systems.
108
+ The geometries of the bursts and the MGRS tiles in this package are all in `epsg:4326` (standard lon/lat).
109
+ The geometries are all between -180 and 180 so those geometries that cross the antimeridian/dateline are generally wrapped.
110
+ For MGRS tiles, the statement that a geometry overlaps the antimeridian occurs if and only if the geometry is a Polygon.
111
+ The same is true for burst geometries.
112
+ See `test_antimeridian_crossing` in [`tests/test_mgrs_burst_data.py`](tests/test_mgrs_burst_data.py).
113
+
105
114
  # Contributing
106
115
 
107
116
  We welcome contributions to this open-source package. To do so:
@@ -123,7 +123,10 @@ def enumerate_one_dist_s1_product(
123
123
  if lookback_strategy == 'immediate_lookback':
124
124
  # Add 5 minutes buffer to ensure we don't include post-images in pre-image set.
125
125
  print('Searching for pre-images for immediate_lookback products')
126
- print(f'Lookback days {params.delta_lookback_days} and window days {params.delta_window_days}')
126
+ print(
127
+ f'Lookback days {params.delta_lookback_days} and window days {params.delta_window_days} '
128
+ f'with max pre-images per burst {params.max_pre_imgs_per_burst}'
129
+ )
127
130
  post_date_min = df_rtc_post.acq_dt.min() - pd.Timedelta(seconds=300)
128
131
  earliest_lookback = params.delta_window_days + params.delta_lookback_days
129
132
  latest_lookback = params.delta_lookback_days
@@ -146,7 +149,10 @@ def enumerate_one_dist_s1_product(
146
149
  df_rtc_pre_list = []
147
150
  zipped_data = list(zip(params.delta_lookback_days, params.max_pre_imgs_per_burst))
148
151
  print('Searching for pre-images for multi_window baseline')
149
- print(f'Lookback days {params.delta_lookback_days} and window days {params.delta_window_days}')
152
+ print(
153
+ f'Lookback days {params.delta_lookback_days} and window days {params.delta_window_days} '
154
+ f'with max pre-images per burst {params.max_pre_imgs_per_burst}'
155
+ )
150
156
  for delta_lookback_day, max_pre_img_per_burst in tqdm(
151
157
  zipped_data,
152
158
  desc='Windows',
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: dist-s1-enumerator
3
- Version: 1.0.5
3
+ Version: 1.0.7
4
4
  Summary: Enumeration and ops library for the OPERA DIST-S1 project
5
5
  Author-email: "Richard West, Charlie Marshak, Talib Oliver-Cabrera, and Jungkyo Jung" <charlie.z.marshak@jpl.nasa.gov>
6
6
  License: Apache-2.0
@@ -125,6 +125,15 @@ There are two category of tests: unit tests and integration tests. The former ca
125
125
  The integration tests that are the most time consuming are represented by the notebooks and are run only upon a release PR.
126
126
  These notebook tests are tagged with `notebooks` and can be excluded from the other tests with `pytest tests -m 'not notebooks'`.
127
127
 
128
+ # Remarks about the Dateline/Dateline and Geometry
129
+
130
+ The antimeridian (or dateline) is the line at the -180 longitude mark that global CRS tiles are wrapped by standard global reference systems.
131
+ The geometries of the bursts and the MGRS tiles in this package are all in `epsg:4326` (standard lon/lat).
132
+ The geometries are all between -180 and 180 so those geometries that cross the antimeridian/dateline are generally wrapped.
133
+ For MGRS tiles, the statement that a geometry overlaps the antimeridian occurs if and only if the geometry is a Polygon.
134
+ The same is true for burst geometries.
135
+ See `test_antimeridian_crossing` in [`tests/test_mgrs_burst_data.py`](tests/test_mgrs_burst_data.py).
136
+
128
137
  # Contributing
129
138
 
130
139
  We welcome contributions to this open-source package. To do so:
@@ -1,5 +1,5 @@
1
1
  import pytest
2
- from shapely.geometry import Point
2
+ from shapely.geometry import LineString, MultiPolygon, Point, Polygon
3
3
 
4
4
  from dist_s1_enumerator.exceptions import NoMGRSCoverage
5
5
  from dist_s1_enumerator.mgrs_burst_data import (
@@ -161,3 +161,20 @@ def test_all_bursts_in_lut() -> None:
161
161
  df_merged = df_bursts.merge(df_mgrs_lut, on='jpl_burst_id', indicator=True, how='left')
162
162
  burst_ids_not_in_lut = df_merged[df_merged['_merge'] == 'left_only'].jpl_burst_id.unique().tolist()
163
163
  assert len(burst_ids_not_in_lut) == 0
164
+
165
+
166
+ def test_antimeridian_crossing() -> None:
167
+ df_mgrs = get_mgrs_table()
168
+ df_burst = get_burst_table()
169
+ antimeridian_0 = LineString(coordinates=((-180, 90), (-180, -90))).buffer(0.00000001)
170
+ antimeridian_1 = LineString(coordinates=((180, 90), (180, -90))).buffer(0.00000001)
171
+
172
+ for df in [df_mgrs, df_burst]:
173
+ for antimeridian in [antimeridian_0, antimeridian_1]:
174
+ ind_anti = df.geometry.intersects(antimeridian)
175
+ df_antimerid = df[ind_anti].reset_index(drop=True)
176
+ any_polygons = (df_antimerid.geometry.map(lambda geo: isinstance(geo, Polygon))).sum()
177
+ assert any_polygons == 0
178
+ df_antimerid_not = df[~ind_anti].reset_index(drop=True)
179
+ any_multis = (df_antimerid_not.geometry.map(lambda geo: isinstance(geo, MultiPolygon))).sum()
180
+ assert any_multis == 0