Changelog
All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.
[1.0.0] - in planning
Aim: 4 species, 2 crop growth models, farm model, GAEC scenarios, experimental analysis
[0.9.0] - unreleased
This minor release changes the map to ATKIS.
Added
data/regions/auxiliary/rasterise_maps.jlto create input raster maps from ATKIS and soil atlas vector maps (#150)data/regions/auxiliary/createinputs.shto automate the creation of input data for the regions (includes downloading and processing of weather and map data, #89)LandCoverCategoryenum to provide "supertypes" forLandCoverdata/regions/auxiliary/extract_weather_data.Rscript now automatically interpolates missing weather data
Changed
Land cover map source changed from Mundialis to ATKIS, spatial resolution increased to 3m (#150)
LandCoverenum expanded from 6 to 32 land cover classesnaturesubmodel renamed toanimal(#125)using
Rasters.jlinstead ofGeoArrays.jlto read in maps (#152)world.mapresolutionparameter is now the constantMAPRESOLUTIONimproved
runprofile.jlscript
Deprecated
Removed
world.fixlandcoverparameter
Fixed
improved type stability in landscape.jl
fixed logic in
createdatadir()whenoverwrite="no"
[0.8.0] - 29-8-2025
This minor release adds the first butterfly model (marbled white), and expands the farm model.
Added
Marbled white (Melanargia galathea) species model with associated data outputs
implemented management of extensive and intensive grassland in the farm model (new parameters:
farm.extensivegrassland,farm.mowingthreshold,farm.mowingperiod)management scenarios can now be implemented using functions in the farm model and activated using the
farm.scenariosparameteradded
cropgroup()functionsadded macros for weather functions (
@humidity(),@maxtemp(), etc.)added
runparallel.jlandslurm.shto allow parallel processing of parameter scans on an HPCregion-specific modified crop parameters for use with AquaCrop will now be loaded automatically from the
data/crops/aquacrop/regions/directory, e.g. the filedata/crops/aquacrop/regions/jena/winter_wheat.tomlcan be used to overload the parameters for "winter wheat" in the "jena" region. Use of the modified crop parameters can be controlled with thecrop.use_region_specific_paramsconfiguration file parameter.
Changed
Skylark model parameters can be set via configuration file
added Skylark parameters
limitterritoryandofffieldnestingSetasides (fallows) are now reassigned to new fields every year
ALMaSS grassland data expanded to allow continued growth after mowing
crop rotation on all fields can now be set via parameter
farm.croprotationthe model now attempts to fix misclassifications in the land cover map if the
world.fixlandcoverparameter istrueDataOutputs can now be passed a string with an AnnualDate instead of a frequency to specify on which date they should be run
the
world.mapdirectoryparameter has been split up intoworld.mapdirectoryandworld.regionupdated and expanded documentation
Deprecated
Removed
Fixed
fixed post-mowing grass growth in ALMaSS
fixed
isvalidstart()bug inalmass.jlfixed a bug in
initpopulations!()interpolated missing weather data
crop cover is now given as percent by both crop models
[0.7.1] - 17-6-2025
Added
- AquaCrop can now estimate crop height from dry biomass using the rational function regression
y = a * (x/x0)^b / (c + (x/x0)^b)with parameters fitted for maize, winter wheat, winter barley, and winter rapeseed. AquaCrop by itself does not model plant height.
[0.7.0] - 14-03-2025
This minor release adds support for the AquaCrop crop model.
Added
Add AquaCrop crop model
Simple linear crop height estimation for AquaCrop plants from biomass (AquaCrop does not model plant height)
Read soil type map, controlled with the setting "world.soiltypesmap"
Landscape
Pixels store their soil type (enum SoilType)FarmPlots store the most common soil type of their landscapePixels (AquaCrop needs the soil type as an input parameter).
Changed
- Allow multiple crop models to be used in one simulation. The settings "crop.cropmodel" and "crop.cropdirectory" are now comma-separated lists of crop models and their data directories.
Deprecated
Removed
Fixed
[0.6.1] - 14-03-2025
Added
user manual: documentation is now compiled to PDF (#91)
added soil maps to region data, but not used yet
added
mean_cloud_coverandpotential_evapotranspirationfields to weather data csv files
Changed
added soil map section to GIS docs
Changed weather internal representation to struct-of-arrays (previously a dict-of-struct representation). The
Weathertype now stores all weather information for the whole simulation, with a function interface, e.g.sunshine(weather, date).When reading weather data, we now throw an error when there are missing days or any missing values for the fields
min_temperature,max_temperature,mean_temperature,precipitation, andpotential_evapotranspiration. In the future missing values could also be imputed.The script for weather data extraction at
data/regions/auxiliary/extract_weather_data.Rhas been reworked to always return an output row for each day in the date range, even if the day is missing in the original data source. It now also accepts the stations to download as command-line arguments. Therenvlockfile for the R environment used to run the script can be found atdata/regions/auxiliary/renv.lock.
Deprecated
Removed
Fixed
[0.6.0] - 13-01-2025
This minor release re-implements the ALMaSS crop model
Added
crop.cropdirectoryparameter specifies folder in which all crop data files for the selected crop model can be found.
Changed
preprocessparameters()checks whether the map and crop directories are reachable from the current working directory. If not, it checks whether it can be reached from the package directory. This makes running simulations easier when Persefone has been installed as a package.simulate()andinitialise()now take aparamskeyword argument that can be used to override parameters from other input sourcesThe ALMaSS crop data config file
data/crops/almass/crop_data_general.csvnow has extra columns foris_c4_plant,sowingdensity, andphase_before_harvest
Deprecated
Removed
crop.cropfileandcrop.growthfileparameters -> user configuration is now done viacrop.cropdirectory, names of ALMaSS input files are specified as constants inalmass.jl
Fixed
- The implementation of the ALMaSS vegetation model in Persefone has been completely rewritten, hopefully more faithfully reproducing the logic in ALMaSS. The resulting plant heights are now more realistic and do not produce the extreme plant heights seen previously (which was due to an erroneous interpretation of the ALMaSS growth curves).
[0.5.5] - 09-08-2024
This point release implements the first basic farm model
Added
basic farm model that assigns a crop rotation to each field, sowing and harvesting when appropriate
new parameters:
farm.farmmodel,farm.setaside,farm.fieldoutfreqvisualisation of cropped area and crop growth over time
farm.setasidesetting to configure what proportion of land farmers let lie fallowisharvestable()function forFarmPlots@areaofmacro to calculate the area of a given number of landscape pixelsdata/farm/standard_gross_margins.csvfrom KTBL data
Changed
- expanded & adapted general crop data and crop growth curve tables
Fixed
- bug fixes in the ALMaSS crop model
[0.5.4] - 08-08-2024
Skylark data analysis and new internal utility functions
Added
AnnualDatetype and associated functions for working with recurring dates (#101)- can be constructed from two
Int64, aDate, or aTuple{Int64,Int64} - automatic conversion from
DateorTuple{Int64,Int64} - can use operators:
==,<,+,-,: thisyear(),lastyear(),nextyear()functions and macros
- can be constructed from two
new file
core/utils.jlfor utility functions that fit in no other fileirregular data logging using
record!()/@record()(#103)data outputs & visualisation for the skylark model (#97)
randn()function and macro to sample from a vector using a normal distributionmake installto download and install Julia and package dependencies (on Linux, #67)weather file for the Thüringer Becken
Changed
moved random number functions and macros from
input.jltoutils.jlexpanded weather data for Jena to 1990-2023
Non-breeding skylarks only search for neighbours to follow once (-> huge performance improvement!)
Fixed
- bug fixes in the skylark model
[0.5.3] - 31-07-2024
Switchable crop models
Added
Support for switchable crop models (#70), crop models can be set with the
cropmodelsetting in the[crop]section ofparameters.toml.New submodules
ALMaSSfor the ALMaSS crop model, andSimpleCropfor testing switchable crop models.
Changed
All functionality specific to the ALMaSS crop model has been moved to the submodule
ALMaSS.Due to switchable crop models, some types are now parametric:
AgricultureModel{Tcroptype,Tcropstate}andFarmPlot{Tcropstate}.FarmPlot{Tcropstate}now only stores basic information about which pixels are part of the farm plot, all crop-specific information is now stored in the fieldcropstate. Many functions acting on aFarmPlotnow mostly forward to functions of the same name acting on thecropstatefield of aFarmPlot.The type of
heightinALMaSS.CropStateandALMaSS.CropCurveParamsis now a unitful number::Length{Float64}.Both crop models
ALMaSSandSimpleCropnow also support the functionscropcoverandcropyieldin addition tocroptype,cropname,cropheight.cropheightnow returns a unitful number::Length{Float64}, and returns height0cmif the landscape at that position is not aFarmPlot.
[0.5.2] - 30-07-2024
Rewrote the skylark model
Added
Skylark model is largely rewritten to follow a new phase structure (#9)
animals can occupy territories (see
@occupy,@isoccupied,@vacatemacros/functions) (#94)@cropcovermacro and functionODD documentation for Skylark
Changed
input files that are now copied to a separate
inputsdirectory within the output directoryEventTyperenamed toManagementfor claritydocumentation website now has a "Scientific Documentation" section
Removed
- old skylark model (has been rewritten, see above)
Fixed
all skylarks now migrate (#90)
insectbiomass()uses units
[0.5.1] - 13-06-2024
Added Unitful.jl
Added
Unitful.jl now used to add units to quantities
world.mapdirectoryparameter specifies the path to the directory in which
landcovermap, farmfieldsmap, and weatherfile are located
world.mapresolutionparameter specifies the input maps' spatial resolution in meters
Changed
spatial functions now work with explicit distances (using Unitful.jl) rather than using the number of pixels
all species definitions and tests updated to use units
[0.5.0] - 07-06-2024
This release doesn't add much new functionality, but represents a major restructuring of the code base. Specifically, it removes the Agents.jl dependency and changes the way the species definition macros work and are used.
Added
SimulationModeltype, extended byAgricultureModelstruct@createmacro defines a special phase function that is called when an individual animal is created (at birth or on model initialisation)functions (and associated macros) to replace Agents.jl functionality:
move!()andwalk!()nearby_ids(),nearby_animals(),countanimals(),neighbours()directionto(),distanceto(),randomdirection()nagents(),killallanimals!()
@heremacro to return the pixel currently occupied by the active animalcore.logoutputparameter to define whether logs are printed to screen, file, none, or bothlarge logo and model structure diagram
Changelog
Changed
SimulationModelreplacesAgentBasedModelSpecies definition macros revamped:
@speciesnow only defines parameters and variables and creates a mutable struct@phasemust now be defined in the top-level code and creates a global function@initialiserenamed to@populate, must also be called in the top-level codeinitindividual()renamed tocreate!()
Skylark, Wolpertinger, and Wyvern updated to match the new macros
requires Julia 1.10
Removed
- Agents.jl dependency (including
AgentBasedModeland functions for adding/moving/removing agents)
[0.4.1] - 2023-11-14
Initial version of the skylark model
Added
initial version of the Skylark species
small Jena map
animal individuals keep track of their parents' IDs
several new functions and macros for animals
installation instructions for Windows
Changed
- graphics output is more configurable
[0.4.0] - 2023-10-28
Functions for animal populations
Added
initialisation functions for individuals (not just species)
migration function / migrant pool for animals that disappear from the landscape during winter
skylark migration
Changed
online documentation was expanded and restructured
nature macros moved to a separate file
Started changelog at this point, earlier versions are not included.
<!– Template
[version] - unreleased
<comments>
PLANNED
Added
Changed
Deprecated
Removed
Fixed
–>