Skip to content

Latest commit

 

History

History
825 lines (692 loc) · 47.7 KB

glacier_modeling.qmd

File metadata and controls

825 lines (692 loc) · 47.7 KB
## Modeling of Discharge from Glacier Melt {#sec-glacier-modeling} The glacier melt modeling in RSMinerve [@rsminerve_tm] is done (at the time of writing, March 2022) with the GSM model which features a constant area and an unlimited glacier reservoir. It is suitable for short-term simulations of glacier melt where effects of glacier volume change can be neglected but it is not well suited for climate change impact studies where substantial changes in glacier volume are to be expected. However, by assuming that discharge from snow melt can be treated independently from discharge from glacier melt, the discharge contribution from glacier melt can be simulated in R and included as source into RSMinerve models. The following chapter relies on the basic understanding of the glacier mass balance as presented and discussed in [Chapter Snow and Glacier Data](@sec-snow-and-glacier-data), describes the glacier modelling tools in the package `riversCentralAsia` and demonstrates how to use them for joint applied hydrological modelling with RSMinerve. ## Glacier Mass Balance We shift the focus from the catchment to one single glacier within the catchment. Instead of calculating the water balance over the river catchment, we calculate the balance over the glacier. ![Simplified illustration of a glacierized river basin with elevation bands in dashed lines. The zoom is on one of the larger glaciers which can itself be discretized into elevation bands. The glacier mass loss is substracted from the lower most elevation band in increasing elevation.](images/hydrological_modeling/glacier_modeling_zoom_in_elevation_bands.png){#fig-glacier-model-zoom-in} The glacier mass balance is given in @eq-general-glacier-mass-balance [@oneel_reanalysis_2019]. $$ \Delta S = \text{ablation} + \text{accumulation} $$ {#eq-general-glacier-mass-balance} where $\text{ablation}$ denotes the ablation of glacier mass, i.e. glacier mass loss, and $\text{accumulation}$ is the accumulation of glacier mass, i.e. glacier mass growth. Glacier ablation can be modeled using a temperature index model (described in the next section). Note that the ablation term is a negative number. Many processes contribute to glacier ablation and accumulation, e.g. [@cogley_glossary_2011, @benn_glaciers_2010]. The most dominant accumulation processes in high mountain areas are snow fall, avalanches and wind-blown snow. In high mountain regions, glacier ablation is driven by the energy balance at the glacier-air interface [@hock_glacier_2005]. For most regional hydrological modeling tasks, is is sufficient to simplify the glacier mass balance to @eq-simplified-glacier-mass-balance [@oneel_reanalysis_2019]. A glacier that is in balance will melt the equivalent of the long-term average precipitation during the warm summer months, called balance ablation [@pritchard_asias_2019]. $$ \Delta S = P-\text{Melt} \approx Q_{\text{Gl,imbal}} $$ {#eq-simplified-glacier-mass-balance} where the change of water storage ($\Delta S$) is equal to the precipitation ($P$) minus the glacier melt ($\text{Melt}$). Since temperatures are increasing globally melt typically exceeds precipitation and we have negative $\Delta S$, that is imbalance ablation $Q_{\text{Gl,imbal}}$, indicating glacier storage loss. The glacier mass balance is calculated in annual time steps. We thereby refer to the hydrological year starting on October 1st of the previous year to take a full accumulation and ablation season into account. ### Temperature Index Model One of the arguably simplest models to describe glacier melt (or snow melt) is the temperature index model. @hock_temperature_2003 describes several variants of the temperature index model for simulating glacier melt. The `riversCentralAsia` package implements the simplest temperature index melt model described in [@hock_temperature_2003] in the function `glacierMelt_TI` (@eq-temperature-index-model), requiring only temperature time series and 2 parameters as input. $$ M = \biggl\{ \begin{array}{l, l} 0, & T < T_{threshold} \\ f_{M} \cdot \left( T - T_{threshold} \right), & T >= T_{threshold} \end{array} $$ {#eq-temperature-index-model} where $M$ is the glacier melt in $mm/d$, $T$ is the daily average temperature in $^{\circ} C$. The two parameters $f_{M}$ and $T_{\text{threshold}}$ refer to the melt factor and the threshold temperature above which glacier melt occurs and need to be calibrated. They have the units $\frac{mm}{^{\circ} C \cdot d}$ and $^{\circ} C$ respectively. Glacier melt is calculated in daily time steps. ## Glacier Volume Development As glaciers melt, their volume changes. This has to be taken into account for the long-term simulation of glacier discharge. To determine the initial glacier volume, the area of the geometry of the Randolph Glacier Inventory (RGI) v6.0 data set is multiplied with the average thickness of the glacier (the Farinotti data set). From the combination of these two data sets, the well established area-volume relationship by @erasov_1968 can be verified (see section on [Area-Volume scaling](#glacier-area-volume-scaling)). Please note that the data and the retrieval of the data are described in [Part II](@sec-data) of this book. ## Area-volume scaling {#glacier-area-volume-scaling} The best known scaling relationships for Central Asian glaciers is the Erasov scaling function (@eq-erasov). $$ V_{\text{Erasov}} = 0.027 \cdot A^{1.5} $$ {#eq-erasov} Where $A$ is the glacier area in $km^2$ and $V_{\text{Erasov}}$ is the glacier volume in $km^3$. The following code snippet shows how the area volume relationship is re-fitted using the glacier outlines from RGI v6.0 and the glacier thickness data set by @farinotti_consensus_2019. ```{r} # Loading the necessary libraries library(sf, quietly = TRUE) library(raster, quietly = TRUE) library(tidyverse, quietly = TRUE) library(lubridate, quietly = TRUE) library(gridExtra, quietly = TRUE) library(broom, quietly = TRUE) devtools::install_github("hydrosolutions/riversCentralAsia", quiet = TRUE) library(riversCentralAsia, quietly = TRUE) # Load the RGIv6.0 data set of the RGI region of Central Asia rgi <- st_read("../caham_data/central_asia_domain/glaciers/RGIv60/13_rgi60_CentralAsia.shp", quiet = TRUE) |> sf::st_make_valid() rgi <- rgi |> dplyr::select(RGIId) |> mutate(Area_m2 = as.numeric(st_area(rgi))) ``` ```{r} #| eval: false # To extract the data for the entire Central Asian # region takes a several hours on a recent personal computer. # Get a list of the glacier thickness maps from Farinotti and Huss glacier_thickness_dir <- "/FARINOTTI_Glacier_Thickness/composite_thickness_RGI60-13/RGI60-13/" filelist <- list.files(path = glacier_thickness_dir, pattern = ".tif$", full.names = TRUE) # Filter the glacier thickness file list for the glacier ids in the RGI data set # (if a subset is to be analysed). #filelist <- filelist[sapply(rgi$RGIId, grep, filelist)] # Get the mean glacier thickness for each of the glaciers in filelist. glacier_thickness <- NULL res <- NULL for (glacier in c(1:length(filelist))) { rgiid <- str_extract(filelist[glacier], "RGI60-13.\\d{5}") rast <- raster(filelist[glacier]) temp <- exact_extract(rast, rgi$geometry[rgi$RGIId == rgiid], fun = c("weighted_mean", "weighted_sum"), weights = "area") |> mutate(RGIId = rgiid) glacier_thickness <- rbind(glacier_thickness, temp) } glacier_thickness <- glacier_thickness |> rename(Vice_s_m3 = weighted_sum) save(glacier_thickness, file = "../caham_data/central_asia_domain/glaciers/Farinotti/glacier_thickness_extractedRGIreg13.RData") ``` ```{r} # Load the average glacier thickness per glacier load("../caham_data/central_asia_domain/glaciers/Farinotti/glacier_thickness_extractedRGIreg13.RData") rgi <- rgi |> left_join(glacier_thickness |> dplyr::select(RGIId, weighted_mean), by = "RGIId") |> rename(thickness_m = weighted_mean) |> mutate(Volume_m3 = Area_m2 * thickness_m) # Prepare the data for curve fitting. Exclude Fedchenko glacier as it is # so much larger than all other glaciers in RGI region 13. data <- rgi |> st_drop_geometry() |> dplyr::select(RGIId, Area_m2, thickness_m, Volume_m3) |> mutate(Area_km2 = Area_m2 * 10^(-6), Volume_km3 = Volume_m3 * 10^(-9)) |> dplyr::filter(Area_km2 < 200) |> drop_na() # Fit a model of similar shape as Erasovs area-volume relationship. # V = 0.027 * A ^1.5 # Note: We use the inverse of the glacier area to weight the fitting to not # favor glaciers with large areas in the fit. nlVAw <- nls(Volume_km3 ~ a * Area_km2^b, data = data, weights = 1/data$Area_km2, # start = list(a = 0.05, b = 1.2)) # Add the modeled volume to the "observed" volume. data_nlVAw <- data |> mutate(.fitted = augment(nlVAw)$.fitted, Volume_RGIF_km3 = .fitted, Volume_Erasov_km3 = glacierVolume_Erasov(Area_km2)) ``` ```{r} #| fig-cap: "Glacier volume and glacier area estimated with different methods." #| label: fig-glacier-varea-volume-scaling #| warning: false #| message: false #| error: false # Plotting the results a <- ggplot(data_nlVAw) + geom_point(aes(Area_km2, Volume_km3, colour = "Obs"), size = 0.4, alpha = 0.4) + geom_point(aes(Area_km2, Volume_Erasov_km3, colour = "Erasov"), size = 0.4, alpha = 0.4) + geom_point(aes(Area_km2, Volume_RGIF_km3, colour = "RGIF"), alpha = 0.4, size = 0.4) + scale_colour_manual(name = "Legend", values = c("Obs" = "black", "Erasov" = "green", "RGIF" = "forestgreen")) + ylab(expression("Volume [" * km^3 * "]")) + xlab(expression("Area [" * km^2 * "]")) + theme_bw() b <- ggplot(data_nlVAw) + geom_point(aes(Area_km2, Volume_km3, colour = "Obs"), size = 0.4, alpha = 0.4) + geom_point(aes(Area_km2, Volume_Erasov_km3, colour = "Erasov"), size = 0.4, alpha = 0.4) + geom_point(aes(Area_km2, Volume_RGIF_km3, colour = "RGIF"), alpha = 0.4, size = 0.4) + scale_colour_manual(name = "Legend", values = c("Obs" = "black", "Erasov" = "green", "RGIF" = "forestgreen")) + ylab(expression("Volume [" * km^3 * "]")) + xlab(expression("Area [" * km^2 * "]")) + ylim(c(0, 4)) + xlim(c(0, 20)) + theme_bw() grid.arrange(a, b, nrow = 1) ``` @fig-glacier-varea-volume-scaling shows the glacier volume estimate with different methods vs. the glacier area. The two functions perform similarly for small glaciers, i.e. Erasov is still valid. For large glaciers the two parameter sets differ. However, the uncertainties of the glacier volume estimates are larger than the difference between the two functions so Erasov can still be considered to be valid also for larger glaciers though we use the RGIF fit here which is based on more and newer data. Based on the large data set, the empirical glacier area-volume relationship based on the RGI v6.0 glacier outlines and the glacier thickness by @farinotti_consensus_2019 may be more suitable for large glaciers in Central Asia. $$ V_{\text{RGIF}}= a \cdot A^{b} $$ {#eq-volume-rgif} With $A$ being the glacier area in $km^2$, $V_{\text{RGIF}}$ beging the glacier volume in $km^3$, and the parameters $a=$ `r as.numeric(round(nlVAw$m$getPars()[1], digits = 4))` and $b=$ `r as.numeric(round(nlVAw$m$getPars()[2], digits = 3))`. The newly fitted scaling relationship is implemented as `glacierVolume_RGIF` in the package `riversCentralAsia`, the Erasov scaling relationship is implemented as `glacierVolume_Erasov`. The area-volume scaling by Erasov and the area-volume scaling with updated parameters (RGIF) can be reversed. Thereby it is possible to update the glacier area as a function of the glacier volume. $$ A = \exp \Bigg( \frac{\log V - \log a}{b}\Bigg) $$ {#eq-area-erasov} where $V$ is the glacier volume in $km^3$ and $A$ is the glacier area in $km^2$. The parameters $a$ and $b$ are the parameters of the Erasov scaling function or the RGIF scaling function. The equations are implemented in the `riversCentralAsia` package as `glacierArea_Erasov` and `glacierArea_RGIF` respectively. ## References