inst/shiny-example/server.R

#
# This is the server logic of a Shiny web application. You can run the
# application by clicking 'Run App' above.
#
# Find out more about building applications with Shiny here:
#
#    http://shiny.rstudio.com/
#

library(shiny)
library(ggplot2)
library(stochvolTMB)

# Define server logic required to draw a histogram
shinyServer(function(input, output) {
    
    data <- reactive({
        
        param <- list(phi = input$phi,
                      sigma_h = input$sigma_h,
                      sigma_y = input$sigma_y, 
                      df = input$nu,
                      alpha = input$alpha,
                      rho = input$rho)
        
        # Simulate data 
        data_sim <- sim_sv(param = param, nobs = input$nobs, model = input$model)
        data_sim$t <- 1:input$nobs
        
        return(data_sim)
    })
    

    estimate <- reactive({
        # Estimate parameters
        estimate <- estimate_parameters(data = data()$y, model = input$model)

    })
        
    #})

    output$sim_y <- renderPlot({

        #if(is.null(values$data_sim)) return(NULL)

        ggplot(data(), aes(x = t, y = y)) +
            geom_line() +
            labs(title = "Observations",
                 xlab = "",
                 ylab = "y")
        
    })
    
    output$sim_h <- renderPlot({
        ggplot(data(), aes(x = t, y = h)) +
            geom_line() +
            labs(title = "Latent process",
                 xlab = "",
                 ylab = "h")
    })

    
    
    output$estPlot <- renderPlot({

        #if(is.null(values$estimates)) return(NULL)
        if("plot_log" %in% input$plot_settings) plot_log <- TRUE else plot_log <- FALSE
        if("include_ci" %in% input$plot_settings) include_ci <- TRUE else include_ci <- FALSE

        plot(estimate(), include_ci = include_ci, plot_log = plot_log)


    })

    output$est_vs_sim <- renderPlot({

        #$if(is.null(values$estimates)) return(NULL)
        h_est <- summary(estimate(), report = "random")
        
        data <- data()[, .(estimated = h_est$estimate, true = h, time = 1:.N)]
        data <- data.table::melt(data, id.vars = "time")
     


        ggplot(data) +
            geom_line(aes(time, value, color = variable)) +
            labs(title = "Estimated vs true latent process",
                 xlab = "",
                 ylab = "h") +
            theme(legend.position="bottom",
                  legend.title = element_blank(),
                  legend.text = element_text(size = 15))


    })

})

Try the stochvolTMB package in your browser

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

stochvolTMB documentation built on Aug. 13, 2021, 5:07 p.m.