Skip to content

Commit

Permalink
Merge pull request #52 from DidierMurilloF/row-column-optimization
Browse files Browse the repository at this point in the history
Fix: Plot rendering for row-column design
  • Loading branch information
DidierMurilloF authored Jul 17, 2024
2 parents a7fa9cd + eb28b3f commit e39f325
Show file tree
Hide file tree
Showing 9 changed files with 27 additions and 18 deletions.
3 changes: 3 additions & 0 deletions .Rbuildignore
Original file line number Diff line number Diff line change
Expand Up @@ -42,3 +42,6 @@ $run_dev.*
^vignettes/incomplete_blocks\.Rmd$
^vignettes/rectangular_lattice\.Rmd$
^vignettes/square_lattice\.Rmd$
^vignettes/sparse_allocation\.Rmd$
^vignettes/optimized_arrangement\.Rmd$

2 changes: 1 addition & 1 deletion DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
Package: FielDHub
Title: A Shiny App for Design of Experiments in Life Sciences
Version: 1.4.1
Version: 1.4.2
Authors@R:
c(person(given = "Didier",
family = "Murillo",
Expand Down
3 changes: 0 additions & 3 deletions NAMESPACE
Original file line number Diff line number Diff line change
Expand Up @@ -12,14 +12,12 @@ export(alpha_lattice)
export(diagonal_arrangement)
export(do_optim)
export(full_factorial)
export(improve_efficiency)
export(incomplete_blocks)
export(latin_square)
export(multi_location_prep)
export(optimized_arrangement)
export(partially_replicated)
export(rectangular_lattice)
export(report_efficiency)
export(row_column)
export(run_app)
export(sparse_allocation)
Expand All @@ -29,7 +27,6 @@ export(split_split_plot)
export(square_lattice)
export(strip_plot)
export(swap_pairs)
export(swap_treatments)
import(shiny)
importFrom(config,get)
importFrom(dplyr,glimpse)
Expand Down
2 changes: 1 addition & 1 deletion R/app_ui.R
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ app_ui <- function(request) {
tagList(
golem_add_external_resources(),
fluidPage(theme = shinythemes::shinytheme("flatly"),
navbarPage(title = "FielDHub v1.4.1",
navbarPage(title = "FielDHub v1.4.2",
tabPanel(
" Welcome!", icon = icon("home", lib = "glyphicon"),
suppressWarnings(
Expand Down
16 changes: 10 additions & 6 deletions R/fct_row_column.R
Original file line number Diff line number Diff line change
Expand Up @@ -40,11 +40,12 @@
#'
#' @examples
#'
#' # Example 1: Generates a row-column design with 3 full blocks and 36 treatments
#' # Example 1: Generates a row-column design with 3 full blocks and 24 treatments
#' # and 6 rows. This for one location.
#' rowcold1 <- row_column(t = 36, nrows = 6, r = 3, l = 1,
#' rowcold1 <- row_column(t = 24, nrows = 6, r = 3, l = 1,
#' plotNumber= 101,
#' locationNames = "Loc1",
#' iterations = 500,
#' seed = 21)
#' rowcold1$infoDesign
#' rowcold1$resolvableBlocks
Expand All @@ -61,6 +62,7 @@
#' plotNumber= c(101,1001),
#' locationNames = c("A", "B"),
#' seed = 15,
#' iterations = 500,
#' data = treatment_list)
#' rowcold2$infoDesign
#' rowcold2$resolvableBlocks
Expand Down Expand Up @@ -164,7 +166,10 @@ row_column <- function(t = NULL, nrows = NULL, r = NULL, l = 1, plotNumber= 101,
PLOT = plots,
ENTRY = treatments) |>
dplyr::mutate(
REP = as.numeric(factor(REP, levels = unique(REP))),
REP = as.numeric(factor(REP, levels = unique(REP)))
) |>
dplyr::group_by(REP) |>
dplyr::mutate(
COLUMN = as.numeric(factor(COLUMN, levels = unique(COLUMN))),
ROW = as.numeric(factor(ROW, levels = unique(ROW)))
) |>
Expand All @@ -179,7 +184,7 @@ row_column <- function(t = NULL, nrows = NULL, r = NULL, l = 1, plotNumber= 101,
out_row_col <- dplyr::bind_rows(out_row_col_loc)
out_row_col$ENTRY <- as.numeric(out_row_col$ENTRY)

if(lookup) {
if (lookup) {
out_row_col <- dplyr::inner_join(out_row_col, dataLookUp, by = "ENTRY")
out_row_col <- out_row_col |>
dplyr::rename(TREATMENT = LABEL_TREATMENT) |>
Expand All @@ -191,11 +196,10 @@ row_column <- function(t = NULL, nrows = NULL, r = NULL, l = 1, plotNumber= 101,
ID <- 1:nrow(out_row_col)
out_row_col_id <- cbind(ID, out_row_col)

out_row_col_id <- out_row_col_id[order(out_row_col_id$LOCATION, out_row_col_id$REP, out_row_col_id$ROW),]
row_col_plots <- ibd_plot_numbers(nt = nt, plot.number = plotNumber, r = r, l = l)
out_row_col_id$PLOT <- as.vector(unlist(row_col_plots))

# return(list(fieldBook = out_row_col_id, blocks_model = blocks_model))

loc <- levels(out_row_col_id$LOCATION)
ib <- nt/k
Resolvable_rc_reps <- vector(mode = "list", length = r*l)
Expand Down
5 changes: 4 additions & 1 deletion R/globals.R
Original file line number Diff line number Diff line change
Expand Up @@ -32,4 +32,7 @@ utils::globalVariables(c("ENTRY",
"Times",
"all_consecutive",
"are_consecutive",
"plots", "arcbd_plot", "new_order_treatments"))
"plots", "arcbd_plot", "new_order_treatments",
"LABEL_TREATMENT",
"Level",
"Level_3"))
2 changes: 1 addition & 1 deletion R/utils_plot_latinSQ.R
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ plot_latinSQ <- function(x = NULL, dims = NULL, n_Reps = NULL, layout = 1,
plots <- NewBook$PLOT
if (x$infoDesign$id_design == 9) {
plots <- NewBook$PLOT
NewROWS1 <- rep(1:(rsRep*n_Reps), each = csRep)
NewROWS1 <- rep(1:(rsRep * n_Reps), each = csRep)
NewCOLUMNS1 <- NewBook$COLUMN
NewROWS2 <- NewBook$ROW
} else if (x$infoDesign$id_design == 7) {
Expand Down
6 changes: 3 additions & 3 deletions R/utils_row_col_optimization.R
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Function to randomly swap a pair of treatments within a random
# level of Level_2 for all levels of Level_1
#' @export
#' @noRd
swap_treatments <- function(df) {
# Split the dataframe by Level_1
df_split <- split(df, df$Level_1)
Expand Down Expand Up @@ -36,7 +36,7 @@ swap_treatments <- function(df) {
}

# Function to improve A-Efficiency for Level 2
#' @export
#' @noRd
improve_efficiency <- function(design, iterations, seed) {
set.seed(seed)
# Initial design
Expand Down Expand Up @@ -76,7 +76,7 @@ improve_efficiency <- function(design, iterations, seed) {
}

# Function to calculate and return combined BlockEfficiencies
#' @export
#' @noRd
report_efficiency <- function(design) {
# Calculate row block efficiencies
row_blocks <- design |>
Expand Down
6 changes: 4 additions & 2 deletions man/row_column.Rd

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

0 comments on commit e39f325

Please sign in to comment.