-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #395 from GEMScienceTools/slab_geojson
Slab geojson
- Loading branch information
Showing
13 changed files
with
69,860 additions
and
20 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,88 @@ | ||
#!/usr/bin/env python | ||
# ------------------- The OpenQuake Model Building Toolkit -------------------- | ||
# Copyright (C) 2022 GEM Foundation | ||
# _______ _______ __ __ _______ _______ ___ _ | ||
# | || | | |_| || _ || || | | | | ||
# | _ || _ | ____ | || |_| ||_ _|| |_| | | ||
# | | | || | | ||____|| || | | | | _| | ||
# | |_| || |_| | | || _ | | | | |_ | ||
# | || | | ||_|| || |_| | | | | _ | | ||
# |_______||____||_| |_| |_||_______| |___| |___| |_| | ||
# | ||
# This program is free software: you can redistribute it and/or modify it under | ||
# the terms of the GNU Affero General Public License as published by the Free | ||
# Software Foundation, either version 3 of the License, or (at your option) any | ||
# later version. | ||
# | ||
# This program is distributed in the hope that it will be useful, but WITHOUT | ||
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS | ||
# FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more | ||
# details. | ||
# | ||
# You should have received a copy of the GNU Affero General Public License | ||
# along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
# ----------------------------------------------------------------------------- | ||
# vim: tabstop=4 shiftwidth=4 softtabstop=4 | ||
# coding: utf-8 | ||
|
||
import toml | ||
from openquake.baselib import sap | ||
from openquake.wkf.utils import create_folder | ||
from openquake.sub.get_profiles_from_slab2pt0 import get_profiles_geojson | ||
|
||
|
||
def main(fname_conf: str): | ||
""" | ||
Given a geojson file and the Slab2.0 depth .grd file, this code creates | ||
a set of profiles describing the surface of the slab. | ||
The geojson file should contain cross-sections as line segments, with | ||
dipdir and length (in m) columns for each cross-section | ||
(see sub/tests/data/izu_slab2_css.geojson for example) | ||
:param fname_conf: | ||
Name of the .toml formatted file. If the configuration file defines | ||
the `output_folder` variable, the profiles are saved in that folder | ||
for further use. If the configuration file defines the `fname_fig` | ||
variable, a figure with the traces is saved. | ||
Example of .toml file | ||
``` | ||
fname_geojson ='izu_slab2_css.geojson' | ||
fname_dep ='izu_slab2_dep_02.24.18.grd' | ||
spacing = 200.0 | ||
folder_out = './cs' | ||
fname_fig = './mar.pdf' | ||
``` | ||
""" | ||
|
||
# Read configuration file | ||
conf = toml.load(fname_conf) | ||
|
||
# Name of the .grd file with the depth values | ||
fname_dep = conf.get('fname_dep', None) | ||
|
||
# Name of the geojson file | ||
fname_geojson = conf.get('fname_geojson', None) | ||
|
||
# set spacing from configuration file | ||
spacing = conf.get('spacing', 100.) | ||
|
||
# Name of the folder where to save the profiles | ||
folder_out = conf.get('folder_out', None) | ||
|
||
# Name of the figure | ||
fname_fig = conf.get('fname_fig', '') | ||
|
||
# Get profiles | ||
slb = get_profiles_geojson(fname_geojson, fname_dep, spacing, fname_fig) | ||
|
||
# Save profiles | ||
if folder_out is not None: | ||
create_folder(folder_out) | ||
slb.write_profiles(folder_out) | ||
|
||
|
||
main.fname_conf = 'Name of .toml file with configuration parameters' | ||
|
||
if __name__ == '__main__': | ||
sap.run(main) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.