Back to Multiple platform build/check report for BioC 3.11
[A]BCDEFGHIJKLMNOPQRSTUVWXYZ

CHECK report for aroma.light on tokay2

This page was generated on 2020-10-17 11:56:06 -0400 (Sat, 17 Oct 2020).

TO THE DEVELOPERS/MAINTAINERS OF THE aroma.light PACKAGE: Please make sure to use the following settings in order to reproduce any error or warning you see on this page.
Package 77/1905HostnameOS / ArchINSTALLBUILDCHECKBUILD BIN
aroma.light 3.18.0
Henrik Bengtsson
Snapshot Date: 2020-10-16 14:40:19 -0400 (Fri, 16 Oct 2020)
URL: https://git.bioconductor.org/packages/aroma.light
Branch: RELEASE_3_11
Last Commit: cbe7b51
Last Changed Date: 2020-04-27 14:13:39 -0400 (Mon, 27 Apr 2020)
malbec2 Linux (Ubuntu 18.04.4 LTS) / x86_64  OK  OK  OK UNNEEDED, same version exists in internal repository
tokay2 Windows Server 2012 R2 Standard / x64  OK  OK [ WARNINGS ] OK UNNEEDED, same version exists in internal repository
machv2 macOS 10.14.6 Mojave / x86_64  OK  OK  OK  OK UNNEEDED, same version exists in internal repository

Summary

Package: aroma.light
Version: 3.18.0
Command: C:\Users\biocbuild\bbs-3.11-bioc\R\bin\R.exe CMD check --force-multiarch --install=check:aroma.light.install-out.txt --library=C:\Users\biocbuild\bbs-3.11-bioc\R\library --no-vignettes --timings aroma.light_3.18.0.tar.gz
StartedAt: 2020-10-17 01:35:00 -0400 (Sat, 17 Oct 2020)
EndedAt: 2020-10-17 01:38:06 -0400 (Sat, 17 Oct 2020)
EllapsedTime: 185.6 seconds
RetCode: 0
Status:  WARNINGS  
CheckDir: aroma.light.Rcheck
Warnings: 1

Command output

##############################################################################
##############################################################################
###
### Running command:
###
###   C:\Users\biocbuild\bbs-3.11-bioc\R\bin\R.exe CMD check --force-multiarch --install=check:aroma.light.install-out.txt --library=C:\Users\biocbuild\bbs-3.11-bioc\R\library --no-vignettes --timings aroma.light_3.18.0.tar.gz
###
##############################################################################
##############################################################################


* using log directory 'C:/Users/biocbuild/bbs-3.11-bioc/meat/aroma.light.Rcheck'
* using R version 4.0.3 (2020-10-10)
* using platform: x86_64-w64-mingw32 (64-bit)
* using session charset: ISO8859-1
* using option '--no-vignettes'
* checking for file 'aroma.light/DESCRIPTION' ... OK
* this is package 'aroma.light' version '3.18.0'
* package encoding: latin1
* checking package namespace information ... OK
* checking package dependencies ... OK
* checking if this is a source package ... OK
* checking if there is a namespace ... OK
* checking for hidden files and directories ... NOTE
Found the following hidden files and directories:
  inst/rsp/.rspPlugins
These were most likely included in error. See section 'Package
structure' in the 'Writing R Extensions' manual.
* checking for portable file names ... OK
* checking whether package 'aroma.light' can be installed ... WARNING
Found the following significant warnings:
  Rd warning: C:/Users/biocbuild/bbs-3.11-bioc/tmpdir/Rtmp6hbSdP/R.INSTALLea06d144fac/aroma.light/man/plotDensity.Rd:44: file link 'plot' in package 'graphics' does not exist and so has been treated as a topic
See 'C:/Users/biocbuild/bbs-3.11-bioc/meat/aroma.light.Rcheck/00install.out' for details.
* checking installed package size ... OK
* checking package directory ... OK
* checking DESCRIPTION meta-information ... OK
* checking top-level files ... OK
* checking for left-over files ... OK
* checking index information ... OK
* checking package subdirectories ... OK
* checking R files for non-ASCII characters ... OK
* checking R files for syntax errors ... OK
* loading checks for arch 'i386'
** checking whether the package can be loaded ... OK
** checking whether the package can be loaded with stated dependencies ... OK
** checking whether the package can be unloaded cleanly ... OK
** checking whether the namespace can be loaded with stated dependencies ... OK
** checking whether the namespace can be unloaded cleanly ... OK
* loading checks for arch 'x64'
** checking whether the package can be loaded ... OK
** checking whether the package can be loaded with stated dependencies ... OK
** checking whether the package can be unloaded cleanly ... OK
** checking whether the namespace can be loaded with stated dependencies ... OK
** checking whether the namespace can be unloaded cleanly ... OK
* checking dependencies in R code ... OK
* checking S3 generic/method consistency ... OK
* checking replacement functions ... OK
* checking foreign function calls ... OK
* checking R code for possible problems ... OK
* checking Rd files ... OK
* checking Rd metadata ... OK
* checking Rd cross-references ... OK
* checking for missing documentation entries ... OK
* checking for code/documentation mismatches ... OK
* checking Rd \usage sections ... OK
* checking Rd contents ... OK
* checking for unstated dependencies in examples ... OK
* checking examples ...
** running examples for arch 'i386' ... OK
Examples with CPU (user + system) or elapsed time > 5s
                  user system elapsed
normalizeCurveFit 8.24   0.00    8.24
normalizeAffine   7.64   0.03    7.69
** running examples for arch 'x64' ... OK
Examples with CPU (user + system) or elapsed time > 5s
                  user system elapsed
normalizeAffine   6.84   0.02    6.86
normalizeCurveFit 6.77   0.00    6.77
* checking for unstated dependencies in 'tests' ... OK
* checking tests ...
** running tests for arch 'i386' ...
  Running 'backtransformAffine.matrix.R'
  Running 'backtransformPrincipalCurve.matrix.R'
  Running 'callNaiveGenotypes.R'
  Running 'distanceBetweenLines.R'
  Running 'findPeaksAndValleys.R'
  Running 'fitPrincipalCurve.matrix.R'
  Running 'fitXYCurve.matrix.R'
  Running 'iwpca.matrix.R'
  Running 'likelihood.smooth.spline.R'
  Running 'medianPolish.matrix.R'
  Running 'normalizeAffine.matrix.R'
  Running 'normalizeAverage.list.R'
  Running 'normalizeAverage.matrix.R'
  Running 'normalizeCurveFit.matrix.R'
  Running 'normalizeDifferencesToAverage.R'
  Running 'normalizeFragmentLength-ex1.R'
  Running 'normalizeFragmentLength-ex2.R'
  Running 'normalizeQuantileRank.list.R'
  Running 'normalizeQuantileRank.matrix.R'
  Running 'normalizeQuantileSpline.matrix.R'
  Running 'normalizeTumorBoost,flavors.R'
  Running 'normalizeTumorBoost.R'
  Running 'robustSmoothSpline.R'
  Running 'rowAverages.matrix.R'
  Running 'sampleCorrelations.matrix.R'
  Running 'sampleTuples.R'
  Running 'wpca.matrix.R'
  Running 'wpca2.matrix.R'
 OK
** running tests for arch 'x64' ...
  Running 'backtransformAffine.matrix.R'
  Running 'backtransformPrincipalCurve.matrix.R'
  Running 'callNaiveGenotypes.R'
  Running 'distanceBetweenLines.R'
  Running 'findPeaksAndValleys.R'
  Running 'fitPrincipalCurve.matrix.R'
  Running 'fitXYCurve.matrix.R'
  Running 'iwpca.matrix.R'
  Running 'likelihood.smooth.spline.R'
  Running 'medianPolish.matrix.R'
  Running 'normalizeAffine.matrix.R'
  Running 'normalizeAverage.list.R'
  Running 'normalizeAverage.matrix.R'
  Running 'normalizeCurveFit.matrix.R'
  Running 'normalizeDifferencesToAverage.R'
  Running 'normalizeFragmentLength-ex1.R'
  Running 'normalizeFragmentLength-ex2.R'
  Running 'normalizeQuantileRank.list.R'
  Running 'normalizeQuantileRank.matrix.R'
  Running 'normalizeQuantileSpline.matrix.R'
  Running 'normalizeTumorBoost,flavors.R'
  Running 'normalizeTumorBoost.R'
  Running 'robustSmoothSpline.R'
  Running 'rowAverages.matrix.R'
  Running 'sampleCorrelations.matrix.R'
  Running 'sampleTuples.R'
  Running 'wpca.matrix.R'
  Running 'wpca2.matrix.R'
 OK
* checking PDF version of manual ... OK
* DONE

Status: 1 WARNING, 1 NOTE
See
  'C:/Users/biocbuild/bbs-3.11-bioc/meat/aroma.light.Rcheck/00check.log'
for details.



Installation output

aroma.light.Rcheck/00install.out

##############################################################################
##############################################################################
###
### Running command:
###
###   C:\cygwin\bin\curl.exe -O https://malbec2.bioconductor.org/BBS/3.11/bioc/src/contrib/aroma.light_3.18.0.tar.gz && rm -rf aroma.light.buildbin-libdir && mkdir aroma.light.buildbin-libdir && C:\Users\biocbuild\bbs-3.11-bioc\R\bin\R.exe CMD INSTALL --merge-multiarch --build --library=aroma.light.buildbin-libdir aroma.light_3.18.0.tar.gz && C:\Users\biocbuild\bbs-3.11-bioc\R\bin\R.exe CMD INSTALL aroma.light_3.18.0.zip && rm aroma.light_3.18.0.tar.gz aroma.light_3.18.0.zip
###
##############################################################################
##############################################################################


  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed

  0     0    0     0    0     0      0      0 --:--:-- --:--:-- --:--:--     0
 35  406k   35  144k    0     0   446k      0 --:--:-- --:--:-- --:--:--  454k
100  406k  100  406k    0     0  1249k      0 --:--:-- --:--:-- --:--:-- 1268k

install for i386

* installing *source* package 'aroma.light' ...
** using staged installation
** R
** inst
** byte-compile and prepare package for lazy loading
** help
*** installing help indices
  converting help for package 'aroma.light'
    finding HTML links ... done
    1._Calibration_and_Normalization        html  
    Non-documented_objects                  html  
    aroma.light-package                     html  
    averageQuantile                         html  
    backtransformAffine                     html  
    backtransformPrincipalCurve             html  
    calibrateMultiscan                      html  
    callNaiveGenotypes                      html  
    distanceBetweenLines                    html  
    findPeaksAndValleys                     html  
    fitIWPCA                                html  
    fitNaiveGenotypes                       html  
    fitPrincipalCurve                       html  
    fitXYCurve                              html  
    iwpca                                   html  
    likelihood.smooth.spline                html  
    medianPolish                            html  
    normalizeAffine                         html  
    normalizeAverage                        html  
    normalizeCurveFit                       html  
    normalizeDifferencesToAverage           html  
    normalizeFragmentLength                 html  
    normalizeQuantileRank                   html  
    normalizeQuantileRank.matrix            html  
    normalizeQuantileSpline                 html  
    normalizeTumorBoost                     html  
    pairedAlleleSpecificCopyNumbers         html  
    plotDensity                             html  
Rd warning: C:/Users/biocbuild/bbs-3.11-bioc/tmpdir/Rtmp6hbSdP/R.INSTALLea06d144fac/aroma.light/man/plotDensity.Rd:44: file link 'plot' in package 'graphics' does not exist and so has been treated as a topic
    plotMvsA                                html  
    plotMvsAPairs                           html  
    plotMvsMPairs                           html  
    plotXYCurve                             html  
    print.SmoothSplineLikelihood            html  
    robustSmoothSpline                      html  
    sampleCorrelations                      html  
    sampleTuples                            html  
    wpca                                    html  
** building package indices
** testing if installed package can be loaded from temporary location
** testing if installed package can be loaded from final location
** testing if installed package keeps a record of temporary installation path

install for x64

* installing *source* package 'aroma.light' ...
** testing if installed package can be loaded
* MD5 sums
packaged installation of 'aroma.light' as aroma.light_3.18.0.zip
* DONE (aroma.light)
* installing to library 'C:/Users/biocbuild/bbs-3.11-bioc/R/library'
package 'aroma.light' successfully unpacked and MD5 sums checked

Tests output

aroma.light.Rcheck/tests_i386/backtransformAffine.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> X <- matrix(1:8, nrow=4, ncol=2)
> X[2,2] <- NA_integer_
> 
> print(X)
     [,1] [,2]
[1,]    1    5
[2,]    2   NA
[3,]    3    7
[4,]    4    8
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=c(1,5)))
     [,1] [,2]
[1,]    0    0
[2,]    1   NA
[3,]    2    2
[4,]    3    3
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, b=c(1,1/2)))
     [,1] [,2]
[1,]    1   10
[2,]    2   NA
[3,]    3   14
[4,]    4   16
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:4,ncol=1)))
     [,1] [,2]
[1,]    0    4
[2,]    0   NA
[3,]    0    4
[4,]    0    4
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:3,ncol=1)))
     [,1] [,2]
[1,]    0    4
[2,]    0   NA
[3,]    0    4
[4,]    3    7
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:2,ncol=1), b=c(1,2)))
     [,1] [,2]
[1,]    0    2
[2,]    0   NA
[3,]    2    3
[4,]    2    3
> 
> # Returns a 4x1 matrix
> print(backtransformAffine(X, b=c(1,1/2), project=TRUE))
     [,1]
[1,]  2.8
[2,]  1.6
[3,]  5.2
[4,]  6.4
> 
> # If the columns of X are identical, and a identity
> # backtransformation is applied and projected, the
> # same matrix is returned.
> X <- matrix(1:4, nrow=4, ncol=3)
> Y <- backtransformAffine(X, b=c(1,1,1), project=TRUE)
> print(X)
     [,1] [,2] [,3]
[1,]    1    1    1
[2,]    2    2    2
[3,]    3    3    3
[4,]    4    4    4
> print(Y)
     [,1]
[1,]    1
[2,]    2
[3,]    3
[4,]    4
> stopifnot(sum(X[,1]-Y) <= .Machine$double.eps)
> 
> 
> # If the columns of X are identical, and a identity
> # backtransformation is applied and projected, the
> # same matrix is returned.
> X <- matrix(1:4, nrow=4, ncol=3)
> X[,2] <- X[,2]*2; X[,3] <- X[,3]*3
> print(X)
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    2    4    6
[3,]    3    6    9
[4,]    4    8   12
> Y <- backtransformAffine(X, b=c(1,2,3))
> print(Y)
     [,1] [,2] [,3]
[1,]    1    1    1
[2,]    2    2    2
[3,]    3    3    3
[4,]    4    4    4
> Y <- backtransformAffine(X, b=c(1,2,3), project=TRUE)
> print(Y)
     [,1]
[1,]    1
[2,]    2
[3,]    3
[4,]    4
> stopifnot(sum(X[,1]-Y) <= .Machine$double.eps)
> 
> proc.time()
   user  system elapsed 
   0.39    0.09    0.45 

aroma.light.Rcheck/tests_x64/backtransformAffine.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> X <- matrix(1:8, nrow=4, ncol=2)
> X[2,2] <- NA_integer_
> 
> print(X)
     [,1] [,2]
[1,]    1    5
[2,]    2   NA
[3,]    3    7
[4,]    4    8
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=c(1,5)))
     [,1] [,2]
[1,]    0    0
[2,]    1   NA
[3,]    2    2
[4,]    3    3
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, b=c(1,1/2)))
     [,1] [,2]
[1,]    1   10
[2,]    2   NA
[3,]    3   14
[4,]    4   16
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:4,ncol=1)))
     [,1] [,2]
[1,]    0    4
[2,]    0   NA
[3,]    0    4
[4,]    0    4
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:3,ncol=1)))
     [,1] [,2]
[1,]    0    4
[2,]    0   NA
[3,]    0    4
[4,]    3    7
> 
> # Returns a 4x2 matrix
> print(backtransformAffine(X, a=matrix(1:2,ncol=1), b=c(1,2)))
     [,1] [,2]
[1,]    0    2
[2,]    0   NA
[3,]    2    3
[4,]    2    3
> 
> # Returns a 4x1 matrix
> print(backtransformAffine(X, b=c(1,1/2), project=TRUE))
     [,1]
[1,]  2.8
[2,]  1.6
[3,]  5.2
[4,]  6.4
> 
> # If the columns of X are identical, and a identity
> # backtransformation is applied and projected, the
> # same matrix is returned.
> X <- matrix(1:4, nrow=4, ncol=3)
> Y <- backtransformAffine(X, b=c(1,1,1), project=TRUE)
> print(X)
     [,1] [,2] [,3]
[1,]    1    1    1
[2,]    2    2    2
[3,]    3    3    3
[4,]    4    4    4
> print(Y)
     [,1]
[1,]    1
[2,]    2
[3,]    3
[4,]    4
> stopifnot(sum(X[,1]-Y) <= .Machine$double.eps)
> 
> 
> # If the columns of X are identical, and a identity
> # backtransformation is applied and projected, the
> # same matrix is returned.
> X <- matrix(1:4, nrow=4, ncol=3)
> X[,2] <- X[,2]*2; X[,3] <- X[,3]*3
> print(X)
     [,1] [,2] [,3]
[1,]    1    2    3
[2,]    2    4    6
[3,]    3    6    9
[4,]    4    8   12
> Y <- backtransformAffine(X, b=c(1,2,3))
> print(Y)
     [,1] [,2] [,3]
[1,]    1    1    1
[2,]    2    2    2
[3,]    3    3    3
[4,]    4    4    4
> Y <- backtransformAffine(X, b=c(1,2,3), project=TRUE)
> print(Y)
     [,1]
[1,]    1
[2,]    2
[3,]    3
[4,]    4
> stopifnot(sum(X[,1]-Y) <= .Machine$double.eps)
> 
> proc.time()
   user  system elapsed 
   0.42    0.04    0.45 

