diff --git a/.gitignore b/.gitignore index 4cae3f03..7719602e 100644 --- a/.gitignore +++ b/.gitignore @@ -132,4 +132,6 @@ examples/data/aggregation_zones/output /examples/aggregation_zones_example_files /examples/data/aggregation_zones/aggregation_zones_test1/ /examples/data/aggregation_zones/aggregation_zones_test2/ -examples/aggregation_zones_example.html \ No newline at end of file +examples/aggregation_zones_example.html +examples/aggregation_zones_example_files/ +examples/data/road_network/FIAT model \ No newline at end of file diff --git a/docs/_static/Region_download.PNG b/docs/_static/Region_download.PNG new file mode 100644 index 00000000..b3b17536 Binary files /dev/null and b/docs/_static/Region_download.PNG differ diff --git a/docs/_static/charelston.PNG.svg b/docs/_static/charelston.PNG.svg new file mode 100644 index 00000000..6d2a318e --- /dev/null +++ b/docs/_static/charelston.PNG.svg @@ -0,0 +1,39 @@ + + + + + + + + + + diff --git a/examples/add_roadnetwork.ipynb b/examples/add_roadnetwork.ipynb new file mode 100644 index 00000000..0224320d --- /dev/null +++ b/examples/add_roadnetwork.ipynb @@ -0,0 +1,1319 @@ +{ + "cells": [ + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **FIAT Model Setup for a Road Network**" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "Roads are vital to the infrastructure of a community and, when blocked and/or (partially) destroyed \n", + "cause numerous issues for various players. Therefore, it is imperative to assess the impact of loss in mobility when analyzing flood events and other hazards. \n", + "\n", + "FIAT offers a tool to compute the monetary impact of the road blockage/destruction based on the **extent of the hazard, the road type (e.g. motorway, trunk, primary roads), and the number of lanes.**\n", + "\n", + "To run the FIAT model on a road network it is necessary to create the [exposure data](https://github.com/Deltares/Delft-FIAT/blob/master/docs/user_guide/data/exposure.qmd) and [vulnerability data](https://github.com/Deltares/Delft-FIAT/blob/master/docs/user_guide/data/vulnerability.qmd).\n", + "\n", + "**Notebook Output**: \n", + "The output of this notebook will be: \n", + "- `exposure data`\n", + "- `vulnerability data` \n", + "\n", + " which are neccessary to run the FIAT model for various events and scenarios of a flood event on a road network.\n", + "\n", + "\n", + ">*Note: This notebook will cover the road impact assessment based on Open Sreet Map (OSM) data." + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Let's get started!**" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Step 1**: Import required packages" + ] + }, + { + "cell_type": "code", + "execution_count": 2, + "metadata": {}, + "outputs": [], + "source": [ + "# First, all required packages must be installed.\n", + "\n", + "from hydromt_fiat.fiat import FiatModel\n", + "from hydromt.log import setuplog\n", + "from pathlib import Path\n", + "import geopandas as gpd\n", + "import pandas as pd\n", + "import os \n", + "import json\n", + "import yaml\n", + "from hydromt.config import configread\n", + "from shapely.geometry import Polygon\n", + "import matplotlib.pyplot as plt" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Step 2:** Data Input" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "To run FIAT the user must provide data about the road network and the sudy area of interest;\n", + "- Polygon of the region of interest (from the coordinates we will create a shapely polygon)\n", + "- Information on the road network within the study area (geospatial file format e.g. *.shp, *.geojson, *.gpkg ):\n", + " - road type\n", + " - number of lanes\n", + " - segment length\n", + "- Model configuration (see section **Step 2b: Create configuration file**) " + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## **Step 2a:** Define the study area" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "FIAT requires the input of a region in form of a **shapely Polygon** to download the **OSM road dataset**. This can be done via **vector file** or **GeoJSON object** of the study area. We recommened to download the region from [Geojson.io](https://geojson.io/#map=2/0/20). \n", + "\n", + "**GeoJson.io** \n", + "Draw a polygon on the map and create a polygon from the GeoJson Object. You can download a vector file, you need to refer to in the \"region\" tab in the *yaml* file using the file path. You can also copy the GeoJson code directly into the configuration file (see example in [configuration file](C:/Users/rautenba/hydromt_fiat/examples/data/road_network/configuration.yml)).\n", + "\n", + "![Region_download.PNG](../docs/_static/charelston.PNG.svg)\n" + ] + }, + { + "cell_type": "code", + "execution_count": 3, + "metadata": {}, + "outputs": [], + "source": [ + "# Create a dictionary of the GeoJson Object\n", + "\n", + "region = {\n", + " \"type\": \"FeatureCollection\",\n", + " \"features\": [\n", + " {\n", + " \"type\": \"Feature\",\n", + " \"properties\": {},\n", + " \"geometry\": {\n", + " \"type\": \"Polygon\",\n", + " \"coordinates\": [\n", + " [\n", + " [-79.96177042294748, 32.79061007407526],\n", + " [-79.96177042294748, 32.76748645567278],\n", + " [-79.91724162366485, 32.76748645567278],\n", + " [-79.91724162366485, 32.79061007407526],\n", + " [-79.96177042294748, 32.79061007407526],\n", + " ]\n", + " ],\n", + " },\n", + " }\n", + " ],\n", + "}\n", + "\n", + "# Extract the coordinates\n", + "coordinates = region[\"features\"][0][\"geometry\"][\"coordinates\"]\n", + "\n", + "# Create a Shapely Polygon\n", + "polygon = Polygon(coordinates[0]) # Extract the coordinates of the exterior ring" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "## **Step 2b:** Create the configuration file" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "We must configure the FIAT model form of a `yaml`-file or a dictionary, in which the model parameters are defined. The configuration file must define the **vulnerability** and **exposure setup**. \n", + "The required fields are:\n", + " \n", + "*setup_road_vulnerability:*\n", + "- **vertical_unit**:Unit of vertical inundation (feet or meter)\n", + "- **threshold_value**: Threshold inundation height at which road is fully destroyed \n", + "- **min_hazard_value**: minimum inundation height (recommended: 0)\n", + "- **max_hazard_value**: maximum inundation height (e.g. 6 meters) \n", + "- **step_hazard_value**: discrete levels or steps of inundation height\n", + "\n", + "*setup_exposure_roads:*\n", + "- **roads_fn**: File path to road network file or OSM data (for OSM data use: \"OSM\")\n", + "- **road_types**: Road type keys (if OSM data use keys from from OSM e.g. \"motorway\", \"primary\")\n", + "- **road_damage**: Damages per lane and per length unit\n", + "- **unit**: Unit of road length (feet or meter)\n", + "\n", + "The provided parameters need to be incorporated into the YAML structure. Please check [here](C:/Users/rautenba/hydromt_fiat/examples/data/road_network/configuration.yaml) for the setup of the *configuration.yml*. " + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "### Load the configuration file" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "**This step is not necessary to run the model. It's just for visualization purposes.** \n", + "\n", + "The configuration file can be read in python and its information are converted into a python dictionary.

\n", + "

Note: Instead of loading a yaml file it is possible to create a python dictionary directly, built upon the structure seen below.

" + ] + }, + { + "cell_type": "code", + "execution_count": 4, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "{\n", + " \"setup_road_vulnerability\": {\n", + " \"vertical_unit\": \"feet\",\n", + " \"threshold_value\": 0.6,\n", + " \"min_hazard_value\": 0,\n", + " \"max_hazard_value\": 10,\n", + " \"step_hazard_value\": 1\n", + " },\n", + " \"setup_exposure_roads\": {\n", + " \"roads_fn\": \"OSM\",\n", + " \"road_types\": [\n", + " \"motorway\",\n", + " \"primary\",\n", + " \"secondary\",\n", + " \"tertiary\"\n", + " ],\n", + " \"road_damage\": \"default_road_max_potential_damages\",\n", + " \"unit\": \"meter\"\n", + " }\n", + "}\n" + ] + } + ], + "source": [ + "# Let's read the configuration file holding the required information for the FIAT model \n", + "with open(Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"configuration.yaml\", 'r') as file:\n", + " config = yaml.safe_load(file)\n", + "\n", + "print(json.dumps(config, indent=4, sort_keys=False))" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Step 3**: Define variables for the FIAT model" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "To build the model some settings must be ingested as variables. So you need to set up the root path to the FIAT model, the logger settings, the region and the data catalog:\n", + "- `root`: Directory path where the FIAT model data is stored. \n", + "- `logger`: The logger variable defines the frequencies of log-entries during the initialisation of the model.\n", + "- `region`: Define the region as a variable from the config dictionary.\n", + "- `data_catalog_yml`: Define the data catalogue as a variable from the config dictionary.\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 5, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:02,291 - hydromt_fiat - log - INFO - HydroMT version: 0.8.0\n" + ] + } + ], + "source": [ + "# Set up Fiat Model\n", + "root = Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"FIAT model\" \n", + "\n", + "# Set up the logger\n", + "logger = setuplog(\"hydromt_fiat\", log_level=10)\n", + "\n", + "# Set up datacatalog\n", + "data_catalog_yml = Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"hydromt_fiat_catalog_USA.yml\"" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Step 4:** Run the FIAT model" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "It's time to run the road network FIAT model. The output will be stored in the root-directory. \n", + "\n", + "The output will be an **exposure folder** incl. `exposure.csv` together with vector data files, a **vulnerability folder** incl. `damage_curve.csv`, a **hazard folder** (empty) and an **output folder** (empty). \n", + "\n", + ">*Note*: Ignore the output folder (in this notebook only)! \n", + " In this example we don't provide any hazard data, so the `output folder` will be empty. In case hazard data is provided the `output` folder contains an updated `exposure.csv` with the damages of the event on the road segment." + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,731 - hydromt_fiat - data_catalog - INFO - Parsing data catalog from c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\hydromt_fiat_catalog_USA.yml\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Parsing data catalog from c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\hydromt_fiat_catalog_USA.yml\n", + "WARNING:py.warnings:c:\\Users\\rautenba\\AppData\\Local\\mambaforge\\envs\\hydromt-fiat-dev\\lib\\site-packages\\hydromt\\data_adapter\\geodataframe.py:99: DeprecationWarning: Passing additional keyword arguments to be used by the GeoDataFrameAdapter driver is deprecated and will be removed in a future version. Please use 'driver_kwargs' instead.\n", + " warnings.warn(\n", + "\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,744 - hydromt_fiat - model_api - WARNING - Model dir already exists and files might be overwritten: c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\exposure.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "WARNING:hydromt_fiat:Model dir already exists and files might be overwritten: c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\exposure.\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,746 - hydromt_fiat - model_api - WARNING - Model dir already exists and files might be overwritten: c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\vulnerability.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "WARNING:hydromt_fiat:Model dir already exists and files might be overwritten: c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\vulnerability.\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,749 - hydromt_fiat - model_api - INFO - Initializing fiat model from hydromt_fiat (v0.2.1.dev0).\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Initializing fiat model from hydromt_fiat (v0.2.1.dev0).\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,760 - hydromt_fiat - model_api - INFO - setup_region.region: {'geom': geometry\n", + "0 POLYGON ((-79.96177 32.79061, -79.96177 32.767...}\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_region.region: {'geom': geometry\n", + "0 POLYGON ((-79.96177 32.79061, -79.96177 32.767...}\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,763 - hydromt_fiat - basin_mask - DEBUG - Parsed region (kind=geom): {'geom': 'GeoDataFrame [-79.96177042 32.76748646 -79.91724162 32.79061007] (crs = EPSG:4326)'}\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "DEBUG:hydromt_fiat:Parsed region (kind=geom): {'geom': 'GeoDataFrame [-79.96177042 32.76748646 -79.91724162 32.79061007] (crs = EPSG:4326)'}\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,767 - hydromt_fiat - model_api - INFO - setup_road_vulnerability.vertical_unit: feet\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_road_vulnerability.vertical_unit: feet\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,768 - hydromt_fiat - model_api - INFO - setup_road_vulnerability.threshold_value: 0.6\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_road_vulnerability.threshold_value: 0.6\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,770 - hydromt_fiat - model_api - INFO - setup_road_vulnerability.min_hazard_value: 0\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_road_vulnerability.min_hazard_value: 0\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,772 - hydromt_fiat - model_api - INFO - setup_road_vulnerability.max_hazard_value: 10\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_road_vulnerability.max_hazard_value: 10\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,773 - hydromt_fiat - model_api - INFO - setup_road_vulnerability.step_hazard_value: 1\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_road_vulnerability.step_hazard_value: 1\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,775 - hydromt_fiat - model_api - INFO - setup_exposure_roads.roads_fn: OSM\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_exposure_roads.roads_fn: OSM\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,776 - hydromt_fiat - model_api - INFO - setup_exposure_roads.road_damage: default_road_max_potential_damages\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_exposure_roads.road_damage: default_road_max_potential_damages\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,778 - hydromt_fiat - model_api - INFO - setup_exposure_roads.road_types: ['motorway', 'primary', 'secondary', 'tertiary']\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_exposure_roads.road_types: ['motorway', 'primary', 'secondary', 'tertiary']\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,779 - hydromt_fiat - model_api - INFO - setup_exposure_roads.unit: meter\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:setup_exposure_roads.unit: meter\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,781 - hydromt_fiat - exposure_vector - INFO - Setting up roads...\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Setting up roads...\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,939 - hydromt_fiat - exposure_vector - INFO - The damage function 'roads' is selected for all of the structure damage to the roads.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:The damage function 'roads' is selected for all of the structure damage to the roads.\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,941 - hydromt_fiat - data_catalog - INFO - DataCatalog: Getting default_road_max_potential_damages DataFrame csv data from c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\us_road_damage.csv\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:DataCatalog: Getting default_road_max_potential_damages DataFrame csv data from c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\us_road_damage.csv\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,943 - hydromt_fiat - dataframe - INFO - DataFrame: Read csv data.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:DataFrame: Read csv data.\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,968 - hydromt_fiat - exposure_vector - INFO - Setting exposure geometries...\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Setting exposure geometries...\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,970 - hydromt_fiat - exposure_vector - INFO - Setting geometry name to roads...\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Setting geometry name to roads...\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,973 - hydromt_fiat - fiat - INFO - Updating all data objects...\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Updating all data objects...\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,975 - hydromt_fiat - model_api - ERROR - Default config file not found at c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\fiat\\settings.toml\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "ERROR:hydromt_fiat:Default config file not found at c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\fiat\\settings.toml\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,977 - hydromt_fiat - model_api - WARNING - Replacing geom: region\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "WARNING:hydromt_fiat:Replacing geom: region\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,979 - hydromt_fiat - fiat - INFO - Writing model data to c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Writing model data to c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,980 - hydromt_fiat - model_api - INFO - Writing model config to c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\settings.toml\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Writing model config to c:\\Users\\rautenba\\hydromt_fiat\\examples\\data\\road_network\\FIAT model\\settings.toml\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:15,982 - hydromt_fiat - model_api - DEBUG - Writing file exposure/region.gpkg\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "DEBUG:hydromt_fiat:Writing file exposure/region.gpkg\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:16,070 - hydromt_fiat - model_api - DEBUG - Writing file exposure/roads.gpkg\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "DEBUG:hydromt_fiat:Writing file exposure/roads.gpkg\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:16,182 - hydromt_fiat - fiat - INFO - Writing model exposure table file to exposure/exposure.csv.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Writing model exposure table file to exposure/exposure.csv.\n" + ] + }, + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2023-10-31 14:00:16,187 - hydromt_fiat - fiat - INFO - Writing model vulnerability_curves table file to vulnerability/vulnerability_curves.csv.\n" + ] + }, + { + "name": "stderr", + "output_type": "stream", + "text": [ + "INFO:hydromt_fiat:Writing model vulnerability_curves table file to vulnerability/vulnerability_curves.csv.\n" + ] + } + ], + "source": [ + "# Build the FIAT model \n", + "fiat_model = FiatModel(root=root, mode=\"w+\", data_libs=[data_catalog_yml], logger=logger)\n", + "\n", + "region = gpd.GeoDataFrame.from_features(region, crs=4326)\n", + "opt = configread(Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"configuration.yaml\")\n", + "fiat_model.build(region={\"geom\": region}, opt=opt, write=False)\n", + "fiat_model.write()" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "# **Done!**\n", + "Your **FIAT model** created the exposure and vulnerability files for the road network. Using that data in combination with a hazard map, the impact for the defined hazard can be computed. \n", + "\n", + "Let's have a look at the output!" + ] + }, + { + "cell_type": "code", + "execution_count": 24, + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "
Make this Notebook Trusted to load map: File -> Trust Notebook
" + ], + "text/plain": [ + "" + ] + }, + "execution_count": 24, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "# Load exposure.csv into dataframe\n", + "df_exposure = pd.read_csv(Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"FIAT model\" / \"exposure\" / \"exposure.csv\")\n", + "\n", + "# Load exposure geopackage into GeoDataFrame\n", + "gdf_exposure =gpd.read_file(Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"FIAT model\" / \"exposure\" / \"roads.gpkg\")\n", + "\n", + "# Merge dataframe with GeoDataFrame\n", + "merged_gdf = gdf_exposure.merge(df_exposure, left_on='Object ID', right_on='Object ID', how='inner')\n", + "\n", + "# Display the road network\n", + "road_network = merged_gdf.explore(column = 'Max Potential Damage: Structure')\n", + "road_network" + ] + }, + { + "cell_type": "markdown", + "metadata": {}, + "source": [ + "The vulnerability is translated into a step function, which is determined by the water level threshold. Water levels beyond the threshold result in untraversible road segments. \n", + "\n", + "We can have a look at the `vulnerability.csv` output and the vulnerability curve. " + ] + }, + { + "cell_type": "code", + "execution_count": 11, + "metadata": {}, + "outputs": [ + { + "data": { + "text/html": [ + "
\n", + "\n", + "\n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + " \n", + "
#UNIT=feet
#METHODmean
water depth [feet]roads
0.00.0
0.590.0
0.61.0
1.01.0
2.01.0
3.01.0
4.01.0
5.01.0
6.01.0
7.01.0
8.01.0
9.01.0
10.01.0
\n", + "
" + ], + "text/plain": [ + " #UNIT=feet\n", + "#METHOD mean\n", + "water depth [feet] roads\n", + "0.0 0.0\n", + "0.59 0.0\n", + "0.6 1.0\n", + "1.0 1.0\n", + "2.0 1.0\n", + "3.0 1.0\n", + "4.0 1.0\n", + "5.0 1.0\n", + "6.0 1.0\n", + "7.0 1.0\n", + "8.0 1.0\n", + "9.0 1.0\n", + "10.0 1.0" + ] + }, + "execution_count": 11, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "# Display vulnerability.csv \n", + "df_vulnerability = pd.read_csv(Path(os.path.abspath(\"\")) / \"data\" / \"road_network\" / \"FIAT model\" / \"vulnerability\" / \"vulnerability_curves.csv\")\n", + "df_vulnerability" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": {}, + "outputs": [ + { + "data": { + "image/png": "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", + "text/plain": [ + "
" + ] + }, + "metadata": {}, + "output_type": "display_data" + } + ], + "source": [ + "# Display vulnerability curves\n", + "water_depths = fiat_model.vulnerability.hazard_values\n", + "\n", + "# Plot damage curves for some occupancy types\n", + "line_styles = ['--', '-', ':']\n", + "for function_name, ls in zip(fiat_model.vulnerability.functions.keys(), line_styles):\n", + " dmg = [float(i) for i in fiat_model.vulnerability.functions[function_name]]\n", + " plt.plot(water_depths, dmg, label=function_name, ls=ls)\n", + "plt.xlabel('depth (m)')\n", + "plt.ylabel('damage fraction (-)')\n", + "plt.legend(bbox_to_anchor=(1.04, 1), loc=\"upper left\")\n", + "plt.show()" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "hydromt-fiat-dev", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.12" + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/examples/data/road_network/configuration.yaml b/examples/data/road_network/configuration.yaml new file mode 100644 index 00000000..f0c0b7ca --- /dev/null +++ b/examples/data/road_network/configuration.yaml @@ -0,0 +1,12 @@ +setup_road_vulnerability: + vertical_unit: feet + threshold_value: 0.6 + min_hazard_value: 0 + max_hazard_value: 10 + step_hazard_value: 1 +setup_exposure_roads: + roads_fn: OSM + road_types: ["motorway", "primary", "secondary", "tertiary"] + road_damage: default_road_max_potential_damages + unit: meter + \ No newline at end of file diff --git a/examples/data/road_network/hydromt_fiat_catalog_USA.yml b/examples/data/road_network/hydromt_fiat_catalog_USA.yml new file mode 100644 index 00000000..40481d85 --- /dev/null +++ b/examples/data/road_network/hydromt_fiat_catalog_USA.yml @@ -0,0 +1,57 @@ + +NSI: + path: "https://nsi.sec.usace.army.mil/nsiapi/structures?fmt=fc" + data_type: GeoDataFrame + driver: vector + crs: 4326 + translation_fn: "attribute_linking/NSI_attributes_to_FIAT.json" + meta: + category: exposure + +default_vulnerability_curves: + path: damage_functions/flooding/Hazus_IWR_curves.csv + data_type: DataFrame + driver: csv + meta: + unit: ft + category: vulnerability + source: HAZUS SQL database, USACE-IWR and FEMA expert elicitation curves. The source of these curves is the Draft Report Nonresidential Flood Depth-Damage Functions Derived from Expert Elicitation, April 2009, Revised 2013. FEMA Contract Number HSFEHQ-06-D-0162. Task Order HSFEHQ-08-J-0014. Not for distribution, but data shared by USACE. + +jrc_vulnerability_curves: + path: damage_functions/flooding/JRC_damage_functions.xlsx + data_type: DataFrame + driver: xlsx + meta: + unit: m + category: vulnerability + +hazus_max_potential_damages: + path: max_potential_damages/damage_values_fema_hazus-inventory-technical-manual-4.2.3.xlsx + data_type: DataFrame + driver: xlsx + meta: + unit: ft + category: vulnerability + +social_vulnerability: + path: social_vulnerability/census_vulnerability_data_codebook.xlsx + data_type: DataFrame + driver: xlsx + meta: + category: social_vulnerability + +default_hazus_iwr_linking: + path: vulnerability_linking/default_hazus_iwr_curve_linking.csv + data_type: DataFrame + driver: csv + meta: + category: vulnerability + +default_road_max_potential_damages: + path: us_road_damage.csv + data_type: DataFrame + driver: csv + meta: + unit: ft + category: exposure + source: Bouwer, Laurens & Haasnoot, Marjolijn & Wagenaar, Dennis & Roscoe, Kathryn. (2018). Assessment of alternative flood mitigation strategies for the C-7 Basin in Miami, Florida. \ No newline at end of file diff --git a/examples/data/road_network/us_road_damage.csv b/examples/data/road_network/us_road_damage.csv new file mode 100644 index 00000000..54ceaf71 --- /dev/null +++ b/examples/data/road_network/us_road_damage.csv @@ -0,0 +1,7 @@ +lanes,cost [USD/ft] +1,240 +2,240 +3,360 +4,480 +5,600 +6,720