inst/shiny-squid/source/server/modules/module8/svr_mod8_step_2.R

#Server functions for module 8 step 2
c(
    
    ######### Set variables ######### 
    Mod8Step2updateVind <- function(input, nb.IS){
        m <- matrix(rep(0,nb.IS*nb.IS),nb.IS)
        diag(m)[1] <- input$Mod8Step2_Vi
        diag(m)[2] <- input$Mod8Step2_Vs1
        diag(m)[3] <- input$Mod8Step2_Vs2
        diag(m)[4] <- input$Mod8Step2_Vs12
        m[2,1]     <- input$Mod8Step2_CorIS1
        m[3,1]     <- input$Mod8Step2_CorIS2
        m[4,1]     <- input$Mod8Step2_CorIS12
        m[3,2]     <- input$Mod8Step2_CorS1S2
        m[4,2]     <- input$Mod8Step2_CorS1S12
        m[4,3]     <- input$Mod8Step2_CorS2S12
        return(m)
    },
    Mod8Step2updateB    <- function(input){
        m <- matrix(c(0,
                      input$Mod8Step2_B1,
                      input$Mod8Step2_B2, 
                      input$Mod8Step2_B12), 1)
        return(m)
    },
    
    # Set hidden variables
    output$Mod8Step2_hidden <- renderUI({
        list(
            numericInput("Mod8Step2_Tmax", "", Modules_VAR$Tmax$max),
            numericInput("Mod8Step2_NI", "",500),
            numericInput("Mod8Step2_NR", "",20),
            
            shinyMatrix::matrixInput("Mod8Step2_Vind", value = Mod8Step2updateVind(input, nb.IS), class = "numeric"),
            shinyMatrix::matrixInput("Mod8Step2_B", value = Mod8Step2updateB(input), class = "numeric"),
            
            checkboxInput("Mod8Step2_X1_state", "",      value = TRUE),
            checkboxInput("Mod8Step2_X1_sto_state", "",  value = TRUE),
            checkboxInput("Mod8Step2_X1_sto_shared", "", value = FALSE),
            
            checkboxInput("Mod8Step2_X2_state", "",      value = TRUE),
            checkboxInput("Mod8Step2_X2_sto_state", "",  value = TRUE),
            checkboxInput("Mod8Step2_X2_sto_shared", "", value = FALSE),
            
            checkboxInput("Mod8Step2_X_Interaction", "", value = TRUE)
        )
    }),
    outputOptions(output, "Mod8Step2_hidden", suspendWhenHidden = FALSE),
    
    ######### Run simulation #########
    # Run simulation and return results
    Mod8Step2_output <- reactive({
        
        if (input$Mod8Step2_Run == 0) # if Run button is pressed
            return(NULL)
        
        isolate({ 
            
            updateCheckboxInput(session, "isRunning", value = TRUE)
            
            # Call app main function
            data <- squid::squidR(input, module = "Mod8Step2")  
            
            # model [1] with witouth random slope in X interaction
            LMR1      <- lme4::lmer(Phenotype ~ 1 + X1*X2 + (1+X1+X2|Individual), data = data$sampled_data)
            FIXEF1    <- lme4::fixef(LMR1)
            SE.FIXEF1 <- arm::se.fixef(LMR1)
            RANDEF1   <- as.data.frame(lme4::VarCorr(LMR1))$vcov
            
            data$LMR1        <- LMR1

            data$Vi_1        <- round(RANDEF1[1],2)
            data$Vs1_1       <- round(RANDEF1[2],2)
            data$Vs2_1       <- round(RANDEF1[3],2)
            data$COVis1_1    <- round(RANDEF1[4],2)
            data$COVis2_1    <- round(RANDEF1[5],2)
            data$COVs1s2_1   <- round(RANDEF1[6],2)
            data$Vr_1        <- round(RANDEF1[7],2)

            data$B0_1        <- round(FIXEF1["(Intercept)"],2)
            data$se.B0_1     <- round(SE.FIXEF1["(Intercept)"],2)

            data$B1_1        <- round(FIXEF1["X1"],2)
            data$se.B1_1     <- round(SE.FIXEF1["X1"],2)

            data$B2_1        <- round(FIXEF1["X2"],2)
            data$se.B2_1     <- round(SE.FIXEF1["X2"],2)

            data$B12_1       <- round(FIXEF1["X1:X2"],2)
            data$se.B12_1    <- round(SE.FIXEF1["X1:X2"],2)
            
            # model [2] with witouth random slope in X interaction
            LMR2      <- lme4::lmer(Phenotype ~ 1 + X1*X2 + (1+X1*X2|Individual), data = data$sampled_data)
            FIXEF2    <- lme4::fixef(LMR2)
            SE.FIXEF2 <- arm::se.fixef(LMR2)
            RANDEF2   <- as.data.frame(lme4::VarCorr(LMR2))$vcov
            
            data$LMR2        <- LMR2
            
            data$Vi_2        <- round(RANDEF2[1],2)
            data$Vs1_2       <- round(RANDEF2[2],2)
            data$Vs2_2       <- round(RANDEF2[3],2)
            data$Vs12_2      <- round(RANDEF2[4],2)
            data$COVis1_2    <- round(RANDEF2[5],2)
            data$COVis2_2    <- round(RANDEF2[6],2)
            data$COVis12_2   <- round(RANDEF2[7],2)
            data$COVs1s2_2   <- round(RANDEF2[8],2)
            data$COVs1s12_2  <- round(RANDEF2[9],2)
            data$COVs2s12_2  <- round(RANDEF2[10],2)
            data$Vr_2        <- round(RANDEF2[11],2)
            
            data$B0_2        <- round(FIXEF2["(Intercept)"],2)
            data$se.B0_2     <- round(SE.FIXEF2["(Intercept)"],2)
            
            data$B1_2        <- round(FIXEF2["X1"],2)
            data$se.B1_2     <- round(SE.FIXEF2["X1"],2)
            
            data$B2_2        <- round(FIXEF2["X2"],2)
            data$se.B2_2     <- round(SE.FIXEF2["X2"],2)
            
            data$B12_2       <- round(FIXEF2["X1:X2"],2)
            data$se.B12_2    <- round(SE.FIXEF2["X1:X2"],2)
            
            updateCheckboxInput(session, "isRunning", value = FALSE)
            
            return(data)
        })  
    }),
    
    
    ######### Show results #########
    
    output$Mod8Step2_summary_table <- renderUI({ 
        
        data <- Mod8Step2_output()
        
        myTable <- data.frame(
            "Parameter" = c("Parameter",
                            "Fixed effects",
                            paste0("Mean of the trait $",EQ1$mean0,"$"),
                            paste0("Population slope of $",EQ2$env1,"$ ($",EQ1$mean1,"$)"),
                            paste0("Population slope of $",EQ2$env2,"$ ($",EQ1$mean2,"$)"),
                            paste0("Population slope of $",EQ2$env12,"$ ($",EQ1$mean12,"$)"),
                            "Random effects",
                            paste0("Among-individual variance in intercepts ($V_{",NOT$devI,"}$)"),
                            paste0("Among-individual variance in slopes ($V_{",EQ3$dev1,"}$)"),
                            paste0("Among-individual variance in slopes ($V_{",EQ3$dev2,"}$)"),
                            paste0("Among-individual variance in slopes ($V_{",EQ3$dev12,"}$)"),
                            paste0("Covariance between individual intercept and slope $(Cov_{",NOT$devI,EQ3$dev1,"})$"),
                            paste0("Covariance between individual intercept and slope $(Cov_{",NOT$devI,EQ3$dev2,"})$"),
                            paste0("Covariance between individual intercept and slope $(Cov_{",NOT$devI,EQ3$dev12,"})$"),
                            paste0("Covariance between individual slope to $",EQ2$env1,"$ and to $",EQ2$env2,"$ $(Cov_{",EQ3$dev1,EQ3$dev2,"})$"),
                            paste0("Covariance between individual slope to $",EQ2$env1,"$ and to $",EQ2$env12,"$ $(Cov_{",EQ3$dev1,EQ3$dev12,"})$"),
                            paste0("Covariance between individual slope to $",EQ2$env2,"$ and to $",EQ2$env12,"$ $(Cov_{",EQ3$dev2,EQ3$dev12,"})$"),
                            paste0("Measurement variance ($V_{",NOT$mError,"}$)")
            ),

            "True" = c("True",
                       "",
                       0,
                       input$Mod8Step2_B1,
                       input$Mod8Step2_B2,
                       input$Mod8Step2_B12,
                       "",
                       input$Mod8Step2_Vi,
                       input$Mod8Step2_Vs1,
                       input$Mod8Step2_Vs2,
                       input$Mod8Step2_Vs12,
                       round(input$Mod8Step2_CorIS1  * sqrt(input$Mod8Step2_Vi*input$Mod8Step2_Vs1),3),
                       round(input$Mod8Step2_CorIS2  * sqrt(input$Mod8Step2_Vi*input$Mod8Step2_Vs2),3),
                       round(input$Mod8Step2_CorIS12 * sqrt(input$Mod8Step2_Vi*input$Mod8Step2_Vs12),3),
                       round(input$Mod8Step2_CorS1S2 * sqrt(input$Mod8Step2_Vs1*input$Mod8Step2_Vs2),3),
                       round(input$Mod8Step2_CorS1S12 * sqrt(input$Mod8Step2_Vs1*input$Mod8Step2_Vs12),3),
                       round(input$Mod8Step2_CorS2S12 * sqrt(input$Mod8Step2_Vs2*input$Mod8Step2_Vs12),3),
                       input$Mod8Step2_Ve
            ),

            "Estimated"      = c("Estimated : Incomplete",
                                 "",
                                 paste("$",NOT$mean,"'_{0}$ =", ifelse(!is.null(data), paste(data$B0_1,"\U00b1", data$se.B0_1),"...")),
                                 paste("$",NOT$mean,"'_{1}$ =", ifelse(!is.null(data), paste(data$B1_1,"\U00b1", data$se.B1_1),"...")),
                                 paste("$",NOT$mean,"'_{2}$ =", ifelse(!is.null(data), paste(data$B2_1,"\U00b1", data$se.B2_1),"...")),
                                 paste("$",NOT$mean,"'_{12}$ =",ifelse(!is.null(data), paste(data$B12_1,"\U00b1",data$se.B12_1),"...")),
                                 "",
                                 paste("$V'_{",NOT$devI,"}$ =", ifelse(!is.null(data), data$Vi_1,"...")),
                                 paste("$V'_{",EQ3$dev1,"}$ =", ifelse(!is.null(data), data$Vs1_1,"...")),
                                 paste("$V'_{",EQ3$dev2,"}$ =", ifelse(!is.null(data), data$Vs2_1,"...")),
                                 "-",
                                 paste("$COV'_{",NOT$devI, EQ3$dev1,"}$ =", ifelse(!is.null(data), data$COVis1_1,"...")),
                                 paste("$COV'_{",NOT$devI, EQ3$dev2,"}$ =", ifelse(!is.null(data), data$COVis2_1,"...")),
                                 "-",
                                 paste("$COV'_{",EQ3$dev1, EQ3$dev2,"}$ =", ifelse(!is.null(data), data$COVs1s2_1,"...")),
                                 "-",
                                 "-",
                                 paste("Residual variance $V'_{",NOT$residualUpper,"}$ =", ifelse(!is.null(data), data$Vr_1,"..."))
            ),

            "Estimated_full" = c("Estimated : Full",
                                 "",
                                 paste("$",NOT$mean,"'_{0}$ =", ifelse(!is.null(data), paste(data$B0_2,"\U00b1", data$se.B0_2),"...")),
                                 paste("$",NOT$mean,"'_{1}$ =", ifelse(!is.null(data), paste(data$B1_2,"\U00b1", data$se.B1_2),"...")),
                                 paste("$",NOT$mean,"'_{2}$ =", ifelse(!is.null(data), paste(data$B2_2,"\U00b1", data$se.B2_2),"...")),
                                 paste("$",NOT$mean,"'_{12}$ =",ifelse(!is.null(data), paste(data$B12_2,"\U00b1",data$se.B12_2),"...")),
                                 "",
                                 paste("$V'_{",NOT$devI,"}$ =", ifelse(!is.null(data), data$Vi_2,"...")),
                                 paste("$V'_{",EQ3$dev1,"}$ =", ifelse(!is.null(data), data$Vs1_2,"...")),
                                 paste("$V'_{",EQ3$dev2,"}$ =", ifelse(!is.null(data), data$Vs2_2,"...")),
                                 paste("$V'_{",EQ3$dev12,"}$ =", ifelse(!is.null(data), data$Vs12_2,"...")),
                                 paste("$COV'_{",NOT$devI, EQ3$dev1,"}$ =", ifelse(!is.null(data), data$COVis1_2,"...")),
                                 paste("$COV'_{",NOT$devI, EQ3$dev2,"}$ =", ifelse(!is.null(data), data$COVis2_2,"...")),
                                 paste("$COV'_{",NOT$devI, EQ3$dev12,"}$ =", ifelse(!is.null(data), data$COVis12_2,"...")),
                                 paste("$COV'_{",EQ3$dev1, EQ3$dev2,"}$ =", ifelse(!is.null(data), data$COVs1s2_2,"...")),
                                 paste("$COV'_{",EQ3$dev1, EQ3$dev12,"}$ =", ifelse(!is.null(data), data$COVs1s12_2,"...")),
                                 paste("$COV'_{",EQ3$dev2, EQ3$dev12,"}$ =", ifelse(!is.null(data), data$COVs2s12_2,"...")),
                                 paste("Residual variance $V'_{",NOT$residualUpper,"}$ =", ifelse(!is.null(data), data$Vr_2,"..."))
            )
        )

        getTable(myTable, header = TRUE)
    }),
    
    # Display 3D figure
    output$Mod8Step2_3D <- renderPlotly({
        
        data <- Mod8Step2_output()
        
        isolate({
            
            if (!is.null(data)) {
                
                datas <- as.data.table(data$sampled_data)
                lmr   <- data$LMR2
                
                # population mean surface
                X_seq <- seq(from = min(datas[ , c("X1", "X2")]), to = max(datas[ , c("X1", "X2")]), length.out = 10)
                
                predictors      <- cbind("intecept" = 1, expand.grid("X1" = X_seq, "X2" = X_seq))
                predictors$X1X2 <- predictors$X1 * predictors$X2
                
                Phenotype_mean <- as.matrix(predictors) %*% as.vector(input$Mod8Step2_B)
                Phenotype_mean <- t(matrix(Phenotype_mean, nrow = length(X_seq), ncol = length(X_seq)))
                
                # individual surfaces
                datas     <- datas[Individual %in% sample(unique(Individual),3)]
                
                Ind_data <- lapply(unique(datas$Individual), function(id){
                    
                    dt <- copy(datas[Individual == id])
                    
                    X1_seq <- seq(min(dt$X1), max(dt$X2), length.out = 10)
                    X2_seq <- seq(min(dt$X2), max(dt$X2), length.out = 10)
                    
                    X     <- cbind("intecept" = 1,
                                   expand.grid("X1" = X1_seq, 
                                               "X2" = X2_seq))
                    X$X1X2 <- X$X1 * X$X2
                    
                    blup <- as.numeric(lme4::ranef(lmr)$Individual[id, ])
                    
                    Phenotype <- as.matrix(X) %*% (as.vector(input$Mod8Step2_B) + blup)
                    Phenotype <- t(matrix(Phenotype, nrow = length(X1_seq), ncol = length(X2_seq)))
                    
                    return(list("X1_seq"    = X1_seq,
                                "X2_seq"    = X2_seq, 
                                "Phenotype" = Phenotype))
                    
                })
                
                plotly::plot_ly(hoverinfo = "none")  %>%
                    plotly::add_surface(x = Ind_data[[1]]$X1_seq, y = Ind_data[[1]]$X2_seq, z = Ind_data[[1]]$Phenotype,
                                        opacity = 0.7, colorscale = list(c(0, 1), c("yellow", "yellow"))) %>%
                    plotly::add_surface(x = Ind_data[[2]]$X1_seq, y = Ind_data[[2]]$X2_seq, z = Ind_data[[2]]$Phenotype,
                                        opacity = 0.7, colorscale = list(c(0, 1), c("blue", "blue"))) %>%
                    plotly::add_surface(x = Ind_data[[3]]$X1_seq, y = Ind_data[[3]]$X2_seq, z = Ind_data[[3]]$Phenotype,
                                        opacity = 0.7, colorscale = list(c(0, 1), c("green", "green"))) %>%
                    
                    plotly::add_surface(x = X_seq, y = X_seq, z = Phenotype_mean, opacity = 0.7,
                                        colorscale = list(c(0, 1), c("black", "black"))) %>%
                    plotly::layout(showlegend = FALSE) %>%
                    plotly::hide_colorbar() %>%
                    plotly::layout(scene = list(xaxis=list(title = "X1"),
                                                yaxis=list(title = "X2"),  
                                                zaxis=list(title = "Phenotype")))
                
            }else{defaultPlot()}
            
        })
    })

) # End return

Try the squid package in your browser

Any scripts or data that you put into this service are public.

squid documentation built on Jan. 22, 2022, 1:06 a.m.