Title: | Cell Type Deconvolution from Gene Expressions |
---|---|
Description: | Deconvolving cell types from high-throughput gene profiling data. For more information on dtangle see Hunt et al. (2019) <doi:10.1093/bioinformatics/bty926>. |
Authors: | Gregory Hunt [aut, cre], Johann Gagnon-Bartsch [aut] |
Maintainer: | Gregory Hunt <[email protected]> |
License: | GPL-3 |
Version: | 2.0.9 |
Built: | 2025-01-04 07:10:41 UTC |
Source: | CRAN |
Estimate the offset terms.
baseline_exprs(Y, pure_samples, markers, summary_fn = mean)
baseline_exprs(Y, pure_samples, markers, summary_fn = mean)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
markers |
Marker gene indices. (Optional) List of one-dimensional integer. Top-level list should be same length as |
summary_fn |
What summary statistic to use when aggregating expression measurements. (Optional) Function that takes a one-dimensional vector of numeric and returns a single numeric. Defaults to the mean. Other good options include the median. |
List of vectors. Each vector is estimated estimated basline in pure samples of markers for each group, resp.
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log markers = find_markers(Y=Y, pure_samples = pure_samples,data_type='microarray-gene',marker_method='ratio')$L K = length(pure_samples) n_markers = rep(20,K) mrkrs <- lapply(1:K, function(i) { markers[[i]][1:n_markers[i]] }) dtangle:::baseline_exprs(Y, pure_samples, mrkrs)
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log markers = find_markers(Y=Y, pure_samples = pure_samples,data_type='microarray-gene',marker_method='ratio')$L K = length(pure_samples) n_markers = rep(20,K) mrkrs <- lapply(1:K, function(i) { markers[[i]][1:n_markers[i]] }) dtangle:::baseline_exprs(Y, pure_samples, mrkrs)
Y
with references
and generates pure_samples
.Row-binds Y
with references
and generates pure_samples
.
combine_Y_refs(Y, references, pure_samples)
combine_Y_refs(Y, references, pure_samples)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
references |
Cell-type reference expression matrix. (Optional) Two-dimensional numeric. Must implement Each row contains expression measurements for a reference profile of a particular cell type. Columns contain measurements of reference profiles of a gene. Optionally may merge this matrix with |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
Deconvolve cell type mixing proportions from gene expression data.
dtangle(Y, references = NULL, pure_samples = NULL, n_markers = NULL, data_type = NULL, gamma = NULL, markers = NULL, marker_method = "ratio", summary_fn = mean)
dtangle(Y, references = NULL, pure_samples = NULL, n_markers = NULL, data_type = NULL, gamma = NULL, markers = NULL, marker_method = "ratio", summary_fn = mean)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
references |
Cell-type reference expression matrix. (Optional) Two-dimensional numeric. Must implement Each row contains expression measurements for a reference profile of a particular cell type. Columns contain measurements of reference profiles of a gene. Optionally may merge this matrix with |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
n_markers |
Number of marker genes. (Optional) One-dimensional numeric. How many markers genes to use for deconvolution. Can either be a single integer, vector of integers (one for each cell type), or single or vector of percentages (numeric in 0 to 1). If a single integer then all cell types use that number of markers. If a vector then the i-th element determines how many marker genes are used for the i-th cell type. If single percentage (in 0 to 1) then that percentage of markers are used for all types. If vector of percentages then that percentage used for each type, respectively. If not specified then top 10% of genes are used. |
data_type |
Type of expression measurements. (Optional) One-dimensional string. An optional string indicating the type of the expression measurements. This is used to set gamma to a pre-determined value based upon the data type. Valid values are for probe-level microarray as “microarray-probe”, gene-level microarray as “microarray-gene” or rna-seq as “rna-seq”. Alternatively can set |
gamma |
Expression adjustment term. (Optional) One-dimensional positive numeric. If provided as a single positive number then that value will be used for |
markers |
Marker gene indices. (Optional) List of one-dimensional integer. Top-level list should be same length as |
marker_method |
Method used to rank marker genes. (Optional) One-dimensional string. The method used to rank genes as markers. If not supplied defaults to “ratio”. Only used if markers are not provided to argument “markers”. Options are
|
summary_fn |
What summary statistic to use when aggregating expression measurements. (Optional) Function that takes a one-dimensional vector of numeric and returns a single numeric. Defaults to the mean. Other good options include the median. |
List.
'estimates' a matrix estimated mixing proportions. One row for each sample, one column for each cell type.
'markers' list of vectors of marker used for each cell type. Each element of list is vector of columns of Y
used as a marker for the i-th cell type.
'n_markers' vector of number of markers used for each cell type.
'gamma' value of the sensitivity parameter gamma used by dtangle.
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log n_markers = 20 dtangle(Y, pure_samples = pure_samples, n_markers=n_markers,data_type='microarray-gene',marker_method = 'ratio') n_markers = c(10,11,12) dtangle(Y, pure_samples=pure_samples, n_markers=n_markers,gamma=.8,marker_method = 'regression')
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log n_markers = 20 dtangle(Y, pure_samples = pure_samples, n_markers=n_markers,data_type='microarray-gene',marker_method = 'ratio') n_markers = c(10,11,12) dtangle(Y, pure_samples=pure_samples, n_markers=n_markers,gamma=.8,marker_method = 'regression')
Deconvolve cell type mixing proportions from gene expression data.
dtangle2(Y, references = NULL, pure_samples = NULL, n_markers = NULL, markers = NULL, marker_method = "ratio", weights = NULL, sto = TRUE, inv_scale = function(x) 2^x, fit_scale = log, loss_smry = "var", dtangle_init = TRUE, seed = NULL, verbose = FALSE, optim_opts = NULL)
dtangle2(Y, references = NULL, pure_samples = NULL, n_markers = NULL, markers = NULL, marker_method = "ratio", weights = NULL, sto = TRUE, inv_scale = function(x) 2^x, fit_scale = log, loss_smry = "var", dtangle_init = TRUE, seed = NULL, verbose = FALSE, optim_opts = NULL)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
references |
Cell-type reference expression matrix. (Optional) Two-dimensional numeric. Must implement Each row contains expression measurements for a reference profile of a particular cell type. Columns contain measurements of reference profiles of a gene. Optionally may merge this matrix with |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
n_markers |
Number of marker genes. (Optional) One-dimensional numeric. How many markers genes to use for deconvolution. Can either be a single integer, vector of integers (one for each cell type), or single or vector of percentages (numeric in 0 to 1). If a single integer then all cell types use that number of markers. If a vector then the i-th element determines how many marker genes are used for the i-th cell type. If single percentage (in 0 to 1) then that percentage of markers are used for all types. If vector of percentages then that percentage used for each type, respectively. If not specified then top 10% of genes are used. |
markers |
Marker gene indices. (Optional) List of one-dimensional integer. Top-level list should be same length as |
marker_method |
Method used to rank marker genes. (Optional) One-dimensional string. The method used to rank genes as markers. If not supplied defaults to “ratio”. Only used if markers are not provided to argument “markers”. Options are
|
weights |
Weights for the genes. (Optional) String or one-dimensional numeric vector. Weights for the genes in the optimization. If NULL (default) then does not weight genes differently. If 'variance' then inversely weights with the variance of the references. This only works if there is more than one reference per cell type so that the variance can be estimated. If a numeric then this uses whatever is specified as weights. They must be non-negative. |
sto |
Sum-to-one constraint. (Optional) Boolean. Re-normalize the estimates so that the cell-type proportions sum to one. |
inv_scale |
Inverse scale transformation. (Optional) Function. Defaults to 2^x. This is equivalent to assuming that the data has been log2-transformed. If another transformation has been applied to the data then this function should be used to specify the inverse of that transformation needed to put gene expressions on the linear scale. |
fit_scale |
Transformation to used as part of optimization. (Optional) Function. Function to apply to gene expressions as part of optimization. Defaults to log. |
loss_smry |
Loss summary function minimized to find estimated proportions. (Optional) String. Either 'var' (default) to minimze the (weighted) variance of the residuals or 'L2' to minimize the (weighted) sums of squares of the residuals. |
dtangle_init |
Optimization initialization. (Optional) Boolean. Boolean controlling if dtangle2 optimization should be initialized using dtangle1 estimates. |
seed |
(Optional) Integer. Value at which to seed the random seed before estimating. Optimization initialization might change if this value is not specified. |
verbose |
(Optional) Boolean. Controls if optimization output is printed or not. |
optim_opts |
(Optional) List. Optimization options passed to DEoptimR controlling optimization. Options that may be set are
|
List.
'estimates' a matrix estimated mixing proportions. One row for each sample, one column for each cell type.
'markers' list of vectors of marker used for each cell type. Each element of list is vector of columns of Y
used as a marker for the i-th cell type.
'n_markers' vector of number of markers used for each cell type.
'weights' the weights used as part of the optimization.
'diag' diagnostic values for the estimated proportions.
resids_hat
,loss_hat
, and p_hat
are the residuals, loss, and estimates for the proportions returned by dtangle2. Similarly, resids_opt
,loss_opt
and p_opt
are these values for the optimized value not re-scaled to enforce the STO constraint.
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log n_markers = 20 dtangle2(Y, pure_samples = pure_samples, n_markers=n_markers)
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log n_markers = 20 dtangle2(Y, pure_samples = pure_samples, n_markers=n_markers)
Estimate the gene type proportions.
est_phats(Y, markers, baseline_ests, gamma, summary_fn = mean, inv_scale = function(x) 2^x)
est_phats(Y, markers, baseline_ests, gamma, summary_fn = mean, inv_scale = function(x) 2^x)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
markers |
Marker gene indices. (Optional) List of one-dimensional integer. Top-level list should be same length as |
baseline_ests |
List of vectors (same structure as markers). One list entry for each cell type. Each list element is a vector of estimated offset for each marker of the respective type (output from |
gamma |
Expression adjustment term. (Optional) One-dimensional positive numeric. If provided as a single positive number then that value will be used for |
summary_fn |
What summary statistic to use when aggregating expression measurements. (Optional) Function that takes a one-dimensional vector of numeric and returns a single numeric. Defaults to the mean. Other good options include the median. |
inv_scale |
Inverse scale transformation. Default to exponential as dtangle assumes data has been logarithmically transformed. |
Estimated matrix of mixing proportions.
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log markers = find_markers(Y=Y,pure_samples = pure_samples, data_type='microarray-gene',marker_method='ratio')$L K = length(pure_samples) n_markers = rep(20,K) mrkrs <- lapply(1:K, function(i) { markers[[i]][1:n_markers[i]] }) baseline = dtangle:::baseline_exprs(Y, pure_samples, mrkrs) phats <- dtangle:::est_phats(Y, mrkrs, baseline, gamma=.8)
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log markers = find_markers(Y=Y,pure_samples = pure_samples, data_type='microarray-gene',marker_method='ratio')$L K = length(pure_samples) n_markers = rep(20,K) mrkrs <- lapply(1:K, function(i) { markers[[i]][1:n_markers[i]] }) baseline = dtangle:::baseline_exprs(Y, pure_samples, mrkrs) phats <- dtangle:::est_phats(Y, mrkrs, baseline, gamma=.8)
Find marker genes for each cell type.
find_markers(Y, references = NULL, pure_samples = NULL, data_type = NULL, gamma = NULL, marker_method = "ratio")
find_markers(Y, references = NULL, pure_samples = NULL, data_type = NULL, gamma = NULL, marker_method = "ratio")
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
references |
Cell-type reference expression matrix. (Optional) Two-dimensional numeric. Must implement Each row contains expression measurements for a reference profile of a particular cell type. Columns contain measurements of reference profiles of a gene. Optionally may merge this matrix with |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
data_type |
Type of expression measurements. (Optional) One-dimensional string. An optional string indicating the type of the expression measurements. This is used to set gamma to a pre-determined value based upon the data type. Valid values are for probe-level microarray as “microarray-probe”, gene-level microarray as “microarray-gene” or rna-seq as “rna-seq”. Alternatively can set |
gamma |
Expression adjustment term. (Optional) One-dimensional positive numeric. If provided as a single positive number then that value will be used for |
marker_method |
Method used to rank marker genes. (Optional) One-dimensional string. The method used to rank genes as markers. If not supplied defaults to “ratio”. Only used if markers are not provided to argument “markers”. Options are
|
List with four elements. “L” is respective ranked markers for each cell type and “V” is the corresponding values of the ranking method (higher are better) used to determine markers and sort them, “M” is the matrix used to create the other two arguments after sorting and subsetting, and “sM” is a sorted version of M.
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log find_markers(Y=Y,pure_samples=pure_samples, data_type='microarray-gene',marker_method='ratio')
truth = shen_orr_ex$annotation$mixture pure_samples <- lapply(1:3, function(i) { which(truth[, i] == 1) }) Y <- shen_orr_ex$data$log find_markers(Y=Y,pure_samples=pure_samples, data_type='microarray-gene',marker_method='ratio')
Determine gamma value by data type.
get_gamma(data_type)
get_gamma(data_type)
data_type |
Type of expression measurements. (Optional) One-dimensional string. An optional string indicating the type of the expression measurements. This is used to set gamma to a pre-determined value based upon the data type. Valid values are for probe-level microarray as “microarray-probe”, gene-level microarray as “microarray-gene” or rna-seq as “rna-seq”. Alternatively can set |
n_markers
, marker list mrkrs
, and gamma
.Determines number of markers n_markers
, marker list mrkrs
, and gamma
.
process_markers(Y, pure_samples, n_markers, data_type, gamma, markers, marker_method)
process_markers(Y, pure_samples, n_markers, data_type, gamma, markers, marker_method)
Y |
Expression matrix. (Required) Two-dimensional numeric. Must implement Each row contains expression measurements for a particular sample. Each columm contains the measurements of the same gene over all individuals. Can either contain just the mixture samples to be deconvolved or both the mixture samples and the reference samples. See |
pure_samples |
The pure sample indicies. (Optional) List of one-dimensional integer. Must implement The i-th element of the top-level list is a vector of indicies (rows of |
n_markers |
Number of marker genes. (Optional) One-dimensional numeric. How many markers genes to use for deconvolution. Can either be a single integer, vector of integers (one for each cell type), or single or vector of percentages (numeric in 0 to 1). If a single integer then all cell types use that number of markers. If a vector then the i-th element determines how many marker genes are used for the i-th cell type. If single percentage (in 0 to 1) then that percentage of markers are used for all types. If vector of percentages then that percentage used for each type, respectively. If not specified then top 10% of genes are used. |
data_type |
Type of expression measurements. (Optional) One-dimensional string. An optional string indicating the type of the expression measurements. This is used to set gamma to a pre-determined value based upon the data type. Valid values are for probe-level microarray as “microarray-probe”, gene-level microarray as “microarray-gene” or rna-seq as “rna-seq”. Alternatively can set |
gamma |
Expression adjustment term. (Optional) One-dimensional positive numeric. If provided as a single positive number then that value will be used for |
markers |
Marker gene indices. (Optional) List of one-dimensional integer. Top-level list should be same length as |
marker_method |
Method used to rank marker genes. (Optional) One-dimensional string. The method used to rank genes as markers. If not supplied defaults to “ratio”. Only used if markers are not provided to argument “markers”. Options are
|
A subset of data from Shen-Orr et al. Triplicate samples of liver, brain and lung tissue were extracted from rats. RNA was extracted and mixed in known quantities. Gene expressions were measured using the Affymetrix Rat Genome 230 2.0 Array. True mixture proportions were known from experimental design. Gene expression measurements were summarized by RMA at the log2 level. Cell types reported are Liver, Brain and Lung. Data set introduced in 'Cell type-specific gene expression differences in complex tissues' by Shen-Orr et al.
shen_orr_ex
shen_orr_ex
List of lists.
list of data sets
annotation for the data set
https://www.ncbi.nlm.nih.gov/geo/query/acc.cgi?acc=GSE19830, http://www.nature.com/nmeth/journal/v7/n4/abs/nmeth.1439.html