Title: | Fitting Shared Atoms Nested Models via Variational Bayes |
---|---|
Description: | An efficient tool for fitting the nested common and shared atoms models using variational Bayes approximate inference for fast computation. Specifically, the package implements the common atoms model (Denti et al., 2023), its finite version (D'Angelo et al., 2023), and a hybrid finite-infinite model. All models use Gaussian mixtures with a normal-inverse-gamma prior distribution on the parameters. Additional functions are provided to help analyze the results of the fitting procedure. References: Denti, Camerlenghi, Guindani, Mira (2023) <doi:10.1080/01621459.2021.1933499>, D’Angelo, Canale, Yu, Guindani (2023) <doi:10.1111/biom.13626>. |
Authors: | Francesco Denti [aut, cre, cph] , Laura D'Angelo [aut] |
Maintainer: | Francesco Denti <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.1.1 |
Built: | 2024-12-12 06:48:11 UTC |
Source: | CRAN |
This function estimates the posterior atoms and weights characterizing the discrete mixing distributions using the variational estimates obtained from one of the model implemented in SANvi.
estimate_atoms_weights_vi(output) ## S3 method for class 'vi_atoms_weights' plot(x, DC_num = NULL, lim = 2, ...) ## S3 method for class 'vi_atoms_weights' print(x, thr = 0.01, ...)
estimate_atoms_weights_vi(output) ## S3 method for class 'vi_atoms_weights' plot(x, DC_num = NULL, lim = 2, ...) ## S3 method for class 'vi_atoms_weights' print(x, thr = 0.01, ...)
output |
an object of class |
x |
an object of class |
DC_num |
an integer or a vector of integers indicating which distributional clusters to plot. |
lim |
optional value for |
... |
ignored. |
thr |
argument for the |
an object of class vi_atoms_weights
, which is matrix comprising posterior means,
variances, and a columns for each estimated DC containing the posterior weights.
variational_CAM
, variational_fiSAN
,
variational_fSAN
, extract_best
.
# Generate example data set.seed(1232) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Fitting fiSAN via variational inference est <- variational_fiSAN(y,g,verbose = FALSE) # Estimate posterior atoms and weights estimate_atoms_weights_vi(est)
# Generate example data set.seed(1232) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Fitting fiSAN via variational inference est <- variational_fiSAN(y,g,verbose = FALSE) # Estimate posterior atoms and weights estimate_atoms_weights_vi(est)
This function estimates posterior clustering assignments based on posterior variational estimates obtained from one of the model implemented in SANvi.
estimate_clustering_vi(output, ordered = TRUE) ## S3 method for class 'vi_clustering' plot( x, DC_num = NULL, type = c("ecdf", "boxplot", "scatter"), palette_brewed = FALSE, ... ) ## S3 method for class 'vi_clustering' print(x, ...)
estimate_clustering_vi(output, ordered = TRUE) ## S3 method for class 'vi_clustering' plot( x, DC_num = NULL, type = c("ecdf", "boxplot", "scatter"), palette_brewed = FALSE, ... ) ## S3 method for class 'vi_clustering' print(x, ...)
output |
an object of class |
ordered |
logical, if |
x |
an object of class |
DC_num |
an integer or a vector of integers indicating which distributional clusters to plot. |
type |
what type of plot should be drawn (only for the left-side plot). Possible types are "boxplot", "ecdf", and "scatter". |
palette_brewed |
(logical) the color palette to be used. Default is |
... |
ignored. |
a list of class clustering
containing
obs_level
: a data frame containing the data values, their group indexes, the observational and distributional clustering assignments for each observation.
dis_level
: a vector with the distributional clustering assignment for each unit.
variational_CAM
, variational_fiSAN
, variational_fSAN
, extract_best
.
# Generate example data set.seed(123) y <- c(rnorm(100),rnorm(100,-5),rnorm(100,5),rnorm(100), rnorm(100),rnorm(100,-5),rnorm(100,5),rnorm(100)) g <- rep(1:4,rep(200,4)) # Fitting fiSAN via variational inference est <- SANvi::variational_fiSAN(y,g,verbose = FALSE) # Estimate clustering assignments estimate_clustering_vi(est)
# Generate example data set.seed(123) y <- c(rnorm(100),rnorm(100,-5),rnorm(100,5),rnorm(100), rnorm(100),rnorm(100,-5),rnorm(100,5),rnorm(100)) g <- rep(1:4,rep(200,4)) # Fitting fiSAN via variational inference est <- SANvi::variational_fiSAN(y,g,verbose = FALSE) # Estimate clustering assignments estimate_clustering_vi(est)
A simple function to automatically extract the best run from a collection of fitted variational models.
extract_best(object)
extract_best(object)
object |
an object of class |
the single best run, an object of class SANvb
.
# Generate example dataset set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Estimate multiple models via variational inference est <- variational_multistart(y, g, runs=5, alpha_bar = 3, beta_bar = 3, root=1234, warmstart = FALSE) # Obtain best run extract_best(est)
# Generate example dataset set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Estimate multiple models via variational inference est <- variational_multistart(y, g, runs=5, alpha_bar = 3, beta_bar = 3, root=1234, warmstart = FALSE) # Obtain best run extract_best(est)
Plot method for objects of class SANvb
.
The function displays two graphs, meant to analyze the estimated distributional and observational clusters.
## S3 method for class 'SANvb' plot(x, ...)
## S3 method for class 'SANvb' plot(x, ...)
x |
object of class |
... |
additional graphical parameters to be passed. |
The function plots a summary of the fitted model.
print.SANvb
, variational_CAM
,
variational_fiSAN
, variational_fSAN
.
Print method for objects of class SANvb
.
## S3 method for class 'SANvb' print(x, ...)
## S3 method for class 'SANvb' print(x, ...)
x |
object of class |
... |
further arguments passed to or from other methods. |
The function prints a summary of the fitted model.
variational_CAM
is used to perform posterior inference under the common atoms model (CAM) of Denti et al. (2023) with Gaussian likelihood.
The model uses Dirichlet process mixtures (DPM) at both the observational and distributional levels.
variational_CAM(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_hyperpar = c(1,1,1,1), conc_par = NULL, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE, verbose = FALSE)
variational_CAM(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_hyperpar = c(1,1,1,1), conc_par = NULL, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE, verbose = FALSE)
y |
Numerical vector of observations (required). |
group |
Numerical vector of the same length of |
maxL , maxK
|
integers, the upper bounds for the observational and distributional clusters to fit, respectively. |
m0 , tau0 , lambda0 , gamma0
|
Hyperparameters on |
conc_hyperpar , conc_par
|
Vectors of values used for the concentration parameters of of the stick-breaking representation for the distributional and observational DPs, respectively. The following two arguments can be passed. Specifically,
|
epsilon |
the tolerance that drives the convergence criterion adopted as stopping rule |
seed |
random seed to control the initialization. |
maxSIM |
the maximum number of CAVI iteration to perform. |
warmstart |
logical, if |
verbose |
logical, if |
The common atoms mixture model is used to perform inference in nested settings, where the data are organized into groups.
The data should be continuous observations
, where each
contains the
observations from group
, for
.
The function takes as input the data as a numeric vector
y
in this concatenated form. Hence y
should be a vector of length
. The
group
parameter is a numeric vector of the same size as y
indicating the group membership for each
individual observation.
Notice that with this specification the observations in the same group need not be contiguous as long as the correspondence between the variables
y
and group
is maintained.
Model
The data are modeled using a Gaussian likelihood, where both the mean and the variance are observational-cluster-specific, i.e.,
where is the observational cluster indicator of observation
in group
.
The prior on the model parameters is a Normal-Inverse-Gamma distribution
,
i.e.,
,
(shape, rate).
Clustering
The model performs a clustering of both observations and groups.
The clustering of groups (distributional clustering) is provided by the allocation variables , with
The distribution of the probabilities is ,
where GEM is the Griffiths-Engen-McCloskey distribution of parameter
,
which characterizes the stick-breaking construction of the DP (Sethuraman, 1994).
The clustering of observations (observational clustering) is provided by the allocation variables , with
The distribution of the probabilities is for all
variational_CAM
returns a list of class SANvb
containing four objects:
model
: name of the fitted model.
params
: list containing the data and the parameters used in the simulation. Details below.
sim
: list containing the simulated values (optimized variational parameters). Details below.
time
: total computation time.
Data and parameters:
params
is a list with the following components:
y, group, Nj, J
Data, group labels, group frequencies, and number of groups.
K, L
Number of fitted distributional and observational clusters.
m0, tau0, lambda0, gamma0
Model hyperparameters.
epsilon, seed
The threshold controlling the convergence criterion and the random seed adopted to replicate the run.
hyp_alpha1,hyp_alpha2
) or alpha
Hyperparameters on (if
random);
or provided value for
(if fixed).
hyp_beta1,hyp_beta2
) or beta
Hyperparameters on (if
random);
or provided value for
(if fixed).
Simulated values:
sim
is a list with the following components:
theta_l
Matrix of size (L,4). Each row is a posterior variational estimate of the four normal-inverse gamma hyperparameters.
Elbo_val
Vector containing the values of the ELBO.
XI
A list of length J. Each element is a matrix of size (N, L)
posterior variational probability of assignment of assignment of the i-th observation in the j-th group to the l-th OC,
i.e., .
RHO
Matrix of size (J, K).
Each row is a posterior variational probability of assignment of the j-th group to the k-th DC, i.e., .
a_tilde_k,b_tilde_k
Vector of updated variational parameters of the Beta distributions governing the distributional stick-breaking process.
a_tilde_lk,b_tilde_lk
Matrix of updated variational parameters of the Beta distributions governing the observational stick-breaking process (arranged by column).
conc_hyper
If the concentration parameters are chosen to be random, these object contain a vector with the four updated hyperparameters.
alpha
,beta
If the concentration parameters are chosen to be fixed, these objects contain the passed values.
Denti, F., Camerlenghi, F., Guindani, M., and Mira, A. (2023). A Common Atoms Model for the Bayesian Nonparametric Analysis of Nested Data. Journal of the American Statistical Association, 118(541), 405-416. DOI: 10.1080/01621459.2021.1933499
Sethuraman, A.J. (1994). A Constructive Definition of Dirichlet Priors, Statistica Sinica, 4, 639–650.
set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) est <- variational_CAM(y, g, verbose = FALSE,epsilon = 1e-2)
set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) est <- variational_CAM(y, g, verbose = FALSE,epsilon = 1e-2)
variational_fiSAN
is used to perform posterior inference under the finite-infinite shared atoms nested (fiSAN) model with Gaussian likelihood.
The model uses a Dirichlet process mixture prior at the distributional level, and finite Dirichlet mixture at the observational one.
variational_fiSAN(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_hyperpar = c(1,1), conc_par = NULL, beta_bar = .005, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE, verbose = FALSE)
variational_fiSAN(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_hyperpar = c(1,1), conc_par = NULL, beta_bar = .005, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE, verbose = FALSE)
y |
Numerical vector of observations (required). |
group |
Numerical vector of the same length of |
maxL , maxK
|
integers, the upper bounds for the observational and distributional clusters to fit, respectively |
m0 , tau0 , lambda0 , gamma0
|
Hyperparameters on |
conc_hyperpar , conc_par
|
Vectors of values used the concentration parameters of of the stick-breaking representation for the distributional and observational DPs, respectively. The following two arguments can be passed. Specifically,
|
beta_bar |
the hyperparameter of the symmetric observational Dirichlet distribution. |
epsilon |
the tolerance that drives the convergence criterion adopted as stopping rule |
seed |
random seed to control the initialization. |
maxSIM |
the maximum number of CAVI iteration to perform. |
warmstart |
logical, if |
verbose |
logical, if |
Data structure
The finite-infinite common atoms mixture model is used to perform inference in nested settings, where the data are organized into groups.
The data should be continuous observations
, where each
contains the
observations from group
, for
.
The function takes as input the data as a numeric vector
y
in this concatenated form. Hence y
should be a vector of length
. The
group
parameter is a numeric vector of the same size as y
indicating the group membership for each
individual observation.
Notice that with this specification the observations in the same group need not be contiguous as long as the correspondence between the variables
y
and group
is maintained.
Model
The data are modeled using a Gaussian likelihood, where both the mean and the variance are observational-cluster-specific, i.e.,
where is the observational cluster indicator of observation
in group
.
The prior on the model parameters is a Normal-Inverse-Gamma distribution
,
i.e.,
,
(shape, rate).
Clustering
The model performs a clustering of both observations and groups.
The clustering of groups (distributional clustering) is provided by the allocation variables , with
The distribution of the probabilities is ,
where GEM is the Griffiths-Engen-McCloskey distribution of parameter
,
which characterizes the stick-breaking construction of the DP (Sethuraman, 1994).
The clustering of observations (observational clustering) is provided by the allocation variables , with
The distribution of the probabilities is for all
.
Here, the dimension
is fixed.
variational_fiSAN
returns a list of class SANvb
containing four objects:
model
: name of the fitted model.
params
: list containing the data and the parameters used in the simulation. Details below.
sim
: list containing the simulated values (optimized variational parameters). Details below.
time
: total computation time.
Data and parameters:
params
is a list with the following components:
y, group, Nj, J
Data, group labels, group frequencies, and number of groups.
K, L
Number of fitted distributional and observational clusters.
m0, tau0, lambda0, gamma0
Model hyperparameters.
epsilon, seed
The threshold controlling the convergence criterion and the random seed adopted to replicate the run.
hyp_alpha1,hyp_alpha2
) or alpha
Hyperparameters on (if
random);
or provided value for
(if fixed).
beta_bar
the hyperparameter governing all the finite Dirichlet distributions at the observational level.
Simulated values:
sim
is a list with the following components:
theta_l
Matrix of size (L,4). Each row is a posterior variational estimate of the four normal-inverse gamma hyperparameters.
Elbo_val
Vector containing the values of the ELBO.
XI
A list of length J. Each element is a matrix of size (N, L)
posterior variational probability of assignment of assignment of the i-th observation in the j-th group to the l-th OC,
i.e., .
RHO
Matrix of size (J, K).
Each row is a posterior variational probability of assignment of the j-th group to the k-th DC, i.e., .
a_tilde_k,b_tilde_k
Vector of updated variational parameters of the Beta distributions governing the distributional stick-breaking process.
beta_bar_lk
Matrix of updated variational parameters of the Dirichlet distributions governing the observational clustering (arranged by column).
conc_hyper
If the concentration parameters is chosen to be random, these object contain a vector with the two updated hyperparameters.
alpha
If the concentration parameters is chosen to be fixed, this object contains the passed values.
set.seed(1234) y <- c( rnorm(100) ,rnorm(100,5)) g <- rep( 1:2, rep(100,2)) est <- variational_fiSAN( y, g, verbose = FALSE,epsilon = 1e-2)
set.seed(1234) y <- c( rnorm(100) ,rnorm(100,5)) g <- rep( 1:2, rep(100,2)) est <- variational_fiSAN( y, g, verbose = FALSE,epsilon = 1e-2)
variational_fSAN
is used to perform posterior inference under the finite shared atoms nested (fSAN) model with Gaussian likelihood (originally proposed in D'Angelo et al., 2023).
The model uses finite Dirichlet mixtures for both the distributional and observational levels of the model.
variational_fSAN(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, alpha_bar = .005, beta_bar = .005, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE,verbose = FALSE)
variational_fSAN(y, group, maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, alpha_bar = .005, beta_bar = .005, epsilon = 1e-6, seed = NULL, maxSIM = 1e5, warmstart = TRUE,verbose = FALSE)
y |
Numerical vector of observations (required). |
group |
Numerical vector of the same length of |
maxL , maxK
|
integers, the upper bounds for the observational and distributional clusters to fit, respectively |
m0 , tau0 , lambda0 , gamma0
|
Hyperparameters on |
alpha_bar |
the hyperparameter of the symmetric distributional Dirichlet distribution. |
beta_bar |
the hyperparameter of the symmetric observational Dirichlet distribution. |
epsilon |
the tolerance that drives the convergence criterion adopted as stopping rule |
seed |
random seed to control the initialization. |
maxSIM |
the maximum number of CAVI iteration to perform. |
warmstart |
logical, if |
verbose |
logical, if |
Data structure
The finite common atoms mixture model is used to perform inference in nested settings, where the data are organized into groups.
The data should be continuous observations
, where each
contains the
observations from group
, for
.
The function takes as input the data as a numeric vector
y
in this concatenated form. Hence y
should be a vector of length
. The
group
parameter is a numeric vector of the same size as y
indicating the group membership for each
individual observation.
Notice that with this specification the observations in the same group need not be contiguous as long as the correspondence between the variables
y
and group
is maintained.
Model
The data are modeled using a Gaussian likelihood, where both the mean and the variance are observational-cluster-specific, i.e.,
where is the observational cluster indicator of observation
in group
.
The prior on the model parameters is a Normal-Inverse-Gamma distribution
,
i.e.,
,
(shape, rate).
Clustering
The model performs a clustering of both observations and groups.
The clustering of groups (distributional clustering) is provided by the allocation variables , with
The distribution of the probabilities is .
Here, the dimension
is fixed.
The clustering of observations (observational clustering) is provided by the allocation variables , with
The distribution of the probabilities is for all
.
Here, the dimension
is fixed.
variational_fSAN
returns a list of class SANvb
containing four objects:
model
: name of the fitted model.
params
: list containing the data and the parameters used in the simulation. Details below.
sim
: list containing the simulated values (optimized variational parameters). Details below.
time
: total computation time.
Data and parameters:
params
is a list with the following components:
y, group, Nj, J
Data, group labels, group frequencies, and number of groups.
K, L
Number of fitted distributional and observational clusters.
m0, tau0, lambda0, gamma0
Model hyperparameters.
epsilon, seed
The threshold controlling the convergence criterion and the random seed adopted to replicate the run.
alpha_bar, beta_bar
the hyperparameters governing all the finite Dirichlet distributions at the distributional and observational level.
Simulated values:
sim
is a list with the following components:
theta_l
Matrix of size (L,4). Each row is a posterior variational estimate of the four normal-inverse gamma hyperparameters.
Elbo_val
Vector containing the values of the ELBO.
XI
A list of length J. Each element is a matrix of size (N, L)
posterior variational probability of assignment of assignment of the i-th observation in the j-th group to the l-th OC,
i.e., .
RHO
Matrix of size (J, K).
Each row is a posterior variational probability of assignment of the j-th group to the k-th DC, i.e., .
a_tilde_k,b_tilde_k
Vector of updated variational parameters of the Beta distributions governing the distributional stick-breaking process.
alpha_bar_k
Vector of updated variational parameters of the Dirichlet distributions governing the distributional clustering.
beta_bar_lk
Matrix of updated variational parameters of the Dirichlet distributions governing the observational clustering (arranged by column).
D’Angelo, L., Canale, A., Yu, Z., and Guindani, M. (2023). Bayesian nonparametric analysis for the detection of spikes in noisy calcium imaging data. Biometrics, 79(2), 1370–1382. DOI: 10.1111/biom.13626
set.seed(123) y <- c(rnorm(50),rnorm(50,5)) g <- rep(1:2,rep(50,2)) est <- variational_fSAN(y, g, verbose = FALSE, epsilon = 1e-2, maxL=15, maxK=10)
set.seed(123) y <- c(rnorm(50),rnorm(50,5)) g <- rep(1:2,rep(50,2)) est <- variational_fSAN(y, g, verbose = FALSE, epsilon = 1e-2, maxL=15, maxK=10)
variational_multistart
is the main function of the package.
It is used to estimate via variational inference the three models we present (CAM, fiSAN, fSAN) while adopting multiple random starting points to better explore the variational parameter space.
The run that provides the highest Expected Lower BOund (ELBO) is usually the one considered for inference. Note that the arguments passed to this functions are a union of the arguments
of the functions variational_CAM
, variational_fiSAN
, and variational_fSAN
.
variational_multistart(y, group, runs, cores = 1, model = c("fiSAN","CAM","fSAN"), maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_par = NULL, conc_hyperpar = c(1,1,1,1), alpha_bar = 0.05, beta_bar = 0.05, epsilon = 1e-6, root = 1234, maxSIM = 1e5, warmstart = TRUE) ## S3 method for class 'multistart' plot(x, type = c("elbo", "time"), log_scale_iter = TRUE, ...) ## S3 method for class 'multistart' print(x, ...)
variational_multistart(y, group, runs, cores = 1, model = c("fiSAN","CAM","fSAN"), maxL = 30, maxK = 20, m0 = 0, tau0 = .01, lambda0 = 3, gamma0 = 2, conc_par = NULL, conc_hyperpar = c(1,1,1,1), alpha_bar = 0.05, beta_bar = 0.05, epsilon = 1e-6, root = 1234, maxSIM = 1e5, warmstart = TRUE) ## S3 method for class 'multistart' plot(x, type = c("elbo", "time"), log_scale_iter = TRUE, ...) ## S3 method for class 'multistart' print(x, ...)
y |
vector of observations. |
group |
vector of the same length of y indicating the group membership (numeric). |
runs |
the number of multiple runs to launch. |
cores |
the number of cores to dedicate to the multiple runs. |
model |
a string specifying the model to use. It can be |
maxL , maxK
|
integers, the upper bounds for the observational and distributional clusters to fit, respectively. |
m0 , tau0 , lambda0 , gamma0
|
hyperparameters on |
conc_hyperpar , conc_par , alpha_bar , beta_bar
|
these values crucially depend on the chosen model. See |
epsilon |
the tolerance that drives the convergence criterion adopted as stopping rule. |
root |
common part of the random seeds used to control the initialization in order to provide reproducibility even in paralleled settings. |
maxSIM |
the maximum number of CAVI iteration to perform. |
warmstart |
logical, if |
x |
an object of class |
type |
a string specifying the type of plot. It can be either |
log_scale_iter |
logical. If |
... |
ignored |
For the details of the single models, see their specific documentations: variational_CAM
, variational_fiSAN
, and variational_fSAN
.
A list with all the runs performed. Each element of the list is a fitted variational model of class SANvb
.
variational_CAM
, variational_fiSAN
, variational_fSAN
, extract_best
.
# Generate example data set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Estimate multiple models via variational inference est <- variational_multistart(y, g, runs=5)
# Generate example data set.seed(123) y <- c(rnorm(100),rnorm(100,5)) g <- rep(1:2,rep(100,2)) # Estimate multiple models via variational inference est <- variational_multistart(y, g, runs=5)