pacman::p_load(
raster, # rasters data
terra, # raster data
exactextractr, # Extracció de raster data agregant-les per pol. sf
sf,
tmap,
tidyverse,
classInt)
terraOptions(progress=0) # Per a no veure la barra de progrés
Introducción
En el ámbito del ODS 11: Alcanzar que las ciudades y los asentamientos humanos sean inclusivos, seguros, resilientes y sostenibles, la meta 11.5 dice: Dentro de 2030, reducir significativamente el número de muertes causadas por los desastres, incluidos los relacionados con el agua, y de personas afectadas por ellos, y reducir considerablemente las pérdidas económicas directas provocadas por los desastres en comparación del producto interno bruto mundial, haciendo especial énfasis en la protección de los pobres y las personas en situaciones de vulnerabilidad.
Siguiendo en el trabajo de búsqueda y evaluación de indicadores que midan los ODS a nivel municipal, como hemos visto en la nota técnica 6, una de las problemáticas recurrentes en España es la de las inundaciones provocadas por lluvias torrenciales. Por eso, estamos investigando datos que nos puedan permitir diseñar una ratio para cuantificar de forma clara objetiva el posible perjuicio que el riesgo de inudación entraña.
Con dicha finalidad testaremos los datos estimados sobre zonas con riesgo de inundación del Servicio de Gestión de Emergencias Copernicus - CEMS-Floods y las del SIOSE - Sistema de Información de Ocupación del Territorio. Esto nos debería permitir obtener una tasa de zona residencial inundable para cada municipio.
Los datos del Servicio de Gestión de Emergencias Copernicus - CEMS-Floods
CEMS-Floods dispone de un conjunto de datos globales y paneuropeos de resolución de 3 segundos de arco (90 m aprox) de inundaciones para diferentes escenarios de periodo de retorno (RP) (10, 20, 50, 75 , 100, 200, 500 años). Estos datos se utilizan para producir la capa de mapas de inundaciones a partir de las previsiones.
¿Qué es el período de retorno? Un evento de 10 años de PR tiene una probabilidad 0,1, es decir del 10% de ser igualado o superado en un año cualquiera (probabilidad de superación = 1/periodo de retorno = 1/10). Para un período de retorno de 100 años, que es el que hemos seleccionado para este trabajo, la probabilidad será del 1%.
Descripción del dataset
Los mapas globales de riesgo de inundaciones fluviales son un dataset en cuadrícula que representa las inundaciones a lo largo de la red fluvial, para siete períodos de retorno de inundaciones diferentes. Los datos de caudal fluvial de entrada para los nuevos mapas se generan mediante el modelo hidrológico de código abierto LISFLOOD, mientras que las simulaciones de inundaciones se realizan con el modelo hidrodinámico LISFLOOD-FP.
LISFLOOD es un modelo que simula el ciclo completo del agua, desde la lluvia hasta llegar a ríos, lagos y aguas subterráneas. Simula los efectos combinados de los cambios meteorológicos y climáticos, el uso del suelo, los cambios socioeconómicos en la demanda de agua, así como las medidas políticas para el ahorro de agua o el control de inundaciones. El modelo se utiliza para estudios hídricos y climáticos, así como para la previsión de inundaciones y sequías.
LISFLOOD-FP es un modelo hidrodinámico bidimensional diseñado específicamente para simular inundaciones en llanuras aluviales de una manera computacionalmente eficiente sobre una topografía compleja. Es capaz de simular cuadrículas de hasta 106 celdas para eventos de inundación dinámicos y puede aprovechar nuevas fuentes de información del terreno provenientes de técnicas de teledetección como la altimetría láser aerotransportada y el radar interferométrico satelital. El modelo predice las profundidades del agua en cada celda de la cuadrícula en cada paso de tiempo y, por lo tanto, puede simular la propagación dinámica de las ondas de inundación sobre llanuras aluviales fluviales, costeras y estuarinas. Es un código de investigación no comercial desarrollado como parte de un esfuerzo por mejorar nuestra comprensión fundamental de la hidráulica de inundaciones, la predicción de inundaciones y la evaluación del riesgo de inundaciones.
Nuestra elección
Hemos utilizado pues dichos datos para mapear el riesgo de inundaciones en Cataluña con un período de retorno de 100 años. Seguramente puede parecer exagerado medir efectos de eventos con ese bajo nivel de probabilidad; sin embargo creemos que puede ser importante por dos razones:
- Nos encontramos en un escenario nuevo: el cambio climático pone en crisis las proyecciones sobre datos históricos. Eventos que se consideraban muy improbables hasta hoy podrían no serlo tanto, en futuro.
- El tema en si está muy relacionados con la planificación urbana que debe (o debería) tener un horizonte muy a largo plazo.
Los datos descargados
Los datasets se pueden descargar en formato
.tif
en esta página, donde habrá que elegir el período de
retorno (RP) y la banda long/lato (la nuestra será N50,
W0).
Para cada período de retorno y para cada ficha, están disponibles dos mapas de riesgo: uno muestra la profundidad bruta del agua y el otro muestra la profundidad del agua categorizada.
Hay que tener en cuenta que las profundidades de agua muy elevadas pueden ser causadas por limitaciones en el modelo hidráulico o por sumideros artificiales. Por parte de los proveedores de los datos, se recomienda precaución al utilizar los valores de profundidad en estas áreas. A nosotros este aspecto nos va a afectar poco, ya que el indicador se creará definiendo áreas inundables, indipendientemente de la profundidad del agua prevista.
#=======================================
# EXTRACCIÓN DE DATOS
#=======================================
#===========================
# 1. MUNICIPIOS SF
#===========================
mun_cat <- st_read("../repo/divisions-administratives/divisions-administratives-v2r1-municipis-1000000-20240118.shp")
## Reading layer `divisions-administratives-v2r1-municipis-1000000-20240118' from data source `C:\DataPortatil\Laboratori_R\Mapes\repo\divisions-administratives\divisions-administratives-v2r1-municipis-1000000-20240118.shp'
## using driver `ESRI Shapefile'
## Simple feature collection with 947 features and 13 fields
## Geometry type: MULTIPOLYGON
## Dimension: XY
## Bounding box: xmin: 260160.2 ymin: 4488767 xmax: 527397.6 ymax: 4747976
## Projected CRS: ETRS89 / UTM zone 31N
mun_cat <- sf::st_as_sf(mun_cat)
mun_cat <- st_transform(mun_cat, crs = 4326)
comar_cat <- st_read("../repo/divisions-administratives/divisions-administratives-v2r1-comarques-1000000-20240118.shp")
## Reading layer `divisions-administratives-v2r1-comarques-1000000-20240118' from data source `C:\DataPortatil\Laboratori_R\Mapes\repo\divisions-administratives\divisions-administratives-v2r1-comarques-1000000-20240118.shp'
## using driver `ESRI Shapefile'
## Simple feature collection with 43 features and 4 fields
## Geometry type: MULTIPOLYGON
## Dimension: XY
## Bounding box: xmin: 260160.2 ymin: 4488767 xmax: 527397.6 ymax: 4747976
## Projected CRS: ETRS89 / UTM zone 31N
comarques <- st_transform(comar_cat, crs = 4326)
#====================================================
# 2. FLOOD DATA - DATOS DE PROYECCION DE INUNDACIONES
# RP - RETURN PERIOD: 100 YEARS - 1% PROBABILITY
#====================================================
# LINKS PARA DESCARGAR DATOS CEMS-GLOFAS SOBRE RIESGOS DE INUNDACIONES
#---------------------------------------------------------------------
# https://jeodpp.jrc.ec.europa.eu/ftp/jrc-opendata/CEMS-GLOFAS/flood_hazard/RP100/ID122_N40_E10_RP100_depth.tif
# https://jeodpp.jrc.ec.europa.eu/ftp/jrc-opendata/CEMS-GLOFAS/flood_hazard/RP100/ID122_N40_E10_RP100_depth_reclass.tif
var <- c(
"depth", "depth_reclass"
)
urls <- paste0(
"https://jeodpp.jrc.ec.europa.eu/ftp/jrc-opendata/CEMS-GLOFAS/flood_hazard/RP100/ID113_N50_W0_RP100_",
var,
".tif"
)
inun_data <- lapply(
urls, terra::rast # It loads raster files into R
)
#==============================
# 3. CROP DATA: ENCAJAAR LOS DATOS DEL RASTER EN LAS COORDENADAS DE MAPA VECTORIAL DE CATALUNYA
#==============================
# Crop the forest data only for Catalonia
# terra::crop takes the raster files and crop them for the extent we choose
cat_data <- lapply(
inun_data,
function(x) {
terra::crop(
x,
terra::vect(mun_cat)
)
}
)
# Para aumentar la resolución del raster
cat_data[[1]] <- terra::disagg(cat_data[[1]], fact=4)
# Igualar extents
ext(cat_data[[1]]) <- ext(mun_cat)
sup.inundable <- cat_data[[1]]
El segundo elemento del indicador
Es evidente que simplemente medir la superficie municipal afectada por eventuales inundaciones es insuficiente para construir el indicador. Como ya destacamos, hay que definir una magnitud cercana a las personas.
En nuestra nota anterior ensayamos la posibilidad de utilizar el Exposure Mapping del Servicio de Gestión de Emergencias de Copernicus para mapear población residente en las celdas del raster del riesgo hidráulico. Sin embargo, descubrimos que, para construir nuestro indicador, ese dato es demasiado impreciso e inestable (en situaciones de ausencia de dato puede en cambio ser muy útil).
SIOSE - Sistema de Información de Ocupación del Territorio
Finalmente, decidimos obviar dicha falta utilizando una magnitud que indirectamente nos mida la posibilidad de daños personales y nos permita realizar comparaciones: la extensión del área residencial afectada. Para ello, hemos utilizado los datos del SIOSE.
También el Institut Cartogràfic i Geològic de Catalunya - ICGC dispone de dichos datos, pero presenta algunas diferencias en la clasificación respecto al SIOSE, con lo cual, hemos utilizado esta fuente, para facilitar, además, la reproducibilidad de nuestra metodología en otras Comunidades Autónomas.
Los datos se pueden descargar en esta página. En el marco de esta trabajo, utilizamos los datos SIOSE en lugar de los SIOSE AR, porque son más ágiles de descarga, aunque no tan definidos y actualizados.
Las coberturas que se han seleccionado son las estrictamente residenciales, esto es las clasificadas con los CODIIGE 111 - Casco, 112 - Ensanche y 113 - Discontinuo (urbanizaciones y similares), excluyendo todas las demás (área verde urbana, industrial, servicio dotacional, aeropuerto, etc.), descritas en el manual de descarga (Anexo II).
Una primera visualización de las capas de datos creadas
El siguiente visor es una representación seguramente interesante. Por eso hemos optado por la imagen satelitar para el mapa base, ya que permite observar muy en detalle las situaciones que necesitan mucho acercamiento, jugando con las tres diferentes capas: la capa de inundabilidad, la capa de zonas residenciales, la de los perímetros municipales y la ortofoto satelital.
Visor de zonas inundables con período de retorno de 100 años en zonas residenciales de diferente tipo
#===================================================
# VISUALIZACIÓN DE LOS DATOS OBTENIDOS CON TMAP
#===================================================
pal <- c('#b9dbfe','#9accff','#6699fe','#3266fe')
tm_shape(sup.inundable)+
tm_raster(alpha = 1,
style = "fixed",
n= 4,
breaks = c(min(values(cat_data[[1]]), na.rm=TRUE),
0.999,2.999,9.999,
max(values(cat_data[[1]]), na.rm=TRUE)),
palette = pal,
labels = c("0.10 - 0.99",
"1.00 - 2.99",
"3.00 - 9.99",
">= 10"),
legend.format = list(text.separator= '-'),
title = "Profundidad de inundación (m)") +
tm_shape(zona_residencial) +
tm_polygons(
col = "CODIIGE",
style = "cat",
n=4,
palette = c("darkred","papayawhip"),
labels = c("Casco","Ensanche","Discontinuo"),
title= "Tipo de ocupación urbana",
alpha = 0.6,
legend.show = TRUE,
interactive= FALSE
) +
tm_shape(mun_cat)+
tm_polygons(id= "NOMMUNI",
border.col = "steelblue",
alpha=0,
lwd= 0.8,
popup.vars=c("Superficie municipal: "= "AREAM5000"),
popup.format = list(AREAM5000= list(digits = 2))
) +
tmap_mode('view') +
tm_view(set.view = 10) +
tmap_options(basemaps = "Esri.WorldImagery",
basemaps.alpha = 1,
check.and.fix = TRUE)