Title: | Analyses of Circadian Data |
---|---|
Description: | Uses non-linear regression to statistically compare two circadian rhythms. Groups are only compared if both are rhythmic (amplitude is non-zero). Performs analyses regarding mesor, phase, and amplitude, reporting on estimates and statistical differences, for each, between groups. Details can be found in Parsons et al (2020) <doi:10.1093/bioinformatics/btz730>. |
Authors: | Rex Parsons [aut, cre] , Alexander Bender [ctb] |
Maintainer: | Rex Parsons <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.0.9000 |
Built: | 2025-01-03 03:43:23 UTC |
Source: | https://github.com/rwparsons/circacompare |
circa_single
performs an analysis on a single rhythmic dataset. It estimates the mesor, amplitude and phase of the data provided.
circa_single( x, col_time, col_outcome, period = 24, alpha_threshold = 0.05, timeout_n = 10000, return_figure = TRUE, control = list(), weights = NULL, suppress_all = FALSE )
circa_single( x, col_time, col_outcome, period = 24, alpha_threshold = 0.05, timeout_n = 10000, return_figure = TRUE, control = list(), weights = NULL, suppress_all = FALSE )
x |
data.frame. This is the data.frame which contains the rhythmic data in a tidy format. |
col_time |
The name of the column within the data.frame, x, which contains time in hours at which the data were collected. |
col_outcome |
The name of the column within the data.frame, x, which contains outcome measure of interest. |
period |
The period of the rhythm. For circadian rhythms, leave this as the default value, 24. |
alpha_threshold |
The level of alpha for which the presence of rhythmicity is considered. Default is 0.05. |
timeout_n |
The upper limit for the model fitting attempts. Default is 10,000. |
return_figure |
Whether or not to return a ggplot graph of the rhythm and cosine model. |
control |
|
weights |
An optional numeric vector of (fixed) weights. When present, the objective function is weighted least squares. |
suppress_all |
Logical. Set to |
list
df <- make_data() df <- df[df$group == "g1", ] out <- circa_single(x = df, col_time = "time", col_outcome = "measure") out # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circa_single( x = df, col_time = "time", col_outcome = "measure", weights = sw, suppress_all = TRUE ) out2
df <- make_data() df <- df[df$group == "g1", ] out <- circa_single(x = df, col_time = "time", col_outcome = "measure") out # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circa_single( x = df, col_time = "time", col_outcome = "measure", weights = sw, suppress_all = TRUE ) out2
circa_single_mixed
is similar to circa_single
but allows for some simple, user-specified random-effects on the rhythmic parameters of choice.
circa_single_mixed( x, col_time, col_outcome, col_id, randomeffects = c("k", "alpha", "phi"), period = 24, alpha_threshold = 0.05, nlme_control = list(), nlme_method = "ML", weights = NULL, suppress_all = FALSE, timeout_n = 10000, return_figure = TRUE, control = list() )
circa_single_mixed( x, col_time, col_outcome, col_id, randomeffects = c("k", "alpha", "phi"), period = 24, alpha_threshold = 0.05, nlme_control = list(), nlme_method = "ML", weights = NULL, suppress_all = FALSE, timeout_n = 10000, return_figure = TRUE, control = list() )
x |
data.frame. This is the data.frame which contains the rhythmic data in a tidy format. |
col_time |
The name of the column within the data.frame, x, which contains time in hours at which the data were collected. |
col_outcome |
The name of the column within the data.frame, x, which contains outcome measure of interest. |
col_id |
The name of the column within the data.frame, |
randomeffects |
which rhythmic parameters to allow random effects. The default is to include all rhythmic parameters. |
period |
The period of the rhythm. For circadian rhythms, leave this as the default value, |
alpha_threshold |
The level of alpha for which the presence of rhythmicity is considered. Default is to |
nlme_control |
A list of control values for the estimation algorithm to replace the default values returned by the function nlme::nlmeControl. Defaults to an empty list. |
nlme_method |
A character string. If "REML" the model is fit by maximizing the restricted log-likelihood. If "ML" the log-likelihood is maximized. Defaults to "ML". |
weights |
An optional numeric vector of (fixed) weights internally passed to |
suppress_all |
Logical. Set to |
timeout_n |
The upper limit for the model fitting attempts. Default is |
return_figure |
Whether or not to return a ggplot graph of the rhythm and cosine model. |
control |
|
list
set.seed(42) mixed_data <- function(n) { counter <- 1 for (i in 1:n) { x <- make_data(k1 = rnorm(1, 10, 2), alpha1 = 0, phi1 = 0) x$id <- counter counter <- counter + 1 if (i == 1) { res <- x } else { res <- rbind(res, x) } } return(res) } df <- mixed_data(n = 50) out <- circa_single_mixed( x = df, col_time = "time", col_outcome = "measure", col_id = "id", randomeffects = c("k") ) # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circa_single_mixed( x = df, col_time = "time", col_outcome = "measure", col_id = "id", randomeffects = c("k"), weights = sw )
set.seed(42) mixed_data <- function(n) { counter <- 1 for (i in 1:n) { x <- make_data(k1 = rnorm(1, 10, 2), alpha1 = 0, phi1 = 0) x$id <- counter counter <- counter + 1 if (i == 1) { res <- x } else { res <- rbind(res, x) } } return(res) } df <- mixed_data(n = 50) out <- circa_single_mixed( x = df, col_time = "time", col_outcome = "measure", col_id = "id", randomeffects = c("k") ) # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circa_single_mixed( x = df, col_time = "time", col_outcome = "measure", col_id = "id", randomeffects = c("k"), weights = sw )
circacompare
performs a comparison between two rhythmic groups of data. It tests for rhythmicity and then fits a nonlinear model with parametrization to estimate and statistically support differences in mesor, amplitude, and phase between groups.
circacompare( x, col_time, col_group, col_outcome, period = 24, alpha_threshold = 0.05, timeout_n = 10000, control = list(), weights = NULL, suppress_all = FALSE )
circacompare( x, col_time, col_group, col_outcome, period = 24, alpha_threshold = 0.05, timeout_n = 10000, control = list(), weights = NULL, suppress_all = FALSE )
x |
data.frame. This is the data.frame which contains the rhythmic data for two groups in a tidy format. |
col_time |
The name of the column within the data.frame, x, which contains time in hours at which the data were collected. |
col_group |
The name of the column within the data.frame, x, which contains the grouping variable. This should only have two levels. |
col_outcome |
The name of the column within the data.frame, x, which contains outcome measure of interest. |
period |
The period of the rhythm. For circadian rhythms, leave this as the default value, 24. |
alpha_threshold |
The level of alpha for which the presence of rhythmicity is considered. Default is 0.05. |
timeout_n |
The upper limit for the model fitting attempts. Default is 10,000. |
control |
|
weights |
An optional numeric vector of (fixed) weights. When present, the objective function is weighted least squares. |
suppress_all |
Logical. Set to |
list
df <- make_data(phi1 = 6) out <- circacompare( x = df, col_time = "time", col_group = "group", col_outcome = "measure" ) out # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circacompare( x = df, col_time = "time", col_group = "group", col_outcome = "measure", weights = sw ) out2
df <- make_data(phi1 = 6) out <- circacompare( x = df, col_time = "time", col_group = "group", col_outcome = "measure" ) out # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circacompare( x = df, col_time = "time", col_group = "group", col_outcome = "measure", weights = sw ) out2
circacompare_mixed
is similar to circacompare
but allows for some simple, user-specified random-effects on the rhythmic parameters of choice.
circacompare_mixed( x, col_time, col_group, col_outcome, col_id, randomeffects = c(), period = 24, alpha_threshold = 0.05, nlme_control = list(), nlme_method = "REML", weights = NULL, suppress_all = FALSE, timeout_n = 10000, control = list() )
circacompare_mixed( x, col_time, col_group, col_outcome, col_id, randomeffects = c(), period = 24, alpha_threshold = 0.05, nlme_control = list(), nlme_method = "REML", weights = NULL, suppress_all = FALSE, timeout_n = 10000, control = list() )
x |
|
col_time |
The name of the column within the data.frame, |
col_group |
The name of the column within the data.frame, |
col_outcome |
The name of the column within the data.frame, |
col_id |
The name of the column within the data.frame, |
randomeffects |
which rhythmic parameters to allow random effects. The default is to include no rhythmic parameters. |
period |
The period of the rhythm. For circadian rhythms, leave this as the default value, |
alpha_threshold |
The level of alpha for which the presence of rhythmicity is considered. Default is to |
nlme_control |
A list of control values for the estimation algorithm to replace the default values returned by the function nlme::nlmeControl. Defaults to an empty list. |
nlme_method |
A character string. If "REML" the model is fit by maximizing the restricted log-likelihood. If "ML" the log-likelihood is maximized. Defaults to "REML". |
weights |
An optional numeric vector of (fixed) weights internally passed to |
suppress_all |
Logical. Set to |
timeout_n |
The upper limit for the model fitting attempts. Default is |
control |
|
list
# Generate some data with within-id correlation for phase-shift (phi1) set.seed(99) phi1_in <- 3.15 mixed_data <- function(n) { counter <- 1 for (i in 1:n) { x <- make_data(k1 = 0, alpha1 = 0, phi1 = rnorm(1, phi1_in, 0.5), hours = 72, noise_sd = 1) x$id <- counter counter <- counter + 1 if (i == 1) { res <- x } else { res <- rbind(res, x) } } return(res) } df <- mixed_data(20) out <- circacompare_mixed( x = df, col_time = "time", col_group = "group", col_outcome = "measure", col_id = "id", control = list(grouped_params = c("phi"), random_params = c("phi1")) ) # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circacompare_mixed( x = df, col_time = "time", col_group = "group", col_outcome = "measure", col_id = "id", control = list(grouped_params = c("phi"), random_params = c("phi1")), weights = sw )
# Generate some data with within-id correlation for phase-shift (phi1) set.seed(99) phi1_in <- 3.15 mixed_data <- function(n) { counter <- 1 for (i in 1:n) { x <- make_data(k1 = 0, alpha1 = 0, phi1 = rnorm(1, phi1_in, 0.5), hours = 72, noise_sd = 1) x$id <- counter counter <- counter + 1 if (i == 1) { res <- x } else { res <- rbind(res, x) } } return(res) } df <- mixed_data(20) out <- circacompare_mixed( x = df, col_time = "time", col_group = "group", col_outcome = "measure", col_id = "id", control = list(grouped_params = c("phi"), random_params = c("phi1")) ) # with sample weights (arbitrary weights for demonstration) sw <- runif(n = nrow(df)) out2 <- circacompare_mixed( x = df, col_time = "time", col_group = "group", col_outcome = "measure", col_id = "id", control = list(grouped_params = c("phi"), random_params = c("phi1")), weights = sw )
Generate example circadian data with specified phase shift between groups
make_data( k = 0, k1 = 3, alpha = 10, alpha1 = 4, phi = 0, phi1 = 3.15, tau = 24, hours = 48, noise_sd = 0.1, seed = NULL )
make_data( k = 0, k1 = 3, alpha = 10, alpha1 = 4, phi = 0, phi1 = 3.15, tau = 24, hours = 48, noise_sd = 0.1, seed = NULL )
k |
mesor of group 1. |
k1 |
change in mesor in group 2 from group 1. |
alpha |
amplitude rhythm for group 1. |
alpha1 |
change in amplitude in group 2 from group 1 |
phi |
phase of rhythm, in radian-hours, in group 1. |
phi1 |
change in phase, in radian-hours, in group 2 from group 1 |
tau |
period of the rhythm, shared between both groups. |
hours |
the number of hours/datapoints to sample. |
noise_sd |
the standard deviation of the noise term. |
seed |
random seed for generating data. |
data.frame
data <- make_data(k1 = 3, alpha1 = 4, phi1 = 6)
data <- make_data(k1 = 3, alpha1 = 4, phi1 = 6)