| Back to Multiple platform build/check report for BioC 3.22: simplified long | 
 | 
This page was generated on 2025-10-25 12:05 -0400 (Sat, 25 Oct 2025).
| Hostname | OS | Arch (*) | R version | Installed pkgs | 
|---|---|---|---|---|
| nebbiolo2 | Linux (Ubuntu 24.04.3 LTS) | x86_64 | 4.5.1 Patched (2025-08-23 r88802) -- "Great Square Root" | 4901 | 
| lconway | macOS 12.7.6 Monterey | x86_64 | 4.5.1 Patched (2025-09-10 r88807) -- "Great Square Root" | 4691 | 
| kjohnson3 | macOS 13.7.7 Ventura | arm64 | 4.5.1 Patched (2025-09-10 r88807) -- "Great Square Root" | 4637 | 
| taishan | Linux (openEuler 24.03 LTS) | aarch64 | 4.5.0 (2025-04-11) -- "How About a Twenty-Six" | 4658 | 
| Click on any hostname to see more info about the system (e.g. compilers) (*) as reported by 'uname -p', except on Windows and Mac OS X | ||||
| Package 179/2361 | Hostname | OS / Arch | INSTALL | BUILD | CHECK | BUILD BIN | ||||||||
| Biobase 2.69.1  (landing page) Bioconductor Package Maintainer 
 | nebbiolo2 | Linux (Ubuntu 24.04.3 LTS) / x86_64 | OK | OK | OK |  | ||||||||
| lconway | macOS 12.7.6 Monterey / x86_64 | OK | OK | OK | OK |  | ||||||||
| kjohnson3 | macOS 13.7.7 Ventura / arm64 | OK | OK | OK | OK |  | ||||||||
| taishan | Linux (openEuler 24.03 LTS) / aarch64 | OK | NA | NA | ||||||||||
| To the developers/maintainers of the Biobase package: - Allow up to 24 hours (and sometimes 48 hours) for your latest push to git@git.bioconductor.org:packages/Biobase.git to reflect on this report. See Troubleshooting Build Report for more information. - Use the following Renviron settings to reproduce errors and warnings. - If 'R CMD check' started to fail recently on the Linux builder(s) over a missing dependency, add the missing dependency to 'Suggests:' in your DESCRIPTION file. See Renviron.bioc for more information. | 
| Package: Biobase | 
| Version: 2.69.1 | 
| Command: /Library/Frameworks/R.framework/Resources/bin/R CMD check --install=check:Biobase.install-out.txt --library=/Library/Frameworks/R.framework/Resources/library --no-vignettes --timings Biobase_2.69.1.tar.gz | 
| StartedAt: 2025-10-24 18:39:50 -0400 (Fri, 24 Oct 2025) | 
| EndedAt: 2025-10-24 18:40:26 -0400 (Fri, 24 Oct 2025) | 
| EllapsedTime: 36.4 seconds | 
| RetCode: 0 | 
| Status: OK | 
| CheckDir: Biobase.Rcheck | 
| Warnings: 0 | 
##############################################################################
##############################################################################
###
### Running command:
###
###   /Library/Frameworks/R.framework/Resources/bin/R CMD check --install=check:Biobase.install-out.txt --library=/Library/Frameworks/R.framework/Resources/library --no-vignettes --timings Biobase_2.69.1.tar.gz
###
##############################################################################
##############################################################################
* using log directory ‘/Users/biocbuild/bbs-3.22-bioc/meat/Biobase.Rcheck’
* using R version 4.5.1 Patched (2025-09-10 r88807)
* using platform: aarch64-apple-darwin20
* R was compiled by
    Apple clang version 16.0.0 (clang-1600.0.26.6)
    GNU Fortran (GCC) 14.2.0
