Title: | Utilities for modelling carbon based on CBM-CFS3 |
---|---|
Description: | Implementation of several components of the Carbon Budget Model of the Canadian Forest Service (v3). |
Authors: | Céline Boisvenue [aut],
Alex M Chubaty [aut, cre] |
Maintainer: | Alex M Chubaty <[email protected]> |
License: | GPL-3 |
Version: | 2.0.1.0000 |
Built: | 2025-03-27 23:21:15 UTC |
Source: | https://github.com/PredictiveEcology/CBMutils |
Implements equation 1 of Boudewyn et al. (2007) to determines the total stemwood biomass of
merchantable trees (in metric tonnes per hectare; ),
using parameters
and
from Table 3 (
table3
).
b_m(table3, vol)
b_m(table3, vol)
table3 |
|
vol |
gross merchantable volume per hectare ( |
stemwood biomass of merchantable trees ( in units
)
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
barPlot
barPlot
barPlot(cbmPools)
barPlot(cbmPools)
cbmPools |
TODO |
TODO
Implements equations 4-7 of Boudewyn et al. (2007), used to determine the proportions
of total tree biomass in stemwood, bark, branches, and foliage
(,
,
,
, respectively),
using parameters
,
from Table 6 (
table6
) and volume-proportion caps
from Table 7 (table7
).
biomProp(table6, table7, x, type = "volume")
biomProp(table6, table7, x, type = "volume")
table6 |
|
table7 |
|
x |
|
type |
|
TODO: will eventually add species, ecozone
four-column matrix will columns corresponding to ,
,
, and
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
totalCarbon
or aboveGround
or belowGround
Sum carbon for totalCarbon
or aboveGround
or belowGround
calcC(cbmPools, poolToSum, masterRaster)
calcC(cbmPools, poolToSum, masterRaster)
cbmPools |
DESCRIPTION NEEDED |
poolToSum |
DESCRIPTION NEEDED |
masterRaster |
A |
DESCRIPTION NEEDED
carbonOutPlot
carbonOutPlot
carbonOutPlot(emissionsProducts)
carbonOutPlot(emissionsProducts)
emissionsProducts |
TODO |
invoked for side effect of creating plot
)Implements the flowchart from figure 3 of Boudewyn et al. (2007) using an alternative
set of parameter to divide total above ground biomass () into total merchantable
stemwood biomass (
), foliage biomass (
), and other wood biomass (
).
convertAGB2pools(oneCurve, table6, table7)
convertAGB2pools(oneCurve, table6, table7)
oneCurve |
|
table6 |
|
table7 |
|
three-column matrix with columns corresponding to biomass () for
total merchantable, foliage, and other wood.
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
Implements the flowchart from figure 3 of Boudewyn et al. (2007) to determined the
total above ground biomass () from gross merchantable volume (
).
convertM3biom( meta, gCvalues, spsMatch, ecozones, params3, params4, params5, params6, params7 )
convertM3biom( meta, gCvalues, spsMatch, ecozones, params3, params4, params5, params6, params7 )
meta |
DESCRIPTION NEEDED |
gCvalues |
DESCRIPTION NEEDED |
spsMatch |
DESCRIPTION NEEDED |
ecozones |
DESCRIPTION NEEDED |
params3 |
|
params4 |
|
params5 |
|
params6 |
|
params7 |
|
three-column matrix with columns corresponding to biomass () for
total merchantable, foliage, and other.
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
cumPools
data.tableCreate cumPools
data.table
cumPoolsCreate( fullSpecies, gcMeta, userGcM3, stable3, stable4, stable5, stable6, stable7, thisAdmin )
cumPoolsCreate( fullSpecies, gcMeta, userGcM3, stable3, stable4, stable5, stable6, stable7, thisAdmin )
fullSpecies |
DESCRIPTION NEEDED |
gcMeta |
DESCRIPTION NEEDED |
userGcM3 |
DESCRIPTION NEEDED |
stable3 |
DESCRIPTION NEEDED |
stable4 |
DESCRIPTION NEEDED |
stable5 |
DESCRIPTION NEEDED |
stable6 |
DESCRIPTION NEEDED |
stable7 |
DESCRIPTION NEEDED |
thisAdmin |
DESCRIPTION NEEDED |
cumPools
data.table
)Implements the flowchart from figure 3 of Boudewyn et al. (2007) using an alternative
set of parameter to divide total above ground biomass () into total merchantable
stemwood biomass (
), foliage biomass (
), and other wood biomass (
).
cumPoolsCreateAGB(allInfoAGBin, table6, table7, pixGroupCol)
cumPoolsCreateAGB(allInfoAGBin, table6, table7, pixGroupCol)
allInfoAGBin |
|
table6 |
|
table7 |
|
pixGroupCol |
the name of the column in |
biomass () in each above ground pool for each cohort per pixel group.
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
cumPools
data.table
This uses the Chapman Richards equation to smooth the curves that are in colsToUse
.
cumPoolsSmooth( cumPoolsRaw, colsToUse = c("totMerch", "fol", "other"), colsToUseNew = paste0(colsToUse, "_New") )
cumPoolsSmooth( cumPoolsRaw, colsToUse = c("totMerch", "fol", "other"), colsToUseNew = paste0(colsToUse, "_New") )
cumPoolsRaw |
Data.table with a numeric column called |
colsToUse |
A character vector of columns to smooth. |
colsToUseNew |
A character vector of column names for the new smoothed columns |
#' A data.table
with original columns plus new columns named 'colsToUseNew“.
Celine Boisvenue and Eliot McIntire
Process disturbanceRasters
into a table of disturbanceEvents
for the CBM_core module.
Optionally resample to align with a template raster.
dataPrep_disturbanceRasters( disturbanceRasters, eventID = NULL, templateRast = NULL, year = NULL )
dataPrep_disturbanceRasters( disturbanceRasters, eventID = NULL, templateRast = NULL, year = NULL )
disturbanceRasters |
terra |
eventID |
integer. Disturbance event ID. All non-NA cells will be included as events of this type. If NULL, the raster cell values must be the event IDs. |
templateRast |
terra |
year |
digit or character. One or more years to summarize disturbance events for. If NULL, all available years are summarized. |
disturbanceEvents
data.table with integer columns 'pixelIndex', 'year', 'eventID'.
Process disturbanceRastersURL
into disturbanceRasters
.
dataPrep_disturbanceRastersURL(disturbanceRastersURL, bandYears = NULL, ...)
dataPrep_disturbanceRastersURL(disturbanceRastersURL, bandYears = NULL, ...)
disturbanceRastersURL |
character. URL of either an archive of raster files or a single raster file. |
bandYears |
4 digit numeric or character years. If the URL is of a single raster file, provide the disturbance years that each raster band represents. |
... |
additional arguments to reproducible |
disturbanceRasters
.
If URL is an archive: a list of terra SpatRaster
where each item is named by the disturbance year.
If URL is a single raster file: a terra SpatRaster
where each raster band layer is named by the disturbance year.
Download and unzip URL
download_unzip_url(url, destdir, overwrite = FALSE)
download_unzip_url(url, destdir, overwrite = FALSE)
url |
character. |
destdir |
character. Path to destination directory |
overwrite |
logical. Overwrite existing file |
This uses the underscore delimiter between column names.
gcidsCreate(...)
gcidsCreate(...)
... |
The data.table with ONLY the columns on which to determine unique gcids |
Extract the species- and location- specific parameters for equation 4-7 of Boudewyn et al. (2007). If there is no match for the given ecozone, the parameters for a different ecozone in the same province/territory is returned. If there is no match for a given province/territory, the parameters for a different province/territory in the same ecozone is returned. If there is no match for the given ecozone and province/territory, the parameters for a different location is returned.
getParameters(table6, table7, canfi_species, ecozone, juris_id)
getParameters(table6, table7, canfi_species, ecozone, juris_id)
table6 |
|
table7 |
|
canfi_species |
the canfi code of the species |
ecozone |
the code of the ecozone |
juris_id |
the 2-letter code for the province/territory |
a list with 2 vectors for the parameters in table6 and table7 respectively.
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
Identifies the stand-replacing wildfire disturbance in each spatial unit.
histDist(spuIDs, localeID = 1, ask = FALSE, ...)
histDist(spuIDs, localeID = 1, ask = FALSE, ...)
spuIDs |
Spatial unit ID(s) |
localeID |
CBM-CFS3 locale_id |
ask |
logical. If TRUE, prompt the user to choose the correct disturbance matches. If FALSE, the function will look for exact name matches. |
... |
arguments to |
In all spatial units in Canada, the historical disturbance is set to fire. Historical disturbances in CBM-CFS3 are used for "filling-up" the soil-related carbon pools. Boudewyn et al. (2007) translate the m3/ha curves into biomass per ha in each of four pools: total biomass for stem wood, total biomass for bark, total biomass for branches and total biomass for foliage. Biomass in coarse and fine roots, in aboveground- and belowground- very-fast, -fast, -slow, in medium-soil, and in snags still needs to be estimated. A stand-replacing fire disturbance is used in a disturb-grow cycle, where stands are disturbed and regrown with turnover, overmature, decay, functioning until the dead organic matter pools biomass values stabilize (+/- 10%) (TODO: check this).
Plot all columns that are not id_col
m3ToBiomPlots( inc = "increments", id_col = "gcids", nrow = 5, ncol = 5, filenameBase = "rawCumBiomass_", path = NULL, title = "Cumulative merch fol other by gc id", scales = "free_y" )
m3ToBiomPlots( inc = "increments", id_col = "gcids", nrow = 5, ncol = 5, filenameBase = "rawCumBiomass_", path = NULL, title = "Cumulative merch fol other by gc id", scales = "free_y" )
inc |
DESCRIPTION NEEDED |
id_col |
DESCRIPTION NEEDED |
nrow |
DESCRIPTION NEEDED |
ncol |
DESCRIPTION NEEDED |
filenameBase |
DESCRIPTION NEEDED |
path |
DESCRIPTION NEEDED |
title |
DESCRIPTION NEEDED |
scales |
DESCRIPTION NEEDED |
Implements equation 2 of Boudewyn et al. (2007), used to determine the total stem wood biomass
(in metric tonnes per hectare; ) of non-merchantable trees (
), together
with the stemwood biomass of live merchantable and non-merchantable trees (
),
using parameters
,
, and
from Table 4 (
table4
).
nmfac(table4, eq1, vol)
nmfac(table4, eq1, vol)
table4 |
|
eq1 |
stemwood biomass of merchantable trees ( |
vol |
gross merchantable volume per hectare ( |
two-column matrix with columns corresponding to and
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
NPPplot
NPPplot
NPPplot(spatialDT, NPP, masterRaster)
NPPplot(spatialDT, NPP, masterRaster)
spatialDT |
TODO |
NPP |
TODO |
masterRaster |
A |
TODO
Download the pyenv-win Python version management tool from Github if necessary. See: https://github.com/pyenv-win/pyenv-win
reticulate_install_python_windows( version = NULL, useGit = TRUE, prompt = interactive(), pyenvRoot = tools::R_user_dir("CBMutils") )
reticulate_install_python_windows( version = NULL, useGit = TRUE, prompt = interactive(), pyenvRoot = tools::R_user_dir("CBMutils") )
version |
character. Python version string. |
useGit |
logical. Allow reticulate to clone pyenv-win if Git is available |
prompt |
logical. Prompt user to approve download of pyenv-win tool |
pyenvRoot |
character. Path to directory of where to download the pyenv-win tool |
Get path to Python interpreter, including installs at a given pyenv-win location
reticulate_python_path( version = NULL, pyenvRoot = tools::R_user_dir("CBMutils"), pyenvOnly = FALSE )
reticulate_python_path( version = NULL, pyenvRoot = tools::R_user_dir("CBMutils"), pyenvOnly = FALSE )
version |
character. Python version or a comma separated list of version constraints. See ?reticulate::virtualenv_starter 'version' argument |
pyenvRoot |
character. Path to directory containing pyenv-win tool |
pyenvOnly |
logical. Exclude versions not within a pyenv install directory |
character or NULL. IF found, a path to Python interpreter
Use reticulate to find or install Python that meets version requirements. Download the pyenv-win Python version management tool from Github if necessary.
ReticulateFindPython( version, versionInstall = version, useGit = TRUE, prompt = FALSE, pyenvRoot = tools::R_user_dir("CBMutils"), pyenvOnly = FALSE )
ReticulateFindPython( version, versionInstall = version, useGit = TRUE, prompt = FALSE, pyenvRoot = tools::R_user_dir("CBMutils"), pyenvOnly = FALSE )
version |
character. Python version or a comma separated list of version constraints. See ?reticulate::virtualenv_starter 'version' argument |
versionInstall |
character. Version to install if suitable version not found. Defaults to 'version'. Required if 'version' is a string of versions constraints instead of a specific version. |
useGit |
logical. Allow reticulate to clone pyenv-win if Git is available |
prompt |
logical. Prompt user to approve download of pyenv-win tool |
pyenvRoot |
character. Path to directory of where to download the pyenv-win tool |
pyenvOnly |
logical. Exclude versions not within a pyenv install directory |
This function was created to bypass the requirement for Git to be installed
when install_python
is called on a Windows computer
without pyenv-win already installed.
pyenv-win is installed by reticulate by cloning the Github repository.
This will instead download the pyenv-win repository as a ZIP file.
Note: If pyenv-win is installed by ZIP download instead of via Git clone, it will not be updated after the first time it is downloaded.
character. Path to Python interpreter
Implements equation 3 of Boudewyn et al. (2007), used to determine the total stem wood biomass
(in metric tonnes per hectare; ) of sapling-sized trees (
),
using parameters
,
, and
from Table 5 (
table5
).
sapfac(table5, eq2, vol)
sapfac(table5, eq2, vol)
table5 |
|
eq2 |
two-column matrix giving stemwood biomass of non-merchantable trees
(i.e., |
vol |
gross merchantable volume per hectare ( |
stemwood biomass of sapling-sized trees ( in units
)
Boudewyn, P., Song, X., Magnussen, S., & Gillis, M. D. (2007). Model-based, volume-to-biomass conversion for forested and vegetated land in Canada (BC-X-411). Natural Resource Canada, Pacific Forestry Centre. https://cfs.nrcan.gc.ca/pubwarehouse/pdfs/27434.pdf
Retrieve disturbance source pools, sink pools, and the proportions transferred.
seeDist( EXN = TRUE, matrixIDs = NULL, dbPath = NULL, disturbance_matrix_value = NULL )
seeDist( EXN = TRUE, matrixIDs = NULL, dbPath = NULL, disturbance_matrix_value = NULL )
EXN |
logical. Use CBM-EXN CBM-CFS3 equivalent model data. |
matrixIDs |
character. Optional. Subset disturbances by disturbance_matrix_id |
dbPath |
Path to CBM-CFS3 SQLite database file. Required if EXN = FALSE |
disturbance_matrix_value |
disturbance_matrix_value table from CBM-EXN Required if EXN = TRUE |
List of data.frame
named by disturbance_matrix_id
get the descriptive name and proportions transferred for disturbances in a simulation requires a simulation list post simulations (from spades()) and returns a list of data.frames. Each data had the descriptive name of a disturbance used in the simulations, the disturbance matrix identification number from cbm_defaults, the pool from which carbon is taken (source pools) in this specific disturbance, the pools into which carbon goes, and the proportion in which the carbon-transfers are completed.
simDist(sim)
simDist(sim)
sim |
A |
List of data.frame
for each disturbance matrix id in the study area, named by disturbance name
spatialPlot
spatialPlot
spatialPlot(cbmPools, years, masterRaster, spatialDT)
spatialPlot(cbmPools, years, masterRaster, spatialDT)
cbmPools |
TODO |
years |
TODO |
masterRaster |
A |
spatialDT |
TODO |
TODO
Identify the disturbances possible in spatial units.
spuDist( EXN = TRUE, spuIDs = NULL, dbPath = NULL, disturbance_matrix_association = NULL, localeID = 1 )
spuDist( EXN = TRUE, spuIDs = NULL, dbPath = NULL, disturbance_matrix_association = NULL, localeID = 1 )
EXN |
logical. Use CBM-EXN CBM-CFS3 equivalent model data. |
spuIDs |
Optional. Subset by spatial unit ID(s) |
dbPath |
Path to CBM-CFS3 SQLite database file. Required if EXN = TRUE or EXN = FALSE. |
disturbance_matrix_association |
data.frame. Optional. Alternative disturbance_matrix_association table with columns "spatial_unit_id", "disturbance_type_id", and "disturbance_matrix_id". Required if EXN = TRUE. |
localeID |
CBM-CFS3 locale_id |
data.table
with 'disturbance_type_tr' columns
"spatial_unit_id", "disturbance_type_id", "name", "description"
and 'disturbance_matrix_association' columns
"spatial_unit_id" and "disturbance_matrix_id"
Match disturbance names with CBM-CFS3 spatial unit disturbances.
spuDistMatch( distTable, ask = interactive(), nearMatches = TRUE, listDist = NULL, ... )
spuDistMatch( distTable, ask = interactive(), nearMatches = TRUE, listDist = NULL, ... )
distTable |
|
ask |
logical. If TRUE, prompt the user to choose the correct disturbance matches. If FALSE, the function will look for exact name matches. |
nearMatches |
logical. Allow for near matches; e.g. "clearcut" can match "clear-cut". |
listDist |
data.table. Optional. Result of a call to |
... |
arguments to |
data.table
with columns 'spatial_unit_id'
'disturbance_type_id', 'disturbance_matrix_id', 'name', 'description'