Skip to content

Commit

Permalink
Update inventory from hazard; add to documentation (exposed in Open API)
Browse files Browse the repository at this point in the history
Signed-off-by: Joe Moorhouse <[email protected]>
  • Loading branch information
joemoorhouse committed Dec 31, 2024
1 parent 266bbb2 commit 6da3756
Show file tree
Hide file tree
Showing 3 changed files with 141 additions and 53 deletions.
15 changes: 15 additions & 0 deletions src/physrisk/api/v1/common.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
from enum import Enum
from typing import Annotated, Dict, List, Optional, Sequence, Union

import numpy as np
Expand All @@ -22,6 +23,20 @@ def serialize_array(array: npt.NDArray) -> str:
]


class HazardType(str, Enum):
coastal_inundation = "CoastalInundation"
chronic_heat = "ChronicHeat"
drought = "Drought"
fire = "Fire"
hail = "Hail"
pluvial_inundation = "PluvialInundation"
precipitation = "Precipitation"
riverine_inundation = "RiverineInundation"
subsidence = "Subsidence"
water_risk = "WaterRisk"
wind = "Wind"


class Asset(BaseModel):
"""Defines an asset.
Expand Down
58 changes: 56 additions & 2 deletions src/physrisk/api/v1/hazard_data.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@

from pydantic import BaseModel, Field

from physrisk.api.v1.common import BaseHazardRequest, IntensityCurve
from physrisk.api.v1.common import BaseHazardRequest, HazardType, IntensityCurve


class Colormap(BaseModel):
Expand Down Expand Up @@ -202,7 +202,7 @@ class HazardDataRequestItem(BaseModel):
longitudes: List[float]
latitudes: List[float]
request_item_id: str
hazard_type: Optional[str] = None # e.g. RiverineInundation
hazard_type: Optional[HazardType] = None # e.g. RiverineInundation
event_type: Optional[str] = (
None # e.g. RiverineInundation; deprecated: use hazard_type
)
Expand All @@ -214,6 +214,25 @@ class HazardDataRequestItem(BaseModel):


class HazardDataRequest(BaseHazardRequest):
"""Request hazard indicator data for a set of locations, specified by latitude and longitude
(in coordinate reference system EPSG:4326).
A hazard indicator is defined by the type of the hazard ('hazard_type') and the indicator ('indicator_id').
A hazard indicator is a measure that is used to quantify the hazard. For example, for hazard type
'RiverineInundation', flood depth (unprotected) is given by the indicator 'flood_depth'.
In addition, 'scenario' and 'year' are required. For 'historical' scenario, year is ignored and can
be set to e.g. '-1'. Scenarios can be RCPs and SSPs; convention is e.g. 'rcp8p5' (RCP 8.5) and
'ssp585'.
If only 'hazard_type' and 'indicator_id' are provided, then the default physrisk logic will be used to
identify the data sets. If a specific data set is required, 'path' can be supplied. The path is the
unique identifier of a 'hazard resource'. A hazard resource is a collection of data arrays for different
scenarios and years, typically made available by the same model provider.
Current behaviour is that empty arrays are returned if there is no match for the scenario and year in the
selected / specified resource (an alternative would be to allow interpolation of years and proxying/interpolation
of scenarios).
"""

interpolation: str = "floor"
provider_max_requests: Dict[str, int] = Field(
{},
Expand All @@ -223,6 +242,41 @@ class HazardDataRequest(BaseHazardRequest):
)
items: List[HazardDataRequestItem]

model_config = {
"json_schema_extra": {
"examples": [
{
"items": [
{
"request_item_id": "my_id",
"hazard_type": "RiverineInundation",
"indicator_id": "flood_depth",
"latitudes": [45.4089, 43.4923],
"longitudes": [20.3162, 4.7877],
"path": "inundation/river_tudelft/v2/flood_depth_unprot_{scenario}_{year}",
"scenario": "rcp8p5",
"year": 2035,
}
]
},
{
"items": [
{
"request_item_id": "my_id",
"hazard_type": "RiverineInundation",
"indicator_id": "flood_depth",
"latitudes": [45.4089, 43.4923],
"longitudes": [20.3162, 4.7877],
"path": "inundation/river_tudelft/v2/flood_depth_unprot_{scenario}_{year}",
"scenario": "historical",
"year": -1,
}
]
},
]
}
}


class HazardDataResponseItem(BaseModel):
intensity_curve_set: List[IntensityCurve]
Expand Down
Loading

0 comments on commit 6da3756

Please sign in to comment.