* running under: macOS Ventura 13.7.7
* using session charset: UTF-8
* using option ‘--no-vignettes’
* checking for file ‘Biobase/DESCRIPTION’ ... OK
* this is package ‘Biobase’ version ‘2.69.1’
* 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 ... OK
* checking for portable file names ... OK
* checking for sufficient/correct file permissions ... OK
* checking whether package ‘Biobase’ can be installed ... OK
* used C compiler: ‘Apple clang version 15.0.0 (clang-1500.1.0.2.5)’
* used SDK: ‘MacOSX11.3.1.sdk’
* checking installed package size ... OK
* checking package directory ... OK
* checking ‘build’ 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 code files for non-ASCII characters ... OK
* checking R files for syntax errors ... OK
* 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 whether startup messages can be suppressed ... 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 ... NOTE
Found the following Rd file(s) with Rd \link{} targets missing package
anchors:
  class.AnnotatedDataFrame.Rd: updateObject
  class.ExpressionSet.Rd: updateObject
  class.MIAME.Rd: updateObject
  class.MultiSet.Rd: updateObject
  class.NChannelSet.Rd: updateObject
  class.SnpSet.Rd: updateObject
  class.eSet.Rd: updateObject
Please provide package anchors for all Rd \link{} targets not in the
package itself and the base packages.
* 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 contents of ‘data’ directory ... OK
* checking data for non-ASCII characters ... OK
* checking data for ASCII and uncompressed saves ... OK
* checking line endings in C/C++/Fortran sources/headers ... OK
* checking compiled code ... NOTE
Note: information on .o files is not available
* checking sizes of PDF files under ‘inst/doc’ ... OK
* checking files in ‘vignettes’ ... OK
* checking examples ... OK
* checking for unstated dependencies in ‘tests’ ... OK
* checking tests ...
  Running ‘test-all.R’
  Running ‘test-rowMedians.R’
 OK
* checking for unstated dependencies in vignettes ... OK
* checking package vignettes ... OK
* checking running R code from vignettes ... SKIPPED
* checking re-building of vignette outputs ... SKIPPED
* checking PDF version of manual ... OK
* DONE
Status: 2 NOTEs
See
  ‘/Users/biocbuild/bbs-3.22-bioc/meat/Biobase.Rcheck/00check.log’
for details.
Biobase.Rcheck/00install.out
############################################################################## ############################################################################## ### ### Running command: ### ### /Library/Frameworks/R.framework/Resources/bin/R CMD INSTALL Biobase ### ############################################################################## ############################################################################## * installing to library ‘/Library/Frameworks/R.framework/Versions/4.5-arm64/Resources/library’ * installing *source* package ‘Biobase’ ... ** this is package ‘Biobase’ version ‘2.69.1’ ** using staged installation ** libs using C compiler: ‘Apple clang version 15.0.0 (clang-1500.1.0.2.5)’ using SDK: ‘MacOSX11.3.1.sdk’ clang -arch arm64 -std=gnu2x -I"/Library/Frameworks/R.framework/Resources/include" -DNDEBUG -I/opt/R/arm64/include -fPIC -falign-functions=64 -Wall -g -O2 -c Rinit.c -o Rinit.o clang -arch arm64 -std=gnu2x -I"/Library/Frameworks/R.framework/Resources/include" -DNDEBUG -I/opt/R/arm64/include -fPIC -falign-functions=64 -Wall -g -O2 -c envir.c -o envir.o clang -arch arm64 -std=gnu2x -I"/Library/Frameworks/R.framework/Resources/include" -DNDEBUG -I/opt/R/arm64/include -fPIC -falign-functions=64 -Wall -g -O2 -c matchpt.c -o matchpt.o clang -arch arm64 -std=gnu2x -I"/Library/Frameworks/R.framework/Resources/include" -DNDEBUG -I/opt/R/arm64/include -fPIC -falign-functions=64 -Wall -g -O2 -c rowMedians.c -o rowMedians.o clang -arch arm64 -std=gnu2x -I"/Library/Frameworks/R.framework/Resources/include" -DNDEBUG -I/opt/R/arm64/include -fPIC -falign-functions=64 -Wall -g -O2 -c sublist_extract.c -o sublist_extract.o clang -arch arm64 -std=gnu2x -dynamiclib -Wl,-headerpad_max_install_names -undefined dynamic_lookup -L/Library/Frameworks/R.framework/Resources/lib -L/opt/R/arm64/lib -o Biobase.so Rinit.o envir.o matchpt.o rowMedians.o sublist_extract.o -F/Library/Frameworks/R.framework/.. -framework R installing to /Library/Frameworks/R.framework/Versions/4.5-arm64/Resources/library/00LOCK-Biobase/00new/Biobase/libs ** R ** data ** inst ** byte-compile and prepare package for lazy loading ** help *** installing help indices ** building package indices ** installing vignettes ** testing if installed package can be loaded from temporary location ** checking absolute paths in shared objects and dynamic libraries ** testing if installed package can be loaded from final location ** testing if installed package keeps a record of temporary installation path * DONE (Biobase)
Biobase.Rcheck/tests/test-all.Rout
R version 4.5.1 Patched (2025-09-10 r88807) -- "Great Square Root"
Copyright (C) 2025 The R Foundation for Statistical Computing
Platform: aarch64-apple-darwin20
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.
> BiocGenerics:::testPackage("Biobase")
Attaching package: 'generics'
The following objects are masked from 'package:base':
    as.difftime, as.factor, as.ordered, intersect, is.element, setdiff,
    setequal, union
