Skip to content

Commit

Permalink
Add warnings for bad site<-~ normalization; closes #171; remove ddply #…
Browse files Browse the repository at this point in the history
  • Loading branch information
brownag committed Jan 21, 2021
1 parent d069609 commit 414928f
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 15 deletions.
22 changes: 13 additions & 9 deletions R/SoilProfileCollection-setters.R
Original file line number Diff line number Diff line change
Expand Up @@ -335,22 +335,26 @@ setReplaceMethod("site", signature(object = "SoilProfileCollection"),
names_attr <- names(mf)
idx <- match(names_attr, horizonNames(object))

# remove the index to the ID columnm, as we do not want to remove this from
# remove the index to the ID column, as we do not want to remove this from
# the horizon data !
idx <- idx[-match(idname(object), names_attr)]

# this will break when multiple horizons in the same pedon have different site data!
# this seems to work fine in all cases, as we keep the ID column
# and it ensures that the result is in the same order as the IDs
new_site_data <- ddply(mf, idname(object),
.fun=function(x) {
unique(x[, names_attr, drop = FALSE])
}
)

.SD <- NULL

dth <- as.data.table(horizons(object))

new_site_data <- .as.data.frame.aqp(unique(dth[, .SD, .SDcols = names_attr]), aqp_df_class(object))

if (nrow(new_site_data) != length(object)) {
warning("One or more horizon columns cannot be normalized to site. Leaving site data unchanged.", call. = FALSE)
return(object)
}

# if site data is already present, we don't overwrite/erase it
site_data <- merge(object@site, new_site_data, by = idname(object),
all.x = TRUE, sort = FALSE)
site_data <- merge(object@site, new_site_data, by = idname(object), all.x = TRUE, sort = FALSE)

# remove the named site data from horizon_data
h <- object@horizons
Expand Down
15 changes: 9 additions & 6 deletions tests/testthat/test-denormalize.R
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,14 @@ depths(sp1) <- id ~ top + bottom
sp1$sitevar <- round(runif(length(sp1)))

test_that("denormalize result is 1:1 with horizons", {
# use denormalize() to create a mirror of sitevar in the horizon table
# name the attribute something different (e.g. `hz.sitevar`) to prevent collision with the site attribute
# the attributes can have the same name but you will then need site() or horizons() to access explicitly
# use denormalize() to create a mirror of sitevar in the horizon table
# name the attribute something different (e.g. `hz.sitevar`) to prevent collision with the site attribute
# the attributes can have the same name but you will then need site() or horizons() to access explicitly
sp1.hz.sitevar <- denormalize(sp1, 'sitevar')

expect_error(sp1.hz.sitevar <- denormalize(sp1, 'foo'))

# compare number of horizons to number of values in denormalize result
# compare number of horizons to number of values in denormalize result
expect_equal(nrow(sp1), length(sp1.hz.sitevar)) # check that the output is 1:1 with horizon

sp1$hz.sitevar <- sp1.hz.sitevar
Expand Down Expand Up @@ -56,9 +56,12 @@ test_that("round trip normalize/denormalize", {
sp3$foo4 <- 1:nrow(sp3)

# do that SPC dirty...
# TODO: fix these
expect_silent(site(sp3) <- ~ foo3 + foo4)
expect_warning(site(sp3) <- ~ foo3 + foo4)

# still valid
expect_true(spc_in_sync(sp3)$valid)

# didn't do anything
expect_equal(length(sp3$foo3), nrow(sp3))
expect_equal(length(sp3$foo4), nrow(sp3))
})

0 comments on commit 414928f

Please sign in to comment.