MintPy use pyKML to generate KMZ (Keyhole Markup Zip) files for easy offline viewing in Google Earth via save_kmz_timeseries.py
and save_kmz.py
script. Below are screenshots of the displacement time-series and average velocity of Fernandina volcano estimated from Sentinel-1 data.
save_kmz_timeseries.py
takes 3D displacement time-series file and outputs a KMZ file with interactive time-seires plot.
save_kmz.py
takes any 2D matrix and outputs a KMZ file with a overlay image.
save_kmz_timeseries.py takes the 3D HDF5 file and outputs a KMZ file at multiple levels of details (LODs). It divides the data matrix into regionalized boxes, writes the required KML files, references the appropriate auxiliary resources, and zips all of the files together into a KMZ file.
The script also embeds a javascript using dygraphs for interactive plot of the time-series deformation at each point. This allows the user to select any placemark onscreen to display the time-series data in an interactive chart. The Placemarks are colored based on the velocity.
KML files are capable of holding a very large amount of data, but earth viewer programs, such as Google Earth, often struggle to display extremely large datasets effectively. As such, a few tradeoffs and specialized file structures have been enabled within save_kmz_timeseries.py
to increase Google Earth's performance with large data sets.
- Multiple Levels of Detail
By default, MintPy will read in the provided dataset and then subset the data into three separate levels of details: a low resolution, a high-resolution, and a full-resolution. The low-resolution LOD contains 1 point for every 20x20 points in the original file. The high-resolution LOD contains 1 point for every 3x3 points in the original file. And the full-resolution LOD contains every point in the original file.
Each LOD is displayed at a different zoom-level within Google Earth. On startup, the low-resolution LOD is displayed, while the high-resolution LOD becomes visible around 20km in altitude, and the full-resolution LOD at around 10km in altitude. This ensures that Google Earth only has to load as many Placemark as are on the screen currently, which drastically increases performance as fewer Placemarks are onscreen at higher zoom levels.
The full-resolution LOD is presently calculated and presented only for those actions showing signs of active deformation so as to further increase performance.
- Regionalized Network Links
To further increase performance, MintPy splits each LOD into 300x300 point subsets known as regions. Each region is written to a separate KML file, and are then referenced via a "Network Link" in a master level KML file. Google Earth specifically has the ability to load conditionally load Network Link elements based on whether or not the coordinates dictating their bounding box are on screen at a given moment, so this method ensures that, at high zoom-levels, only as many placemarks as are onscreen at the time are loaded.
If you wish to add or modify the levels of detail or other aspects of the KMZ generation process, the function generate_network_link(inps, ts_obj, box_list, step, lod, output_file=None)
handles the generation and reference linking of the required files. Be sure to handle the initial reading of the data and filesystem cleanup afterward.