Attaching package: 'BiocGenerics'
The following objects are masked from 'package:stats':
    IQR, mad, sd, var, xtabs
The following objects are masked from 'package:base':
    Filter, Find, Map, Position, Reduce, anyDuplicated, aperm, append,
    as.data.frame, basename, cbind, colnames, dirname, do.call,
    duplicated, eval, evalq, get, grep, grepl, is.unsorted, lapply,
    mapply, match, mget, order, paste, pmax, pmax.int, pmin, pmin.int,
    rank, rbind, rownames, sapply, saveRDS, table, tapply, unique,
    unsplit, which.max, which.min
Welcome to Bioconductor
    Vignettes contain introductory material; view with
    'browseVignettes()'. To cite Bioconductor, see
    'citation("Biobase")', and for packages 'citation("pkgname")'.
RUNIT TEST PROTOCOL -- Fri Oct 24 18:40:12 2025 
*********************************************** 
Number of test functions: 101 
Number of errors: 0 
Number of failures: 0 
 
1 Test Suite : 
Biobase RUnit Tests - 101 test functions, 0 errors, 0 failures
Number of test functions: 101 
Number of errors: 0 
Number of failures: 0 
Warning message:
In environment(FUN) <- e1 :
  setting environment(<primitive function>) is not possible and trying it is deprecated
> 
> proc.time()
   user  system elapsed 
  3.002   0.067   3.195 
Biobase.Rcheck/tests/test-rowMedians.Rout
R version 4.5.1 Patched (2025-09-10 r88807) -- "Great Square Root"
Copyright (C) 2025 The R Foundation for Statistical Computing
Platform: aarch64-apple-darwin20
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(Biobase)
Loading required package: BiocGenerics
Loading required package: generics
Attaching package: 'generics'
The following objects are masked from 'package:base':
    as.difftime, as.factor, as.ordered, intersect, is.element, setdiff,
    setequal, union
Attaching package: 'BiocGenerics'
The following objects are masked from 'package:stats':
    IQR, mad, sd, var, xtabs
The following objects are masked from 'package:base':
    Filter, Find, Map, Position, Reduce, anyDuplicated, aperm, append,
    as.data.frame, basename, cbind, colnames, dirname, do.call,
    duplicated, eval, evalq, get, grep, grepl, is.unsorted, lapply,
    mapply, match, mget, order, paste, pmax, pmax.int, pmin, pmin.int,
    rank, rbind, rownames, sapply, saveRDS, table, tapply, unique,
    unsplit, which.max, which.min
