How to use the sprtt package"

knitr::opts_chunk$set(
  collapse = TRUE,
  comment = "#>"
)

Note

Overview

The sprtt package is a sequential probability ratio tests toolbox (sprtt). This vignette demonstrates the usage of the package using the seq_ttest() function and all arguments with short examples. The theoretical background of the sequential t-test will not be covered by this vignette.

The seq_ttest() function has arguments to specify the requested sequential t-test. The table below shows all possible combinations which can be performed with the package.

| | Two-sample test | One-sample test | |----------------------------|-----------------|-----------------| | Two-sided | x | x | | One-sided | x | x | | Paired (repeated measures) | x | |

Other recommended vignettes cover:

Installation

Prior to using the sprtt package it must be installed and loaded. The latest release version of the package can either be installed from CRAN or in the latest development version from GitHub. More information for the installation can be found here.

# load the package
library(sprtt)

What does the package contain?

The sprtt package contains:

How do I use the seq_ttest() function?

The seq_ttest() function works similarly to the t.test() function from the stats package if one is familiar with that already.

Sequential t-tests require some specification from the user:

However, in some cases, it is not necessary to specify all arguments because some of them have default values. If these values are the ones required, they can be skipped.

| Argument | Default value | Input option | |-------------|:--------------|:-------------------------------| | x | - | formula or numeric input | | y | NULL | numeric vector | | data | NULL | data frame | | mu | 0 | numeric value | | d | - | numeric value | | alpha | 0.05 | numeric value between 0 and 1 | | power | 0.95 | numeric value between 0 and 1 | | alternative | "two.sided" | "two.sided", "greater", "less" | | paired | FALSE | TRUE or FALSE | | na.rm | TRUE | TRUE or FALSE | | verbose | TRUE | TRUE or FALSE |

There are two different ways how the data can be transferred into the function. The x argument takes either formula or numeric input. Which input option is recommended depends on the structure of the data.

x argument: formula input

The formula input is used when both groups are merged in one variable and there is a second variable that indicates group membership. This input option uses the x argument and the data argument if the variables are stored in a data frame.

Two-sample test

# show data frame --------------------------------------------------------------
head(df_income)

# sequential t-test: data argument ---------------------------------------------
seq_ttest(monthly_income ~ sex,     # x argument 
          data = df_income,
          d = 0.2)

One-sample test

To perform a one-sample test, the right side of the formula has to be 1. The mu argument is also required, which specifies the mean value that one wants to test against.

# show data frame --------------------------------------------------------------
head(df_income)

# sequential t-test: data argument ---------------------------------------------
seq_ttest(monthly_income ~ 1,     # x argument 
          mu = 3000,
          d = 0.5,
          data = df_income)

x argument: numeric input

The numeric input is used when each group has its own variable. The variables can either be put in the global environment directly or be stored in a data frame.

Two-sample test

If one wants to perform a two-sample test, the y argument is required in addition to x. If the data are stored in a data frame, the $ operator is essential to get access to the variables.

# show data frame --------------------------------------------------------------
head(df_cancer)

# sequential t-test: $ operator ------------------------------------------------
seq_ttest(df_cancer$treatment_group, # x argument
          df_cancer$control_group,   # y argument
          d = 0.3,                   
          verbose = FALSE)           


# sequential t-test: global variables ------------------------------------------
treatment <- df_cancer$treatment_group
control <- df_cancer$control_group

seq_ttest(treatment,
          control,
          d = 0.3,
          verbose = FALSE)

One-sample test

If one wants to perform a one-sample test there is only one group and therefore only one variable. If the data are in a data frame, the $ operator is essential to get access to the variables. The mu argument is additionally required, which specifies the mean which one wants to test against.

# show data frame --------------------------------------------------------------
head(df_cancer)

# sequential t-test: $ operator ------------------------------------------------
seq_ttest(df_cancer$treatment_group,     # x argument
          mu = 3.5,            
          d = 0.2,
          verbose = FALSE)


# sequential t-test: global variables ------------------------------------------
treatment <- df_cancer$treatment_group

seq_ttest(treatment,     # x argument
          mu = 3.5, 
          data = df,
          d = 0.2,                  
          verbose = FALSE)

Further arguments

Paired

The paired argument states if the data are paired. To perform a paired sequential t-test, paired has to be set to TRUE.

# show data frame --------------------------------------------------------------
head(df_stress)

# sequential t-test: $ operator ------------------------------------------------
seq_ttest(df_stress$baseline_stress, # x argument
          df_stress$one_year_stress, # y argument
          d = 0.3,
          paired = TRUE,
          data = df_stress)  

Alternative

The alternative argument states in which way the test is to be performed:

# show data frame --------------------------------------------------------------
head(df_income)

# sequential t-test: data argument ---------------------------------------------
seq_ttest(monthly_income ~ 1,     # x argument 
          mu = 1000,
          d = 0.3,
          alternative = "two.sided",
          data = df_income)

Na.rm

The na.rm argument defines the handling of missing values. If set to TRUE (default value), it will remove all missing values automatically. If this behavior is not wanted, the na.rm argument has to be set to FALSE. If missing values are discovered, an error is triggered.

Verbose

The verbose argument defines the extent of the output shown in the console. If set to TRUE (default value), the output will be elaborate, if set to FALSE the output will be short.

# sequential t-test: verbose FALSE ---------------------------------------------
seq_ttest(df_cancer$treatment_group, # x argument
          df_cancer$control_group,   # y argument
          d = 0.3,
          verbose = FALSE)

# sequential t-test: verbose TRUE ----------------------------------------------
seq_ttest(df_cancer$treatment_group, # x argument
          df_cancer$control_group,   # y argument
          d = 0.3,
          verbose = TRUE) 

How do I get access to the results?

The simplest way to get access to the results is to run the seq_ttest() function. It will print the results automatically in the console. The verbose argument specifies how much information is wished to be shown.

However, the recommended way is to save the results in an object (e.g "results"). Doing so allows running further calculations with it afterward. It is important to keep in mind that the output object will be an S4 class. Therefore the access operator is the @ sign or the [] brackets.

# save the resuts in a object 
results <- seq_ttest(df_cancer$treatment_group,
                     df_cancer$control_group,  
                     d = 0.3)
# access the object with the @ operator 
results@decision

# access the object with the [] brackets
results["decision"]


Try the sprtt package in your browser

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

sprtt documentation built on July 9, 2023, 6:14 p.m.