From 63c23829ab44346aa27f26ee4915c50c13fca3ae Mon Sep 17 00:00:00 2001 From: Isabelle Weindl Date: Fri, 14 Jul 2023 15:20:25 +0200 Subject: [PATCH 01/11] temporal development of milk demand is integrated in the calculation of the pasture management factor --- .../15_food/anthro_iso_jun22/equations.gms | 2 +- .../15_food/anthro_iso_jun22/exodietmacro.gms | 2 +- modules/15_food/anthro_iso_jun22/input.gms | 4 +-- modules/15_food/anthro_iso_jun22/preloop.gms | 4 +-- modules/15_food/anthro_iso_jun22/sets.gms | 7 ++--- .../anthropometrics_jan18/equations.gms | 2 +- .../15_food/anthropometrics_jan18/input.gms | 4 +-- .../anthropometrics_jan18/intersolve.gms | 2 +- .../15_food/anthropometrics_jan18/preloop.gms | 4 +-- .../anthropometrics_jan18/presolve.gms | 2 +- .../15_food/anthropometrics_jan18/sets.gms | 7 ++--- modules/16_demand/sector_may15/sets.gms | 12 +++++++++ modules/31_past/grasslands_apr22/input.gms | 2 +- modules/51_nitrogen/module.gms | 1 - .../70_livestock/fbask_jan16/declarations.gms | 3 ++- modules/70_livestock/fbask_jan16/presolve.gms | 27 ++++++++++++++----- 16 files changed, 56 insertions(+), 29 deletions(-) diff --git a/modules/15_food/anthro_iso_jun22/equations.gms b/modules/15_food/anthro_iso_jun22/equations.gms index 6cb9c227b4..421dd270e5 100644 --- a/modules/15_food/anthro_iso_jun22/equations.gms +++ b/modules/15_food/anthro_iso_jun22/equations.gms @@ -9,7 +9,7 @@ q15_food_demand(i2,kfo) .. (vm_dem_food(i2,kfo) + sum(ct, f15_household_balanceflow(ct,i2,kfo,"dm"))) - * sum(ct,(f15_nutrition_attributes(ct,kfo,"kcal") * 10**6)) =g= + * sum(ct,(fm_nutrition_attributes(ct,kfo,"kcal") * 10**6)) =g= sum(ct,im_pop(ct,i2) * p15_kcal_pc_calibrated(ct,i2,kfo)) * 365 ; diff --git a/modules/15_food/anthro_iso_jun22/exodietmacro.gms b/modules/15_food/anthro_iso_jun22/exodietmacro.gms index ca0b6813d4..9821ded778 100644 --- a/modules/15_food/anthro_iso_jun22/exodietmacro.gms +++ b/modules/15_food/anthro_iso_jun22/exodietmacro.gms @@ -108,7 +108,7 @@ if (s15_run_diet_postprocessing = 1, + p15_kcal_pc_iso_rumdairy_orig(t,iso) * (1- i15_rumdairy_fadeout(t,iso))); *** Substitution of ruminant meat and dairy products (kfo_rd) with single-cell protein (SCP) based on protein/cap/day - i15_protein_to_kcal_ratio(t,kfo) = f15_nutrition_attributes(t,kfo,"protein")/f15_nutrition_attributes(t,kfo,"kcal"); + i15_protein_to_kcal_ratio(t,kfo) = fm_nutrition_attributes(t,kfo,"protein")/fm_nutrition_attributes(t,kfo,"kcal"); * Before the substitution, kfo_rd is converted from kcal/cap/day to g protein/cap/day * using i15_protein_to_kcal_ratio(t,kfo_rd). * After the substitution of kfo_rd with SCP (1-i15_rumdairy_scp_fadeout), SCP is converted diff --git a/modules/15_food/anthro_iso_jun22/input.gms b/modules/15_food/anthro_iso_jun22/input.gms index 45e9a4493e..56e930f351 100644 --- a/modules/15_food/anthro_iso_jun22/input.gms +++ b/modules/15_food/anthro_iso_jun22/input.gms @@ -29,7 +29,7 @@ $setglobal c15_fishscen constant $setglobal c15_alcscen constant $setglobal c15_livescen constant $setglobal c15_rumdairyscen constant -$setglobal c15_rumdairy_scp_scen constant +$setglobal c15_rumdairy_scp_scen sigmoid_20pc_20_50 $setglobal c15_livescen_target constant $setglobal c15_exo_foodscen lin_zero_20_50 @@ -124,7 +124,7 @@ $ondelim $include "./modules/15_food/input/f15_household_balanceflow.cs3" $offdelim; -table f15_nutrition_attributes(t_all,kall,nutrition) Nutrition attributes of food items dedicated for fooduse (mio. kcal per tDM | t Protein per tDM) +table fm_nutrition_attributes(t_all,kall,nutrition) Nutrition attributes of food items dedicated for fooduse (mio. kcal per tDM | t Protein per tDM) $ondelim $include "./modules/15_food/input/f15_nutrition_attributes.cs3" $offdelim; diff --git a/modules/15_food/anthro_iso_jun22/preloop.gms b/modules/15_food/anthro_iso_jun22/preloop.gms index 80684940c3..0397c55f4b 100644 --- a/modules/15_food/anthro_iso_jun22/preloop.gms +++ b/modules/15_food/anthro_iso_jun22/preloop.gms @@ -92,7 +92,7 @@ $else $endif * initial prices in $US per Kcal -i15_prices_initial_kcal(iso,kfo)$(f15_nutrition_attributes("y1995",kfo,"kcal")>0) = f15_prices_initial(kfo) - / (f15_nutrition_attributes("y1995",kfo,"kcal")*10**6); +i15_prices_initial_kcal(iso,kfo)$(fm_nutrition_attributes("y1995",kfo,"kcal")>0) = f15_prices_initial(kfo) + / (fm_nutrition_attributes("y1995",kfo,"kcal")*10**6); p15_prices_kcal(t,iso,kfo,"iter1")=i15_prices_initial_kcal(iso,kfo); p15_convergence_measure(t,iter15)=NA; diff --git a/modules/15_food/anthro_iso_jun22/sets.gms b/modules/15_food/anthro_iso_jun22/sets.gms index 942de46d9e..18f196764f 100644 --- a/modules/15_food/anthro_iso_jun22/sets.gms +++ b/modules/15_food/anthro_iso_jun22/sets.gms @@ -102,9 +102,6 @@ sets kfo_lp(kfo) Livestock food products / livst_rum,livst_pig,livst_chick, livst_egg, livst_milk / - kfo_rd(kfo) Ruminant meat and dairy food products - / livst_rum,livst_milk / - kfo_st(kfo) Staple products / tece,maiz,trce,rice_pro,soybean,rapeseed,groundnut,sunflower,puls_pro, potato,cassav_sp,sugr_cane,sugr_beet,molasses,brans,scp / @@ -148,6 +145,10 @@ sets livst_fadeoutscen15 Scenarios for changed composition of livestock products / halving2050, constant / +* The set kfo_rd can be defined in default.cfg and is used in the food substitution scenarios c15_rumdairy_scp_scen and c15_rumdairyscen + kfo_rd(kfo) Ruminant meat and dairy food products + / livst_rum,livst_milk / + fadeoutscen15 Food substitution scenarios including functional forms with targets and transition periods / constant, lin_zero_10_50, lin_zero_20_50, lin_zero_20_30, lin_zero_20_70, lin_50pc_20_50, lin_50pc_20_50_extend65, lin_50pc_20_50_extend80, diff --git a/modules/15_food/anthropometrics_jan18/equations.gms b/modules/15_food/anthropometrics_jan18/equations.gms index 6cb9c227b4..421dd270e5 100644 --- a/modules/15_food/anthropometrics_jan18/equations.gms +++ b/modules/15_food/anthropometrics_jan18/equations.gms @@ -9,7 +9,7 @@ q15_food_demand(i2,kfo) .. (vm_dem_food(i2,kfo) + sum(ct, f15_household_balanceflow(ct,i2,kfo,"dm"))) - * sum(ct,(f15_nutrition_attributes(ct,kfo,"kcal") * 10**6)) =g= + * sum(ct,(fm_nutrition_attributes(ct,kfo,"kcal") * 10**6)) =g= sum(ct,im_pop(ct,i2) * p15_kcal_pc_calibrated(ct,i2,kfo)) * 365 ; diff --git a/modules/15_food/anthropometrics_jan18/input.gms b/modules/15_food/anthropometrics_jan18/input.gms index cbf8b2f6ac..895fe24a3a 100644 --- a/modules/15_food/anthropometrics_jan18/input.gms +++ b/modules/15_food/anthropometrics_jan18/input.gms @@ -29,7 +29,7 @@ $setglobal c15_fishscen constant $setglobal c15_alcscen constant $setglobal c15_livescen constant $setglobal c15_rumdairyscen constant -$setglobal c15_rumdairy_scp_scen constant +$setglobal c15_rumdairy_scp_scen sigmoid_20pc_20_50 $setglobal c15_livescen_target constant $setglobal c15_exo_foodscen lin_zero_20_50 @@ -105,7 +105,7 @@ $ondelim $include "./modules/15_food/input/f15_household_balanceflow.cs3" $offdelim; -table f15_nutrition_attributes(t_all,kall,nutrition) Nutrition attributes of food items dedicated for fooduse (mio. kcal per tDM | t Protein per tDM) +table fm_nutrition_attributes(t_all,kall,nutrition) Nutrition attributes of food items dedicated for fooduse (mio. kcal per tDM | t Protein per tDM) $ondelim $include "./modules/15_food/input/f15_nutrition_attributes.cs3" $offdelim; diff --git a/modules/15_food/anthropometrics_jan18/intersolve.gms b/modules/15_food/anthropometrics_jan18/intersolve.gms index c980023b73..a8326dab0a 100644 --- a/modules/15_food/anthropometrics_jan18/intersolve.gms +++ b/modules/15_food/anthropometrics_jan18/intersolve.gms @@ -222,7 +222,7 @@ p15_kcal_pc_calibrated(t,i,kfo_pp) = p15_plant_kcal_structure_orig(t,i,kfo_pp) + p15_kcal_pc_calibrated_rumdairy_orig(t,i) * (1-i15_rumdairy_fadeout(t,i))); *** Substitution of ruminant meat and dairy products (kfo_rd) with single-cell protein (SCP) based on protein/cap/day -i15_protein_to_kcal_ratio(t,kfo) = f15_nutrition_attributes(t,kfo,"protein")/f15_nutrition_attributes(t,kfo,"kcal"); +i15_protein_to_kcal_ratio(t,kfo) = fm_nutrition_attributes(t,kfo,"protein")/fm_nutrition_attributes(t,kfo,"kcal"); * Before the substitution, kfo_rd is converted from kcal/cap/day to g protein/cap/day * using i15_protein_to_kcal_ratio(t,kfo_rd). * After the substitution of kfo_rd with SCP (1-i15_rumdairy_scp_fadeout), SCP is converted diff --git a/modules/15_food/anthropometrics_jan18/preloop.gms b/modules/15_food/anthropometrics_jan18/preloop.gms index 00e0fbe2ac..8d84dcd7c6 100644 --- a/modules/15_food/anthropometrics_jan18/preloop.gms +++ b/modules/15_food/anthropometrics_jan18/preloop.gms @@ -98,7 +98,7 @@ i15_exo_foodscen_fader(t,i) = (1-f15_food_substitution_fader(t,"%c15_exo_foodsce * initial prices in $US per Kcal -i15_prices_initial_kcal(iso,kfo)$(f15_nutrition_attributes("y1995",kfo,"kcal")>0) = f15_prices_initial(kfo) - / (f15_nutrition_attributes("y1995",kfo,"kcal")*10**6); +i15_prices_initial_kcal(iso,kfo)$(fm_nutrition_attributes("y1995",kfo,"kcal")>0) = f15_prices_initial(kfo) + / (fm_nutrition_attributes("y1995",kfo,"kcal")*10**6); p15_prices_kcal(t,iso,kfo,"iter1")=i15_prices_initial_kcal(iso,kfo); p15_convergence_measure(t,iter15)=NA; diff --git a/modules/15_food/anthropometrics_jan18/presolve.gms b/modules/15_food/anthropometrics_jan18/presolve.gms index 4cb9ed673d..64ed7f2fe4 100644 --- a/modules/15_food/anthropometrics_jan18/presolve.gms +++ b/modules/15_food/anthropometrics_jan18/presolve.gms @@ -429,7 +429,7 @@ p15_kcal_pc_calibrated(t,i,kfo_pp) = p15_plant_kcal_structure_orig(t,i,kfo_pp) + p15_kcal_pc_calibrated_rumdairy_orig(t,i) * (1-i15_rumdairy_fadeout(t,i))); *** Substitution of ruminant meat and dairy products (kfo_rd) with single-cell protein (SCP) based on protein/cap/day -i15_protein_to_kcal_ratio(t,kfo) = f15_nutrition_attributes(t,kfo,"protein")/f15_nutrition_attributes(t,kfo,"kcal"); +i15_protein_to_kcal_ratio(t,kfo) = fm_nutrition_attributes(t,kfo,"protein")/fm_nutrition_attributes(t,kfo,"kcal"); * Before the substitution, kfo_rd is converted from kcal/cap/day to g protein/cap/day * using i15_protein_to_kcal_ratio(t,kfo_rd). * After the substitution of kfo_rd with SCP (1-i15_rumdairy_scp_fadeout), SCP is converted diff --git a/modules/15_food/anthropometrics_jan18/sets.gms b/modules/15_food/anthropometrics_jan18/sets.gms index 04a1576e6f..4f1ae4d1d5 100644 --- a/modules/15_food/anthropometrics_jan18/sets.gms +++ b/modules/15_food/anthropometrics_jan18/sets.gms @@ -102,9 +102,6 @@ sets kfo_lp(kfo) Livestock food products / livst_rum,livst_pig,livst_chick, livst_egg, livst_milk / - kfo_rd(kfo) Ruminant meat and dairy food products - / livst_rum,livst_milk / - kfo_st(kfo) Staple products / tece,maiz,trce,rice_pro,soybean,rapeseed,groundnut,sunflower,puls_pro, potato,cassav_sp,sugr_cane,sugr_beet,molasses,brans,scp / @@ -148,6 +145,10 @@ sets livst_fadeoutscen15 Scenarios for changed composition of livestock products / halving2050, constant / +* The set kfo_rd can be defined in default.cfg and is used in the food substitution scenarios c15_rumdairy_scp_scen and c15_rumdairyscen + kfo_rd(kfo) Ruminant meat and dairy food products + / livst_rum,livst_milk / + fadeoutscen15 Food substitution scenarios including functional forms with targets and transition periods / constant, lin_zero_10_50, lin_zero_20_50, lin_zero_20_30, lin_zero_20_70, lin_50pc_20_50, lin_50pc_20_50_extend65, lin_50pc_20_50_extend80, diff --git a/modules/16_demand/sector_may15/sets.gms b/modules/16_demand/sector_may15/sets.gms index 2fc3950776..7a4dc3cc8f 100644 --- a/modules/16_demand/sector_may15/sets.gms +++ b/modules/16_demand/sector_may15/sets.gms @@ -21,6 +21,18 @@ sets kli(kap) Livestock products / livst_rum, livst_pig, livst_chick, livst_egg, livst_milk / + kli_rd(kap) Ruminant meat and dairy products + / livst_rum,livst_milk / + + kap_to_kfo_ap(kap,kfo_ap) Mapping between animal products and animal food products + /livst_rum . livst_rum + livst_pig . livst_pig + livst_chick . livst_chick + livst_egg . livst_egg + livst_milk . livst_milk + fish . fish + / + kforestry(k) forestry products / wood, woodfuel / diff --git a/modules/31_past/grasslands_apr22/input.gms b/modules/31_past/grasslands_apr22/input.gms index 0896afc475..ae18cdf7fc 100644 --- a/modules/31_past/grasslands_apr22/input.gms +++ b/modules/31_past/grasslands_apr22/input.gms @@ -11,7 +11,7 @@ scalars s31_cost_grass_prod Grasslands factor costs (USD05MER per tDM) / 1 / ; -$setglobal c31_past_suit_scen ssp370 +$setglobal c31_past_suit_scen ssp245 table f31_pastr_suitability(t_all,j,ssp_past) Areas suitable for pasture management (mio. ha) $ondelim diff --git a/modules/51_nitrogen/module.gms b/modules/51_nitrogen/module.gms index 4b530725d6..e28a27bf21 100644 --- a/modules/51_nitrogen/module.gms +++ b/modules/51_nitrogen/module.gms @@ -14,7 +14,6 @@ *' @authors Benjamin Leon Bodirsky *###################### R SECTION START (MODULETYPES) ########################## -$Ifi "%nitrogen%" == "ipcc2006_sep16" $include "./modules/51_nitrogen/ipcc2006_sep16/realization.gms" $Ifi "%nitrogen%" == "off" $include "./modules/51_nitrogen/off/realization.gms" $Ifi "%nitrogen%" == "rescaled_jan21" $include "./modules/51_nitrogen/rescaled_jan21/realization.gms" *###################### R SECTION END (MODULETYPES) ############################ diff --git a/modules/70_livestock/fbask_jan16/declarations.gms b/modules/70_livestock/fbask_jan16/declarations.gms index 71dc155495..d35eb4f5a4 100644 --- a/modules/70_livestock/fbask_jan16/declarations.gms +++ b/modules/70_livestock/fbask_jan16/declarations.gms @@ -23,7 +23,8 @@ parameters im_slaughter_feed_share(t_all,i,kap,attributes) Share of feed that is incorporated in animal biomass (1) i70_livestock_productivity(t_all,i,sys) Productivity indicator for livestock production (t FM per animal per yr) im_feed_baskets(t_all,i,kap,kall) Feed baskets in tDM per tDM livestock product (1) - p70_cattle_stock_proxy(t,i) Proxy for cattle stocks needed to fullfil domestic food demand (mio. animals per yr) + p70_cattle_stock_proxy(t,i) Proxy for cattle stocks needed to fullfil food demand for ruminant meat (mio. animals per yr) + p70_milk_cow_proxy(t,i) Proxy for milk cows needed to fullfil food demand for milk (mio. animals per yr) p70_incr_cattle(t,i) Change in estimated cattle stocks attributed to food demand projections (1) pm_past_mngmnt_factor(t,i) Regional pasture management intensification factor (1) i70_cereal_scp_fadeout(t_all,i) Cereal feed fadeout (share 0-1) to be replaced by SCP (1) diff --git a/modules/70_livestock/fbask_jan16/presolve.gms b/modules/70_livestock/fbask_jan16/presolve.gms index 0e14beeb88..160dae859e 100644 --- a/modules/70_livestock/fbask_jan16/presolve.gms +++ b/modules/70_livestock/fbask_jan16/presolve.gms @@ -12,25 +12,38 @@ *' biophysical pasture yields in the module [14_yields]. *' The exogenous calculation of pasture management requires information on -*' the number of cattle reared to fulfil the domestic demand for ruminant +*' changes in the number of cattle reared to fulfil the food demand for ruminant *' livestock products: p70_cattle_stock_proxy(t,i) = im_pop(t,i)*pm_kcal_pc_initial(t,i,"livst_rum") - /i70_livestock_productivity(t,i,"sys_beef"); + /i70_livestock_productivity(t,i,"sys_beef"); -*' The lower bound for `p70_cattle_stock_proxy` is set to 20% of initial cattle -*' stocks in 1995: +p70_milk_cow_proxy(t,i) = im_pop(t,i)*pm_kcal_pc_initial(t,i,"livst_milk") + /i70_livestock_productivity(t,i,"sys_dairy"); + +*' The lower bound for `p70_cattle_stock_proxy` and `p70_milk_cow_proxy` is +*' set to 20% of initial values in 1995: p70_cattle_stock_proxy(t,i)$(p70_cattle_stock_proxy(t,i) < 0.2*p70_cattle_stock_proxy("y1995",i)) = 0.2*p70_cattle_stock_proxy("y1995",i); +p70_milk_cow_proxy(t,i)$(p70_milk_cow_proxy(t,i) < 0.2*p70_milk_cow_proxy("y1995",i)) = 0.2*p70_milk_cow_proxy("y1995",i); + -*' The parameter `p70_incr_cattle` describes the changes in cattle stocks +*' The parameter `p70_incr_cattle` describes the changes in the number of cattle *' relative to the previous time step: p70_incr_cattle(t,i) = 1$(ord(t)=1) - + (p70_cattle_stock_proxy(t,i)/p70_cattle_stock_proxy(t-1,i))$(ord(t)>1); + + ( + ( ( pm_kcal_pc_initial(t,i,"livst_rum")*im_feed_baskets(t,i,"livst_rum","pasture")/fm_nutrition_attributes(t,"livst_rum","kcal") ) + / sum(kli_rd, sum(kap_to_kfo_ap(kli_rd,kfo_ap),pm_kcal_pc_initial(t,i,kfo_ap))*im_feed_baskets(t,i,kli_rd,"pasture")/fm_nutrition_attributes(t,kli_rd,"kcal") ) ) + * (p70_cattle_stock_proxy(t,i)/p70_cattle_stock_proxy(t-1,i)) + + + ( ( pm_kcal_pc_initial(t,i,"livst_milk")*im_feed_baskets(t,i,"livst_milk","pasture")/fm_nutrition_attributes(t,"livst_milk","kcal") ) + / sum(kli_rd, sum(kap_to_kfo_ap(kli_rd,kfo_ap),pm_kcal_pc_initial(t,i,kfo_ap))*im_feed_baskets(t,i,kli_rd,"pasture")/fm_nutrition_attributes(t,kli_rd,"kcal") ) ) + *(p70_milk_cow_proxy(t,i)/p70_milk_cow_proxy(t-1,i)) + )$(ord(t)>1); *' The pasture management factor is calculated by applying a linear relationship -*' that links changes in pasture management with changes in cattle stocks: +*' that links changes in pasture management with changes in the number of cattle: if (m_year(t) <= s70_past_mngmnt_factor_fix, pm_past_mngmnt_factor(t,i) = 1; From f57b06854bd3c37de2c37a55b39890bace7d7e12 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Fri, 14 Jul 2023 16:00:25 +0200 Subject: [PATCH 02/11] Update CHANGELOG.md --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index e20a9323f3..e58eb532a2 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -12,6 +12,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/). - **scripts** start_functions.R can now handle clusters per region flexibly - **scripts** the REMIND-MAgPIE coupling now uses renv - **41_area_equipped_for_irrigation** new AEI data (Mehta2022) replacing old Siebert data +- **70_livestock** consideration of milk demand in the calculation of the pasture management factor ### added - **scripts** New output script for reporting disaggregated land use patterns to the SEALS (Spatial Economic Allocation Landscape Simulator) downscaling model From bf3c69a39aacb778575b10b5c5409dafd65279a1 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Fri, 14 Jul 2023 16:23:34 +0200 Subject: [PATCH 03/11] Update declarations.gms --- modules/15_food/anthropometrics_jan18/declarations.gms | 1 - 1 file changed, 1 deletion(-) diff --git a/modules/15_food/anthropometrics_jan18/declarations.gms b/modules/15_food/anthropometrics_jan18/declarations.gms index 22224c44f3..79341f3bce 100644 --- a/modules/15_food/anthropometrics_jan18/declarations.gms +++ b/modules/15_food/anthropometrics_jan18/declarations.gms @@ -126,7 +126,6 @@ parameters * before shock o15_kcal_regr_initial(t,iso,kfo) Uncalibrated per capita demand before price shock (kcal per capita per day) - p15_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock on regional level (kcal per capita per day) pm_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock (kcal per capita per day) p15_kcal_pc_initial_iso(t,iso,kfo) Per capita consumption in food demand model before price shock on country level (kcal per capita per day) From 1a45f11ca499b9d02c06a253530efd6d6fb5b1c9 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Fri, 14 Jul 2023 16:24:28 +0200 Subject: [PATCH 04/11] Update declarations.gms --- modules/15_food/anthro_iso_jun22/declarations.gms | 1 - 1 file changed, 1 deletion(-) diff --git a/modules/15_food/anthro_iso_jun22/declarations.gms b/modules/15_food/anthro_iso_jun22/declarations.gms index 89a8964cf8..b4e2d6df01 100644 --- a/modules/15_food/anthro_iso_jun22/declarations.gms +++ b/modules/15_food/anthro_iso_jun22/declarations.gms @@ -125,7 +125,6 @@ parameters * before shock o15_kcal_regr_initial(t,iso,kfo) Uncalibrated per capita demand before price shock (kcal per capita per day) - p15_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock on regional level (kcal per capita per day) pm_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock (kcal per capita per day) p15_kcal_pc_initial_iso(t,iso,kfo) Per capita consumption in food demand model before price shock on country level (kcal per capita per day) From 351b8b529020a7b262dd796b91617e01f58d0f6a Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Fri, 14 Jul 2023 16:36:17 +0200 Subject: [PATCH 05/11] Consistent use of s15_calibrate to switch on/off calibration --- modules/15_food/anthro_iso_jun22/exodietmacro.gms | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/modules/15_food/anthro_iso_jun22/exodietmacro.gms b/modules/15_food/anthro_iso_jun22/exodietmacro.gms index 9821ded778..a8a5b23e44 100644 --- a/modules/15_food/anthro_iso_jun22/exodietmacro.gms +++ b/modules/15_food/anthro_iso_jun22/exodietmacro.gms @@ -28,8 +28,7 @@ if (s15_run_diet_postprocessing = 1, p15_bmi_shr_regr(t,iso,sex,age,bmi_group15) = v15_bmi_shr_regr.l(iso,sex,age,bmi_group15); p15_bmi_shr_calibrated(t,iso,sex,age,bmi_group15) = - p15_bmi_shr_regr(t,iso,sex,age,bmi_group15)+ - i15_bmi_shr_calib(t,iso,sex,age,bmi_group15); + p15_bmi_shr_regr(t,iso,sex,age,bmi_group15) + i15_bmi_shr_calib(t,iso,sex,age,bmi_group15) * s15_calibrate; * The BMI shares are not allowed to exceed the bounds 0 and 1. Values are corrected to the bounds. p15_bmi_shr_calibrated(t,iso,sex,age,bmi_group15)$(p15_bmi_shr_calibrated(t,iso,sex,age,bmi_group15)<0) = 0; From 616fb6937de17bede198bac05677df6e7526f4e4 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Sun, 16 Jul 2023 22:27:16 +0200 Subject: [PATCH 06/11] Update calibration --- config/default.cfg | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/default.cfg b/config/default.cfg index 821203f355..f796720c61 100644 --- a/config/default.cfg +++ b/config/default.cfg @@ -26,7 +26,7 @@ cfg$input <- c(regional = "rev4.87_h12_magpie.tgz", cellular = "rev4.87_h12_fd712c0b_cellularmagpie_c200_MRI-ESM2-0-ssp370_lpjml-8e6c5eb1.tgz", validation = "rev4.87_h12_validation.tgz", additional = "additional_data_rev4.43.tgz", - calibration = "calibration_H12_per_ton_fao_may22_glo_08Jul23.tgz") + calibration = "calibration_H12_per_ton_fao_may22_glo_14Jul23.tgz") # NOTE: It is recommended to recalibrate the model when changing cellular input data # as well as for any other setting that would affect initial values in the model, From 45d5a3e148a1c47020e08a7e4972cf54cff1be9e Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Wed, 19 Jul 2023 10:35:09 +0200 Subject: [PATCH 07/11] Clean-up Co-authored-by: Jan Dietrich --- modules/15_food/anthro_iso_jun22/input.gms | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/15_food/anthro_iso_jun22/input.gms b/modules/15_food/anthro_iso_jun22/input.gms index 56e930f351..099e6acbfc 100644 --- a/modules/15_food/anthro_iso_jun22/input.gms +++ b/modules/15_food/anthro_iso_jun22/input.gms @@ -29,7 +29,7 @@ $setglobal c15_fishscen constant $setglobal c15_alcscen constant $setglobal c15_livescen constant $setglobal c15_rumdairyscen constant -$setglobal c15_rumdairy_scp_scen sigmoid_20pc_20_50 +$setglobal c15_rumdairy_scp_scen constant $setglobal c15_livescen_target constant $setglobal c15_exo_foodscen lin_zero_20_50 From 11794298cccbd8943f65c217ac4305d5ab8adc02 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Wed, 19 Jul 2023 10:42:26 +0200 Subject: [PATCH 08/11] clean up Co-authored-by: Jan Dietrich --- modules/15_food/anthropometrics_jan18/input.gms | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/15_food/anthropometrics_jan18/input.gms b/modules/15_food/anthropometrics_jan18/input.gms index 895fe24a3a..bd81857867 100644 --- a/modules/15_food/anthropometrics_jan18/input.gms +++ b/modules/15_food/anthropometrics_jan18/input.gms @@ -29,7 +29,7 @@ $setglobal c15_fishscen constant $setglobal c15_alcscen constant $setglobal c15_livescen constant $setglobal c15_rumdairyscen constant -$setglobal c15_rumdairy_scp_scen sigmoid_20pc_20_50 +$setglobal c15_rumdairy_scp_scen constant $setglobal c15_livescen_target constant $setglobal c15_exo_foodscen lin_zero_20_50 From 5546be91d2a0546936884f65750b86384a848098 Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Wed, 19 Jul 2023 13:34:04 +0200 Subject: [PATCH 09/11] clean up Co-authored-by: Jan Dietrich --- modules/31_past/grasslands_apr22/input.gms | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/31_past/grasslands_apr22/input.gms b/modules/31_past/grasslands_apr22/input.gms index ae18cdf7fc..0896afc475 100644 --- a/modules/31_past/grasslands_apr22/input.gms +++ b/modules/31_past/grasslands_apr22/input.gms @@ -11,7 +11,7 @@ scalars s31_cost_grass_prod Grasslands factor costs (USD05MER per tDM) / 1 / ; -$setglobal c31_past_suit_scen ssp245 +$setglobal c31_past_suit_scen ssp370 table f31_pastr_suitability(t_all,j,ssp_past) Areas suitable for pasture management (mio. ha) $ondelim From cb65b5d0e94d1d1c94b4ffcb6e5f7542e730641f Mon Sep 17 00:00:00 2001 From: Isabelle Weindl Date: Wed, 19 Jul 2023 22:41:08 +0200 Subject: [PATCH 10/11] clean up and better readability --- modules/15_food/anthro_iso_jun22/declarations.gms | 2 +- .../anthropometrics_jan18/declarations.gms | 2 +- modules/16_demand/sector_may15/sets.gms | 9 --------- modules/70_livestock/fbask_jan16/declarations.gms | 1 + modules/70_livestock/fbask_jan16/presolve.gms | 15 ++++++++------- 5 files changed, 11 insertions(+), 18 deletions(-) diff --git a/modules/15_food/anthro_iso_jun22/declarations.gms b/modules/15_food/anthro_iso_jun22/declarations.gms index b4e2d6df01..b5f7cd8ef2 100644 --- a/modules/15_food/anthro_iso_jun22/declarations.gms +++ b/modules/15_food/anthro_iso_jun22/declarations.gms @@ -125,7 +125,7 @@ parameters * before shock o15_kcal_regr_initial(t,iso,kfo) Uncalibrated per capita demand before price shock (kcal per capita per day) - pm_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock (kcal per capita per day) + pm_kcal_pc_initial(t,i,kall) Per capita consumption in food demand model before price shock (kcal per capita per day) p15_kcal_pc_initial_iso(t,iso,kfo) Per capita consumption in food demand model before price shock on country level (kcal per capita per day) * after price shock diff --git a/modules/15_food/anthropometrics_jan18/declarations.gms b/modules/15_food/anthropometrics_jan18/declarations.gms index 79341f3bce..072a935f0c 100644 --- a/modules/15_food/anthropometrics_jan18/declarations.gms +++ b/modules/15_food/anthropometrics_jan18/declarations.gms @@ -126,7 +126,7 @@ parameters * before shock o15_kcal_regr_initial(t,iso,kfo) Uncalibrated per capita demand before price shock (kcal per capita per day) - pm_kcal_pc_initial(t,i,kfo) Per capita consumption in food demand model before price shock (kcal per capita per day) + pm_kcal_pc_initial(t,i,kall) Per capita consumption in food demand model before price shock (kcal per capita per day) p15_kcal_pc_initial_iso(t,iso,kfo) Per capita consumption in food demand model before price shock on country level (kcal per capita per day) * after price shock diff --git a/modules/16_demand/sector_may15/sets.gms b/modules/16_demand/sector_may15/sets.gms index 7a4dc3cc8f..2f2b3f9c5c 100644 --- a/modules/16_demand/sector_may15/sets.gms +++ b/modules/16_demand/sector_may15/sets.gms @@ -24,15 +24,6 @@ sets kli_rd(kap) Ruminant meat and dairy products / livst_rum,livst_milk / - kap_to_kfo_ap(kap,kfo_ap) Mapping between animal products and animal food products - /livst_rum . livst_rum - livst_pig . livst_pig - livst_chick . livst_chick - livst_egg . livst_egg - livst_milk . livst_milk - fish . fish - / - kforestry(k) forestry products / wood, woodfuel / diff --git a/modules/70_livestock/fbask_jan16/declarations.gms b/modules/70_livestock/fbask_jan16/declarations.gms index d35eb4f5a4..c6c5851514 100644 --- a/modules/70_livestock/fbask_jan16/declarations.gms +++ b/modules/70_livestock/fbask_jan16/declarations.gms @@ -25,6 +25,7 @@ parameters im_feed_baskets(t_all,i,kap,kall) Feed baskets in tDM per tDM livestock product (1) p70_cattle_stock_proxy(t,i) Proxy for cattle stocks needed to fullfil food demand for ruminant meat (mio. animals per yr) p70_milk_cow_proxy(t,i) Proxy for milk cows needed to fullfil food demand for milk (mio. animals per yr) + p70_cattle_feed_pc_proxy(t,i,kli_rd) Proxy for daily per capita feed demand for pasture biomass driven by demand for beef and dairy products (tDM per capita per day) p70_incr_cattle(t,i) Change in estimated cattle stocks attributed to food demand projections (1) pm_past_mngmnt_factor(t,i) Regional pasture management intensification factor (1) i70_cereal_scp_fadeout(t_all,i) Cereal feed fadeout (share 0-1) to be replaced by SCP (1) diff --git a/modules/70_livestock/fbask_jan16/presolve.gms b/modules/70_livestock/fbask_jan16/presolve.gms index 160dae859e..902ad25139 100644 --- a/modules/70_livestock/fbask_jan16/presolve.gms +++ b/modules/70_livestock/fbask_jan16/presolve.gms @@ -27,19 +27,20 @@ p70_milk_cow_proxy(t,i) = im_pop(t,i)*pm_kcal_pc_initial(t,i,"livst_milk") p70_cattle_stock_proxy(t,i)$(p70_cattle_stock_proxy(t,i) < 0.2*p70_cattle_stock_proxy("y1995",i)) = 0.2*p70_cattle_stock_proxy("y1995",i); p70_milk_cow_proxy(t,i)$(p70_milk_cow_proxy(t,i) < 0.2*p70_milk_cow_proxy("y1995",i)) = 0.2*p70_milk_cow_proxy("y1995",i); +*' The parameter `p70_cattle_feed_pc_proxy` is a proxy for regional daily per capita +*' feed demand for pasture biomass driven by demand for beef and dairy products, +*' which is later used for weighted aggregation. +p70_cattle_feed_pc_proxy(t,i,kli_rd) = pm_kcal_pc_initial(t,i,kli_rd)*im_feed_baskets(t,i,kli_rd,"pasture")/(fm_nutrition_attributes(t,kli_rd,"kcal") * 10**6); *' The parameter `p70_incr_cattle` describes the changes in the number of cattle *' relative to the previous time step: p70_incr_cattle(t,i) = 1$(ord(t)=1) + ( - ( ( pm_kcal_pc_initial(t,i,"livst_rum")*im_feed_baskets(t,i,"livst_rum","pasture")/fm_nutrition_attributes(t,"livst_rum","kcal") ) - / sum(kli_rd, sum(kap_to_kfo_ap(kli_rd,kfo_ap),pm_kcal_pc_initial(t,i,kfo_ap))*im_feed_baskets(t,i,kli_rd,"pasture")/fm_nutrition_attributes(t,kli_rd,"kcal") ) ) - * (p70_cattle_stock_proxy(t,i)/p70_cattle_stock_proxy(t-1,i)) - + - ( ( pm_kcal_pc_initial(t,i,"livst_milk")*im_feed_baskets(t,i,"livst_milk","pasture")/fm_nutrition_attributes(t,"livst_milk","kcal") ) - / sum(kli_rd, sum(kap_to_kfo_ap(kli_rd,kfo_ap),pm_kcal_pc_initial(t,i,kfo_ap))*im_feed_baskets(t,i,kli_rd,"pasture")/fm_nutrition_attributes(t,kli_rd,"kcal") ) ) - *(p70_milk_cow_proxy(t,i)/p70_milk_cow_proxy(t-1,i)) + ( p70_cattle_feed_pc_proxy(t,i,"livst_rum") * (p70_cattle_stock_proxy(t,i)/p70_cattle_stock_proxy(t-1,i)) + + + p70_cattle_feed_pc_proxy(t,i,"livst_milk") * (p70_milk_cow_proxy(t,i)/p70_milk_cow_proxy(t-1,i)) ) + / sum(kli_rd, p70_cattle_feed_pc_proxy(t,i,kli_rd) ) )$(ord(t)>1); *' The pasture management factor is calculated by applying a linear relationship From e27a70fdab046a1bb4b834ff57a6d160a31f5e3a Mon Sep 17 00:00:00 2001 From: weindl <39915455+weindl@users.noreply.github.com> Date: Thu, 20 Jul 2023 15:10:40 +0200 Subject: [PATCH 11/11] Added information about new interface to the respective module description --- modules/15_food/module.gms | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/modules/15_food/module.gms b/modules/15_food/module.gms index b228f51668..6df74f2de3 100644 --- a/modules/15_food/module.gms +++ b/modules/15_food/module.gms @@ -15,7 +15,9 @@ *' agricultural commodities q15_food_demand.m to change food demand and iterates *' with MAgPIE until a common solution is found. Outputs include next to food *' demand also projections of anthropometric parameters such as body height and -*' weight distribution, as well as phyiscal activity levels. +*' weight distribution, as well as phyiscal activity levels. In addition, this +*' module also provides information about nutrition attributes of foods that can +*' be used in other modules via the interface fm_nutrition_attributes. *' @authors Benjamin Leon Bodirsky, Isabelle Weindl, Jan Philipp Dietrich *###################### R SECTION START (MODULETYPES) ##########################