aroma.light.Rcheck/tests_i386/backtransformPrincipalCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Consider the case where K=4 measurements have been done
> # for the same underlying signals 'x'.  The different measurements
> # have different systematic variation
> #
> #   y_k = f(x_k) + eps_k; k = 1,...,K.
> #
> # In this example, we assume non-linear measurement functions
> #
> #   f(x) = a + b*x + x^c + eps(b*x)
> #
> # where 'a' is an offset, 'b' a scale factor, and 'c' an exponential.
> # We also assume heteroscedastic zero-mean noise with standard
> # deviation proportional to the rescaled underlying signal 'x'.
> #
> # Furthermore, we assume that measurements k=2 and k=3 undergo the
> # same transformation, which may illustrate that the come from
> # the same batch. However, when *fitting* the model below we
> # will assume they are independent.
> 
> # Transforms
> a <- c(2, 15, 15,   3)
> b <- c(2,  3,  3,   4)
> c <- c(1,  2,  2, 1/2)
> K <- length(a)
> 
> # The true signal
> N <- 1000
> x <- rexp(N)
> 
> # The noise
> bX <- outer(b,x)
> E <- apply(bX, MARGIN=2, FUN=function(x) rnorm(K, mean=0, sd=0.1*x))
> 
> # The transformed signals with noise
> Xc <- t(sapply(c, FUN=function(c) x^c))
> Y <- a + bX + Xc + E
> Y <- t(Y)
> 
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Fit principal curve
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Fit principal curve through Y = (y_1, y_2, ..., y_K)
> fit <- fitPrincipalCurve(Y)
> 
> # Flip direction of 'lambda'?
> rho <- cor(fit$lambda, Y[,1], use="complete.obs")
> flip <- (rho < 0)
> if (flip) {
+   fit$lambda <- max(fit$lambda, na.rm=TRUE)-fit$lambda
+ }
> 
> L <- ncol(fit$s)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Backtransform data according to model fit
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Backtransform toward the principal curve (the "common scale")
> YN1 <- backtransformPrincipalCurve(Y, fit=fit)
> stopifnot(ncol(YN1) == K)
> 
> 
> # Backtransform toward the first dimension
> YN2 <- backtransformPrincipalCurve(Y, fit=fit, targetDimension=1)
> stopifnot(ncol(YN2) == K)
> 
> 
> # Backtransform toward the last (fitted) dimension
> YN3 <- backtransformPrincipalCurve(Y, fit=fit, targetDimension=L)
> stopifnot(ncol(YN3) == K)
> 
> 
> # Backtransform toward the third dimension (dimension by dimension)
> # Note, this assumes that K == L.
> YN4 <- Y
> for (cc in 1:L) {
+   YN4[,cc] <- backtransformPrincipalCurve(Y, fit=fit,
+                                   targetDimension=1, dimensions=cc)
+ }
> stopifnot(identical(YN4, YN2))
> 
> 
> # Backtransform a subset toward the first dimension
> # Note, this assumes that K == L.
> YN5 <- backtransformPrincipalCurve(Y, fit=fit,
+                                targetDimension=1, dimensions=2:3)
> stopifnot(identical(YN5, YN2[,2:3]))
> stopifnot(ncol(YN5) == 2)
> 
> 
> # Extract signals from measurement #2 and backtransform according
> # its model fit.  Signals are standardized to target dimension 1.
> y6 <- Y[,2,drop=FALSE]
> yN6 <- backtransformPrincipalCurve(y6, fit=fit, dimensions=2,
+                                                targetDimension=1)
> stopifnot(identical(yN6, YN2[,2,drop=FALSE]))
> stopifnot(ncol(yN6) == 1)
> 
> 
> # Extract signals from measurement #2 and backtransform according
> # the the model fit of measurement #3 (because we believe these
> # two have undergone very similar transformations.
> # Signals are standardized to target dimension 1.
> y7 <- Y[,2,drop=FALSE]
> yN7 <- backtransformPrincipalCurve(y7, fit=fit, dimensions=3,
+                                                targetDimension=1)
> stopifnot(ncol(yN7) == 1)
> 
> rho <- cor(yN7, yN6)
> print(rho)
          [,1]
[1,] 0.9999858
> stopifnot(rho > 0.999)
> 
> proc.time()
   user  system elapsed 
   0.98    0.04    1.00 

aroma.light.Rcheck/tests_x64/backtransformPrincipalCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Consider the case where K=4 measurements have been done
> # for the same underlying signals 'x'.  The different measurements
> # have different systematic variation
> #
> #   y_k = f(x_k) + eps_k; k = 1,...,K.
> #
> # In this example, we assume non-linear measurement functions
> #
> #   f(x) = a + b*x + x^c + eps(b*x)
> #
> # where 'a' is an offset, 'b' a scale factor, and 'c' an exponential.
> # We also assume heteroscedastic zero-mean noise with standard
> # deviation proportional to the rescaled underlying signal 'x'.
> #
> # Furthermore, we assume that measurements k=2 and k=3 undergo the
> # same transformation, which may illustrate that the come from
> # the same batch. However, when *fitting* the model below we
> # will assume they are independent.
> 
> # Transforms
> a <- c(2, 15, 15,   3)
> b <- c(2,  3,  3,   4)
> c <- c(1,  2,  2, 1/2)
> K <- length(a)
> 
> # The true signal
> N <- 1000
> x <- rexp(N)
> 
> # The noise
> bX <- outer(b,x)
> E <- apply(bX, MARGIN=2, FUN=function(x) rnorm(K, mean=0, sd=0.1*x))
> 
> # The transformed signals with noise
> Xc <- t(sapply(c, FUN=function(c) x^c))
> Y <- a + bX + Xc + E
> Y <- t(Y)
> 
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Fit principal curve
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Fit principal curve through Y = (y_1, y_2, ..., y_K)
> fit <- fitPrincipalCurve(Y)
> 
> # Flip direction of 'lambda'?
> rho <- cor(fit$lambda, Y[,1], use="complete.obs")
> flip <- (rho < 0)
> if (flip) {
+   fit$lambda <- max(fit$lambda, na.rm=TRUE)-fit$lambda
+ }
> 
> L <- ncol(fit$s)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Backtransform data according to model fit
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Backtransform toward the principal curve (the "common scale")
> YN1 <- backtransformPrincipalCurve(Y, fit=fit)
> stopifnot(ncol(YN1) == K)
> 
> 
> # Backtransform toward the first dimension
> YN2 <- backtransformPrincipalCurve(Y, fit=fit, targetDimension=1)
> stopifnot(ncol(YN2) == K)
> 
> 
> # Backtransform toward the last (fitted) dimension
> YN3 <- backtransformPrincipalCurve(Y, fit=fit, targetDimension=L)
> stopifnot(ncol(YN3) == K)
> 
> 
> # Backtransform toward the third dimension (dimension by dimension)
> # Note, this assumes that K == L.
> YN4 <- Y
> for (cc in 1:L) {
+   YN4[,cc] <- backtransformPrincipalCurve(Y, fit=fit,
+                                   targetDimension=1, dimensions=cc)
+ }
> stopifnot(identical(YN4, YN2))
> 
> 
> # Backtransform a subset toward the first dimension
> # Note, this assumes that K == L.
> YN5 <- backtransformPrincipalCurve(Y, fit=fit,
+                                targetDimension=1, dimensions=2:3)
> stopifnot(identical(YN5, YN2[,2:3]))
> stopifnot(ncol(YN5) == 2)
> 
> 
> # Extract signals from measurement #2 and backtransform according
> # its model fit.  Signals are standardized to target dimension 1.
> y6 <- Y[,2,drop=FALSE]
> yN6 <- backtransformPrincipalCurve(y6, fit=fit, dimensions=2,
+                                                targetDimension=1)
> stopifnot(identical(yN6, YN2[,2,drop=FALSE]))
> stopifnot(ncol(yN6) == 1)
> 
> 
> # Extract signals from measurement #2 and backtransform according
> # the the model fit of measurement #3 (because we believe these
> # two have undergone very similar transformations.
> # Signals are standardized to target dimension 1.
> y7 <- Y[,2,drop=FALSE]
> yN7 <- backtransformPrincipalCurve(y7, fit=fit, dimensions=3,
+                                                targetDimension=1)
> stopifnot(ncol(yN7) == 1)
> 
> rho <- cor(yN7, yN6)
> print(rho)
         [,1]
[1,] 0.999984
> stopifnot(rho > 0.999)
> 
> proc.time()
   user  system elapsed 
   1.04    0.07    1.11 

aroma.light.Rcheck/tests_i386/callNaiveGenotypes.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> layout(matrix(1:3, ncol=1))
> par(mar=c(2,4,4,1)+0.1)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A bimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAA <- rnorm(n=10000, mean=0, sd=0.1)
> xBB <- rnorm(n=10000, mean=1, sd=0.1)
> x <- c(xAA,xBB)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type            x      density
1   peak -0.004920549 1.6772199951
2 valley  0.498735013 0.0002753765
3   peak  0.994065690 1.6945216910
> calls <- callNaiveGenotypes(x, cn=rep(1,length(x)), verbose=-20)
Calling genotypes from allele B fractions (BAFs)...
 Fitting naive genotype model...
  Fitting naive genotype model from normal allele B fractions (BAFs)...
   Flavor: density
   Censoring BAFs...
    Before:
          Min.    1st Qu.     Median       Mean    3rd Qu.       Max. 
    -0.3937625  0.0000688  0.5240715  0.4994219  0.9994514  1.3537705 
    [1] 20000
    After:
         Min.   1st Qu.    Median      Mean   3rd Qu.      Max. 
         -Inf 0.0000688 0.5240715           0.9994514       Inf 
    [1] 16836
   Censoring BAFs...done
   Copy number level #1 (C=1) of 1...
    Identified extreme points in density of BAF:
        type          x     density
    1   peak 0.01474651 1.627858450
    2 valley 0.49825533 0.003834183
    3   peak 0.97833501 1.646225126
    Local minimas ("valleys") in BAF:
        type         x     density
    2 valley 0.4982553 0.003834183
   Copy number level #1 (C=1) of 1...done
  Fitting naive genotype model from normal allele B fractions (BAFs)...done
  [[1]]
  [[1]]$flavor
  [1] "density"
  
  [[1]]$cn
  [1] 1
  
  [[1]]$nbrOfGenotypeGroups
  [1] 2
  
  [[1]]$tau
  [1] 0.4982553
  
  [[1]]$n
  [1] 16836
  
  [[1]]$fit
      type          x     density
  1   peak 0.01474651 1.627858450
  2 valley 0.49825533 0.003834183
  3   peak 0.97833501 1.646225126
  
  [[1]]$fitValleys
      type         x     density
  2 valley 0.4982553 0.003834183
  
  
  attr(,"class")
  [1] "NaiveGenotypeModelFit" "list"                 
 Fitting naive genotype model...done
 Copy number level #1 (C=1) of 1...
  Model fit:
  $flavor
  [1] "density"
  
  $cn
  [1] 1
  
  $nbrOfGenotypeGroups
  [1] 2
  
  $tau
  [1] 0.4982553
  
  $n
  [1] 16836
  
  $fit
      type          x     density
  1   peak 0.01474651 1.627858450
  2 valley 0.49825533 0.003834183
  3   peak 0.97833501 1.646225126
  
  $fitValleys
      type         x     density
  2 valley 0.4982553 0.003834183
  
  Genotype threshholds [1]: 0.49825533027243
  TCN=1 => BAF in {0,1}.
  Call regions: A = (-Inf,0.498], B = (0.498,+Inf)
 Copy number level #1 (C=1) of 1...done
Calling genotypes from allele B fractions (BAFs)...done
> xc <- split(x, calls)
> print(table(calls))
calls
    0     1 
10000 10000 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA,BB)")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with missing values
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAB <- rnorm(n=10000, mean=1/2, sd=0.1)
> x <- c(xAA,xAB,xBB)
> x[sample(length(x), size=0.05*length(x))] <- NA_real_
> x[sample(length(x), size=0.01*length(x))] <- -Inf
> x[sample(length(x), size=0.01*length(x))] <- +Inf
> fit <- findPeaksAndValleys(x)
> print(fit)
    type           x   density
1   peak -0.00506203 1.1655172
2 valley  0.24645370 0.1967596
3   peak  0.49397712 1.1661152
4 valley  0.74549285 0.1847864
5   peak  0.99700858 1.1784343
> calls <- callNaiveGenotypes(x)
> xc <- split(x, calls)
> print(table(calls))
calls
   0  0.5    1 
9600 9298 9634 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA,AB,BB)")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with clear separation
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAA <- rnorm(n=10000, mean=0, sd=0.02)
> xAB <- rnorm(n=10000, mean=1/2, sd=0.02)
> xBB <- rnorm(n=10000, mean=1, sd=0.02)
> x <- c(xAA,xAB,xBB)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type            x      density
1   peak -0.001818202 2.602457e+00
2 valley  0.248482790 3.143264e-05
3   peak  0.495971412 2.606636e+00
4 valley  0.746272404 3.226187e-05
5   peak  0.996573396 2.615836e+00
> calls <- callNaiveGenotypes(x)
> xc <- split(x, calls)
> print(table(calls))
calls
    0   0.5     1 
10000 10000 10000 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA',AB',BB')")
> abline(v=fit$x)
> 
> proc.time()
   user  system elapsed 
   0.85    0.09    0.93 

aroma.light.Rcheck/tests_x64/callNaiveGenotypes.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> layout(matrix(1:3, ncol=1))
> par(mar=c(2,4,4,1)+0.1)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A bimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAA <- rnorm(n=10000, mean=0, sd=0.1)
> xBB <- rnorm(n=10000, mean=1, sd=0.1)
> x <- c(xAA,xBB)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type            x      density
1   peak -0.002510552 1.6875511387
2 valley  0.503600125 0.0006508271
3   peak  0.997162604 1.6907764983
> calls <- callNaiveGenotypes(x, cn=rep(1,length(x)), verbose=-20)
Calling genotypes from allele B fractions (BAFs)...
 Fitting naive genotype model...
  Fitting naive genotype model from normal allele B fractions (BAFs)...
   Flavor: density
   Censoring BAFs...
    Before:
         Min.   1st Qu.    Median      Mean   3rd Qu.      Max. 
    -0.347991  0.001996  0.519147  0.501111  1.001633  1.409567 
    [1] 20000
    After:
        Min.  1st Qu.   Median     Mean  3rd Qu.     Max. 
        -Inf 0.001996 0.519147          1.001633      Inf 
    [1] 16844
   Censoring BAFs...done
   Copy number level #1 (C=1) of 1...
    Identified extreme points in density of BAF:
        type          x     density
    1   peak 0.01466953 1.640212542
    2 valley 0.49828721 0.004279134
    3   peak 0.98190489 1.638163661
    Local minimas ("valleys") in BAF:
        type         x     density
    2 valley 0.4982872 0.004279134
   Copy number level #1 (C=1) of 1...done
  Fitting naive genotype model from normal allele B fractions (BAFs)...done
  [[1]]
  [[1]]$flavor
  [1] "density"
  
  [[1]]$cn
  [1] 1
  
  [[1]]$nbrOfGenotypeGroups
  [1] 2
  
  [[1]]$tau
  [1] 0.4982872
  
  [[1]]$n
  [1] 16844
  
  [[1]]$fit
      type          x     density
  1   peak 0.01466953 1.640212542
  2 valley 0.49828721 0.004279134
  3   peak 0.98190489 1.638163661
  
  [[1]]$fitValleys
      type         x     density
  2 valley 0.4982872 0.004279134
  
  
  attr(,"class")
  [1] "NaiveGenotypeModelFit" "list"                 
 Fitting naive genotype model...done
 Copy number level #1 (C=1) of 1...
  Model fit:
  $flavor
  [1] "density"
  
  $cn
  [1] 1
  
  $nbrOfGenotypeGroups
  [1] 2
  
  $tau
  [1] 0.4982872
  
  $n
  [1] 16844
  
  $fit
      type          x     density
  1   peak 0.01466953 1.640212542
  2 valley 0.49828721 0.004279134
  3   peak 0.98190489 1.638163661
  
  $fitValleys
      type         x     density
  2 valley 0.4982872 0.004279134
  
  Genotype threshholds [1]: 0.498287213153104
  TCN=1 => BAF in {0,1}.
  Call regions: A = (-Inf,0.498], B = (0.498,+Inf)
 Copy number level #1 (C=1) of 1...done
Calling genotypes from allele B fractions (BAFs)...done
> xc <- split(x, calls)
> print(table(calls))
calls
    0     1 
10000 10000 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA,BB)")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with missing values
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAB <- rnorm(n=10000, mean=1/2, sd=0.1)
> x <- c(xAA,xAB,xBB)
> x[sample(length(x), size=0.05*length(x))] <- NA_real_
> x[sample(length(x), size=0.01*length(x))] <- -Inf
> x[sample(length(x), size=0.01*length(x))] <- +Inf
> fit <- findPeaksAndValleys(x)
> print(fit)
    type             x   density
1   peak -0.0009082974 1.1740748
2 valley  0.2478853898 0.1980817
3   peak  0.4926662756 1.1668210
4 valley  0.7454727642 0.1852370
5   peak  0.9982792529 1.1773810
> calls <- callNaiveGenotypes(x)
> xc <- split(x, calls)
> print(table(calls))
calls
   0  0.5    1 
9588 9299 9641 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA,AB,BB)")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with clear separation
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> xAA <- rnorm(n=10000, mean=0, sd=0.02)
> xAB <- rnorm(n=10000, mean=1/2, sd=0.02)
> xBB <- rnorm(n=10000, mean=1, sd=0.02)
> x <- c(xAA,xAB,xBB)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type            x      density
1   peak -0.003305398 2.605034e+00
2 valley  0.246568161 3.281716e-05
3   peak  0.496441719 2.602450e+00
4 valley  0.746315278 3.323060e-05
5   peak  0.996188837 2.605594e+00
> calls <- callNaiveGenotypes(x)
> xc <- split(x, calls)
> print(table(calls))
calls
    0   0.5     1 
10000 10000 10000 
> xx <- c(list(x),xc)
> plotDensity(xx, adjust=1.5, lwd=2, col=seq_along(xx), main="(AA',AB',BB')")
> abline(v=fit$x)
> 
> proc.time()
   user  system elapsed 
   0.98    0.06    1.03 

