Skip to content

Commit

Permalink
Add clip_coh_below phase linking parameter to zero out low correlat…
Browse files Browse the repository at this point in the history
…ion values
  • Loading branch information
scottstanie committed Oct 27, 2024
1 parent 76d013b commit 30806d7
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 2 deletions.
16 changes: 16 additions & 0 deletions src/dolphin/phase_link/_core.py
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ def run_phase_linking(
strides: Strides = DEFAULT_STRIDES,
use_evd: bool = False,
beta: float = 0.0,
clip_coh_below: float = 0.0,
reference_idx: int = 0,
nodata_mask: ArrayLike | None = None,
mask_input_ps: bool = False,
Expand Down Expand Up @@ -96,6 +97,9 @@ def run_phase_linking(
the EMI algorithm.
beta : float, optional
The regularization parameter, by default 0 (no regularization).
clip_coh_below : float, optional
Snap correlation values in the coherence matrix below this value to 0.
Default is 0 (no clipping).
reference_idx : int, optional
The index of the (non compressed) reference SLC, by default 0
nodata_mask : ArrayLike, optional
Expand Down Expand Up @@ -191,6 +195,7 @@ def run_phase_linking(
strides=strides,
use_evd=use_evd,
beta=beta,
clip_coh_below=clip_coh_below,
reference_idx=reference_idx,
neighbor_arrays=neighbor_arrays,
calc_average_coh=calc_average_coh,
Expand Down Expand Up @@ -247,6 +252,7 @@ def run_cpl(
strides: Strides,
use_evd: bool = False,
beta: float = 0,
clip_coh_below: float = 0.0,
reference_idx: int = 0,
neighbor_arrays: Optional[np.ndarray] = None,
calc_average_coh: bool = False,
Expand All @@ -272,6 +278,9 @@ def run_cpl(
the EMI algorithm.
beta : float, optional
The regularization parameter, by default 0 (no regularization).
clip_coh_below : float, optional
Snap correlation values in the coherence matrix below this value to 0.
Default is 0 (no clipping).
reference_idx : int, optional
The index of the (non compressed) reference SLC, by default 0
use_slc_amp : bool, optional
Expand Down Expand Up @@ -328,6 +337,7 @@ def run_cpl(
C_arrays,
use_evd=use_evd,
beta=beta,
clip_coh_below=clip_coh_below,
reference_idx=reference_idx,
)
# Get the temporal coherence
Expand Down Expand Up @@ -364,6 +374,7 @@ def process_coherence_matrices(
C_arrays,
use_evd: bool = False,
beta: float = 0.0,
clip_coh_below: float = 0.0,
reference_idx: int = 0,
) -> tuple[Array, Array, Array]:
"""Estimate the linked phase for a stack of coherence matrices.
Expand All @@ -383,6 +394,9 @@ def process_coherence_matrices(
The regularization parameter for inverting Gamma = |C|
The regularization is applied as (1 - beta) * Gamma + beta * I
Default is 0 (no regularization).
clip_coh_below : float, optional
Snap correlation values in the coherence matrix below this value to 0.
Default is 0 (no clipping).
reference_idx : int, optional
The index of the reference acquisition, by default 0
All outputs are multiplied by the conjugate of the data at this index.
Expand Down Expand Up @@ -420,6 +434,8 @@ def process_coherence_matrices(
if beta > 0:
# Perform regularization
Gamma = (1 - beta) * Gamma + beta * Id
# if clip_coh_below > 0.0:
Gamma = jnp.where(Gamma < clip_coh_below, 0, Gamma)

# Attempt to invert Gamma
cho, is_lower = cho_factor(Gamma)
Expand Down
8 changes: 8 additions & 0 deletions src/dolphin/workflows/config/_common.py
Original file line number Diff line number Diff line change
Expand Up @@ -106,6 +106,14 @@ class PhaseLinkingOptions(BaseModel, extra="forbid"):
ge=0.0,
le=1.0,
)
clip_coh_below: float = Field(
0.00,
description=(
"Snap correlation values in the coherence matrix below this value to 0."
),
ge=0.0,
le=1.0,
)
shp_method: ShpMethod = ShpMethod.GLRT
shp_alpha: float = Field(
0.001,
Expand Down
2 changes: 2 additions & 0 deletions src/dolphin/workflows/sequential.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,7 @@ def run_wrapped_phase_sequential(
shp_nslc: Optional[int] = None,
use_evd: bool = False,
beta: float = 0.00,
clip_coh_below: float = 0.0,
similarity_nearest_n: int | None = None,
compressed_slc_plan: CompressedSlcPlan = CompressedSlcPlan.ALWAYS_FIRST,
max_num_compressed: int = 100,
Expand Down Expand Up @@ -123,6 +124,7 @@ def already_processed(d: Path, search_ext: str = ".tif") -> bool:
strides=strides,
use_evd=use_evd,
beta=beta,
clip_coh_below=clip_coh_below,
mask_file=mask_file,
ps_mask_file=ps_mask_file,
amp_mean_file=amp_mean_file,
Expand Down
2 changes: 2 additions & 0 deletions src/dolphin/workflows/single.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ def run_wrapped_phase_single(
half_window: dict,
strides: Optional[dict] = None,
beta: float = 0.00,
clip_coh_below: float = 0.0,
use_evd: bool = False,
mask_file: Optional[Filename] = None,
ps_mask_file: Optional[Filename] = None,
Expand Down Expand Up @@ -198,6 +199,7 @@ def run_wrapped_phase_single(
strides=strides_tup,
use_evd=use_evd,
beta=beta,
clip_coh_below=clip_coh_below,
reference_idx=ministack.output_reference_idx,
nodata_mask=nodata_mask[in_rows, in_cols],
ps_mask=ps_mask[in_rows, in_cols],
Expand Down
5 changes: 3 additions & 2 deletions src/dolphin/workflows/wrapped_phase.py
Original file line number Diff line number Diff line change
Expand Up @@ -189,18 +189,19 @@ def run(
strides=strides,
use_evd=cfg.phase_linking.use_evd,
beta=cfg.phase_linking.beta,
clip_coh_below=cfg.phase_linking.clip_coh_below,
mask_file=mask_filename,
ps_mask_file=ps_output,
amp_mean_file=cfg.ps_options._amp_mean_file,
amp_dispersion_file=cfg.ps_options._amp_dispersion_file,
shp_method=cfg.phase_linking.shp_method,
shp_alpha=cfg.phase_linking.shp_alpha,
shp_nslc=shp_nslc,
baseline_lag=cfg.phase_linking.baseline_lag,
compressed_slc_plan=cfg.phase_linking.compressed_slc_plan,
similarity_nearest_n=similarity_nearest_n,
cslc_date_fmt=cfg.input_options.cslc_date_fmt,
block_shape=cfg.worker_settings.block_shape,
baseline_lag=cfg.phase_linking.baseline_lag,
compressed_slc_plan=cfg.phase_linking.compressed_slc_plan,
**kwargs,
)
# Dump the used options for JSON parsing
Expand Down

0 comments on commit 30806d7

Please sign in to comment.