Tools for indexing, shelving, copying, and modifying SETSM and ASP dems
Version 1.2
released 2023-03-10.
Scripts that support writing to an output Postgres database (such as index_setsm) have a --config
argument path to a config file containing database access information. See the example config for reference. Alternatively, the information in this config file may be sourced from the Postgres standard pair of ~/.pgpass and ~/.pg_service.conf files.
Note: The
~/.pg_service.conf
file does not support definition of an active schema in the config service information. When leveraging a service from the~/.pg_service.conf
file in a script argument forpgcdemtools
scripts, always indicate the schema name of the target layer. For example,"PG:service_name:schema_name.layer_name"
. If the schema name is not provided and~/.pg_service.conf
is used, the default schema name (usually 'public') will be assumed.
rename_setsm_add_version
index_setsm - Build a gdb or shapefile index of a single SETSM DEM scene, strip, or tile, or a directory of DEMs of these types.
package_setsm - Build an index of a SETSM DEM or directory of DEMs and package all auxilary files into tar.gz archives.
package_setsm_tiles - Build an index of a SETSM DEM mosaic tiles or directory of tiles and package all auxilary files into tar.gz archives.
shelve_setsm_by_date - Move or copy a SETSM DEM or a directory of DEMs into folders based on acquisition date.
shelve_setsm_by_geocell - Move or copy a SETSM DEM or a directory of DEMs into folders based on the geocell that intersects with the DEM cetroid, as identified by the lower left geocell corner.
shelve_setsm_by_shp - Move or copy a SETSM DEM or a directory of DEMs into folders based on a custon shapefile index.
copy_dems - Copy DEMs using a subset of the DEM index bult using index_setsm.py.
apply_setsm_registration - If GCP registration information is included with a SETSM DEM, apply the offset and output a new raster.
resample_setsm - resample SETSM DEMs to a lower resolution.
divide_setsm_tiles - Divide SETSM DEM mosaic tiles into subtiles.
build_stac_items - scans a directory for DEMs and creates a STAC Item for each DEM.
build_stac_tree - scans a directory tree for STAC Items and builds a PGC STAC open data catalog
STAC_DIR: output base directory for STAC files
DEM_DIR: A STAC item is created for each *_dem.tif found (recursively) under this directory
DOMAIN: arcticdem, earthdem, or rema. Must match the domain for the DEMs in DEM_DIR
# Build STAC items in parallel
find "${DEM_DIR} \
-maxdepth 1 -type d -print0 | \
xargs -0 -n 1 -I'{}' -P8 \
./build_stac_items.py --overwrite --stac-base-dir="${STAC_DIR}" --domain=${DOMAIN} '{}'
# (re-)Build STAC Catalogs/Collections tree from STAC Items
./build_stac_tree.py --overwrite "${STAC_DIR}"
Some of the tools are designed to be run either in a serial, parallel, or with a PBS or SLURM scheduler. If a scheduler is present, the --scheduler option can be used to submit the jobs to PBS or SLURM. The pbs_* and slurm_* scripts can be modified or used as a template for job submission scripts. The --parallel-processes option, if available, allows the given tool to operate on several tasks at once.
Most unit tests and functional tests for pgcdemtools are written using python's unittest library. They use licensed commercial data that cannot be distributed freely but is available to project contributors.
On Linux systems:
# first time only
ln -s <test_data_location>/tests/testdata tests/
# run the tests
python tests/func_test_index.pr
python tests/func_test_package.py
etc...
To report any questions or issues, please open a github issue or contact the Polar Geospatial Center: [email protected]