Welcome to Bioconductor
    Vignettes contain introductory material; view with
    'browseVignettes()'. To cite Bioconductor, see
    'citation("Biobase")', and for packages 'citation("pkgname")'.
> set.seed(1)
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Consistency checks
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> 
> # rowMedians() by rowQ()
> rowMedians2 <- function(imat) {
+   nr <- ncol(imat)
+   half <- (nr + 1)/2
+   if (nr%%2 == 1) {
+     return(rowQ(imat, half))
+   } else {
+     return((rowQ(imat, half) + rowQ(imat, half+1))/2)
+   }
+ }
> 
> cat("Consistency checks:\n")
Consistency checks:
> set.seed(1)
> for (kk in 1:20) {
+   cat("Random test #", kk, "\n", sep="")
+ 
+   # Simulate data in a matrix of any shape
+   nrow <- sample(2000, size=1)
+   ncol <- sample(2000, size=1)
+   x <- rnorm(nrow*ncol)
+   dim(x) <- c(nrow, ncol)
+ 
+   # Add NAs?
+   nas <- sample(c(TRUE,FALSE), size=1)
+   if (nas) {
+     nna <- sample(nrow*ncol, size=1)
+     x[sample(length(x), size=nna)] <- NA
+   }
+ 
+   na.rm <- nas
+   t1 <- system.time({
+     y1 <- rowMedians(x, na.rm=na.rm)
+   })
+   t2 <- system.time({
+     y2 <- apply(x, MARGIN=1, FUN=median, na.rm=na.rm)
+   })
+   # When all values of 'y2' are NA, 'y2' is logical
+   if (is.logical(y2)) y2 <- as.double(y2)
+   stopifnot(all.equal(y1,y2))
+   cat(sprintf("rowMedians()/apply(): %.3g\n", (t1/t2)[3]))
+ 
+   if (!nas) {
+     t3 <- system.time({
+       y3 <- rowMedians2(x)
+     })
+     stopifnot(all.equal(y1,y3))
+     cat(sprintf("rowMedians()/rowMedians2(): %.3g\n", (t1/t3)[3]))
+   }
+ }
Random test #1
rowMedians()/apply(): 0.367
Random test #2
rowMedians()/apply(): 0.231
rowMedians()/rowMedians2(): 0.409
Random test #3
rowMedians()/apply(): 0.2
Random test #4
rowMedians()/apply(): 0.308
rowMedians()/rowMedians2(): 0.364
Random test #5
rowMedians()/apply(): 0.317
rowMedians()/rowMedians2(): 0.376
Random test #6
rowMedians()/apply(): 0.391
rowMedians()/rowMedians2(): 0.474
Random test #7
rowMedians()/apply(): 0.425
Random test #8
rowMedians()/apply(): 0
rowMedians()/rowMedians2(): NaN
Random test #9
rowMedians()/apply(): 0.333
Random test #10
rowMedians()/apply(): 0.0968
Random test #11
rowMedians()/apply(): 0.25
Random test #12
rowMedians()/apply(): 0.174
Random test #13
rowMedians()/apply(): 0.6
rowMedians()/rowMedians2(): 1.5
Random test #14
rowMedians()/apply(): 0.412
Random test #15
rowMedians()/apply(): 0.271
Random test #16
rowMedians()/apply(): 0.211
rowMedians()/rowMedians2(): 0.4
Random test #17
rowMedians()/apply(): 0.258
Random test #18
rowMedians()/apply(): 0.219
rowMedians()/rowMedians2(): 0.778
Random test #19
rowMedians()/apply(): 0.392
rowMedians()/rowMedians2(): 0.69
Random test #20
rowMedians()/apply(): 0.321
rowMedians()/rowMedians2(): 0.386
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Benchmarking
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> cat("Benchmarking:\n")
Benchmarking:
> 
> # Simulate data in a matrix of any shape
> nrow <- 1000
> ncol <- 1000
> x <- rnorm(nrow*ncol)
> dim(x) <- c(nrow, ncol)
> 
> gc()
          used (Mb) gc trigger (Mb) limit (Mb) max used (Mb)
