Web UI for browsing InSAR time series
Project description
Bowser
Map-based viewer for InSAR time-series outputs — GeoZarr cubes, dolphin workflow directories, or loose GeoTIFFs — served through a local FastAPI server and rendered by titiler in the browser.
Quickstart
Zero-install — run the latest release against a GeoZarr cube:
uvx --from bowser-insar bowser run --stack-file example-cube.zarr
Open the http://127.0.0.1:8000 link that bowser prints.
Note on PyPI installing an GDAL: The PyPI wheel is enough for GeoZarr cubes and plain GeoTIFFs. For other input formats,
pixiis the easiest way:pixi global install bowser-insar
Installation in another project
# GeoZarr / GeoTIFF only
pip install bowser-insar # or: uv add bowser-insar
# Full format support (NetCDF, HDF5, VRT) via conda-forge GDAL
pixi add bowser-insar
Quickstarts
From dolphin
bowser setup-dolphin scans a dolphin work directory and writes a
bowser_rasters.json describing every raster group it finds. bowser run
then serves them.
bowser setup-dolphin work/
bowser run
Note: these outputs must be geocoded to work with bowser, which lays them out on a basemap using web mapping tools.
If you're running over ssh, tunnel the port back to your laptop:
ssh -N -L 8000:localhost:8000 myserver
From dolphin → GeoZarr cube
Once the bowser_rasters.json file is created, you can convert the data into a GeoZarr cube:
pixi run -e writer bowser tifs-to-geozarr \
--pyramid bowser_rasters.json cube.zarr
DISP-S1 → GeoZarr cube
To work with DISP-S1 products, you may convert them once into a single pyramidal GeoZarr cube, then serve that. The converter handles the reference-date bookkeeping for morving temporal reference,, builds multiscale pyramids, and writes GeoZarr convention attributes so titiler can pick the right overview per tile zoom.
# 1. prepare per-band GeoTIFFs and a bowser_rasters.json
bowser setup-disp-s1 /path/to/disp-s1/outputs
# 2. convert to a single sharded GeoZarr cube with pyramid
pixi run -e writer bowser tifs-to-geozarr \
--pyramid bowser_rasters.json cube.zarr
# 3. serve
bowser run --stack-file cube.zarr
For a multi-dataset catalog (pick from a map of bounding boxes at startup) and an EC2 deployment serving cubes from a private S3 bucket, see deploy/README.md for the bowser register CLI, the Docker image, and the EC2 bootstrap script end-to-end.
CLI Usage
$ bowser --help
Commands:
prepare-amplitude Convert complex SLC GeoTIFFs to amplitude-in-dB.
prepare-disp-s1 Create VRTs pointing into DISP-S1 NetCDFs.
prepare-nisar-gunw Create VRTs pointing into NISAR GUNW NetCDFs.
register Add a dataset entry to a catalog TOML file.
run Run the web server.
set-data Specify what raster data to use (interactive).
setup-aligned-disp-s1 Write bowser_rasters.json for aligned DISP-S1.
setup-disp-s1 Write bowser_rasters.json for DISP-S1 outputs.
setup-dolphin Write bowser_rasters.json for a dolphin run.
setup-hyp3 Write bowser_rasters.json for HyP3 Gamma.
setup-nisar-gunw Write bowser_rasters.json for NISAR GUNW.
Developer setup
git clone git@github.com:opera-adt/bowser.git && cd bowser
pixi install # default env: runtime deps
pixi install -e writer # optional env: includes geozarr-toolkit for the converter
pixi run bowser run
Frontend (TypeScript + Vite):
npm install
npm run build # rebuilds src/bowser/dist/ after .tsx / CSS changes
The PyPI wheel bundles src/bowser/dist/ (built by the CD workflow before publishing), so end users can pip install bowser-insar without Node. From a git checkout, run npm run build first to populate src/bowser/dist/ before pip install -e ..
For a hot-reload loop on UI/styling changes, run the backend and the Vite dev server in two terminals. Vite proxies API calls to the backend on port 8000:
# Terminal 1 — backend
pixi run bowser run
# Terminal 2 — frontend with HMR on http://localhost:5173
npm run dev
Override the backend URL with VITE_API_URL=http://localhost:8001 npm run dev.
Legacy workflows
DISP-S1 via VRTs (pre-GeoZarr)
The older path is to make a GDAL VRT per NetCDF variable and let bowser
read through those. This predates bowser tifs-to-geozarr and has
two drawbacks: remote NetCDF/HDF5 reads are slow (no standard overview
format), and VRTs require a conda-forge GDAL with the NetCDF driver.
Kept working, but prefer the GeoZarr path above for new setups.
mkdir my_disp_files; cd my_disp-files
s5cmd --numworkers 4 cp 's3://opera-bucket/OPERA_L3_DISP-S1_IW_F11115*/*.nc' .
bowser prepare-disp-s1 -o vrts *.nc
bowser setup-disp-s1 vrts
bowser run
License
Copyright 2024, by the California Institute of Technology. ALL RIGHTS RESERVED. United States Government Sponsorship acknowledged. Any commercial use must be negotiated with the Office of Technology Transfer at the California Institute of Technology.
This software may be subject to U.S. export control laws. By accepting this software, the user agrees to comply with all applicable U.S. export laws and regulations. User has the responsibility to obtain export licenses, or other export authority as may be required before exporting such information to foreign countries or providing access to foreign persons.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bowser_insar-0.4.0.tar.gz.
File metadata
- Download URL: bowser_insar-0.4.0.tar.gz
- Upload date:
- Size: 4.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
535bb5cd5fb8a3b9b35853f2fc632a0124a0249db68c1b675b34e4b98f46d3ab
|
|
| MD5 |
ccd33e30d7b544095219291182a6031d
|
|
| BLAKE2b-256 |
c553ae6d81e7e2a52930ddd667a2c2cdba913eebe55e3a303601ac0c5d69c6b4
|
Provenance
The following attestation bundles were made for bowser_insar-0.4.0.tar.gz:
Publisher:
cd.yml on opera-adt/bowser
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bowser_insar-0.4.0.tar.gz -
Subject digest:
535bb5cd5fb8a3b9b35853f2fc632a0124a0249db68c1b675b34e4b98f46d3ab - Sigstore transparency entry: 1422866837
- Sigstore integration time:
-
Permalink:
opera-adt/bowser@b350475cc6bd7d8cfb773469ed6ea2d197d48f29 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/opera-adt
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cd.yml@b350475cc6bd7d8cfb773469ed6ea2d197d48f29 -
Trigger Event:
release
-
Statement type:
File details
Details for the file bowser_insar-0.4.0-py3-none-any.whl.
File metadata
- Download URL: bowser_insar-0.4.0-py3-none-any.whl
- Upload date:
- Size: 388.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b5a26f0dccc1a4aac9782aaa367a48e9cb2138c384f4826eedde089849056f14
|
|
| MD5 |
20a5b653c46597aa276df946cd4a7601
|
|
| BLAKE2b-256 |
87e9d052998197b92186101a425c8ca0e200689b05a481f8c68c620d35cfae06
|
Provenance
The following attestation bundles were made for bowser_insar-0.4.0-py3-none-any.whl:
Publisher:
cd.yml on opera-adt/bowser
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
bowser_insar-0.4.0-py3-none-any.whl -
Subject digest:
b5a26f0dccc1a4aac9782aaa367a48e9cb2138c384f4826eedde089849056f14 - Sigstore transparency entry: 1422866917
- Sigstore integration time:
-
Permalink:
opera-adt/bowser@b350475cc6bd7d8cfb773469ed6ea2d197d48f29 -
Branch / Tag:
refs/tags/v0.4.0 - Owner: https://github.com/opera-adt
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
cd.yml@b350475cc6bd7d8cfb773469ed6ea2d197d48f29 -
Trigger Event:
release
-
Statement type: