#'@title Convert Block Column to Rownames
#'
#'@description Detect externally generated blocking columns and convert to rownames
#'@param RunMatrix The run matrix
#'@param blocking Whether random effects should be included.
#'@param varianceratios A vector of variance ratios for each level of restricted randomization
#'@return Row-name encoded blocked run matrix
#'@keywords internal
convert_blockcolumn_rownames = function(
RunMatrix,
blocking,
varianceratios,
verbose = FALSE
) {
if (
is.null(attr(RunMatrix, "splitanalyzable")) &&
any(grepl(
"(Block|block)(\\s?)+[0-9]+$",
colnames(RunMatrix),
perl = TRUE
)) ||
any(grepl(
"(Whole Plots|Whole\\.Plots|Subplots)",
colnames(RunMatrix),
perl = TRUE
))
) {
blockcols = grepl(
"(Block|block)(\\s?)+[0-9]+$",
colnames(RunMatrix),
perl = TRUE
) |
grepl(
"(Whole Plots|Whole\\.Plots|Subplots)",
colnames(RunMatrix),
perl = TRUE
)
if (blocking) {
if (verbose) {
message(
"Detected externally generated blocking columns: attempting to interpret blocking structure."
)
}
blockmatrix = RunMatrix[, blockcols, drop = FALSE]
block_max = apply(blockmatrix, 2, max)
blockmatrix = blockmatrix[, order(block_max), drop = FALSE]
block_order = do.call(order, lapply(blockmatrix, `[`))
blockmatrix = blockmatrix[
block_order,
order(unlist(lapply(lapply(blockmatrix, unique), length))),
drop = FALSE
]
blockvals = lapply(blockmatrix, unique)
rownamematrix = cbind(
do.call("cbind", lapply(blockmatrix, as.character)),
matrix(
as.character(seq_len(nrow(blockmatrix))),
ncol = 1,
nrow = nrow(blockmatrix)
)
)
blockgroups = lapply(blockmatrix, table)
names(blockgroups) = NULL
if (
length(blockgroups) != length(varianceratios) &&
length(varianceratios) == 1
) {
varianceratios = c(rep(varianceratios, length(blockgroups) - 1), 1)
}
if (length(blockgroups) - 1 == length(varianceratios)) {
varianceratios = c(varianceratios, 1)
}
if (length(blockgroups) + 1 == length(varianceratios)) {
varianceratios = varianceratios[-length(varianceratios)]
}
if (length(blockgroups) != length(varianceratios)) {
stop(
"skpr: Wrong number of variance ratios specified. ",
length(varianceratios),
" variance ratios given: c(",
paste(varianceratios, collapse = ", "),
"), ",
length(blockgroups),
" expected. Either specify value for all blocking levels or one ratio for all blocks other than then run-to-run variance."
)
}
zlist = list()
for (i in seq_len(length(blockgroups))) {
tempblocks = blockgroups[[i]]
block_column = blockmatrix[, i, drop = TRUE]
tempnumberblocks = length(tempblocks)
ztemp = matrix(0, nrow = nrow(RunMatrix), ncol = tempnumberblocks)
currentrow = 1
for (j in seq_len(tempnumberblocks)) {
blockname = names(tempblocks)[j]
current_block = block_column == blockname
ztemp[current_block, j] = varianceratios[i]
currentrow = currentrow + tempblocks[j]
}
zlist[[i]] = ztemp
}
if (is.null(attr(RunMatrix, "z.matrix.list"))) {
attr(RunMatrix, "z.matrix.list") = zlist
} else {
attr(RunMatrix, "z.matrix.list") = list(
attr(RunMatrix, "z.matrix.list"),
zlist
)
}
allattr = attributes(RunMatrix)
allattr$names = allattr$names[!blockcols]
RunMatrix = RunMatrix[block_order, !blockcols, drop = FALSE]
attributes(RunMatrix) = allattr
rownames(RunMatrix) = apply(rownamematrix, 1, paste, collapse = ".")
} else {
warning(
"Detected externally generated blocking columns but blocking not turned on: ignoring blocking structure and removing blocking columns."
)
allattr = attributes(RunMatrix)
allattr$names = allattr$names[!blockcols]
RunMatrix = RunMatrix[, !blockcols, drop = FALSE]
attributes(RunMatrix) = allattr
}
} else {
if (
any(grepl(
"(Block|block)(\\s?)+[0-9]+$",
colnames(RunMatrix),
perl = TRUE
)) ||
any(grepl(
"(Whole Plots|Whole\\.Plots|Subplots)",
colnames(RunMatrix),
perl = TRUE
))
) {
added_cols = colnames(RunMatrix)[
grepl("(Block|block)(\\s?)+[0-9]+$", colnames(RunMatrix), perl = TRUE) |
grepl(
"(Whole Plots|Whole\\.Plots|Subplots)",
colnames(RunMatrix),
perl = TRUE
)
]
extra_cols = paste0(sprintf("`%s`", added_cols), collapse = ", ")
blockcols = grepl(
"(Block|block)(\\s?)+[0-9]+$",
colnames(RunMatrix),
perl = TRUE
) |
grepl(
"(Whole Plots|Whole\\.Plots|Subplots)",
colnames(RunMatrix),
perl = TRUE
)
allattr = attributes(RunMatrix)
allattr$names = allattr$names[!blockcols]
RunMatrix = RunMatrix[, !blockcols, drop = FALSE]
attributes(RunMatrix) = allattr
warning(sprintf(
"skpr: Externally added block columns detected: extra block columns (%s) ignored.",
extra_cols
))
}
}
attr(RunMatrix, "tempvar") = varianceratios
return(RunMatrix)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.