Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Replace udunits2 with units #2989

Merged
merged 44 commits into from
Aug 1, 2022
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
44 commits
Select commit Hold shift + click to select a range
1d8facc
replaced ud.convert() with ud_convert() in PEcAn.utils and PEcAn.DB p…
nanu1605 Jul 27, 2022
fc09bfd
Merge branch 'PecanProject:develop' into replace_udunits2
nanu1605 Jul 27, 2022
a357f3b
updated docker/depends/pecan.depends.R
nanu1605 Jul 27, 2022
7d8cd4b
replaced ud.convert() with ud_convert()
nanu1605 Jul 27, 2022
1941da1
updated docker/depends/pecan.depends.R
nanu1605 Jul 27, 2022
09b4c95
Update base/utils/R/ud_convert.R
nanu1605 Jul 28, 2022
7e24653
Update base/utils/R/ud_convert.R
nanu1605 Jul 28, 2022
9ea3198
Update base/utils/R/ud_convert.R
nanu1605 Jul 28, 2022
0be9b99
Update base/utils/R/ud_convert.R
nanu1605 Jul 28, 2022
d098c5e
Update modules/data.atmosphere/R/merge.met.variable.R
nanu1605 Jul 28, 2022
338e47a
Update base/utils/R/ud_convert.R
nanu1605 Jul 28, 2022
9d4dbf7
changes in ud_convert.Rd
nanu1605 Jul 28, 2022
9d83c1e
changed base/db/R/insert.format.vars.R
nanu1605 Jul 28, 2022
2b0558e
Merge branch 'PecanProject:develop' into replace_udunits2
nanu1605 Jul 28, 2022
040d3e1
added test-ud_convert.R
nanu1605 Jul 29, 2022
b722c6d
Update base/utils/tests/testthat/test-ud_convert.R
nanu1605 Jul 30, 2022
e964094
Update base/utils/tests/testthat/test-ud_convert.R
nanu1605 Jul 30, 2022
e028034
added one more test
nanu1605 Jul 30, 2022
ef230ba
added one more test
nanu1605 Jul 30, 2022
ebbd07b
updated the Rcheck_reference.log file for assim.batch
nanu1605 Jul 30, 2022
86db0a4
minor change in the Rcheck_reference.log file for assim.batch
nanu1605 Jul 30, 2022
7482b9c
Update base/db/R/insert.format.vars.R
nanu1605 Jul 30, 2022
38feefb
Update base/db/R/insert.format.vars.R
nanu1605 Jul 30, 2022
1cf137a
Update base/utils/tests/testthat/test-ud_convert.R
nanu1605 Jul 30, 2022
1a374af
Update modules/data.atmosphere/R/merge.met.variable.R
nanu1605 Jul 30, 2022
edfc16f
Update base/utils/tests/testthat/test-ud_convert.R
infotroph Jul 30, 2022
45c238a
Update modules/data.atmosphere/R/metgapfill.R
nanu1605 Jul 31, 2022
9f4ee29
change in Rcheck_reference.log of data.land
nanu1605 Jul 31, 2022
bdb1331
suggested changes
nanu1605 Jul 31, 2022
05e1dcf
minor change in Rcheck_reference.log of data.land
nanu1605 Jul 31, 2022
f72a7b4
changed Rcheck_reference.log of data.land
nanu1605 Jul 31, 2022
ad657cd
changed DESCRIPTION of PEcAn.dvmdostem
nanu1605 Jul 31, 2022
7aa3938
updated Makefile.depends
nanu1605 Jul 31, 2022
a68c6b6
added stringr in the DESCRIPTION of fates
nanu1605 Jul 31, 2022
00c33d0
some changes in PEcAn.fates
nanu1605 Jul 31, 2022
3a1e71e
Some changes in the DESCRIPTION of jules package
nanu1605 Jul 31, 2022
5612b90
updated DESCRIPTION of lpjguess
nanu1605 Jul 31, 2022
efcc60c
Merge branch 'develop' into replace_udunits2
mdietze Jul 31, 2022
9f41042
Update models/fates/R/met2model.FATES.R
nanu1605 Aug 1, 2022
ddf96d5
Update models/lpjguess/R/met2model.LPJGUESS.R
nanu1605 Aug 1, 2022
bce964b
Merge branch 'develop' into replace_udunits2
nanu1605 Aug 1, 2022
097e4b4
updated CHANGELOG.md
nanu1605 Aug 1, 2022
ef81a3d
Merge branch 'develop' into replace_udunits2
mdietze Aug 1, 2022
c1d07ce
Update CHANGELOG.md
nanu1605 Aug 1, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion base/db/DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ Imports:
rlang,
tibble,
tidyr,
udunits2,
units
Suggests:
bit64,
data.table,
Expand Down
4 changes: 2 additions & 2 deletions base/db/R/insert.format.vars.R
Original file line number Diff line number Diff line change
Expand Up @@ -126,13 +126,13 @@ insert.format.vars <- function(con, format_name, mimetype_id, notes = NULL, head
u1 <- formats_variables[1,"unit"]
u2 <- dplyr::tbl(con, "variables") %>% dplyr::select(.data$id, units) %>% dplyr::filter(.data$id %in% !!formats_variables[[1, "variable_id"]]) %>% dplyr::pull(.data$units)

if(!udunits2::ud.is.parseable(u1)){
if(!units::install_unit(u1)){
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
PEcAn.logger::logger.error(
"Units not parseable. Please enter a unit that is parseable by the udunits library."
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
)
}
# Grab the bety units and
if(!udunits2::ud.are.convertible(u1, u2)){
if(!units::ud_are_convertible(u1, u2)){
PEcAn.logger::logger.error(
"Units are not convertable."
)
Expand Down
4 changes: 2 additions & 2 deletions base/db/R/query.dplyr.R
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,8 @@ dplyr.count <- function(df) {
#' @export
ncdays2date <- function(time, unit) {
date <- lubridate::parse_date_time(unit, c("ymd_hms", "ymd_h", "ymd"))
days <- udunits2::ud.convert(time, unit, paste("days since ", date))
seconds <- udunits2::ud.convert(days, "days", "seconds")
days <- PEcAn.utils::ud_convert(time, unit, paste("days since ", date))
seconds <- PEcAn.utils::ud_convert(days, "days", "seconds")
return(as.POSIXct.numeric(seconds, origin = date, tz = "UTC"))
} # ncdays2date

Expand Down
2 changes: 1 addition & 1 deletion base/db/R/query.format.vars.R
Original file line number Diff line number Diff line change
Expand Up @@ -133,7 +133,7 @@ query.format.vars <- function(bety, input.id=NA, format.id=NA, var.ids=NA) {

# This would be a good place to put a test for valid sotrage types. Currently not implemented.

} else if (udunits2::ud.are.convertible(format$vars$input_units[i], format$vars$pecan_units[i]) == FALSE) {
} else if (units::ud_are_convertible(format$vars$input_units[i], format$vars$pecan_units[i]) == FALSE) {

if (PEcAn.utils::misc.are.convertible(format$vars$input_units[i], format$vars$pecan_units[i]) == FALSE) {
PEcAn.logger::logger.warn("Units not convertible for",format$vars$input_name[i], "with units of",format$vars$input_units[i], ". Please make sure the varible has units that can be converted to", format$vars$pecan_units[i])
Expand Down
3 changes: 1 addition & 2 deletions base/db/inst/import-try/96.load.data.R
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
# 6. Add TRY data to BETY
source("common.R")
load("try.5.RData")
library(udunits2)
library(stringr)

setkey(try.dat, ObservationID)
Expand Down Expand Up @@ -57,7 +56,7 @@ for(i in 1:nrow(try.entities)){
site_id = try.sub[j, bety.site.id],
specie_id = try.sub[j, bety.species.id],
citation_id = try.sub[j, bety.citation.id],
mean = try.sub[j, udunits2::ud.convert(StdValue, UnitName, units)],
mean = try.sub[j, PEcAn.utils::ud_convert(StdValue, UnitName, units)],
n = try.sub[j, Replicates],
user_id = user_id,
entity_id = entity,
Expand Down
2 changes: 1 addition & 1 deletion base/utils/DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ Imports:
RCurl,
rlang,
stringi,
udunits2 (>= 0.11),
units,
XML
Suggests:
coda (>= 0.18),
Expand Down
1 change: 1 addition & 0 deletions base/utils/NAMESPACE
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@ export(to_ncvar)
export(trait.lookup)
export(transformstats)
export(tryl)
export(ud_convert)
export(units_are_equivalent)
export(vecpaste)
export(zero.truncate)
Expand Down
4 changes: 2 additions & 2 deletions base/utils/R/cf2date.R
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
#' cf2datetime(365, "days since 2000-01-01 12:00:00 -05:00")
cf2datetime <- function(value, unit, tz = "UTC") {
origin <- "1970-01-01 00:00:00 UTC"
ctint <- udunits2::ud.convert(value, unit, paste("seconds since", origin))
ctint <- ud_convert(value, unit, paste("seconds since", origin))
result <- as.POSIXct(ctint, origin = origin)
attr(result, "tzone") <- tz
result
Expand All @@ -43,7 +43,7 @@ datetime2cf <- function(datetime, unit, ...) {
}
origin <- "1970-01-01 00:00:00 UTC"
raw_ct <- as.numeric(datetime, origin = origin)
udunits2::ud.convert(raw_ct, paste("seconds since", origin), unit)
ud_convert(raw_ct, paste("seconds since", origin), unit)
}

#' Extract Julian day from CF or POSIXct date-times
Expand Down
4 changes: 2 additions & 2 deletions base/utils/R/read.output.R
Original file line number Diff line number Diff line change
Expand Up @@ -218,7 +218,7 @@ read.output <- function(runid, outdir,
}

if (dataframe) {
seconds <- udunits2::ud.convert(
seconds <- ud_convert(
nc$dim$time$vals,
nc$dim$time$units,
paste("seconds since", run_origin)
Expand Down Expand Up @@ -264,7 +264,7 @@ read.output <- function(runid, outdir,
# Dropping attempt to provide more sensible units because of graph unit errors,
# issue #792
# if (v %in% c(cflux, wflux)) {
# newresult <- udunits2::ud.convert(newresult, 'kg m-2 s-1', 'kg ha-1 yr-1')
# newresult <- ud_convert(newresult, 'kg m-2 s-1', 'kg ha-1 yr-1')
# }
result[[v]] <- abind::abind(result[[v]], newresult)
}
Expand Down
2 changes: 1 addition & 1 deletion base/utils/R/seconds_in_year.R
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,6 @@
#' @export
seconds_in_year <- function(year, leap_year = TRUE, ...) {
diy <- days_in_year(year, leap_year)
siy <- udunits2::ud.convert(diy, 'days', 'seconds')
siy <- ud_convert(diy, 'days', 'seconds')
return(siy)
}
17 changes: 17 additions & 0 deletions base/utils/R/ud_convert.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
##' @title Convert units
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
##'
##' This function takes the numeric argument `x`, quantified in units `u1` and converts it to be of units `u2`.
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
##' @author Chris Black
##'
##' @param x numeric vector with units `u1` to be converted to units `u2`
##' @param u1 string which is parseable into a `units` compatible unit.
##' @param u2 string which is parseable into a `units` compatible unit,
##' and for which there exists a defined transformation from the units represented by `u1`.
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
##'
##' @return numeric vector stripped of units
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
##' @export
ud_convert <- function(x, u1, u2) {
stopifnot(units::ud_are_convertible(u1, u2))
a <- units::set_units(x, value = u1, mode = "standard")
units::drop_units(units::set_units(a, value = u2, mode = "standard"))
} # ud_convert
nanu1605 marked this conversation as resolved.
Show resolved Hide resolved
2 changes: 1 addition & 1 deletion base/utils/R/units_are_equivalent.R
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,6 @@
#' @author Alexey Shiklomanov
#' @export
units_are_equivalent <- function(x, y) {
x2y <- udunits2::ud.convert(1, x, y)
x2y <- ud_convert(1, x, y)
1 == x2y
}
18 changes: 9 additions & 9 deletions base/utils/R/utils.R
Original file line number Diff line number Diff line change
Expand Up @@ -389,8 +389,8 @@ tabnum <- function(x, n = 3) {
##' @export
##' @author unknown
arrhenius.scaling <- function(observed.value, old.temp, new.temp = 25) {
new.temp.K <- udunits2::ud.convert(new.temp, "degC", "K")
old.temp.K <- udunits2::ud.convert(old.temp, "degC", "K")
new.temp.K <- ud_convert(new.temp, "degC", "K")
old.temp.K <- ud_convert(old.temp, "degC", "K")
return(observed.value / exp(3000 * (1 / (new.temp.K) - 1 / (old.temp.K))))
} # arrhenius.scaling
#--------------------------------------------------------------------------------------------------#
Expand Down Expand Up @@ -558,21 +558,21 @@ misc.convert <- function(x, u1, u2) {
mmH2O <- 18.01528 # molar mass of H2O, g/mol

if (u1 == "umol C m-2 s-1" & u2 == "kg C m-2 s-1") {
val <- udunits2::ud.convert(x, "ug", "kg") * amC
val <- ud_convert(x, "ug", "kg") * amC
} else if (u1 == "kg C m-2 s-1" & u2 == "umol C m-2 s-1") {
val <- udunits2::ud.convert(x, "kg", "ug") / amC
val <- ud_convert(x, "kg", "ug") / amC
} else if (u1 == "mol H2O m-2 s-1" & u2 == "kg H2O m-2 s-1") {
val <- udunits2::ud.convert(x, "g", "kg") * mmH2O
val <- ud_convert(x, "g", "kg") * mmH2O
} else if (u1 == "kg H2O m-2 s-1" & u2 == "mol H2O m-2 s-1") {
val <- udunits2::ud.convert(x, "kg", "g") / mmH2O
val <- ud_convert(x, "kg", "g") / mmH2O
} else if (u1 == "Mg ha-1" & u2 == "kg C m-2") {
val <- x * udunits2::ud.convert(1, "Mg", "kg") * udunits2::ud.convert(1, "ha-1", "m-2")
val <- x * ud_convert(1, "Mg", "kg") * ud_convert(1, "ha-1", "m-2")
} else if (u1 == "kg C m-2" & u2 == "Mg ha-1") {
val <- x * udunits2::ud.convert(1, "kg", "Mg") * udunits2::ud.convert(1, "m-2", "ha-1")
val <- x * ud_convert(1, "kg", "Mg") * ud_convert(1, "m-2", "ha-1")
} else {
u1 <- gsub("gC","g*12",u1)
u2 <- gsub("gC","g*12",u2)
val <- udunits2::ud.convert(x,u1,u2)
val <- ud_convert(x,u1,u2)


# PEcAn.logger::logger.severe(paste("Unknown units", u1, u2))
Expand Down
29 changes: 29 additions & 0 deletions base/utils/man/ud_convert.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion docker/depends/pecan.depends.R
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ wanted <- c(
'traits',
'TruncatedNormal',
'truncnorm',
'udunits2',
'units',
'urltools',
'utils',
'vdiffr',
Expand Down
1 change: 0 additions & 1 deletion models/basgra/DESCRIPTION
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ Imports:
PEcAn.utils (>= 1.4.8),
lubridate,
ncdf4,
udunits2
Suggests:
testthat (>= 1.0.2)
OS_type: unix
Expand Down
36 changes: 18 additions & 18 deletions models/basgra/R/run_BASGRA.R
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ run_BASGRA <- function(run_met, run_params, site_harvest, site_fertilize, start_

## convert time to seconds
sec <- nc$dim$time$vals
sec <- udunits2::ud.convert(sec, unlist(strsplit(nc$dim$time$units, " "))[1], "seconds")
sec <- PEcAn.utils::ud_convert(sec, unlist(strsplit(nc$dim$time$units, " "))[1], "seconds")

dt <- diff(sec)[1]
tstep <- round(86400 / dt)
Expand Down Expand Up @@ -121,7 +121,7 @@ run_BASGRA <- function(run_met, run_params, site_harvest, site_fertilize, start_

Tair <- ncdf4::ncvar_get(nc, "air_temperature") ## in Kelvin
Tair <- Tair[ydays %in% simdays]
Tair_C <- udunits2::ud.convert(Tair, "K", "degC")
Tair_C <- PEcAn.utils::ud_convert(Tair, "K", "degC")


#in BASGRA tmin and tmax is only used to calculate the average daily temperature, see environment.f90
Expand Down Expand Up @@ -360,36 +360,36 @@ run_BASGRA <- function(run_met, run_params, site_harvest, site_fertilize, start_
outlist[[length(outlist)+1]] <- output[thisyear, which(outputNames == "LAI")] # LAI in (m2 m-2)

CropYield <- output[thisyear, which(outputNames == "YIELD_POT")] # (g DM m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(CropYield, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(CropYield, "g m-2", "kg m-2")

clitt <- output[thisyear, which(outputNames == "CLITT")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(clitt, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(clitt, "g m-2", "kg m-2")

cstub <- output[thisyear, which(outputNames == "CSTUB")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(cstub, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(cstub, "g m-2", "kg m-2")

cst <- output[thisyear, which(outputNames == "CST")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(cst, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(cst, "g m-2", "kg m-2")

crt <- output[thisyear, which(outputNames == "CRT")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(crt, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(crt, "g m-2", "kg m-2")

cres <- output[thisyear, which(outputNames == "CRES")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(cres, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(cres, "g m-2", "kg m-2")

clv <- output[thisyear, which(outputNames == "CLV")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(clv, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(clv, "g m-2", "kg m-2")

clvd <- output[thisyear, which(outputNames == "CLVD")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(clvd, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(clvd, "g m-2", "kg m-2")

csomf <- output[thisyear, which(outputNames == "CSOMF")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(csomf, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(csomf, "g m-2", "kg m-2")

csoms <- output[thisyear, which(outputNames == "CSOMS")] # (g C m-2)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(csoms, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(csoms, "g m-2", "kg m-2")

outlist[[length(outlist)+1]] <- udunits2::ud.convert(csomf + csoms, "g m-2", "kg m-2")
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(csomf + csoms, "g m-2", "kg m-2")

outlist[[length(outlist)+1]] <- output[thisyear, which(outputNames == "TILG1")]
outlist[[length(outlist)+1]] <- output[thisyear, which(outputNames == "TILG2")]
Expand All @@ -401,22 +401,22 @@ run_BASGRA <- function(run_met, run_params, site_harvest, site_fertilize, start_

# Soil Respiration in kgC/m2/s
rsoil <- output[thisyear, which(outputNames == "Rsoil")] # (g C m-2 d-1)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(rsoil, "g m-2", "kg m-2") / sec_in_day
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(rsoil, "g m-2", "kg m-2") / sec_in_day

# Autotrophic Respiration in kgC/m2/s
rplantaer <- output[thisyear, which(outputNames == "RplantAer")] # (g C m-2 d-1)
outlist[[length(outlist)+1]] <- udunits2::ud.convert(rplantaer, "g m-2", "kg m-2") / sec_in_day
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(rplantaer, "g m-2", "kg m-2") / sec_in_day

# NEE in kgC/m2/s
# NOTE: According to BASGRA_N documentation: LUEMXQ (used in PHOT calculation) accounts for carbon lost to maintenance respiration,
# but not growth respiration. So, photosynthesis rate is gross photosynthesis minus maintenance respiration
# So this is not really GPP, but it wasn't obvious to add what to get GPP, but I just want NEE for now, so it's OK
phot <- output[thisyear, which(outputNames == "PHOT")] # (g C m-2 d-1)
nee <- -1.0 * (phot - (rsoil + rplantaer))
outlist[[length(outlist)+1]] <- udunits2::ud.convert(nee, "g m-2", "kg m-2") / sec_in_day
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(nee, "g m-2", "kg m-2") / sec_in_day

# again this is not technically GPP
outlist[[length(outlist)+1]] <- udunits2::ud.convert(phot, "g m-2", "kg m-2") / sec_in_day
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(phot, "g m-2", "kg m-2") / sec_in_day

# Qle W/m2
outlist[[length(outlist)+1]] <- ( output[thisyear, which(outputNames == "EVAP")] + output[thisyear, which(outputNames == "TRAN")] *
Expand All @@ -425,7 +425,7 @@ run_BASGRA <- function(run_met, run_params, site_harvest, site_fertilize, start_
# SoilMoist (!!! only liquid water !!!) kg m-2
# during the groowing season its depth will mainly be equal to the rooting depth, but during winter its depth will be ROOTD-Fdepth
soilm <- output[thisyear, which(outputNames == "WAL")] # mm
outlist[[length(outlist)+1]] <- udunits2::ud.convert(soilm, "mm", "m") * 1000 # (kg m-3) density of water in soil
outlist[[length(outlist)+1]] <- PEcAn.utils::ud_convert(soilm, "mm", "m") * 1000 # (kg m-3) density of water in soil

# ******************** Declare netCDF dimensions and variables ********************#
t <- ncdf4::ncdim_def(name = "time",
Expand Down
Loading