aroma.light.Rcheck/tests_i386/distanceBetweenLines.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ layout(matrix(1:4, nrow=2, ncol=2, byrow=TRUE))
+ 
+ ############################################################
+ # Lines in two-dimensions
+ ############################################################
+ x <- list(a=c(1,0), b=c(1,2))
+ y <- list(a=c(0,2), b=c(1,1))
+ fit <- distanceBetweenLines(ax=x$a, bx=x$b, ay=y$a, by=y$b)
+ 
+ xlim <- ylim <- c(-1,8)
+ plot(NA, xlab="", ylab="", xlim=ylim, ylim=ylim)
+ 
+ # Highlight the offset coordinates for both lines
+ points(t(x$a), pch="+", col="red")
+ text(t(x$a), label=expression(a[x]), adj=c(-1,0.5))
+ points(t(y$a), pch="+", col="blue")
+ text(t(y$a), label=expression(a[y]), adj=c(-1,0.5))
+ 
+ v <- c(-1,1)*10
+ xv <- list(x=x$a[1]+x$b[1]*v, y=x$a[2]+x$b[2]*v)
+ yv <- list(x=y$a[1]+y$b[1]*v, y=y$a[2]+y$b[2]*v)
+ 
+ lines(xv, col="red")
+ lines(yv, col="blue")
+ 
+ points(t(fit$xs), cex=2.0, col="red")
+ text(t(fit$xs), label=expression(x(s)), adj=c(+2,0.5))
+ points(t(fit$yt), cex=1.5, col="blue")
+ text(t(fit$yt), label=expression(y(t)), adj=c(-1,0.5))
+ print(fit)
+ 
+ 
+ ############################################################
+ # Lines in three-dimensions
+ ############################################################
+ x <- list(a=c(0,0,0), b=c(1,1,1))  # The 'diagonal'
+ y <- list(a=c(2,1,2), b=c(2,1,3))  # A 'fitted' line
+ fit <- distanceBetweenLines(ax=x$a, bx=x$b, ay=y$a, by=y$b)
+ 
+ xlim <- ylim <- zlim <- c(-1,3)
+ dummy <- t(c(1,1,1))*100
+ 
+ # Coordinates for the lines in 3d
+ v <- seq(-10,10, by=1)
+ xv <- list(x=x$a[1]+x$b[1]*v, y=x$a[2]+x$b[2]*v, z=x$a[3]+x$b[3]*v)
+ yv <- list(x=y$a[1]+y$b[1]*v, y=y$a[2]+y$b[2]*v, z=y$a[3]+y$b[3]*v)
+ 
+ for (theta in seq(30,140,length.out=3)) {
+   plot3d(dummy, theta=theta, phi=30, xlab="", ylab="", zlab="",
+                              xlim=ylim, ylim=ylim, zlim=zlim)
+ 
+   # Highlight the offset coordinates for both lines
+   points3d(t(x$a), pch="+", col="red")
+   text3d(t(x$a), label=expression(a[x]), adj=c(-1,0.5))
+   points3d(t(y$a), pch="+", col="blue")
+   text3d(t(y$a), label=expression(a[y]), adj=c(-1,0.5))
+ 
+   # Draw the lines
+   lines3d(xv, col="red")
+   lines3d(yv, col="blue")
+ 
+   # Draw the two points that are closest to each other
+   points3d(t(fit$xs), cex=2.0, col="red")
+   text3d(t(fit$xs), label=expression(x(s)), adj=c(+2,0.5))
+   points3d(t(fit$yt), cex=1.5, col="blue")
+   text3d(t(fit$yt), label=expression(y(t)), adj=c(-1,0.5))
+ 
+   # Draw the distance between the two points
+   lines3d(rbind(fit$xs,fit$yt), col="purple", lwd=2)
+ }
+ 
+ print(fit)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.53    0.06    0.56 

aroma.light.Rcheck/tests_x64/distanceBetweenLines.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ layout(matrix(1:4, nrow=2, ncol=2, byrow=TRUE))
+ 
+ ############################################################
+ # Lines in two-dimensions
+ ############################################################
+ x <- list(a=c(1,0), b=c(1,2))
+ y <- list(a=c(0,2), b=c(1,1))
+ fit <- distanceBetweenLines(ax=x$a, bx=x$b, ay=y$a, by=y$b)
+ 
+ xlim <- ylim <- c(-1,8)
+ plot(NA, xlab="", ylab="", xlim=ylim, ylim=ylim)
+ 
+ # Highlight the offset coordinates for both lines
+ points(t(x$a), pch="+", col="red")
+ text(t(x$a), label=expression(a[x]), adj=c(-1,0.5))
+ points(t(y$a), pch="+", col="blue")
+ text(t(y$a), label=expression(a[y]), adj=c(-1,0.5))
+ 
+ v <- c(-1,1)*10
+ xv <- list(x=x$a[1]+x$b[1]*v, y=x$a[2]+x$b[2]*v)
+ yv <- list(x=y$a[1]+y$b[1]*v, y=y$a[2]+y$b[2]*v)
+ 
+ lines(xv, col="red")
+ lines(yv, col="blue")
+ 
+ points(t(fit$xs), cex=2.0, col="red")
+ text(t(fit$xs), label=expression(x(s)), adj=c(+2,0.5))
+ points(t(fit$yt), cex=1.5, col="blue")
+ text(t(fit$yt), label=expression(y(t)), adj=c(-1,0.5))
+ print(fit)
+ 
+ 
+ ############################################################
+ # Lines in three-dimensions
+ ############################################################
+ x <- list(a=c(0,0,0), b=c(1,1,1))  # The 'diagonal'
+ y <- list(a=c(2,1,2), b=c(2,1,3))  # A 'fitted' line
+ fit <- distanceBetweenLines(ax=x$a, bx=x$b, ay=y$a, by=y$b)
+ 
+ xlim <- ylim <- zlim <- c(-1,3)
+ dummy <- t(c(1,1,1))*100
+ 
+ # Coordinates for the lines in 3d
+ v <- seq(-10,10, by=1)
+ xv <- list(x=x$a[1]+x$b[1]*v, y=x$a[2]+x$b[2]*v, z=x$a[3]+x$b[3]*v)
+ yv <- list(x=y$a[1]+y$b[1]*v, y=y$a[2]+y$b[2]*v, z=y$a[3]+y$b[3]*v)
+ 
+ for (theta in seq(30,140,length.out=3)) {
+   plot3d(dummy, theta=theta, phi=30, xlab="", ylab="", zlab="",
+                              xlim=ylim, ylim=ylim, zlim=zlim)
+ 
+   # Highlight the offset coordinates for both lines
+   points3d(t(x$a), pch="+", col="red")
+   text3d(t(x$a), label=expression(a[x]), adj=c(-1,0.5))
+   points3d(t(y$a), pch="+", col="blue")
+   text3d(t(y$a), label=expression(a[y]), adj=c(-1,0.5))
+ 
+   # Draw the lines
+   lines3d(xv, col="red")
+   lines3d(yv, col="blue")
+ 
+   # Draw the two points that are closest to each other
+   points3d(t(fit$xs), cex=2.0, col="red")
+   text3d(t(fit$xs), label=expression(x(s)), adj=c(+2,0.5))
+   points3d(t(fit$yt), cex=1.5, col="blue")
+   text3d(t(fit$yt), label=expression(y(t)), adj=c(-1,0.5))
+ 
+   # Draw the distance between the two points
+   lines3d(rbind(fit$xs,fit$yt), col="purple", lwd=2)
+ }
+ 
+ print(fit)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.50    0.04    0.53 

aroma.light.Rcheck/tests_i386/findPeaksAndValleys.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> layout(matrix(1:3, ncol=1))
> par(mar=c(2,4,4,1)+0.1)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A unimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x1 <- rnorm(n=10000, mean=0, sd=1)
> x <- x1
> fit <- findPeaksAndValleys(x)
> print(fit)
    type            x      density
1   peak -4.355306471 2.781126e-04
2 valley -3.907925563 3.875941e-06
3   peak -0.006764048 3.984233e-01
> plot(density(x), lwd=2, main="x1")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x2 <- rnorm(n=10000, mean=4, sd=1)
> x3 <- rnorm(n=10000, mean=8, sd=1)
> x <- c(x1,x2,x3)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type           x    density
1   peak -0.05050345 0.12451275
2 valley  1.95017924 0.04173653
3   peak  3.95086194 0.12561413
4 valley  5.95154464 0.04508577
5   peak  7.95222734 0.12491640
> plot(density(x), lwd=2, main="c(x1,x2,x3)")
> abline(v=fit$x)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with clear separation
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x1b <- rnorm(n=10000, mean=0, sd=0.1)
> x2b <- rnorm(n=10000, mean=4, sd=0.1)
> x3b <- rnorm(n=10000, mean=8, sd=0.1)
> x <- c(x1b,x2b,x3b)
> 
> # Illustrating explicit usage of density()
> d <- density(x)
> fit <- findPeaksAndValleys(d, tol=0)
> print(fit)
    type           x      density
1   peak -0.03229953 3.421528e-01
2 valley  1.97880467 1.197583e-06
3   peak  3.96828410 3.419143e-01
4 valley  5.97938830 1.229813e-06
5   peak  7.96886772 3.422388e-01
> plot(d, lwd=2, main="c(x1b,x2b,x3b)")
> abline(v=fit$x)
> 
> proc.time()
   user  system elapsed 
   0.53    0.04    0.56 

aroma.light.Rcheck/tests_x64/findPeaksAndValleys.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> layout(matrix(1:3, ncol=1))
> par(mar=c(2,4,4,1)+0.1)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A unimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x1 <- rnorm(n=10000, mean=0, sd=1)
> x <- x1
> fit <- findPeaksAndValleys(x)
> print(fit)
  type          x   density
1 peak 0.09398443 0.3939781
> plot(density(x), lwd=2, main="x1")
> abline(v=fit$x)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x2 <- rnorm(n=10000, mean=4, sd=1)
> x3 <- rnorm(n=10000, mean=8, sd=1)
> x <- c(x1,x2,x3)
> fit <- findPeaksAndValleys(x)
> print(fit)
    type           x    density
1   peak -0.01351679 0.12378933
2 valley  1.95928762 0.04389211
3   peak  3.96610590 0.12307546
4 valley  5.90489644 0.04427898
5   peak  8.01375632 0.12386566
> plot(density(x), lwd=2, main="c(x1,x2,x3)")
> abline(v=fit$x)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # A trimodal distribution with clear separation
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> x1b <- rnorm(n=10000, mean=0, sd=0.1)
> x2b <- rnorm(n=10000, mean=4, sd=0.1)
> x3b <- rnorm(n=10000, mean=8, sd=0.1)
> x <- c(x1b,x2b,x3b)
> 
> # Illustrating explicit usage of density()
> d <- density(x)
> fit <- findPeaksAndValleys(d, tol=0)
> print(fit)
    type           x      density
1   peak -0.02656939 3.422320e-01
2 valley  1.97985827 1.211751e-06
3   peak  3.98628593 3.427078e-01
4 valley  5.97113910 1.241955e-06
5   peak  7.97756676 3.426816e-01
> plot(d, lwd=2, main="c(x1b,x2b,x3b)")
> abline(v=fit$x)
> 
> proc.time()
   user  system elapsed 
   0.56    0.03    0.59 

aroma.light.Rcheck/tests_i386/fitPrincipalCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate data from the model y <- a + bx + x^c + eps(bx)
> J <- 1000
> x <- rexp(J)
> a <- c(2,15,3)
> b <- c(2,3,4)
> c <- c(1,2,1/2)
> bx <- outer(b,x)
> xc <- t(sapply(c, FUN=function(c) x^c))
> eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(b), mean=0, sd=0.1*x))
> y <- a + bx + xc + eps
> y <- t(y)
> 
> # Fit principal curve through (y_1, y_2, y_3)
> fit <- fitPrincipalCurve(y, verbose=TRUE)
Fitting principal curve...
 Data size: 1000x3
 Identifying missing values...
 Identifying missing values...done
 Data size after removing non-finite data points: 1000x3
 Calling principal_curve()...
Starting curve---distance^2: 1752132
Iteration 1---distance^2: 403.8842
Iteration 2---distance^2: 403.3983
Iteration 3---distance^2: 403.4023
  Converged: TRUE
  Number of iterations: 3
  Processing time/iteration: 0.2s (0.0s/iteration)
 Calling principal_curve()...done
Fitting principal curve...done
> 
> # Flip direction of 'lambda'?
> rho <- cor(fit$lambda, y[,1], use="complete.obs")
> flip <- (rho < 0)
> if (flip) {
+   fit$lambda <- max(fit$lambda, na.rm=TRUE)-fit$lambda
+ }
> 
> 
> # Backtransform (y_1, y_2, y_3) to be proportional to each other
> yN <- backtransformPrincipalCurve(y, fit=fit)
> 
> # Same backtransformation dimension by dimension
> yN2 <- y
> for (cc in 1:ncol(y)) {
+   yN2[,cc] <- backtransformPrincipalCurve(y, fit=fit, dimensions=cc)
+ }
> stopifnot(identical(yN2, yN))
> 
> 
> xlim <- c(0, 1.04*max(x))
> ylim <- range(c(y,yN), na.rm=TRUE)
> 
> 
> # Pairwise signals vs x before and after transform
> layout(matrix(1:4, nrow=2, byrow=TRUE))
> par(mar=c(4,4,3,2)+0.1)
> for (cc in 1:3) {
+   ylab <- substitute(y[c], env=list(c=cc))
+   plot(NA, xlim=xlim, ylim=ylim, xlab="x", ylab=ylab)
+   abline(h=a[cc], lty=3)
+   mtext(side=4, at=a[cc], sprintf("a=%g", a[cc]),
+         cex=0.8, las=2, line=0, adj=1.1, padj=-0.2)
+   points(x, y[,cc])
+   points(x, yN[,cc], col="tomato")
+   legend("topleft", col=c("black", "tomato"), pch=19,
+                     c("orignal", "transformed"), bty="n")
+ }
> title(main="Pairwise signals vs x before and after transform", outer=TRUE, line=-2)
> 
> 
> # Pairwise signals before and after transform
> layout(matrix(1:4, nrow=2, byrow=TRUE))
> par(mar=c(4,4,3,2)+0.1)
> for (rr in 3:2) {
+   ylab <- substitute(y[c], env=list(c=rr))
+   for (cc in 1:2) {
+     if (cc == rr) {
+       plot.new()
+       next
+     }
+     xlab <- substitute(y[c], env=list(c=cc))
+     plot(NA, xlim=ylim, ylim=ylim, xlab=xlab, ylab=ylab)
+     abline(a=0, b=1, lty=2)
+     points(y[,c(cc,rr)])
+     points(yN[,c(cc,rr)], col="tomato")
+     legend("topleft", col=c("black", "tomato"), pch=19,
+                       c("orignal", "transformed"), bty="n")
+   }
+ }
> title(main="Pairwise signals before and after transform", outer=TRUE, line=-2)
> 
> proc.time()
   user  system elapsed 
   1.20    0.12    1.31 

aroma.light.Rcheck/tests_x64/fitPrincipalCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate data from the model y <- a + bx + x^c + eps(bx)
> J <- 1000
> x <- rexp(J)
> a <- c(2,15,3)
> b <- c(2,3,4)
> c <- c(1,2,1/2)
> bx <- outer(b,x)
> xc <- t(sapply(c, FUN=function(c) x^c))
> eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(b), mean=0, sd=0.1*x))
> y <- a + bx + xc + eps
> y <- t(y)
> 
> # Fit principal curve through (y_1, y_2, y_3)
> fit <- fitPrincipalCurve(y, verbose=TRUE)
Fitting principal curve...
 Data size: 1000x3
 Identifying missing values...
 Identifying missing values...done
 Data size after removing non-finite data points: 1000x3
 Calling principal_curve()...
Starting curve---distance^2: 1555957
Iteration 1---distance^2: 375.5634
Iteration 2---distance^2: 375.3571
  Converged: TRUE
  Number of iterations: 2
  Processing time/iteration: 0.1s (0.0s/iteration)
 Calling principal_curve()...done
Fitting principal curve...done
> 
> # Flip direction of 'lambda'?
> rho <- cor(fit$lambda, y[,1], use="complete.obs")
> flip <- (rho < 0)
> if (flip) {
+   fit$lambda <- max(fit$lambda, na.rm=TRUE)-fit$lambda
+ }
> 
> 
> # Backtransform (y_1, y_2, y_3) to be proportional to each other
> yN <- backtransformPrincipalCurve(y, fit=fit)
> 
> # Same backtransformation dimension by dimension
> yN2 <- y
> for (cc in 1:ncol(y)) {
+   yN2[,cc] <- backtransformPrincipalCurve(y, fit=fit, dimensions=cc)
+ }
> stopifnot(identical(yN2, yN))
> 
> 
> xlim <- c(0, 1.04*max(x))
> ylim <- range(c(y,yN), na.rm=TRUE)
> 
> 
> # Pairwise signals vs x before and after transform
> layout(matrix(1:4, nrow=2, byrow=TRUE))
> par(mar=c(4,4,3,2)+0.1)
> for (cc in 1:3) {
+   ylab <- substitute(y[c], env=list(c=cc))
+   plot(NA, xlim=xlim, ylim=ylim, xlab="x", ylab=ylab)
+   abline(h=a[cc], lty=3)
+   mtext(side=4, at=a[cc], sprintf("a=%g", a[cc]),
+         cex=0.8, las=2, line=0, adj=1.1, padj=-0.2)
+   points(x, y[,cc])
+   points(x, yN[,cc], col="tomato")
+   legend("topleft", col=c("black", "tomato"), pch=19,
+                     c("orignal", "transformed"), bty="n")
+ }
> title(main="Pairwise signals vs x before and after transform", outer=TRUE, line=-2)
> 
> 
> # Pairwise signals before and after transform
> layout(matrix(1:4, nrow=2, byrow=TRUE))
> par(mar=c(4,4,3,2)+0.1)
> for (rr in 3:2) {
+   ylab <- substitute(y[c], env=list(c=rr))
+   for (cc in 1:2) {
+     if (cc == rr) {
+       plot.new()
+       next
+     }
+     xlab <- substitute(y[c], env=list(c=cc))
+     plot(NA, xlim=ylim, ylim=ylim, xlab=xlab, ylab=ylab)
+     abline(a=0, b=1, lty=2)
+     points(y[,c(cc,rr)])
+     points(yN[,c(cc,rr)], col="tomato")
+     legend("topleft", col=c("black", "tomato"), pch=19,
+                       c("orignal", "transformed"), bty="n")
+   }
+ }
> title(main="Pairwise signals before and after transform", outer=TRUE, line=-2)
> 
> proc.time()
   user  system elapsed 
   1.32    0.09    1.39 

aroma.light.Rcheck/tests_i386/fitXYCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate data from the model y <- a + bx + x^c + eps(bx)
> x <- rexp(1000)
> a <- c(2,15)
> b <- c(2,1)
> c <- c(1,2)
> bx <- outer(b,x)
> xc <- t(sapply(c, FUN=function(c) x^c))
> eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
> Y <- a + bx + xc + eps
> Y <- t(Y)
> 
> lim <- c(0,70)
> plot(Y, xlim=lim, ylim=lim)
> 
> # Fit principal curve through a subset of (y_1, y_2)
> subset <- sample(nrow(Y), size=0.3*nrow(Y))
> fit <- fitXYCurve(Y[subset,], bandwidth=0.2)
> 
> lines(fit, col="red", lwd=2)
> 
> # Backtransform (y_1, y_2) keeping y_1 unchanged
> YN <- backtransformXYCurve(Y, fit=fit)
> points(YN, col="blue")
> abline(a=0, b=1, col="red", lwd=2)
> 
> proc.time()
   user  system elapsed 
   0.57    0.06    0.62 