Ncells  608909 32.6    1210018 64.7         NA  1129176 60.4
Vcells 2116829 16.2   12255594 93.6     196608 12353907 94.3
> t0 <- system.time({
+   for (rr in 1:20)
+     y0 <- apply(x, MARGIN=1, FUN=median, na.rm=FALSE)
+ })
> gc()
          used (Mb) gc trigger (Mb) limit (Mb) max used (Mb)
Ncells  608925 32.6    1210018 64.7         NA  1210018 64.7
Vcells 2117846 16.2   12255594 93.6     196608 12353907 94.3
> t1 <- system.time({
+   for (rr in 1:20)
+     y1 <- rowMedians(x, na.rm=FALSE)
+ })
> gc()
          used (Mb) gc trigger (Mb) limit (Mb) max used (Mb)
Ncells  608925 32.6    1210018 64.7         NA  1210018 64.7
Vcells 2116971 16.2   12255594 93.6     196608 12353907 94.3
> stopifnot(all.equal(y0,y1))
> cat(sprintf("rowMedians()/apply(): %.3g\n", (t1/t0)[3]))
rowMedians()/apply(): 0.299
> 
> 
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> # Consistency checks
> # - - - - - - - - - - - - - - - - - - - - - - - - - - - -
> cat("Consistency checks without NAs:\n")
Consistency checks without NAs:
> for (kk in 1:20) {
+   cat("Random test #", kk, "\n", sep="")
+ 
+   # Simulate data in a matrix of any shape
+   nrow <- sample(1000, size=1)
+   ncol <- sample(1000, size=1)
+   x <- rnorm(nrow*ncol)
+   dim(x) <- c(nrow, ncol)
+ 
+   t0 <- system.time({
+     y0 <- apply(x, MARGIN=1, FUN=median, na.rm=FALSE)
+   })
+   t1 <- system.time({
+     y1 <- rowMedians(x, na.rm=FALSE)
+   })
+   stopifnot(all.equal(y0,y1))
+ } # for (kk in ...)
Random test #1
Random test #2
Random test #3
Random test #4
Random test #5
Random test #6
Random test #7
Random test #8
Random test #9
Random test #10
Random test #11
Random test #12
Random test #13
Random test #14
Random test #15
Random test #16
Random test #17
Random test #18
Random test #19
Random test #20
> 
> 
> 
> cat("Consistency checks with NAs:\n")
Consistency checks with NAs:
> for (kk in 1:20) {
+   cat("Random test #", kk, "\n", sep="")
+ 
+   # Simulate data in a matrix of any shape
+   nrow <- sample(1000, size=1)
+   ncol <- sample(1000, size=1)
+   x <- rnorm(nrow*ncol)
+   dim(x) <- c(nrow, ncol)
+ 
+   # Add NAs
+   nna <- sample(nrow*ncol-1, size=1)
+   x[sample(length(x), size=nna)] <- NA
+ 
+   t0 <- system.time({
+     y0 <- apply(x, MARGIN=1, FUN=median, na.rm=TRUE)
+     y0[is.na(y0)] <- NA
+   })
+   t1 <- system.time({
+     y1 <- rowMedians(x, na.rm=TRUE)
+   })
+   stopifnot(all.equal(y0,y1))
+ } # for (kk in ...)
Random test #1
Random test #2
Random test #3
Random test #4
Random test #5
Random test #6
Random test #7
Random test #8
Random test #9
Random test #10
Random test #11
Random test #12
Random test #13
Random test #14
Random test #15
Random test #16
Random test #17
Random test #18
Random test #19
Random test #20
> 
> proc.time()
   user  system elapsed 
  7.398   0.299   7.996 
