water-column-sonar-processing 0.0.12__tar.gz → 0.0.13__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.

Potentially problematic release.


This version of water-column-sonar-processing might be problematic. Click here for more details.

Files changed (55) hide show
  1. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/PKG-INFO +6 -3
  2. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/README.md +5 -2
  3. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/pyproject.toml +1 -1
  4. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/conftest.py +5 -1
  5. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/cruise/resample_regrid.py +23 -3
  6. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/model/zarr_manager.py +2 -2
  7. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing.egg-info/PKG-INFO +6 -3
  8. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/.env-test +0 -0
  9. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/.github/workflows/test_action.yaml +0 -0
  10. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/.gitignore +0 -0
  11. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/.pre-commit-config.yaml +0 -0
  12. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/.python-version +0 -0
  13. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/LICENSE +0 -0
  14. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/open-science-data-federation/ml/autoencoder_example.py +0 -0
  15. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/open-science-data-federation/osdf_examples/foo.ipynb +0 -0
  16. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/open-science-data-federation/osdf_examples/sonar_ai.ipynb +0 -0
  17. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/pytest.ini +0 -0
  18. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/requirements.txt +0 -0
  19. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/requirements_dev.txt +0 -0
  20. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/setup.cfg +0 -0
  21. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/test_process.py +0 -0
  22. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/test_resources/index/calibrated_cruises.csv +0 -0
  23. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/test_resources/raw_to_zarr/D20070724-T042400.bot +0 -0
  24. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/test_resources/raw_to_zarr/D20070724-T042400.idx +0 -0
  25. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/tests/test_resources/raw_to_zarr/D20070724-T042400.raw +0 -0
  26. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/__init__.py +0 -0
  27. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/__init__.py +0 -0
  28. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/dynamodb_manager.py +0 -0
  29. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/s3_manager.py +0 -0
  30. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/s3fs_manager.py +0 -0
  31. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/sns_manager.py +0 -0
  32. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/aws/sqs_manager.py +0 -0
  33. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/cruise/__init__.py +0 -0
  34. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/cruise/create_empty_zarr_store.py +0 -0
  35. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/cruise/experiment_datatree.py +0 -0
  36. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/geometry/__init__.py +0 -0
  37. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/geometry/geometry_manager.py +0 -0
  38. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/geometry/geometry_simplification.py +0 -0
  39. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/geometry/pmtile_generation.py +0 -0
  40. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/index/__init__.py +0 -0
  41. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/index/index_manager.py +0 -0
  42. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/model/__init__.py +0 -0
  43. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/process.py +0 -0
  44. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/processing/__init__.py +0 -0
  45. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/processing/cruise_sampler.py +0 -0
  46. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/processing/raw_to_zarr.py +0 -0
  47. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/utility/__init__.py +0 -0
  48. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/utility/cleaner.py +0 -0
  49. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/utility/constants.py +0 -0
  50. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/utility/pipeline_status.py +0 -0
  51. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing/utility/timestamp.py +0 -0
  52. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing.egg-info/SOURCES.txt +0 -0
  53. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing.egg-info/dependency_links.txt +0 -0
  54. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing.egg-info/requires.txt +0 -0
  55. {water_column_sonar_processing-0.0.12 → water_column_sonar_processing-0.0.13}/water_column_sonar_processing.egg-info/top_level.txt +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: water_column_sonar_processing
3
- Version: 0.0.12
3
+ Version: 0.0.13
4
4
  Summary: A processing tool for water column sonar data.
5
5
  Author-email: Rudy Klucik <rudy.klucik@noaa.gov>
6
6
  Project-URL: Homepage, https://github.com/CI-CMG/water-column-sonar-processing
@@ -131,9 +131,12 @@ https://colab.research.google.com/drive/1KiLMueXiz9WVB9o4RuzYeGjNZ6PsZU7a#scroll
131
131
  3 failed, 38 passed, 3 skipped, 1 warning in 7.24s
132
132
 
133
133
  # Tag a Release