aroma.light.Rcheck/tests_x64/fitXYCurve.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate data from the model y <- a + bx + x^c + eps(bx)
> x <- rexp(1000)
> a <- c(2,15)
> b <- c(2,1)
> c <- c(1,2)
> bx <- outer(b,x)
> xc <- t(sapply(c, FUN=function(c) x^c))
> eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
> Y <- a + bx + xc + eps
> Y <- t(Y)
> 
> lim <- c(0,70)
> plot(Y, xlim=lim, ylim=lim)
> 
> # Fit principal curve through a subset of (y_1, y_2)
> subset <- sample(nrow(Y), size=0.3*nrow(Y))
> fit <- fitXYCurve(Y[subset,], bandwidth=0.2)
> 
> lines(fit, col="red", lwd=2)
> 
> # Backtransform (y_1, y_2) keeping y_1 unchanged
> YN <- backtransformXYCurve(Y, fit=fit)
> points(YN, col="blue")
> abline(a=0, b=1, col="red", lwd=2)
> 
> proc.time()
   user  system elapsed 
   0.64    0.04    0.67 

aroma.light.Rcheck/tests_i386/iwpca.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ # Simulate data from the model y <- a + bx + eps(bx)
+ x <- rexp(1000)
+ a <- c(2,15,3)
+ b <- c(2,3,4)
+ bx <- outer(b,x)
+ eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
+ y <- a + bx + eps
+ y <- t(y)
+ 
+ # Add some outliers by permuting the dimensions for 1/10 of the observations
+ idx <- sample(1:nrow(y), size=1/10*nrow(y))
+ y[idx,] <- y[idx,c(2,3,1)]
+ 
+ # Plot the data with fitted lines at four different view points
+ opar <- par(mar=c(1,1,1,1)+0.1)
+ N <- 4
+ layout(matrix(1:N, nrow=2, byrow=TRUE))
+ theta <- seq(0,270,length.out=N)
+ phi <- rep(20, length.out=N)
+ xlim <- ylim <- zlim <- c(0,45)
+ persp <- list()
+ for (kk in seq_along(theta)) {
+   # Plot the data
+   persp[[kk]] <- plot3d(y, theta=theta[kk], phi=phi[kk], xlim=xlim, ylim=ylim, zlim=zlim)
+ }
+ 
+ # Weights on the observations
+ # Example a: Equal weights
+ w <- NULL
+ # Example b: More weight on the outliers (uncomment to test)
+ w <- rep(1, length(x)); w[idx] <- 0.8
+ 
+ # ...and show all iterations too with different colors.
+ maxIter <- c(seq(1,20,length.out=10),Inf)
+ col <- topo.colors(length(maxIter))
+ # Show the fitted value for every iteration
+ for (ii in seq_along(maxIter)) {
+   # Fit a line using IWPCA through data
+   fit <- iwpca(y, w=w, maxIter=maxIter[ii], swapDirections=TRUE)
+ 
+   ymid <- fit$xMean
+   d0 <- apply(y, MARGIN=2, FUN=min) - ymid
+   d1 <- apply(y, MARGIN=2, FUN=max) - ymid
+   b <- fit$vt[1,]
+   y0 <- -b * max(abs(d0))
+   y1 <-  b * max(abs(d1))
+   yline <- matrix(c(y0,y1), nrow=length(b), ncol=2)
+   yline <- yline + ymid
+ 
+   for (kk in seq_along(theta)) {
+     # Set pane to draw in
+     par(mfg=c((kk-1) %/% 2, (kk-1) %% 2) + 1)
+     # Set the viewpoint of the pane
+     options(persp.matrix=persp[[kk]])
+ 
+     # Get the first principal component
+     points3d(t(ymid), col=col[ii])
+     lines3d(t(yline), col=col[ii])
+ 
+     # Highlight the last one
+     if (ii == length(maxIter))
+       lines3d(t(yline), col="red", lwd=3)
+   }
+ }
+ 
+ par(opar)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.54    0.03    0.54 

aroma.light.Rcheck/tests_x64/iwpca.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ # Simulate data from the model y <- a + bx + eps(bx)
+ x <- rexp(1000)
+ a <- c(2,15,3)
+ b <- c(2,3,4)
+ bx <- outer(b,x)
+ eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
+ y <- a + bx + eps
+ y <- t(y)
+ 
+ # Add some outliers by permuting the dimensions for 1/10 of the observations
+ idx <- sample(1:nrow(y), size=1/10*nrow(y))
+ y[idx,] <- y[idx,c(2,3,1)]
+ 
+ # Plot the data with fitted lines at four different view points
+ opar <- par(mar=c(1,1,1,1)+0.1)
+ N <- 4
+ layout(matrix(1:N, nrow=2, byrow=TRUE))
+ theta <- seq(0,270,length.out=N)
+ phi <- rep(20, length.out=N)
+ xlim <- ylim <- zlim <- c(0,45)
+ persp <- list()
+ for (kk in seq_along(theta)) {
+   # Plot the data
+   persp[[kk]] <- plot3d(y, theta=theta[kk], phi=phi[kk], xlim=xlim, ylim=ylim, zlim=zlim)
+ }
+ 
+ # Weights on the observations
+ # Example a: Equal weights
+ w <- NULL
+ # Example b: More weight on the outliers (uncomment to test)
+ w <- rep(1, length(x)); w[idx] <- 0.8
+ 
+ # ...and show all iterations too with different colors.
+ maxIter <- c(seq(1,20,length.out=10),Inf)
+ col <- topo.colors(length(maxIter))
+ # Show the fitted value for every iteration
+ for (ii in seq_along(maxIter)) {
+   # Fit a line using IWPCA through data
+   fit <- iwpca(y, w=w, maxIter=maxIter[ii], swapDirections=TRUE)
+ 
+   ymid <- fit$xMean
+   d0 <- apply(y, MARGIN=2, FUN=min) - ymid
+   d1 <- apply(y, MARGIN=2, FUN=max) - ymid
+   b <- fit$vt[1,]
+   y0 <- -b * max(abs(d0))
+   y1 <-  b * max(abs(d1))
+   yline <- matrix(c(y0,y1), nrow=length(b), ncol=2)
+   yline <- yline + ymid
+ 
+   for (kk in seq_along(theta)) {
+     # Set pane to draw in
+     par(mfg=c((kk-1) %/% 2, (kk-1) %% 2) + 1)
+     # Set the viewpoint of the pane
+     options(persp.matrix=persp[[kk]])
+ 
+     # Get the first principal component
+     points3d(t(ymid), col=col[ii])
+     lines3d(t(yline), col=col[ii])
+ 
+     # Highlight the last one
+     if (ii == length(maxIter))
+       lines3d(t(yline), col="red", lwd=3)
+   }
+ }
+ 
+ par(opar)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.48    0.09    0.56 

aroma.light.Rcheck/tests_i386/likelihood.smooth.spline.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Define f(x)
> f <- expression(0.1*x^4 + 1*x^3 + 2*x^2 + x + 10*sin(2*x))
> 
> # Simulate data from this function in the range [a,b]
> a <- -2; b <- 5
> x <- seq(a, b, length.out=3000)
> y <- eval(f)
> 
> # Add some noise to the data
> y <- y + rnorm(length(y), 0, 10)
> 
> # Plot the function and its second derivative
> plot(x,y, type="l", lwd=4)
> 
> # Fit a cubic smoothing spline and plot it
> g <- smooth.spline(x,y, df=16)
> lines(g, col="yellow", lwd=2, lty=2)
> 
> # Calculating the (log) likelihood of the fitted spline
> l <- likelihood(g)
> 
> cat("Log likelihood with unique x values:\n")
Log likelihood with unique x values:
> print(l)
Likelihood of smoothing spline: -312334.7 
 Log base: 2.718282 
 Weighted residuals sum of square: 312334.8 
 Penalty: -0.1219267 
 Smoothing parameter lambda: 0.0009257147 
 Roughness score: 131.7109 
> 
> # Note that this is not the same as the log likelihood of the
> # data on the fitted spline iff the x values are non-unique
> x[1:5] <- x[1]  # Non-unique x values
> g <- smooth.spline(x,y, df=16)
> l <- likelihood(g)
> 
> cat("\nLog likelihood of the *spline* data set:\n")

Log likelihood of the *spline* data set:
> print(l)
Likelihood of smoothing spline: -311380.2 
 Log base: 2.718282 
 Weighted residuals sum of square: 311380.3 
 Penalty: -0.1219875 
 Smoothing parameter lambda: 0.0009261969 
 Roughness score: 131.7079 
> 
> # In cases with non unique x values one has to proceed as
> # below if one want to get the log likelihood for the original
> # data.
> l <- likelihood(g, x=x, y=y)
> cat("\nLog likelihood of the *original* data set:\n")

Log likelihood of the *original* data set:
> print(l)
Likelihood of smoothing spline: -312332.6 
 Log base: 2.718282 
 Weighted residuals sum of square: 312332.8 
 Penalty: -0.121988 
 Smoothing parameter lambda: 0.0009261969 
 Roughness score: 131.7085 
> 
> 
> 
> 
> 
> 
> proc.time()
   user  system elapsed 
   0.46    0.03    0.48 

aroma.light.Rcheck/tests_x64/likelihood.smooth.spline.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Define f(x)
> f <- expression(0.1*x^4 + 1*x^3 + 2*x^2 + x + 10*sin(2*x))
> 
> # Simulate data from this function in the range [a,b]
> a <- -2; b <- 5
> x <- seq(a, b, length.out=3000)
> y <- eval(f)
> 
> # Add some noise to the data
> y <- y + rnorm(length(y), 0, 10)
> 
> # Plot the function and its second derivative
> plot(x,y, type="l", lwd=4)
> 
> # Fit a cubic smoothing spline and plot it
> g <- smooth.spline(x,y, df=16)
> lines(g, col="yellow", lwd=2, lty=2)
> 
> # Calculating the (log) likelihood of the fitted spline
> l <- likelihood(g)
> 
> cat("Log likelihood with unique x values:\n")
Log likelihood with unique x values:
> print(l)
Likelihood of smoothing spline: -296815.7 
 Log base: 2.718282 
 Weighted residuals sum of square: 296815.8 
 Penalty: -0.1194844 
 Smoothing parameter lambda: 0.0009257147 
 Roughness score: 129.0726 
> 
> # Note that this is not the same as the log likelihood of the
> # data on the fitted spline iff the x values are non-unique
> x[1:5] <- x[1]  # Non-unique x values
> g <- smooth.spline(x,y, df=16)
> l <- likelihood(g)
> 
> cat("\nLog likelihood of the *spline* data set:\n")

Log likelihood of the *spline* data set:
> print(l)
Likelihood of smoothing spline: -296212.1 
 Log base: 2.718282 
 Weighted residuals sum of square: 296212.2 
 Penalty: -0.1194463 
 Smoothing parameter lambda: 0.0009261969 
 Roughness score: 128.9643 
> 
> # In cases with non unique x values one has to proceed as
> # below if one want to get the log likelihood for the original
> # data.
> l <- likelihood(g, x=x, y=y)
> cat("\nLog likelihood of the *original* data set:\n")

Log likelihood of the *original* data set:
> print(l)
Likelihood of smoothing spline: -296819.2 
 Log base: 2.718282 
 Weighted residuals sum of square: 296819.3 
 Penalty: -0.1194463 
 Smoothing parameter lambda: 0.0009261969 
 Roughness score: 128.9643 
> 
> 
> 
> 
> 
> 
> proc.time()
   user  system elapsed 
   0.45    0.03    0.46 

aroma.light.Rcheck/tests_i386/medianPolish.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Deaths from sport parachuting;  from ABC of EDA, p.224:
> deaths <- matrix(c(14,15,14, 7,4,7, 8,2,10, 15,9,10, 0,2,0), ncol=3, byrow=TRUE)
> rownames(deaths) <- c("1-24", "25-74", "75-199", "200++", "NA")
> colnames(deaths) <- 1973:1975
> 
> print(deaths)
       1973 1974 1975
1-24     14   15   14
25-74     7    4    7
75-199    8    2   10
200++    15    9   10
NA        0    2    0
> 
> mp <- medianPolish(deaths)
> mp1 <- medpolish(deaths, trace=FALSE)
> print(mp)

Median Polish Results (Dataset: "deaths")

Overall: 8

Row Effects:
  1-24  25-74 75-199  200++     NA 
     6     -1      0      2     -8 

Column Effects:
1973 1974 1975 
   0   -1    0 

Residuals:
       1973 1974 1975
1-24      0    2    0
25-74     0   -2    0
75-199    0   -5    2
200++     5    0    0
NA        0    3    0

> 
> ff <- c("overall", "row", "col", "residuals")
> stopifnot(all.equal(mp[ff], mp1[ff]))
> 
> # Validate decomposition:
> stopifnot(all.equal(deaths, mp$overall+outer(mp$row,mp$col,"+")+mp$resid))
> 
> proc.time()
   user  system elapsed 
   0.23    0.12    0.34 

aroma.light.Rcheck/tests_x64/medianPolish.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Deaths from sport parachuting;  from ABC of EDA, p.224:
> deaths <- matrix(c(14,15,14, 7,4,7, 8,2,10, 15,9,10, 0,2,0), ncol=3, byrow=TRUE)
> rownames(deaths) <- c("1-24", "25-74", "75-199", "200++", "NA")
> colnames(deaths) <- 1973:1975
> 
> print(deaths)
       1973 1974 1975
1-24     14   15   14
25-74     7    4    7
75-199    8    2   10
200++    15    9   10
NA        0    2    0
> 
> mp <- medianPolish(deaths)
> mp1 <- medpolish(deaths, trace=FALSE)
> print(mp)

Median Polish Results (Dataset: "deaths")

Overall: 8

Row Effects:
  1-24  25-74 75-199  200++     NA 
     6     -1      0      2     -8 

Column Effects:
1973 1974 1975 
   0   -1    0 

Residuals:
       1973 1974 1975
1-24      0    2    0
25-74     0   -2    0
75-199    0   -5    2
200++     5    0    0
NA        0    3    0

> 
> ff <- c("overall", "row", "col", "residuals")
> stopifnot(all.equal(mp[ff], mp1[ff]))
> 
> # Validate decomposition:
> stopifnot(all.equal(deaths, mp$overall+outer(mp$row,mp$col,"+")+mp$resid))
> 
> proc.time()
   user  system elapsed 
   0.42    0.06    0.46 

aroma.light.Rcheck/tests_i386/normalizeAffine.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pathname <- system.file("data-ex", "PMT-RGData.dat", package="aroma.light")
> rg <- read.table(pathname, header=TRUE, sep="\t")
> nbrOfScans <- max(rg$slide)
> 
> rg <- as.list(rg)
> for (field in c("R", "G"))
+   rg[[field]] <- matrix(as.double(rg[[field]]), ncol=nbrOfScans)
> rg$slide <- rg$spot <- NULL
> rg <- as.matrix(as.data.frame(rg))
> colnames(rg) <- rep(c("R", "G"), each=nbrOfScans)
> 
> rgC <- rg
> 
> layout(matrix(c(1,2,0,3,4,0,5,6,7), ncol=3, byrow=TRUE))
> 
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   channelColor <- switch(channel, R="red", G="green")
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The raw data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   plotMvsAPairs(rg, channel=channel)
+   title(main=paste("Observed", channel))
+   box(col=channelColor)
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The calibrated data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   rgC[,sidx] <- calibrateMultiscan(rg[,sidx], average=NULL)
+ 
+   plotMvsAPairs(rgC, channel=channel)
+   title(main=paste("Calibrated", channel))
+   box(col=channelColor)
+ } # for (channel ...)
There were 50 or more warnings (use warnings() to see the first 50)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The average calibrated data
> #
> # Note how the red signals are weaker than the green. The reason
> # for this can be that the scale factor in the green channel is
> # greater than in the red channel, but it can also be that there
> # is a remaining relative difference in bias between the green
> # and the red channel, a bias that precedes the scanning.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCA <- matrix(NA_real_, nrow=nrow(rg), ncol=2)
> colnames(rgCA) <- c("R", "G")
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCA[,channel] <- calibrateMultiscan(rg[,sidx])
+ }
> 
> plotMvsA(rgCA)
> title(main="Average calibrated")
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The affine normalized average calibrated data
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Create a matrix where the columns represent the channels
> # to be normalized.
> rgCAN <- rgCA
> # Affine normalization of channels
> rgCAN <- normalizeAffine(rgCAN)
> 
> plotMvsA(rgCAN)
> title(main="Affine normalized A.C.")
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # It is always ok to rescale the affine normalized data if its
> # done on (R,G); not on (A,M)! However, this is only needed for
> # esthetic purposes.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCAN <- rgCAN * 2^5
> plotMvsA(rgCAN)
> title(main="Rescaled normalized")
> 
> 
> 
> proc.time()
   user  system elapsed 
   3.59    0.18    3.75 

aroma.light.Rcheck/tests_x64/normalizeAffine.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pathname <- system.file("data-ex", "PMT-RGData.dat", package="aroma.light")
> rg <- read.table(pathname, header=TRUE, sep="\t")
> nbrOfScans <- max(rg$slide)
> 
> rg <- as.list(rg)
> for (field in c("R", "G"))
+   rg[[field]] <- matrix(as.double(rg[[field]]), ncol=nbrOfScans)
> rg$slide <- rg$spot <- NULL
> rg <- as.matrix(as.data.frame(rg))
> colnames(rg) <- rep(c("R", "G"), each=nbrOfScans)
> 
> rgC <- rg
> 
> layout(matrix(c(1,2,0,3,4,0,5,6,7), ncol=3, byrow=TRUE))
> 
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   channelColor <- switch(channel, R="red", G="green")
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The raw data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   plotMvsAPairs(rg, channel=channel)
+   title(main=paste("Observed", channel))
+   box(col=channelColor)
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The calibrated data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   rgC[,sidx] <- calibrateMultiscan(rg[,sidx], average=NULL)
+ 
+   plotMvsAPairs(rgC, channel=channel)
+   title(main=paste("Calibrated", channel))
+   box(col=channelColor)
+ } # for (channel ...)
There were 50 or more warnings (use warnings() to see the first 50)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The average calibrated data
> #
> # Note how the red signals are weaker than the green. The reason
> # for this can be that the scale factor in the green channel is
> # greater than in the red channel, but it can also be that there
> # is a remaining relative difference in bias between the green
> # and the red channel, a bias that precedes the scanning.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCA <- matrix(NA_real_, nrow=nrow(rg), ncol=2)
> colnames(rgCA) <- c("R", "G")
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCA[,channel] <- calibrateMultiscan(rg[,sidx])
+ }
> 
> plotMvsA(rgCA)
> title(main="Average calibrated")
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The affine normalized average calibrated data
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Create a matrix where the columns represent the channels
> # to be normalized.
> rgCAN <- rgCA
> # Affine normalization of channels
> rgCAN <- normalizeAffine(rgCAN)
> 
> plotMvsA(rgCAN)
> title(main="Affine normalized A.C.")
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # It is always ok to rescale the affine normalized data if its
> # done on (R,G); not on (A,M)! However, this is only needed for
> # esthetic purposes.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCAN <- rgCAN * 2^5
> plotMvsA(rgCAN)
> title(main="Rescaled normalized")
> 
> 
> 
> proc.time()
   user  system elapsed 
   2.95    0.14    3.07 