Biobase.Rcheck/Biobase-Ex.timings
| name | user | system | elapsed | |
| Aggregate | 0.002 | 0.001 | 0.002 | |
| ScalarObject-class | 0.024 | 0.000 | 0.024 | |
| addVig2Menu | 0.000 | 0.000 | 0.001 | |
| anyMissing | 0 | 0 | 0 | |
| cache | 0.001 | 0.001 | 0.002 | |
| channel | 0.041 | 0.004 | 0.045 | |
| channelNames | 0.01 | 0.00 | 0.01 | |
| class.AnnotatedDataFrame | 0.007 | 0.001 | 0.012 | |
| class.ExpressionSet | 0.048 | 0.004 | 0.052 | |
| class.MIAxE | 0.006 | 0.000 | 0.006 | |
| class.MultiSet | 0.006 | 0.001 | 0.006 | |
| class.NChannelSet | 0.033 | 0.001 | 0.035 | |
| class.Versioned | 0.013 | 0.001 | 0.014 | |
| class.VersionedBiobase | 0.008 | 0.001 | 0.010 | |
| class.Versions | 0.003 | 0.000 | 0.006 | |
| class.VersionsNull | 0.000 | 0.001 | 0.000 | |
| class.container | 0.001 | 0.000 | 0.000 | |
| class.eSet | 0.019 | 0.001 | 0.020 | |
| classVersion | 0.001 | 0.001 | 0.001 | |
| contents | 0.001 | 0.000 | 0.001 | |
| copyEnv | 0 | 0 | 0 | |
| copySubstitute | 0.002 | 0.005 | 0.007 | |
| createPackage | 0.001 | 0.002 | 0.004 | |
| data.aaMap | 0.001 | 0.001 | 0.002 | |
| data.geneData | 0.008 | 0.002 | 0.010 | |
| data.reporter | 0.000 | 0.000 | 0.001 | |
| data.sample.ExpressionSet | 0.005 | 0.000 | 0.006 | |
| data.sample.MultiSet | 0.002 | 0.000 | 0.003 | |
| dumpPackTxt | 0.000 | 0.000 | 0.002 | |
| esApply | 0.242 | 0.004 | 0.254 | |
| getPkgVigs | 0.003 | 0.002 | 0.005 | |
| isCurrent | 0.007 | 0.001 | 0.007 | |
| isUnique | 0 | 0 | 0 | |
| isVersioned | 0.003 | 0.000 | 0.003 | |
| lcSuffix | 0.001 | 0.000 | 0.000 | |
| listLen | 0 | 0 | 0 | |
| makeDataPackage | 0.031 | 0.003 | 0.035 | |
| matchpt | 0.002 | 0.000 | 0.002 | |
| multiassign | 0.000 | 0.000 | 0.001 | |
| note | 0 | 0 | 0 | |
| openPDF | 0 | 0 | 0 | |
| openVignette | 0.000 | 0.001 | 0.000 | |
| package.version | 0.000 | 0.000 | 0.001 | |
| read.AnnotatedDataFrame | 0.003 | 0.001 | 0.004 | |
| read.MIAME | 0.001 | 0.000 | 0.001 | |
| readExpressionSet | 0.018 | 0.001 | 0.021 | |
| reverseSplit | 0 | 0 | 0 | |
| rowMedians | 0.010 | 0.002 | 0.014 | |
| rowQ | 0.006 | 0.003 | 0.010 | |
| selectChannels | 0.010 | 0.000 | 0.011 | |
| selectSome | 0.000 | 0.000 | 0.001 | |
| strbreak | 0 | 0 | 0 | |
| subListExtract | 0.235 | 0.007 | 0.246 | |
| testBioCConnection | 0.008 | 0.005 | 0.175 | |
| updateOldESet | 0 | 0 | 0 | |
| validMsg | 0.001 | 0.000 | 0.000 | |