Skip to content

Commit

Permalink
Merge pull request #238 from ASFHyP3/phase-filter-param
Browse files Browse the repository at this point in the history
Add `phase_filter_parameter` for InSAR jobs
  • Loading branch information
jtherrmann authored Oct 23, 2023
2 parents e905feb + 086fe4d commit 41bd416
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 3 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [PEP 440](https://www.python.org/dev/peps/pep-0440/)
and uses [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [3.1.0]
### Added
* Added the `phase_filter_parameter` keyword argument for the `HyP3.submit_insar_job` and `HyP3.prepare_insar_job` methods.

## [3.0.0]
### Removed
* Removed the `Job.subscription_id` attribute in response to the Subscriptions feature being removed from HyP3.
Expand Down
15 changes: 13 additions & 2 deletions src/hyp3_sdk/hyp3.py
Original file line number Diff line number Diff line change
Expand Up @@ -335,7 +335,8 @@ def submit_insar_job(self,
include_dem: bool = False,
include_wrapped_phase: bool = False,
apply_water_mask: bool = False,
include_displacement_maps: bool = False) -> Batch:
include_displacement_maps: bool = False,
phase_filter_parameter: float = 0.6) -> Batch:
"""Submit an InSAR job
Args:
Expand All @@ -353,6 +354,10 @@ def submit_insar_job(self,
apply_water_mask: Sets pixels over coastal waters and large inland waterbodies
as invalid for phase unwrapping
include_displacement_maps: Include displacement maps (line-of-sight and vertical) in the product package
phase_filter_parameter: Adaptive phase filter parameter.
Useful values fall in the range 0.2 to 1.
Larger values result in stronger filtering.
If zero, adaptive phase filter will be skipped.
Returns:
A Batch object containing the InSAR job
Expand All @@ -374,7 +379,8 @@ def prepare_insar_job(cls,
include_dem: bool = False,
include_wrapped_phase: bool = False,
apply_water_mask: bool = False,
include_displacement_maps: bool = False) -> dict:
include_displacement_maps: bool = False,
phase_filter_parameter: float = 0.6) -> dict:
"""Submit an InSAR job
Args:
Expand All @@ -392,6 +398,11 @@ def prepare_insar_job(cls,
apply_water_mask: Sets pixels over coastal waters and large inland waterbodies
as invalid for phase unwrapping
include_displacement_maps: Include displacement maps (line-of-sight and vertical) in the product package
phase_filter_parameter: Adaptive phase filter parameter.
Useful values fall in the range 0.2 to 1.
Larger values result in stronger filtering.
If zero, adaptive phase filter will be skipped.
Returns:
A dictionary containing the prepared InSAR job
"""
Expand Down
4 changes: 3 additions & 1 deletion tests/test_hyp3.py
Original file line number Diff line number Diff line change
Expand Up @@ -272,12 +272,13 @@ def test_prepare_insar_job():
'include_wrapped_phase': False,
'apply_water_mask': False,
'include_displacement_maps': False,
'phase_filter_parameter': 0.6,
}
}
assert HyP3.prepare_insar_job(granule1='my_granule1', granule2='my_granule2', name='my_name', looks='10x2',
include_los_displacement=True, include_look_vectors=True, include_inc_map=True,
include_dem=True, include_wrapped_phase=True, apply_water_mask=True,
include_displacement_maps=True) == {
include_displacement_maps=True, phase_filter_parameter=0.4) == {
'job_type': 'INSAR_GAMMA',
'name': 'my_name',
'job_parameters': {
Expand All @@ -290,6 +291,7 @@ def test_prepare_insar_job():
'include_wrapped_phase': True,
'apply_water_mask': True,
'include_displacement_maps': True,
'phase_filter_parameter': 0.4,
},
}

Expand Down

0 comments on commit 41bd416

Please sign in to comment.