aroma.light.Rcheck/tests_i386/normalizeAverage.list.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate ten samples of different lengths
> N <- 10000
> X <- list()
> for (kk in 1:8) {
+   rfcn <- list(rnorm, rgamma)[[sample(2, size=1)]]
+   size <- runif(1, min=0.3, max=1)
+   a <- rgamma(1, shape=20, rate=10)
+   b <- rgamma(1, shape=10, rate=10)
+   values <- rfcn(size*N, a, b)
+ 
+   # "Censor" values
+   values[values < 0 | values > 8] <- NA_real_
+ 
+   X[[kk]] <- values
+ }
> 
> # Add 20% missing values
> X <- lapply(X, FUN=function(x) {
+   x[sample(length(x), size=0.20*length(x))] <- NA_real_
+   x
+ })
> 
> # Normalize quantiles
> Xn <- normalizeAverage(X, na.rm=TRUE, targetAvg=median(unlist(X), na.rm=TRUE))
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.65    0.07    0.70 

aroma.light.Rcheck/tests_x64/normalizeAverage.list.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate ten samples of different lengths
> N <- 10000
> X <- list()
> for (kk in 1:8) {
+   rfcn <- list(rnorm, rgamma)[[sample(2, size=1)]]
+   size <- runif(1, min=0.3, max=1)
+   a <- rgamma(1, shape=20, rate=10)
+   b <- rgamma(1, shape=10, rate=10)
+   values <- rfcn(size*N, a, b)
+ 
+   # "Censor" values
+   values[values < 0 | values > 8] <- NA_real_
+ 
+   X[[kk]] <- values
+ }
> 
> # Add 20% missing values
> X <- lapply(X, FUN=function(x) {
+   x[sample(length(x), size=0.20*length(x))] <- NA_real_
+   x
+ })
> 
> # Normalize quantiles
> Xn <- normalizeAverage(X, na.rm=TRUE, targetAvg=median(unlist(X), na.rm=TRUE))
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.62    0.09    0.71 

aroma.light.Rcheck/tests_i386/normalizeAverage.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Normalize quantiles
> Xn <- normalizeAverage(X, na.rm=TRUE, targetAvg=median(X, na.rm=TRUE))
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.46    0.10    0.56 

aroma.light.Rcheck/tests_x64/normalizeAverage.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Normalize quantiles
> Xn <- normalizeAverage(X, na.rm=TRUE, targetAvg=median(X, na.rm=TRUE))
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.54    0.06    0.60 

aroma.light.Rcheck/tests_i386/normalizeCurveFit.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pathname <- system.file("data-ex", "PMT-RGData.dat", package="aroma.light")
> rg <- read.table(pathname, header=TRUE, sep="\t")
> nbrOfScans <- max(rg$slide)
> 
> rg <- as.list(rg)
> for (field in c("R", "G"))
+   rg[[field]] <- matrix(as.double(rg[[field]]), ncol=nbrOfScans)
> rg$slide <- rg$spot <- NULL
> rg <- as.matrix(as.data.frame(rg))
> colnames(rg) <- rep(c("R", "G"), each=nbrOfScans)
> 
> layout(matrix(c(1,2,0,3,4,0,5,6,7), ncol=3, byrow=TRUE))
> 
> rgC <- rg
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   channelColor <- switch(channel, R="red", G="green")
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The raw data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   plotMvsAPairs(rg[,sidx])
+   title(main=paste("Observed", channel))
+   box(col=channelColor)
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The calibrated data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   rgC[,sidx] <- calibrateMultiscan(rg[,sidx], average=NULL)
+ 
+   plotMvsAPairs(rgC[,sidx])
+   title(main=paste("Calibrated", channel))
+   box(col=channelColor)
+ } # for (channel ...)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The average calibrated data
> #
> # Note how the red signals are weaker than the green. The reason
> # for this can be that the scale factor in the green channel is
> # greater than in the red channel, but it can also be that there
> # is a remaining relative difference in bias between the green
> # and the red channel, a bias that precedes the scanning.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCA <- rg
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCA[,sidx] <- calibrateMultiscan(rg[,sidx])
+ }
> 
> rgCAavg <- matrix(NA_real_, nrow=nrow(rgCA), ncol=2)
> colnames(rgCAavg) <- c("R", "G")
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCAavg[,channel] <- apply(rgCA[,sidx], MARGIN=1, FUN=median, na.rm=TRUE)
+ }
> 
> # Add some "fake" outliers
> outliers <- 1:600
> rgCAavg[outliers,"G"] <- 50000
> 
> plotMvsA(rgCAavg)
> title(main="Average calibrated (AC)")
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Normalize data
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Weight-down outliers when normalizing
> weights <- rep(1, nrow(rgCAavg))
> weights[outliers] <- 0.001
> 
> # Affine normalization of channels
> rgCANa <- normalizeAffine(rgCAavg, weights=weights)
> # It is always ok to rescale the affine normalized data if its
> # done on (R,G); not on (A,M)! However, this is only needed for
> # esthetic purposes.
> rgCANa <- rgCANa *2^1.4
> plotMvsA(rgCANa)
> title(main="Normalized AC")
> 
> # Curve-fit (lowess) normalization
> rgCANlw <- normalizeLowess(rgCAavg, weights=weights)
Warning message:
In normalizeCurveFit.matrix(X, method = "lowess", ...) :
  Weights were rounded to {0,1} since 'lowess' normalization supports only zero-one weights.
> plotMvsA(rgCANlw, col="orange", add=TRUE)
> 
> # Curve-fit (loess) normalization
> rgCANl <- normalizeLoess(rgCAavg, weights=weights)
> plotMvsA(rgCANl, col="red", add=TRUE)
> 
> # Curve-fit (robust spline) normalization
> rgCANrs <- normalizeRobustSpline(rgCAavg, weights=weights)
> plotMvsA(rgCANrs, col="blue", add=TRUE)
> 
> legend(x=0,y=16, legend=c("affine", "lowess", "loess", "r. spline"), pch=19,
+        col=c("black", "orange", "red", "blue"), ncol=2, x.intersp=0.3, bty="n")
> 
> 
> plotMvsMPairs(cbind(rgCANa, rgCANlw), col="orange", xlab=expression(M[affine]))
> title(main="Normalized AC")
> plotMvsMPairs(cbind(rgCANa, rgCANl), col="red", add=TRUE)
> plotMvsMPairs(cbind(rgCANa, rgCANrs), col="blue", add=TRUE)
> abline(a=0, b=1, lty=2)
> legend(x=-6,y=6, legend=c("lowess", "loess", "r. spline"), pch=19,
+        col=c("orange", "red", "blue"), ncol=2, x.intersp=0.3, bty="n")
> 
> 
> proc.time()
   user  system elapsed 
   7.75    0.12    7.84 

aroma.light.Rcheck/tests_x64/normalizeCurveFit.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pathname <- system.file("data-ex", "PMT-RGData.dat", package="aroma.light")
> rg <- read.table(pathname, header=TRUE, sep="\t")
> nbrOfScans <- max(rg$slide)
> 
> rg <- as.list(rg)
> for (field in c("R", "G"))
+   rg[[field]] <- matrix(as.double(rg[[field]]), ncol=nbrOfScans)
> rg$slide <- rg$spot <- NULL
> rg <- as.matrix(as.data.frame(rg))
> colnames(rg) <- rep(c("R", "G"), each=nbrOfScans)
> 
> layout(matrix(c(1,2,0,3,4,0,5,6,7), ncol=3, byrow=TRUE))
> 
> rgC <- rg
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   channelColor <- switch(channel, R="red", G="green")
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The raw data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   plotMvsAPairs(rg[,sidx])
+   title(main=paste("Observed", channel))
+   box(col=channelColor)
+ 
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   # The calibrated data
+   # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+   rgC[,sidx] <- calibrateMultiscan(rg[,sidx], average=NULL)
+ 
+   plotMvsAPairs(rgC[,sidx])
+   title(main=paste("Calibrated", channel))
+   box(col=channelColor)
+ } # for (channel ...)
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # The average calibrated data
> #
> # Note how the red signals are weaker than the green. The reason
> # for this can be that the scale factor in the green channel is
> # greater than in the red channel, but it can also be that there
> # is a remaining relative difference in bias between the green
> # and the red channel, a bias that precedes the scanning.
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> rgCA <- rg
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCA[,sidx] <- calibrateMultiscan(rg[,sidx])
+ }
> 
> rgCAavg <- matrix(NA_real_, nrow=nrow(rgCA), ncol=2)
> colnames(rgCAavg) <- c("R", "G")
> for (channel in c("R", "G")) {
+   sidx <- which(colnames(rg) == channel)
+   rgCAavg[,channel] <- apply(rgCA[,sidx], MARGIN=1, FUN=median, na.rm=TRUE)
+ }
> 
> # Add some "fake" outliers
> outliers <- 1:600
> rgCAavg[outliers,"G"] <- 50000
> 
> plotMvsA(rgCAavg)
> title(main="Average calibrated (AC)")
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Normalize data
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Weight-down outliers when normalizing
> weights <- rep(1, nrow(rgCAavg))
> weights[outliers] <- 0.001
> 
> # Affine normalization of channels
> rgCANa <- normalizeAffine(rgCAavg, weights=weights)
> # It is always ok to rescale the affine normalized data if its
> # done on (R,G); not on (A,M)! However, this is only needed for
> # esthetic purposes.
> rgCANa <- rgCANa *2^1.4
> plotMvsA(rgCANa)
> title(main="Normalized AC")
> 
> # Curve-fit (lowess) normalization
> rgCANlw <- normalizeLowess(rgCAavg, weights=weights)
Warning message:
In normalizeCurveFit.matrix(X, method = "lowess", ...) :
  Weights were rounded to {0,1} since 'lowess' normalization supports only zero-one weights.
> plotMvsA(rgCANlw, col="orange", add=TRUE)
> 
> # Curve-fit (loess) normalization
> rgCANl <- normalizeLoess(rgCAavg, weights=weights)
> plotMvsA(rgCANl, col="red", add=TRUE)
> 
> # Curve-fit (robust spline) normalization
> rgCANrs <- normalizeRobustSpline(rgCAavg, weights=weights)
> plotMvsA(rgCANrs, col="blue", add=TRUE)
> 
> legend(x=0,y=16, legend=c("affine", "lowess", "loess", "r. spline"), pch=19,
+        col=c("black", "orange", "red", "blue"), ncol=2, x.intersp=0.3, bty="n")
> 
> 
> plotMvsMPairs(cbind(rgCANa, rgCANlw), col="orange", xlab=expression(M[affine]))
> title(main="Normalized AC")
> plotMvsMPairs(cbind(rgCANa, rgCANl), col="red", add=TRUE)
> plotMvsMPairs(cbind(rgCANa, rgCANrs), col="blue", add=TRUE)
> abline(a=0, b=1, lty=2)
> legend(x=-6,y=6, legend=c("lowess", "loess", "r. spline"), pch=19,
+        col=c("orange", "red", "blue"), ncol=2, x.intersp=0.3, bty="n")
> 
> 
> proc.time()
   user  system elapsed 
   7.14    0.07    7.20 

aroma.light.Rcheck/tests_i386/normalizeDifferencesToAverage.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three shifted tracks of different lengths with same profiles
> ns <- c(A=2, B=1, C=0.25)*1000
> xx <- lapply(ns, FUN=function(n) { seq(from=1, to=max(ns), length.out=n) })
> zz <- mapply(seq_along(ns), ns, FUN=function(z,n) rep(z,n))
> 
> yy <- list(
+   A = rnorm(ns["A"], mean=0, sd=0.5),
+   B = rnorm(ns["B"], mean=5, sd=0.4),
+   C = rnorm(ns["C"], mean=-5, sd=1.1)
+ )
> yy <- lapply(yy, FUN=function(y) {
+   n <- length(y)
+   y[1:(n/2)] <- y[1:(n/2)] + 2
+   y[1:(n/4)] <- y[1:(n/4)] - 4
+   y
+ })
> 
> # Shift all tracks toward the first track
> yyN <- normalizeDifferencesToAverage(yy, baseline=1)
> 
> # The baseline channel is not changed
> stopifnot(identical(yy[[1]], yyN[[1]]))
> 
> # Get the estimated parameters
> fit <- attr(yyN, "fit")
> 
> # Plot the tracks
> layout(matrix(1:2, ncol=1))
> x <- unlist(xx)
> col <- unlist(zz)
> y <- unlist(yy)
> yN <- unlist(yyN)
> plot(x, y, col=col, ylim=c(-10,10))
> plot(x, yN, col=col, ylim=c(-10,10))
> 
> proc.time()
   user  system elapsed 
   0.64    0.01    0.64 

aroma.light.Rcheck/tests_x64/normalizeDifferencesToAverage.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three shifted tracks of different lengths with same profiles
> ns <- c(A=2, B=1, C=0.25)*1000
> xx <- lapply(ns, FUN=function(n) { seq(from=1, to=max(ns), length.out=n) })
> zz <- mapply(seq_along(ns), ns, FUN=function(z,n) rep(z,n))
> 
> yy <- list(
+   A = rnorm(ns["A"], mean=0, sd=0.5),
+   B = rnorm(ns["B"], mean=5, sd=0.4),
+   C = rnorm(ns["C"], mean=-5, sd=1.1)
+ )
> yy <- lapply(yy, FUN=function(y) {
+   n <- length(y)
+   y[1:(n/2)] <- y[1:(n/2)] + 2
+   y[1:(n/4)] <- y[1:(n/4)] - 4
+   y
+ })
> 
> # Shift all tracks toward the first track
> yyN <- normalizeDifferencesToAverage(yy, baseline=1)
> 
> # The baseline channel is not changed
> stopifnot(identical(yy[[1]], yyN[[1]]))
> 
> # Get the estimated parameters
> fit <- attr(yyN, "fit")
> 
> # Plot the tracks
> layout(matrix(1:2, ncol=1))
> x <- unlist(xx)
> col <- unlist(zz)
> y <- unlist(yy)
> yN <- unlist(yyN)
> plot(x, y, col=col, ylim=c(-10,10))
> plot(x, yN, col=col, ylim=c(-10,10))
> 
> proc.time()
   user  system elapsed 
   0.73    0.07    0.79 

aroma.light.Rcheck/tests_i386/normalizeFragmentLength-ex1.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Example 1: Single-enzyme fragment-length normalization of 6 arrays
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Number samples
> I <- 9
> 
> # Number of loci
> J <- 1000
> 
> # Fragment lengths
> fl <- seq(from=100, to=1000, length.out=J)
> 
> # Simulate data points with unknown fragment lengths
> hasUnknownFL <- seq(from=1, to=J, by=50)
> fl[hasUnknownFL] <- NA_real_
> 
> # Simulate data
> y <- matrix(0, nrow=J, ncol=I)
> maxY <- 12
> for (kk in 1:I) {
+   k <- runif(n=1, min=3, max=5)
+   mu <- function(fl) {
+     mu <- rep(maxY, length(fl))
+     ok <- !is.na(fl)
+     mu[ok] <- mu[ok] - fl[ok]^{1/k}
+     mu
+   }
+   eps <- rnorm(J, mean=0, sd=1)
+   y[,kk] <- mu(fl) + eps
+ }
> 
> # Normalize data (to a zero baseline)
> yN <- apply(y, MARGIN=2, FUN=function(y) {
+   normalizeFragmentLength(y, fragmentLengths=fl, onMissing="median")
+ })
> 
> # The correction factors
> rho <- y-yN
> print(summary(rho))
       V1              V2              V3              V4       
 Min.   :7.527   Min.   :4.441   Min.   :7.412   Min.   :7.787  
 1st Qu.:7.754   1st Qu.:5.056   1st Qu.:7.565   1st Qu.:8.006  
 Median :8.056   Median :5.707   Median :7.796   Median :8.233  
 Mean   :8.145   Mean   :5.891   Mean   :7.988   Mean   :8.354  
 3rd Qu.:8.507   3rd Qu.:6.691   3rd Qu.:8.379   3rd Qu.:8.672  
 Max.   :9.060   Max.   :7.882   Max.   :9.113   Max.   :9.295  
       V5              V6              V7              V8       
 Min.   :2.056   Min.   :6.159   Min.   :5.140   Min.   :7.273  
 1st Qu.:2.943   1st Qu.:6.580   1st Qu.:5.715   1st Qu.:7.516  
 Median :3.939   Median :7.063   Median :6.288   Median :7.785  
 Mean   :4.165   Mean   :7.153   Mean   :6.450   Mean   :7.917  
 3rd Qu.:5.306   3rd Qu.:7.705   3rd Qu.:7.159   3rd Qu.:8.299  
 Max.   :7.068   Max.   :8.422   Max.   :8.240   Max.   :8.918  
       V9       
 Min.   :5.837  
 1st Qu.:6.327  
 Median :6.825  
 Mean   :6.937  
 3rd Qu.:7.518  
 Max.   :8.405  
