Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove b perp from tssetup #435

Merged
merged 12 commits into from
Aug 13, 2024
3 changes: 0 additions & 3 deletions tests/regression/validate_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,16 +30,13 @@
}
ENVI_FILES['tssetup'] = {
'azimuthAngle': 'azimuthAngle/20230829_20230724',
'bPerpendicular_20230829_20230724': 'bPerpendicular/20230829_20230724',
'bPerpendicular_20230829_20230817': 'bPerpendicular/20230829_20230817',
'connectedComponents_20230829_20230724':
'connectedComponents/20230829_20230724',
'connectedComponents_20230829_20230817':
'connectedComponents/20230829_20230817',
'incidenceAngle': 'incidenceAngle/20230829_20230724',
'ionosphere_20230829_20230724': 'ionosphere/20230829_20230724',
'ionosphere_20230829_20230817': 'ionosphere/20230829_20230817',
'lookAngle': 'lookAngle/20230829_20230724',
'solidEarthTide_20230829_20230724': 'solidEarthTide/20230829_20230724',
'solidEarthTide_20230829_20230817': 'solidEarthTide/20230829_20230817',
'troposphereTotal_HRRR_20230829_20230817':
Expand Down
7 changes: 4 additions & 3 deletions tools/ARIAtools/constants.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,9 +33,10 @@
ARIA_LAYERS += ARIA_INTERNAL_CORRECTIONS
ARIA_LAYERS += ARIA_TROPO_MODELS

ARIA_STANDARD_LAYERS = [
'unwrappedPhase', 'coherence', 'incidenceAngle', 'azimuthAngle',
'bPerpendicular']
ARIA_STANDARD_INTF_LAYERS = ['unwrappedPhase', 'coherence']
ARIA_STANDARD_GEOM_LAYERS = ['incidenceAngle', 'azimuthAngle']
ARIA_STANDARD_LAYERS = ARIA_STANDARD_INTF_LAYERS + ARIA_STANDARD_GEOM_LAYERS


ARIA_STACK_DEFAULTS = ['unwrappedPhase',
'coherence',
Expand Down
22 changes: 22 additions & 0 deletions tools/ARIAtools/extractProduct.py
Original file line number Diff line number Diff line change
Expand Up @@ -701,6 +701,28 @@ def generate_diff(ref_outname, sec_outname, outname, key, OG_key, tropo_total,
return


def extract_bperp_dict(products, num_threads):
"""Extracts bPerpendicular mean over frames for each product in products"""
def read_and_average_bperp(frame):
"""Helper function for dask multiprocessing"""
return osgeo.gdal.Open(frame).ReadAsArray().mean()

bperp_dict = {}
for product in products:
jobs = []
for frame in product['bPerpendicular']:
jobs.append(dask.delayed(read_and_average_bperp)(frame))

mean_bperp_by_frames = dask.compute(
jobs, num_workers=int(num_threads), scheduler='threads')[0]

LOGGER.debug('Pair name: %s, bPerpendicular %s' % (
product['pair_name'][0], mean_bperp_by_frames))
bperp_dict[product['pair_name'][0]] = float(
np.mean(mean_bperp_by_frames))
return bperp_dict


def handle_epoch_layers(
layers, product_dict, proj, lyr_path, user_lyrs, map_lyrs, key,
sec_key, ref_key, tropo_total, workdir, prog_bar, bounds, arrres,
Expand Down
76 changes: 55 additions & 21 deletions tools/bin/ariaTSsetup.py
Original file line number Diff line number Diff line change
Expand Up @@ -20,17 +20,21 @@
import argparse
import datetime
import collections
import contextlib
import json

import numpy as np
import osgeo.gdal
import tile_mate

import ARIAtools.extractProduct
import ARIAtools.product
import ARIAtools.util.vrt
import ARIAtools.util.misc
import ARIAtools.util.mask
import ARIAtools.util.log
import ARIAtools.util.dem
import ARIAtools.extractProduct
import ARIAtools.util.log
import ARIAtools.util.mask
import ARIAtools.util.misc
import ARIAtools.util.vrt
import ARIAtools.constants

from ARIAtools.constants import ARIA_EXTERNAL_CORRECTIONS, \
ARIA_TROPO_MODELS, ARIA_STACK_DEFAULTS, ARIA_STACK_OUTFILES, \
Expand Down Expand Up @@ -268,7 +272,15 @@ def generate_stack(aria_prod, stack_layer, output_file_name,
aztime_list.append(i['azimuthZeroDopplerMidTime'])

# get bperp value
b_perp = extract_bperp_dict(domain_name, dlist)
b_perp_json_file = os.path.join(
workdir, 'bPerpendicular', 'bperp.json')

if os.path.isfile(b_perp_json_file):
LOGGER.debug("Loading bPerpendicular from bperp.json")
with open(b_perp_json_file) as ifp:
b_perp = json.loads(ifp.read())
else:
b_perp = extract_bperp_dict(domain_name, dlist)

# Confirm 1-to-1 match between UNW and other derived products
if ref_dlist and new_dlist != ref_dlist:
Expand Down Expand Up @@ -400,6 +412,17 @@ def main():
'Thread count specified for gdal multiprocessing = %s' % (
args.num_threads))

# If bPerpendicular specified on command line extract bPerp layer,
# otherwise extract the average from GUNWs into json file.
extract_bperp_layer = False
with contextlib.suppress(TypeError):
extract_bperp_layer = 'bPerpendicular' in args.layers
if extract_bperp_layer:
# Remove bPerpendicular from args.layers
layers = [layer.strip() for layer in args.layers.split(',')]
layers.pop(layers.index('bPerpendicular'))
args.layers = ','.join(layers)

if args.layers.lower() == 'standard':
LOGGER.debug("Using standard layers: %s" % ARIA_STANDARD_LAYERS)
args.layers = ','.join(ARIA_STANDARD_LAYERS)
Expand Down Expand Up @@ -510,10 +533,8 @@ def main():
}

# export unwrappedPhase
layers = ['unwrappedPhase', 'coherence']
LOGGER.info(
'Extracting unwrapped phase, coherence, and connected components for '
'each interferogram pair')
layers = ARIAtools.constants.ARIA_STANDARD_INTF_LAYERS
LOGGER.info('Extracting %s for each interferogram pair' % layers)
ref_arr_record = ARIAtools.extractProduct.export_products(
standardproduct_info.products[1], tropo_total=False, layers=layers,
rankedResampling=args.rankedResampling, multiproc_method='threads',
Expand All @@ -527,26 +548,39 @@ def main():
for item in list(set(d[key])):
extract_dict[key].append(item)

layers = ['incidenceAngle', 'lookAngle', 'azimuthAngle']
layers = ARIAtools.constants.ARIA_STANDARD_GEOM_LAYERS
LOGGER.info(
'Extracting single incidence angle, look angle and azimuth angle '
'files valid over common interferometric grid')
'Extracting single %s '
'files valid over common interferometric grid' % layers)
prod_arr_record = ARIAtools.extractProduct.export_products(
[extract_dict], tropo_total=False, layers=layers,
multiproc_method='gnu_parallel', **export_dict)

# Track consistency of dimensions
ARIAtools.util.vrt.dim_check(ref_arr_record, prod_arr_record)

layers = ['bPerpendicular']
LOGGER.info(
'Extracting perpendicular baseline grids for each interferogram pair')
prod_arr_record = ARIAtools.extractProduct.export_products(
standardproduct_info.products[1], tropo_total=False, layers=layers,
multiproc_method='gnu_parallel', **export_dict)
if extract_bperp_layer:
LOGGER.info(
'Extracting perpendicular baseline grids for each interferogram '
'pair')
prod_arr_record = ARIAtools.extractProduct.export_products(
standardproduct_info.products[1], tropo_total=False,
layers=['bPerpendicular'], multiproc_method='gnu_parallel',
**export_dict)

# Track consistency of dimensions
ARIAtools.util.vrt.dim_check(ref_arr_record, prod_arr_record)
# Track consistency of dimensions
ARIAtools.util.vrt.dim_check(ref_arr_record, prod_arr_record)
else:
# Extract bPerpendicular to json file
bperp_dict = ARIAtools.extractProduct.extract_bperp_dict(
standardproduct_info.products[1], num_threads=args.num_threads)

bperp_outdir = os.path.join(args.workdir, 'bPerpendicular')
with contextlib.suppress(FileExistsError):
os.mkdir(bperp_outdir)

with open(os.path.join(bperp_outdir, 'bperp.json'), 'w') as ofp:
json.dump(bperp_dict, ofp)

# Extracting other layers, if specified
(layers, args.tropo_total, model_names) = ARIAtools.util.vrt.layerCheck(
Expand Down