134
+ Step 1 --> increment the semantic version in the zarr_manager.py "metadata" & the "pyproject.toml"
135
+ ```commandline
136
+ git tag "v0.0.13" -a
137
+ ```
138
+ Step 3 --> enter description
134
139
  ```commandline
135
- git tag "v0.0.12" -a
136
- # enter description
137
140
  git push origin --tags
138
141
  ```
139
142
 
@@ -95,9 +95,12 @@ https://colab.research.google.com/drive/1KiLMueXiz9WVB9o4RuzYeGjNZ6PsZU7a#scroll
95
95
  3 failed, 38 passed, 3 skipped, 1 warning in 7.24s
96
96
 
97
97
  # Tag a Release
98
+ Step 1 --> increment the semantic version in the zarr_manager.py "metadata" & the "pyproject.toml"
99
+ ```commandline
100
+ git tag "v0.0.13" -a
101
+ ```
102
+ Step 3 --> enter description
98
103
  ```commandline
99
- git tag "v0.0.12" -a
100
- # enter description
101
104
  git push origin --tags
102
105
  ```
103
106
 
@@ -8,7 +8,7 @@ build-backend = "setuptools.build_meta"
8
8
 
9
9
  [project]
10
10
  name = "water_column_sonar_processing"
11
- version = "0.0.12"
11
+ version = "0.0.13"
12
12
  authors = [
13
13
  { name="Rudy Klucik", email="rudy.klucik@noaa.gov" },
14
14
  ]
@@ -16,13 +16,17 @@ HB0707_RAW = pooch.create(
16
16
  #https://noaa-wcsd-pds.s3.amazonaws.com/data/raw/Henry_B._Bigelow/HB0707/EK60/D20070711-T182032.raw
17
17
  # TODO: add bottom files
18
18
  "D20070712-T124906.raw": "sha256:44f9b2402a8d6d51c69235d1e33c3e4ab570fc541e9f269009924378bf4d97a2", # 250 m, 158 MB
19
+ "D20070712-T124906.bot": "sha256:9eebd8b85a514f3df6b7c4ba127967302dfea7c5e9fb47c22e3182ad1a93c78f",
19
20
  "D20070712-T152416.raw": "sha256:94a937eefd6ae5763c27c9ba1e4769b2b76fcc2d840e7db6c2e0edd925d6f70f", # 1000 m, 200 MB
21
+ "D20070712-T152416.bot": "sha256:65b16cff596502889f841e58061217660e066b07fb732ccf211f1c6e46ee8210",
20
22
  },
21
23
  )
22
24
 
23
25
  def fetch_raw_files():
24
26
  HB0707_RAW.fetch(fname="D20070712-T124906.raw", progressbar=True)
25
- file_name = HB0707_RAW.fetch(fname="D20070712-T152416.raw", progressbar=True)
27
+ HB0707_RAW.fetch(fname="D20070712-T124906.bot", progressbar=True)
28
+ HB0707_RAW.fetch(fname="D20070712-T152416.raw", progressbar=True)
29
+ file_name = HB0707_RAW.fetch(fname="D20070712-T152416.bot", progressbar=True)
26
30
  return Path(file_name).parent #joinpath(Path(file_path).stem)
27
31
 
28
32
  @pytest.fixture(scope="session")
@@ -188,10 +188,10 @@ class ResampleRegrid:
188
188
  for file_name in all_file_names:
189
189
  gc.collect()
190
190
  file_name_stem = Path(file_name).stem
191
- # file_name_stem = "D20070724-T151330"
192
191
  print(f"Processing file: {file_name_stem}.")
193
- # if f"{file_name_stem}.raw" not in list(cruise_df['FILE_NAME']):
194
- # raise Exception(f"Raw file file_stem not found in dynamodb.")
192
+
193
+ if f"{file_name_stem}.raw" not in list(cruise_df['FILE_NAME']):
194
+ raise Exception(f"Raw file file_stem not found in dynamodb.")
195
195
 
196
196
  # status = PipelineStatus['LEVEL_1_PROCESSING']