> # The correction for units with unknown fragment lengths
> # equals the median correction factor of all other units
> print(summary(rho[hasUnknownFL,]))
       V1              V2              V3              V4       
 Min.   :8.056   Min.   :5.707   Min.   :7.796   Min.   :8.233  
 1st Qu.:8.056   1st Qu.:5.707   1st Qu.:7.796   1st Qu.:8.233  
 Median :8.056   Median :5.707   Median :7.796   Median :8.233  
 Mean   :8.056   Mean   :5.707   Mean   :7.796   Mean   :8.233  
 3rd Qu.:8.056   3rd Qu.:5.707   3rd Qu.:7.796   3rd Qu.:8.233  
 Max.   :8.056   Max.   :5.707   Max.   :7.796   Max.   :8.233  
       V5              V6              V7              V8       
 Min.   :3.939   Min.   :7.063   Min.   :6.288   Min.   :7.785  
 1st Qu.:3.939   1st Qu.:7.063   1st Qu.:6.288   1st Qu.:7.785  
 Median :3.939   Median :7.063   Median :6.288   Median :7.785  
 Mean   :3.939   Mean   :7.063   Mean   :6.288   Mean   :7.785  
 3rd Qu.:3.939   3rd Qu.:7.063   3rd Qu.:6.288   3rd Qu.:7.785  
 Max.   :3.939   Max.   :7.063   Max.   :6.288   Max.   :7.785  
       V9       
 Min.   :6.825  
 1st Qu.:6.825  
 Median :6.825  
 Mean   :6.825  
 3rd Qu.:6.825  
 Max.   :6.825  
> 
> # Plot raw data
> layout(matrix(1:9, ncol=3))
> xlim <- c(0,max(fl, na.rm=TRUE))
> ylim <- c(0,max(y, na.rm=TRUE))
> xlab <- "Fragment length"
> ylab <- expression(log2(theta))
> for (kk in 1:I) {
+   plot(fl, y[,kk], xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab)
+   ok <- (is.finite(fl) & is.finite(y[,kk]))
+   lines(lowess(fl[ok], y[ok,kk]), col="red", lwd=2)
+ }
> 
> # Plot normalized data
> layout(matrix(1:9, ncol=3))
> ylim <- c(-1,1)*max(y, na.rm=TRUE)/2
> for (kk in 1:I) {
+   plot(fl, yN[,kk], xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab)
+   ok <- (is.finite(fl) & is.finite(y[,kk]))
+   lines(lowess(fl[ok], yN[ok,kk]), col="blue", lwd=2)
+ }
> 
> proc.time()
   user  system elapsed 
   1.17    0.03    1.18 

aroma.light.Rcheck/tests_x64/normalizeFragmentLength-ex1.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Example 1: Single-enzyme fragment-length normalization of 6 arrays
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Number samples
> I <- 9
> 
> # Number of loci
> J <- 1000
> 
> # Fragment lengths
> fl <- seq(from=100, to=1000, length.out=J)
> 
> # Simulate data points with unknown fragment lengths
> hasUnknownFL <- seq(from=1, to=J, by=50)
> fl[hasUnknownFL] <- NA_real_
> 
> # Simulate data
> y <- matrix(0, nrow=J, ncol=I)
> maxY <- 12
> for (kk in 1:I) {
+   k <- runif(n=1, min=3, max=5)
+   mu <- function(fl) {
+     mu <- rep(maxY, length(fl))
+     ok <- !is.na(fl)
+     mu[ok] <- mu[ok] - fl[ok]^{1/k}
+     mu
+   }
+   eps <- rnorm(J, mean=0, sd=1)
+   y[,kk] <- mu(fl) + eps
+ }
> 
> # Normalize data (to a zero baseline)
> yN <- apply(y, MARGIN=2, FUN=function(y) {
+   normalizeFragmentLength(y, fragmentLengths=fl, onMissing="median")
+ })
> 
> # The correction factors
> rho <- y-yN
> print(summary(rho))
       V1              V2              V3              V4       
 Min.   :7.957   Min.   :6.876   Min.   :7.806   Min.   :2.176  
 1st Qu.:8.202   1st Qu.:7.199   1st Qu.:8.084   1st Qu.:3.012  
 Median :8.436   Median :7.615   Median :8.383   Median :3.966  
 Mean   :8.542   Mean   :7.717   Mean   :8.446   Mean   :4.211  
 3rd Qu.:8.858   3rd Qu.:8.215   3rd Qu.:8.801   3rd Qu.:5.343  
 Max.   :9.441   Max.   :8.871   Max.   :9.270   Max.   :7.045  
       V5              V6              V7              V8       
 Min.   :7.169   Min.   :2.435   Min.   :7.935   Min.   :7.377  
 1st Qu.:7.549   1st Qu.:3.155   1st Qu.:8.117   1st Qu.:7.572  
 Median :7.939   Median :4.127   Median :8.376   Median :7.859  
 Mean   :7.982   Mean   :4.335   Mean   :8.465   Mean   :7.994  
 3rd Qu.:8.390   3rd Qu.:5.432   3rd Qu.:8.768   3rd Qu.:8.364  
 Max.   :8.988   Max.   :6.984   Max.   :9.327   Max.   :9.085  
       V9       
 Min.   :8.049  
 1st Qu.:8.233  
 Median :8.452  
 Mean   :8.534  
 3rd Qu.:8.820  
 Max.   :9.264  
> # The correction for units with unknown fragment lengths
> # equals the median correction factor of all other units
> print(summary(rho[hasUnknownFL,]))
       V1              V2              V3              V4       
 Min.   :8.436   Min.   :7.615   Min.   :8.383   Min.   :3.966  
 1st Qu.:8.436   1st Qu.:7.615   1st Qu.:8.383   1st Qu.:3.966  
 Median :8.436   Median :7.615   Median :8.383   Median :3.966  
 Mean   :8.436   Mean   :7.615   Mean   :8.383   Mean   :3.966  
 3rd Qu.:8.436   3rd Qu.:7.615   3rd Qu.:8.383   3rd Qu.:3.966  
 Max.   :8.436   Max.   :7.615   Max.   :8.383   Max.   :3.966  
       V5              V6              V7              V8       
 Min.   :7.939   Min.   :4.127   Min.   :8.376   Min.   :7.859  
 1st Qu.:7.939   1st Qu.:4.127   1st Qu.:8.376   1st Qu.:7.859  
 Median :7.939   Median :4.127   Median :8.376   Median :7.859  
 Mean   :7.939   Mean   :4.127   Mean   :8.376   Mean   :7.859  
 3rd Qu.:7.939   3rd Qu.:4.127   3rd Qu.:8.376   3rd Qu.:7.859  
 Max.   :7.939   Max.   :4.127   Max.   :8.376   Max.   :7.859  
       V9       
 Min.   :8.452  
 1st Qu.:8.452  
 Median :8.452  
 Mean   :8.452  
 3rd Qu.:8.452  
 Max.   :8.452  
> 
> # Plot raw data
> layout(matrix(1:9, ncol=3))
> xlim <- c(0,max(fl, na.rm=TRUE))
> ylim <- c(0,max(y, na.rm=TRUE))
> xlab <- "Fragment length"
> ylab <- expression(log2(theta))
> for (kk in 1:I) {
+   plot(fl, y[,kk], xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab)
+   ok <- (is.finite(fl) & is.finite(y[,kk]))
+   lines(lowess(fl[ok], y[ok,kk]), col="red", lwd=2)
+ }
> 
> # Plot normalized data
> layout(matrix(1:9, ncol=3))
> ylim <- c(-1,1)*max(y, na.rm=TRUE)/2
> for (kk in 1:I) {
+   plot(fl, yN[,kk], xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab)
+   ok <- (is.finite(fl) & is.finite(y[,kk]))
+   lines(lowess(fl[ok], yN[ok,kk]), col="blue", lwd=2)
+ }
> 
> proc.time()
   user  system elapsed 
   1.31    0.07    1.37 

aroma.light.Rcheck/tests_i386/normalizeFragmentLength-ex2.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Example 2: Two-enzyme fragment-length normalization of 6 arrays
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> set.seed(0xbeef)
> 
> # Number samples
> I <- 5
> 
> # Number of loci
> J <- 3000
> 
> # Fragment lengths (two enzymes)
> fl <- matrix(0, nrow=J, ncol=2)
> fl[,1] <- seq(from=100, to=1000, length.out=J)
> fl[,2] <- seq(from=1000, to=100, length.out=J)
> 
> # Let 1/2 of the units be on both enzymes
> fl[seq(from=1, to=J, by=4),1] <- NA_real_
> fl[seq(from=2, to=J, by=4),2] <- NA_real_
> 
> # Let some have unknown fragment lengths
> hasUnknownFL <- seq(from=1, to=J, by=15)
> fl[hasUnknownFL,] <- NA_real_
> 
> # Sty/Nsp mixing proportions:
> rho <- rep(1, I)
> rho[1] <- 1/3;  # Less Sty in 1st sample
> rho[3] <- 3/2;  # More Sty in 3rd sample
> 
> 
> # Simulate data
> z <- array(0, dim=c(J,2,I))
> maxLog2Theta <- 12
> for (ii in 1:I) {
+   # Common effect for both enzymes
+   mu <- function(fl) {
+     k <- runif(n=1, min=3, max=5)
+     mu <- rep(maxLog2Theta, length(fl))
+     ok <- is.finite(fl)
+     mu[ok] <- mu[ok] - fl[ok]^{1/k}
+     mu
+   }
+ 
+   # Calculate the effect for each data point
+   for (ee in 1:2) {
+     z[,ee,ii] <- mu(fl[,ee])
+   }
+ 
+   # Update the Sty/Nsp mixing proportions
+   ee <- 2
+   z[,ee,ii] <- rho[ii]*z[,ee,ii]
+ 
+   # Add random errors
+   for (ee in 1:2) {
+     eps <- rnorm(J, mean=0, sd=1/sqrt(2))
+     z[,ee,ii] <- z[,ee,ii] + eps
+   }
+ }
> 
> 
> hasFl <- is.finite(fl)
> 
> unitSets <- list(
+   nsp  = which( hasFl[,1] & !hasFl[,2]),
+   sty  = which(!hasFl[,1] &  hasFl[,2]),
+   both = which( hasFl[,1] &  hasFl[,2]),
+   none = which(!hasFl[,1] & !hasFl[,2])
+ )
> 
> # The observed data is a mix of two enzymes
> theta <- matrix(NA_real_, nrow=J, ncol=I)
> 
> # Single-enzyme units
> for (ee in 1:2) {
+   uu <- unitSets[[ee]]
+   theta[uu,] <- 2^z[uu,ee,]
+ }
> 
> # Both-enzyme units (sum on intensity scale)
> uu <- unitSets$both
> theta[uu,] <- (2^z[uu,1,]+2^z[uu,2,])/2
> 
> # Missing units (sample from the others)
> uu <- unitSets$none
> theta[uu,] <- apply(theta, MARGIN=2, sample, size=length(uu))
> 
> # Calculate target array
> thetaT <- rowMeans(theta, na.rm=TRUE)
> targetFcns <- list()
> for (ee in 1:2) {
+   uu <- unitSets[[ee]]
+   fit <- lowess(fl[uu,ee], log2(thetaT[uu]))
+   class(fit) <- "lowess"
+   targetFcns[[ee]] <- function(fl, ...) {
+     predict(fit, newdata=fl)
+   }
+ }
> 
> 
> # Fit model only to a subset of the data
> subsetToFit <- setdiff(1:J, seq(from=1, to=J, by=10))
> 
> # Normalize data (to a target baseline)
> thetaN <- matrix(NA_real_, nrow=J, ncol=I)
> fits <- vector("list", I)
> for (ii in 1:I) {
+   lthetaNi <- normalizeFragmentLength(log2(theta[,ii]), targetFcns=targetFcns,
+                      fragmentLengths=fl, onMissing="median",
+                      subsetToFit=subsetToFit, .returnFit=TRUE)
+   fits[[ii]] <- attr(lthetaNi, "modelFit")
+   thetaN[,ii] <- 2^lthetaNi
+ }
> 
> 
> # Plot raw data
> xlim <- c(0, max(fl, na.rm=TRUE))
> ylim <- c(0, max(log2(theta), na.rm=TRUE))
> Mlim <- c(-1,1)*4
> xlab <- "Fragment length"
> ylab <- expression(log2(theta))
> Mlab <- expression(M==log[2](theta/theta[R]))
> 
> layout(matrix(1:(3*I), ncol=I, byrow=TRUE))
> for (ii in 1:I) {
+   plot(NA, xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab, main="raw")
+ 
+   # Single-enzyme units
+   for (ee in 1:2) {
+     # The raw data
+     uu <- unitSets[[ee]]
+     points(fl[uu,ee], log2(theta[uu,ii]), col=ee+1)
+   }
+ 
+   # Both-enzyme units (use fragment-length for enzyme #1)
+   uu <- unitSets$both
+   points(fl[uu,1], log2(theta[uu,ii]), col=3+1)
+ 
+   for (ee in 1:2) {
+     # The true effects
+     uu <- unitSets[[ee]]
+     lines(lowess(fl[uu,ee], log2(theta[uu,ii])), col="black", lwd=4, lty=3)
+ 
+     # The estimated effects
+     fit <- fits[[ii]][[ee]]$fit
+     lines(fit, col="orange", lwd=3)
+ 
+     muT <- targetFcns[[ee]](fl[uu,ee])
+     lines(fl[uu,ee], muT, col="cyan", lwd=1)
+   }
+ }
> 
> # Calculate log-ratios
> thetaR <- rowMeans(thetaN, na.rm=TRUE)
> M <- log2(thetaN/thetaR)
> 
> # Plot normalized data
> for (ii in 1:I) {
+   plot(NA, xlim=xlim, ylim=Mlim, xlab=xlab, ylab=Mlab, main="normalized")
+   # Single-enzyme units
+   for (ee in 1:2) {
+     # The normalized data
+     uu <- unitSets[[ee]]
+     points(fl[uu,ee], M[uu,ii], col=ee+1)
+   }
+   # Both-enzyme units (use fragment-length for enzyme #1)
+   uu <- unitSets$both
+   points(fl[uu,1], M[uu,ii], col=3+1)
+ }
> 
> ylim <- c(0,1.5)
> for (ii in 1:I) {
+   data <- list()
+   for (ee in 1:2) {
+     # The normalized data
+     uu <- unitSets[[ee]]
+     data[[ee]] <- M[uu,ii]
+   }
+   uu <- unitSets$both
+   if (length(uu) > 0)
+     data[[3]] <- M[uu,ii]
+ 
+   uu <- unitSets$none
+   if (length(uu) > 0)
+     data[[4]] <- M[uu,ii]
+ 
+   cols <- seq_along(data)+1
+   plotDensity(data, col=cols, xlim=Mlim, xlab=Mlab, main="normalized")
+ 
+   abline(v=0, lty=2)
+ }
> 
> 
> proc.time()
   user  system elapsed 
   1.43    0.06    1.48 

aroma.light.Rcheck/tests_x64/normalizeFragmentLength-ex2.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Example 2: Two-enzyme fragment-length normalization of 6 arrays
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> set.seed(0xbeef)
> 
> # Number samples
> I <- 5
> 
> # Number of loci
> J <- 3000
> 
> # Fragment lengths (two enzymes)
> fl <- matrix(0, nrow=J, ncol=2)
> fl[,1] <- seq(from=100, to=1000, length.out=J)
> fl[,2] <- seq(from=1000, to=100, length.out=J)
> 
> # Let 1/2 of the units be on both enzymes
> fl[seq(from=1, to=J, by=4),1] <- NA_real_
> fl[seq(from=2, to=J, by=4),2] <- NA_real_
> 
> # Let some have unknown fragment lengths
> hasUnknownFL <- seq(from=1, to=J, by=15)
> fl[hasUnknownFL,] <- NA_real_
> 
> # Sty/Nsp mixing proportions:
> rho <- rep(1, I)
> rho[1] <- 1/3;  # Less Sty in 1st sample
> rho[3] <- 3/2;  # More Sty in 3rd sample
> 
> 
> # Simulate data
> z <- array(0, dim=c(J,2,I))
> maxLog2Theta <- 12
> for (ii in 1:I) {
+   # Common effect for both enzymes
+   mu <- function(fl) {
+     k <- runif(n=1, min=3, max=5)
+     mu <- rep(maxLog2Theta, length(fl))
+     ok <- is.finite(fl)
+     mu[ok] <- mu[ok] - fl[ok]^{1/k}
+     mu
+   }
+ 
+   # Calculate the effect for each data point
+   for (ee in 1:2) {
+     z[,ee,ii] <- mu(fl[,ee])
+   }
+ 
+   # Update the Sty/Nsp mixing proportions
+   ee <- 2
+   z[,ee,ii] <- rho[ii]*z[,ee,ii]
+ 
+   # Add random errors
+   for (ee in 1:2) {
+     eps <- rnorm(J, mean=0, sd=1/sqrt(2))
+     z[,ee,ii] <- z[,ee,ii] + eps
+   }
+ }
> 
> 
> hasFl <- is.finite(fl)
> 
> unitSets <- list(
+   nsp  = which( hasFl[,1] & !hasFl[,2]),
+   sty  = which(!hasFl[,1] &  hasFl[,2]),
+   both = which( hasFl[,1] &  hasFl[,2]),
+   none = which(!hasFl[,1] & !hasFl[,2])
+ )
> 
> # The observed data is a mix of two enzymes
> theta <- matrix(NA_real_, nrow=J, ncol=I)
> 
> # Single-enzyme units
> for (ee in 1:2) {
+   uu <- unitSets[[ee]]
+   theta[uu,] <- 2^z[uu,ee,]
+ }
> 
> # Both-enzyme units (sum on intensity scale)
> uu <- unitSets$both
> theta[uu,] <- (2^z[uu,1,]+2^z[uu,2,])/2
> 
> # Missing units (sample from the others)
> uu <- unitSets$none
> theta[uu,] <- apply(theta, MARGIN=2, sample, size=length(uu))
> 
> # Calculate target array
> thetaT <- rowMeans(theta, na.rm=TRUE)
> targetFcns <- list()
> for (ee in 1:2) {
+   uu <- unitSets[[ee]]
+   fit <- lowess(fl[uu,ee], log2(thetaT[uu]))
+   class(fit) <- "lowess"
+   targetFcns[[ee]] <- function(fl, ...) {
+     predict(fit, newdata=fl)
+   }
+ }
> 
> 
> # Fit model only to a subset of the data
> subsetToFit <- setdiff(1:J, seq(from=1, to=J, by=10))
> 
> # Normalize data (to a target baseline)
> thetaN <- matrix(NA_real_, nrow=J, ncol=I)
> fits <- vector("list", I)
> for (ii in 1:I) {
+   lthetaNi <- normalizeFragmentLength(log2(theta[,ii]), targetFcns=targetFcns,
+                      fragmentLengths=fl, onMissing="median",
+                      subsetToFit=subsetToFit, .returnFit=TRUE)
+   fits[[ii]] <- attr(lthetaNi, "modelFit")
+   thetaN[,ii] <- 2^lthetaNi
+ }
> 
> 
> # Plot raw data
> xlim <- c(0, max(fl, na.rm=TRUE))
> ylim <- c(0, max(log2(theta), na.rm=TRUE))
> Mlim <- c(-1,1)*4
> xlab <- "Fragment length"
> ylab <- expression(log2(theta))
> Mlab <- expression(M==log[2](theta/theta[R]))
> 
> layout(matrix(1:(3*I), ncol=I, byrow=TRUE))
> for (ii in 1:I) {
+   plot(NA, xlim=xlim, ylim=ylim, xlab=xlab, ylab=ylab, main="raw")
+ 
+   # Single-enzyme units
+   for (ee in 1:2) {
+     # The raw data
+     uu <- unitSets[[ee]]
+     points(fl[uu,ee], log2(theta[uu,ii]), col=ee+1)
+   }
+ 
+   # Both-enzyme units (use fragment-length for enzyme #1)
+   uu <- unitSets$both
+   points(fl[uu,1], log2(theta[uu,ii]), col=3+1)
+ 
+   for (ee in 1:2) {
+     # The true effects
+     uu <- unitSets[[ee]]
+     lines(lowess(fl[uu,ee], log2(theta[uu,ii])), col="black", lwd=4, lty=3)
+ 
+     # The estimated effects
+     fit <- fits[[ii]][[ee]]$fit
+     lines(fit, col="orange", lwd=3)
+ 
+     muT <- targetFcns[[ee]](fl[uu,ee])
+     lines(fl[uu,ee], muT, col="cyan", lwd=1)
+   }
+ }
> 
> # Calculate log-ratios
> thetaR <- rowMeans(thetaN, na.rm=TRUE)
> M <- log2(thetaN/thetaR)
> 
> # Plot normalized data
> for (ii in 1:I) {
+   plot(NA, xlim=xlim, ylim=Mlim, xlab=xlab, ylab=Mlab, main="normalized")
+   # Single-enzyme units
+   for (ee in 1:2) {
+     # The normalized data
+     uu <- unitSets[[ee]]
+     points(fl[uu,ee], M[uu,ii], col=ee+1)
+   }
+   # Both-enzyme units (use fragment-length for enzyme #1)
+   uu <- unitSets$both
+   points(fl[uu,1], M[uu,ii], col=3+1)
+ }
> 
> ylim <- c(0,1.5)
> for (ii in 1:I) {
+   data <- list()
+   for (ee in 1:2) {
+     # The normalized data
+     uu <- unitSets[[ee]]
+     data[[ee]] <- M[uu,ii]
+   }
+   uu <- unitSets$both
+   if (length(uu) > 0)
+     data[[3]] <- M[uu,ii]
+ 
+   uu <- unitSets$none
+   if (length(uu) > 0)
+     data[[4]] <- M[uu,ii]
+ 
+   cols <- seq_along(data)+1
+   plotDensity(data, col=cols, xlim=Mlim, xlab=Mlab, main="normalized")
+ 
+   abline(v=0, lty=2)
+ }
> 
> 
> proc.time()
   user  system elapsed 
   1.32    0.04    1.36 

