1#ifndef SCRAN_MODEL_GENE_VARIANCES_H
2#define SCRAN_MODEL_GENE_VARIANCES_H
5#include "tatami_stats/tatami_stats.hpp"
64template<
typename Stat_>
91template<
typename Stat_>
149template<
typename Stat_>
155 std::vector<ModelGeneVariancesBuffers<Stat_> >
per_block;
168template<
typename Stat_>
188 std::vector<ModelGeneVariancesResults<Stat_> >
per_block;
202template<
typename Value_,
typename Index_,
typename Stat_,
typename Block_>
224 tatami_stats::grouped_variances::direct(
240 auto stat = tatami_stats::variances::direct(
ptr,
NC,
false);
248template<
typename Value_,
typename Index_,
typename Stat_,
typename Block_>
275 tatami_stats::grouped_variances::direct(
293 auto stat = tatami_stats::variances::direct(
range.value,
range.number,
NC,
false);
301template<
typename Value_,
typename Index_,
typename Stat_,
typename Block_>
322 std::vector<tatami_stats::variances::RunningDense<Stat_, Value_, Index_> >
runners;
348template<
typename Value_,
typename Index_,
typename Stat_,
typename Block_>
373 std::vector<tatami_stats::variances::RunningSparse<Stat_, Value_, Index_> >
runners;
399template<
typename Value_,
typename Index_,
typename Stat_,
typename Block_>
407 if (
mat.prefer_rows()) {
422template<
typename Index_,
typename Stat_,
class Function_>
479template<
typename Value_,
typename Index_,
typename Block_,
typename Stat_>
506 std::fill_n(
current.fitted,
NR, std::numeric_limits<double>::quiet_NaN());
507 std::fill_n(
current.residuals,
NR, std::numeric_limits<double>::quiet_NaN());
558template<
typename Value_,
typename Index_,
typename Stat_>
587template<
typename Stat_ =
double,
typename Value_,
typename Index_>
618template<
typename Stat_ =
double,
typename Value_,
typename Index_,
typename Block_>
633 if (!
options.compute_average) {
Fit a mean-variance trend to log-count data.
void average_vectors_weighted(size_t n, std::vector< Stat_ * > in, const Weight_ *w, Output_ *out, bool skip_nan)
Variance modelling for single-cell expression data.
Definition choose_highly_variable_genes.hpp:14
void fit_variance_trend(size_t n, const Float_ *mean, const Float_ *variance, Float_ *fitted, Float_ *residuals, FitVarianceTrendWorkspace< Float_ > &workspace, const FitVarianceTrendOptions &options)
Definition fit_variance_trend.hpp:120
void model_gene_variances_blocked(const tatami::Matrix< Value_, Index_ > &mat, const Block_ *block, const ModelGeneVariancesBlockedBuffers< Stat_ > &buffers, const ModelGeneVariancesOptions &options)
Definition model_gene_variances.hpp:480
void model_gene_variances(const tatami::Matrix< Value_, Index_ > &mat, ModelGeneVariancesBuffers< Stat_ > buffers, const ModelGeneVariancesOptions &options)
Definition model_gene_variances.hpp:559
void choose_highly_variable_genes(size_t n, const Stat_ *statistic, Bool_ *output, const ChooseHighlyVariableGenesOptions &options)
Definition choose_highly_variable_genes.hpp:188
void parallelize(Function_ fun, Index_ tasks, int threads)
Options for fit_variance_trend().
Definition fit_variance_trend.hpp:19
Workspace for fit_variance_trend().
Definition fit_variance_trend.hpp:80
Buffers for model_gene_variances_blocked().
Definition model_gene_variances.hpp:150
ModelGeneVariancesBuffers< Stat_ > average
Definition model_gene_variances.hpp:161
std::vector< ModelGeneVariancesBuffers< Stat_ > > per_block
Definition model_gene_variances.hpp:155
Results of model_gene_variances_blocked().
Definition model_gene_variances.hpp:169
std::vector< ModelGeneVariancesResults< Stat_ > > per_block
Definition model_gene_variances.hpp:188
ModelGeneVariancesResults< Stat_ > average
Definition model_gene_variances.hpp:194
Buffers for model_gene_variances() and friends.
Definition model_gene_variances.hpp:65
Stat_ * means
Definition model_gene_variances.hpp:69
Stat_ * residuals
Definition model_gene_variances.hpp:84
Stat_ * variances
Definition model_gene_variances.hpp:74
Stat_ * fitted
Definition model_gene_variances.hpp:79
Options for model_gene_variances() and friends.
Definition model_gene_variances.hpp:24
FitVarianceTrendOptions fit_variance_trend_options
Definition model_gene_variances.hpp:28
bool compute_average
Definition model_gene_variances.hpp:47
scran_blocks::VariableWeightParameters variable_block_weight_parameters
Definition model_gene_variances.hpp:41
int num_threads
Definition model_gene_variances.hpp:53
scran_blocks::WeightPolicy block_weight_policy
Definition model_gene_variances.hpp:34
Results of model_gene_variances().
Definition model_gene_variances.hpp:92
std::vector< Stat_ > fitted
Definition model_gene_variances.hpp:137
std::vector< Stat_ > means
Definition model_gene_variances.hpp:127
std::vector< Stat_ > residuals
Definition model_gene_variances.hpp:142
std::vector< Stat_ > variances
Definition model_gene_variances.hpp:132
bool sparse_ordered_index