197
197
  # TODO: filter rows by enum success, filter the dataframe just for enums >= LEVEL_1_PROCESSING
@@ -296,6 +296,26 @@ class ResampleRegrid:
296
296
  output_zarr_store.longitude[
297
297
  start_ping_time_index:end_ping_time_index
298
298
  ] = geospatial.dropna()["longitude"].values
299
+
300
+ #########################################################################
301
+ # TODO: add the "detected_seafloor_depth/" to the
302
+ # L2 cruise dataarrays
303
+ # TODO: make bottom optional if 'detected_seafloor_depth' in input_xr.variables:
304
+ # TODO: Only checking the first channel for now. Need to average across all channels
305
+ # in the future. See https://github.com/CI-CMG/water-column-sonar-processing/issues/11
306
+ # detected_seafloor_depths = input_xr.detected_seafloor_depth.values[0, :] # note can include nans?
307
+ detected_seafloor_depth = input_xr.detected_seafloor_depth.values
308
+ detected_seafloor_depth[detected_seafloor_depth == 0.] = np.nan
309
+ detected_seafloor_depths = np.nanmean(detected_seafloor_depth, 0)
310
+ detected_seafloor_depths[detected_seafloor_depths == 0.] = np.nan
311
+ print(f"min depth measured: {np.nanmin(detected_seafloor_depths)}")
312
+ print(f"max depth measured: {np.nanmax(detected_seafloor_depths)}")
313
+ #available_indices = np.argwhere(np.isnan(geospatial['latitude'].values))
314
+ output_zarr_store.bottom[
315
+ start_ping_time_index:end_ping_time_index
316
+ ] = detected_seafloor_depths
317
+ #########################################################################
318
+ #########################################################################
299
319
  except Exception as err:
300
320
  print(f"Problem interpolating the data: {err}")
301
321
  raise err
@@ -246,7 +246,7 @@ class ZarrManager:
246
246
  #
247
247
  root.attrs["processing_software_name"] = Coordinates.PROJECT_NAME.value
248
248
  root.attrs["processing_software_version"] = (
249
- "0.0.12" # TODO: get programmatically, echopype>utils>prov.py
249
+ "0.0.13" # TODO: get programmatically, echopype>utils>prov.py
250
250
  )
251
251
  root.attrs["processing_software_time"] = Timestamp.get_timestamp()
252
252
  #
@@ -288,7 +288,7 @@ class ZarrManager:
288
288
  ):
289
289
  # Mounts a Zarr store using pythons Zarr implementation. The mounted store
290
290
  # will have read/write privileges so that store can be updated.
291
- print("Opening Zarr store with Zarr.")
291
+ print("Opening L2 Zarr store with Zarr for writing.")
292
292
  try:
293
293
  s3fs_manager = S3FSManager(endpoint_url=endpoint_url)
294
294
  root = f"{output_bucket_name}/level_2/{ship_name}/{cruise_name}/{sensor_name}/{cruise_name}.zarr"
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: water_column_sonar_processing
3
- Version: 0.0.12
3
+ Version: 0.0.13
4
4
  Summary: A processing tool for water column sonar data.
5
5
  Author-email: Rudy Klucik <rudy.klucik@noaa.gov>
6
6
  Project-URL: Homepage, https://github.com/CI-CMG/water-column-sonar-processing
@@ -131,9 +131,12 @@ https://colab.research.google.com/drive/1KiLMueXiz9WVB9o4RuzYeGjNZ6PsZU7a#scroll
131
131
  3 failed, 38 passed, 3 skipped, 1 warning in 7.24s
132
132
 
133
133
  # Tag a Release
134
+ Step 1 --> increment the semantic version in the zarr_manager.py "metadata" & the "pyproject.toml"
135
+ ```commandline
136
+ git tag "v0.0.13" -a
137
+ ```
138
+ Step 3 --> enter description
134
139
  ```commandline
135
- git tag "v0.0.12" -a
136
- # enter description
137
140
  git push origin --tags
138
141
  ```
139
142