aroma.light.Rcheck/tests_i386/normalizeQuantileRank.list.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate ten samples of different lengths
> N <- 10000
> X <- list()
> for (kk in 1:8) {
+   rfcn <- list(rnorm, rgamma)[[sample(2, size=1)]]
+   size <- runif(1, min=0.3, max=1)
+   a <- rgamma(1, shape=20, rate=10)
+   b <- rgamma(1, shape=10, rate=10)
+   values <- rfcn(size*N, a, b)
+ 
+   # "Censor" values
+   values[values < 0 | values > 8] <- NA_real_
+ 
+   X[[kk]] <- values
+ }
> 
> # Add 20% missing values
> X <- lapply(X, FUN=function(x) {
+   x[sample(length(x), size=0.20*length(x))] <- NA_real_
+   x
+ })
> 
> # Normalize quantiles
> Xn <- normalizeQuantile(X)
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.45    0.03    0.46 

aroma.light.Rcheck/tests_x64/normalizeQuantileRank.list.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate ten samples of different lengths
> N <- 10000
> X <- list()
> for (kk in 1:8) {
+   rfcn <- list(rnorm, rgamma)[[sample(2, size=1)]]
+   size <- runif(1, min=0.3, max=1)
+   a <- rgamma(1, shape=20, rate=10)
+   b <- rgamma(1, shape=10, rate=10)
+   values <- rfcn(size*N, a, b)
+ 
+   # "Censor" values
+   values[values < 0 | values > 8] <- NA_real_
+ 
+   X[[kk]] <- values
+ }
> 
> # Add 20% missing values
> X <- lapply(X, FUN=function(x) {
+   x[sample(length(x), size=0.20*length(x))] <- NA_real_
+   x
+ })
> 
> # Normalize quantiles
> Xn <- normalizeQuantile(X)
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.65    0.06    0.70 

aroma.light.Rcheck/tests_i386/normalizeQuantileRank.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Normalize quantiles
> Xn <- normalizeQuantile(X)
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.56    0.09    0.62 

