Package: SRS 0.2.3

Lukas Beule

SRS: Scaling with Ranked Subsampling

Analysis of species count data in ecology often requires normalization to an identical sample size. Rarefying (random subsampling without replacement), which is a popular method for normalization, has been widely criticized for its poor reproducibility and potential distortion of the community structure. In the context of microbiome count data, researchers explicitly advised against the use of rarefying. An alternative to rarefying is scaling with ranked subsampling (SRS). SRS consists of two steps. In the first step, the total counts for all OTUs (operational taxonomic units) or species in each sample are divided by a scaling factor chosen in such a way that the sum of the scaled counts Cscaled equals Cmin. In the second step, the non-integer Cscaled values are converted into integers by an algorithm that we dub ranked subsampling. The Cscaled value for each OTU or species is split into the integer part Cint (Cint = floor(Cscaled)) and the fractional part Cfrac (Cfrac = Cscaled - Cints). Since the sum of Cint is smaller or equal to Cmin, additional delta C = Cmin - the sum of Cint counts have to be added to the library to reach the total count of Cmin. This is achieved as follows. OTUs are ranked in the descending order of their Cfrac values. Beginning with the OTU of the highest rank, single count per OTU is added to the normalized library until the total number of added counts reaches delta C and the sum of all counts in the normalized library equals Cmin. When the lowest Cfrag involved in picking delta C counts is shared by several OTUs, the OTUs used for adding a single count to the library are selected in the order of their Cint values. This selection minimizes the effect of normalization on the relative frequencies of OTUs. OTUs with identical Cfrag as well as Cint are sampled randomly without replacement. See Beule & Karlovsky (2020) <doi:10.7717/peerj.9593> for details.

Authors:Lukas Beule [aut, cre], Vitor Heidrich [aut], Petr Karlovsky [aut]

SRS_0.2.3.tar.gz
SRS_0.2.3.zip(r-4.5)SRS_0.2.3.zip(r-4.4)SRS_0.2.3.zip(r-4.3)
SRS_0.2.3.tgz(r-4.4-any)SRS_0.2.3.tgz(r-4.3-any)
SRS_0.2.3.tar.gz(r-4.5-noble)SRS_0.2.3.tar.gz(r-4.4-noble)
SRS_0.2.3.tgz(r-4.4-emscripten)SRS_0.2.3.tgz(r-4.3-emscripten)
SRS.pdf |SRS.html
SRS/json (API)

# Install 'SRS' in R:
install.packages('SRS', repos = c('https://lukasbeule.r-universe.dev', 'https://cloud.r-project.org'))

Peer review:

On CRAN:

This package does not link to any Github/Gitlab/R-forge repository. No issue tracker or development information is available.

3 exports 3.95 score 51 dependencies 1 dependents 31 mentions 45 scripts 405 downloads

Last updated 2 years agofrom:5020814288. Checks:OK: 7. Indexed: yes.

TargetResultDate
Doc / VignettesOKSep 03 2024
R-4.5-winOKSep 03 2024
R-4.5-linuxOKSep 03 2024
R-4.4-winOKSep 03 2024
R-4.4-macOKSep 03 2024
R-4.3-winOKSep 03 2024
R-4.3-macOKSep 03 2024

Exports:SRSSRS.shiny.appSRScurve

Dependencies:base64encbslibcachemcliclustercommonmarkcrayoncrosstalkdigestDTevaluatefastmapfontawesomefsgluehighrhtmltoolshtmlwidgetshttpuvjquerylibjsonliteknitrlaterlatticelazyevallifecyclemagrittrMASSMatrixmemoisemgcvmimenlmepermutepromisesR6rappdirsRcpprlangrmarkdownsassshinyshinybusyshinycssloaderssourcetoolstinytexveganwithrxfunxtableyaml