lpjmlkit-boundaries

A collection of basic functions to facilitate the work with the DGVM LPJmL (specifically for the work with boundaries R package) hosted at the Potsdam Institute for Climate Impact Research. It provides functions for running LPJmL, as well as reading, processing and writing model-related data such as inputs and outputs or configuration files.

https://github.com/pik-tess/lpjmlkit-boundaries

Science Score: 67.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
    Found CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 7 DOI reference(s) in README
  • Academic publication links
    Links to: zenodo.org
  • Academic email domains
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (17.5%) to scientific vocabulary
Last synced: 7 months ago · JSON representation ·

Repository

A collection of basic functions to facilitate the work with the DGVM LPJmL (specifically for the work with boundaries R package) hosted at the Potsdam Institute for Climate Impact Research. It provides functions for running LPJmL, as well as reading, processing and writing model-related data such as inputs and outputs or configuration files.

Basic Info
  • Host: GitHub
  • Owner: pik-tess
  • License: agpl-3.0
  • Language: R
  • Default Branch: master
  • Size: 1.97 MB
Statistics
  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • Open Issues: 0
  • Releases: 1
Created about 1 year ago · Last pushed about 1 year ago
Metadata Files
Readme Contributing License Citation

README.md

logo Toolkit for Basic LPJmL Handling

R package lpjmlkit, version 1.7.7-boundaries.0

CRAN status DOI R build status codecov r-universe

Purpose and Functionality

A collection of basic functions to facilitate the work with the Dynamic Global Vegetation Model (DGVM) Lund-Potsdam-Jena managed Land (LPJmL) hosted at the Potsdam Institute for Climate Impact Research (PIK). It provides functions for performing LPJmL simulations, as well as reading, processing and writing model-related data such as inputs and outputs or configuration files.

Overview

LPJmL Runner 🏃 to perform LPJmL simulations

LPJmL Runner only supports Unix-based operating systems that have an LPJmL version >= 4 installed. - ✍ write_config() write config.json files using a data frame with parameters to be changed and a base configuration file - 🔍 check_config() check if generated config.json files are valid for LPJmL simulations - ▶ run_lpjml() run LPJmL directly (e.g. single cell simulations) or 🚀 submit_lpjml() to SLURM (e.g. global simulations)

LPJmL Data 💾 for reading and processing LPJmL data

  • read_io() read LPJmL input and output as a LPJmLData object, containing the data array and LPJmLMetaData

    • 📈 plot() the data or get insights via summary() and other base stats
    • 🔁 transform() it to other time and space formats
    • subset() the underlying data
    • 📦 as_array(), as_tibble() and as_raster() / as_terra() to export into common R data formats
  • read_meta() read meta or header files as LPJmLMetaData object

miscellaneous

  • calc_cellarea() to calculate the area of LPJmLData objects underlying grid or for other objects latitudes
  • functions to handle LPJmL file headers, read_header() read the header of LPJmL files, get_headersize() get the size of a file header or create_header() to create a header object for writing input files
  • get_datatype() get information on the data type used in different LPJmL files
  • asub() functionality of the subset method to be used on a base array, also to replace data
  • ... more functions via library(help = "lpjmlkit")

Installation

For installation of the most recent package version an additional repository has to be added in R:

r options(repos = c(CRAN = "@CRAN@", pik = "https://rse.pik-potsdam.de/r/packages")) The additional repository can be made available permanently by adding the line above to a file called .Rprofile stored in the home folder of your system (Sys.glob("~") in R returns the home directory).

After that the most recent version of the package can be installed using install.packages:

r install.packages("lpjmlkit")

Package updates can be installed using update.packages (make sure that the additional repository has been added before running that command):

r update.packages()

Tutorial

The package comes with vignettes describing the basic functionality of the package and how to use it. You can load them with the following command (the package needs to be installed):

r vignette("lpjml-data") # LPJmL Data vignette("lpjml-runner") # LPJmL Runner

Questions / Problems

In case of questions / problems please contact Jannes Breier jannesbr@pik-potsdam.de.

Citation

To cite package lpjmlkit in publications use:

Breier J, Ostberg S, Wirth S, Minoli S, Stenzel F, Hötten D, Müller C (2025). "lpjmlkit: Toolkit for Basic LPJmL Handling." doi:10.5281/zenodo.7773134 https://doi.org/10.5281/zenodo.14850990, Version: 1.7.7-boundaries.1, https://github.com/PIK-LPJmL/lpjmlkit.

A BibTeX entry for LaTeX users is

latex @Misc{, title = {lpjmlkit: Toolkit for Basic LPJmL Handling}, author = {Jannes Breier and Sebastian Ostberg and Stephen Björn Wirth and Sara Minoli and Fabian Stenzel and David Hötten and Christoph Müller}, doi = {10.5281/zenodo.7773134}, date = {2025-02-11}, year = {2025}, url = {https://github.com/PIK-LPJmL/lpjmlkit}, note = {Version: 1.7.7-boundaries.1}, }

Owner

  • Name: Terrestrial Safe Operating Space (TESS)
  • Login: pik-tess
  • Kind: organization
  • Location: Germany

Dynamics and interactions of terrestrial planetary boundaries, including their improved definition, quantification, regionalisation and operationalisation.

Citation (CITATION.cff)

cff-version: 1.2.0
message: If you use this software, please cite it using the metadata from this file.
type: software
title: 'lpjmlkit: Toolkit for Basic LPJmL Handling'
version: 1.7.7-boundaries.1
date-released: '2025-02-11'
abstract: A collection of basic functions to facilitate the work with the Dynamic
  Global Vegetation Model (DGVM) Lund-Potsdam-Jena managed Land (LPJmL) hosted at
  the Potsdam Institute for Climate Impact Research (PIK). It provides functions for
  performing LPJmL simulations, as well as reading, processing and writing model-related
  data such as inputs and outputs or configuration files.
authors:
- family-names: Breier
  given-names: Jannes
  email: jannesbr@pik-potsdam.de
  orcid: https://orcid.org/0000-0002-9055-6904
- family-names: Ostberg
  given-names: Sebastian
  email: ostberg@pik-potsdam.de
  orcid: https://orcid.org/0000-0002-2368-7015
- family-names: Wirth
  given-names: Stephen Björn
  email: wirth@pik-potsdam.de
  orcid: https://orcid.org/0000-0003-3090-3318
- family-names: Minoli
  given-names: Sara
  email: minoli@pik-potsdam.de
  orcid: https://orcid.org/0000-0001-7920-3107
- family-names: Stenzel
  given-names: Fabian
  email: stenzel@pik-potsdam.de
  orcid: https://orcid.org/0000-0002-5109-0048
- family-names: Hötten
  given-names: David
  email: davidho@pik-potsdam.de
- family-names: Müller
  given-names: Christoph
  email: cmueller@pik-potsdam.de
  orcid: https://orcid.org/0000-0002-9491-3550
license: AGPL-3.0
repository-code: https://github.com/PIK-LPJmL/lpjmlkit
doi: 10.5281/zenodo.14850990

GitHub Events

Total
  • Release event: 1
  • Push event: 1
  • Create event: 3
Last Year
  • Release event: 1
  • Push event: 1
  • Create event: 3

Dependencies

.github/workflows/check.yaml actions
  • actions/checkout v4 composite
  • actions/setup-python v5 composite
  • r-lib/actions/setup-pandoc v2 composite
  • r-lib/actions/setup-r v2 composite
  • r-lib/actions/setup-r-dependencies v2 composite
DESCRIPTION cran
  • R >= 3.5.0 depends
  • abind * imports
  • cli * imports
  • doParallel * imports
  • dplyr * imports
  • foreach * imports
  • grDevices * imports
  • jsonlite * imports
  • magrittr * imports
  • methods * imports
  • processx * imports
  • rlang * imports
  • stringi * imports
  • tibble * imports
  • utils * imports
  • withr * imports
  • CFtime * suggests
  • R6 * suggests
  • knitr * suggests
  • maps * suggests
  • ncdf4 * suggests
  • raster * suggests
  • reshape2 * suggests
  • rmarkdown * suggests
  • sf * suggests
  • terra * suggests
  • testthat >= 3.0.0 suggests