aroma.light.Rcheck/tests_x64/normalizeQuantileRank.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Normalize quantiles
> Xn <- normalizeQuantile(X)
> 
> # Plot the data
> layout(matrix(1:2, ncol=1))
> xlim <- range(X, Xn, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   0.35    0.09    0.43 

aroma.light.Rcheck/tests_i386/normalizeQuantileSpline.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Plot the data
> layout(matrix(c(1,0,2:5), ncol=2, byrow=TRUE))
> xlim <- range(X, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> 
> Xn <- normalizeQuantile(X)
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> plotXYCurve(X, Xn, xlim=xlim, main="The three normalized distributions")
> 
> Xn2 <- normalizeQuantileSpline(X, xTarget=Xn[,1], spar=0.99)
> plotDensity(Xn2, lwd=2, xlim=xlim, main="The three normalized distributions")
> plotXYCurve(X, Xn2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   1.65    0.17    1.79 

aroma.light.Rcheck/tests_x64/normalizeQuantileSpline.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate three samples with on average 20% missing values
> N <- 10000
> X <- cbind(rnorm(N, mean=3, sd=1),
+            rnorm(N, mean=4, sd=2),
+            rgamma(N, shape=2, rate=1))
> X[sample(3*N, size=0.20*3*N)] <- NA_real_
> 
> # Plot the data
> layout(matrix(c(1,0,2:5), ncol=2, byrow=TRUE))
> xlim <- range(X, na.rm=TRUE)
> plotDensity(X, lwd=2, xlim=xlim, main="The three original distributions")
> 
> Xn <- normalizeQuantile(X)
> plotDensity(Xn, lwd=2, xlim=xlim, main="The three normalized distributions")
> plotXYCurve(X, Xn, xlim=xlim, main="The three normalized distributions")
> 
> Xn2 <- normalizeQuantileSpline(X, xTarget=Xn[,1], spar=0.99)
> plotDensity(Xn2, lwd=2, xlim=xlim, main="The three normalized distributions")
> plotXYCurve(X, Xn2, xlim=xlim, main="The three normalized distributions")
> 
> proc.time()
   user  system elapsed 
   1.20    0.15    1.34 

aroma.light.Rcheck/tests_i386/normalizeTumorBoost.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> library("R.utils")
Loading required package: R.oo
Loading required package: R.methodsS3
R.methodsS3 v1.8.1 (2020-08-26 16:20:06 UTC) successfully loaded. See ?R.methodsS3 for help.
R.oo v1.24.0 (2020-08-26 16:11:58 UTC) successfully loaded. See ?R.oo for help.

Attaching package: 'R.oo'

The following object is masked from 'package:R.methodsS3':

    throw

The following objects are masked from 'package:methods':

    getClasses, getMethods

The following objects are masked from 'package:base':

    attach, detach, load, save

R.utils v2.10.1 (2020-08-26 22:50:31 UTC) successfully loaded. See ?R.utils for help.

Attaching package: 'R.utils'

The following object is masked from 'package:utils':

    timestamp

The following objects are masked from 'package:base':

    cat, commandArgs, getOption, inherits, isOpen, nullfile, parse,
    warnings

> 
> # Load data
> pathname <- system.file("data-ex/TumorBoost,fracB,exampleData.Rbin", package="aroma.light")
> data <- loadObject(pathname)
> attachLocally(data)
> pos <- position/1e6
> muN <- genotypeN
> 
> layout(matrix(1:4, ncol=1))
> par(mar=c(2.5,4,0.5,1)+0.1)
> ylim <- c(-0.05, 1.05)
> col <- rep("#999999", length(muN))
> col[muN == 1/2] <- "#000000"
> 
> # Allele B fractions for the normal sample
> plot(pos, betaN, col=col, ylim=ylim)
> 
> # Allele B fractions for the tumor sample
> plot(pos, betaT, col=col, ylim=ylim)
> 
> # TumorBoost w/ naive genotype calls
> betaTN <- normalizeTumorBoost(betaT=betaT, betaN=betaN, preserveScale=FALSE)
> plot(pos, betaTN, col=col, ylim=ylim)
> 
> # TumorBoost w/ external multi-sample genotype calls
> betaTNx <- normalizeTumorBoost(betaT=betaT, betaN=betaN, muN=muN, preserveScale=FALSE)
> plot(pos, betaTNx, col=col, ylim=ylim)
> 
> proc.time()
   user  system elapsed 
   0.71    0.12    0.82 

aroma.light.Rcheck/tests_x64/normalizeTumorBoost.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> library("R.utils")
Loading required package: R.oo
Loading required package: R.methodsS3
R.methodsS3 v1.8.1 (2020-08-26 16:20:06 UTC) successfully loaded. See ?R.methodsS3 for help.
R.oo v1.24.0 (2020-08-26 16:11:58 UTC) successfully loaded. See ?R.oo for help.

Attaching package: 'R.oo'

The following object is masked from 'package:R.methodsS3':

    throw

The following objects are masked from 'package:methods':

    getClasses, getMethods

The following objects are masked from 'package:base':

    attach, detach, load, save

R.utils v2.10.1 (2020-08-26 22:50:31 UTC) successfully loaded. See ?R.utils for help.

Attaching package: 'R.utils'

The following object is masked from 'package:utils':

    timestamp

The following objects are masked from 'package:base':

    cat, commandArgs, getOption, inherits, isOpen, nullfile, parse,
    warnings

> 
> # Load data
> pathname <- system.file("data-ex/TumorBoost,fracB,exampleData.Rbin", package="aroma.light")
> data <- loadObject(pathname)
> attachLocally(data)
> pos <- position/1e6
> muN <- genotypeN
> 
> layout(matrix(1:4, ncol=1))
> par(mar=c(2.5,4,0.5,1)+0.1)
> ylim <- c(-0.05, 1.05)
> col <- rep("#999999", length(muN))
> col[muN == 1/2] <- "#000000"
> 
> # Allele B fractions for the normal sample
> plot(pos, betaN, col=col, ylim=ylim)
> 
> # Allele B fractions for the tumor sample
> plot(pos, betaT, col=col, ylim=ylim)
> 
> # TumorBoost w/ naive genotype calls
> betaTN <- normalizeTumorBoost(betaT=betaT, betaN=betaN, preserveScale=FALSE)
> plot(pos, betaTN, col=col, ylim=ylim)
> 
> # TumorBoost w/ external multi-sample genotype calls
> betaTNx <- normalizeTumorBoost(betaT=betaT, betaN=betaN, muN=muN, preserveScale=FALSE)
> plot(pos, betaTNx, col=col, ylim=ylim)
> 
> proc.time()
   user  system elapsed 
   0.82    0.04    0.85 

aroma.light.Rcheck/tests_i386/normalizeTumorBoost,flavors.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> library("R.utils")
Loading required package: R.oo
Loading required package: R.methodsS3
R.methodsS3 v1.8.1 (2020-08-26 16:20:06 UTC) successfully loaded. See ?R.methodsS3 for help.
R.oo v1.24.0 (2020-08-26 16:11:58 UTC) successfully loaded. See ?R.oo for help.

Attaching package: 'R.oo'

The following object is masked from 'package:R.methodsS3':

    throw

The following objects are masked from 'package:methods':

    getClasses, getMethods

The following objects are masked from 'package:base':

    attach, detach, load, save

R.utils v2.10.1 (2020-08-26 22:50:31 UTC) successfully loaded. See ?R.utils for help.

Attaching package: 'R.utils'

The following object is masked from 'package:utils':

    timestamp

The following objects are masked from 'package:base':

    cat, commandArgs, getOption, inherits, isOpen, nullfile, parse,
    warnings

> 
> # Load data
> pathname <- system.file("data-ex/TumorBoost,fracB,exampleData.Rbin", package="aroma.light")
> data <- loadObject(pathname)
> 
> # Drop loci with missing values
> data <- na.omit(data)
> 
> attachLocally(data)
> pos <- position/1e6
> 
> # Call naive genotypes
> muN <- callNaiveGenotypes(betaN)
> 
> # Genotype classes
> isAA <- (muN == 0)
> isAB <- (muN == 1/2)
> isBB <- (muN == 1)
> 
> # Sanity checks
> stopifnot(all(muN[isAA] == 0))
> stopifnot(all(muN[isAB] == 1/2))
> stopifnot(all(muN[isBB] == 1))
> 
> # TumorBoost normalization with different flavors
> betaTNs <- list()
> for (flavor in c("v1", "v2", "v3", "v4")) {
+   betaTN <- normalizeTumorBoost(betaT=betaT, betaN=betaN, preserveScale=FALSE, flavor=flavor)
+ 
+   # Assert that no non-finite values are introduced
+   stopifnot(all(is.finite(betaTN)))
+ 
+   # Assert that nothing is flipped
+   stopifnot(all(betaTN[isAA] < 1/2))
+   stopifnot(all(betaTN[isBB] > 1/2))
+ 
+   betaTNs[[flavor]] <- betaTN
+ }
> 
> # Plot
> layout(matrix(1:4, ncol=1))
> par(mar=c(2.5,4,0.5,1)+0.1)
> ylim <- c(-0.05, 1.05)
> col <- rep("#999999", length(muN))
> col[muN == 1/2] <- "#000000"
> for (flavor in names(betaTNs)) {
+   betaTN <- betaTNs[[flavor]]
+   ylab <- sprintf("betaTN[%s]", flavor)
+   plot(pos, betaTN, col=col, ylim=ylim, ylab=ylab)
+ }
> 
> proc.time()
   user  system elapsed 
   1.04    0.03    1.06 

aroma.light.Rcheck/tests_x64/normalizeTumorBoost,flavors.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> library("R.utils")
Loading required package: R.oo
Loading required package: R.methodsS3
R.methodsS3 v1.8.1 (2020-08-26 16:20:06 UTC) successfully loaded. See ?R.methodsS3 for help.
R.oo v1.24.0 (2020-08-26 16:11:58 UTC) successfully loaded. See ?R.oo for help.

Attaching package: 'R.oo'

The following object is masked from 'package:R.methodsS3':

    throw

The following objects are masked from 'package:methods':

    getClasses, getMethods

The following objects are masked from 'package:base':

    attach, detach, load, save

R.utils v2.10.1 (2020-08-26 22:50:31 UTC) successfully loaded. See ?R.utils for help.

Attaching package: 'R.utils'

The following object is masked from 'package:utils':

    timestamp

The following objects are masked from 'package:base':

    cat, commandArgs, getOption, inherits, isOpen, nullfile, parse,
    warnings

> 
> # Load data
> pathname <- system.file("data-ex/TumorBoost,fracB,exampleData.Rbin", package="aroma.light")
> data <- loadObject(pathname)
> 
> # Drop loci with missing values
> data <- na.omit(data)
> 
> attachLocally(data)
> pos <- position/1e6
> 
> # Call naive genotypes
> muN <- callNaiveGenotypes(betaN)
> 
> # Genotype classes
> isAA <- (muN == 0)
> isAB <- (muN == 1/2)
> isBB <- (muN == 1)
> 
> # Sanity checks
> stopifnot(all(muN[isAA] == 0))
> stopifnot(all(muN[isAB] == 1/2))
> stopifnot(all(muN[isBB] == 1))
> 
> # TumorBoost normalization with different flavors
> betaTNs <- list()
> for (flavor in c("v1", "v2", "v3", "v4")) {
+   betaTN <- normalizeTumorBoost(betaT=betaT, betaN=betaN, preserveScale=FALSE, flavor=flavor)
+ 
+   # Assert that no non-finite values are introduced
+   stopifnot(all(is.finite(betaTN)))
+ 
+   # Assert that nothing is flipped
+   stopifnot(all(betaTN[isAA] < 1/2))
+   stopifnot(all(betaTN[isBB] > 1/2))
+ 
+   betaTNs[[flavor]] <- betaTN
+ }
> 
> # Plot
> layout(matrix(1:4, ncol=1))
> par(mar=c(2.5,4,0.5,1)+0.1)
> ylim <- c(-0.05, 1.05)
> col <- rep("#999999", length(muN))
> col[muN == 1/2] <- "#000000"
> for (flavor in names(betaTNs)) {
+   betaTN <- betaTNs[[flavor]]
+   ylab <- sprintf("betaTN[%s]", flavor)
+   plot(pos, betaTN, col=col, ylim=ylim, ylab=ylab)
+ }
> 
> proc.time()
   user  system elapsed 
   0.92    0.12    1.03 

aroma.light.Rcheck/tests_i386/robustSmoothSpline.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> data(cars)
> attach(cars)
> plot(speed, dist, main = "data(cars)  &  robust smoothing splines")
> 
> # Fit a smoothing spline using L_2 norm
> cars.spl <- smooth.spline(speed, dist)
> lines(cars.spl, col = "blue")
> 
> # Fit a smoothing spline using L_1 norm
> cars.rspl <- robustSmoothSpline(speed, dist)
> lines(cars.rspl, col = "red")
> 
> # Fit a smoothing spline using L_2 norm with 10 degrees of freedom
> lines(smooth.spline(speed, dist, df=10), lty=2, col = "blue")
> 
> # Fit a smoothing spline using L_1 norm with 10 degrees of freedom
> lines(robustSmoothSpline(speed, dist, df=10), lty=2, col = "red")
> 
> # Fit a smoothing spline using Tukey's biweight norm
> cars.rspl <- robustSmoothSpline(speed, dist, method = "symmetric")
> lines(cars.rspl, col = "purple")
> 
> legend(5,120, c(
+       paste("smooth.spline [C.V.] => df =",round(cars.spl$df,1)),
+       paste("robustSmoothSpline L1 [C.V.] => df =",round(cars.rspl$df,1)),
+       paste("robustSmoothSpline symmetric [C.V.] => df =",round(cars.rspl$df,1)),
+       "standard with s( * , df = 10)", "robust with s( * , df = 10)"
+     ),
+     col = c("blue","red","purple","blue","red"), lty = c(1,1,1,2,2),
+     bg='bisque')
> 
> proc.time()
   user  system elapsed 
   0.43    0.14    0.56 

aroma.light.Rcheck/tests_x64/robustSmoothSpline.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> data(cars)
> attach(cars)
> plot(speed, dist, main = "data(cars)  &  robust smoothing splines")
> 
> # Fit a smoothing spline using L_2 norm
> cars.spl <- smooth.spline(speed, dist)
> lines(cars.spl, col = "blue")
> 
> # Fit a smoothing spline using L_1 norm
> cars.rspl <- robustSmoothSpline(speed, dist)
> lines(cars.rspl, col = "red")
> 
> # Fit a smoothing spline using L_2 norm with 10 degrees of freedom
> lines(smooth.spline(speed, dist, df=10), lty=2, col = "blue")
> 
> # Fit a smoothing spline using L_1 norm with 10 degrees of freedom
> lines(robustSmoothSpline(speed, dist, df=10), lty=2, col = "red")
> 
> # Fit a smoothing spline using Tukey's biweight norm
> cars.rspl <- robustSmoothSpline(speed, dist, method = "symmetric")
> lines(cars.rspl, col = "purple")
> 
> legend(5,120, c(
+       paste("smooth.spline [C.V.] => df =",round(cars.spl$df,1)),
+       paste("robustSmoothSpline L1 [C.V.] => df =",round(cars.rspl$df,1)),
+       paste("robustSmoothSpline symmetric [C.V.] => df =",round(cars.rspl$df,1)),
+       "standard with s( * , df = 10)", "robust with s( * , df = 10)"
+     ),
+     col = c("blue","red","purple","blue","red"), lty = c(1,1,1,2,2),
+     bg='bisque')
> 
> proc.time()
   user  system elapsed 
   0.45    0.10    0.54 

aroma.light.Rcheck/tests_i386/rowAverages.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> X <- matrix(1:30, nrow=5L, ncol=6L)
> mu <- rowMeans(X)
> sd <- apply(X, MARGIN=1L, FUN=sd)
> 
> y <- rowAverages(X)
> stopifnot(all(y == mu))
> stopifnot(all(attr(y,"deviance") == sd))
> stopifnot(all(attr(y,"df") == ncol(X)))
> 
> proc.time()
   user  system elapsed 
   0.48    0.07    0.53 

aroma.light.Rcheck/tests_x64/rowAverages.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> X <- matrix(1:30, nrow=5L, ncol=6L)
> mu <- rowMeans(X)
> sd <- apply(X, MARGIN=1L, FUN=sd)
> 
> y <- rowAverages(X)
> stopifnot(all(y == mu))
> stopifnot(all(attr(y,"deviance") == sd))
> stopifnot(all(attr(y,"df") == ncol(X)))
> 
> proc.time()
   user  system elapsed 
   0.37    0.07    0.43 

aroma.light.Rcheck/tests_i386/sampleCorrelations.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate 20000 genes with 10 observations each
> X <- matrix(rnorm(n=20000), ncol=10)
> 
> # Calculate the correlation for 5000 random gene pairs
> cor <- sampleCorrelations(X, npairs=5000)
> print(summary(cor))
     Min.   1st Qu.    Median      Mean   3rd Qu.      Max. 
-0.909423 -0.248601 -0.005881 -0.005239  0.234393  0.888320 
> 
> 
> proc.time()
   user  system elapsed 
   0.70    0.18    0.85 

aroma.light.Rcheck/tests_x64/sampleCorrelations.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # Simulate 20000 genes with 10 observations each
> X <- matrix(rnorm(n=20000), ncol=10)
> 
> # Calculate the correlation for 5000 random gene pairs
> cor <- sampleCorrelations(X, npairs=5000)
> print(summary(cor))
      Min.    1st Qu.     Median       Mean    3rd Qu.       Max. 
-0.8572080 -0.2435865  0.0017469 -0.0001762  0.2410705  0.9169056 
> 
> 
> proc.time()
   user  system elapsed 
   0.70    0.03    0.71 

aroma.light.Rcheck/tests_i386/sampleTuples.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pairs <- sampleTuples(1:10, size=5, length=2)
> print(pairs)
     [,1] [,2]
[1,]    2   10
[2,]    7    2
[3,]    8    3
[4,]    1    7
[5,]    7    5
> 
> triples <- sampleTuples(1:10, size=5, length=3)
> print(triples)
     [,1] [,2] [,3]
[1,]    3    4    8
[2,]    8    3    1
[3,]    3    6    8
[4,]    3    7    4
[5,]   10    9    7
> 
> # Allow tuples with repeated elements
> quadruples <- sampleTuples(1:3, size=5, length=4, replace=TRUE)
> print(quadruples)
     [,1] [,2] [,3] [,4]
[1,]    1    2    3    1
[2,]    2    3    1    3
[3,]    2    3    1    2
[4,]    2    1    2    3
[5,]    1    1    3    2
> 
> proc.time()
   user  system elapsed 
   0.35    0.10    0.45 

aroma.light.Rcheck/tests_x64/sampleTuples.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> pairs <- sampleTuples(1:10, size=5, length=2)
> print(pairs)
     [,1] [,2]
[1,]    1    8
[2,]    6    5
[3,]    3    8
[4,]    2    1
[5,]    4    6
> 
> triples <- sampleTuples(1:10, size=5, length=3)
> print(triples)
     [,1] [,2] [,3]
[1,]    9    7   10
[2,]    8   10    3
[3,]   10    2    6
[4,]    6    4    9
[5,]    5    4    9
> 
> # Allow tuples with repeated elements
> quadruples <- sampleTuples(1:3, size=5, length=4, replace=TRUE)
> print(quadruples)
     [,1] [,2] [,3] [,4]
[1,]    1    3    1    1
[2,]    1    2    3    3
[3,]    1    1    2    2
[4,]    3    1    2    3
[5,]    2    3    1    1
> 
> proc.time()
   user  system elapsed 
   0.37    0.09    0.45 

aroma.light.Rcheck/tests_i386/wpca.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ # -------------------------------------------------------------
+ # A first example
+ # -------------------------------------------------------------
+ # Simulate data from the model y <- a + bx + eps(bx)
+ x <- rexp(1000)
+ a <- c(2,15,3)
+ b <- c(2,3,15)
+ bx <- outer(b,x)
+ eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
+ y <- a + bx + eps
+ y <- t(y)
+ 
+ # Add some outliers by permuting the dimensions for 1/3 of the observations
+ idx <- sample(1:nrow(y), size=1/3*nrow(y))
+ y[idx,] <- y[idx,c(2,3,1)]
+ 
+ # Down-weight the outliers W times to demonstrate how weights are used
+ W <- 10
+ 
+ # Plot the data with fitted lines at four different view points
+ N <- 4
+ theta <- seq(0,180,length.out=N)
+ phi <- rep(30, length.out=N)
+ 
+ # Use a different color for each set of weights
+ col <- topo.colors(W)
+ 
+ opar <- par(mar=c(1,1,1,1)+0.1)
+ layout(matrix(1:N, nrow=2, byrow=TRUE))
+ for (kk in seq(theta)) {
+   # Plot the data
+   plot3d(y, theta=theta[kk], phi=phi[kk])
+ 
+   # First, same weights for all observations
+   w <- rep(1, length=nrow(y))
+ 
+   for (ww in 1:W) {
+     # Fit a line using IWPCA through data
+     fit <- wpca(y, w=w, swapDirections=TRUE)
+ 
+     # Get the first principal component
+     ymid <- fit$xMean
+     d0 <- apply(y, MARGIN=2, FUN=min) - ymid
+     d1 <- apply(y, MARGIN=2, FUN=max) - ymid
+     b <- fit$vt[1,]
+     y0 <- -b * max(abs(d0))
+     y1 <-  b * max(abs(d1))
+     yline <- matrix(c(y0,y1), nrow=length(b), ncol=2)
+     yline <- yline + ymid
+ 
+     points3d(t(ymid), col=col)
+     lines3d(t(yline), col=col)
+ 
+     # Down-weight outliers only, because here we know which they are.
+     w[idx] <- w[idx]/2
+   }
+ 
+   # Highlight the last one
+   lines3d(t(yline), col="red", lwd=3)
+ }
+ 
+ par(opar)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.48    0.06    0.53 

aroma.light.Rcheck/tests_x64/wpca.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> for (zzz in 0) {
+ 
+ # This example requires plot3d() in R.basic [http://www.braju.com/R/]
+ if (!require(pkgName <- "R.basic", character.only=TRUE)) break
+ 
+ # -------------------------------------------------------------
+ # A first example
+ # -------------------------------------------------------------
+ # Simulate data from the model y <- a + bx + eps(bx)
+ x <- rexp(1000)
+ a <- c(2,15,3)
+ b <- c(2,3,15)
+ bx <- outer(b,x)
+ eps <- apply(bx, MARGIN=2, FUN=function(x) rnorm(length(x), mean=0, sd=0.1*x))
+ y <- a + bx + eps
+ y <- t(y)
+ 
+ # Add some outliers by permuting the dimensions for 1/3 of the observations
+ idx <- sample(1:nrow(y), size=1/3*nrow(y))
+ y[idx,] <- y[idx,c(2,3,1)]
+ 
+ # Down-weight the outliers W times to demonstrate how weights are used
+ W <- 10
+ 
+ # Plot the data with fitted lines at four different view points
+ N <- 4
+ theta <- seq(0,180,length.out=N)
+ phi <- rep(30, length.out=N)
+ 
+ # Use a different color for each set of weights
+ col <- topo.colors(W)
+ 
+ opar <- par(mar=c(1,1,1,1)+0.1)
+ layout(matrix(1:N, nrow=2, byrow=TRUE))
+ for (kk in seq(theta)) {
+   # Plot the data
+   plot3d(y, theta=theta[kk], phi=phi[kk])
+ 
+   # First, same weights for all observations
+   w <- rep(1, length=nrow(y))
+ 
+   for (ww in 1:W) {
+     # Fit a line using IWPCA through data
+     fit <- wpca(y, w=w, swapDirections=TRUE)
+ 
+     # Get the first principal component
+     ymid <- fit$xMean
+     d0 <- apply(y, MARGIN=2, FUN=min) - ymid
+     d1 <- apply(y, MARGIN=2, FUN=max) - ymid
+     b <- fit$vt[1,]
+     y0 <- -b * max(abs(d0))
+     y1 <-  b * max(abs(d1))
+     yline <- matrix(c(y0,y1), nrow=length(b), ncol=2)
+     yline <- yline + ymid
+ 
+     points3d(t(ymid), col=col)
+     lines3d(t(yline), col=col)
+ 
+     # Down-weight outliers only, because here we know which they are.
+     w[idx] <- w[idx]/2
+   }
+ 
+   # Highlight the last one
+   lines3d(t(yline), col="red", lwd=3)
+ }
+ 
+ par(opar)
+ 
+ } # for (zzz in 0)
Loading required package: R.basic
Warning message:
In library(package, lib.loc = lib.loc, character.only = TRUE, logical.return = TRUE,  :
  there is no package called 'R.basic'
> rm(zzz)
> 
> proc.time()
   user  system elapsed 
   0.34    0.01    0.35 

aroma.light.Rcheck/tests_i386/wpca2.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: i386-w64-mingw32/i386 (32-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # -------------------------------------------------------------
> # A second example
> # -------------------------------------------------------------
> # Data
> x <- c(1,2,3,4,5)
> y <- c(2,4,3,3,6)
> 
> opar <- par(bty="L")
> opalette <- palette(c("blue", "red", "black"))
> xlim <- ylim <- c(0,6)
> 
> # Plot the data and the center mass
> plot(x,y, pch=16, cex=1.5, xlim=xlim, ylim=ylim)
> points(mean(x), mean(y), cex=2, lwd=2, col="blue")
> 
> 
> # Linear regression y ~ x
> fit <- lm(y ~ x)
> abline(fit, lty=1, col=1)
> 
> # Linear regression y ~ x through without intercept
> fit <- lm(y ~ x - 1)
> abline(fit, lty=2, col=1)
> 
> 
> # Linear regression x ~ y
> fit <- lm(x ~ y)
> c <- coefficients(fit)
> b <- 1/c[2]
> a <- -b*c[1]
> abline(a=a, b=b, lty=1, col=2)
> 
> # Linear regression x ~ y through without intercept
> fit <- lm(x ~ y - 1)
> b <- 1/coefficients(fit)
> abline(a=0, b=b, lty=2, col=2)
> 
> 
> # Orthogonal linear "regression"
> fit <- wpca(cbind(x,y))
> 
> b <- fit$vt[1,2]/fit$vt[1,1]
> a <- fit$xMean[2]-b*fit$xMean[1]
> abline(a=a, b=b, lwd=2, col=3)
> 
> # Orthogonal linear "regression" without intercept
> fit <- wpca(cbind(x,y), center=FALSE)
> b <- fit$vt[1,2]/fit$vt[1,1]
> a <- fit$xMean[2]-b*fit$xMean[1]
> abline(a=a, b=b, lty=2, lwd=2, col=3)
> 
> legend(xlim[1],ylim[2], legend=c("lm(y~x)", "lm(y~x-1)", "lm(x~y)",
+           "lm(x~y-1)", "pca", "pca w/o intercept"), lty=rep(1:2,3),
+                      lwd=rep(c(1,1,2),each=2), col=rep(1:3,each=2))
> 
> palette(opalette)
> par(opar)
> 
> proc.time()
   user  system elapsed 
   0.48    0.04    0.50 

aroma.light.Rcheck/tests_x64/wpca2.matrix.Rout


R version 4.0.3 (2020-10-10) -- "Bunny-Wunnies Freak Out"
Copyright (C) 2020 The R Foundation for Statistical Computing
Platform: x86_64-w64-mingw32/x64 (64-bit)

R is free software and comes with ABSOLUTELY NO WARRANTY.
You are welcome to redistribute it under certain conditions.
Type 'license()' or 'licence()' for distribution details.

R is a collaborative project with many contributors.
Type 'contributors()' for more information and
'citation()' on how to cite R or R packages in publications.

Type 'demo()' for some demos, 'help()' for on-line help, or
'help.start()' for an HTML browser interface to help.
Type 'q()' to quit R.

> library("aroma.light")
aroma.light v3.18.0 successfully loaded. See ?aroma.light for help.
> 
> # -------------------------------------------------------------
> # A second example
> # -------------------------------------------------------------
> # Data
> x <- c(1,2,3,4,5)
> y <- c(2,4,3,3,6)
> 
> opar <- par(bty="L")
> opalette <- palette(c("blue", "red", "black"))
> xlim <- ylim <- c(0,6)
> 
> # Plot the data and the center mass
> plot(x,y, pch=16, cex=1.5, xlim=xlim, ylim=ylim)
> points(mean(x), mean(y), cex=2, lwd=2, col="blue")
> 
> 
> # Linear regression y ~ x
> fit <- lm(y ~ x)
> abline(fit, lty=1, col=1)
> 
> # Linear regression y ~ x through without intercept
> fit <- lm(y ~ x - 1)
> abline(fit, lty=2, col=1)
> 
> 
> # Linear regression x ~ y
> fit <- lm(x ~ y)
> c <- coefficients(fit)
> b <- 1/c[2]
> a <- -b*c[1]
> abline(a=a, b=b, lty=1, col=2)
> 
> # Linear regression x ~ y through without intercept
> fit <- lm(x ~ y - 1)
> b <- 1/coefficients(fit)
> abline(a=0, b=b, lty=2, col=2)
> 
> 
> # Orthogonal linear "regression"
> fit <- wpca(cbind(x,y))
> 
> b <- fit$vt[1,2]/fit$vt[1,1]
> a <- fit$xMean[2]-b*fit$xMean[1]
> abline(a=a, b=b, lwd=2, col=3)
> 
> # Orthogonal linear "regression" without intercept
> fit <- wpca(cbind(x,y), center=FALSE)
> b <- fit$vt[1,2]/fit$vt[1,1]
> a <- fit$xMean[2]-b*fit$xMean[1]
> abline(a=a, b=b, lty=2, lwd=2, col=3)
> 
> legend(xlim[1],ylim[2], legend=c("lm(y~x)", "lm(y~x-1)", "lm(x~y)",
+           "lm(x~y-1)", "pca", "pca w/o intercept"), lty=rep(1:2,3),
+                      lwd=rep(c(1,1,2),each=2), col=rep(1:3,each=2))
> 
> palette(opalette)
> par(opar)
> 
> proc.time()
   user  system elapsed 
   0.42    0.07    0.48 

Example timings

aroma.light.Rcheck/examples_i386/aroma.light-Ex.timings

nameusersystemelapsed
backtransformAffine000
backtransformPrincipalCurve0.830.031.50
calibrateMultiscan000
callNaiveGenotypes0.550.000.55
distanceBetweenLines0.150.000.16
findPeaksAndValleys0.050.020.06
fitPrincipalCurve0.940.000.94
fitXYCurve0.230.000.23
iwpca0.090.000.09
likelihood.smooth.spline0.210.020.24
medianPolish0.010.000.01
normalizeAffine7.640.037.69
normalizeCurveFit8.240.008.24
normalizeDifferencesToAverage0.310.010.32
normalizeFragmentLength1.940.031.97
normalizeQuantileRank0.890.000.89
normalizeQuantileRank.matrix0.060.000.07
normalizeQuantileSpline0.830.020.84
normalizeTumorBoost0.560.050.61
robustSmoothSpline0.590.000.60
sampleCorrelations0.440.000.44
sampleTuples0.010.000.01
wpca0.210.010.24

aroma.light.Rcheck/examples_x64/aroma.light-Ex.timings

nameusersystemelapsed
backtransformAffine000
backtransformPrincipalCurve0.500.060.57
calibrateMultiscan000
callNaiveGenotypes0.310.010.32
distanceBetweenLines0.090.000.10
findPeaksAndValleys0.050.000.05
fitPrincipalCurve0.630.000.62
fitXYCurve0.210.000.22
iwpca0.080.000.08
likelihood.smooth.spline0.130.000.12
medianPolish000
normalizeAffine6.840.026.86
normalizeCurveFit6.770.006.77
normalizeDifferencesToAverage0.330.000.33
normalizeFragmentLength2.370.022.39
normalizeQuantileRank0.970.000.96
normalizeQuantileRank.matrix0.050.000.05
normalizeQuantileSpline0.700.010.72
normalizeTumorBoost0.330.020.34
robustSmoothSpline0.400.010.43
sampleCorrelations0.220.000.21
sampleTuples000
wpca0.100.020.11