[med-svn] [r-bioc-summarizedexperiment] 10/12: New upstream version 1.6.3

Andreas Tille tille at debian.org
Mon Oct 2 09:54:52 UTC 2017


This is an automated email from the git hooks/post-receive script.

tille pushed a commit to branch master
in repository r-bioc-summarizedexperiment.

commit 28bc7c1db76af330cc707ca7cf2caeb8136f789d
Author: Andreas Tille <tille at debian.org>
Date:   Mon Oct 2 11:52:32 2017 +0200

    New upstream version 1.6.3
---
 DESCRIPTION                                        |   30 +
 NAMESPACE                                          |  123 +
 NEWS                                               |  120 +
 NOTES                                              |   35 +
 R/Assays-class.R                                   |  377 +++
 R/RangedSummarizedExperiment-class.R               |  572 ++++
 R/SummarizedExperiment-class.R                     |  844 ++++++
 R/coverage-methods.R                               |   15 +
 R/findOverlaps-methods.R                           |   42 +
 R/inter-range-methods.R                            |   22 +
 R/intra-range-methods.R                            |   79 +
 R/makeSummarizedExperimentFromDataFrame.R          |   32 +
 R/makeSummarizedExperimentFromExpressionSet.R      |  265 ++
 R/nearest-methods.R                                |  117 +
 R/readKallisto.R                                   |  196 ++
 R/saveHDF5SummarizedExperiment.R                   |  127 +
 R/zzz.R                                            |    2 +
 build/vignette.rds                                 |  Bin 0 -> 209 bytes
 debian/README.test                                 |   15 -
 debian/changelog                                   |   61 -
 debian/compat                                      |    1 -
 debian/control                                     |   30 -
 debian/copyright                                   |  107 -
 debian/docs                                        |    1 -
 debian/patches/series                              |    1 -
 .../skip_test_needing_not_packaged_database.patch  |   54 -
 debian/rules                                       |    4 -
 debian/source/format                               |    1 -
 debian/tests/control                               |    3 -
 debian/tests/run-unit-test                         |    6 -
 debian/watch                                       |    3 -
 inst/doc/SummarizedExperiment.R                    |  101 +
 inst/doc/SummarizedExperiment.Rmd                  |  345 +++
 inst/doc/SummarizedExperiment.html                 |  541 ++++
 inst/extdata/kallisto/abundance.h5                 |  Bin 0 -> 1086722 bytes
 inst/extdata/kallisto/abundance.tsv                | 2859 ++++++++++++++++++++
 inst/extdata/kallisto/abundance.txt                |   16 +
 inst/extdata/kallisto/run_info.json                |    8 +
 inst/scripts/Find_and_update_objects/README        |   68 +
 .../collect_rda_objects_to_update.R                |  133 +
 .../data_store_RDA_OBJECTS_TO_UPDATE               |   30 +
 .../pkgs_RDA_OBJECTS_TO_UPDATE                     |    9 +
 .../Find_and_update_objects/scan_rda_files.R       |   68 +
 .../Find_and_update_objects/update_rda_objects.R   |   70 +
 inst/unitTests/test_Assays-class.R                 |   88 +
 .../test_RangedSummarizedExperiment-class.R        |  375 +++
 inst/unitTests/test_SummarizedExperiment-class.R   |  339 +++
 inst/unitTests/test_coverage-methods.R             |   56 +
 inst/unitTests/test_findOverlaps-methods.R         |   92 +
 inst/unitTests/test_inter-range-methods.R          |   52 +
 inst/unitTests/test_intra-range-methods.R          |   94 +
 .../test_makeSummarizedExperimentFromDataFrame.R   |   56 +
 ...est_makeSummarizedExperimentFromExpressionSet.R |  187 ++
 inst/unitTests/test_nearest-methods.R              |   70 +
 man/Assays-class.Rd                                |  172 ++
 man/RangedSummarizedExperiment-class.Rd            |  335 +++
 man/SummarizedExperiment-class.Rd                  |  454 ++++
 man/coverage-methods.Rd                            |   80 +
 man/findOverlaps-methods.Rd                        |  105 +
 man/inter-range-methods.Rd                         |   95 +
 man/intra-range-methods.Rd                         |  151 ++
 man/makeSummarizedExperimentFromDataFrame.Rd       |   87 +
 man/makeSummarizedExperimentFromExpressionSet.Rd   |  112 +
 man/nearest-methods.Rd                             |  149 +
 man/readKallisto.Rd                                |  120 +
 man/saveHDF5SummarizedExperiment.Rd                |  144 +
 tests/run_unitTests.R                              |    2 +
 vignettes/SummarizedExperiment.Rmd                 |  345 +++
 68 files changed, 11006 insertions(+), 287 deletions(-)

diff --git a/DESCRIPTION b/DESCRIPTION
new file mode 100644
index 0000000..5cb8739
--- /dev/null
+++ b/DESCRIPTION
@@ -0,0 +1,30 @@
+Package: SummarizedExperiment
+Title: SummarizedExperiment container
+Description: The SummarizedExperiment container contains one or more assays,
+	each represented by a matrix-like object of numeric or other mode.
+	The rows typically represent genomic ranges of interest and the columns
+	represent samples.
+Version: 1.6.3
+Encoding: UTF-8
+Author: Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès
+Maintainer: Bioconductor Package Maintainer <maintainer at bioconductor.org>
+biocViews: Genetics, Infrastructure, Sequencing, Annotation, Coverage,
+        GenomeAnnotation
+Depends: R (>= 3.2), methods, GenomicRanges (>= 1.27.22), Biobase,
+        DelayedArray (>= 0.1.9)
+Imports: utils, stats, tools, Matrix, BiocGenerics (>= 0.15.3),
+        S4Vectors (>= 0.13.13), IRanges (>= 2.7.2), GenomeInfoDb (>=
+        1.11.4)
+Suggests: annotate, AnnotationDbi, hgu95av2.db, GenomicFeatures,
+        TxDb.Hsapiens.UCSC.hg19.knownGene, BiocStyle, knitr, rmarkdown,
+        digest, jsonlite, rhdf5, HDF5Array (>= 1.4.8), airway, RUnit
+VignetteBuilder: knitr
+License: Artistic-2.0
+Collate: Assays-class.R SummarizedExperiment-class.R
+        RangedSummarizedExperiment-class.R intra-range-methods.R
+        inter-range-methods.R coverage-methods.R findOverlaps-methods.R
+        nearest-methods.R makeSummarizedExperimentFromExpressionSet.R
+        makeSummarizedExperimentFromDataFrame.R readKallisto.R
+        saveHDF5SummarizedExperiment.R zzz.R
+NeedsCompilation: no
+Packaged: 2017-05-29 00:08:18 UTC; biocbuild
diff --git a/NAMESPACE b/NAMESPACE
new file mode 100644
index 0000000..eaee9f8
--- /dev/null
+++ b/NAMESPACE
@@ -0,0 +1,123 @@
+import(methods)
+importFrom(utils, read.delim, .DollarNames)
+importFrom(stats, setNames)
+importFrom(tools, file_path_as_absolute)
+importClassFrom(Matrix, Matrix)  # for the "acbind" and "arbind" methods
+import(BiocGenerics)
+import(S4Vectors)
+import(IRanges)
+import(GenomeInfoDb)
+import(GenomicRanges)
+import(Biobase)
+import(DelayedArray)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Export S4 classes
+###
+
+exportClasses(
+    Assays, ShallowData, ShallowSimpleListAssays,
+    SummarizedExperiment,
+    RangedSummarizedExperiment
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Export S4 methods for generics not defined in SummarizedExperiment
+###
+
+exportMethods(
+    length, names, "names<-",
+    dim, dimnames, "dimnames<-",
+    "[", "[<-", "[[", "[[<-", "$", "$<-",
+    as.data.frame,
+    coerce,
+    show,
+    c,
+    merge,
+    Compare,
+
+    ## Generics defined in BiocGenerics:
+    cbind, rbind,
+    duplicated, match,
+    is.unsorted, order, rank, sort,
+    start, "start<-", end, "end<-", width, "width<-",
+    strand, "strand<-",
+    updateObject,
+
+    ## Generics defined in S4Vectors:
+    "metadata<-",
+    mcols, "mcols<-",
+    elementMetadata, "elementMetadata<-",
+    values, "values<-",
+    extractROWS, replaceROWS,
+    subset,
+    pcompare,
+
+    ## Generics defined in IRanges:
+    ranges, "ranges<-",
+    shift, narrow, resize, flank, promoters, restrict, trim,
+    isDisjoint, disjointBins,
+    coverage,
+    findOverlaps,
+    precede, follow, nearest, distance, distanceToNearest,
+    acbind, arbind,
+
+    ## Generics defined in GenomeInfoDb:
+    seqinfo, "seqinfo<-",
+    seqnames, "seqnames<-",
+
+    ## Generics defined in DelayedArray:
+    rowRanges, realize
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Export non-generic functions
+###
+
+export(
+    Assays,
+    .DollarNames.SummarizedExperiment,
+    .DollarNames.RangedSummarizedExperiment,
+    makeSummarizedExperimentFromExpressionSet,
+    makeSummarizedExperimentFromDataFrame,
+    naiveRangeMapper, probeRangeMapper, geneRangeMapper,
+    readKallisto, readKallistoBootstrap, KALLISTO_ASSAYS,
+    saveHDF5SummarizedExperiment, loadHDF5SummarizedExperiment
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Export S4 generics defined in SummarizedExperiment + export corresponding
+### methods
+###
+
+export(
+    SummarizedExperiment,
+    "rowRanges<-",
+    rowData, "rowData<-",
+    colData, "colData<-",
+    assayNames, "assayNames<-",
+    assays, "assays<-",
+    assay, "assay<-"
+)
+
+### Exactly the same list as above.
+exportMethods(
+    SummarizedExperiment,
+    "rowRanges<-",
+    rowData, "rowData<-",
+    colData, "colData<-",
+    assayNames, "assayNames<-",
+    assays, "assays<-",
+    assay, "assay<-"
+)
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Register S3 methods
+###
+
+S3method(.DollarNames, SummarizedExperiment)
+S3method(.DollarNames, RangedSummarizedExperiment)
diff --git a/NEWS b/NEWS
new file mode 100644
index 0000000..cc48bc3
--- /dev/null
+++ b/NEWS
@@ -0,0 +1,120 @@
+CHANGES IN VERSION 1.6.1
+------------------------
+
+BUG FIXES
+
+    o '$' completion on SummarizedExperiment works in RStudio and on
+      RangedSummarizedExperiment.
+
+CHANGES IN VERSION 1.6.0
+------------------------
+
+NEW FEATURES
+
+    o Add saveHDF5SummarizedExperiment() and loadHDF5SummarizedExperiment() for
+      saving/loading HDF5-based SummarizedExperiment objects to/from disk.
+
+DEPRECATED AND DEFUNCT
+
+    o Remove SummarizedExperiment0 class (was introduced to ease transition
+      from old SummarizedExperiment class defined in GenomicRanges to new
+      RangedSummarizedExperiment class defined in SummarizedExperiment package).
+
+
+CHANGES IN VERSION 1.4.0
+------------------------
+
+NEW FEATURES
+
+    o Add makeSummarizedExperimentFromDataFrame() function.
+
+    o Add "acbind" and "arbind" methods for Matrix objects.
+
+SIGNIFICANT USER-VISIBLE CHANGES
+
+    o Speed up "cbind" method for SummarizedExperiment objects based on a
+      suggestion by Peter Hickey.
+
+DEPRECATED AND DEFUNCT
+
+    o Remove exptData() getter and setter (were defunct in BioC 3.3).
+
+BUG FIXES
+
+
+CHANGES IN VERSION 1.2.0
+------------------------
+
+NEW FEATURES
+
+    o Add 'rowData' argument to SummarizedExperiment() constructor. This allows
+      the user to supply the row data at construction time.
+
+    o The SummarizedExperiment() constructor function and the assay() setter
+      now both take any matrix-like object as long as the resulting
+      SummarizedExperiment object is valid.
+
+    o Support r/cbind'ing of SummarizedExperiment objects with assays of
+      arbitrary dimensions (based on a patch by Pete Hickey).
+
+    o Add "is.unsorted" method for RangedSummarizedExperiment objects.
+
+    o NULL colnames() supported during SummarizedExperiment construction.
+
+    o readKallisto() warns early when files need names.
+
+    o base::rank() gained a new 'ties.method="last"' option and base::order()
+      a new argument ('method') in R 3.3. Thus so do the "rank" and "order"
+      methods for RangedSummarizedExperiment objects.
+
+SIGNIFICANT USER-VISIBLE CHANGES
+
+    o Re-introduce the rowData() accessor (was defunt in BioC 3.2) as an alias
+      for mcols() and make it the preferred way to access the row data. There
+      is now a pleasant symmetry between rowData and colData.
+
+    o Rename SummarizedExperiment0 class -> SummarizedExperiment.
+
+    o Improved vignette.
+
+    o Remove updateObject() method for "old" SummarizedExperiment objects.
+
+DEPRECATED AND DEFUNCT
+
+    o exptData() is now defunct, metadata() should be used instead.
+
+BUG FIXES
+
+    o Fix bug in "sort" method for RangedSummarizedExperiment objects when
+      'ignore.strand=TRUE' (the argument was ignored).
+
+    o Fix 2 bugs when r/cbind'ing SummarizedExperiment objects:
+      - r/cbind'ing assays without names would return only the first element.
+        See https://stat.ethz.ch/pipermail/bioc-devel/2015-November/008318.html
+      - r/cbind'ing assays with names in different order would stop() with
+        'Assays must have the same names()"
+
+    o Fix validity method for SummarizedExperiment objects reporting incorrect
+      numbers when the nb of cols in assay(x) doesn't match the nb of rows in
+      colData(x).
+
+    o assay colnames() must agree with colData rownames()
+
+    o Fix bug where assays(se, withDimnames=TRUE) was dropping the dimnames of
+      the 3rd and higher-order dimensions of the assays. Thanks to Pete Hickey
+      for catching this and providing a patch.
+
+    o A couple of minor tweaks to the rowData() setter to make it behave
+      consistently with mcols()/elementMetadata() setters for Vector objects
+      in general.
+
+
+CHANGES IN VERSION 0.3.*
+------------------------
+
+NEW FEATURES
+
+    o readKallisto() and readKallistoBootstrap() input kallisto
+      transcript quantification output into SummarizedExperiment (and
+      other) instances.
+
diff --git a/NOTES b/NOTES
new file mode 100644
index 0000000..30ddb40
--- /dev/null
+++ b/NOTES
@@ -0,0 +1,35 @@
+We need a mechanism to save an HDF5Array-based (or more generally
+DelayedArray-based) SummarizedExperiment object to disk.
+
+- The object can have more than 1 assay. Even though most of the time these
+  assays are either all in memory (e.g. ordinary arrays or data frames) or all
+  on disk and using the same backend (i.e. all HDF5-based DelayedArray
+  objects), they can be a mix of in-memory and on-disk assays. Even a given
+  assay can use more than 1 kind of on-disk backend. For example it could be
+  the result of adding an HDF5-based DelayedArray object with a DelayedArray
+  object based on another backend. Since the addition of DelayedArray objects
+  is delayed, the result of this addition is a DelayedArray object with mixed
+  backends.
+
+- Standard mechanisms save() and saveRDS() cannot handle this complexity.
+
+- We need a mechanism that produces several files: one .rda (or .rds)
+  file containing the result of calling save() (or saveRDS()) on the
+  object + all the files (e.g. HDF5) containing the on-disk assay data.
+  The files containing the on-disk assay data can be a mix of HDF5 files
+  and other formats.
+  How should these files be bundled together? By putting them together in a
+  destination folder? By creating a tarball of this folder? Should the creation
+  of the tarball be left to the user or should the save function create it?
+
+- Should the on-disk assays with delayed operations on them be "realized"
+  before the SummarizedExperiment object is saved to disk? Doing this has
+  some significant advantages:
+    (1) It "simplifies" the object: it reduces the number of files needed to
+        store the on-disk assay data (only 1 file per on-disk assay).
+    (2) It relocates and reduces the size of the on-disk data needed to
+        represent the object.
+
+- Should the in-memory assays be converted into on-disk assays before saving?
+  Should this be controlled by the user?
+
diff --git a/R/Assays-class.R b/R/Assays-class.R
new file mode 100644
index 0000000..292ff8e
--- /dev/null
+++ b/R/Assays-class.R
@@ -0,0 +1,377 @@
+### =========================================================================
+### Assays objects
+### -------------------------------------------------------------------------
+###
+### The Assays API consists of:
+###   (a) The Assays() constructor function.
+###   (b) Lossless back and forth coercion from/to SimpleList. The coercion
+###       method from SimpleList doesn't need (and should not) validate the
+###       returned object.
+###   (c) length, names, names<-, [[, [[<-, dim, [, [<-, rbind, cbind
+###
+### An Assays concrete subclass needs to implement (b) (required) plus
+### optionally any of the methods in (c).
+###
+### IMPORTANT: Methods that return a modified Assays object (a.k.a.
+### endomorphisms), that is, [ as well as replacement methods names<-, [[<-,
+### and [<-, must respect the copy-on-change contract. With objects that
+### don't make use of references internally, the developer doesn't need to
+### take any special action for that because it's automatically taken care of
+### by R itself. However, for objects that do make use of references internally
+### (e.g. environments, external pointers, pointer to a file on disk, etc...),
+### the developer needs to be careful to implement endomorphisms with
+### copy-on-change semantics. This can easily be achieved (and is what the
+### default methods for Assays objects do) by performaing a full (deep) copy
+### of the object before modifying it instead of trying to modify it in-place.
+### Note that the full (deep) copy is not always necessary in order to achieve
+### copy-on-change semantics: it's enough (and often preferrable for
+### performance reasons) to copy only the parts of the objects that need to
+### be modified.
+###
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Assays class
+###
+
+setClass("Assays")
+
+### Validity
+
+.valid.Assays <- function(x)
+{
+    assays <- as(x, "SimpleList", strict=FALSE)
+    if (!is(assays, "SimpleList"))
+        return("'assays' must be a SimpleList object")
+    if (length(assays) == 0L)
+        return(NULL)
+
+    ## Check dims.
+    all_dims <- sapply(assays, function(assay) dim(assay)[1:2])
+    if (any(is.na(all_dims)))
+        return(wmsg("all assays must be matrix-like objects ",
+                    "with 2 (or more?) dimensions"))
+    if (!all(all_dims == all_dims[ , 1L]))
+        stop("all assays must have the same nrow and ncol")
+
+    NULL
+}
+
+setValidity2("Assays", .valid.Assays)
+
+### Constructor
+
+.normarg_assays <- function(assays)
+{
+    if (!is(assays, "SimpleList")) {
+        if (is.list(assays) || is.array(assays)) {
+            assays <- SimpleList(assays)
+        } else {
+            stop("'assays' must be a SimpleList, list or array")
+        }
+    }
+    assays
+}
+
+Assays <- function(assays=SimpleList())
+{
+    assays <- .normarg_assays(assays)
+    #ans <- as(assays, "SimpleListAssays")
+    ans <- as(assays, "ShallowSimpleListAssays")
+    #ans <- as(assays, "AssaysInEnv")  # a *broken* alternative
+    validObject(ans)
+    ans
+}
+
+### Accessors
+
+.SL_get_length <- selectMethod("length", "SimpleList")
+setMethod("length", "Assays",
+    function(x)
+    {
+        assays <- as(x, "SimpleList", strict=FALSE)
+        .SL_get_length(assays)
+    }
+)
+
+.SL_get_names <- selectMethod("names", "SimpleList")
+setMethod("names", "Assays",
+    function(x)
+    {
+        assays <- as(x, "SimpleList", strict=FALSE)
+        .SL_get_names(assays)
+    }
+)
+
+.SL_set_names <- selectMethod("names<-", "SimpleList")
+setReplaceMethod("names", "Assays",
+    function(x, value)
+    {
+        assays <- as(x, "SimpleList", strict=FALSE)
+        assays <- .SL_set_names(assays, value)
+        as(assays, class(x))
+    }
+)
+
+setMethod("[[", "Assays",
+    function(x, i, j, ...)
+    {
+        assays <- as(x, "SimpleList", strict=FALSE)
+        getListElement(assays, i)
+    }
+)
+
+setReplaceMethod("[[", "Assays",
+    function(x, i, j, ..., value)
+    {
+        assays <- as(x, "SimpleList", strict=FALSE)
+        assays <- setListElement(assays, i, value)
+        ans <- as(assays, class(x))
+        validObject(ans)
+        ans
+    }
+)
+
+setMethod("dim", "Assays",
+    function(x)
+    {
+        if (length(x) == 0L)
+            return(c(0L, 0L))
+        dim(x[[1L]])
+    }
+)
+
+### 2D-Subsetting
+
+.extract_Assays_subset <- function(x, i, j)
+{
+    ## need to expand Rle's for subsetting standard matrix
+    if (!missing(i) && !missing(j)) {
+        fun <- function(x) {
+            switch(length(dim(x)),
+                   stop("'[' on assays() with 1 dimension not supported"),
+                   x[i, j, drop=FALSE],
+                   x[i, j, , drop=FALSE],
+                   x[i, j, , , drop=FALSE],
+                   stop("'[' on assays() with >4 dimensions not supported"))
+        }
+    } else if (!missing(i)) {
+        fun <- function(x) {
+            switch(length(dim(x)),
+                   stop("'[' on assays() with 1 dimension not supported"),
+                   x[i, , drop=FALSE],
+                   x[i, , , drop=FALSE],
+                   x[i, , , , drop=FALSE],
+                   stop("'[' on assays() with >4 dimensions not supported"))
+        }
+    } else if (!missing(j)) {
+        fun <- function(x) {
+            switch(length(dim(x)),
+                   stop("'[' on assays() with 1 dimension not supported"),
+                   x[, j, drop=FALSE],
+                   x[, j, , drop=FALSE],
+                   x[, j, , , drop=FALSE],
+                   stop("'[' on assays() with >4 dimensions not supported"))
+        }
+    }
+    assays <- as(x, "SimpleList", strict=FALSE)
+    as(endoapply(assays, fun), class(x))
+}
+
+setMethod("[", "Assays",
+    function(x, i, j, ..., drop=TRUE) .extract_Assays_subset(x, i, j)
+)
+
+.replace_Assays_subset <- function(x, i, j, value)
+{
+    ## need to expand Rle's for subsetting standard matrix
+    if (!missing(i) && !missing(j)) {
+        fun <- function(x, value) {
+            switch(length(dim(x)),
+                   stop("'[<-' on assays() with 1 dimension not supported"),
+                   x[i, j] <- value,
+                   x[i, j, ] <- value,
+                   x[i, j, , ] <- value,
+                   stop("'[<-' on assays() with >4 dimensions not supported"))
+            x
+        }
+    } else if (!missing(i)) {
+        fun <- function(x, value) {
+            switch(length(dim(x)),
+                   stop("'[<-' on assays() with 1 dimension not supported"),
+                   x[i, ] <- value,
+                   x[i, , ] <- value,
+                   x[i, , , ] <- value,
+                   stop("'[<-' on assays() with >4 dimensions not supported"))
+            x
+        }
+    } else if (!missing(j)) {
+        fun <- function(x, value) {
+            switch(length(dim(x)),
+                   stop("'[<-' on assays() with 1 dimension not supported"),
+                   x[, j] <- value,
+                   x[, j, ] <- value,
+                   x[, j, , ] <- value,
+                   stop("'[<-' on assays() with >4 dimensions not supported"))
+            x
+        }
+    }
+    a <- as(x, "SimpleList", strict=FALSE)
+    v <- as(value, "SimpleList", strict=FALSE)
+    as(mendoapply(fun, x=a, value=v), class(x))
+}
+
+setReplaceMethod("[", "Assays",
+    function(x, i, j, ..., value) .replace_Assays_subset(x, i, j, value)
+)
+
+### rbind/cbind
+
+.bind_Assays <- function(lst, bind)
+{
+    if (length(lst) == 0L)
+        return(Assays())
+    lens <- sapply(lst, length)
+    if (length(unique(lens)) != 1)
+        stop("assays must have the same length")
+    len1 <- lens[1L]
+    if (len1 == 0L)
+        return(Assays())
+    var <- lapply(lst, names)
+    uvar <- unique(unlist(var))
+    if (is.null(uvar)) {
+        ## no names, match by position
+        res <- lapply(seq_len(len1), function(index) {
+            e1 <- lapply(lst, "[[", index)
+            do.call(bind, e1)
+        })
+    } else {
+        ## match by name
+        ok <- all(vapply(var, function(x, y) identical(sort(x), y),
+                         logical(1), sort(uvar)))
+        if (!ok)
+            stop("assays must have the same names()")
+        res <- lapply(uvar, function(index) {
+            e1 <- lapply(lst, "[[", index)
+            do.call(bind, e1)
+        })
+        names(res) <- uvar
+    }
+    as(SimpleList(res), class(lst[[1L]]))
+}
+
+setMethod("rbind", "Assays",
+    function(..., deparse.level=1) .bind_Assays(unname(list(...)), arbind)
+)
+
+setMethod("cbind", "Assays",
+    function(..., deparse.level=1) .bind_Assays(unname(list(...)), acbind)
+)
+
+### Having "arbind" and "acbind" methods for Matrix objects will make rbind()
+### and cbind() work on Assays objects with Matrix list elements.
+### Maybe these methods should be defined next to the arbind() and acbind()
+### generics (which are defined in the IRanges package) but that would require
+### to make IRanges depend on the Matrix package.
+setMethod("arbind", "Matrix", function(...) rbind(...))
+setMethod("acbind", "Matrix", function(...) cbind(...))
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### SimpleListAssays class
+###
+
+### The order of inheritance is important: first Assays, then SimpleList!
+setClass("SimpleListAssays", contains=c("Assays", "SimpleList"))
+
+### Lossless back and forth coercion from/to SimpleList are automatically
+### taken care of by automatic methods defined by the methods package.
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### ShallowSimpleListAssays class
+###
+### We implement the REQUIRED coercions only.
+###
+
+.ShallowData <- setRefClass("ShallowData",
+    fields = list( data = "ANY" ))
+
+.ShallowSimpleListAssays0 <- setRefClass("ShallowSimpleListAssays",
+    fields = list( data = "SimpleList" ),
+    contains = c("ShallowData", "Assays"))
+
+setAs("SimpleList", "ShallowSimpleListAssays",
+    function(from) .ShallowSimpleListAssays0(data=from)
+)
+
+setAs("ShallowSimpleListAssays", "SimpleList", function(from) from$data)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### AssaysInEnv class
+###
+### A *broken* alternative to ShallowSimpleListAssays that does NOT respect
+### the copy-on-change contract (only provided for illustration purposes).
+###
+### We implement the REQUIRED coercions plus OPTIONAL methods: length, names,
+### names<-, [[, and [[<-.
+###
+
+setClass("AssaysInEnv",
+    contains="Assays",
+    representation(envir="environment")
+)
+
+.NAMES_SYMBOL <- ".names"  # must begin with a . so is ommitted by ls() 
+
+setMethod("length", "AssaysInEnv", function(x) length(x at envir) - 1L)
+
+setMethod("names", "AssaysInEnv", function(x) x at envir[[.NAMES_SYMBOL]])
+
+### Does NOT respect the copy-on-change contract!
+setReplaceMethod("names", "AssaysInEnv",
+    function(x, value)
+    {
+        value <- S4Vectors:::normalize_names_replacement_value(value, x)
+        x at envir[[.NAMES_SYMBOL]] <- value
+        x
+    }
+)
+
+setMethod("[[", "AssaysInEnv",
+    function(x, i, j, ...)
+    {
+        key <- setNames(ls(x at envir, sorted=TRUE), names(x))[[i]]
+        get(key, envir=x at envir)
+    }
+)
+
+### Does NOT respect the copy-on-change contract!
+setReplaceMethod("[[", "AssaysInEnv",
+    function(x, i, j, ..., value)
+    {
+        key <- setNames(ls(x at envir, sorted=TRUE), names(x))[[i]]
+        assign(key, value, envir=x at envir)
+        x
+    }
+)
+
+setAs("SimpleList", "AssaysInEnv",
+    function(from)
+    {
+        from <- as.list(from)
+        from_names <- names(from)
+        keys <- paste(sprintf("%09d", seq_along(from)), from_names, sep=":")
+        names(from) <- keys
+        envir <- list2env(from, parent=emptyenv())
+        envir[[.NAMES_SYMBOL]] <- from_names
+        new("AssaysInEnv", envir=envir)
+    }
+)
+
+setAs("AssaysInEnv", "SimpleList",
+    function(from)
+        SimpleList(setNames(as.list(from at envir, sorted=TRUE), names(from)))
+)
+
diff --git a/R/RangedSummarizedExperiment-class.R b/R/RangedSummarizedExperiment-class.R
new file mode 100644
index 0000000..9e7945f
--- /dev/null
+++ b/R/RangedSummarizedExperiment-class.R
@@ -0,0 +1,572 @@
+### =========================================================================
+### RangedSummarizedExperiment objects
+### -------------------------------------------------------------------------
+###
+
+
+### The 'elementMetadata' slot must contain a zero-column DataFrame at all time
+### (this is checked by the validity method). The top-level mcols are stored on
+### the rowRanges component.
+setClass("RangedSummarizedExperiment",
+    contains="SummarizedExperiment",
+    representation(
+        rowRanges="GenomicRangesORGRangesList"
+    ),
+    prototype(
+        rowRanges=GRanges()
+    )
+)
+
+### Combine the new parallel slots with those of the parent class. Make sure
+### to put the new parallel slots *first*.
+setMethod("parallelSlotNames", "RangedSummarizedExperiment",
+    function(x) c("rowRanges", callNextMethod())
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Validity.
+###
+
+### The names and mcols of a RangedSummarizedExperiment must be set on its
+### rowRanges slot, not in its NAMES and elementMetadata slots!
+.valid.RangedSummarizedExperiment <- function(x)
+{
+    if (!is.null(x at NAMES))
+        return("'NAMES' slot must be set to NULL at all time")
+    if (ncol(x at elementMetadata) != 0L)
+        return(wmsg("'elementMetadata' slot must contain a zero-column ",
+                    "DataFrame at all time"))
+    rowRanges_len <- length(x at rowRanges)
+    x_nrow <- length(x)
+    if (rowRanges_len != x_nrow) {
+        txt <- sprintf(
+            "\n  length of 'rowRanges' (%d) must equal nb of rows in 'x' (%d)",
+            rowRanges_len, x_nrow)
+        return(txt)
+    }
+    NULL
+}
+
+setValidity2("RangedSummarizedExperiment", .valid.RangedSummarizedExperiment)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Constructor.
+###
+
+.new_RangedSummarizedExperiment <- function(assays, rowRanges, colData,
+                                            metadata)
+{
+    elementMetadata <- S4Vectors:::make_zero_col_DataFrame(length(rowRanges))
+    if (!is(assays, "Assays"))
+        assays <- Assays(assays)
+    new("RangedSummarizedExperiment", rowRanges=rowRanges,
+                                      colData=colData,
+                                      assays=assays,
+                                      elementMetadata=elementMetadata,
+                                      metadata=as.list(metadata))
+}
+
+.get_colnames_from_assays <- function(assays)
+{
+    if (length(assays) == 0L)
+        return(NULL)
+    colnames(assays[[1L]])
+}
+
+.get_rownames_from_assays <- function(assays)
+{
+    if (length(assays) == 0L)
+        return(NULL)
+    rownames(assays[[1L]])
+}
+
+setGeneric("SummarizedExperiment",
+    function(assays, ...) standardGeneric("SummarizedExperiment"))
+
+setMethod("SummarizedExperiment", "SimpleList",
+   function(assays, rowData=NULL, rowRanges=GRangesList(), colData=DataFrame(),
+            metadata=list())
+{
+    if (missing(colData) && 0L != length(assays)) {
+        assay <- assays[[1]]
+        nms <- colnames(assay)
+        colData <- DataFrame(x=seq_len(ncol(assay)), row.names=nms)[, FALSE]
+    } else if (!missing(colData)) {
+        colData <- as(colData, "DataFrame")
+        if (is.null(rownames(colData)))
+            rownames(colData) <- .get_colnames_from_assays(assays)
+    }
+    ans_colnames <- rownames(colData)
+
+    if (is.null(rowData)) {
+        if (missing(rowRanges)) {
+            ans_rownames <- .get_rownames_from_assays(assays)
+        } else {
+            if (is.null(names(rowRanges)))
+                names(rowRanges) <- .get_rownames_from_assays(assays)
+            ans_rownames <- names(rowRanges)
+        }
+    } else {
+        if (!missing(rowRanges))
+            stop("only one of 'rowData' and 'rowRanges' can be specified")
+        if (is(rowData, "GenomicRangesORGRangesList")) {
+            rowRanges <- rowData
+            if (is.null(names(rowRanges)))
+                names(rowRanges) <- .get_rownames_from_assays(assays)
+            ans_rownames <- names(rowRanges)
+        } else {
+            rowData <- as(rowData, "DataFrame")
+            ans_rownames <- rownames(rowData)
+            if (is.null(ans_rownames))
+                ans_rownames <- .get_rownames_from_assays(assays)
+        }
+    }
+
+    ## validate
+    ok <- vapply(assays, function(x) {
+        colnames <- colnames(x)
+        test <- is.null(colnames) || identical(colnames, ans_colnames)
+        if (!test)
+            stop("assay colnames() must be NULL or equal colData rownames()")
+
+        rownames <- rownames(x)
+        test <- test &&
+            is.null(rownames) || identical(rownames, ans_rownames)
+        if (!test) {
+            txt <- "assay rownames() must be NULL or equal rowData rownames() /
+                    rowRanges names()"
+            stop(paste(strwrap(txt, exdent=2), collapse="\n"))
+        }
+
+        test
+    }, logical(1))
+
+    assays <- Assays(assays)
+
+    if (missing(rowRanges) && !is(rowData, "GenomicRangesORGRangesList")) {
+        new_SummarizedExperiment(assays, ans_rownames, rowData, colData,
+                                 metadata)
+    } else {
+        .new_RangedSummarizedExperiment(assays, rowRanges, colData, metadata)
+    }
+})
+
+setMethod("SummarizedExperiment", "ANY",
+    function(assays, ...)
+{
+    if (is.matrix(assays) && is.list(assays))
+        ## special case -- matrix of lists
+        assays <- list(assays)
+    SummarizedExperiment(SimpleList(assays), ...)
+})
+
+setMethod("SummarizedExperiment", "list",
+    function(assays, ...)
+{
+    SummarizedExperiment(do.call(SimpleList, assays), ...)
+})
+
+setMethod("SummarizedExperiment", "missing",
+    function(assays, ...)
+{
+    SummarizedExperiment(SimpleList(), ...)
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Coercion.
+###
+### See makeSummarizedExperimentFromExpressionSet.R for coercion back and
+### forth between SummarizedExperiment and ExpressionSet.
+###
+
+.from_RangedSummarizedExperiment_to_SummarizedExperiment <- function(from)
+{
+    new_SummarizedExperiment(from at assays,
+                             names(from at rowRanges),
+                             mcols(from at rowRanges),
+                             from at colData,
+                             from at metadata)
+}
+
+setAs("RangedSummarizedExperiment", "SummarizedExperiment",
+    .from_RangedSummarizedExperiment_to_SummarizedExperiment
+)
+
+.from_SummarizedExperiment_to_RangedSummarizedExperiment <- function(from)
+{
+    partitioning <- PartitioningByEnd(integer(length(from)), names=names(from))
+    rowRanges <- relist(GRanges(), partitioning)
+    .new_RangedSummarizedExperiment(from at assays,
+                                    rowRanges,
+                                    from at colData,
+                                    from at metadata)
+}
+
+setAs("SummarizedExperiment", "RangedSummarizedExperiment",
+    .from_SummarizedExperiment_to_RangedSummarizedExperiment
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Getters and setters.
+###
+
+### The rowRanges() generic is defined in the DelayedArray package.
+setMethod("rowRanges", "RangedSummarizedExperiment",
+    function(x, ...) x at rowRanges
+)
+
+setGeneric("rowRanges<-",
+    function(x, ..., value) standardGeneric("rowRanges<-"))
+
+.SummarizedExperiment.rowRanges.replace <-
+    function(x, ..., value)
+{
+    if (!is(x, "RangedSummarizedExperiment"))
+        x <- as(x, "RangedSummarizedExperiment")
+    x <- BiocGenerics:::replaceSlots(x, ...,
+             rowRanges=value,
+             elementMetadata=S4Vectors:::make_zero_col_DataFrame(length(value)),
+             check=FALSE)
+    msg <- .valid.SummarizedExperiment.assays_nrow(x)
+    if (!is.null(msg))
+        stop(msg)
+    x
+}
+
+setReplaceMethod("rowRanges", c("SummarizedExperiment", "GenomicRanges"),
+    .SummarizedExperiment.rowRanges.replace)
+
+setReplaceMethod("rowRanges", c("SummarizedExperiment", "GRangesList"),
+    .SummarizedExperiment.rowRanges.replace)
+
+setMethod("names", "RangedSummarizedExperiment",
+    function(x) names(rowRanges(x))
+)
+
+setReplaceMethod("names", "RangedSummarizedExperiment",
+    function(x, value)
+{
+    rowRanges <- rowRanges(x)
+    names(rowRanges) <- value
+    BiocGenerics:::replaceSlots(x, rowRanges=rowRanges, check=FALSE)
+})
+
+setMethod("dimnames", "RangedSummarizedExperiment",
+    function(x)
+{
+    list(names(x), rownames(colData(x)))
+})
+
+setReplaceMethod("dimnames", c("RangedSummarizedExperiment", "list"),
+    function(x, value)
+{
+    rowRanges <- rowRanges(x)
+    names(rowRanges) <- value[[1]]
+    colData <- colData(x)
+    rownames(colData) <- value[[2]]
+    BiocGenerics:::replaceSlots(x,
+        rowRanges=rowRanges,
+        colData=colData,
+        check=FALSE)
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Subsetting.
+###
+
+.DollarNames.RangedSummarizedExperiment <-
+    .DollarNames.SummarizedExperiment
+
+setMethod("subset", "RangedSummarizedExperiment",
+    function(x, subset, select, ...)
+{
+    i <- S4Vectors:::evalqForSubset(subset, rowRanges(x), ...)
+    j <- S4Vectors:::evalqForSubset(select, colData(x), ...)
+    x[i, j]
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+## colData-as-GRanges compatibility: allow direct access to GRanges /
+## GRangesList colData for select functions
+
+## Not supported:
+## 
+## Not consistent SummarizedExperiment structure: length, names,
+##   as.data.frame, c.
+## Length-changing endomorphisms: disjoin, gaps, reduce, unique.
+## 'legacy' data types / functions: as "RangedData", as "RangesList",
+##   renameSeqlevels, keepSeqlevels.
+## Possile to implement, but not yet: Ops, map, window, window<-
+
+## mcols
+setMethod("mcols", "RangedSummarizedExperiment",
+    function(x, use.names=FALSE, ...)
+{
+    mcols(rowRanges(x), use.names=use.names, ...)
+})
+
+setReplaceMethod("mcols", "RangedSummarizedExperiment",
+    function(x, ..., value)
+{
+    BiocGenerics:::replaceSlots(x,
+        rowRanges=local({
+            r <- rowRanges(x)
+            mcols(r) <- value
+            r
+        }),
+        check=FALSE)
+})
+
+### mcols() is the recommended way for accessing the metadata columns.
+### Use of values() or elementMetadata() is discouraged.
+
+setMethod("elementMetadata", "RangedSummarizedExperiment",
+    function(x, use.names=FALSE, ...)
+{
+    elementMetadata(rowRanges(x), use.names=use.names, ...)
+})
+
+setReplaceMethod("elementMetadata", "RangedSummarizedExperiment",
+    function(x, ..., value)
+{
+    elementMetadata(rowRanges(x), ...) <- value
+    x
+})
+
+## Single dispatch, generic signature fun(x, ...)
+local({
+    .funs <-
+        c("duplicated", "end", "end<-", "ranges", "seqinfo", "seqnames",
+          "start", "start<-", "strand", "width", "width<-")
+
+    endomorphisms <- .funs[grepl("<-$", .funs)]
+
+    tmpl <- function() {}
+    environment(tmpl) <- parent.frame(2)
+    for (.fun in .funs) {
+        generic <- getGeneric(.fun)
+        formals(tmpl) <- formals(generic)
+        fmls <- as.list(formals(tmpl))
+        fmls[] <- sapply(names(fmls), as.symbol)
+        fmls[[generic at signature]] <- quote(rowRanges(x))
+        if (.fun %in% endomorphisms)
+            body(tmpl) <- substitute({
+                rowRanges(x) <- do.call(FUN, ARGS)
+                x
+            }, list(FUN=.fun, ARGS=fmls))
+        else
+            body(tmpl) <-
+                substitute(do.call(FUN, ARGS),
+                           list(FUN=as.symbol(.fun), ARGS=fmls))
+        setMethod(.fun, "RangedSummarizedExperiment", tmpl)
+    }
+})
+
+setMethod("granges", "RangedSummarizedExperiment",
+    function(x, use.mcols=FALSE, ...)
+{
+    if (!identical(use.mcols, FALSE))
+        stop("\"granges\" method for RangedSummarizedExperiment objects ",
+             "does not support the 'use.mcols' argument")
+    rowRanges(x)
+})
+
+## 2-argument dispatch:
+## pcompare / Compare 
+## 
+.RangedSummarizedExperiment.pcompare <-
+    function(x, y)
+{
+    if (is(x, "RangedSummarizedExperiment"))
+        x <- rowRanges(x)
+    if (is(y, "RangedSummarizedExperiment"))
+        y <- rowRanges(y)
+    pcompare(x, y)
+}
+
+.RangedSummarizedExperiment.Compare <-
+    function(e1, e2)
+{
+    if (is(e1, "RangedSummarizedExperiment"))
+        e1 <- rowRanges(e1)
+    if (is(e2, "RangedSummarizedExperiment"))
+        e2 <- rowRanges(e2)
+    callGeneric(e1=e1, e2=e2)
+}
+
+local({
+    .signatures <- list(
+        c("RangedSummarizedExperiment", "ANY"),
+        c("ANY", "RangedSummarizedExperiment"),
+        c("RangedSummarizedExperiment", "RangedSummarizedExperiment"))
+
+    for (.sig in .signatures) {
+        setMethod("pcompare", .sig, .RangedSummarizedExperiment.pcompare)
+        setMethod("Compare", .sig, .RangedSummarizedExperiment.Compare)
+    }
+})
+
+## additional getters / setters
+
+setReplaceMethod("strand", "RangedSummarizedExperiment",
+    function(x, ..., value)
+{
+    strand(rowRanges(x)) <- value
+    x
+})
+
+setReplaceMethod("ranges", "RangedSummarizedExperiment",
+    function(x, ..., value)
+{
+    ranges(rowRanges(x)) <- value
+    x
+})
+
+## order, rank, sort
+
+setMethod("is.unsorted", "RangedSummarizedExperiment",
+    function(x, na.rm = FALSE, strictly = FALSE, ignore.strand = FALSE)
+{
+    x <- rowRanges(x)
+    if (!is(x, "GenomicRanges"))
+        stop("is.unsorted() is not yet supported when 'rowRanges(x)' is a ",
+             class(x), " object")
+    callGeneric()
+})
+
+setMethod("order", "RangedSummarizedExperiment",
+    function(..., na.last=TRUE, decreasing=FALSE,
+             method=c("auto", "shell", "radix"))
+{
+    args <- lapply(list(...), rowRanges)
+    do.call("order", c(args, list(na.last=na.last,
+                                  decreasing=decreasing,
+                                  method=method)))
+})
+
+setMethod("rank", "RangedSummarizedExperiment",
+    function(x, na.last = TRUE,
+        ties.method = c("average", "first", "last", "random", "max", "min"))
+{
+    ties.method <- match.arg(ties.method)
+    rank(rowRanges(x), na.last=na.last, ties.method=ties.method)
+})
+
+setMethod("sort", "RangedSummarizedExperiment",
+    function(x, decreasing = FALSE, ignore.strand = FALSE)
+{
+    x_rowRanges <- rowRanges(x)
+    if (!is(x_rowRanges, "GenomicRanges"))
+        stop("sort() is not yet supported when 'rowRanges(x)' is a ",
+             class(x_rowRanges), " object")
+    oo <- GenomicRanges:::order_GenomicRanges(x_rowRanges,
+                                              decreasing = decreasing,
+                                              ignore.strand = ignore.strand)
+    x[oo]
+})
+
+## seqinfo (also seqlevels, genome, seqlevels<-, genome<-), seqinfo<-
+
+setMethod("seqinfo", "RangedSummarizedExperiment",
+    function(x)
+{
+    seqinfo(x at rowRanges)
+})
+
+setReplaceMethod("seqinfo", "RangedSummarizedExperiment",
+    function (x, new2old= NULL, force=FALSE,
+              pruning.mode=c("error", "coarse", "fine", "tidy"),
+              value)
+{
+    if (!is(value, "Seqinfo")) 
+        stop("the supplied 'seqinfo' must be a Seqinfo object")
+    dangling_seqlevels <-
+        GenomeInfoDb:::getDanglingSeqlevels(x at rowRanges, new2old=new2old,
+                                            force=force,
+                                            pruning.mode=pruning.mode,
+                                            seqlevels(value))
+    if (length(dangling_seqlevels) != 0L) 
+        x <- x[!(seqnames(x) %in% dangling_seqlevels)]
+    x at rowRanges <-
+        update(x at rowRanges,
+               seqnames = GenomeInfoDb:::makeNewSeqnames(x, new2old,
+                                                         seqlevels(value)),
+               seqinfo = value)
+    if (is.character(msg <- .valid.RangedSummarizedExperiment(x)))
+        stop(msg)
+    x
+})
+
+setMethod("split", "RangedSummarizedExperiment",
+    function(x, f, drop=FALSE, ...) 
+{
+    splitAsList(x, f, drop=drop)
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### updateObject()
+###
+
+.old_SummarizedExperiment_slots <- c(
+    "assays",
+    "rowData",
+    "colData",
+    "exptData"
+)
+
+.has_old_SummarizedExperiment_internal_structure <- function(object)
+    all(sapply(.old_SummarizedExperiment_slots, .hasSlot, object=object))
+
+.from_old_SummarizedExperiment_to_RangedSummarizedExperiment <- function(from)
+    .new_RangedSummarizedExperiment(from at assays,
+                                    from at rowData,
+                                    from at colData,
+                                    from at exptData)
+
+.update_old_SummarizedExperiment <- function(object, ..., verbose=FALSE)
+{
+    if (.has_old_SummarizedExperiment_internal_structure(object)) {
+        rse <- .from_old_SummarizedExperiment_to_RangedSummarizedExperiment(object)
+    } else if (!(.hasSlot(object, "NAMES") &&
+                 .hasSlot(object, "elementMetadata"))) {
+        rse <- .new_RangedSummarizedExperiment(object at assays,
+                                               object at rowRanges,
+                                               object at colData,
+                                               object at metadata)
+    } else {
+        return(object)
+    }
+
+    if (!(extends(class(object), "RangedSummarizedExperiment") &&
+          class(object) != "RangedSummarizedExperiment"))
+        return(rse)
+
+    xslotnames <- setdiff(slotNames(class(object)), slotNames(class(rse)))
+    xslots <- attributes(object)[xslotnames]
+    #do.call("new", c(list(Class=class(object), rse), xslots))
+
+    ## The line above doesn't work because of a bug in R (see
+    ## https://stat.ethz.ch/pipermail/r-devel/2015-May/071130.html),
+    ## so we use the workaround below.
+    rse_slots <- attributes(rse)[slotNames(class(rse))]
+
+    ## Because of another bug in R, rse_slots$NAMES is broken when the NAMES
+    ## slot is NULL so we repair it (see
+    ## https://bugs.r-project.org/bugzilla/show_bug.cgi?id=16428).
+    if (is.name(rse_slots$NAMES))
+        rse_slots$NAMES <- NULL
+
+    do.call("new", c(list(Class=class(object)), rse_slots, xslots))
+}
+
+setMethod("updateObject", "SummarizedExperiment",
+    .update_old_SummarizedExperiment
+)
+
diff --git a/R/SummarizedExperiment-class.R b/R/SummarizedExperiment-class.R
new file mode 100644
index 0000000..4fbeb0a
--- /dev/null
+++ b/R/SummarizedExperiment-class.R
@@ -0,0 +1,844 @@
+### =========================================================================
+### SummarizedExperiment objects
+### -------------------------------------------------------------------------
+###
+
+
+setClass("SummarizedExperiment",
+    contains="Vector",
+    representation(
+        colData="DataFrame",              # columns and their annotations
+        assays="Assays",                  # Data -- e.g., list of matricies
+        NAMES="character_OR_NULL",
+        elementMetadata="DataFrame"
+    ),
+    prototype(
+        assays=Assays()
+    )
+)
+
+### Combine the new parallel slots with those of the parent class. Make sure
+### to put the new parallel slots *first*.
+setMethod("parallelSlotNames", "SummarizedExperiment",
+    function(x) c("NAMES", callNextMethod())
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Validity.
+###
+
+.valid.SummarizedExperiment.assays_nrow <- function(x)
+{
+    if (length(x at assays) == 0L)
+        return(NULL)
+    assays_nrow <- nrow(x at assays)
+    rowData_nrow <- length(x)
+    if (assays_nrow != rowData_nrow) {
+        txt <- sprintf(
+            "\n  nb of rows in 'assay' (%d) must equal nb of rows in 'rowData' (%d)",
+            assays_nrow, rowData_nrow)
+        return(txt)
+    }
+    NULL
+}
+
+.valid.SummarizedExperiment.assays_ncol <- function(x)
+{
+    if (length(x at assays) == 0L)
+        return(NULL)
+    assays_ncol <- ncol(x at assays)
+    colData_nrow <- nrow(colData(x))
+    if (assays_ncol != colData_nrow) {
+        txt <- sprintf(
+            "\n  nb of cols in 'assay' (%d) must equal nb of rows in 'colData' (%d)",
+            assays_ncol, colData_nrow)
+        return(txt)
+    }
+    NULL
+}
+
+.valid.SummarizedExperiment.assays_dim <- function(x)
+{
+    c(.valid.SummarizedExperiment.assays_nrow(x),
+      .valid.SummarizedExperiment.assays_ncol(x))
+}
+
+.valid.SummarizedExperiment <- function(x)
+{
+    .valid.SummarizedExperiment.assays_dim(x)
+}
+
+setValidity2("SummarizedExperiment", .valid.SummarizedExperiment)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Low-level constructor (not exported).
+###
+
+new_SummarizedExperiment <- function(assays, names, rowData, colData,
+                                     metadata)
+{
+    if (!is(assays, "Assays"))
+        assays <- Assays(assays)
+    if (is.null(rowData)) {
+        if (is.null(names))
+            nrow <- nrow(assays)
+        else
+            nrow <- length(names)
+        rowData <- S4Vectors:::make_zero_col_DataFrame(nrow)
+    } else {
+        rownames(rowData) <- NULL
+    }
+    new("SummarizedExperiment", NAMES=names,
+                                elementMetadata=rowData,
+                                colData=colData,
+                                assays=assays,
+                                metadata=as.list(metadata))
+}
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Getters and setters.
+###
+
+setMethod("length", "SummarizedExperiment",
+    function(x) nrow(x at elementMetadata)
+)
+
+setMethod("names", "SummarizedExperiment", function(x) x at NAMES)
+
+setReplaceMethod("names", "SummarizedExperiment",
+    function(x, value)
+    {
+        NAMES <- S4Vectors:::normalize_names_replacement_value(value, x)
+        BiocGenerics:::replaceSlots(x, NAMES=NAMES, check=FALSE)
+    }
+)
+
+## rowData, colData seem too vague, but from eSet derived classes wanted to
+## call the rows / cols something different from 'features' or 'samples', so
+## might as well avoid the issue
+
+setGeneric("rowData", function(x, ...) standardGeneric("rowData"))
+
+setMethod("rowData", "SummarizedExperiment",
+    function(x, ...) mcols(x, ...)
+)
+
+setGeneric("rowData<-",
+    function(x, ..., value) standardGeneric("rowData<-"))
+
+setReplaceMethod("rowData", "SummarizedExperiment",
+    function(x, ..., value) `mcols<-`(x, ..., value=value)
+)
+
+setGeneric("colData", function(x, ...) standardGeneric("colData"))
+
+setMethod("colData", "SummarizedExperiment", function(x, ...) x at colData)
+
+setGeneric("colData<-",
+    function(x, ..., value) standardGeneric("colData<-"))
+
+setReplaceMethod("colData", c("SummarizedExperiment", "DataFrame"),
+    function(x, ..., value)
+{
+    if (nrow(value) != ncol(x))
+        stop("nrow of supplied 'colData' must equal ncol of object")
+    BiocGenerics:::replaceSlots(x, colData=value, check=FALSE)
+})
+
+setGeneric("assays",
+    function(x, ..., withDimnames=TRUE) standardGeneric("assays"),
+    signature="x")
+
+setMethod("assays", "SummarizedExperiment",
+    function(x, ..., withDimnames=TRUE)
+{
+    assays <- as(x at assays, "SimpleList")
+    if (withDimnames) {
+        assays <- endoapply(assays,
+            function(assay) {
+                dimnames(assay)[1:2] <- dimnames(x)
+                assay
+            }
+        )
+    }
+    assays
+})
+
+setGeneric("assays<-",
+    function(x, ..., withDimnames=TRUE, value) standardGeneric("assays<-"),
+    signature=c("x", "value"))
+
+.SummarizedExperiment.assays.replace <-
+    function(x, ..., withDimnames=TRUE, value)
+{
+    ## withDimnames arg allows names(assays(se, withDimnames=FALSE)) <- value
+    ok <- vapply(value, function(elt, xdimnames) {
+        e <- dimnames(elt)
+        (is.null(e[[1]]) || identical(e[[1]], xdimnames[[1]])) &&
+             (is.null(e[[2]]) || identical(e[[2]], xdimnames[[2]]))
+    }, logical(1), xdimnames=dimnames(x))
+    if (!all(ok))
+        stop("current and replacement dimnames() differ")
+    x <- BiocGenerics:::replaceSlots(x, assays=Assays(value), check=FALSE)
+    ## validObject(x) should be called below because it would then fully
+    ## re-validate objects that derive from SummarizedExperiment (e.g.
+    ## DESeqDataSet objects) after the user sets the assays slot with
+    ## assays(x) <- value. For example the assays slot of a DESeqDataSet
+    ## object must contain a matrix named 'counts' and calling validObject(x)
+    ## would check that but .valid.SummarizedExperiment(x) doesn't.
+    ## The FourC() constructor function defined in the FourCSeq package
+    ## actually takes advantage of the incomplete validation below to
+    ## purposedly return invalid FourC objects!
+    msg <- .valid.SummarizedExperiment(x)
+    if (!is.null(msg)) 
+        stop(msg)
+    x
+}
+
+setReplaceMethod("assays", c("SummarizedExperiment", "SimpleList"),
+    .SummarizedExperiment.assays.replace)
+
+setReplaceMethod("assays", c("SummarizedExperiment", "list"),
+    .SummarizedExperiment.assays.replace)
+
+setGeneric("assay", function(x, i, ...) standardGeneric("assay"))
+
+## convenience for common use case
+setMethod("assay", c("SummarizedExperiment", "missing"),
+    function(x, i, ...)
+{
+    assays <- assays(x, ...)
+    if (0L == length(assays))
+        stop("'assay(<", class(x), ">, i=\"missing\", ...) ",
+             "length(assays(<", class(x), ">)) is 0'")
+    assays[[1]]
+})
+
+setMethod("assay", c("SummarizedExperiment", "numeric"),
+    function(x, i, ...)
+{
+    tryCatch({
+        assays(x, ...)[[i]]
+    }, error=function(err) {
+        stop("'assay(<", class(x), ">, i=\"numeric\", ...)' ",
+             "invalid subscript 'i'\n", conditionMessage(err))
+    })
+})
+
+setMethod("assay", c("SummarizedExperiment", "character"),
+    function(x, i, ...)
+{
+    msg <- paste0("'assay(<", class(x), ">, i=\"character\", ...)' ",
+                  "invalid subscript 'i'")
+    res <- tryCatch({
+        assays(x, ...)[[i]]
+    }, error=function(err) {
+        stop(msg, "\n", conditionMessage(err))
+    })
+    if (is.null(res))
+        stop(msg, "\n'i' not in names(assays(<", class(x), ">))")
+    res
+})
+
+setGeneric("assay<-", signature=c("x", "i"),
+    function(x, i, ..., value) standardGeneric("assay<-"))
+
+setReplaceMethod("assay", c("SummarizedExperiment", "missing"),
+    function(x, i, ..., value)
+{
+    if (0L == length(assays(x)))
+        stop("'assay(<", class(x), ">) <- value' ", "length(assays(<",
+             class(x), ">)) is 0")
+    assays(x)[[1]] <- value
+    x
+})
+
+setReplaceMethod("assay", c("SummarizedExperiment", "numeric"),
+    function(x, i = 1, ..., value)
+{
+    assays(x, ...)[[i]] <- value
+    x
+})
+
+setReplaceMethod("assay", c("SummarizedExperiment", "character"),
+    function(x, i, ..., value)
+{
+    assays(x, ...)[[i]] <- value
+    x
+})
+
+setGeneric("assayNames", function(x, ...) standardGeneric("assayNames"))
+
+setMethod("assayNames", "SummarizedExperiment",
+    function(x, ...)
+{
+    names(assays(x, withDimnames=FALSE))
+})
+
+setGeneric("assayNames<-",
+    function(x, ..., value) standardGeneric("assayNames<-"))
+
+setReplaceMethod("assayNames", c("SummarizedExperiment", "character"),
+    function(x, ..., value)
+{
+    names(assays(x, withDimnames=FALSE)) <- value
+    x
+})
+
+## cannonical location for dim, dimnames; dimnames should be checked
+## for consistency (if non-null) and stripped from assays on
+## construction, or added from assays if row/col names are NULL in
+## <SummarizedExperiment> but not assays. dimnames need to be added on
+## to assays when assays() invoked
+setMethod("dim", "SummarizedExperiment",
+    function(x)
+{
+    c(length(x), nrow(colData(x)))
+})
+
+setMethod("dimnames", "SummarizedExperiment",
+    function(x)
+{
+    list(names(x), rownames(colData(x)))
+})
+
+setReplaceMethod("dimnames", c("SummarizedExperiment", "list"),
+    function(x, value)
+{
+    NAMES <- S4Vectors:::normalize_names_replacement_value(value[[1]], x)
+    colData <- colData(x)
+    rownames(colData) <- value[[2]]
+    BiocGenerics:::replaceSlots(x, NAMES=NAMES, colData=colData, check=FALSE)
+})
+
+setReplaceMethod("dimnames", c("SummarizedExperiment", "NULL"),
+    function(x, value)
+{
+    dimnames(x) <- list(NULL, NULL)
+    x
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Subsetting.
+###
+
+.SummarizedExperiment.charbound <-
+    function(idx, txt, fmt)
+{
+    orig <- idx
+    idx <- match(idx, txt)
+    if (any(bad <- is.na(idx))) {
+        msg <- paste(S4Vectors:::selectSome(orig[bad]), collapse=" ")
+        stop(sprintf(fmt, msg))
+    }
+    idx
+}
+
+setMethod("[", c("SummarizedExperiment", "ANY", "ANY"),
+    function(x, i, j, ..., drop=TRUE)
+{
+    if (1L != length(drop) || (!missing(drop) && drop))
+        warning("'drop' ignored '[,", class(x), ",ANY,ANY-method'")
+
+    if (missing(i) && missing(j))
+        return(x)
+
+    if (!missing(i)) {
+        if (is.character(i)) {
+            fmt <- paste0("<", class(x), ">[i,] index out of bounds: %s")
+            i <- .SummarizedExperiment.charbound(i, rownames(x), fmt)
+        }
+        ii <- as.vector(i)
+        ans_elementMetadata <- x at elementMetadata[i, , drop=FALSE]
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans_rowRanges <- x at rowRanges[i]
+        } else {
+            ans_NAMES <- x at NAMES[ii]
+        }
+    }
+    if (!missing(j)) {
+        if (is.character(j)) {
+            fmt <- paste0("<", class(x), ">[,j] index out of bounds: %s")
+            j <- .SummarizedExperiment.charbound(j, colnames(x), fmt)
+        }
+        ans_colData <- x at colData[j, , drop=FALSE]
+        jj <- as.vector(j)
+    }
+
+    if (missing(i)) {
+        ans_assays <- x at assays[ , jj]
+        ans <- BiocGenerics:::replaceSlots(x, ...,
+                       colData=ans_colData,
+                       assays=ans_assays,
+                       check=FALSE)
+    } else if (missing(j)) {
+        ans_assays <- x at assays[ii, ]
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       elementMetadata=ans_elementMetadata,
+                       rowRanges=ans_rowRanges,
+                       assays=ans_assays,
+                       check=FALSE)
+        } else {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       elementMetadata=ans_elementMetadata,
+                       NAMES=ans_NAMES,
+                       assays=ans_assays,
+                       check=FALSE)
+        }
+    } else {
+        ans_assays <- x at assays[ii, jj]
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       elementMetadata=ans_elementMetadata,
+                       rowRanges=ans_rowRanges,
+                       colData=ans_colData,
+                       assays=ans_assays,
+                       check=FALSE)
+        } else {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       elementMetadata=ans_elementMetadata,
+                       NAMES=ans_NAMES,
+                       colData=ans_colData,
+                       assays=ans_assays,
+                       check=FALSE)
+        }
+    }
+    ans
+})
+
+setReplaceMethod("[",
+    c("SummarizedExperiment", "ANY", "ANY", "SummarizedExperiment"),
+    function(x, i, j, ..., value)
+{
+    if (missing(i) && missing(j))
+        return(value)
+
+    ans_metadata <- c(metadata(x), metadata(value))
+
+    if (!missing(i)) {
+        if (is.character(i)) {
+            fmt <- paste0("<", class(x), ">[i,] index out of bounds: %s")
+            i <- .SummarizedExperiment.charbound(i, rownames(x), fmt)
+        }
+        ii <- as.vector(i)
+        ans_elementMetadata <- local({
+            emd <- x at elementMetadata
+            emd[i,] <- value at elementMetadata
+            emd
+        })
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans_rowRanges <- local({
+                r <- x at rowRanges
+                r[i] <- value at rowRanges
+                names(r)[ii] <- names(value at rowRanges)
+                r
+            })
+        } else {
+            ans_NAMES <- local({
+                nms <- x at NAMES
+                nms[ii] <- value at NAMES
+                nms
+            })
+        }
+    }
+
+    if (!missing(j)) {
+        if (is.character(j)) {
+            fmt <- paste0("<", class(x), ">[,j] index out of bounds: %s")
+            j <- .SummarizedExperiment.charbound(j, colnames(x), fmt)
+        }
+        jj <- as.vector(j)
+        ans_colData <- local({
+            c <- x at colData
+            c[j,] <- value at colData
+            rownames(c)[jj] <- rownames(value at colData)
+            c
+        })
+    }
+
+    if (missing(i)) {
+        ans_assays <- local({
+            a <- x at assays
+            a[ , jj] <- value at assays
+            a
+        })
+        ans <- BiocGenerics:::replaceSlots(x, ...,
+                   metadata=ans_metadata,
+                   colData=ans_colData,
+                   assays=ans_assays,
+                   check=FALSE)
+        msg <- .valid.SummarizedExperiment.assays_ncol(ans)
+    } else if (missing(j)) {
+        ans_assays <- local({
+            a <- x at assays
+            a[ii, ] <- value at assays
+            a
+        })
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       metadata=ans_metadata,
+                       elementMetadata=ans_elementMetadata,
+                       rowRanges=ans_rowRanges,
+                       assays=ans_assays,
+                       check=FALSE)
+        } else {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       metadata=ans_metadata,
+                       elementMetadata=ans_elementMetadata,
+                       NAMES=ans_NAMES,
+                       assays=ans_assays,
+                       check=FALSE)
+        }
+        msg <- .valid.SummarizedExperiment.assays_nrow(ans)
+    } else {
+        ans_assays <- local({
+            a <- x at assays
+            a[ii, jj] <- value at assays
+            a
+        })
+        if (is(x, "RangedSummarizedExperiment")) {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       metadata=ans_metadata,
+                       elementMetadata=ans_elementMetadata,
+                       rowRanges=ans_rowRanges,
+                       colData=ans_colData,
+                       assays=ans_assays,
+                       check=FALSE)
+        } else {
+            ans <- BiocGenerics:::replaceSlots(x, ...,
+                       metadata=ans_metadata,
+                       elementMetadata=ans_elementMetadata,
+                       NAMES=ans_NAMES,
+                       colData=ans_colData,
+                       assays=ans_assays,
+                       check=FALSE)
+        }
+        msg <- .valid.SummarizedExperiment.assays_dim(ans)
+    }
+    if (!is.null(msg))
+        stop(msg)
+    ans
+})
+
+setMethod("extractROWS", "SummarizedExperiment",
+    function(x, i)
+    {
+        i <- normalizeSingleBracketSubscript(i, x)
+        x[i, ]
+    }
+)
+
+setMethod("replaceROWS", "SummarizedExperiment",
+    function(x, i, value)
+    {
+        i <- normalizeSingleBracketSubscript(i, x)
+        x[i, ] <- value
+        x
+    }
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Quick colData access.
+###
+
+setMethod("[[", c("SummarizedExperiment", "ANY", "missing"),
+    function(x, i, j, ...)
+{
+    colData(x)[[i, ...]]
+})
+
+setReplaceMethod("[[", c("SummarizedExperiment", "ANY", "missing"),
+    function(x, i, j, ..., value)
+{
+    colData(x)[[i, ...]] <- value
+    x
+})
+
+.DollarNames.SummarizedExperiment <- function(x, pattern = "")
+    grep(pattern, names(colData(x)), value=TRUE)
+
+setMethod("$", "SummarizedExperiment",
+    function(x, name)
+{
+    colData(x)[[name]]
+})
+
+setReplaceMethod("$", "SummarizedExperiment",
+    function(x, name, value)
+{
+    colData(x)[[name]] <- value
+    x
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Display.
+###
+
+setMethod("show", "SummarizedExperiment",
+    function(object)
+{
+    selectSome <- S4Vectors:::selectSome
+    scat <- function(fmt, vals=character(), exdent=2, ...)
+    {
+        vals <- ifelse(nzchar(vals), vals, "''")
+        lbls <- paste(S4Vectors:::selectSome(vals), collapse=" ")
+        txt <- sprintf(fmt, length(vals), lbls)
+        cat(strwrap(txt, exdent=exdent, ...), sep="\n")
+    }
+
+    cat("class:", class(object), "\n")
+    cat("dim:", dim(object), "\n")
+
+    ## metadata()
+    expt <- names(metadata(object))
+    if (is.null(expt))
+        expt <- character(length(metadata(object)))
+    scat("metadata(%d): %s\n", expt)
+
+    ## assays()
+    nms <- assayNames(object)
+    if (is.null(nms))
+        nms <- character(length(assays(object, withDimnames=FALSE)))
+    scat("assays(%d): %s\n", nms)
+
+    ## rownames()
+    dimnames <- dimnames(object)
+    dlen <- sapply(dimnames, length)
+    if (dlen[[1]]) scat("rownames(%d): %s\n", dimnames[[1]])
+    else scat("rownames: NULL\n")
+
+    ## rowData()
+    scat("rowData names(%d): %s\n", names(rowData(object)))
+
+    ## colnames()
+    if (dlen[[2]]) scat("colnames(%d): %s\n", dimnames[[2]])
+    else cat("colnames: NULL\n")
+
+    ## colData()
+    scat("colData names(%d): %s\n", names(colData(object)))
+})
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### Combine.
+###
+
+### Appropriate for objects with different ranges and same samples.
+setMethod("rbind", "SummarizedExperiment",
+    function(..., deparse.level=1)
+{
+    args <- unname(list(...))
+    .rbind.SummarizedExperiment(args)
+})
+
+.rbind.SummarizedExperiment <- function(args)
+{
+    if (!.compare(lapply(args, colnames)))
+            stop("'...' objects must have the same colnames")
+    if (!.compare(lapply(args, ncol)))
+            stop("'...' objects must have the same number of samples")
+
+    if (is(args[[1L]], "RangedSummarizedExperiment")) {
+        rowRanges <- do.call(c, lapply(args, rowRanges))
+    } else {
+        ## Code below taken from combine_GAlignments_objects() from the
+        ## GenomicAlignments package.
+
+        ## Combine "NAMES" slots.
+        NAMES_slots <- lapply(args, function(x) x at NAMES)
+        ## TODO: Use elementIsNull() here when it becomes available.
+        has_no_names <- sapply(NAMES_slots, is.null, USE.NAMES=FALSE)
+        if (all(has_no_names)) {
+            NAMES <- NULL
+        } else {
+            noname_idx <- which(has_no_names)
+            if (length(noname_idx) != 0L)
+                NAMES_slots[noname_idx] <-
+                    lapply(elementNROWS(args[noname_idx]), character)
+            NAMES <- unlist(NAMES_slots, use.names=FALSE)
+        }
+    }
+    colData <- .cbind.DataFrame(args, colData, "colData")
+    assays <- do.call(rbind, lapply(args, slot, "assays"))
+    elementMetadata <- do.call(rbind, lapply(args, slot, "elementMetadata"))
+    metadata <- do.call(c, lapply(args, metadata))
+
+    if (is(args[[1L]], "RangedSummarizedExperiment")) {
+        BiocGenerics:::replaceSlots(args[[1L]],
+            rowRanges=rowRanges, colData=colData, assays=assays,
+            elementMetadata=elementMetadata, metadata=metadata)
+    } else {
+        BiocGenerics:::replaceSlots(args[[1L]],
+            NAMES=NAMES, colData=colData, assays=assays,
+            elementMetadata=elementMetadata, metadata=metadata)
+    }
+}
+
+### Appropriate for objects with same ranges and different samples.
+setMethod("cbind", "SummarizedExperiment",
+    function(..., deparse.level=1)
+{
+    args <- unname(list(...))
+    .cbind.SummarizedExperiment(args)
+})
+
+.cbind.SummarizedExperiment <- function(args)
+{
+    if (is(args[[1L]], "RangedSummarizedExperiment")) {
+        if (!.compare(lapply(args, rowRanges), TRUE))
+            stop("'...' object ranges (rows) are not compatible")
+        rowRanges <- rowRanges(args[[1L]])
+        mcols(rowRanges) <- .cbind.DataFrame(args, mcols, "mcols")
+    } else {
+        elementMetadata <- .cbind.DataFrame(args, mcols, "mcols")
+    }
+    colData <- do.call(rbind, lapply(args, colData))
+    assays <- do.call(cbind, lapply(args, slot, "assays"))
+    metadata <- do.call(c, lapply(args, metadata))
+
+    if (is(args[[1L]], "RangedSummarizedExperiment")) {
+        BiocGenerics:::replaceSlots(args[[1L]],
+            rowRanges=rowRanges,
+            colData=colData, assays=assays, metadata=metadata)
+    } else {
+        BiocGenerics:::replaceSlots(args[[1L]],
+            elementMetadata=elementMetadata,
+            colData=colData, assays=assays, metadata=metadata)
+    }
+}
+
+.compare <- function(x, GenomicRanges=FALSE)
+{
+    x1 <- x[[1]]
+    if (GenomicRanges) {
+        if (is(x1, "GRangesList")) {
+            x <- lapply(x, unlist)
+            x1 <- x[[1]]
+        }
+        for (i in seq_along(x)[-1]) {
+            if (!identicalVals(x1, x[[i]]))
+                return(FALSE)
+        }
+        return(TRUE)
+    } else {
+        all(sapply(x[-1],
+            function(xelt) all(identical(xelt, x[[1]]))))
+    }
+}
+
+.cbind.DataFrame <- function(args, accessor, accessorName)
+{
+    lst <- lapply(args, accessor)
+    if (!.compare(lst)) {
+        nms <- lapply(lst, names)
+        nmsv <- unlist(nms, use.names=FALSE)
+        names(nmsv) <- rep(seq_along(nms), elementNROWS(nms))
+        dups <- duplicated(nmsv)
+        ## no duplicates
+        if (!any(dups))
+            return(do.call(cbind, lst))
+        ## confirm duplicates are the same
+        lapply(nmsv[duplicated(nmsv)], function(d) {
+            if (!.compare(lapply(lst, "[", d)))
+                stop("column(s) '", unname(d),
+                     "' in ", sQuote(accessorName),
+                     " are duplicated and the data do not match")})
+        ## remove duplicates
+        do.call(cbind, lst)[,!dups]
+    } else {
+        lst[[1]]
+    }
+}
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### identicalVals()
+###
+### Internal generic and methods (i.e. not exported).
+### Provides a fast implementation of 'length(x) == length(y) && all(x == y)'
+### for various kinds of vector-like objects.
+### TODO: Move this to S4Vectors (for the generic and methods for factor and
+### Rle objects) and IRanges (for the method for Ranges objects).
+###
+
+setGeneric("identicalVals", function(x, y) standardGeneric("identicalVals"))
+
+### Semantically equivalent to identical(as.character(x), as.character(y))
+### but avoids turning the 2 factor objects into character vectors so is more
+### efficient.
+setMethod("identicalVals", c("factor", "factor"),
+    function(x, y)
+    {
+        m <- match(levels(y), levels(x), nomatch=0L)
+        identical(as.integer(x), m[y])
+    }
+)
+
+### Only support factor-Rle objects at the moment!
+### Semantically equivalent to identical(as.character(x), as.character(y))
+### but avoids turning the 2 factor-Rle objects into character vectors so is
+### more efficient.
+setMethod("identicalVals", c("Rle", "Rle"),
+    function(x, y) identical(runLength(x), runLength(y)) &&
+                   identicalVals(runValue(x), runValue(y))
+)
+
+setMethod("identicalVals", c("Ranges", "Ranges"),
+    function(x, y) identical(start(x), start(y)) &&
+                   identical(width(x), width(y))
+)
+
+### Like 'x == y' this method ignores circularity of the underlying sequences
+### e.g. ranges [1, 10] and [101, 110] represent the same position on a
+### circular sequence of length 100 so should be considered equal. However
+### for 'x == y' and the method below, they are not.
+### TODO: Take circularity of the underlying sequences into account.
+setMethod("identicalVals", c("GenomicRanges", "GenomicRanges"),
+    function(x, y)
+    {
+        ## Trying to merge 'seqinfo(x)' and 'seqinfo(y)' will raise an error
+        ## if 'x' and 'y' are not based on the same reference genome. This is
+        ## the standard way to check that 'x' and 'y' are based on the same
+        ## reference genome.
+        merge(seqinfo(x), seqinfo(y))  # we ignore the returned value
+
+        identicalVals(seqnames(x), seqnames(y)) &&
+            identicalVals(ranges(x), ranges(y)) &&
+            identicalVals(strand(x), strand(y))
+    }
+)
+
+
+### - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
+### On-disk realization.
+###
+
+setMethod("realize", "SummarizedExperiment",
+    function(x)
+    {
+        for (i in seq_along(assays(x))) {
+            ## We drop the dimnames of the individual assays for 2 reasons:
+            ##   1) These dimnames are kind of irrelevant. The dimnames that
+            ##      really matter are 'dimnames(x)' and they are stored
+            ##      somewhere else in 'x'. So we don't loose them by not
+            ##      realizing the assay dimnames on disk. As a little extra
+            ##      bonus, this actually saves a little bit of time and disk
+            ##      space.
+            ##   2) Using the HDF5Array backend to realize an array-like object
+            ##      on disk doesn't store the dimnames in the HDF5 file at the
+            ##      moment.
+            a <- assay(x, i, withDimnames=FALSE)
+            dimnames(a) <- NULL
+            assay(x, i) <- realize(a)
+        }
+        x
+    }
+)
+
diff --git a/R/coverage-methods.R b/R/coverage-methods.R
new file mode 100644
index 0000000..2bc5f22
--- /dev/null
+++ b/R/coverage-methods.R
@@ -0,0 +1,15 @@
+### =========================================================================
+### "coverage" method
+### -------------------------------------------------------------------------
+###
+
+
+setMethod("coverage", "RangedSummarizedExperiment",
+    function(x, shift=0L, width=NULL, weight=1L,
+                method=c("auto", "sort", "hash"))
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
diff --git a/R/findOverlaps-methods.R b/R/findOverlaps-methods.R
new file mode 100644
index 0000000..d39afee
--- /dev/null
+++ b/R/findOverlaps-methods.R
@@ -0,0 +1,42 @@
+### =========================================================================
+### findOverlaps methods
+### -------------------------------------------------------------------------
+
+
+### findOverlaps
+
+setMethod("findOverlaps", c("RangedSummarizedExperiment", "Vector"),
+    function(query, subject, maxgap=0L, minoverlap=1L,
+             type=c("any", "start", "end", "within", "equal"),
+             select=c("all", "first", "last", "arbitrary"),
+             ignore.strand=FALSE)
+    {
+        query <- rowRanges(query)
+        callGeneric()
+    }
+)
+
+setMethod("findOverlaps", c("Vector", "RangedSummarizedExperiment"),
+    function(query, subject, maxgap=0L, minoverlap=1L,
+             type=c("any", "start", "end", "within", "equal"),
+             select=c("all", "first", "last", "arbitrary"),
+             ignore.strand=FALSE)
+    {
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
+setMethod("findOverlaps", c("RangedSummarizedExperiment",
+                            "RangedSummarizedExperiment"),
+    function(query, subject, maxgap=0L, minoverlap=1L,
+             type=c("any", "start", "end", "within", "equal"),
+             select=c("all", "first", "last", "arbitrary"),
+             ignore.strand=FALSE)
+    {
+        query <- rowRanges(query)
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
diff --git a/R/inter-range-methods.R b/R/inter-range-methods.R
new file mode 100644
index 0000000..0a36037
--- /dev/null
+++ b/R/inter-range-methods.R
@@ -0,0 +1,22 @@
+### =========================================================================
+### Inter-range methods
+### -------------------------------------------------------------------------
+###
+
+
+setMethod("isDisjoint", "RangedSummarizedExperiment",
+    function(x, ignore.strand=FALSE)
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
+setMethod("disjointBins", "RangedSummarizedExperiment",
+    function(x, ignore.strand = FALSE)
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
diff --git a/R/intra-range-methods.R b/R/intra-range-methods.R
new file mode 100644
index 0000000..e9873c9
--- /dev/null
+++ b/R/intra-range-methods.R
@@ -0,0 +1,79 @@
+### =========================================================================
+### Intra-range methods
+### -------------------------------------------------------------------------
+###
+
+
+setMethod("shift", "RangedSummarizedExperiment",
+    function(x, shift=0L, use.names=TRUE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+setMethod("narrow", "RangedSummarizedExperiment",
+    function(x, start=NA, end=NA, width=NA, use.names=TRUE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+setMethod("resize", "RangedSummarizedExperiment",
+    function(x, width, fix="start", use.names=TRUE, ignore.strand=FALSE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+setMethod("flank", "RangedSummarizedExperiment", 
+    function(x, width, start=TRUE, both=FALSE, use.names=TRUE,
+             ignore.strand=FALSE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+setMethod("promoters", "RangedSummarizedExperiment",
+    function(x, upstream=2000, downstream=200)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+### Because 'keep.all.ranges' is FALSE by default, it will break if some
+### ranges are dropped.
+setMethod("restrict", "RangedSummarizedExperiment",
+    function(x, start=NA, end=NA, keep.all.ranges=FALSE, use.names=TRUE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
+setMethod("trim", "RangedSummarizedExperiment",
+    function(x, use.names=TRUE)
+    {
+        x0 <- x
+        x <- rowRanges(x)
+        rowRanges(x0) <- callGeneric()
+        x0
+    }
+)
+
diff --git a/R/makeSummarizedExperimentFromDataFrame.R b/R/makeSummarizedExperimentFromDataFrame.R
new file mode 100644
index 0000000..57e07a2
--- /dev/null
+++ b/R/makeSummarizedExperimentFromDataFrame.R
@@ -0,0 +1,32 @@
+### =========================================================================
+### makeSummarizedExperimentFromDataFrame()
+### -------------------------------------------------------------------------
+
+### 'df' must be a data.frame or DataFrame object.
+makeSummarizedExperimentFromDataFrame <-
+    function(df,
+             ...,
+             seqinfo = NULL,
+             starts.in.df.are.0based = FALSE)
+    {
+        rowRanges <- makeGRangesFromDataFrame(
+            df,
+            ...,
+            keep.extra.columns = FALSE,
+            seqinfo = seqinfo,
+            starts.in.df.are.0based = starts.in.df.are.0based)
+
+        # Find column names for rowRanges
+        granges_cols <-
+            GenomicRanges:::.find_GRanges_cols(names(df), ...)
+
+        rangedNames <- names(df)[na.omit(granges_cols)]
+        idx <- match(rangedNames, names(df))
+        counts <- as.matrix(df[, -idx, drop = FALSE])
+
+        if (!is(as.vector(counts), "numeric"))
+            stop("failed to coerce non-range columns to 'numeric'")
+
+        SummarizedExperiment(
+            assays=SimpleList(counts), rowRanges=rowRanges)
+    }
diff --git a/R/makeSummarizedExperimentFromExpressionSet.R b/R/makeSummarizedExperimentFromExpressionSet.R
new file mode 100644
index 0000000..66d123f
--- /dev/null
+++ b/R/makeSummarizedExperimentFromExpressionSet.R
@@ -0,0 +1,265 @@
+##
+## makeSummarizedExperimentFromExpressionSet
+
+## coercion
+
+.from_rowRanges_to_FeatureData <- function(from)
+{
+    if (is(from, "GRanges")) {
+        fd <- .from_GRanges_to_FeatureData(from)
+    } else if (is(from, "GRangesList")) {
+        fd <- .from_GRangesList_to_FeatureData(from)
+    } else {
+        stop("class ", sQuote(class(from)),
+             " is not a supported type for rowRanges coercion")
+    }
+    featureNames(fd) <- names(from)
+    fd
+}
+
+.from_GRanges_to_FeatureData <- function(from)
+{
+    data <- as.data.frame(from)
+
+    ## the first mcols are automatically included in the data.frame from
+    ## as.data.frame, the secondary mcols holds the metadata for the first
+    ## metadata columns.
+    metaData <- mcols(mcols(from))
+    if (is.null(metaData)) {
+        metaData <- as.data.frame(matrix(ncol=0, nrow=NCOL(data)))
+    } else {
+        metaData <- as.data.frame(metaData)
+    }
+    AnnotatedDataFrame(data, metaData)
+}
+.from_GRangesList_to_FeatureData <- function(from)
+{
+    data <- as.data.frame(mcols(from))
+
+    ## the first mcols are automatically included in the data.frame from
+    ## as.data.frame, the secondary mcols holds the metadata for the first
+    ## metadata columns.
+    metaData <- mcols(mcols(from))
+    if (is.null(metaData)) {
+        metaData <- as.data.frame(matrix(ncol=0, nrow=NCOL(data)))
+    } else {
+        metaData <- as.data.frame(metaData)
+    }
+    AnnotatedDataFrame(data, metaData)
+}
+
+.from_AnnotatedDataFrame_to_DataFrame <- function(from)
+{
+    df <- DataFrame(pData(from), row.names=rownames(from))
+    mcols(df) <- DataFrame(varMetadata(from))
+    df
+}
+
+.from_DataFrame_to_AnnotatedDataFrame <- function(df)
+{
+    data <- as(df, "data.frame")
+    metaData <- mcols(df)
+    if (is.null(metaData)) {
+        metaData <- as.data.frame(matrix(ncol=0, nrow=NCOL(data)))
+    } else {
+        metaData <- as(metaData, "data.frame")
+    }
+    AnnotatedDataFrame(data, metaData)
+}
+
+## If the ExpressionSet has featureData with range information make
+## GRanges out of that, otherwise make an empty GRangesList with names
+## from the featureNames
+naiveRangeMapper <- function(from)
+{
+    nms <- featureNames(from)
+    res <- tryCatch({
+        makeGRangesFromDataFrame(pData(featureData(from)),
+                                 keep.extra.columns = TRUE)
+    }, error = function(e) {
+        res <- relist(GRanges(), vector("list", length=length(nms)))
+        mcols(res) <- .from_AnnotatedDataFrame_to_DataFrame(featureData(from))
+        res
+    })
+    names(res) <- nms
+    res
+}
+
+# Simple ProbeId to Range mapper
+# Probes with multiple ranges are dropped
+# The sign of the chromosome location is assumed to contain the strand
+# information
+probeRangeMapper <- function(from)
+{
+    annotation <- annotation(from)
+    if (identical(annotation, character(0))) {
+        return(naiveRangeMapper(from))
+    }
+    if (requireNamespace("annotate", quietly = TRUE)) {
+        annotationPackage <- annotate::annPkgName(annotation)
+        test <- require(annotationPackage, character.only = TRUE,
+                        quietly = TRUE)
+        if (test) {
+            db <- get(annotationPackage, envir = asNamespace(annotationPackage))
+            pid <- featureNames(from)
+            locs <- AnnotationDbi::select(
+                db, pid, columns = c("CHR", "CHRLOC", "CHRLOCEND"))
+            locs <- na.omit(locs)
+            dups <- duplicated(locs$PROBEID)
+            if (any(dups)) {
+                locs <- locs[!dups, , drop = FALSE]
+            }
+            strand <- ifelse(locs$CHRLOC > 0, "+", "-")
+            res <- GRanges(seqnames = locs$CHR,
+                           ranges = IRanges(abs(locs$CHRLOC),
+                                            abs(locs$CHRLOCEND)),
+                           strand = strand)
+            names(res) <- locs$PROBEID
+
+            if (NROW(res) < length(pid)) {
+                warning(length(pid) - NROW(res),
+                        " probes could not be mapped.", call. = FALSE)
+            }
+            res
+        } else {
+            stop("Failed to load ", sQuote(annotationPackage), " package",
+                 call. = FALSE)
+        }
+    } else {
+        stop("Failed to load annotate package", call. = FALSE)
+    }
+}
+
+# Simple ProbeId to Gene mapper
+# Is there a way to get the txDb given the annotation package?
+geneRangeMapper <- function(txDbPackage, key = "ENTREZID")
+{
+    function(from) {
+        annotation <- annotation(from)
+        if (identical(annotation, character(0))) {
+            return(naiveRangeMapper(from))
+        }
+        if (requireNamespace("annotate", quietly = TRUE)) {
+            annotationPackage <- annotate::annPkgName(annotation)
+            test <- require(annotationPackage, character.only = TRUE,
+                            quietly = TRUE)
+            if (test) {
+                db <- get(annotationPackage,
+                          envir = asNamespace(annotationPackage))
+                pid <- featureNames(from)
+                probeIdToGeneId <-
+                    AnnotationDbi::mapIds(db, pid, key, "PROBEID")
+                geneIdToProbeId <-
+                    setNames(names(probeIdToGeneId), probeIdToGeneId)
+
+                if (requireNamespace(txDbPackage, quietly = TRUE)) {
+                    txDb <- get(txDbPackage, envir = asNamespace(txDbPackage))
+                    genes <- GenomicFeatures::genes(txDb)
+                    probesWithAMatch <-
+                        probeIdToGeneId[probeIdToGeneId %in% names(genes)]
+                    res <- genes[probesWithAMatch]
+                    names(res) <- geneIdToProbeId[names(res)]
+                    if (NROW(res) < length(pid)) {
+                        warning(length(pid) - NROW(res),
+                                " probes could not be mapped.", call. = FALSE)
+                    }
+                    res
+                } else {
+                    stop("Failed to load ", sQuote(txDbPackage), " package",
+                         call. = FALSE)
+                }
+
+            } else {
+                stop("Failed to load ", sQuote(annotationPackage), " package",
+                     call. = FALSE)
+            }
+        } else {
+            stop("Failed to load annotate package", call. = FALSE)
+        }
+    }
+}
+
+makeSummarizedExperimentFromExpressionSet <-
+    function(from, mapFun = naiveRangeMapper, ...)
+{
+    mapFun <- match.fun(mapFun)
+    rowRanges <- mapFun(from, ...)
+    matches <- match(names(rowRanges),
+                     featureNames(from),
+                     nomatch = 0)
+    from <- from[matches, drop = FALSE]
+    assays <- as.list(assayData(from))
+    colData <- .from_AnnotatedDataFrame_to_DataFrame(phenoData(from))
+    metadata <- SimpleList(
+        experimentData = experimentData(from),
+        annotation = annotation(from),
+        protocolData = protocolData(from)
+    )
+
+    SummarizedExperiment(
+        assays = assays,
+        rowRanges = rowRanges,
+        colData = colData,
+        metadata = metadata
+    )
+}
+
+setAs("ExpressionSet", "RangedSummarizedExperiment", function(from)
+{
+    makeSummarizedExperimentFromExpressionSet(from)
+})
+
+setAs("RangedSummarizedExperiment", "ExpressionSet",
+      function(from)
+{
+    assayData <- list2env(as.list(assays(from)))
+
+    numAssays <- length(assayData)
+
+    if (numAssays == 0) {
+        assayData$exprs <- new("matrix")
+    } else if (!"exprs" %in% ls(assayData)) {
+        ## if there isn't an exprs assay we need to pick one as exprs,
+        ## so rename the first element exprs and issue a warning.
+        exprs <- ls(assayData)[[1]]
+        warning("No assay named ", sQuote("exprs"), " found, renaming ",
+                exprs, " to ", sQuote("exprs"), ".")
+        assayData[["exprs"]] <- assayData[[exprs]]
+        rm(list=exprs, envir=assayData)
+    }
+
+    featureData <- .from_rowRanges_to_FeatureData(rowRanges(from))
+    phenoData <- .from_DataFrame_to_AnnotatedDataFrame(colData(from))
+
+    metadata <- metadata(from)
+
+    experimentData <- if (!is.null(metadata$experimentData)) {
+        metadata$experimentData
+    } else {
+        MIAME()
+    }
+
+    annotation <- if (!is.null(metadata$annotation)) {
+        metadata$annotation
+    } else {
+        character()
+    }
+
+    protocolData <- if (!is.null(metadata$protocolData)) {
+        metadata$protocolData
+    } else {
+        annotatedDataFrameFrom(assayData, byrow=FALSE)
+    }
+
+    ExpressionSet(assayData,
+                  phenoData = phenoData,
+                  featureData = featureData,
+                  experimentData = experimentData,
+                  annotation = annotation,
+                  protocolData = protocolData
+                  )
+})
+
+setAs("SummarizedExperiment", "ExpressionSet", function(from)
+    as(as(from, "RangedSummarizedExperiment"), "ExpressionSet")
+)
diff --git a/R/nearest-methods.R b/R/nearest-methods.R
new file mode 100644
index 0000000..7f20507
--- /dev/null
+++ b/R/nearest-methods.R
@@ -0,0 +1,117 @@
+### =========================================================================
+### nearest (and related) methods
+### -------------------------------------------------------------------------
+###
+
+
+### precede & follow
+
+for (f in c("precede", "follow")) {
+    setMethod(f, c("RangedSummarizedExperiment", "ANY"),
+        function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+        {
+            x <- rowRanges(x)
+            callGeneric()
+        }
+    )
+    setMethod(f, c("ANY", "RangedSummarizedExperiment"),
+        function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+        {
+            subject <- rowRanges(subject)
+            callGeneric()
+        }
+    )
+    setMethod(f, c("RangedSummarizedExperiment", "RangedSummarizedExperiment"),
+        function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+        {
+            x <- rowRanges(x)
+            subject <- rowRanges(subject)
+            callGeneric()
+        }
+    )
+}
+
+### nearest
+
+setMethod("nearest", c("RangedSummarizedExperiment", "ANY"),
+    function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
+setMethod("nearest", c("ANY", "RangedSummarizedExperiment"),
+    function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+    {
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
+setMethod("nearest", c("RangedSummarizedExperiment",
+                       "RangedSummarizedExperiment"),
+    function(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+    {
+        x <- rowRanges(x)
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
+### distance
+
+setMethod("distance", c("RangedSummarizedExperiment", "ANY"),
+    function(x, y, ignore.strand=FALSE, ...)
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
+setMethod("distance", c("ANY", "RangedSummarizedExperiment"),
+    function(x, y, ignore.strand=FALSE, ...)
+    {
+        y <- rowRanges(y)
+        callGeneric()
+    }
+)
+
+setMethod("distance", c("RangedSummarizedExperiment",
+                        "RangedSummarizedExperiment"),
+    function(x, y, ignore.strand=FALSE, ...)
+    {
+        x <- rowRanges(x)
+        y <- rowRanges(y)
+        callGeneric()
+    }
+)
+
+### distanceToNearest
+
+setMethod("distanceToNearest", c("RangedSummarizedExperiment", "ANY"),
+    function(x, subject, ignore.strand=FALSE, ...)
+    {
+        x <- rowRanges(x)
+        callGeneric()
+    }
+)
+
+setMethod("distanceToNearest", c("ANY", "RangedSummarizedExperiment"),
+    function(x, subject, ignore.strand=FALSE, ...)
+    {
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
+setMethod("distanceToNearest", c("RangedSummarizedExperiment",
+                                 "RangedSummarizedExperiment"),
+    function(x, subject, ignore.strand=FALSE, ...)
+    {
+        x <- rowRanges(x)
+        subject <- rowRanges(subject)
+        callGeneric()
+    }
+)
+
diff --git a/R/readKallisto.R b/R/readKallisto.R
new file mode 100644
index 0000000..9a160f2
--- /dev/null
+++ b/R/readKallisto.R
@@ -0,0 +1,196 @@
+.require <-
+    function(pkg)
+{
+    withCallingHandlers({
+        requireNamespace(pkg)
+    }, warning=function(w) {
+        invokeRestart("muffleWarning")
+    }) || {
+        msg <- sprintf('install %s with
+            source("http://bioconductor.org/biocLite.R"); biocLite("%s")',
+            pkg, pkg)
+        stop(paste(strwrap(msg, exdent=2), collapse="\n"))
+    }
+}
+
+.open <- function(files, h5) {
+    lapply(files, function(file) {
+        if (h5 && rhdf5::H5Fis_hdf5(file))
+            rhdf5::H5Fopen(file)
+        else file(file, open="rt")
+    })
+}
+    
+.close <- function(cons)
+    UseMethod(".close")
+
+.close.list <- function(cons)
+    for (con in cons)
+        .close(con)
+
+.close.connection <- function(cons)
+    close(cons)
+
+.close.H5IdComponent <- function(cons)
+    rhdf5::H5Fclose(cons)
+
+.colData <- function(jsonfile) {
+    json <- jsonlite::fromJSON(jsonfile)
+    do.call("data.frame", c(json, stringsAsFactors=FALSE))
+}
+
+.KALLISTO_COLCLASSES <-
+    c("character", "integer" , "numeric", "numeric", "numeric")
+
+.KALLISTO_ROWDATA <- "length"
+
+KALLISTO_ASSAYS <- c("est_counts", "tpm", "eff_length")
+
+.read <- function(con)
+    UseMethod(".read")
+
+.read.connection <- function(con)
+    read.delim(con, header=TRUE, colClasses=.KALLISTO_COLCLASSES, row.names=1)
+    
+.read.H5IdComponent <- function(con) {
+    eff_length <- rhdf5::h5read(con, "/aux/eff_lengths")
+    est_counts <- rhdf5::h5read(con, "/est_counts")
+    tpm0 <- est_counts / eff_length
+    data.frame(row.names=rhdf5::h5read(con, "/aux/ids"),
+               length=rhdf5::h5read(con, "/aux/lengths"),
+               eff_length=eff_length,
+               est_counts=est_counts,
+               tpm=tpm0 / (sum(tpm0) / 1e6))
+}
+
+readKallisto <-
+    function(files,
+             json=file.path(dirname(files), "run_info.json"),
+             h5=any(grepl("\\.h5$", files)),
+             what=KALLISTO_ASSAYS,
+             as=c("SummarizedExperiment", "list", "matrix"))
+{
+    as <- match.arg(as)
+    if (missing(what))
+        what <- what[1]
+    else {
+        whats <- eval(formals()[["what"]])
+        if (!all(what %in% KALLISTO_ASSAYS))
+            stop("'what' must be in ",
+                 paste(sQuote(KALLISTO_ASSAYS), collapse=", "),
+                 call.=FALSE)
+    }
+
+    stopifnot(is.character(files))
+    test <- file.exists(files)
+    if (!all(test))
+        stop("file(s) do not exist:\n  ",
+             paste(files[!test], collapse="\n  "))
+    if (is.null(names(files)))
+        names(files) <- basename(dirname(files))
+    if (anyDuplicated(names(files)))
+        stop("'names()' of 'files' must be unique")
+
+    if (as != "matrix") {
+        .require("jsonlite")
+        stopifnot(length(files) == length(json))
+        if (!is.null(names(json)))
+            stopifnot(identical(names(json), names(files)))
+        else
+            names(json) <- names(files)
+        test <- file.exists(json)
+        if (!all(test))
+            stop("json file(s) do not exist:\n  ",
+                 paste(json[!test], collapse="\n  "))
+    }
+
+    if (h5)
+        .require("rhdf5")
+
+    cons <- .open(files, h5)
+    value <- .read(cons[[1]])
+    rowData <- value[, .KALLISTO_ROWDATA, drop=FALSE]
+    assay <- matrix(0, nrow(rowData), length(cons),
+                    dimnames=list(rownames(rowData), names(cons)))
+    assays <- setNames(replicate(length(what), assay, FALSE), what)
+    for (w in what)
+        assays[[w]][,1] <- value[[w]]
+    for (i in seq_along(cons)[-1]) {
+        value <- .read(cons[[i]])
+        if (!identical(rowData, value[, .KALLISTO_ROWDATA, drop=FALSE]))
+            stop("rowData differs between files:\n  ",
+                 paste(files[c(1, i)], collapse="\n  "))
+        for (w in what)
+            assays[[w]][,i] <- value[[w]]
+    }
+    .close(cons)
+
+    if (as != "matrix")
+        colData <- do.call("rbind", lapply(json, .colData))
+
+    switch(as, matrix={
+        if (length(assays) == 1L)
+            assays[[1]]
+        else assays
+    }, list={
+        c(setNames(list(colData, rowData), c("colData", "rowData")), assays)
+    }, SummarizedExperiment={
+        SummarizedExperiment(assays=assays,
+                             rowData=as(rowData, "DataFrame"),
+                             colData=as(colData, "DataFrame"))
+    })
+}
+
+.readIds <- function(con, i) {
+    if (!missing(i))
+        rhdf5::h5read(con, "/aux/ids", list(i))
+    else rhdf5::h5read(con, "/aux/ids")
+}
+    
+readKallistoBootstrap <-
+    function(file, i, j)
+{
+    .require("rhdf5")
+    stopifnot(length(file) == 1L, is.character(file))
+    stopifnot(file.exists(file))
+    stopifnot(rhdf5::H5Fis_hdf5(file))
+    con <- rhdf5::H5Fopen(file)
+    on.exit(rhdf5::H5Fclose(con))
+    nboot <- as.integer(rhdf5::h5read(con, "/aux/num_bootstrap"))
+    if (nboot == 0L)
+        stop("file contains no bootstraps:\n  ", file)
+
+    if (!missing(i) && is.character(i)) {
+        idx <- match(i, .readIds(con))
+        if (anyNA(i))
+            stop("unknown target id(s)", i[is.na(idx)])
+        i <- idx
+    }
+    if (!missing(j) && is.numeric(j)) {
+        if (any((j < 1L) || any(j > nboot)))
+            stop("'j' must be >0 and <=", nboot)
+        j <- paste0("bs", as.integer(j) - 1L)
+    }
+
+    m <- if (missing(i) && missing(j)) {
+        simplify2array(rhdf5::h5read(con, "/bootstrap"))
+    } else if (missing(i)) {
+        query <- setNames(sprintf("/bootstrap/%s", j), j)
+        simplify2array(lapply(query, rhdf5::h5read, file=con))
+    } else if (missing(j)) {
+        group <- rhdf5::H5Gopen(con, "/bootstrap")
+        name <- rhdf5::h5ls(group)$name
+        rhdf5::H5Gclose(group)
+        query <- setNames(sprintf("/bootstrap/%s", name), name)
+        simplify2array(lapply(query, rhdf5::h5read, file=con, index=list(i)))
+    } else {
+        query <- setNames(sprintf("/bootstrap/%s", j), j)
+        simplify2array(lapply(query, rhdf5::h5read, file=con, index=list(i)))
+    }
+
+    rownames(m) <- .readIds(con, i)
+    if (missing(j)) {
+        o <- order(as.integer(sub("bs", "", colnames(m), fixed=TRUE)))
+        m[,o]
+    } else m
+}
diff --git a/R/saveHDF5SummarizedExperiment.R b/R/saveHDF5SummarizedExperiment.R
new file mode 100644
index 0000000..52a1ba4
--- /dev/null
+++ b/R/saveHDF5SummarizedExperiment.R
@@ -0,0 +1,127 @@
+### =========================================================================
+### Save/load a HDF5-based SummarizedExperiment object
+### -------------------------------------------------------------------------
+
+
+.create_dir <- function(dir, replace)
+{
+    if (dir.exists(dir)) {
+        if (!replace)
+            stop(wmsg("Directory \"", dir, "\" already exists. ",
+                      "Use 'replace=TRUE' to replace it. ",
+                      "Its content will be lost!"))
+        if (unlink(dir, recursive=TRUE) != 0L)
+            stop("failed to delete directory \"", dir, "\"")
+    } else if (file.exists(dir)) {
+        stop(wmsg("\"", dir, "\" already exists and is a file, ",
+                  "not a directory"))
+    }
+    if (!suppressWarnings(dir.create(dir)))
+        stop("cannot create directory \"", dir, "\"")
+}
+
+.write_h5_assays <- function(assays, h5_path, chunk_dim, level, verbose)
+{
+    nassay <- length(assays)
+    for (i in seq_len(nassay)) {
+        a <- assays[[i]]
+        h5_name <- sprintf("assay%03d", i)
+        if (verbose)
+            message("Start writing assay ", i, "/", nassay, " to '",
+                    h5_path, "':")
+        a <- HDF5Array::writeHDF5Array(a, h5_path, h5_name, chunk_dim, level,
+                                       verbose=verbose)
+        if (verbose)
+            message("Finished writing assay ", i, "/", nassay, " to '",
+                    h5_path, "'.")
+        assays[[i]] <- a
+    }
+    assays
+}
+
+.shorten_h5_paths <- function(assays)
+{
+    nassay <- length(assays)
+    for (i in seq_len(nassay)) {
+        a <- assays[[i]]
+        a at seed@file <- basename(a at seed@file)
+        assays[[i]] <- a
+    }
+    assays
+}
+
+### Save all the assays in HDF5 format, including in-memory assays.
+### Delayed assays with delayed operations on them are realized while they
+### are written to disk..
+saveHDF5SummarizedExperiment <- function(x, dir="my_h5_se", replace=FALSE,
+                                         chunk_dim=NULL, level=NULL,
+                                         verbose=FALSE)
+{
+    if (!is(x, "SummarizedExperiment"))
+        stop("'x' must be a SummarizedExperiment object")
+    if (!isSingleString(dir))
+        stop(wmsg("'dir' must be a single string specifying the path ",
+                  "to the directory where to save the ", class(x),
+                  " object (the directory will be created)"))
+    if (!isTRUEorFALSE(replace))
+        stop("'replace' must be TRUE or FALSE")
+    if (!isTRUEorFALSE(verbose))
+        stop("'verbose' must be TRUE or FALSE")
+
+    ## We try library(HDF5Array) before deleting or creating directory 'dir'.
+    ## That way if HDF5Array is not installed then we will stop without having
+    ## made changes to the file system.
+    library(HDF5Array)  # for writeHDF5Array()
+    .create_dir(dir, replace)
+
+    h5_path <- file.path(dir, "assays.h5")
+    x at assays <- .write_h5_assays(x at assays, h5_path, chunk_dim, level, verbose)
+
+    rds_path <- file.path(dir, "se.rds")
+    ans <- x
+    x at assays <- .shorten_h5_paths(x at assays)
+    saveRDS(x, file=rds_path)
+
+    invisible(ans)
+}
+
+.THE_EXPECTED_STUFF <- c(
+    "a HDF5-based SummarizedExperiment object previously ",
+    "saved with saveHDF5SummarizedExperiment()"
+)
+
+.stop_if_bad_dir <- function(dir)
+    stop(wmsg("directory \"", dir, "\" does not seem to contain ",
+              .THE_EXPECTED_STUFF))
+
+### Does a lot of checking and tries to fail graciously if the content
+### of 'dir' doesn't look as expected.
+loadHDF5SummarizedExperiment <- function(dir="my_h5_se")
+{
+    library(rhdf5)  # for h5ls()
+    library(HDF5Array)  # for the HDF5Array class
+    if (!isSingleString(dir))
+        stop(wmsg("'dir' must be a single string specifying the path ",
+                  "to the directory containing ", .THE_EXPECTED_STUFF))
+    h5_path <- file.path(dir, "assays.h5")
+    rds_path <- file.path(dir, "se.rds")
+    if (!file.exists(h5_path) || !file.exists(rds_path))
+        .stop_if_bad_dir(dir)
+    h5_content <- try(rhdf5::h5ls(h5_path), silent=TRUE)
+    if (inherits(h5_content, "try-error"))
+        .stop_if_bad_dir(dir)
+    h5_datasets <- h5_content[ , "name"]
+    ans <- readRDS(rds_path)
+    if (!is(ans, "SummarizedExperiment"))
+        .stop_if_bad_dir(dir)
+    for (i in seq_along(assays(ans))) {
+        a <- assay(ans, i, withDimnames=FALSE)
+        if (!is(a, "HDF5Array") || !identical(a at seed@file, "assays.h5") ||
+            !(a at seed@name %in% h5_datasets))
+            .stop_if_bad_dir(dir)
+        a at seed@file <- file_path_as_absolute(file.path(dir, a at seed@file))
+        assay(ans, i, withDimnames=FALSE) <- a
+    }
+    ans
+}
+
diff --git a/R/zzz.R b/R/zzz.R
new file mode 100644
index 0000000..dd7aaac
--- /dev/null
+++ b/R/zzz.R
@@ -0,0 +1,2 @@
+.test <- function() BiocGenerics:::testPackage("SummarizedExperiment")
+
diff --git a/build/vignette.rds b/build/vignette.rds
new file mode 100644
index 0000000..ea870a4
Binary files /dev/null and b/build/vignette.rds differ
diff --git a/debian/README.test b/debian/README.test
deleted file mode 100644
index d22f2c9..0000000
--- a/debian/README.test
+++ /dev/null
@@ -1,15 +0,0 @@
-Notes on how this package can be tested.
-────────────────────────────────────────
-
-Please make sure you have installed the Recommended package
-r-bioc-shortread.  Then you should be able to successfully run the test
-suite by doing
-
-R --no-save <<EOT
-BiocGenerics:::testPackage('Rsamtools')
-EOT
-
-Currently one out of 73 tests is failing which is sorted out with
-upstream before an autopkgtest will be provided.
-
- -- Andreas Tille <tille at debian.org>  Mon, 16 Jun 2014 16:28:55 +0200
diff --git a/debian/changelog b/debian/changelog
deleted file mode 100644
index 8ee346e..0000000
--- a/debian/changelog
+++ /dev/null
@@ -1,61 +0,0 @@
-r-bioc-summarizedexperiment (1.6.3-1) unstable; urgency=medium
-
-  * Team upload
-  * New upstream version
-  * Add new Build-Depends: r-bioc-delayedarray
-
- -- Graham Inggs <ginggs at debian.org>  Fri, 09 Jun 2017 16:16:24 +0200
-
-r-bioc-summarizedexperiment (1.4.0-2) unstable; urgency=medium
-
-  * Exclude more parts of test suite which fail due to missing data package
-  * debhelper 10
-  * d/watch: version=4
-
- -- Andreas Tille <tille at debian.org>  Sun, 15 Jan 2017 18:43:53 +0100
-
-r-bioc-summarizedexperiment (1.4.0-1) unstable; urgency=medium
-
-  * New upstream version
-  * Convert to dh-r
-  * Generic BioConductor homepage
-  * New Build-Depends: r-cran-matrix
-  * New versioned Build-Depends: r-bioc-s4vectors (>= 0.11.7),
-    r-bioc-iranges (>= 2.7.2),
-
- -- Andreas Tille <tille at debian.org>  Wed, 26 Oct 2016 21:57:26 +0200
-
-r-bioc-summarizedexperiment (1.2.0-1) unstable; urgency=medium
-
-  * New upstream version
-  * Fix versioned Depends
-
- -- Andreas Tille <tille at debian.org>  Sun, 08 May 2016 19:12:19 +0200
-
-r-bioc-summarizedexperiment (1.0.2-3) unstable; urgency=medium
-
-  * Skip test needing unpackaged database (thanks to Gordon Ball
-    <gordon at chronitis.net> for the hint)
-
- -- Andreas Tille <tille at debian.org>  Tue, 03 May 2016 20:27:21 +0200
-
-r-bioc-summarizedexperiment (1.0.2-2) unstable; urgency=medium
-
-  * Add missing Depends to autopkgtest
-
- -- Andreas Tille <tille at debian.org>  Fri, 29 Apr 2016 08:41:09 +0200
-
-r-bioc-summarizedexperiment (1.0.2-1) unstable; urgency=medium
-
-  * New upstream version
-  * cme fix dpkg-control
-  * Fix dependencies of autopkgtest
-  * Increased versioned Depends r-bioc-genomicranges
-
- -- Andreas Tille <tille at debian.org>  Wed, 27 Apr 2016 22:38:57 +0200
-
-r-bioc-summarizedexperiment (1.0.0-1) unstable; urgency=low
-
-  * Initial release (closes: #803616)
-
- -- Andreas Tille <tille at debian.org>  Sat, 31 Oct 2015 22:52:41 +0100
diff --git a/debian/compat b/debian/compat
deleted file mode 100644
index f599e28..0000000
--- a/debian/compat
+++ /dev/null
@@ -1 +0,0 @@
-10
diff --git a/debian/control b/debian/control
deleted file mode 100644
index 9cbdc91..0000000
--- a/debian/control
+++ /dev/null
@@ -1,30 +0,0 @@
-Source: r-bioc-summarizedexperiment
-Maintainer: Debian Med Packaging Team <debian-med-packaging at lists.alioth.debian.org>
-Uploaders: Andreas Tille <tille at debian.org>
-Section: gnu-r
-Priority: optional
-Build-Depends: debhelper (>= 10),
-               dh-r,
-               r-base-dev,
-               r-bioc-biobase (>= 2.26.0),
-               r-bioc-genomicranges (>= 1.24.0),
-               r-bioc-iranges (>= 2.7.2),
-               r-bioc-s4vectors (>= 0.11.7),
-               r-bioc-delayedarray,
-               r-cran-matrix
-Standards-Version: 3.9.8
-Vcs-Browser: https://anonscm.debian.org/viewvc/debian-med/trunk/packages/R/r-bioc-summarizedexperiment/trunk/
-Vcs-Svn: svn://anonscm.debian.org/debian-med/trunk/packages/R/r-bioc-summarizedexperiment/trunk/
-Homepage: https://bioconductor.org/packages/SummarizedExperiment/
-
-Package: r-bioc-summarizedexperiment
-Architecture: all
-Depends: ${R:Depends},
-         ${misc:Depends},
-Recommends: ${R:Recommends}
-Suggests: ${R:Suggests}
-Description: BioConductor assay container
- The SummarizedExperiment container contains one or more assays, each
- represented by a matrix-like object of numeric or other mode. The rows
- typically represent genomic ranges of interest and the columns
- represent samples.
diff --git a/debian/copyright b/debian/copyright
deleted file mode 100644
index 360a81e..0000000
--- a/debian/copyright
+++ /dev/null
@@ -1,107 +0,0 @@
-Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
-Upstream-Name: SummarizedExperiment
-Upstream-Contact: Bioconductor Package Maintainer <maintainer at bioconductor.org> 
-Source: https://bioconductor.org/packages/SummarizedExperiment/
-
-Files: *
-Copyright: © 2014-2016 Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès
-License: Artistic-2.0
-
-
-Files: debian/*
-Copyright: 2015-2016 Andreas Tille <tille at debian.org>
-License: Artistic-2.0
-
-License: Artistic-2.0
-			 The "Artistic License"
- .
-				Preamble
- .
- 1. You may make and give away verbatim copies of the source form of the
-    Standard Version of this Package without restriction, provided that
-    you duplicate all of the original copyright notices and associated
-    disclaimers.
- .
- 2. You may apply bug fixes, portability fixes and other modifications
-    derived from the Public Domain or from the Copyright Holder.  A
-    Package modified in such a way shall still be considered the Standard
-    Version.
- .
- 3. You may otherwise modify your copy of this Package in any way,
-    provided that you insert a prominent notice in each changed file stating
-    how and when you changed that file, and provided that you do at least
-    ONE of the following:
- .
-    a) place your modifications in the Public Domain or otherwise make them
-    Freely Available, such as by posting said modifications to Usenet or
-    an equivalent medium, or placing the modifications on a major archive
-    site such as uunet.uu.net, or by allowing the Copyright Holder to include
-    your modifications in the Standard Version of the Package.
- .
-    b) use the modified Package only within your corporation or organization.
- .
-    c) rename any non-standard executables so the names do not conflict
-    with standard executables, which must also be provided, and provide
-    a separate manual page for each non-standard executable that clearly
-    documents how it differs from the Standard Version.
- .
-    d) make other distribution arrangements with the Copyright Holder.
- .
- 4. You may distribute the programs of this Package in object code or
-    executable form, provided that you do at least ONE of the following:
- .
-    a) distribute a Standard Version of the executables and library files,
-    together with instructions (in the manual page or equivalent) on where
-    to get the Standard Version.
- .
-    b) accompany the distribution with the machine-readable source of
-    the Package with your modifications.
- .
-    c) give non-standard executables non-standard names, and clearly
-    document the differences in manual pages (or equivalent), together
-    with instructions on where to get the Standard Version.
- .
-    d) make other distribution arrangements with the Copyright Holder.
- .
- 5. You may charge a reasonable copying fee for any distribution of this
-    Package.  You may charge any fee you choose for support of this Package.
-    You may not charge a fee for this Package itself.  However, you may
-    distribute this Package in aggregate with other (possibly commercial)
-    programs as part of a larger (possibly commercial) software distribution
-    provided that you do not advertise this Package as a product of your
-    own.  You may embed this Package's interpreter within an executable of
-    yours (by linking); this shall be construed as a mere form of
-    aggregation, provided that the complete Standard Version of the
-    interpreter is so embedded.
- .
- 6. The scripts and library files supplied as input to or produced as
-    output from the programs of this Package do not automatically fall under
-    the copyright of this Package, but belong to whoever generated them, and
-    may be sold commercially, and may be aggregated with this Package.  If
-    such scripts or library files are aggregated with this Package via the
-    so-called "undump" or "unexec" methods of producing a binary executable
-    image, then distribution of such an image shall neither be construed as
-    a distribution of this Package nor shall it fall under the restrictions
-    of Paragraphs 3 and 4, provided that you do not represent such an
-    executable image as a Standard Version of this Package.
- .
- 7. C subroutines (or comparably compiled subroutines in other
-    languages) supplied by you and linked into this Package in order to
-    emulate subroutines and variables of the language defined by this
-    Package shall not be considered part of this Package, but are the
-    equivalent of input as in Paragraph 6, provided these subroutines do
-    not change the language in any way that would cause it to fail the
-    regression tests for the language.
- .
- 8. Aggregation of this Package with a commercial distribution is always
-    permitted provided that the use of this Package is embedded; that is,
-    when no overt attempt is made to make this Package's interfaces visible
-    to the end user of the commercial distribution.  Such use shall not be
-    construed as a distribution of this Package.
- .
- 9. The name of the Copyright Holder may not be used to endorse or promote
-    products derived from this software without specific prior written permission.
- .
- 10. THIS PACKAGE IS PROVIDED "AS IS" AND WITHOUT ANY EXPRESS OR
-    IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
-    WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
diff --git a/debian/docs b/debian/docs
deleted file mode 100644
index 50f6656..0000000
--- a/debian/docs
+++ /dev/null
@@ -1 +0,0 @@
-debian/README.test
diff --git a/debian/patches/series b/debian/patches/series
deleted file mode 100644
index af56ecc..0000000
--- a/debian/patches/series
+++ /dev/null
@@ -1 +0,0 @@
-skip_test_needing_not_packaged_database.patch
diff --git a/debian/patches/skip_test_needing_not_packaged_database.patch b/debian/patches/skip_test_needing_not_packaged_database.patch
deleted file mode 100644
index 639d1db..0000000
--- a/debian/patches/skip_test_needing_not_packaged_database.patch
+++ /dev/null
@@ -1,54 +0,0 @@
-Description: Skip test needing unpackaged database
-Author: Andreas Tille <tille at debian.org>
-Last-Update: Tue, 03 May 2016 20:27:21 +0200
-
---- a/inst/unitTests/test_makeSummarizedExperimentFromExpressionSet.R
-+++ b/inst/unitTests/test_makeSummarizedExperimentFromExpressionSet.R
-@@ -141,47 +141,3 @@ test_GenomicRanges_SummarizedExperiment_
-                        sampleNames(eset5))
- }
- 
--test_GenomicRanges_SummarizedExperiment_coercion_mappingFunctions <- function()
--{
--    ## naiveRangeMapper
--    ## valid object from empty object
--    checkTrue(validObject(makeSummarizedExperimentFromExpressionSet(ExpressionSet())))
--
--    ## valid object from sample ExpressionSet
--    data("sample.ExpressionSet", package = "Biobase")
--    eset1 <- sample.ExpressionSet
--    checkTrue(validObject(makeSummarizedExperimentFromExpressionSet(eset1)))
--
--    ## makeSummarizedExperimentFromExpressionSet should be the same as `as`
--    ## with default args
--    checkEquals(makeSummarizedExperimentFromExpressionSet(eset1),
--                as(eset1, "RangedSummarizedExperiment"))
--
--    ## probeRangeMapper
--    ## valid object from empty object
--    checkTrue(validObject(
--            makeSummarizedExperimentFromExpressionSet(ExpressionSet(),
--                probeRangeMapper)))
--
--    ## valid object from sample ExpressionSet
--    se1 <- makeSummarizedExperimentFromExpressionSet(eset1, probeRangeMapper)
--    checkTrue(validObject(se1))
--
--    ## Granges returned have rownames that were from the featureNames
--    checkTrue(all(rownames(rowRanges(se1)) %in% featureNames(eset1)))
--
--    ## geneRangeMapper
--    ## valid object from empty object
--    checkTrue(validObject(
--            makeSummarizedExperimentFromExpressionSet(ExpressionSet(),
--                geneRangeMapper(NULL))))
--
--    ## valid object from sample ExpressionSet
--    se2 <- makeSummarizedExperimentFromExpressionSet(eset1,
--        geneRangeMapper("TxDb.Hsapiens.UCSC.hg19.knownGene"))
--    checkTrue(validObject(se2))
--
--    ## Granges returned have rownames that were from the featureNames
--    checkTrue(all(rownames(rowRanges(se2)) %in% featureNames(eset1)))
--}
--
diff --git a/debian/rules b/debian/rules
deleted file mode 100755
index 68d9a36..0000000
--- a/debian/rules
+++ /dev/null
@@ -1,4 +0,0 @@
-#!/usr/bin/make -f
-
-%:
-	dh $@ --buildsystem R
diff --git a/debian/source/format b/debian/source/format
deleted file mode 100644
index 163aaf8..0000000
--- a/debian/source/format
+++ /dev/null
@@ -1 +0,0 @@
-3.0 (quilt)
diff --git a/debian/tests/control b/debian/tests/control
deleted file mode 100644
index 768f587..0000000
--- a/debian/tests/control
+++ /dev/null
@@ -1,3 +0,0 @@
-Tests: run-unit-test
-Depends: @, r-cran-runit, r-cran-digest, r-bioc-annotate
-Restrictions: allow-stderr
diff --git a/debian/tests/run-unit-test b/debian/tests/run-unit-test
deleted file mode 100644
index b5e9276..0000000
--- a/debian/tests/run-unit-test
+++ /dev/null
@@ -1,6 +0,0 @@
-#!/bin/sh -e
-
-LC_ALL=C R --no-save <<EOT
-SummarizedExperiment:::.test()
-EOT
-
diff --git a/debian/watch b/debian/watch
deleted file mode 100644
index 9eacbd4..0000000
--- a/debian/watch
+++ /dev/null
@@ -1,3 +0,0 @@
-version=4
-opts=downloadurlmangle=s?^(.*)\.\.?http:$1packages/release/bioc? \
- http://www.bioconductor.org/packages/release/bioc/html/SummarizedExperiment.html .*/SummarizedExperiment_([\d\.]+)\.tar\.gz
diff --git a/inst/doc/SummarizedExperiment.R b/inst/doc/SummarizedExperiment.R
new file mode 100644
index 0000000..716bf4a
--- /dev/null
+++ b/inst/doc/SummarizedExperiment.R
@@ -0,0 +1,101 @@
+## ----style, echo=FALSE, results='asis'-----------------------------------
+BiocStyle::markdown()
+
+## ----include = FALSE-----------------------------------------------------
+# download current version of SE diagram
+#download.file("https://docs.google.com/feeds/download/drawings/Export?id=18OcDb80FpvSGRYnFl-8vUqwNNLaNHrG1I9SWKHCselo&exportFormat=svg", "SE.svg")
+download.file("https://docs.google.com/feeds/download/drawings/Export?id=1kiC8Qlo1mhSnLDqkGiRNPSo6GWn3C2duBszCFbJCB-g&exportFormat=svg", "SE.svg")
+
+## ---- echo=FALSE---------------------------------------------------------
+suppressPackageStartupMessages(library(SummarizedExperiment))
+suppressPackageStartupMessages(data(airway, package="airway"))
+
+## ------------------------------------------------------------------------
+library(SummarizedExperiment)
+data(airway, package="airway")
+se <- airway
+se
+
+## ----assays, eval = FALSE------------------------------------------------
+#  assays(se)$counts
+
+## ----assays_table, echo = FALSE------------------------------------------
+knitr::kable(assays(se)$counts[1:10,])
+
+## ----rowRanges-----------------------------------------------------------
+rowRanges(se)
+
+## ----colData-------------------------------------------------------------
+colData(se)
+
+## ----columnSubset--------------------------------------------------------
+# subset for only those samples treated with dexamethasone
+se[, se$dex == "trt"]
+
+## ----metadata------------------------------------------------------------
+metadata(se)
+
+## ----metadata-formula----------------------------------------------------
+metadata(se)$formula <- counts ~ dex + albut
+
+metadata(se)
+
+## ----constructRSE--------------------------------------------------------
+nrows <- 200
+ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(50, 150)),
+                     IRanges(floor(runif(200, 1e5, 1e6)), width=100),
+                     strand=sample(c("+", "-"), 200, TRUE),
+                     feature_id=sprintf("ID%03d", 1:200))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+
+SummarizedExperiment(assays=list(counts=counts),
+                     rowRanges=rowRanges, colData=colData)
+
+## ----constructSE---------------------------------------------------------
+SummarizedExperiment(assays=list(counts=counts), colData=colData)
+
+## ----2d------------------------------------------------------------------
+# subset the first five transcripts and first three samples
+se[1:5, 1:3]
+
+## ----colDataExtraction---------------------------------------------------
+se[, se$cell == "N61311"]
+
+## ----getSet--------------------------------------------------------------
+counts <- matrix(1:15, 5, 3, dimnames=list(LETTERS[1:5], LETTERS[1:3]))
+
+dates <- SummarizedExperiment(assays=list(counts=counts),
+                              rowData=DataFrame(month=month.name[1:5], day=1:5))
+
+# Subset all January assays
+dates[rowData(dates)$month == "January", ]
+
+## ----assay_assays--------------------------------------------------------
+assays(se)
+
+assays(se)[[1]][1:5, 1:5]
+
+# assay defaults to the first assay if no i is given
+assay(se)[1:5, 1:5]
+
+assay(se, 1)[1:5, 1:5]
+
+## ----overlap-------------------------------------------------------------
+# Subset for only rows which are in the interval 100,000 to 110,000 of
+# chromosome 1
+roi <- GRanges(seqnames="1", ranges=100000:1100000)
+subsetByOverlaps(se, roi)
+
+## ----rseSubclass---------------------------------------------------------
+setClass("MyRSESubclass",
+    contains="RangedSummarizedExperiment",
+    representation=representation(
+        slot1="integer",
+        slot2="function"
+        ## ... maybe more ...
+    )
+)
+
diff --git a/inst/doc/SummarizedExperiment.Rmd b/inst/doc/SummarizedExperiment.Rmd
new file mode 100644
index 0000000..5702f6b
--- /dev/null
+++ b/inst/doc/SummarizedExperiment.Rmd
@@ -0,0 +1,345 @@
+---
+title: "_SummarizedExperiment_ for Coordinating Experimental Assays, Samples, and Regions of Interest"
+author: "Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès"
+date: "Revised: 22 June, 2016"
+output:
+  BiocStyle::html_document:
+    toc: true
+vignette: >
+  %\VignetteIndexEntry{SummarizedExperiment}
+  %\VignetteEngine{knitr::rmarkdown}
+  \usepackage[utf8]{inputenc}
+---
+
+```{r style, echo=FALSE, results='asis'}
+BiocStyle::markdown()
+```
+
+
+# Introduction 
+
+The `SummarizedExperiment` class is used to store rectangular matrices of
+experimental results, which are commonly produced by sequencing and microarray
+experiments.  Each object stores observations of one or more samples, along
+with additional meta-data describing both the observations (features) and
+samples (phenotypes).
+
+A key aspect of the `SummarizedExperiment` class is the coordination of the
+meta-data and assays when subsetting. For example, if you want to exclude a
+given sample you can do for both the meta-data and assay in one operation,
+which ensures the meta-data and observed data will remain in sync.  Improperly
+accounting for meta and observational data has resulted in a number of
+incorrect results and retractions so this is a very desirable
+property.
+
+`SummarizedExperiment` is in many ways similar to the historical
+`ExpressionSet`, the main distinction being that `SummarizedExperiment` is more
+flexible in it's row information, allowing both `GRanges` based as well as those
+described by arbitrary `DataFrame`s.  This makes it ideally suited to a variety
+of experiments, particularly sequencing based experiments such as RNA-Seq and
+ChIp-Seq.
+
+#  Anatomy of a `SummarizedExperiment`
+
+The _SummarizedExperiment_ package contains two classes: 
+`SummarizedExperiment` and `RangedSummarizedExperiment`.
+
+`SummarizedExperiment` is a matrix-like container where rows represent features
+of interest (e.g. genes, transcripts, exons, etc.) and columns represent
+samples. The objects contain one or more assays, each represented by a
+matrix-like object of numeric or other mode. The rows of a
+`SummarizedExperiment` object represent features of interest.  Information
+about these features is stored in a `DataFrame` object, accessible using the
+function `rowData()`. Each row of the `DataFrame` provides information on the
+feature in the corresponding row of the `SummarizedExperiment` object. Columns
+of the DataFrame represent different attributes of the features of interest,
+e.g., gene or transcript IDs, etc.
+
+`RangedSummarizedExperiment` is the child of the `SummarizedExperiment` class
+which means that all the methods on `SummarizedExperiment` also work on a
+`RangedSummarizedExperiment`.
+
+The fundamental difference between the two classes is that the rows of a
+`RangedSummarizedExperiment` object represent genomic ranges of interest
+instead of a `DataFrame` of features. The `RangedSummarizedExperiment` ranges
+are described by a `GRanges` or a `GRangesList` object, accessible using the
+`rowRanges()` function.
+
+The following graphic displays the class geometry and highlights the
+vertical (column) and horizontal (row) relationships.
+
+
+```{r include = FALSE}
+# download current version of SE diagram
+#download.file("https://docs.google.com/feeds/download/drawings/Export?id=18OcDb80FpvSGRYnFl-8vUqwNNLaNHrG1I9SWKHCselo&exportFormat=svg", "SE.svg")
+download.file("https://docs.google.com/feeds/download/drawings/Export?id=1kiC8Qlo1mhSnLDqkGiRNPSo6GWn3C2duBszCFbJCB-g&exportFormat=svg", "SE.svg")
+```
+
+![Summarized Experiment](SE.svg)
+
+## Assays
+
+The `airway` package contains an example dataset from an RNA-Seq experiment of
+read counts per gene for airway smooth muscles.  These data are stored
+in a `RangedSummarizedExperiment` object which contains 8 different
+experimental and assays 64,102 gene transcripts.
+
+```{r, echo=FALSE}
+suppressPackageStartupMessages(library(SummarizedExperiment))
+suppressPackageStartupMessages(data(airway, package="airway"))
+```
+
+```{r}
+library(SummarizedExperiment)
+data(airway, package="airway")
+se <- airway
+se
+```
+
+To retrieve the experiment data from a `SummarizedExperiment` object one can
+use the `assays()` accessor.  An object can have multiple assay datasets
+each of which can be accessed using the `$` operator.
+The `airway` dataset contains only one assay (`counts`).  Here each row
+represents a gene transcript and each column one of the samples.
+
+```{r assays, eval = FALSE}
+assays(se)$counts
+```
+
+```{r assays_table, echo = FALSE}
+knitr::kable(assays(se)$counts[1:10,])
+```
+
+## 'Row' (regions-of-interest) data
+The `rowRanges()` accessor is used to view the range information for a
+`RangedSummarizedExperiment`. (Note if this were the parent 
+`SummarizedExperiment` class we'd use `rowData()`). The data are stored in a 
+`GRangesList` object, where each list element corresponds to one gene 
+transcript and the ranges in each `GRanges` correspond to the exons in the
+transcript.
+
+```{r rowRanges}
+rowRanges(se)
+```
+
+## 'Column' (sample) data
+
+Sample meta-data describing the samples can be accessed using `colData()`, and
+is a `DataFrame` that can store any number of descriptive columns for each
+sample row.
+
+```{r colData}
+colData(se)
+```
+
+This sample metadata can be accessed using the `$` accessor which makes it 
+easy to subset the entire object by a given phenotype.
+
+```{r columnSubset}
+# subset for only those samples treated with dexamethasone
+se[, se$dex == "trt"]
+```
+
+## Experiment-wide metadata
+
+Meta-data describing the experimental methods and publication references can be
+accessed using `metadata()`.
+
+```{r metadata}
+metadata(se)
+```
+
+Note that `metadata()` is just a simple list, so it is appropriate for _any_
+experiment wide metadata the user wishes to save, such as storing model
+formulas.
+
+```{r metadata-formula}
+metadata(se)$formula <- counts ~ dex + albut
+
+metadata(se)
+```
+
+# Constructing a `SummarizedExperiment` 
+
+Often, `SummarizedExperiment` or `RangedSummarizedExperiment` objects are 
+returned by functions written by other packages. However it is possible to 
+create them by hand with a call to the `SummarizedExperiment()` constructor.
+
+Constructing a `RangedSummarizedExperiment` with a `GRanges` as the
+_rowRanges_ argument:
+
+```{r constructRSE}
+nrows <- 200
+ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(50, 150)),
+                     IRanges(floor(runif(200, 1e5, 1e6)), width=100),
+                     strand=sample(c("+", "-"), 200, TRUE),
+                     feature_id=sprintf("ID%03d", 1:200))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+
+SummarizedExperiment(assays=list(counts=counts),
+                     rowRanges=rowRanges, colData=colData)
+```
+
+A `SummarizedExperiment` can be constructed with or without supplying
+a `DataFrame` for the _rowData_ argument:
+
+```{r constructSE}
+SummarizedExperiment(assays=list(counts=counts), colData=colData)
+```
+
+# Common operations on `SummarizedExperiment`
+
+## Subsetting
+
+- `[` Performs two dimensional subsetting, just like subsetting a matrix
+    or data frame.
+```{r 2d}
+# subset the first five transcripts and first three samples
+se[1:5, 1:3]
+```
+- `$` operates on `colData()` columns, for easy sample extraction.
+```{r colDataExtraction}
+se[, se$cell == "N61311"]
+```
+
+## Getters and setters
+
+- `rowRanges()` / (`rowData()`), `colData()`, `metadata()`
+```{r getSet}
+counts <- matrix(1:15, 5, 3, dimnames=list(LETTERS[1:5], LETTERS[1:3]))
+
+dates <- SummarizedExperiment(assays=list(counts=counts),
+                              rowData=DataFrame(month=month.name[1:5], day=1:5))
+
+# Subset all January assays
+dates[rowData(dates)$month == "January", ]
+```
+
+- `assay()` versus `assays()`
+There are two accessor functions for extracting the assay data from a
+`SummarizedExperiment` object.  `assays()` operates on the entire list of assay
+data as a whole, while `assay()` operates on only one assay at a time.
+`assay(x, i)` is simply a convenience function which is equivalent to
+`assays(x)[[i]]`.
+
+```{r assay_assays}
+assays(se)
+
+assays(se)[[1]][1:5, 1:5]
+
+# assay defaults to the first assay if no i is given
+assay(se)[1:5, 1:5]
+
+assay(se, 1)[1:5, 1:5]
+```
+
+## Range-based operations
+
+- `subsetByOverlaps()`
+`SummarizedExperiment` objects support all of the `findOverlaps()` methods and
+associated functions.  This includes `subsetByOverlaps()`, which makes it easy
+to subset a `SummarizedExperiment` object by an interval.
+
+```{r overlap}
+# Subset for only rows which are in the interval 100,000 to 110,000 of
+# chromosome 1
+roi <- GRanges(seqnames="1", ranges=100000:1100000)
+subsetByOverlaps(se, roi)
+```
+
+# Advanced: Extending `RangedSummarizedExperiment`
+
+For representing and manipulating data in their own package, Bioconductor
+developers are encouraged to re-use existing classes defined in other
+packages like the `RangedSummarizedExperiment` or `GRanges` containers
+defined in the `SummarizedExperiment` or `GenomicRanges` infrastructure
+packages, respectively. Many Bioconductor packages are designed around
+these basic containers, that is, they define functions that take and/or
+return a `RangedSummarizedExperiment` or `GRanges` object.
+For example the `csaw` package defines various functions that operate
+on `RangedSummarizedExperiment` objects, which are used to represent the
+number of ChIP-seq reads from each BAM file overlapping pre-specified
+regions.
+
+However, sometimes re-using the `RangedSummarizedExperiment` class as-is
+does not satisfy the needs of the package and the developer makes the choice
+to extend the class in order to accomodate the special needs of the package
+and/or the specificities of the data that it deals with. For example the
+`DESeq2` package defines the `DESeqDataSet` class which extends
+`RangedSummarizedExperiment` to add the `design` and `dispersionFunction`
+slots to it.
+
+The following subsections describe in a nutshell how the developer would
+typically proceed for extending `RangedSummarizedExperiment` in his/her
+own package. Some familiarity with the S4 class system is required. Readers
+not familiar with the S4 class system are encouraged to consult the vignette
+`A quick overview of the S4 class system` located in the `S4Vectors` package
+for the basics of implementing and extending S4 classes.
+
+The approach described below allows the developer to extend
+`RangedSummarizedExperiment` it in a way that remains agnostic of its
+internals. Keeping this separation between the responsibilities of the owners
+of the parent and child classes facilitate maintenance in the long run.
+In particular, the implementation of the child class won't be affected by
+changes in the internals of the parent class.
+
+## Depend on, and import, the `SummarizedExperiment` package
+
+Add `SummarizedExperiment` to the Depends field of the DESCRIPTION file
+of the package and the `import(SummarizedExperiment)` directive to its
+NAMESPACE file.
+
+## Define and export the `RangedSummarizedExperiment` subclass
+
+Define the subclass with something like:
+```{r rseSubclass}
+setClass("MyRSESubclass",
+    contains="RangedSummarizedExperiment",
+    representation=representation(
+        slot1="integer",
+        slot2="function"
+        ## ... maybe more ...
+    )
+)
+```
+
+Export it by adding the `exportClasses(MyRSESubclass)` directive to the
+NAMESPACE file.
+
+## Construct `MyRSESubclass` instances
+
+When calling `new()` for constructing a `MyRSESubclass` instance, specify
+only the MyRSESubclass-specific slots:
+`new("MyRSESubclass", rse, slot1=value1, slot2=value2)`,
+where `rse` is a `RangedSummarizedExperiment` object.
+
+Providing a `MyRSESubclass` constructor function (named as the class itself)
+is recommended.
+
+## Define a validity method
+
+The validity method for `MyRSESubclass` only needs to take care of what's
+new in `MyRSESubclass` with respect to `RangedSummarizedExperiment`, that is,
+of the aspects of `MyRSESubclass` objects that are not already covered by the
+validity method for `RangedSummarizedExperiment` objects. This is because
+calling `validObject()` on a `MyRSESubclass` object automatically validates
+it as a `RangedSummarizedExperiment` object first and then calls the validity
+method for `MyRSESubclass` objects. In other words, validation works
+incrementally starting from the root of the class hierarchy and going in the
+parent-to-child direction.
+
+## Use the `RangedSummarizedExperiment` accessors on `MyRSESubclass` objects
+
+Like any user of `RangedSummarizedExperiment` objects, the developer of
+`MyRSESubclass` should always use the `RangedSummarizedExperiment` accessors
+to access the `RangedSummarizedExperiment`-specific parts of his/her
+`MyRSESubclass` objects.
+
+## Use `callNextMethod`
+
+In case some of the methods defined for `RangedSummarizedExperiment` objects
+need to be overwritten, the new methods should call `callNextMethod`
+internally.
diff --git a/inst/doc/SummarizedExperiment.html b/inst/doc/SummarizedExperiment.html
new file mode 100644
index 0000000..650abb5
--- /dev/null
+++ b/inst/doc/SummarizedExperiment.html
@@ -0,0 +1,541 @@
+<!DOCTYPE html>
+
+<html xmlns="http://www.w3.org/1999/xhtml">
+
+<head>
+
+<meta charset="utf-8">
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+<meta name="generator" content="pandoc" />
+
+<meta name="author" content="Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès" />
+
+
+<title>SummarizedExperiment for Coordinating Experimental Assays, Samples, and Regions of Interest</title>
+
+<link href="data:text/css;charset=utf-8,pre%20%2Eoperator%2C%0Apre%20%2Eparen%20%7B%0Acolor%3A%20rgb%28104%2C%20118%2C%20135%29%0A%7D%0Apre%20%2Eliteral%20%7B%0Acolor%3A%20%23990073%0A%7D%0Apre%20%2Enumber%20%7B%0Acolor%3A%20%23099%3B%0A%7D%0Apre%20%2Ecomment%20%7B%0Acolor%3A%20%23998%3B%0Afont%2Dstyle%3A%20italic%0A%7D%0Apre%20%2Ekeyword%20%7B%0Acolor%3A%20%23900%3B%0Afont%2Dweight%3A%20bold%0A%7D%0Apre%20%2Eidentifier%20%7B%0Acolor%3A%20rgb%280%2C%200%2C%200%29%3B%0A%7D%0Apre%20%2Estri [...]
+<script src="data:application/x-javascript;base64,dmFyIGhsanM9bmV3IGZ1bmN0aW9uKCl7ZnVuY3Rpb24gbShwKXtyZXR1cm4gcC5yZXBsYWNlKC8mL2dtLCImYW1wOyIpLnJlcGxhY2UoLzwvZ20sIiZsdDsiKX1mdW5jdGlvbiBmKHIscSxwKXtyZXR1cm4gUmVnRXhwKHEsIm0iKyhyLmNJPyJpIjoiIikrKHA/ImciOiIiKSl9ZnVuY3Rpb24gYihyKXtmb3IodmFyIHA9MDtwPHIuY2hpbGROb2Rlcy5sZW5ndGg7cCsrKXt2YXIgcT1yLmNoaWxkTm9kZXNbcF07aWYocS5ub2RlTmFtZT09IkNPREUiKXtyZXR1cm4gcX1pZighKHEubm9kZVR5cGU9PTMmJnEubm9kZVZhbHVlLm1hdGNoKC9ccysvKSkpe2JyZWFrfX19ZnVuY3Rpb24gaCh0LH [...]
+
+<style type="text/css">code{white-space: pre;}</style>
+<style type="text/css">
+  pre:not([class]) {
+    background-color: white;
+  }
+</style>
+<script type="text/javascript">
+if (window.hljs && document.readyState && document.readyState === "complete") {
+   window.setTimeout(function() {
+      hljs.initHighlighting();
+   }, 0);
+}
+</script>
+
+
+<link href="data:text/css;charset=utf-8,body%2C%20td%20%7B%0Afont%2Dfamily%3A%20sans%2Dserif%3B%0Abackground%2Dcolor%3A%20white%3B%0Afont%2Dsize%3A%2013px%3B%0A%7D%0Abody%20%7B%0Amax%2Dwidth%3A%20800px%3B%0Amargin%3A%200%20auto%3B%0Apadding%3A%201em%201em%202em%3B%0Aline%2Dheight%3A%2020px%3B%0A%7D%0A%0Adiv%23TOC%20li%20%7B%0Alist%2Dstyle%3Anone%3B%0Abackground%2Dimage%3Anone%3B%0Abackground%2Drepeat%3Anone%3B%0Abackground%2Dposition%3A0%3B%0A%7D%0A%0Ap%2C%20pre%20%7B%20margin%3A%200em%2 [...]
+
+<script type="text/javascript">
+document.addEventListener("DOMContentLoaded", function() {
+  var links = document.links;  
+  for (var i = 0, linksLength = links.length; i < linksLength; i++)
+    if(links[i].hostname != window.location.hostname)
+      links[i].target = '_blank';
+});
+</script>
+
+</head>
+
+<body>
+
+
+<div id="header">
+<h1 class="title"><em>SummarizedExperiment</em> for Coordinating Experimental Assays, Samples, and Regions of Interest</h1>
+<h4 class="author"><em>Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès</em></h4>
+<h4 class="date"><em>Revised: 22 June, 2016</em></h4>
+</div>
+
+<h1>Contents</h1>
+<div id="TOC">
+<ul>
+<li><a href="#introduction"><span class="toc-section-number">1</span> Introduction</a></li>
+<li><a href="#anatomy-of-a-summarizedexperiment"><span class="toc-section-number">2</span> Anatomy of a <code>SummarizedExperiment</code></a><ul>
+<li><a href="#assays"><span class="toc-section-number">2.1</span> Assays</a></li>
+<li><a href="#row-regions-of-interest-data"><span class="toc-section-number">2.2</span> ‘Row’ (regions-of-interest) data</a></li>
+<li><a href="#column-sample-data"><span class="toc-section-number">2.3</span> ‘Column’ (sample) data</a></li>
+<li><a href="#experiment-wide-metadata"><span class="toc-section-number">2.4</span> Experiment-wide metadata</a></li>
+</ul></li>
+<li><a href="#constructing-a-summarizedexperiment"><span class="toc-section-number">3</span> Constructing a <code>SummarizedExperiment</code></a></li>
+<li><a href="#common-operations-on-summarizedexperiment"><span class="toc-section-number">4</span> Common operations on <code>SummarizedExperiment</code></a><ul>
+<li><a href="#subsetting"><span class="toc-section-number">4.1</span> Subsetting</a></li>
+<li><a href="#getters-and-setters"><span class="toc-section-number">4.2</span> Getters and setters</a></li>
+<li><a href="#range-based-operations"><span class="toc-section-number">4.3</span> Range-based operations</a></li>
+</ul></li>
+<li><a href="#advanced-extending-rangedsummarizedexperiment"><span class="toc-section-number">5</span> Advanced: Extending <code>RangedSummarizedExperiment</code></a><ul>
+<li><a href="#depend-on-and-import-the-summarizedexperiment-package"><span class="toc-section-number">5.1</span> Depend on, and import, the <code>SummarizedExperiment</code> package</a></li>
+<li><a href="#define-and-export-the-rangedsummarizedexperiment-subclass"><span class="toc-section-number">5.2</span> Define and export the <code>RangedSummarizedExperiment</code> subclass</a></li>
+<li><a href="#construct-myrsesubclass-instances"><span class="toc-section-number">5.3</span> Construct <code>MyRSESubclass</code> instances</a></li>
+<li><a href="#define-a-validity-method"><span class="toc-section-number">5.4</span> Define a validity method</a></li>
+<li><a href="#use-the-rangedsummarizedexperiment-accessors-on-myrsesubclass-objects"><span class="toc-section-number">5.5</span> Use the <code>RangedSummarizedExperiment</code> accessors on <code>MyRSESubclass</code> objects</a></li>
+<li><a href="#use-callnextmethod"><span class="toc-section-number">5.6</span> Use <code>callNextMethod</code></a></li>
+</ul></li>
+</ul>
+</div>
+
+<script type="text/javascript">
+document.addEventListener("DOMContentLoaded", function() {
+  document.querySelector("h1").className = "title";
+});
+</script>
+<script type="text/javascript">
+document.addEventListener("DOMContentLoaded", function() {
+  var links = document.links;  
+  for (var i = 0, linksLength = links.length; i < linksLength; i++)
+    if (links[i].hostname != window.location.hostname)
+      links[i].target = '_blank';
+});
+</script>
+<div id="introduction" class="section level1">
+<h1><span class="header-section-number">1</span> Introduction</h1>
+<p>The <code>SummarizedExperiment</code> class is used to store rectangular matrices of experimental results, which are commonly produced by sequencing and microarray experiments. Each object stores observations of one or more samples, along with additional meta-data describing both the observations (features) and samples (phenotypes).</p>
+<p>A key aspect of the <code>SummarizedExperiment</code> class is the coordination of the meta-data and assays when subsetting. For example, if you want to exclude a given sample you can do for both the meta-data and assay in one operation, which ensures the meta-data and observed data will remain in sync. Improperly accounting for meta and observational data has resulted in a number of incorrect results and retractions so this is a very desirable property.</p>
+<p><code>SummarizedExperiment</code> is in many ways similar to the historical <code>ExpressionSet</code>, the main distinction being that <code>SummarizedExperiment</code> is more flexible in it’s row information, allowing both <code>GRanges</code> based as well as those described by arbitrary <code>DataFrame</code>s. This makes it ideally suited to a variety of experiments, particularly sequencing based experiments such as RNA-Seq and ChIp-Seq.</p>
+</div>
+<div id="anatomy-of-a-summarizedexperiment" class="section level1">
+<h1><span class="header-section-number">2</span> Anatomy of a <code>SummarizedExperiment</code></h1>
+<p>The <em>SummarizedExperiment</em> package contains two classes: <code>SummarizedExperiment</code> and <code>RangedSummarizedExperiment</code>.</p>
+<p><code>SummarizedExperiment</code> is a matrix-like container where rows represent features of interest (e.g. genes, transcripts, exons, etc.) and columns represent samples. The objects contain one or more assays, each represented by a matrix-like object of numeric or other mode. The rows of a <code>SummarizedExperiment</code> object represent features of interest. Information about these features is stored in a <code>DataFrame</code> object, accessible using the function <code>rowData [...]
+<p><code>RangedSummarizedExperiment</code> is the child of the <code>SummarizedExperiment</code> class which means that all the methods on <code>SummarizedExperiment</code> also work on a <code>RangedSummarizedExperiment</code>.</p>
+<p>The fundamental difference between the two classes is that the rows of a <code>RangedSummarizedExperiment</code> object represent genomic ranges of interest instead of a <code>DataFrame</code> of features. The <code>RangedSummarizedExperiment</code> ranges are described by a <code>GRanges</code> or a <code>GRangesList</code> object, accessible using the <code>rowRanges()</code> function.</p>
+<p>The following graphic displays the class geometry and highlights the vertical (column) and horizontal (row) relationships.</p>
+<p><img src=" [...]
+<div id="assays" class="section level2">
+<h2><span class="header-section-number">2.1</span> Assays</h2>
+<p>The <code>airway</code> package contains an example dataset from an RNA-Seq experiment of read counts per gene for airway smooth muscles. These data are stored in a <code>RangedSummarizedExperiment</code> object which contains 8 different experimental and assays 64,102 gene transcripts.</p>
+<pre class="r"><code>library(SummarizedExperiment)
+data(airway, package="airway")
+se <- airway
+se</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 64102 8 
+## metadata(1): ''
+## assays(1): counts
+## rownames(64102): ENSG00000000003 ENSG00000000005 ... LRG_98 LRG_99
+## rowData names(0):
+## colnames(8): SRR1039508 SRR1039509 ... SRR1039520 SRR1039521
+## colData names(9): SampleName cell ... Sample BioSample</code></pre>
+<p>To retrieve the experiment data from a <code>SummarizedExperiment</code> object one can use the <code>assays()</code> accessor. An object can have multiple assay datasets each of which can be accessed using the <code>$</code> operator. The <code>airway</code> dataset contains only one assay (<code>counts</code>). Here each row represents a gene transcript and each column one of the samples.</p>
+<pre class="r"><code>assays(se)$counts</code></pre>
+<table>
+<thead>
+<tr class="header">
+<th></th>
+<th align="right">SRR1039508</th>
+<th align="right">SRR1039509</th>
+<th align="right">SRR1039512</th>
+<th align="right">SRR1039513</th>
+<th align="right">SRR1039516</th>
+<th align="right">SRR1039517</th>
+<th align="right">SRR1039520</th>
+<th align="right">SRR1039521</th>
+</tr>
+</thead>
+<tbody>
+<tr class="odd">
+<td>ENSG00000000003</td>
+<td align="right">679</td>
+<td align="right">448</td>
+<td align="right">873</td>
+<td align="right">408</td>
+<td align="right">1138</td>
+<td align="right">1047</td>
+<td align="right">770</td>
+<td align="right">572</td>
+</tr>
+<tr class="even">
+<td>ENSG00000000005</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+</tr>
+<tr class="odd">
+<td>ENSG00000000419</td>
+<td align="right">467</td>
+<td align="right">515</td>
+<td align="right">621</td>
+<td align="right">365</td>
+<td align="right">587</td>
+<td align="right">799</td>
+<td align="right">417</td>
+<td align="right">508</td>
+</tr>
+<tr class="even">
+<td>ENSG00000000457</td>
+<td align="right">260</td>
+<td align="right">211</td>
+<td align="right">263</td>
+<td align="right">164</td>
+<td align="right">245</td>
+<td align="right">331</td>
+<td align="right">233</td>
+<td align="right">229</td>
+</tr>
+<tr class="odd">
+<td>ENSG00000000460</td>
+<td align="right">60</td>
+<td align="right">55</td>
+<td align="right">40</td>
+<td align="right">35</td>
+<td align="right">78</td>
+<td align="right">63</td>
+<td align="right">76</td>
+<td align="right">60</td>
+</tr>
+<tr class="even">
+<td>ENSG00000000938</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">2</td>
+<td align="right">0</td>
+<td align="right">1</td>
+<td align="right">0</td>
+<td align="right">0</td>
+<td align="right">0</td>
+</tr>
+<tr class="odd">
+<td>ENSG00000000971</td>
+<td align="right">3251</td>
+<td align="right">3679</td>
+<td align="right">6177</td>
+<td align="right">4252</td>
+<td align="right">6721</td>
+<td align="right">11027</td>
+<td align="right">5176</td>
+<td align="right">7995</td>
+</tr>
+<tr class="even">
+<td>ENSG00000001036</td>
+<td align="right">1433</td>
+<td align="right">1062</td>
+<td align="right">1733</td>
+<td align="right">881</td>
+<td align="right">1424</td>
+<td align="right">1439</td>
+<td align="right">1359</td>
+<td align="right">1109</td>
+</tr>
+<tr class="odd">
+<td>ENSG00000001084</td>
+<td align="right">519</td>
+<td align="right">380</td>
+<td align="right">595</td>
+<td align="right">493</td>
+<td align="right">820</td>
+<td align="right">714</td>
+<td align="right">696</td>
+<td align="right">704</td>
+</tr>
+<tr class="even">
+<td>ENSG00000001167</td>
+<td align="right">394</td>
+<td align="right">236</td>
+<td align="right">464</td>
+<td align="right">175</td>
+<td align="right">658</td>
+<td align="right">584</td>
+<td align="right">360</td>
+<td align="right">269</td>
+</tr>
+</tbody>
+</table>
+</div>
+<div id="row-regions-of-interest-data" class="section level2">
+<h2><span class="header-section-number">2.2</span> ‘Row’ (regions-of-interest) data</h2>
+<p>The <code>rowRanges()</code> accessor is used to view the range information for a <code>RangedSummarizedExperiment</code>. (Note if this were the parent <code>SummarizedExperiment</code> class we’d use <code>rowData()</code>). The data are stored in a <code>GRangesList</code> object, where each list element corresponds to one gene transcript and the ranges in each <code>GRanges</code> correspond to the exons in the transcript.</p>
+<pre class="r"><code>rowRanges(se)</code></pre>
+<pre><code>## GRangesList object of length 64102:
+## $ENSG00000000003 
+## GRanges object with 17 ranges and 2 metadata columns:
+##        seqnames               ranges strand |   exon_id       exon_name
+##           <Rle>            <IRanges>  <Rle> | <integer>     <character>
+##    [1]        X [99883667, 99884983]      - |    667145 ENSE00001459322
+##    [2]        X [99885756, 99885863]      - |    667146 ENSE00000868868
+##    [3]        X [99887482, 99887565]      - |    667147 ENSE00000401072
+##    [4]        X [99887538, 99887565]      - |    667148 ENSE00001849132
+##    [5]        X [99888402, 99888536]      - |    667149 ENSE00003554016
+##    ...      ...                  ...    ... .       ...             ...
+##   [13]        X [99890555, 99890743]      - |    667156 ENSE00003512331
+##   [14]        X [99891188, 99891686]      - |    667158 ENSE00001886883
+##   [15]        X [99891605, 99891803]      - |    667159 ENSE00001855382
+##   [16]        X [99891790, 99892101]      - |    667160 ENSE00001863395
+##   [17]        X [99894942, 99894988]      - |    667161 ENSE00001828996
+## 
+## ...
+## <64101 more elements>
+## -------
+## seqinfo: 722 sequences (1 circular) from an unspecified genome</code></pre>
+</div>
+<div id="column-sample-data" class="section level2">
+<h2><span class="header-section-number">2.3</span> ‘Column’ (sample) data</h2>
+<p>Sample meta-data describing the samples can be accessed using <code>colData()</code>, and is a <code>DataFrame</code> that can store any number of descriptive columns for each sample row.</p>
+<pre class="r"><code>colData(se)</code></pre>
+<pre><code>## DataFrame with 8 rows and 9 columns
+##            SampleName     cell      dex    albut        Run avgLength
+##              <factor> <factor> <factor> <factor>   <factor> <integer>
+## SRR1039508 GSM1275862   N61311    untrt    untrt SRR1039508       126
+## SRR1039509 GSM1275863   N61311      trt    untrt SRR1039509       126
+## SRR1039512 GSM1275866  N052611    untrt    untrt SRR1039512       126
+## SRR1039513 GSM1275867  N052611      trt    untrt SRR1039513        87
+## SRR1039516 GSM1275870  N080611    untrt    untrt SRR1039516       120
+## SRR1039517 GSM1275871  N080611      trt    untrt SRR1039517       126
+## SRR1039520 GSM1275874  N061011    untrt    untrt SRR1039520       101
+## SRR1039521 GSM1275875  N061011      trt    untrt SRR1039521        98
+##            Experiment    Sample    BioSample
+##              <factor>  <factor>     <factor>
+## SRR1039508  SRX384345 SRS508568 SAMN02422669
+## SRR1039509  SRX384346 SRS508567 SAMN02422675
+## SRR1039512  SRX384349 SRS508571 SAMN02422678
+## SRR1039513  SRX384350 SRS508572 SAMN02422670
+## SRR1039516  SRX384353 SRS508575 SAMN02422682
+## SRR1039517  SRX384354 SRS508576 SAMN02422673
+## SRR1039520  SRX384357 SRS508579 SAMN02422683
+## SRR1039521  SRX384358 SRS508580 SAMN02422677</code></pre>
+<p>This sample metadata can be accessed using the <code>$</code> accessor which makes it easy to subset the entire object by a given phenotype.</p>
+<pre class="r"><code># subset for only those samples treated with dexamethasone
+se[, se$dex == "trt"]</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 64102 4 
+## metadata(1): ''
+## assays(1): counts
+## rownames(64102): ENSG00000000003 ENSG00000000005 ... LRG_98 LRG_99
+## rowData names(0):
+## colnames(4): SRR1039509 SRR1039513 SRR1039517 SRR1039521
+## colData names(9): SampleName cell ... Sample BioSample</code></pre>
+</div>
+<div id="experiment-wide-metadata" class="section level2">
+<h2><span class="header-section-number">2.4</span> Experiment-wide metadata</h2>
+<p>Meta-data describing the experimental methods and publication references can be accessed using <code>metadata()</code>.</p>
+<pre class="r"><code>metadata(se)</code></pre>
+<pre><code>## [[1]]
+## Experiment data
+##   Experimenter name: Himes BE 
+##   Laboratory: NA 
+##   Contact information:  
+##   Title: RNA-Seq transcriptome profiling identifies CRISPLD2 as a glucocorticoid responsive gene that modulates cytokine function in airway smooth muscle cells. 
+##   URL: http://www.ncbi.nlm.nih.gov/pubmed/24926665 
+##   PMIDs: 24926665 
+## 
+##   Abstract: A 226 word abstract is available. Use 'abstract' method.</code></pre>
+<p>Note that <code>metadata()</code> is just a simple list, so it is appropriate for <em>any</em> experiment wide metadata the user wishes to save, such as storing model formulas.</p>
+<pre class="r"><code>metadata(se)$formula <- counts ~ dex + albut
+
+metadata(se)</code></pre>
+<pre><code>## [[1]]
+## Experiment data
+##   Experimenter name: Himes BE 
+##   Laboratory: NA 
+##   Contact information:  
+##   Title: RNA-Seq transcriptome profiling identifies CRISPLD2 as a glucocorticoid responsive gene that modulates cytokine function in airway smooth muscle cells. 
+##   URL: http://www.ncbi.nlm.nih.gov/pubmed/24926665 
+##   PMIDs: 24926665 
+## 
+##   Abstract: A 226 word abstract is available. Use 'abstract' method.
+## 
+## $formula
+## counts ~ dex + albut</code></pre>
+</div>
+</div>
+<div id="constructing-a-summarizedexperiment" class="section level1">
+<h1><span class="header-section-number">3</span> Constructing a <code>SummarizedExperiment</code></h1>
+<p>Often, <code>SummarizedExperiment</code> or <code>RangedSummarizedExperiment</code> objects are returned by functions written by other packages. However it is possible to create them by hand with a call to the <code>SummarizedExperiment()</code> constructor.</p>
+<p>Constructing a <code>RangedSummarizedExperiment</code> with a <code>GRanges</code> as the <em>rowRanges</em> argument:</p>
+<pre class="r"><code>nrows <- 200
+ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(50, 150)),
+                     IRanges(floor(runif(200, 1e5, 1e6)), width=100),
+                     strand=sample(c("+", "-"), 200, TRUE),
+                     feature_id=sprintf("ID%03d", 1:200))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+
+SummarizedExperiment(assays=list(counts=counts),
+                     rowRanges=rowRanges, colData=colData)</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 200 6 
+## metadata(0):
+## assays(1): counts
+## rownames: NULL
+## rowData names(1): feature_id
+## colnames(6): A B ... E F
+## colData names(1): Treatment</code></pre>
+<p>A <code>SummarizedExperiment</code> can be constructed with or without supplying a <code>DataFrame</code> for the <em>rowData</em> argument:</p>
+<pre class="r"><code>SummarizedExperiment(assays=list(counts=counts), colData=colData)</code></pre>
+<pre><code>## class: SummarizedExperiment 
+## dim: 200 6 
+## metadata(0):
+## assays(1): counts
+## rownames: NULL
+## rowData names(0):
+## colnames(6): A B ... E F
+## colData names(1): Treatment</code></pre>
+</div>
+<div id="common-operations-on-summarizedexperiment" class="section level1">
+<h1><span class="header-section-number">4</span> Common operations on <code>SummarizedExperiment</code></h1>
+<div id="subsetting" class="section level2">
+<h2><span class="header-section-number">4.1</span> Subsetting</h2>
+<ul>
+<li><code>[</code> Performs two dimensional subsetting, just like subsetting a matrix or data frame.</li>
+</ul>
+<pre class="r"><code># subset the first five transcripts and first three samples
+se[1:5, 1:3]</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 5 3 
+## metadata(2): '' formula
+## assays(1): counts
+## rownames(5): ENSG00000000003 ENSG00000000005 ENSG00000000419
+##   ENSG00000000457 ENSG00000000460
+## rowData names(0):
+## colnames(3): SRR1039508 SRR1039509 SRR1039512
+## colData names(9): SampleName cell ... Sample BioSample</code></pre>
+<ul>
+<li><code>$</code> operates on <code>colData()</code> columns, for easy sample extraction.</li>
+</ul>
+<pre class="r"><code>se[, se$cell == "N61311"]</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 64102 2 
+## metadata(2): '' formula
+## assays(1): counts
+## rownames(64102): ENSG00000000003 ENSG00000000005 ... LRG_98 LRG_99
+## rowData names(0):
+## colnames(2): SRR1039508 SRR1039509
+## colData names(9): SampleName cell ... Sample BioSample</code></pre>
+</div>
+<div id="getters-and-setters" class="section level2">
+<h2><span class="header-section-number">4.2</span> Getters and setters</h2>
+<ul>
+<li><code>rowRanges()</code> / (<code>rowData()</code>), <code>colData()</code>, <code>metadata()</code></li>
+</ul>
+<pre class="r"><code>counts <- matrix(1:15, 5, 3, dimnames=list(LETTERS[1:5], LETTERS[1:3]))
+
+dates <- SummarizedExperiment(assays=list(counts=counts),
+                              rowData=DataFrame(month=month.name[1:5], day=1:5))
+
+# Subset all January assays
+dates[rowData(dates)$month == "January", ]</code></pre>
+<pre><code>## class: SummarizedExperiment 
+## dim: 1 3 
+## metadata(0):
+## assays(1): counts
+## rownames(1): A
+## rowData names(2): month day
+## colnames(3): A B C
+## colData names(0):</code></pre>
+<ul>
+<li><code>assay()</code> versus <code>assays()</code> There are two accessor functions for extracting the assay data from a <code>SummarizedExperiment</code> object. <code>assays()</code> operates on the entire list of assay data as a whole, while <code>assay()</code> operates on only one assay at a time. <code>assay(x, i)</code> is simply a convenience function which is equivalent to <code>assays(x)[[i]]</code>.</li>
+</ul>
+<pre class="r"><code>assays(se)</code></pre>
+<pre><code>## List of length 1
+## names(1): counts</code></pre>
+<pre class="r"><code>assays(se)[[1]][1:5, 1:5]</code></pre>
+<pre><code>##                 SRR1039508 SRR1039509 SRR1039512 SRR1039513 SRR1039516
+## ENSG00000000003        679        448        873        408       1138
+## ENSG00000000005          0          0          0          0          0
+## ENSG00000000419        467        515        621        365        587
+## ENSG00000000457        260        211        263        164        245
+## ENSG00000000460         60         55         40         35         78</code></pre>
+<pre class="r"><code># assay defaults to the first assay if no i is given
+assay(se)[1:5, 1:5]</code></pre>
+<pre><code>##                 SRR1039508 SRR1039509 SRR1039512 SRR1039513 SRR1039516
+## ENSG00000000003        679        448        873        408       1138
+## ENSG00000000005          0          0          0          0          0
+## ENSG00000000419        467        515        621        365        587
+## ENSG00000000457        260        211        263        164        245
+## ENSG00000000460         60         55         40         35         78</code></pre>
+<pre class="r"><code>assay(se, 1)[1:5, 1:5]</code></pre>
+<pre><code>##                 SRR1039508 SRR1039509 SRR1039512 SRR1039513 SRR1039516
+## ENSG00000000003        679        448        873        408       1138
+## ENSG00000000005          0          0          0          0          0
+## ENSG00000000419        467        515        621        365        587
+## ENSG00000000457        260        211        263        164        245
+## ENSG00000000460         60         55         40         35         78</code></pre>
+</div>
+<div id="range-based-operations" class="section level2">
+<h2><span class="header-section-number">4.3</span> Range-based operations</h2>
+<ul>
+<li><code>subsetByOverlaps()</code> <code>SummarizedExperiment</code> objects support all of the <code>findOverlaps()</code> methods and associated functions. This includes <code>subsetByOverlaps()</code>, which makes it easy to subset a <code>SummarizedExperiment</code> object by an interval.</li>
+</ul>
+<pre class="r"><code># Subset for only rows which are in the interval 100,000 to 110,000 of
+# chromosome 1
+roi <- GRanges(seqnames="1", ranges=100000:1100000)
+subsetByOverlaps(se, roi)</code></pre>
+<pre><code>## class: RangedSummarizedExperiment 
+## dim: 74 8 
+## metadata(2): '' formula
+## assays(1): counts
+## rownames(74): ENSG00000131591 ENSG00000177757 ... ENSG00000272512
+##   ENSG00000273443
+## rowData names(0):
+## colnames(8): SRR1039508 SRR1039509 ... SRR1039520 SRR1039521
+## colData names(9): SampleName cell ... Sample BioSample</code></pre>
+</div>
+</div>
+<div id="advanced-extending-rangedsummarizedexperiment" class="section level1">
+<h1><span class="header-section-number">5</span> Advanced: Extending <code>RangedSummarizedExperiment</code></h1>
+<p>For representing and manipulating data in their own package, Bioconductor developers are encouraged to re-use existing classes defined in other packages like the <code>RangedSummarizedExperiment</code> or <code>GRanges</code> containers defined in the <code>SummarizedExperiment</code> or <code>GenomicRanges</code> infrastructure packages, respectively. Many Bioconductor packages are designed around these basic containers, that is, they define functions that take and/or return a <code> [...]
+<p>However, sometimes re-using the <code>RangedSummarizedExperiment</code> class as-is does not satisfy the needs of the package and the developer makes the choice to extend the class in order to accomodate the special needs of the package and/or the specificities of the data that it deals with. For example the <code>DESeq2</code> package defines the <code>DESeqDataSet</code> class which extends <code>RangedSummarizedExperiment</code> to add the <code>design</code> and <code>dispersionFu [...]
+<p>The following subsections describe in a nutshell how the developer would typically proceed for extending <code>RangedSummarizedExperiment</code> in his/her own package. Some familiarity with the S4 class system is required. Readers not familiar with the S4 class system are encouraged to consult the vignette <code>A quick overview of the S4 class system</code> located in the <code>S4Vectors</code> package for the basics of implementing and extending S4 classes.</p>
+<p>The approach described below allows the developer to extend <code>RangedSummarizedExperiment</code> it in a way that remains agnostic of its internals. Keeping this separation between the responsibilities of the owners of the parent and child classes facilitate maintenance in the long run. In particular, the implementation of the child class won’t be affected by changes in the internals of the parent class.</p>
+<div id="depend-on-and-import-the-summarizedexperiment-package" class="section level2">
+<h2><span class="header-section-number">5.1</span> Depend on, and import, the <code>SummarizedExperiment</code> package</h2>
+<p>Add <code>SummarizedExperiment</code> to the Depends field of the DESCRIPTION file of the package and the <code>import(SummarizedExperiment)</code> directive to its NAMESPACE file.</p>
+</div>
+<div id="define-and-export-the-rangedsummarizedexperiment-subclass" class="section level2">
+<h2><span class="header-section-number">5.2</span> Define and export the <code>RangedSummarizedExperiment</code> subclass</h2>
+<p>Define the subclass with something like:</p>
+<pre class="r"><code>setClass("MyRSESubclass",
+    contains="RangedSummarizedExperiment",
+    representation=representation(
+        slot1="integer",
+        slot2="function"
+        ## ... maybe more ...
+    )
+)</code></pre>
+<p>Export it by adding the <code>exportClasses(MyRSESubclass)</code> directive to the NAMESPACE file.</p>
+</div>
+<div id="construct-myrsesubclass-instances" class="section level2">
+<h2><span class="header-section-number">5.3</span> Construct <code>MyRSESubclass</code> instances</h2>
+<p>When calling <code>new()</code> for constructing a <code>MyRSESubclass</code> instance, specify only the MyRSESubclass-specific slots: <code>new("MyRSESubclass", rse, slot1=value1, slot2=value2)</code>, where <code>rse</code> is a <code>RangedSummarizedExperiment</code> object.</p>
+<p>Providing a <code>MyRSESubclass</code> constructor function (named as the class itself) is recommended.</p>
+</div>
+<div id="define-a-validity-method" class="section level2">
+<h2><span class="header-section-number">5.4</span> Define a validity method</h2>
+<p>The validity method for <code>MyRSESubclass</code> only needs to take care of what’s new in <code>MyRSESubclass</code> with respect to <code>RangedSummarizedExperiment</code>, that is, of the aspects of <code>MyRSESubclass</code> objects that are not already covered by the validity method for <code>RangedSummarizedExperiment</code> objects. This is because calling <code>validObject()</code> on a <code>MyRSESubclass</code> object automatically validates it as a <code>RangedSummarizedEx [...]
+</div>
+<div id="use-the-rangedsummarizedexperiment-accessors-on-myrsesubclass-objects" class="section level2">
+<h2><span class="header-section-number">5.5</span> Use the <code>RangedSummarizedExperiment</code> accessors on <code>MyRSESubclass</code> objects</h2>
+<p>Like any user of <code>RangedSummarizedExperiment</code> objects, the developer of <code>MyRSESubclass</code> should always use the <code>RangedSummarizedExperiment</code> accessors to access the <code>RangedSummarizedExperiment</code>-specific parts of his/her <code>MyRSESubclass</code> objects.</p>
+</div>
+<div id="use-callnextmethod" class="section level2">
+<h2><span class="header-section-number">5.6</span> Use <code>callNextMethod</code></h2>
+<p>In case some of the methods defined for <code>RangedSummarizedExperiment</code> objects need to be overwritten, the new methods should call <code>callNextMethod</code> internally.</p>
+</div>
+</div>
+
+
+
+<!-- dynamically load mathjax for compatibility with self-contained -->
+<script>
+  (function () {
+    var script = document.createElement("script");
+    script.type = "text/javascript";
+    script.src  = "https://mathjax.rstudio.com/latest/MathJax.js?config=TeX-AMS-MML_HTMLorMML";
+    document.getElementsByTagName("head")[0].appendChild(script);
+  })();
+</script>
+
+</body>
+</html>
diff --git a/inst/extdata/kallisto/abundance.h5 b/inst/extdata/kallisto/abundance.h5
new file mode 100644
index 0000000..b7ee6be
Binary files /dev/null and b/inst/extdata/kallisto/abundance.h5 differ
diff --git a/inst/extdata/kallisto/abundance.tsv b/inst/extdata/kallisto/abundance.tsv
new file mode 100644
index 0000000..ff68341
--- /dev/null
+++ b/inst/extdata/kallisto/abundance.tsv
@@ -0,0 +1,2859 @@
+target_id	length	eff_length	est_counts	tpm
+uc010tkp.2	981	832	0	0
+uc001vuz.1	31578	31429	0	0
+uc001vva.1	31578	31429	0	0
+uc010ahc.1	31578	31429	0	0
+uc021rmy.1	41	41	0	0
+uc021rmz.1	30	30	0	0
+uc001vvd.3	32	32	0	0
+uc021rna.1	28	28	0	0
+uc021rnb.1	37	37	0	0
+uc021rnd.1	37	37	0	0
+uc021rne.1	41	41	0	0
+uc021rnf.1	30	30	0	0
+uc010tkq.2	32	32	0	0
+uc021rng.1	28	28	0	0
+uc021rnh.1	28	28	0	0
+uc001vvf.2	40	40	0	0
+uc001vvh.3	32	32	0	0
+uc001vvi.3	34158	34009	0	0
+uc001vvk.1	34259	34110	0	0
+uc001vvl.4	42885	42736	2206.9	476.273
+uc021rnj.1	69004	68855	444.552	59.5463
+uc001vvn.3	1387	1238	0	0
+uc001vvt.3	10204	10055	0	0
+uc001vwd.3	4044	3895	0	0
+uc010tkt.2	942	793	0	0
+uc010tku.2	942	793	0	0
+uc010tkv.2	924	775	0	0
+uc001vwh.1	945	796	0	0
+uc010tkw.2	972	823	0	0
+uc001vwj.2	1076	927	0	0
+uc010tkx.2	1047	898	0	0
+uc001vwn.1	939	790	0	0
+uc001vwo.1	1032	883	0	0
+uc010tla.2	927	778	0	0
+uc010tlb.2	1038	889	0	0
+uc010tlc.2	993	844	0	0
+uc010tld.2	975	826	0	0
+uc001vxb.1	14290	14141	247.606	161.491
+uc001vxc.3	14291	14142	231.649	151.073
+uc001vxd.3	14291	14142	231.649	151.073
+uc010tle.2	3310	3161	268.096	782.228
+uc001vxg.3	2642	2493	1428	5282.92
+uc001vxh.3	2642	2493	1428	5282.92
+uc001vxi.3	2642	2493	1428	5282.92
+uc021rnr.1	2642	2493	1428	5282.92
+uc010ahm.2	3822	3673	0	0
+uc010ahn.3	5785	5636	1559.52	2552.04
+uc001vxo.4	8628	8479	0	0
+uc021rns.1	3246	3097	3840.48	11437
+uc001vxp.2	5619	5470	0	0
+uc010tlj.2	651	502	0	0
+uc001vxu.1	16736	16587	0	0
+uc021rnw.1	82	82	0	0
+uc021rnz.1	82	82	0	0
+uc021rob.1	72	72	0	0
+uc021roh.1	73	73	0	0
+uc021roi.1	89	89	0	0
+uc021roj.1	72	72	0	0
+uc001vxw.4	10010	9861	28.5268	26.6809
+uc001vxx.4	16423	16274	17.2901	9.79877
+uc001vxy.4	16423	16274	17.2901	9.79877
+uc001vxz.3	5414	5265	0	0
+uc001vya.3	11827	11678	0	0
+uc021rok.1	444	295	50.5198	1579.45
+uc021rol.1	444	295	14.3732	449.364
+uc001vyc.3	2441	2292	0	0
+uc021rom.1	444	295	0	0
+uc001vyd.3	2522	2373	0	0
+uc021ron.1	444	295	0	0
+uc001vye.4	1417	1268	0	0
+uc021roo.1	453	304	0	0
+uc001vyj.3	946	797	0	0
+uc021roq.1	483	334	0	0
+uc021ror.1	836	687	0	0
+uc010aif.2	37095	36946	1	0.249632
+uc001vyl.1	965	816	0	0
+uc021ros.1	486	337	0	0
+uc010tlk.2	3311	3162	0	0
+uc001vym.3	7225	7076	1092.63	1424.14
+uc001vyn.3	7230	7081	561.687	731.589
+uc001vyo.3	7230	7081	561.687	731.589
+uc001vyr.3	2621	2472	1	3.73095
+uc001vys.4	2621	2472	1	3.73095
+uc001vzh.3	1988	1839	0	0
+uc001vzk.4	2008	1859	0	0
+uc001vzl.2	2009	1860	0	0
+uc021rou.1	471	322	0	0
+uc010tlm.2	465	316	0	0
+uc001vzn.1	5186	5037	0	0
+uc001vzo.1	16539	16390	0	0
+uc001vzp.3	19510	19361	111	52.8765
+uc010aij.3	19510	19361	111	52.8765
+uc010tln.2	19510	19361	111	52.8765
+uc010tlo.2	4788	4639	61.4477	122.166
+uc001wag.3	63325	63176	3.51495	0.513139
+uc001wah.3	33748	33599	0	0
+uc001wai.3	33748	33599	0	0
+uc001waj.1	3812	3663	0	0
+uc001wak.3	30043	29894	0	0
+uc010aim.3	29943	29794	0	0
+uc001wal.3	29448	29299	0	0
+uc001wam.3	27378	27229	0.485047	0.164293
+uc001way.3	19037	18888	318.807	155.671
+uc001waz.3	21985	21836	5.57481e-06	2.35464e-06
+uc010tlu.2	21985	21836	5.57481e-06	2.35464e-06
+uc010tlv.2	11575	11426	1450.81	1171.07
+uc001wbi.2	711	562	0	0
+uc001wbk.3	698	549	0	0
+uc010tmd.2	942	793	0	0
+uc021roz.1	520	371	0	0
+uc001wbn.3	561	412	0	0
+uc021rpa.1	255349	255200	1.00344	0.0362641
+uc021rpb.1	159	10	0	0
+uc001wbp.2	810	661	0	0
+uc010aip.1	13535	13386	0	0
+uc021rpc.1	244	95	0	0
+uc010aiq.1	592	443	0	0
+uc001wbt.1	585	436	0	0
+uc021rpd.1	309	160	0	0
+uc010air.1	594	445	0	0
+uc001wbv.3	117	117	0	0
+uc010ais.1	588	439	0	0
+uc001wbw.2	725946	725797	0	0
+uc001wbx.2	635	486	0	0
+uc001wbz.1	681	532	0	0
+uc010ait.1	681	532	0	0
+uc021rpe.1	219473	219324	0	0
+uc001wcb.2	647	498	0	0
+uc001wcc.3	3761	3612	0	0
+uc021rpf.1	276	127	0	0
+uc021rpg.1	396747	396598	0	0
+uc021rph.1	648	499	0	0
+uc010aiv.1	389875	389726	0	0
+uc021rpi.1	245	96	0	0
+uc021rpj.2	172012	171863	0	0
+uc010aiy.2	577	428	0	0
+uc001wch.2	578	429	0	0
+uc010aiz.2	588	439	0	0
+uc021rpk.1	248	99	0	0
+uc001wck.3	527	378	0	0
+uc021rpl.1	538598	538449	0	0
+uc021rpm.1	594	445	0	0
+uc010tmm.2	87855	87706	0	0
+uc010tmo.2	508219	508070	0	0
+uc001wcq.3	8442	8293	0	0
+uc001wco.3	558067	557918	0	0
+uc010ajd.1	5004	4855	0	0
+uc010aje.1	550895	550746	0	0
+uc001wcp.2	550824	550675	0	0
+uc001wcr.1	550597	550448	0	0
+uc001wcs.1	550597	550448	0	0
+uc010ajf.1	550597	550448	0	0
+uc001wct.4	5069	4920	0	0
+uc001wcu.4	476295	476146	0	0
+uc021rpn.1	476295	476146	0	0
+uc021rpo.1	554	405	0	0
+uc021rpp.1	277	128	0	0
+uc001wcx.4	500362	500213	0	0
+uc001wcy.3	562	413	0	0
+uc021rpq.1	256	107	0	0
+uc001wcz.2	570	421	0	0
+uc021rpr.1	461793	461644	0	0
+uc010tmp.1	595	446	0	0
+uc001wdb.2	1375	1226	0	0
+uc010ajh.1	686	537	0	0
+uc010aji.1	915	766	0	0
+uc001wdd.2	360721	360572	0	0
+uc010ajj.1	398119	397970	0	0
+uc001wde.1	424764	424615	0	0
+uc010tmq.2	24	24	0	0
+uc010ajk.2	400760	400611	0	0
+uc001wdg.1	400414	400265	0	0
+uc021rpt.1	400414	400265	0	0
+uc001wdh.2	582	433	0	0
+uc010ajl.1	368898	368749	0	0
+uc001wdi.2	587	438	0	0
+uc021rpu.1	124	124	0	0
+uc010ajm.2	776	627	0	0
+uc021rpv.1	311404	311255	0	0
+uc001wdk.2	612	463	0	0
+uc010ajn.1	605	456	0	0
+uc010ajo.1	326632	326483	0	0
+uc010ajp.1	322108	321959	0	0
+uc021rpw.1	305227	305078	0	0
+uc001wdn.3	622	473	0	0
+uc021rpx.1	170	21	0	0
+uc010tmr.2	213989	213840	4.31181	0.185968
+uc010ajq.1	563	414	0.991652	22.0916
+uc001wdq.2	459	310	0	0
+uc001wdr.2	555	406	0	0
+uc001wdu.2	562	413	0	0
+uc001wdv.4	129626	129477	0	0
+uc001wdw.2	7594	7445	0	0
+uc001wdx.4	15832	15683	0	0
+uc010ajs.1	7958	7809	0	0
+uc001wdz.4	7266	7117	0	0
+uc010tms.2	8153	8004	0	0
+uc010ajt.3	4741	4592	0	0
+uc010aju.1	5548	5399	0	0
+uc001wea.4	6824	6675	0	0
+uc001wec.3	78798	78649	0	0
+uc001wed.1	1569	1420	0	0
+uc001wee.4	73237	73088	0	0
+uc021rpy.1	58	58	0	0
+uc010tmt.1	68202	68053	0	0
+uc010ajv.1	65443	65294	0	0
+uc001weg.2	68325	68176	0	0
+uc001weh.1	33370	33221	0	0
+uc001wei.3	65884	65735	0	0
+uc001wej.3	63516	63367	0	0
+uc001wek.3	62821	62672	0	0
+uc001wel.3	62624	62475	0	0
+uc001wem.4	61619	61470	0	0
+uc001wen.2	54882	54733	0	0
+uc001weo.2	56700	56551	0	0
+uc010ajw.2	65	65	0	0
+uc001wep.3	57287	57138	0	0
+uc001weq.3	56202	56053	0	0
+uc021rpz.1	66	66	0	0
+uc021rqa.1	50847	50698	0	0
+uc021rqb.1	55214	55065	0	0
+uc001wet.3	52964	52815	0	0
+uc021rqc.1	64	64	0	0
+uc001weu.3	52422	52273	0	0
+uc021rqd.1	112	112	0	0
+uc001wev.3	50509	50360	0	0
+uc021rqe.1	59	59	0	0
+uc021rqf.1	62	62	0	0
+uc010tmv.2	43983	43834	0	0
+uc021rqg.1	55	55	0	0
+uc001wez.2	42616	42467	0	0
+uc001wfa.2	276	127	0	0
+uc010ajx.1	43975	43826	0	0
+uc001wfb.2	40068	39919	0	0
+uc021rqh.1	39133	38984	0	0
+uc001wfd.1	42015	41866	0	0
+uc001wfe.3	42875	42726	0	0
+uc001wfg.2	38390	38241	0	0
+uc021rqi.1	56	56	0	0
+uc001wfh.1	39653	39504	0	0
+uc001wfi.2	34879	34730	0	0
+uc001wfj.1	2388	2239	0	0
+uc001wfk.3	38176	38027	0	0
+uc001wfl.3	30236	30087	0	0
+uc010ajy.2	36496	36347	0	0
+uc001wfn.3	35888	35739	0	0
+uc021rqj.1	61	61	0	0
+uc001wfo.2	2030	1881	0	0
+uc001wfp.3	33671	33522	0	0
+uc021rqk.1	63	63	0	0
+uc001wfq.2	30661	30512	0	0
+uc001wfr.1	27327	27178	0	0
+uc010ajz.1	27312	27163	0	0
+uc021rql.1	65	65	0	0
+uc001wfs.2	25699	25550	0	0
+uc001wft.2	27035	26886	0	0
+uc001wfu.3	21541	21392	0	0
+uc001wfv.2	26312	26163	0	0
+uc001wfw.1	24990	24841	0	0
+uc021rqm.1	62	62	0	0
+uc001wfx.3	25282	25133	0	0
+uc001wfy.2	19228	19079	0	0
+uc001wfz.1	18143	17994	0	0
+uc021rqn.1	137	137	0	0
+uc001wgb.3	1618	1469	0	0
+uc001wgc.2	15829	15680	0	0
+uc021rqo.1	15270	15121	0	0
+uc001wge.4	18649	18500	0	0
+uc021rqp.1	18640	18491	0	0
+uc021rqq.1	59	59	0	0
+uc010tmw.2	15103	14954	0	0
+uc010tmx.2	16006	15857	0	0
+uc010tmy.2	10150	10001	0	0
+uc010akb.2	131	131	0	0
+uc021rqr.1	6820	6671	0	0
+uc001wgh.3	13080	12931	0	0
+uc001wgi.2	7530	7381	0	0
+uc001wgj.1	8463	8314	0	0
+uc001wgk.3	8978	8829	4	4.17846
+uc010tmz.1	6015	5866	0	0
+uc010tna.1	11670	11521	0	0
+uc001wgm.3	14119	13970	458	302.369
+uc010tnb.2	14119	13970	458	302.369
+uc010tnc.2	2101	1952	0	0
+uc001wgn.2	5268	5119	2092.11	3769.36
+uc001wgp.2	5038	4889	4605.89	8688.82
+uc001wgw.4	5155	5006	63	116.069
+uc001wgx.4	5155	5006	63	116.069
+uc001wgy.4	5155	5006	63	116.069
+uc001wgz.4	5155	5006	63	116.069
+uc001wha.4	5155	5006	63	116.069
+uc001whb.4	5155	5006	63	116.069
+uc001whc.3	11011	10862	12	10.1892
+uc001whd.3	6332	6183	1144.79	1707.63
+uc001whe.3	5323	5174	4258.21	7590.47
+uc010tnd.1	3621	3472	5.7037	15.1511
+uc001whf.1	4458	4309	10.2963	22.038
+uc021rqs.1	73	73	0	0
+uc021rqt.1	73	73	0	0
+uc010ake.1	1894	1745	0	0
+uc001wiu.3	4983	4834	523.402	998.611
+uc021rqv.1	423	274	420.333	14148.5
+uc001wjg.4	4998	4849	0	0
+uc001wjh.4	19424	19275	92.5751	44.2963
+uc021rqx.1	4900	4751	0	0
+uc001wji.4	4622	4473	1570.52	3238.26
+uc001wjj.3	5149	5000	0	0
+uc001wjk.3	5998	5849	1678.91	2647.36
+uc001wjq.3	3595	3446	0	0
+uc001wjr.3	3543	3394	0	0
+uc001wjs.3	2965	2816	0	0
+uc001wjt.3	2965	2816	0	0
+uc001wju.3	2965	2816	0	0
+uc010akm.3	2965	2816	0	0
+uc010akn.3	2965	2816	0	0
+uc010ako.3	2965	2816	0	0
+uc001wjy.3	8505	8356	396	437.084
+uc001wjz.3	8505	8356	396	437.084
+uc031qnt.1	47822	47673	3.45502e-08	6.68415e-09
+uc001wkb.5	46772	46623	44.6402	8.83068
+uc001wkg.5	3593	3444	50.9575	136.462
+uc001wkh.5	3593	3444	50.9575	136.462
+uc010akr.4	3593	3444	50.9575	136.462
+uc031qnu.1	3593	3444	50.9575	136.462
+uc031qnv.1	3593	3444	50.9575	136.462
+uc031qnw.1	3593	3444	50.9575	136.462
+uc031qnx.1	3593	3444	50.9575	136.462
+uc001wko.1	6977	6828	0	0
+uc010aku.1	13105	12956	0	0
+uc001wkt.4	9276	9127	28	28.2942
+uc001wku.4	9276	9127	28	28.2942
+uc010akv.3	9276	9127	28	28.2942
+uc010aky.2	14368	14219	0	0
+uc001wla.3	15524	15375	287.815	172.65
+uc001wlb.3	15524	15375	287.815	172.65
+uc010akz.3	15524	15375	287.815	172.65
+uc001wlc.4	52653	52504	0	0
+uc001wld.4	52653	52504	0	0
+uc001wle.4	52653	52504	0	0
+uc001wlf.3	14450	14301	0	0
+uc021rra.1	20817	20668	0	0
+uc021rrb.1	36535	36386	0	0
+uc021rrc.1	36535	36386	0	0
+uc031qnz.1	36535	36386	0	0
+uc021rrd.2	81504	81355	0	0
+uc021rre.1	36394	36245	0	0
+uc010tnt.2	15937	15788	0	0
+uc001wli.4	17591	17442	392.464	207.525
+uc021rrf.1	59994	59845	18.7647	2.89188
+uc010alb.3	11377	11228	0	0
+uc031qoa.1	44369	44220	0	0
+uc031qob.1	44369	44220	0	0
+uc031qoc.1	44369	44220	0	0
+uc010tnu.3	14966	14817	1.08237	0.673726
+uc021rrg.2	14966	14817	1.08237	0.673726
+uc021rrh.2	14966	14817	1.08237	0.673726
+uc021rri.2	14966	14817	1.08237	0.673726
+uc021rrj.2	14966	14817	1.08237	0.673726
+uc001wlj.2	17732	17583	24	12.5888
+uc001wlk.2	7810	7661	0	0
+uc010tnv.2	7251	7102	0	0
+uc001wlm.3	7139	6990	0	0
+uc001wll.3	6561	6412	0	0
+uc001wls.3	6288	6139	0	0
+uc001wlt.3	9857	9708	159.883	151.894
+uc010tnw.2	9857	9708	159.883	151.894
+uc010ald.2	5991	5842	455.204	718.641
+uc010ale.2	5991	5842	455.204	718.641
+uc001wlu.4	9818	9669	1458.9	1391.59
+uc010tnx.2	9818	9669	1458.9	1391.59
+uc001wlv.3	10546	10397	127.911	113.466
+uc001wlw.3	10466	10317	160.775	143.725
+uc001wly.3	10466	10317	160.775	143.725
+uc001wlz.3	10466	10317	160.775	143.725
+uc001wmc.3	9960	9811	328.859	309.146
+uc010tny.2	9960	9811	328.859	309.146
+uc001wma.4	9958	9809	398.488	374.678
+uc001wmb.4	9958	9809	398.488	374.678
+uc001wmf.2	1384	1235	18	134.423
+uc001wmg.3	2799	2650	1165	4054.6
+uc001wmh.3	2799	2650	1165	4054.6
+uc031qod.1	994	845	0	0
+uc001wml.1	14452	14303	238.071	153.514
+uc001wmm.1	8063	7914	663.049	772.711
+uc001wmn.1	13889	13740	0.29702	0.199373
+uc010alg.1	13363	13214	453.745	316.698
+uc001wmo.1	10338	10189	0	0
+uc001wmp.3	15435	15286	0	0
+uc010alh.1	5736	5587	0	0
+uc001wmq.3	6046	5897	231.055	361.37
+uc010alj.3	3600	3451	142.784	381.594
+uc001wmr.3	8230	8081	25	28.5327
+uc001wms.3	8230	8081	25	28.5327
+uc001wne.3	2552	2403	0.00215404	0.00826739
+uc001wnf.3	2552	2403	0.00215404	0.00826739
+uc001wng.3	2529	2380	18.5273	71.7966
+uc001wnh.3	2529	2380	18.5273	71.7966
+uc001wnq.1	1392	1243	135.511	1005.47
+uc001wnu.2	6798	6649	97.4192	135.131
+uc001wnr.3	6800	6651	73.3847	101.762
+uc001wns.3	6800	6651	73.3847	101.762
+uc001wnv.3	6800	6651	73.3847	101.762
+uc010alk.2	6343	6194	1.91645e-05	2.8536e-05
+uc001wnw.3	6345	6196	1.41391e-05	2.10463e-05
+uc001wnx.3	6345	6196	1.41391e-05	2.10463e-05
+uc010all.3	6345	6196	1.41391e-05	2.10463e-05
+uc010toe.1	6021	5872	784.916	1232.83
+uc021rro.1	27626	27477	41.6206	13.9703
+uc001wol.1	5277	5128	766.849	1379.21
+uc001wom.1	2114	1965	368.151	1727.95
+uc001wor.3	1903	1754	21.5515	113.322
+uc010alo.3	1903	1754	21.5515	113.322
+uc021rrp.1	1077	928	5.98646e-08	5.94963e-07
+uc001wos.3	6538	6389	465.599	672.12
+uc010alp.3	4930	4781	122.749	236.792
+uc001wou.3	3337	3188	6.31818	18.2785
+uc021rrq.1	1059	910	96.5165	978.2
+uc010alr.3	12666	12517	0	0
+uc010tok.2	12666	12517	0	0
+uc010tol.2	12666	12517	0	0
+uc010als.2	7207	7058	27.2048	35.5494
+uc010tom.2	12345	12196	0	0
+uc010ton.2	12345	12196	0	0
+uc010too.2	12345	12196	0	0
+uc010alt.3	12096	11947	0	0
+uc010top.2	12096	11947	0	0
+uc010toq.2	12096	11947	0	0
+uc010alu.3	6688	6539	4.2658	6.01667
+uc001wpc.3	11585	11436	0	0
+uc010tor.2	11585	11436	0	0
+uc010tos.2	10509	10360	9.5391e-08	8.4921e-08
+uc010alv.3	10452	10303	1.72422e-05	1.54346e-05
+uc010tot.2	10452	10303	1.72422e-05	1.54346e-05
+uc010tou.2	10452	10303	1.72422e-05	1.54346e-05
+uc010tov.2	10452	10303	1.72422e-05	1.54346e-05
+uc010tow.2	10452	10303	1.72422e-05	1.54346e-05
+uc010tox.2	10452	10303	1.72422e-05	1.54346e-05
+uc001wpd.3	6790	6641	0.142797	0.198314
+uc010toy.2	6790	6641	0.142797	0.198314
+uc010toz.2	6790	6641	0.142797	0.198314
+uc010tpa.2	5910	5761	23.0504	36.9019
+uc010tpb.2	5910	5761	23.0504	36.9019
+uc001wpf.4	20503	20354	62	28.0937
+uc010tpc.2	12056	11907	0	0
+uc001wph.4	11407	11258	335.685	275.004
+uc010alw.3	11388	11239	1648	1352.38
+uc001wpo.1	59226	59077	3.00936	0.469811
+uc021rrs.1	84	84	0	0
+uc001wqc.3	27049	26900	0	0
+uc021rrt.1	27049	26900	0	0
+uc021rru.1	22	22	0	0
+uc001wqe.4	3206	3057	0	0
+uc010tpd.3	5857	5708	0	0
+uc001wqf.3	22091	21942	0	0
+uc021rrw.1	103	103	0	0
+uc010tpe.1	48947	48798	86.567	16.3613
+uc001wqk.2	60718	60569	8.95726	1.36393
+uc010tpf.1	60718	60569	8.95726	1.36393
+uc001wql.1	8539	8390	44.5185	48.938
+uc010amd.2	93724	93575	106.103	10.4577
+uc001wqm.2	113574	113425	34.9286	2.84014
+uc001wqn.2	113574	113425	34.9286	2.84014
+uc010amf.2	113574	113425	34.9286	2.84014
+uc010tpg.2	113574	113425	34.9286	2.84014
+uc010tph.2	113574	113425	34.9286	2.84014
+uc010tpi.2	113509	113360	59.9367	4.87641
+uc001wqp.2	16082	15933	0	0
+uc001wqr.2	16082	15933	0	0
+uc001wqq.4	20521	20372	2.97625	1.34742
+uc001wqt.1	10165	10016	0	0
+uc021rry.1	71345	71196	0.727641	0.0942604
+uc001wqw.4	60333	60184	0	0
+uc001wqx.4	60333	60184	0	0
+uc010amh.3	60333	60184	0	0
+uc001wqy.4	70981	70832	90.969	11.8449
+uc021rrz.1	69808	69659	0	0
+uc001wri.3	32126	31977	52.9042	15.2588
+uc001wrk.4	299839	299690	82.169	2.52874
+uc010amj.3	299839	299690	82.169	2.52874
+uc010tpl.2	283308	283159	0	0
+uc021rsb.1	146655	146506	193.157	12.1597
+uc001wrl.3	82746	82597	11.0243	1.23099
+uc001wrm.3	82440	82291	363.741	40.7669
+uc001wrn.3	82440	82291	363.741	40.7669
+uc001wro.3	82440	82291	363.741	40.7669
+uc001wrp.3	82440	82291	363.741	40.7669
+uc021rsd.1	79	79	0	0
+uc010aml.3	405341	405192	0	0
+uc001wrq.3	503790	503641	95.1424	1.74229
+uc021rse.1	21	21	0	0
+uc001wrr.3	1481	1332	0	0
+uc001wrs.3	864924	864775	1.00032	0.0106685
+uc001wrt.3	864924	864775	1.00032	0.0106685
+uc001wru.3	864924	864775	1.00032	0.0106685
+uc001wrv.3	864924	864775	1.00032	0.0106685
+uc001wrw.3	465861	465712	0	0
+uc010tpo.2	575	426	24	519.6
+uc001wso.3	46670	46521	448.667	88.9493
+uc010tpp.2	46670	46521	448.667	88.9493
+uc010tpq.2	46670	46521	448.667	88.9493
+uc001wsp.3	38477	38328	342.987	82.5332
+uc001wsq.3	36980	36831	4.33396	1.08527
+uc001wsv.1	11051	10902	0	0
+uc001wsy.2	151971	151822	90.1724	5.47781
+uc001wsz.2	151971	151822	90.1724	5.47781
+uc010tps.2	151971	151822	90.1724	5.47781
+uc001wta.4	195156	195007	1145.01	54.1537
+uc001wtc.2	151740	151591	0.192828	0.0117318
+uc031qof.1	151740	151591	0.192828	0.0117318
+uc001wtd.3	25109	24960	237.222	87.6552
+uc010tpt.2	25109	24960	237.222	87.6552
+uc010tpu.2	25026	24877	0	0
+uc001wth.1	3013	2864	2	6.44058
+uc010tpx.1	37563	37414	0	0
+uc001wtl.3	45573	45424	149.245	30.3027
+uc031qog.1	94862	94713	0	0
+uc001wtp.3	1207	1058	0	0
+uc001wtw.1	3202	3053	6.04315	18.2559
+uc001wty.4	20239	20090	376.762	172.964
+uc010amq.3	11814	11665	29.238	23.1169
+uc021rsh.2	1768	1619	25.8915	147.496
+uc010amr.2	309872	309723	0	0
+uc001wub.4	348144	347995	0	0
+uc001wuc.3	353347	353198	25.4194	0.663767
+uc001wud.3	353347	353198	25.4194	0.663767
+uc001wue.3	353347	353198	25.4194	0.663767
+uc010ams.3	353347	353198	25.4194	0.663767
+uc010amt.3	353347	353198	25.4194	0.663767
+uc001wug.3	430192	430043	46.7684	1.00302
+uc001wuh.3	70073	69924	0	0
+uc001wui.3	47186	47037	0	0
+uc001wuj.3	47186	47037	0	0
+uc001wul.1	5065	4916	0	0
+uc021rsi.1	1176	1027	0	0
+uc001wuq.3	22690	22541	36.5	14.9344
+uc001wur.3	22690	22541	36.5	14.9344
+uc001wus.3	22690	22541	36.5	14.9344
+uc010amx.3	22690	22541	36.5	14.9344
+uc001wuw.4	8036	7887	2835	3315.19
+uc010amy.2	14283	14134	0	0
+uc001wux.3	19451	19302	0	0
+uc010tqe.1	80755	80606	0	0
+uc001wuy.4	85922	85773	0.000589264	6.33618e-05
+uc001wuz.4	85922	85773	0.000589264	6.33618e-05
+uc001wva.4	84896	84747	49.3689	5.37275
+uc001wvb.4	84896	84747	49.3689	5.37275
+uc001wvc.4	84896	84747	49.3689	5.37275
+uc001wve.1	41914	41765	0	0
+uc001wvf.4	84070	83921	0.781455	0.0858818
+uc001wvg.4	84070	83921	0.781455	0.0858818
+uc001wvh.4	84070	83921	0.781455	0.0858818
+uc001wvi.4	84070	83921	0.781455	0.0858818
+uc010amz.3	84070	83921	0.781455	0.0858818
+uc001wvj.4	74968	74819	0	0
+uc001wvl.1	21155	21006	2	0.878121
+uc021rsk.1	129	129	0	0
+uc001wvm.3	296989	296840	0	0
+uc010ana.3	205123	204974	0	0
+uc001wvo.3	9954	9805	0	0
+uc001wvp.1	6843	6694	2	2.75557
+uc010anb.1	35192	35043	49.1454	12.9345
+uc001wvu.3	45931	45782	28.9872	5.83955
+uc001wvv.3	112219	112070	56.3551	4.6378
+uc001wvw.3	112219	112070	56.3551	4.6378
+uc010anc.3	112219	112070	56.3551	4.6378
+uc001wvy.4	31503	31354	140.639	41.3696
+uc001wvz.4	31503	31354	140.639	41.3696
+uc010and.3	31503	31354	140.639	41.3696
+uc001wwa.1	5865	5716	128.082	206.664
+uc010ane.3	99	99	0	0
+uc001wwc.2	31491	31342	38.1056	11.2132
+uc001wwd.4	64958	64809	119.825	17.0522
+uc010anf.3	64958	64809	119.825	17.0522
+uc001wwe.4	46194	46045	0	0
+uc010ang.3	25820	25671	0.244448	0.0878237
+uc031qoi.1	437743	437594	0	0
+uc031qoj.1	437743	437594	0	0
+uc031qok.1	30543	30394	0.5	0.151722
+uc031qol.1	30543	30394	0.5	0.151722
+uc021rsl.1	124	124	0	0
+uc021rsp.1	301	152	1635.81	99256.3
+uc001wwn.3	15976	15827	198.91	115.912
+uc001wwo.3	15976	15827	198.91	115.912
+uc001wwp.3	15976	15827	198.91	115.912
+uc010ank.3	15976	15827	198.91	115.912
+uc001wwr.3	2711	2562	864.866	3113.42
+uc001www.3	60048	59899	0	0
+uc010tqg.2	60048	59899	0	0
+uc010tqh.2	60048	59899	0	0
+uc001wwx.3	15070	14921	1141.75	705.734
+uc001wxg.4	4037	3888	504.144	1195.9
+uc021rsu.1	528	379	927.856	22579.2
+uc001wxv.3	10697	10548	34.202	29.9054
+uc001wxw.2	13900	13751	0	0
+uc001wxx.2	13900	13751	0	0
+uc021rsv.1	13900	13751	0	0
+uc010ant.2	16325	16176	261.795	149.265
+uc001wyd.4	99985	99836	25.9382	2.39618
+uc001wye.4	73042	72893	2.03226	0.257135
+uc001wyf.4	73042	72893	2.03226	0.257135
+uc021rsw.1	73042	72893	2.03226	0.257135
+uc021rsx.1	72940	72791	0	0
+uc021rsz.1	88	88	0	0
+uc001wyq.3	32811	32662	5.5	1.55306
+uc001wyr.3	32811	32662	5.5	1.55306
+uc001wys.3	32811	32662	5.5	1.55306
+uc010any.3	32811	32662	5.5	1.55306
+uc010tqr.1	5684	5535	243.104	405.081
+uc001wza.4	17487	17338	309.948	164.876
+uc010aoa.3	17487	17338	309.948	164.876
+uc021rta.1	32165	32016	0	0
+uc001wzb.4	241606	241457	15.6332	0.597138
+uc021rtb.1	104	104	0	0
+uc001wzc.3	78869	78720	3.40818	0.399305
+uc001wzd.3	78869	78720	3.40818	0.399305
+uc001wze.3	32614	32465	17.1028	4.8587
+uc001wzf.3	17081	16932	0	0
+uc001wzg.3	13444	13295	43.9841	30.5123
+uc021rtd.1	107	107	0	0
+uc001wzh.3	122567	122418	0	0
+uc010aoc.2	106993	106844	0	0
+uc001wzi.3	109497	109348	0	0
+uc001wzj.3	109497	109348	0	0
+uc021rte.1	109497	109348	0	0
+uc001wzk.3	92209	92060	0	0
+uc010aod.3	15193	15044	851	521.716
+uc001wzq.3	9012	8863	0	0
+uc001wzr.3	14307	14158	0	0
+uc001wzt.4	84566	84417	51.6517	5.64316
+uc001wzu.4	84566	84417	51.6517	5.64316
+uc010tqv.2	3158	3009	40.297	123.515
+uc010tqw.2	11511	11362	7.4003e-05	6.00706e-05
+uc010tqx.2	20821	20672	80.4001	35.8709
+uc001wzy.3	6499	6350	21.3314	30.9823
+uc001xaa.3	44823	44674	172.722	35.6583
+uc010tqy.2	44823	44674	172.722	35.6583
+uc001xap.3	23262	23113	11.7964	4.70716
+uc001xar.3	23262	23113	11.7964	4.70716
+uc010aoi.1	8896	8747	0	0
+uc010aoj.2	20323	20174	417.838	191.022
+uc010tra.1	27968	27819	0	0
+uc001xay.3	28748	28599	80	25.7992
+uc001xba.3	136260	136111	0	0
+uc001xbb.4	225704	225555	86.8278	3.55037
+uc001xbc.3	225704	225555	86.8278	3.55037
+uc001xbe.3	15875	15726	133.892	78.5246
+uc001xbf.2	47153	47004	0	0
+uc001xbg.2	38528	38379	797.452	191.637
+uc021rtg.1	116	116	0	0
+uc001xbo.3	22363	22214	152.563	63.3417
+uc001xbp.3	22363	22214	152.563	63.3417
+uc021rti.1	1323	1174	189.874	1491.65
+uc001xbq.1	18551	18402	2472.1	1238.99
+uc001xbr.3	16214	16065	803.5	461.289
+uc021rtj.1	16214	16065	803.5	461.289
+uc001xbu.3	82309	82160	186.876	20.9779
+uc010aoo.3	81458	81309	0	0
+uc021rtk.1	2136	1987	1243.06	5769.79
+uc001xbv.3	75927	75778	705.591	85.8771
+uc001xcb.3	104378	104229	1080.7	95.6282
+uc001xcc.3	104378	104229	1080.7	95.6282
+uc001xcd.3	104378	104229	1080.7	95.6282
+uc001xce.3	104378	104229	1080.7	95.6282
+uc001xcf.2	104378	104229	1080.7	95.6282
+uc010trb.2	104378	104229	1080.7	95.6282
+uc010aoq.3	40310	40161	0	0
+uc010trc.2	23311	23162	0	0
+uc001xcg.3	21242	21093	386.754	169.108
+uc031qoq.1	2520	2371	265.023	1030.91
+uc010aos.3	1473	1324	0	0
+uc001xch.3	182939	182790	2	0.100913
+uc001xci.3	36959	36810	0	0
+uc001xcj.3	69895	69746	2.65968	0.351704
+uc001xck.3	34105	33956	12.9509	3.51763
+uc010aot.1	36472	36323	66.6641	16.9269
+uc001xcl.1	55160	55011	0	0
+uc001xcm.3	69722	69573	27.596	3.65825
+uc001xcn.3	69722	69573	27.596	3.65825
+uc010trf.3	69722	69573	27.596	3.65825
+uc001xco.3	34064	33915	169.016	45.9626
+uc021rtn.1	108612	108463	0	0
+uc001xcr.3	117650	117501	0	0
+uc001xcu.4	6570	6421	88.4826	127.093
+uc001xcv.3	21192	21043	43.169	18.9205
+uc010tri.2	21192	21043	43.169	18.9205
+uc010trj.2	21192	21043	43.169	18.9205
+uc001xcx.4	22196	22047	143.667	60.1
+uc010aow.3	22196	22047	143.667	60.1
+uc010trk.2	22196	22047	143.667	60.1
+uc021rtq.1	75	75	0	0
+uc001xdf.3	35521	35372	314.384	81.9725
+uc021rtr.1	22602	22453	0	0
+uc010apc.3	22005	21856	0	0
+uc010trp.2	22005	21856	0	0
+uc001xdj.2	27205	27056	432.286	147.359
+uc001xdk.2	27205	27056	432.286	147.359
+uc021rtt.1	27205	27056	432.286	147.359
+uc010apf.1	7609	7460	47.5832	58.8279
+uc001xdo.3	75230	75081	71.8495	8.82595
+uc001xdp.3	75230	75081	71.8495	8.82595
+uc001xdq.3	75230	75081	71.8495	8.82595
+uc010apg.1	33920	33771	0	0
+uc001xdr.1	12776	12627	15	10.9562
+uc010trq.1	12776	12627	15	10.9562
+uc001xdt.4	121447	121298	100.376	7.63209
+uc001xdu.4	121447	121298	100.376	7.63209
+uc010trr.2	121447	121298	100.376	7.63209
+uc010trs.2	121447	121298	100.376	7.63209
+uc001xdv.4	120840	120691	4.34165e-06	3.31778e-07
+uc010trt.2	97533	97384	0	0
+uc010tru.1	45658	45509	106.363	21.5555
+uc010trv.2	14253	14104	0	0
+uc001xdw.3	10282	10133	0	0
+uc001xdx.3	10282	10133	0	0
+uc010trw.2	9484	9335	0	0
+uc001xdy.4	77501	77352	3.26972	0.389859
+uc001xea.2	182743	182594	2.05284e-06	1.0369e-07
+uc001xeb.1	141957	141808	0	0
+uc031qou.1	107965	107816	200.687	17.1674
+uc001xec.2	16241	16092	83.0466	47.597
+uc001xef.4	20921	20772	126.474	56.1555
+uc001xeg.4	20921	20772	126.474	56.1555
+uc001xeh.4	20921	20772	126.474	56.1555
+uc010try.2	20921	20772	126.474	56.1555
+uc001xei.4	20795	20646	0	0
+uc001xej.4	18170	18021	633.954	324.449
+uc001xeo.3	2173	2024	0	0
+uc001xep.1	143847	143698	0	0
+uc001xer.4	42904	42755	590.145	127.303
+uc001xeq.2	77223	77074	397.809	47.603
+uc010apm.3	16486	16337	332.18	187.529
+uc001xew.4	53336	53187	15.2137	2.63813
+uc010apn.3	53336	53187	15.2137	2.63813
+uc001xex.4	39307	39158	0	0
+uc001xey.4	49840	49691	685.573	127.246
+uc021rtx.1	20	20	0	0
+uc001xfa.4	2588	2439	0	0
+uc010apq.2	74275	74126	210.243	26.1589
+uc001xfd.3	233940	233791	80.6165	3.18027
+uc001xfe.3	233940	233791	80.6165	3.18027
+uc001xfg.2	71872	71723	35.1688	4.52238
+uc001xfh.2	102620	102471	82.7443	7.4474
+uc001xfi.3	102620	102471	82.7443	7.4474
+uc001xfj.1	71760	71611	0	0
+uc001xfk.3	102508	102359	2.92502e-06	2.63554e-07
+uc010trz.2	102487	102338	0	0
+uc010tsa.2	363412	363263	2.70631	0.0687107
+uc001xfn.3	229184	229035	1.24292	0.0500506
+uc010tsb.2	73814	73665	3.5035	0.43864
+uc001xfo.3	7619	7470	7.54854	9.31987
+uc021rtz.1	84174	84025	3	0.329291
+uc010tsc.1	31418	31269	0	0
+uc031qow.1	38885	38736	0	0
+uc001xfq.2	52859	52710	1404.82	245.807
+uc001xfr.2	52859	52710	1404.82	245.807
+uc001xfs.2	52859	52710	1404.82	245.807
+uc021rua.1	50638	50489	85.1349	15.5517
+uc021rub.1	178	29	121.632	38682.9
+uc001xft.3	34072	33923	96	26.1003
+uc010tsd.1	94190	94041	1.00017	0.0980898
+uc001xfu.1	105887	105738	0	0
+uc010tse.1	22370	22221	0	0
+uc010apt.2	16829	16680	0	0
+uc001xgb.2	89129	88980	0	0
+uc021rue.1	142	142	0	0
+uc021rug.1	20	20	0	0
+uc001xgk.3	107936	107787	0	0
+uc001xgl.3	373485	373336	70.9809	1.75351
+uc001xgm.3	373485	373336	70.9809	1.75351
+uc021ruh.1	228904	228755	2119.25	85.4434
+uc010apw.1	22679	22530	26.9433	11.0295
+uc010apx.1	26393	26244	0	0
+uc010apy.3	150835	150686	502.8	30.7744
+uc010apz.1	35476	35327	445.666	116.351
+uc001xgn.3	86509	86360	567.845	60.6436
+uc021rui.1	86509	86360	567.845	60.6436
+uc001xgo.3	85109	84960	11.6585	1.2656
+uc001xgp.3	4225	4076	175.774	397.729
+uc010aqa.3	64378	64229	687.361	98.701
+uc001xgq.3	58955	58806	0	0
+uc001xgr.3	17126	16977	1002.82	544.792
+uc001xgs.3	12309	12160	606.902	460.312
+uc010tsi.2	12309	12160	606.902	460.312
+uc001xgt.3	10496	10347	3.22203e-07	2.87199e-07
+uc010aqe.2	52407	52258	0	0
+uc001xhb.3	71967	71818	1779.38	228.508
+uc010aqf.3	71967	71818	1779.38	228.508
+uc001xhd.4	9005	8856	0	0
+uc021ruk.1	1284	1135	0	0
+uc001xhh.4	20967	20818	54.5308	24.1585
+uc010aqg.3	20378	20229	7.24818e-07	3.30463e-07
+uc001xhi.2	29117	28968	33.8188	10.7673
+uc021rul.1	2142	1993	788.453	3648.68
+uc021rum.1	2405	2256	3.36622	13.7617
+uc001xhj.3	7332	7183	0	0
+uc001xhk.4	2769	2620	1220	4294.64
+uc001xhl.1	39477	39328	0	0
+uc001xhm.1	3271	3122	6	17.725
+uc001xhn.1	39868	39719	67.8649	15.7585
+uc001xho.1	39868	39719	67.8649	15.7585
+uc001xhp.2	16750	16601	2001.38	1111.89
+uc010aqh.1	13701	13552	353.512	240.585
+uc001xhq.1	6284	6135	583.378	877.007
+uc001xhv.3	21006	20857	177.536	78.5057
+uc001xhw.2	21006	20857	177.536	78.5057
+uc021rup.1	21006	20857	177.536	78.5057
+uc010tsj.2	30231	30082	30.63	9.39093
+uc010tsk.2	30231	30082	30.63	9.39093
+uc010tsl.2	148295	148146	138.22	8.60498
+uc010tsm.2	148295	148146	138.22	8.60498
+uc001xia.3	75867	75718	204.546	24.9149
+uc001xib.3	2045	1896	23.3402	113.536
+uc001xid.3	47073	46924	424.066	83.3502
+uc010tso.2	47073	46924	424.066	83.3502
+uc021ruu.1	82	82	0	0
+uc021ruv.1	4394	4245	0	0
+uc001xin.3	333530	333381	45.3027	1.25329
+uc001xio.3	333530	333381	45.3027	1.25329
+uc001xir.4	333530	333381	45.3027	1.25329
+uc010tsp.2	333530	333381	45.3027	1.25329
+uc001xip.3	331392	331243	94.1374	2.6211
+uc001xiq.3	331392	331243	94.1374	2.6211
+uc021rux.1	85	85	0	0
+uc001xiu.3	12163	12014	0.666667	0.511787
+uc001xiv.3	12163	12014	0.666667	0.511787
+uc010tsq.1	12163	12014	0.666667	0.511787
+uc001xiw.3	551609	551460	0	0
+uc001xix.3	674401	674252	11.4176	0.156179
+uc001xiy.3	674401	674252	11.4176	0.156179
+uc010tss.2	674401	674252	11.4176	0.156179
+uc010tst.2	674401	674252	11.4176	0.156179
+uc010tsu.2	358563	358414	258.772	6.65887
+uc001xiz.3	11161	11012	209.607	175.552
+uc010tsv.2	11161	11012	209.607	175.552
+uc001xja.2	39158	39009	1.39333	0.329425
+uc010aqn.2	39158	39009	1.39333	0.329425
+uc001xjb.2	38692	38543	0	0
+uc001xjc.4	94767	94618	599.808	58.4664
+uc001xjd.4	94767	94618	599.808	58.4664
+uc021rva.1	105	105	0	0
+uc001xjg.3	26200	26051	2238	792.325
+uc001xjl.1	56248	56099	183.638	30.1908
+uc010tsw.1	20506	20357	458.246	207.612
+uc001xjm.1	5132	4983	0	0
+uc001xjn.1	19071	18922	154.203	75.1613
+uc010tsx.1	11005	10856	0	0
+uc001xjo.1	8001	7852	0	0
+uc001xjp.1	8013	7864	0	0
+uc031qpe.1	3128	2979	31.1404	96.4099
+uc001xjs.3	31858	31709	1214.36	353.21
+uc001xjz.4	32566	32417	15	4.26762
+uc001xjy.2	3105	2956	0	0
+uc010aqq.3	67548	67399	0	0
+uc001xkd.3	658315	658166	0.224502	0.00314595
+uc010aqr.3	658315	658166	0.224502	0.00314595
+uc001xke.3	678103	677954	97.5041	1.32645
+uc001xkf.2	776243	776094	429.571	5.10491
+uc001xkg.2	910440	910291	108.54	1.09971
+uc031qpf.1	7782	7633	0	0
+uc001xkt.3	52544	52395	111.697	19.6617
+uc001xku.3	52544	52395	111.697	19.6617
+uc001xkv.3	52544	52395	111.697	19.6617
+uc001xkw.3	52544	52395	111.697	19.6617
+uc001xky.3	52544	52395	111.697	19.6617
+uc001xkx.3	52255	52106	188.92	33.4394
+uc010aqt.3	52255	52106	188.92	33.4394
+uc010tte.2	52255	52106	188.92	33.4394
+uc001xla.2	91780	91631	2	0.201305
+uc001xlb.2	94510	94361	0	0
+uc010aqu.2	94510	94361	0	0
+uc021rvg.1	64012	63863	1194.08	172.446
+uc021rvh.1	64012	63863	1194.08	172.446
+uc001xld.4	30809	30660	0	0
+uc001xle.3	63723	63574	76.1324	11.0448
+uc001xlf.4	63723	63574	76.1324	11.0448
+uc001xlg.4	63723	63574	76.1324	11.0448
+uc010aqx.3	63723	63574	76.1324	11.0448
+uc021rvi.1	1855	1706	898.032	4854.9
+uc001xli.2	18937	18788	0	0
+uc010ttf.1	43745	43596	6.02492	1.2746
+uc001xlk.3	103552	103403	1040.24	92.783
+uc010aqz.3	103552	103403	1040.24	92.783
+uc001xll.3	45104	44955	4.58519	0.940692
+uc021rvj.1	3723	3574	1.19025	3.0715
+uc001xln.1	3429	3280	593.107	1667.73
+uc001xlo.3	4894	4745	844.044	1640.58
+uc001xlp.3	4889	4740	391.459	761.686
+uc001xls.2	152970	152821	15783.4	952.542
+uc001xlt.2	152970	152821	15783.4	952.542
+uc021rvp.1	197	48	0	0
+uc001xmd.3	7749	7600	7.90738	9.59593
+uc021rvq.1	2169	2020	46.8013	213.685
+uc001xmi.2	33574	33425	8	2.20743
+uc001xmn.4	105416	105267	2.83044e-08	2.47987e-09
+uc001xmo.2	207978	207829	1867.26	82.864
+uc010are.1	207978	207829	1867.26	82.864
+uc010arf.1	102383	102234	560.893	50.6002
+uc001xmp.2	13400	13251	1656.19	1152.73
+uc001xmq.3	71	71	0	0
+uc021rvt.1	271	122	0	0
+uc001xmr.1	107902	107753	4.24439	0.36329
+uc010ttl.2	1843	1694	0	0
+uc001xms.3	210092	209943	6.91898	0.303954
+uc001xmt.3	210092	209943	6.91898	0.303954
+uc001xmu.3	153123	152974	109.77	6.6181
+uc001xmv.3	151833	151684	1693.34	102.961
+uc010ttm.2	141170	141021	0	0
+uc021rvu.1	889	740	30	373.902
+uc021rvv.1	634422	634273	0.000213722	3.1077e-06
+uc001xna.4	634083	633934	0.00035364	5.145e-06
+uc010ttn.2	634083	633934	0.00035364	5.145e-06
+uc021rvw.1	629677	629528	0.252275	0.00369595
+uc021rvx.1	629677	629528	0.252275	0.00369595
+uc021rvy.1	629677	629528	0.252275	0.00369595
+uc021rvz.1	629677	629528	0.252275	0.00369595
+uc001xmx.4	633453	633304	0.000902257	1.31397e-05
+uc001xmy.4	633453	633304	0.000902257	1.31397e-05
+uc010tto.2	633453	633304	0.000902257	1.31397e-05
+uc021rwa.1	633453	633304	0.000902257	1.31397e-05
+uc021rwb.1	633453	633304	0.000902257	1.31397e-05
+uc010arg.3	53091	52942	0	0
+uc010ttp.1	128560	128411	0	0
+uc021rwc.1	98061	97912	0	0
+uc001xng.3	33318	33169	20.1421	5.60067
+uc001xnh.3	33318	33169	20.1421	5.60067
+uc001xni.3	33318	33169	20.1421	5.60067
+uc001xnj.3	33318	33169	20.1421	5.60067
+uc010ttr.2	33318	33169	20.1421	5.60067
+uc010tts.2	33318	33169	20.1421	5.60067
+uc010ttt.2	33318	33169	20.1421	5.60067
+uc001xnk.3	20144	19995	154.469	71.2505
+uc021rwd.1	72	72	0	0
+uc001xnn.4	42664	42515	0	0
+uc001xno.3	62856	62707	676.608	99.5151
+uc010ttu.2	62856	62707	676.608	99.5151
+uc001xnp.3	49742	49593	510.175	94.8782
+uc001xnq.4	37770	37621	0	0
+uc001xnr.3	87257	87108	211.501	22.3935
+uc001xnv.3	87257	87108	211.501	22.3935
+uc010ark.3	86875	86726	0	0
+uc001xnt.1	69278	69129	0	0
+uc001xnu.3	75725	75576	1900.29	231.902
+uc001xnw.4	37143	36994	17.4582	4.35248
+uc010arl.3	37143	36994	17.4582	4.35248
+uc010ttw.2	37143	36994	17.4582	4.35248
+uc010ttx.2	35024	34875	363.033	96.0063
+uc010tty.2	35024	34875	363.033	96.0063
+uc010arm.3	13931	13782	272.907	182.629
+uc010arn.3	12242	12093	51.6523	39.3934
+uc001xoi.1	16908	16759	0	0
+uc001xok.1	2462	2313	801.815	3197.17
+uc001xol.1	6571	6422	265.188	380.847
+uc010tuc.3	38435	38286	48.2888	11.6325
+uc001xom.4	8039	7890	275.163	321.648
+uc001xon.5	6600	6451	1340.17	1916.02
+uc001xoo.3	4061	3912	4	9.43037
+uc001xop.3	3045	2896	1	3.1847
+uc001xoq.4	58854	58705	35.3583	5.555
+uc010aru.3	58854	58705	35.3583	5.555
+uc010arv.3	58854	58705	35.3583	5.555
+uc021rwi.1	73	73	0	0
+uc001xow.3	33635	33486	174.16	47.9681
+uc010tue.2	33622	33473	251.075	69.1793
+uc001xox.3	33548	33399	1.58532	0.437775
+uc001xoy.2	80318	80169	216.52	24.9092
+uc010ary.2	18469	18320	249.153	125.432
+uc010tuf.2	36908	36759	0	0
+uc001xoz.2	45674	45525	0.000139878	2.83379e-05
+uc001xpa.2	45674	45525	0.000139878	2.83379e-05
+uc001xpb.2	45674	45525	0.000139878	2.83379e-05
+uc010arz.2	45674	45525	0.000139878	2.83379e-05
+uc010tug.2	45674	45525	0.000139878	2.83379e-05
+uc010tuh.2	45674	45525	0.000139878	2.83379e-05
+uc010tui.2	45674	45525	0.000139878	2.83379e-05
+uc010tuj.2	34203	34054	686.984	186.057
+uc001xpe.3	13132	12983	31.044	22.0532
+uc010tuk.2	13177	13028	78.1999	55.36
+uc010tul.2	8827	8678	0	0
+uc010tum.2	8827	8678	0	0
+uc010tun.2	9230	9081	0	0
+uc001xph.3	12859	12710	483.201	350.631
+uc010tup.2	46738	46589	9.77002	1.9341
+uc001xpm.1	51067	50918	136.108	24.6536
+uc001xpp.2	115462	115313	107.422	8.59175
+uc010asb.2	115455	115306	113.744	9.09794
+uc001xpq.3	23267	23118	0	0
+uc001xpw.4	11546	11397	1.20769	0.977313
+uc021rwl.1	2109	1960	0.792307	3.72825
+uc001xpz.3	1849	1700	79.5	431.306
+uc031qph.1	1849	1700	79.5	431.306
+uc021rwn.1	95	95	0	0
+uc001xqe.1	1797	1648	0	0
+uc001xqf.1	22397	22248	0	0
+uc001xqh.3	23541	23392	347.851	137.149
+uc001xqi.3	23649	23500	4.53853	1.78121
+uc001xqj.4	73945	73796	1807.11	225.85
+uc001xql.4	55977	55828	751.315	124.119
+uc001xqm.1	12732	12583	30.5298	22.3773
+uc001xqo.1	3327	3178	0	0
+uc010tuu.2	10001	9852	0	0
+uc001xqu.2	19343	19194	0	0
+uc001xqs.3	21857	21708	1018.94	432.908
+uc001xqt.2	21857	21708	1018.94	432.908
+uc001xqv.2	21857	21708	1018.94	432.908
+uc010tuw.1	21857	21708	1018.94	432.908
+uc001xrc.2	6683	6534	1480	2089.06
+uc001xrh.3	8501	8352	10.5	11.5949
+uc001xri.3	8501	8352	10.5	11.5949
+uc001xrn.3	3457	3308	122	340.143
+uc010tva.2	3457	3308	122	340.143
+uc010asi.3	2592	2443	0	0
+uc001xrp.3	2005	1856	0	0
+uc010asj.3	44896	44747	165.394	34.0896
+uc010tvb.2	44485	44336	39.5442	8.2261
+uc010tvc.2	44345	44196	777.966	162.347
+uc001xrq.3	40568	40419	291.096	66.423
+uc001xrr.3	24551	24402	0	0
+uc001xrs.2	69573	69424	989	131.388
+uc010tvd.1	42708	42559	0	0
+uc001xrv.3	23790	23641	95.142	37.1171
+uc001xrw.2	49192	49043	86.8429	16.3315
+uc010ask.2	226100	225951	1.08252e-07	4.41864e-09
+uc001xrx.3	293875	293726	0	0
+uc001xry.1	84343	84194	487.841	53.4398
+uc001xrz.3	142213	142064	15.3902	0.999147
+uc001xsa.3	171936	171787	366.467	19.6749
+uc001xse.3	73539	73390	0	0
+uc001xsf.2	96688	96539	0	0
+uc010asl.1	96688	96539	0	0
+uc001xsg.2	97997	97848	53.2223	5.0166
+uc010asm.1	97997	97848	53.2223	5.0166
+uc010tve.3	98321	98172	240.278	22.5732
+uc031qpj.1	98321	98172	240.278	22.5732
+uc001xsh.3	50876	50727	157.471	28.6305
+uc001xsi.3	50876	50727	157.471	28.6305
+uc001xsj.1	24769	24620	20.3174	7.61112
+uc001xsk.1	23045	22896	178.329	71.8341
+uc001xsl.3	48438	48289	190.933	36.4671
+uc001xsm.3	3106	2957	82.9494	258.72
+uc001xsn.1	2557	2408	63.5286	243.322
+uc001xso.3	130491	130342	0	0
+uc001xsr.3	130491	130342	0	0
+uc001xsq.1	90969	90820	2.00194	0.2033
+uc001xss.3	11746	11597	0	0
+uc001xst.2	21129	20980	4.88327	2.14671
+uc001xsx.2	43921	43772	0	0
+uc010asn.1	43921	43772	0	0
+uc010aso.1	18089	17940	0	0
+uc010tvg.1	27027	26878	0	0
+uc001xsw.2	43919	43770	0	0
+uc010tvh.1	26273	26124	1	0.353043
+uc001xtc.1	19052	18903	284.413	138.767
+uc001xtd.3	19053	18904	270.587	132.014
+uc001xtf.2	77737	77588	2.5	0.297176
+uc010asq.1	77737	77588	2.5	0.297176
+uc021rws.1	73	73	0	0
+uc001xtj.3	10711	10562	207.098	180.841
+uc001xtk.3	10711	10562	207.098	180.841
+uc010ass.3	10711	10562	207.098	180.841
+uc001xtl.4	1167	1018	0	0
+uc001xtm.3	10235	10086	198.706	181.702
+uc021rwt.1	1803	1654	3.44972	19.2361
+uc001xtq.1	13826	13677	4.55028	3.06842
+uc010tvk.1	10697	10548	0	0
+uc001xtw.3	11443	11294	5481	4475.89
+uc001xue.5	9528	9379	238.5	234.531
+uc031qpl.1	9528	9379	238.5	234.531
+uc031qpm.1	9528	9379	238.5	234.531
+uc031qpn.1	9528	9379	238.5	234.531
+uc001xuh.2	8913	8764	2.01115	2.11646
+uc021rwv.1	8913	8764	2.01115	2.11646
+uc021rww.1	279	130	0	0
+uc010tvo.1	125879	125730	0.272617	0.0199978
+uc001xui.3	133872	133723	97.9517	6.75575
+uc001xuj.3	133872	133723	97.9517	6.75575
+uc001xuk.1	65552	65403	17.5535	2.47534
+uc001xul.3	10723	10574	273.272	238.354
+uc001xum.2	1697918	1.69777e+06	10.8045	0.058694
+uc001xun.4	1464560	1.46441e+06	0	0
+uc010asv.1	373368	373219	0	0
+uc021rwz.1	84	84	0	0
+uc001xup.3	588952	588803	85.4866	1.33905
+uc001xuq.3	588952	588803	85.4866	1.33905
+uc001xur.5	588952	588803	85.4866	1.33905
+uc010asw.4	588952	588803	85.4866	1.33905
+uc001xuw.1	244049	243900	7.83489	0.296271
+uc001xvb.1	152960	152811	0	0
+uc001xvc.3	153426	153277	0	0
+uc010tvs.2	153426	153277	0	0
+uc001xvd.1	190778	190629	1.00005	0.048384
+uc001xvj.3	1239	1090	4	33.8455
+uc021rxc.1	74	74	0	0
+uc021rxd.1	83	83	0	0
+uc021rxe.1	324	175	0	0
+uc031qpp.1	26196	26047	0	0
+uc031qpq.1	26160	26011	0	0
+uc001xvr.3	97783	97634	0	0
+uc010atd.3	97699	97550	0	0
+uc021rxf.1	1983	1834	0	0
+uc001xvs.3	16978	16829	0	0
+uc001xvv.3	9688	9539	0	0
+uc021rxh.1	1014	865	0	0
+uc001xvw.3	62795	62646	4.0047	0.589582
+uc001xwj.3	35	35	0	0
+uc021ryc.1	59	59	0	0
+uc001xwk.3	56	56	0	0
+uc001xwl.3	55	55	0	0
+uc021ryd.1	30	30	0	0
+uc031qpz.1	31	31	0	0
+uc031qqa.1	29	29	0	0
+uc021rye.1	33	33	0	0
+uc001xwq.3	53063	52914	4.23166	0.737577
+uc001xwr.3	53063	52914	4.23166	0.737577
+uc001xws.3	27802	27653	0	0
+uc001xwt.3	22535	22386	0	0
+uc001xwu.3	9108	8959	9.56706	9.84887
+uc001xww.3	50601	50452	173.129	31.6489
+uc001xwx.3	50601	50452	173.129	31.6489
+uc010twd.2	50601	50452	173.129	31.6489
+uc010twe.2	50601	50452	173.129	31.6489
+uc010twf.2	50601	50452	173.129	31.6489
+uc001xwy.3	50163	50014	0	0
+uc010twg.2	40932	40783	0	0
+uc001xxa.3	37670	37521	0	0
+uc001xxb.3	19124	18975	321.216	156.129
+uc001xxc.3	19124	18975	321.216	156.129
+uc010atg.1	28904	28755	0	0
+uc001xxi.3	53418	53269	67.1429	11.625
+uc001xxj.3	53418	53269	67.1429	11.625
+uc001xxk.3	53418	53269	67.1429	11.625
+uc001xxl.3	53418	53269	67.1429	11.625
+uc010ath.3	53418	53269	67.1429	11.625
+uc010ati.3	53418	53269	67.1429	11.625
+uc010atj.3	53418	53269	67.1429	11.625
+uc021ryh.1	73	73	0	0
+uc001xxq.3	2440	2291	21.5023	86.5622
+uc001xxr.3	1261	1112	0	0
+uc021ryi.1	290	141	0	0
+uc010atm.3	89826	89677	0.00983	0.00101097
+uc001xxy.3	88863	88714	256.748	26.692
+uc001xxz.3	88863	88714	256.748	26.692
+uc001xya.3	88863	88714	256.748	26.692
+uc010atn.3	88863	88714	256.748	26.692
+uc001xyb.3	88200	88051	4.71866e-05	4.94256e-06
+uc001xyd.1	48481	48332	0	0
+uc001xye.1	124088	123939	1	0.0744149
+uc001xyf.3	16073	15924	6.12226	3.54591
+uc001xyg.3	16073	15924	6.12226	3.54591
+uc001xyh.3	13472	13323	415.135	287.379
+uc001xyl.2	11293	11144	2306.5	1908.89
+uc010atq.2	11293	11144	2306.5	1908.89
+uc001xym.2	10011	9862	0	0
+uc021ryj.1	3676	3527	0	0
+uc001xyq.3	6249	6100	0	0
+uc001xyr.1	2042	1893	0	0
+uc010atu.3	53709	53560	0	0
+uc010atv.2	75158	75009	0	0
+uc001xyy.2	82462	82313	0	0
+uc001xyv.2	111347	111198	37.341	3.09711
+uc001xyw.2	111347	111198	37.341	3.09711
+uc001xyx.2	111347	111198	37.341	3.09711
+uc001xyz.2	111347	111198	37.341	3.09711
+uc001xza.2	111347	111198	37.341	3.09711
+uc001xzb.2	111347	111198	37.341	3.09711
+uc001xzc.2	111347	111198	37.341	3.09711
+uc010twj.1	55567	55418	0	0
+uc001xze.2	110725	110576	4.81838e-08	4.01891e-09
+uc010atw.3	127	127	0	0
+uc021ryn.1	26	26	0	0
+uc001yah.2	42246	42097	1959	429.191
+uc001yai.3	178901	178752	0	0
+uc010twm.2	178289	178140	0	0
+uc001yak.3	177674	177525	0	0
+uc010auj.3	62147	61998	0	0
+uc010twn.2	58117	57968	0	0
+uc001yan.3	48716	48567	0	0
+uc001yap.3	175210	175061	0	0
+uc010auk.3	175210	175061	0	0
+uc001yaq.3	112756	112607	0	0
+uc001yar.1	9841	9692	0	0
+uc001yas.1	33985	33836	0	0
+uc001yaz.1	45655	45506	472.446	95.7527
+uc001yba.1	6838	6689	4.55447	6.27978
+uc001ybb.1	2083	1934	0	0
+uc001ybc.4	12194	12045	2.5	1.91426
+uc001ybd.4	12194	12045	2.5	1.91426
+uc001ybi.3	4682	4533	0	0
+uc001ybk.4	2136	1987	122.189	567.156
+uc010auo.3	2057	1908	0	0
+uc021sax.1	396	247	86.8109	3241.49
+uc001ybm.4	22161	22012	330.858	138.628
+uc001ybn.4	22161	22012	330.858	138.628
+uc010auq.3	19400	19251	460.285	220.516
+uc001ybs.1	374125	373976	27.0093	0.666098
+uc001ybt.1	1164	1015	0	0
+uc001ybu.1	63274	63125	0	0
+uc001ybv.1	229786	229637	0	0
+uc001ybz.2	10715	10566	0	0
+uc021say.1	10715	10566	0	0
+uc021saz.1	2267	2118	0	0
+uc010aus.2	2266	2117	0	0
+uc001yca.2	2224	2075	0	0
+uc031qqc.1	879	730	0	0
+uc001ycf.3	10283	10134	0	0
+uc001ycg.1	11568	11419	0	0
+uc010twp.2	14400	14251	0	0
+uc001ych.4	13034	12885	0	0
+uc001yci.3	22553	22404	92	37.873
+uc001yck.3	21422	21273	256.5	111.206
+uc001ycl.3	21422	21273	256.5	111.206
+uc001ycm.1	4148	3999	0	0
+uc001ycn.1	5201	5052	0	0
+uc021sba.1	5955	5806	19	30.1817
+uc001ycr.3	53534	53385	0	0
+uc001ycs.1	105424	105275	0	0
+uc010avd.3	8465	8316	0	0
+uc001ydk.3	8461	8312	0	0
+uc001ydl.3	8402	8253	0	0
+uc010ave.3	9399	9250	0	0
+uc001ydm.3	11752	11603	0	0
+uc001ydn.1	6497	6348	0	0
+uc001ydo.4	31996	31847	0	0
+uc010avf.1	2788	2639	0	0
+uc001ydp.3	11757	11608	0	0
+uc001ydr.3	11757	11608	0	0
+uc021sbb.2	11757	11608	0	0
+uc001yds.3	11663	11514	0	0
+uc010avg.3	11663	11514	0	0
+uc001ydt.3	6270	6121	0	0
+uc010twt.1	22246	22097	37.7096	15.7393
+uc001yee.1	2451	2302	4.07152	16.3124
+uc001yem.1	9733	9584	571	549.487
+uc001yen.1	5077	4928	0	0
+uc001yep.1	21063	20914	25.4757	11.2346
+uc021sbf.1	20670	20521	0	0
+uc021sbg.1	22275	22126	0	0
+uc021sbh.1	8592	8443	0	0
+uc001yet.1	10197	10048	0	0
+uc001yeu.2	16577	16428	1.7411	0.977478
+uc001yev.2	16577	16428	1.7411	0.977478
+uc001yew.3	29388	29239	0	0
+uc001yex.3	29388	29239	0	0
+uc010avj.3	29388	29239	0	0
+uc021sbi.1	29388	29239	0	0
+uc001yfa.3	6212	6063	0	0
+uc001yez.3	6227	6078	0	0
+uc001yfd.1	41297	41148	0	0
+uc001yfe.3	48800	48651	0	0
+uc001yff.4	54566	54417	2	0.338971
+uc010avl.2	39369	39220	1151.55	270.797
+uc001yfg.2	39532	39383	23.1498	5.42133
+uc010avm.1	39532	39383	23.1498	5.42133
+uc010twu.1	39532	39383	23.1498	5.42133
+uc001yfh.3	8554	8405	6.73118	7.3862
+uc021sbj.1	1062	913	1.26882	12.8173
+uc001yfj.5	23839	23690	79.8356	31.0813
+uc031qqe.1	23839	23690	79.8356	31.0813
+uc031qqf.1	23839	23690	79.8356	31.0813
+uc001yfl.4	22555	22406	17.4933	7.20071
+uc001yfm.1	7181	7032	0	0
+uc001yfn.3	97317	97168	4.0372	0.383199
+uc001yfo.3	33223	33074	0	0
+uc001yfp.3	33223	33074	0	0
+uc001yfq.3	64741	64592	479.25	68.4307
+uc001yfr.3	64741	64592	479.25	68.4307
+uc010avp.3	64741	64592	479.25	68.4307
+uc010twv.2	64741	64592	479.25	68.4307
+uc001yfs.3	3010	2861	0	0
+uc001yft.3	84268	84119	308	33.7695
+uc001yfu.3	5290	5141	0	0
+uc031qqg.1	3892	3743	0	0
+uc001yfz.2	6154	6005	0	0
+uc021sbm.1	91	91	0	0
+uc001ygi.4	30114	29965	1678.67	516.678
+uc021sbo.1	102	102	0	0
+uc001ygl.1	24132	23983	0	0
+uc010avs.3	31532	31383	0	0
+uc031qqk.1	23	23	0	0
+uc001ygn.1	29020	28871	0	0
+uc001ygo.3	42884	42735	0	0
+uc031qql.1	42598	42449	0	0
+uc001ygp.3	21305	21156	0	0
+uc010avt.1	171748	171599	0	0
+uc010tww.2	168460	168311	0	0
+uc001ygq.3	118177	118028	0	0
+uc001ygr.3	148651	148502	2	0.124213
+uc001ygs.3	148651	148502	2	0.124213
+uc001ygt.3	172423	172274	29.5475	1.58186
+uc001ygv.2	120736	120587	38.9759	2.98101
+uc001ygu.3	78823	78674	1220.48	143.076
+uc021sbp.1	99	99	0	0
+uc001ygw.1	2317	2168	346.996	1476.16
+uc001ygy.2	40270	40121	1994.75	458.548
+uc001ygz.2	2376	2227	1613	6680.08
+uc010twy.1	98	98	0	0
+uc001yhc.3	7037	6888	1	1.33898
+uc001yhd.3	7037	6888	1	1.33898
+uc010avx.3	153886	153737	45.2619	2.71533
+uc021sbq.1	5313	5164	26.7655	47.8031
+uc001yhn.3	153808	153659	3.14912e-07	1.89016e-08
+uc010avy.3	149394	149245	282.973	17.4869
+uc001yho.3	148304	148155	0	0
+uc021sbr.1	244	95	0	0
+uc001yhr.1	15477	15328	0	0
+uc001yhu.4	8263	8114	0	0
+uc001yhs.4	8266	8117	0	0
+uc021sbs.1	330	181	0	0
+uc021sbt.1	84	84	0	0
+uc021sbu.1	204	55	0	0
+uc021sbw.2	28198	28049	0	0
+uc001yhw.3	34916	34767	0	0
+uc001yhy.3	34916	34767	0	0
+uc001yhz.3	34916	34767	0	0
+uc001yib.3	34916	34767	0	0
+uc001yic.3	34916	34767	0	0
+uc001yie.3	34916	34767	0	0
+uc010avz.2	34916	34767	0	0
+uc010txb.2	34916	34767	0	0
+uc010txc.2	34916	34767	0	0
+uc010txd.2	34916	34767	0	0
+uc010txe.2	34916	34767	0	0
+uc010txf.2	34916	34767	0	0
+uc010txg.2	34916	34767	0	0
+uc010txh.2	34916	34767	0	0
+uc021sbv.1	87	87	0	0
+uc021sbx.1	30419	30270	0	0
+uc001yid.2	29603	29454	0	0
+uc021sbz.1	98	98	0	0
+uc001yif.2	2963	2814	0	0
+uc021sca.1	89	89	0	0
+uc010txi.2	93	93	0	0
+uc021scb.1	72	72	0	0
+uc021scc.1	114	114	0	0
+uc021scd.1	93	93	0	0
+uc001yig.3	97	97	0	0
+uc021sce.1	94	94	0	0
+uc010txk.1	82	82	0	0
+uc010txl.1	12199	12050	0	0
+uc021scf.1	77	77	0	0
+uc021scg.1	79	79	0	0
+uc021sch.1	58	58	0	0
+uc001yii.1	70	70	0	0
+uc001yij.3	71	71	0	0
+uc021sci.1	72	72	0	0
+uc001yil.3	74	74	0	0
+uc001yim.1	77	77	0	0
+uc001yin.3	74	74	0	0
+uc001yio.3	76	76	0	0
+uc001yiq.3	71	71	0	0
+uc001yir.3	71	71	0	0
+uc001yis.3	77	77	0	0
+uc001yit.3	74	74	0	0
+uc001yiu.3	104	104	0	0
+uc001yiv.3	69	69	0	0
+uc021scj.1	73	73	0	0
+uc001yiw.3	71	71	0	0
+uc001yix.1	76	76	0	0
+uc001yiy.1	71	71	0	0
+uc001yiz.3	71	71	0	0
+uc001yja.3	71	71	0	0
+uc001yjb.3	74	74	0	0
+uc001yjc.3	74	74	0	0
+uc001yjd.3	73	73	0	0
+uc001yje.3	74	74	0	0
+uc001yjf.1	71	71	0	0
+uc001yjg.3	69	69	0	0
+uc001yjh.3	74	74	0	0
+uc001yji.3	71	71	0	0
+uc001yjj.3	74	74	0	0
+uc021sck.1	78	78	0	0
+uc001yjk.1	71	71	0	0
+uc001yjl.3	71	71	0	0
+uc001yjm.3	71	71	0	0
+uc001yjn.3	71	71	0	0
+uc001yjo.1	71	71	0	0
+uc001yjp.1	71	71	0	0
+uc001yjq.3	71	71	0	0
+uc001yjr.3	69	69	0	0
+uc001yjs.3	71	71	0	0
+uc001yjt.1	69	69	0	0
+uc001yju.3	71	71	0	0
+uc001yjv.3	74	74	0	0
+uc021scl.1	75	75	0	0
+uc010awa.1	67	67	0	0
+uc021scm.1	96	96	0	0
+uc001yjx.1	63	63	0	0
+uc021scn.1	80	80	0	0
+uc010awb.1	61	61	0	0
+uc021sco.1	88	88	0	0
+uc001yjy.1	86	86	0	0
+uc021scp.1	88	88	0	0
+uc021scq.1	80	80	0	0
+uc021scr.1	84	84	0	0
+uc010txm.2	81	81	0	0
+uc021scs.1	78	78	0	0
+uc021sct.1	78	78	0	0
+uc021scu.1	82	82	0	0
+uc021scv.1	81	81	0	0
+uc021scw.1	77	77	0	0
+uc021scx.1	80	80	0	0
+uc010txn.1	66	66	0	0
+uc021scy.1	109	109	0	0
+uc021scz.1	80	80	0	0
+uc021sda.1	81	81	0	0
+uc021sdb.1	100	100	0	0
+uc010awc.1	68	68	0	0
+uc021sdc.1	82	82	0	0
+uc021sdd.1	85	85	0	0
+uc021sde.1	85	85	0	0
+uc010awd.3	75	75	0	0
+uc021sdf.1	84	84	0	0
+uc021sdg.1	78	78	0	0
+uc021sdh.1	79	79	0	0
+uc021sdi.1	91	91	0	0
+uc021sdj.1	97	97	0	0
+uc021sdk.1	80	80	0	0
+uc010awe.3	76	76	0	0
+uc010txo.1	73	73	0	0
+uc021sdl.1	66	66	0	0
+uc021sdm.1	73	73	0	0
+uc021sdn.1	82	82	0	0
+uc010awg.3	84	84	0	0
+uc021sdo.1	81	81	0	0
+uc021sdp.1	102	102	0	0
+uc010awh.1	69	69	0	0
+uc021sdq.1	84	84	0	0
+uc021sdr.1	79	79	0	0
+uc021sds.1	91	91	0	0
+uc010txp.1	70	70	0	0
+uc021sdt.1	80	80	0	0
+uc021sdu.1	79	79	0	0
+uc021sdv.1	78	78	0	0
+uc001yjz.2	3026	2877	0	0
+uc010awi.1	557	408	0	0
+uc021sdx.1	2102	1953	20	94.4486
+uc010awj.3	2089	1940	0	0
+uc001ykj.4	74775	74626	26.0803	3.22322
+uc001ykk.3	166194	166045	168.544	9.36173
+uc010txr.2	166194	166045	168.544	9.36173
+uc001ykl.1	1005	856	9.96308	107.346
+uc010txs.1	73214	73065	0	0
+uc010txt.2	96845	96696	0	0
+uc001ykn.3	102823	102674	0	0
+uc001yko.3	118189	118040	348.017	27.1919
+uc001ykp.3	118189	118040	348.017	27.1919
+uc001ykq.3	30465	30316	0	0
+uc001ykr.1	2194	2045	0	0
+uc001yks.2	86271	86122	59445.6	6366.1
+uc001ykt.1	8699	8550	4346.37	4688.44
+uc001ykz.3	70679	70530	0	0
+uc001yla.3	70679	70530	0	0
+uc001ylb.3	70679	70530	0	0
+uc001ylf.3	70679	70530	0	0
+uc010txu.2	70679	70530	0	0
+uc001ylc.3	75153	75004	0	0
+uc001yld.3	83822	83673	330.57	36.4372
+uc001yle.3	83822	83673	330.57	36.4372
+uc021sdy.1	2766	2617	8.32187	29.3282
+uc021sdz.1	74	74	0	0
+uc001ylo.3	25798	25649	0	0
+uc031qqo.1	23877	23728	1.60428e-06	6.23571e-07
+uc001ylp.3	23424	23275	123.362	48.883
+uc010awk.2	23424	23275	123.362	48.883
+uc001ylq.1	16383	16234	15.6066	8.86645
+uc001ylr.3	17190	17041	0	0
+uc001yls.3	11553	11404	0	0
+uc001ylt.3	8242	8093	17.8563	20.3493
+uc010txw.2	62310	62161	0	0
+uc010awl.3	102709	102560	0	0
+uc001ylw.2	139519	139370	822.558	54.4333
+uc010txx.2	139519	139370	822.558	54.4333
+uc021sed.1	83	83	0	0
+uc001ymb.4	137918	137769	1344.52	90.0088
+uc001ymc.2	134022	133873	543.654	37.4539
+uc001ymd.2	134022	133873	543.654	37.4539
+uc001yme.2	134022	133873	543.654	37.4539
+uc010txy.2	134022	133873	543.654	37.4539
+uc001ymf.1	2717	2568	27.2857	97.996
+uc001ymg.4	8187	8038	0	0
+uc001ymh.4	7921	7772	12	14.2402
+uc001ymk.3	10414	10265	40	35.9392
+uc001yml.1	3096	2947	71.9949	225.315
+uc001ymm.1	11113	10964	849.023	714.198
+uc010awo.1	11113	10964	849.023	714.198
+uc010txz.1	10435	10286	928.591	832.618
+uc010tya.1	3525	3376	1317.37	3598.92
+uc021see.1	23	23	0	0
+uc001ymq.4	11023	10874	1062.17	900.89
+uc001ymr.4	11023	10874	1062.17	900.89
+uc001ymt.4	10164	10015	0.547871	0.50454
+uc001ymu.3	10076	9927	2235.12	2076.59
+uc001ymv.1	126	126	0	0
+uc001ymw.4	118466	118317	84.0853	6.55451
+uc001ymx.4	118466	118317	84.0853	6.55451
+uc001ymy.4	118466	118317	84.0853	6.55451
+uc001ymz.4	118466	118317	84.0853	6.55451
+uc001yna.4	118466	118317	84.0853	6.55451
+uc010awp.3	118466	118317	84.0853	6.55451
+uc021sef.1	542	393	138.428	3248.61
+uc010tyb.2	38273	38124	857.891	207.54
+uc010awq.3	28837	28688	0	0
+uc001ynd.3	3962	3813	705.938	1707.53
+uc001yng.3	7902	7753	688	818.439
+uc010aws.3	7902	7753	688	818.439
+uc010tyc.2	27938	27789	170.924	56.728
+uc010tyd.1	123270	123121	93.3797	6.995
+uc010tye.1	56129	55980	0	0
+uc001ynm.1	57044	56895	63.3319	10.2664
+uc001yno.3	72364	72215	714.772	91.2868
+uc010tyf.2	72364	72215	714.772	91.2868
+uc021seh.1	10543	10394	0.455076	0.403803
+uc001ynp.1	18149	18000	0	0
+uc001ynq.1	18149	18000	0	0
+uc001ynr.1	18149	18000	0	0
+uc010awu.1	18149	18000	0	0
+uc001yns.3	25863	25714	1638.07	587.532
+uc001ynw.1	3277	3128	0	0
+uc001yoc.3	17925	17776	664.603	344.823
+uc001yod.3	17925	17776	664.603	344.823
+uc001yoe.3	2238	2089	1033.79	4564.19
+uc001yoh.1	10329	10180	2	1.81197
+uc001yom.4	124188	124039	990.873	73.6762
+uc001yon.4	82127	81978	366.83	41.2701
+uc031qqq.1	3250	3101	158.352	470.965
+uc001yoo.2	21660	21511	0	0
+uc001yoq.2	27024	26875	24	8.23627
+uc001yor.2	27024	26875	24	8.23627
+uc010tyg.2	110	110	0	0
+uc001yos.4	42176	42027	3069	673.498
+uc010tyh.1	9063	8914	0	0
+uc001yow.1	10128	9979	0	0
+uc010awy.1	2367	2218	0	0
+uc001yoy.4	15203	15054	121.003	74.1334
+uc001ypb.2	30005	29856	2158.79	666.878
+uc001ypc.2	30005	29856	2158.79	666.878
+uc010awz.1	12358	12209	1203.41	909.082
+uc001ypd.3	23114	22965	2452	984.74
+uc001ype.3	17420	17271	0	0
+uc001ypf.3	17420	17271	0	0
+uc010tyj.1	4353	4204	0.266608	0.584896
+uc001ypg.1	6521	6372	272.217	394.01
+uc001yph.3	6527	6378	1151.6	1665.27
+uc001ypi.3	6527	6378	1151.6	1665.27
+uc021sel.1	2232	2083	150.311	665.531
+uc001ypp.3	4116	3967	411.052	955.658
+uc021sem.1	1269	1120	21.948	180.736
+uc001ypq.4	2518	2369	22	85.6496
+uc001yps.3	31458	31309	2134.92	628.899
+uc010axb.4	31458	31309	2134.92	628.899
+uc001ypt.3	8727	8578	442.153	475.394
+uc001ypu.1	8387	8238	0	0
+uc010tyl.1	8387	8238	0	0
+uc001ypy.1	9240	9091	95	96.3784
+uc001ypz.1	9240	9091	95	96.3784
+uc010tym.1	9240	9091	95	96.3784
+uc010tyq.2	2552	2403	1008.62	3871.18
+uc001yqs.2	97315	97166	269.656	25.5954
+uc001yqt.3	83733	83584	891.028	98.3186
+uc001yqu.3	83733	83584	891.028	98.3186
+uc001yqw.3	15277	15128	101	61.5755
+uc001yqx.3	50872	50723	59.0234	10.7322
+uc001yqy.3	50872	50723	59.0234	10.7322
+uc021seq.1	50872	50723	59.0234	10.7322
+uc001yqz.1	22282	22133	633.359	263.923
+uc001yra.1	22282	22133	633.359	263.923
+uc001yrb.3	12451	12302	6080.21	4558.38
+uc010tyr.2	7233	7084	1.28543	1.67354
+uc031qqr.1	7233	7084	1.28543	1.67354
+uc031qqs.1	7233	7084	1.28543	1.67354
+uc001yrc.3	5987	5838	0	0
+uc001yrd.2	5396	5247	142.087	249.753
+uc031qqt.1	5396	5247	142.087	249.753
+uc031qqu.1	5396	5247	142.087	249.753
+uc031qqv.1	5396	5247	142.087	249.753
+uc001yrf.2	4312	4163	0	0
+uc001yrg.3	2925	2776	2851.8	9474.73
+uc031qqw.1	22	22	0	0
+uc001yri.4	1868	1719	2830	15183.7
+uc001yrj.3	9394	9245	0	0
+uc001yrk.3	9066	8917	184.028	190.341
+uc001yrm.3	8000	7851	281.324	330.483
+uc001yrn.3	8000	7851	281.324	330.483
+uc001yro.3	8000	7851	281.324	330.483
+uc010tys.2	7142	6993	0	0
+uc001yrp.1	3587	3438	0	0
+uc021ses.1	960	811	0.831088	9.45135
+uc001yrr.3	2463	2314	0	0
+uc001ysq.3	32551	32402	0	0
+uc001ysr.3	32551	32402	0	0
+uc001yss.3	13815	13666	0	0
+uc001yst.3	14665	14516	0	0
+uc021seu.1	698	549	0	0
+uc001ysy.2	13075	12926	763.369	544.676
+uc031qnr.1	3097	2948	0	0
+uc001vvb.3	4041	3892	0	0
+uc021rnc.1	40	40	0	0
+uc001vvg.2	40	40	0	0
+uc021rni.1	40	40	0	0
+uc001vvo.1	10225	10076	0	0
+uc001vvq.1	68973	68824	204.029	27.3413
+uc001vvr.1	45125	44976	524.761	107.609
+uc010ahe.1	45125	44976	524.761	107.609
+uc001vvs.1	34237	34088	0	0
+uc001vvu.3	1388	1239	0	0
+uc001vvv.1	5842	5693	0	0
+uc001vvw.2	34158	34009	0	0
+uc001vvx.2	32	32	0	0
+uc021rnk.1	40	40	0	0
+uc001vvz.2	40	40	0	0
+uc010tkr.2	32	32	0	0
+uc021rnl.1	41	41	0	0
+uc021rnm.1	28	28	0	0
+uc010tks.2	32	32	0	0
+uc021rnn.1	41	41	0	0
+uc001vwb.3	36319	36170	64.5	16.4467
+uc001vwc.3	36319	36170	64.5	16.4467
+uc021rno.1	1429	1280	0	0
+uc010tky.2	933	784	0	0
+uc010tkz.2	915	766	0	0
+uc001vwt.3	16853	16704	249.5	137.758
+uc001vwu.3	16853	16704	249.5	137.758
+uc001vwv.4	18006	17857	1094.33	565.208
+uc001vwx.4	21643	21494	0	0
+uc001vwy.4	21945	21796	36.8892	15.6096
+uc001vwz.4	21945	21796	36.8892	15.6096
+uc021rnp.2	21945	21796	36.8892	15.6096
+uc010ahh.2	17828	17679	0	0
+uc021rnq.1	148	148	0	0
+uc010ahi.1	99	99	0	0
+uc001vxa.1	341	192	24	1152.86
+uc010ahj.1	7481	7332	31.9164	40.1475
+uc010ahk.3	26101	25952	191.944	68.2136
+uc001vxe.3	47754	47605	0.000314474	6.09257e-05
+uc010tlf.1	45513	45364	90.6021	18.4202
+uc010tlg.1	45513	45364	90.6021	18.4202
+uc010tlh.1	10868	10719	112.935	97.1724
+uc010tli.2	6832	6683	0	0
+uc001vxf.3	8061	7912	1341	1563.18
+uc001vxk.2	3626	3477	890	2360.77
+uc001vxl.2	3626	3477	890	2360.77
+uc001vxq.4	4839	4690	0	0
+uc010aho.3	4839	4690	0	0
+uc010ahp.3	4839	4690	0	0
+uc010ahq.3	4839	4690	0	0
+uc010ahr.3	4839	4690	0	0
+uc010ahs.3	4839	4690	0	0
+uc010aht.3	4839	4690	0	0
+uc010ahu.3	4839	4690	0	0
+uc021rnt.1	618	469	0	0
+uc010ahv.3	4833	4684	0	0
+uc010ahx.3	5096	4947	0	0
+uc010ahw.3	5101	4952	0	0
+uc001vxs.3	7366	7217	0	0
+uc021rnu.1	600	451	0	0
+uc001vxt.3	743	594	0	0
+uc021rnv.1	72	72	0	0
+uc021rnx.1	72	72	0	0
+uc021rny.1	73	73	0	0
+uc021roa.1	73	73	0	0
+uc001vxv.1	996	847	0	0
+uc021roc.1	94	94	0	0
+uc021rod.1	94	94	0	0
+uc021roe.1	94	94	0	0
+uc021rof.1	94	94	0	0
+uc021rog.1	82	82	0	0
+uc001vyf.3	1044	895	0	0
+uc001vyg.3	1522	1373	0	0
+uc001vyh.3	1522	1373	0	0
+uc001vyi.3	1522	1373	0	0
+uc021rop.1	471	322	0	0
+uc001vyt.3	6058	5909	177.465	276.992
+uc001vyu.3	6559	6410	104.73	150.689
+uc001vyv.3	8264	8115	50.5797	57.4852
+uc001vyw.3	8277	8128	11.1976	12.706
+uc001vyx.3	8343	8194	0.00550266	0.00619361
+uc001vyy.3	8343	8194	0.00550266	0.00619361
+uc001vyz.3	8343	8194	0.00550266	0.00619361
+uc001vza.3	8343	8194	0.00550266	0.00619361
+uc001vzb.3	8343	8194	0.00550266	0.00619361
+uc001vzc.3	8742	8593	0	0
+uc001vzd.3	9014	8865	0	0
+uc001vze.3	9014	8865	0	0
+uc001vzf.3	9014	8865	0	0
+uc001vzg.3	9014	8865	0	0
+uc010aig.3	9014	8865	0	0
+uc010tll.2	54110	53961	0	0
+uc001vzj.3	1966	1817	0	0
+uc021rot.1	471	322	0	0
+uc001vzr.2	8604	8455	1783.06	1945
+uc001vzs.2	8969	8820	0	0
+uc010aik.1	14659	14510	20.4944	13.0267
+uc010tlp.2	1089	940	0	0
+uc001vzu.2	5425	5276	8.22334	14.3751
+uc021rov.1	6822	6673	4.77666	6.60194
+uc001vzw.3	60343	60194	28.7529	4.40551
+uc001vzx.3	60343	60194	28.7529	4.40551
+uc001vzy.3	60343	60194	28.7529	4.40551
+uc001vzz.3	60343	60194	28.7529	4.40551
+uc001waa.3	60343	60194	28.7529	4.40551
+uc001wac.3	60343	60194	28.7529	4.40551
+uc001wad.3	60343	60194	28.7529	4.40551
+uc010ail.3	60343	60194	28.7529	4.40551
+uc010tlq.2	60343	60194	28.7529	4.40551
+uc010tlr.2	19606	19457	12.3536	5.85578
+uc001wae.3	58712	58563	0	0
+uc001wao.2	32795	32646	3361.06	949.542
+uc001waq.2	1286	1137	42.9405	348.317
+uc001war.2	46515	46366	5128.31	1020.1
+uc001was.2	52105	51956	1291.93	229.335
+uc001wat.1	103	103	0	0
+uc001wau.1	109	109	0	0
+uc001wav.1	9710	9561	682.764	658.621
+uc021row.1	300	151	0	0
+uc010tls.2	17654	17505	0	0
+uc001wax.3	17954	17805	85.021	44.0405
+uc010ain.4	17954	17805	85.021	44.0405
+uc010tlt.2	17954	17805	85.021	44.0405
+uc001wbb.3	5691	5542	924.736	1538.93
+uc001wbc.3	13176	13027	0.0915321	0.0648033
+uc010tlw.1	10403	10254	468.16	421.084
+uc010tlx.2	10164	10015	0	0
+uc021rox.1	9626	9477	0.0588644	0.0572862
+uc021roy.1	29	29	0	0
+uc010tly.2	5131	4982	0	0
+uc001wbe.3	16106	15957	0	0
+uc001wbf.3	4890	4741	0	0
+uc010tlz.1	4890	4741	0	0
+uc001wbg.1	15865	15716	0	0
+uc010tma.1	15865	15716	0	0
+uc010tmb.2	942	793	0	0
+uc010tmc.2	933	784	0	0
+uc001wds.1	102866	102717	0	0
+uc001wdt.1	15199	15050	1.69654	1.03967
+uc001web.1	624	475	0	0
+uc001wgl.2	24337	24188	1820	693.968
+uc001wgr.4	42187	42038	22.0104	4.82897
+uc001wgs.4	42676	42527	0.000408549	8.86027e-05
+uc001wgt.4	43245	43096	0	0
+uc001wgu.4	46589	46440	0	0
+uc001wgv.4	46589	46440	0	0
+uc001whg.3	18543	18394	682.714	342.318
+uc001whh.3	18543	18394	682.714	342.318
+uc001whi.3	18543	18394	682.714	342.318
+uc001whj.3	18543	18394	682.714	342.318
+uc010tne.2	18543	18394	682.714	342.318
+uc001whk.1	16431	16282	0	0
+uc001whl.1	8929	8780	845.5	888.151
+uc001whm.1	8929	8780	845.5	888.151
+uc001whn.1	8929	8780	845.5	888.151
+uc010tnf.1	8929	8780	845.5	888.151
+uc010tng.1	8929	8780	845.5	888.151
+uc010tnh.1	8929	8780	845.5	888.151
+uc001who.3	8949	8800	559.604	586.497
+uc001wht.3	10915	10766	51.2661	43.9181
+uc001whu.3	10915	10766	51.2661	43.9181
+uc001whv.3	10915	10766	51.2661	43.9181
+uc001whw.3	10915	10766	51.2661	43.9181
+uc001whq.3	10921	10772	30.3316	25.9697
+uc021rqu.1	80	80	0	0
+uc001why.3	6023	5874	1064.11	1670.78
+uc001whz.3	11439	11290	662.891	541.522
+uc001wib.2	13233	13084	487.228	343.447
+uc001wic.2	14137	13988	0	0
+uc001wia.4	23251	23102	20.7544	8.2857
+uc001wie.3	23251	23102	20.7544	8.2857
+uc001wif.3	23251	23102	20.7544	8.2857
+uc001wig.3	23251	23102	20.7544	8.2857
+uc001wih.3	23251	23102	20.7544	8.2857
+uc001wii.3	9295	9146	2864.11	2888.19
+uc001wij.3	9295	9146	2864.11	2888.19
+uc010tni.2	9370	9221	738.777	738.93
+uc001wil.3	10478	10329	1762.5	1573.76
+uc010akf.3	10478	10329	1762.5	1573.76
+uc001win.3	5185	5036	0	0
+uc001wio.4	11053	10904	3449.67	2917.83
+uc001wip.4	12974	12825	0	0
+uc001wiq.4	13006	12857	0	0
+uc001wir.4	13006	12857	0	0
+uc001wis.4	22245	22096	3035.91	1267.19
+uc001wit.4	37050	36901	217.896	54.4602
+uc010akg.3	37050	36901	217.896	54.4602
+uc010tnj.2	37050	36901	217.896	54.4602
+uc010aki.1	4547	4398	0	0
+uc001wiv.2	2306	2157	2	8.5516
+uc001wiw.3	4849	4700	356.991	700.53
+uc001wix.4	29156	29007	0	0
+uc010tnk.3	29156	29007	0	0
+uc001wiy.4	30164	30015	56.4403	17.3428
+uc010tnl.3	30164	30015	56.4403	17.3428
+uc001wiz.4	58366	58217	2.06429	0.32703
+uc010akj.4	58366	58217	2.06429	0.32703
+uc021rqw.1	106	106	0	0
+uc001wja.2	12466	12317	550.653	412.326
+uc001wjb.2	25904	25755	15.8863	5.68891
+uc031qns.1	6928	6779	40.8212	55.5378
+uc001wjc.2	5163	5014	61.8899	113.842
+uc001wjl.3	6134	5985	0	0
+uc010akk.3	6134	5985	0	0
+uc001wjm.3	6554	6405	0	0
+uc001wjn.3	6554	6405	0	0
+uc010akl.1	3950	3801	0	0
+uc001wjo.4	9234	9085	0	0
+uc001wjp.4	9234	9085	0	0
+uc010tnm.3	9234	9085	0	0
+uc001wjv.3	26288	26139	0	0
+uc010tnn.2	71	71	0	0
+uc010akp.2	8566	8417	0	0
+uc001wjx.3	22924	22775	0	0
+uc021rqy.1	77	77	0	0
+uc010akq.3	5948	5799	29.7309	47.2849
+uc010tno.2	30795	30646	24.9264	7.50159
+uc001wke.3	2328	2179	0	0
+uc001wkk.3	7947	7798	1120.5	1325.24
+uc001wkl.2	8503	8354	0	0
+uc001wkn.2	8503	8354	0	0
+uc001wkp.1	3365	3216	431.147	1236.45
+uc010tnp.1	4679	4530	202.08	411.427
+uc010aks.3	2532	2383	239.435	926.682
+uc010akt.3	3088	2939	0	0
+uc010tnq.1	2396	2247	0.840146	3.44841
+uc010tnr.1	4967	4818	0	0
+uc001wkq.2	10766	10617	0	0
+uc001wkr.2	10766	10617	0	0
+uc001wks.2	3850	3701	0	0
+uc031qny.1	11690	11541	0	0
+uc001wky.3	15453	15304	96.0726	57.8979
+uc001wkz.3	15453	15304	96.0726	57.8979
+uc010akx.1	16359	16210	0	0
+uc021rrk.1	1840	1691	5.20993	28.4156
+uc001wlo.3	4517	4368	7.24664	15.3011
+uc001wlp.3	15024	14875	5.67567	3.51907
+uc001wlq.3	34908	34759	6.97723	1.85133
+uc001wmi.3	2624	2475	600	2235.86
+uc001wmj.3	3282	3133	247	727.117
+uc001wmt.1	4545	4396	1414.92	2968.53
+uc001wmu.2	8651	8502	50.9039	55.2202
+uc001wmv.1	9590	9441	47.3592	46.2652
+uc001wmw.1	9590	9441	47.3592	46.2652
+uc001wmx.1	9590	9441	47.3592	46.2652
+uc001wmy.1	9590	9441	47.3592	46.2652
+uc010tnz.1	9590	9441	47.3592	46.2652
+uc001wmz.2	10435	10286	5560.66	4985.95
+uc001wnb.1	6958	6809	23.9051	32.3798
+uc010toa.1	6958	6809	23.9051	32.3798
+uc010tob.1	25433	25284	339.326	123.777
+uc001wnc.3	5639	5490	3869.79	6501.05
+uc001wni.3	4571	4422	286.545	597.644
+uc010toc.2	4571	4422	286.545	597.644
+uc001wnj.4	6490	6341	277.563	403.712
+uc001wnk.2	3332	3183	0	0
+uc001wnl.2	2662	2513	0	0
+uc001wnm.2	2662	2513	0	0
+uc021rrl.1	2662	2513	0	0
+uc021rrm.1	18962	18813	0	0
+uc001wnn.2	15520	15371	1787	1072.24
+uc001wno.2	15520	15371	1787	1072.24
+uc001wnp.2	5766	5617	0	0
+uc010alm.3	2350	2201	434.293	1819.83
+uc001woa.4	3030	2881	43.4268	139.022
+uc001wob.4	3030	2881	43.4268	139.022
+uc001woc.4	3030	2881	43.4268	139.022
+uc010tof.2	3030	2881	43.4268	139.022
+uc001wod.3	14097	13948	226.845	149.998
+uc010tog.2	14097	13948	226.845	149.998
+uc021rrn.1	1277	1128	107.309	877.396
+uc001wof.4	6090	5941	596.406	925.871
+uc001wog.4	6090	5941	596.406	925.871
+uc010aln.2	4059	3910	591.213	1394.55
+uc001woj.2	8863	8714	0	0
+uc001wok.3	9236	9087	1166.35	1183.8
+uc001won.3	2796	2647	1125.74	3922.39
+uc001woo.3	6184	6035	404.988	618.918
+uc001wop.3	6184	6035	404.988	618.918
+uc001wow.3	16723	16574	0	0
+uc001wox.3	16723	16574	0	0
+uc001woy.3	16723	16574	0	0
+uc010toh.2	16723	16574	0	0
+uc001woz.4	2819	2670	0	0
+uc001wpa.3	3045	2896	0	0
+uc001wpb.3	4016	3867	0	0
+uc010alq.3	4016	3867	0	0
+uc010toi.2	4016	3867	0	0
+uc010toj.1	1991	1842	0	0
+uc001wpg.4	2992	2843	49	158.96
+uc001wpi.3	2687	2538	262.514	953.958
+uc001wpm.3	3036	2887	297.798	951.356
+uc001wpp.1	2760	2611	0	0
+uc010alx.1	2760	2611	0	0
+uc001wpq.3	2743	2594	0	0
+uc001wpr.2	3241	3092	0	0
+uc010aly.2	3241	3092	0	0
+uc010alz.2	3241	3092	0	0
+uc031qoe.1	3241	3092	0	0
+uc001wps.2	3272	3123	0	0
+uc010ama.2	3272	3123	0	0
+uc010amb.2	3272	3123	0	0
+uc001wpt.3	7378	7229	0.904426	1.15389
+uc001wpu.3	237790	237641	2.78655e-06	1.08147e-07
+uc001wpv.3	237866	237717	2.06183e-06	7.99944e-08
+uc001wpw.3	237866	237717	2.06183e-06	7.99944e-08
+uc001wpx.1	234304	234155	3.09572	0.121934
+uc021rrr.1	84	84	0	0
+uc001wpy.3	151872	151723	0	0
+uc001wpz.3	151872	151723	0	0
+uc001wqa.3	151872	151723	0	0
+uc001wqb.3	127637	127488	0	0
+uc010amc.2	351220	351071	20.4818	0.538074
+uc001wqg.1	2294	2145	0	0
+uc021rrv.1	278492	278343	0	0
+uc001wqh.3	351213	351064	0	0
+uc001wqi.3	344	195	0	0
+uc001wqj.1	964	815	0	0
+uc001wqs.3	13630	13481	0	0
+uc001wqu.2	132603	132454	257.838	17.9535
+uc001wqv.2	132603	132454	257.838	17.9535
+uc010tpj.1	132603	132454	257.838	17.9535
+uc021rrx.1	97	97	0	0
+uc001wra.1	23553	23404	0	0
+uc001wrb.1	29190	29041	1875.26	595.549
+uc001wrc.1	107366	107217	2101.22	180.749
+uc001wrd.1	55369	55220	807.411	134.855
+uc001wre.3	4635	4486	114.115	234.613
+uc010ami.3	95588	95439	1063.22	102.746
+uc001wrf.4	128795	128646	2130.73	152.757
+uc001wrg.1	63811	63662	0	0
+uc010tpk.1	123163	123014	0	0
+uc001wrh.3	20315	20166	0	0
+uc001wrj.3	11438	11289	245.069	200.217
+uc021rsa.1	5002	4853	0	0
+uc021rsc.1	71	71	0	0
+uc010amk.3	1281	1132	41	334.045
+uc001wry.3	26612	26463	0	0
+uc001wsa.4	26864	26715	556	191.95
+uc001wsc.3	29325	29176	2419.94	764.973
+uc001wsd.1	23809	23660	431	168.008
+uc001wse.1	68698	68549	169.654	22.826
+uc001wsf.1	68749	68600	555.68	74.7082
+uc010tpm.1	68749	68600	555.68	74.7082
+uc010amm.1	62307	62158	0	0
+uc001wsg.3	3436	3287	674.454	1892.43
+uc010tpn.1	4174	4025	0	0
+uc001wsh.3	4442	4293	24.1819	51.9514
+uc001wsi.3	4442	4293	24.1819	51.9514
+uc001wsj.3	4442	4293	24.1819	51.9514
+uc001wsk.3	122917	122768	788.533	59.2383
+uc001wsl.3	122917	122768	788.533	59.2383
+uc001wsm.1	74709	74560	0	0
+uc001wss.3	36842	36693	0.000884763	0.000222388
+uc001wst.3	36842	36693	0.000884763	0.000222388
+uc001wsu.3	37002	36853	51.2149	12.8171
+uc010tpr.2	37002	36853	51.2149	12.8171
+uc010amn.1	23439	23290	0	0
+uc001wsw.3	14646	14497	0	0
+uc001wsx.1	14335	14186	9.50261	6.17804
+uc001wtf.4	3245	3096	1965	5853.68
+uc010amp.3	134671	134522	125.938	8.63437
+uc001wti.3	270875	270726	89.3325	3.04332
+uc001wtj.3	270875	270726	89.3325	3.04332
+uc010tpv.2	270875	270726	89.3325	3.04332
+uc010tpw.1	260117	259968	0	0
+uc001wtk.1	84778	84629	51.384	5.59985
+uc031qoh.1	40942	40793	0	0
+uc001wtm.2	22119	21970	44.5	18.6809
+uc001wtn.2	22119	21970	44.5	18.6809
+uc001wto.2	22119	21970	44.5	18.6809
+uc010tpy.1	22119	21970	44.5	18.6809
+uc001wtq.3	40497	40348	0	0
+uc001wtr.3	40497	40348	0	0
+uc001wts.3	46324	46175	0	0
+uc001wtt.3	3300	3151	51.2789	150.092
+uc001wtu.3	3827	3678	3.33898	8.37279
+uc001wtv.3	3827	3678	3.33898	8.37279
+uc001wtx.3	2571	2422	14	53.3116
+uc001wtz.2	494740	494591	21.5623	0.402083
+uc021rsf.1	494740	494591	21.5623	0.402083
+uc021rsg.1	83	83	0	0
+uc010tpz.3	4711	4562	382.662	773.62
+uc001wuf.4	5569	5420	385.338	655.708
+uc001wuk.2	6065	5916	0	0
+uc001wum.2	2371	2222	0	0
+uc010amw.2	89866	89717	3.31974	0.341269
+uc021rsj.1	167544	167395	0	0
+uc001wun.3	198933	198784	0	0
+uc001wuo.3	198933	198784	0	0
+uc001wup.1	71315	71166	276.757	35.8669
+uc010tqa.1	71315	71166	276.757	35.8669
+uc010tqb.1	71315	71166	276.757	35.8669
+uc010tqc.1	36515	36366	192.73	48.8789
+uc001wut.1	22620	22471	59	24.2157
+uc001wuu.1	22620	22471	59	24.2157
+uc001wuv.1	22620	22471	59	24.2157
+uc010tqd.1	22620	22471	59	24.2157
+uc001wvd.3	1359	1210	9.51806e-07	7.25489e-06
+uc001wvk.3	36128	35979	398.986	102.277
+uc001wvn.3	3146	2997	0	0
+uc001wvq.4	36809	36660	0	0
+uc001wvr.3	37653	37504	122.732	30.1819
+uc001wvs.1	2019	1870	0	0
+uc001wvt.4	2206	2057	79.2685	355.414
+uc001wvx.1	829	680	0	0
+uc010tqf.2	19208	19059	208	100.654
+uc001wwf.3	50213	50064	632	116.428
+uc010anh.2	26660	26511	0	0
+uc001wwg.3	809	660	0	0
+uc001wwh.4	42597	42448	7.60899	1.65325
+uc001wwi.4	503611	503462	4.6376	0.084956
+uc001wwj.4	835330	835181	0	0
+uc010ani.3	755586	755437	12.8293	0.156629
+uc021rsn.1	110	110	0	0
+uc001wwk.2	30062	29913	4.83419	1.4905
+uc021rso.1	68	68	0	0
+uc010anj.1	286513	286364	350.252	11.2805
+uc001wwl.4	9745	9596	63.3622	60.8987
+uc001wwm.4	2845	2696	1792.9	6133.44
+uc001wwq.2	1998	1849	684.636	3415
+uc021rsq.1	321	172	1904.1	102101
+uc001wws.4	10057	9908	236.941	220.557
+uc001wwt.4	10057	9908	236.941	220.557
+uc010ann.3	21123	20974	158.867	69.8589
+uc001wwu.3	44829	44680	9.48524e-07	1.95796e-07
+uc021rsr.1	44829	44680	9.48524e-07	1.95796e-07
+uc010ano.3	38200	38051	106.502	25.8142
+uc001wwz.3	15711	15562	0	0
+uc001wxa.3	17747	17598	58.7162	30.7725
+uc001wxc.3	69008	68859	352.67	47.2363
+uc010tqi.2	69008	68859	352.67	47.2363
+uc001wxe.2	67897	67748	2.08627	0.284015
+uc001wxd.1	36336	36187	0.010704	0.00272811
+uc010anq.1	32726	32577	0	0
+uc021rst.1	301	152	1008	61162.4
+uc001wxh.1	18424	18275	0	0
+uc001wxi.1	25809	25660	22.9204	8.23822
+uc010tqj.3	1212	1063	4.05049	35.1433
+uc031qom.1	32572	32423	4.48218	1.27498
+uc001wxl.3	3637	3488	1.51782	4.01338
+uc010tqk.2	8993	8844	4	4.17137
+uc001wxn.1	7595	7446	0	0
+uc001wxo.1	7948	7799	60	70.9545
+uc001wxp.1	7948	7799	60	70.9545
+uc001wxq.1	7948	7799	60	70.9545
+uc010ans.3	13635	13486	111.74	76.4175
+uc001wxs.4	114254	114105	81.4801	6.5859
+uc010tql.2	114254	114105	81.4801	6.5859
+uc010tqm.1	22998	22849	86.5831	34.9489
+uc001wxt.2	24791	24642	61.7168	23.0991
+uc010tqn.2	74663	74514	15.31	1.89499
+uc001wxu.3	69796	69647	614.562	81.3825
+uc010tqo.1	66347	66198	0	0
+uc001wxz.3	65923	65774	0.0844651	0.0118438
+uc010anu.2	80469	80320	190.027	21.8202
+uc001wya.3	114166	114017	198.724	16.0749
+uc001wyb.3	114166	114017	198.724	16.0749
+uc001wyc.1	10588	10439	63.611	56.2006
+uc010anv.1	92163	92014	0	0
+uc001wyh.2	34774	34625	528.243	140.706
+uc021rsy.2	3175	3026	251.835	767.564
+uc001wyi.3	111359	111210	696.785	57.786
+uc001wyj.3	111359	111210	696.785	57.786
+uc001wyk.3	105294	105145	0	0
+uc001wym.2	105294	105145	0	0
+uc001wyn.3	12255	12106	42.2999	32.226
+uc001wyo.3	103889	103740	0	0
+uc001wyp.1	60734	60585	0	0
+uc001wyu.3	39314	39165	948.273	223.307
+uc010tqq.2	39314	39165	948.273	223.307
+uc010anz.1	8276	8127	337.454	382.959
+uc001wyw.4	21280	21131	0	0
+uc001wyx.4	120442	120293	0	0
+uc001wyy.2	116927	116778	0	0
+uc001wyz.4	99638	99489	4	0.370811
+uc031qon.1	145441	145292	0	0
+uc031qoo.1	53324	53175	0	0
+uc021rtc.1	2227	2078	0	0
+uc001wzo.3	64427	64278	3.52837e-05	5.06267e-06
+uc010tqs.2	64427	64278	3.52837e-05	5.06267e-06
+uc010tqt.1	63502	63353	30.0348	4.37245
+uc001wzp.3	56520	56371	0	0
+uc001wzs.3	121994	121845	71.1342	5.38442
+uc010aoe.3	121994	121845	71.1342	5.38442
+uc010tqu.2	121994	121845	71.1342	5.38442
+uc001wzv.3	53815	53666	841	144.532
+uc001xab.3	16476	16327	795.686	449.473
+uc001xad.3	93603	93454	0	0
+uc001xac.3	93827	93678	1735.73	170.888
+uc001xae.3	93827	93678	1735.73	170.888
+uc001xaf.3	91610	91461	0	0
+uc001xag.3	56925	56776	625.924	101.677
+uc001xah.3	116589	116440	92.3755	7.31682
+uc001xai.3	116589	116440	92.3755	7.31682
+uc001xaj.3	116589	116440	92.3755	7.31682
+uc001xak.1	8813	8664	0.865937	0.921798
+uc031qop.1	58	58	0	0
+uc001xal.4	3719	3570	255	658.779
+uc010aoh.3	4816	4667	0	0
+uc001xan.4	7100	6951	0	0
+uc001xao.4	7100	6951	0	0
+uc001xat.1	14502	14353	1141.5	733.501
+uc001xav.1	14502	14353	1141.5	733.501
+uc021rtf.1	14536	14387	493	316.042
+uc001xbd.1	2211	2062	0	0
+uc001xbh.1	60819	60670	62.4082	9.48714
+uc001xbi.1	60819	60670	62.4082	9.48714
+uc001xbj.1	60819	60670	62.4082	9.48714
+uc001xbk.1	60819	60670	62.4082	9.48714
+uc010aol.1	60819	60670	62.4082	9.48714
+uc001xbl.1	57182	57033	0	0
+uc021rth.1	81	81	0	0
+uc010aom.2	52463	52314	68.2137	12.026
+uc001xbm.2	88164	88015	551.003	57.7384
+uc001xbn.2	88164	88015	551.003	57.7384
+uc001xbs.3	43563	43414	454.5	96.5543
+uc001xbt.3	43563	43414	454.5	96.5543
+uc001xbw.2	24912	24763	262.425	97.7393
+uc001xbx.2	45468	45319	0	0
+uc001xby.3	26334	26185	0	0
+uc001xbz.2	22121	21972	47.1217	19.7797
+uc001xca.3	3936	3787	39.8783	97.1201
+uc010trd.2	15540	15391	0	0
+uc010tre.2	15540	15391	0	0
+uc021rtl.1	84	84	0	0
+uc001xcp.4	4957	4808	0	0
+uc021rtm.2	4957	4808	0	0
+uc031qor.1	4957	4808	0	0
+uc001xcq.4	9770	9621	0	0
+uc010aou.4	9770	9621	0	0
+uc031qos.1	9770	9621	0	0
+uc031qot.1	9770	9621	0	0
+uc001xcs.3	29897	29748	358.662	111.197
+uc001xct.3	66424	66275	47.7795	6.64905
+uc010trg.2	66424	66275	47.7795	6.64905
+uc010trh.2	66424	66275	47.7795	6.64905
+uc001xcy.2	23982	23833	0	0
+uc001xcz.2	23982	23833	0	0
+uc010trl.1	23982	23833	0	0
+uc010trm.1	23982	23833	0	0
+uc010trn.1	23982	23833	0	0
+uc010aox.1	15256	15107	0	0
+uc010aoy.3	15078	14929	0	0
+uc010aoz.1	32976	32827	0	0
+uc010apa.1	32976	32827	0	0
+uc021rtp.1	301953	301804	0	0
+uc001xdc.3	148040	147891	0	0
+uc010tro.2	294048	293899	20.3854	0.639718
+uc001xdd.3	134742	134593	0	0
+uc001xde.3	35982	35833	0	0
+uc021rts.1	73	73	0	0
+uc001xdl.3	32773	32624	42.8721	12.1201
+uc021rtu.1	32773	32624	42.8721	12.1201
+uc001xdn.2	24202	24053	0	0
+uc010apd.2	12547	12398	37.7775	28.1028
+uc010ape.2	12547	12398	37.7775	28.1028
+uc010aph.3	18591	18442	2.73272e-06	1.36664e-06
+uc001xds.3	18863	18714	124.502	61.3589
+uc010api.3	18863	18714	124.502	61.3589
+uc021rtv.1	84	84	0	0
+uc001xed.2	36320	36171	144.684	36.8916
+uc010apj.3	1820	1671	88.316	487.451
+uc001xee.1	11668	11519	303.378	242.905
+uc010trx.1	5683	5534	186.622	311.022
+uc021rtw.1	71765	71616	1.00086	0.128893
+uc001xek.2	34839	34690	0.319646	0.084983
+uc010apl.2	34839	34690	0.319646	0.084983
+uc001xem.1	131738	131589	1.36827	0.0959004
+uc001xen.1	274864	274715	0	0
+uc001xes.3	20712	20563	1319.87	591.986
+uc001xet.3	25062	24913	0	0
+uc001xev.1	5524	5375	0	0
+uc001xez.4	50091	49942	0	0
+uc010apo.3	50091	49942	0	0
+uc001xfb.4	4739	4590	128	257.196
+uc001xfc.3	14597	14448	882.452	563.315
+uc010app.1	6351	6202	138.548	206.033
+uc001xff.4	9616	9467	476.981	464.682
+uc021rty.1	72	72	0	0
+uc001xfl.3	4442	4293	0	0
+uc001xfm.3	19798	19649	0	0
+uc031qov.1	9592	9443	2	1.95338
+uc021ruc.1	2051	1902	85.717	415.646
+uc001xfx.3	338011	337862	0	0
+uc001xfy.3	338011	337862	0	0
+uc001xfz.1	389627	389478	0	0
+uc001xga.3	152054	151905	0	0
+uc021rud.1	6045	5896	0	0
+uc010tsf.1	133601	133452	0	0
+uc010tsg.1	133602	133453	0	0
+uc001xgd.1	168725	168576	175.033	9.57618
+uc001xge.2	168725	168576	175.033	9.57618
+uc010tsh.1	168725	168576	175.033	9.57618
+uc001xgf.1	161306	161157	0	0
+uc001xgg.4	92092	91943	0	0
+uc001xgh.4	44885	44736	95.5001	19.6886
+uc001xgi.4	44885	44736	95.5001	19.6886
+uc031qox.1	44885	44736	95.5001	19.6886
+uc021ruf.1	1164	1015	141.5	1285.75
+uc001xgj.3	43822	43673	402.551	85.011
+uc001xgy.2	56043	55894	0	0
+uc001xgu.3	67378	67229	0	0
+uc001xgv.3	111518	111369	19.1747	1.58794
+uc001xgw.3	111518	111369	19.1747	1.58794
+uc001xgx.3	111518	111369	19.1747	1.58794
+uc031qoy.1	55258	55109	0	0
+uc010aqb.1	50047	49898	0	0
+uc010aqc.1	50047	49898	0	0
+uc001xha.1	61382	61233	0	0
+uc001xgz.2	48189	48040	0	0
+uc010aqd.1	25779	25630	0	0
+uc021ruj.2	2139	1990	2	9.26925
+uc001xhc.3	56108	55959	514.873	84.859
+uc001xhf.3	17000	16851	4.71363e-06	2.57987e-06
+uc001xhg.3	18377	18228	126.844	64.18
+uc010aqi.3	36271	36122	871.748	222.58
+uc001xhr.3	76863	76714	903.9	108.671
+uc001xhs.3	133601	133452	2.35207	0.162553
+uc001xht.3	56747	56598	0	0
+uc001xhu.3	113485	113336	0	0
+uc021run.1	84	84	0	0
+uc021ruo.1	293	144	0	0
+uc001xhy.2	3754	3605	0	0
+uc021ruq.2	3754	3605	0	0
+uc031qoz.1	3754	3605	0	0
+uc001xhz.2	26344	26195	20.03	7.0523
+uc021rur.1	26344	26195	20.03	7.0523
+uc021rus.1	26344	26195	20.03	7.0523
+uc021rut.1	26344	26195	20.03	7.0523
+uc001xic.2	96444	96295	56.9939	5.45874
+uc031qpa.1	96444	96295	56.9939	5.45874
+uc001xie.2	27421	27272	164.744	55.7134
+uc001xif.2	27421	27272	164.744	55.7134
+uc001xig.2	27421	27272	164.744	55.7134
+uc001xih.2	27421	27272	164.744	55.7134
+uc031qpb.1	27572	27423	358.743	120.652
+uc001xij.2	25352	25203	0	0
+uc001xii.2	25201	25052	0	0
+uc001xik.4	18806	18657	0	0
+uc031qpc.1	18806	18657	0	0
+uc031qpd.1	18957	18808	0	0
+uc001xil.3	9455	9306	0	0
+uc021ruw.1	66	66	0	0
+uc001xim.4	2025	1876	0.979454	4.81525
+uc021ruz.1	109	109	0	0
+uc010tsr.3	13125	12976	0	0
+uc001xjf.3	22140	21991	557.811	233.943
+uc001xjh.1	25129	24980	90	33.229
+uc001xji.1	849	700	0	0
+uc001xjj.1	61406	61257	1.0059	0.151449
+uc001xjk.3	45039	44890	0	0
+uc021rvb.1	504	355	3.99417	103.769
+uc001xjr.1	10995	10846	201.772	171.577
+uc010tsy.1	7047	6898	0	0
+uc001xjt.3	23736	23587	90.8802	35.5357
+uc001xju.3	23736	23587	90.8802	35.5357
+uc010aqp.3	23736	23587	90.8802	35.5357
+uc001xjv.4	18992	18843	1189.6	582.261
+uc001xjw.4	18992	18843	1189.6	582.261
+uc001xjx.4	18992	18843	1189.6	582.261
+uc001xka.2	70070	69921	1516.6	200.046
+uc010tsz.1	70070	69921	1516.6	200.046
+uc001xkb.3	11112	10963	0	0
+uc021rvc.1	318	169	0	0
+uc001xkc.4	55808	55659	0	0
+uc010tta.2	20357	20208	0	0
+uc021rvd.1	298	149	0	0
+uc001xkh.2	6260	6111	1227.47	1852.54
+uc001xki.2	6260	6111	1227.47	1852.54
+uc021rve.1	8589	8440	51.1774	55.9246
+uc021rvf.1	499	350	3.87772	102.182
+uc001xkk.3	14141	13992	6399.38	4218.19
+uc010ttb.2	103444	103295	0	0
+uc001xkl.3	105244	105095	2815.51	247.083
+uc001xkm.3	105244	105095	2815.51	247.083
+uc001xkn.3	105244	105095	2815.51	247.083
+uc010ttc.2	7197	7048	3164.08	4140.46
+uc001xko.1	94087	93938	0	0
+uc010ttd.1	93495	93346	0	0
+uc001xkp.3	102278	102129	688.406	62.1675
+uc001xkq.3	102278	102129	688.406	62.1675
+uc001xkr.4	63994	63845	0	0
+uc001xks.2	35011	34862	0	0
+uc001xlc.2	18182	18033	2451.75	1253.94
+uc010aqy.4	5070	4921	6.6816	12.5226
+uc031qpg.1	2124	1975	1.3184	6.15669
+uc021rvk.1	1431	1282	4.61474	33.1992
+uc001xlr.2	21455	21306	2	0.865757
+uc001xlu.3	35990	35841	0	0
+uc001xlv.3	35990	35841	0	0
+uc001xlw.3	144854	144705	1.56863	0.0999778
+uc001xlx.3	144854	144705	1.56863	0.0999778
+uc001xly.3	144854	144705	1.56863	0.0999778
+uc001xlz.3	144854	144705	1.56863	0.0999778
+uc010ara.3	144854	144705	1.56863	0.0999778
+uc001xma.2	34132	33983	0.838795	0.227647
+uc010ttg.2	2049	1900	10.2913	49.9556
+uc001xmb.3	34651	34502	72.5775	19.4011
+uc021rvl.1	34651	34502	72.5775	19.4011
+uc021rvm.1	92010	91861	75.2995	7.56012
+uc021rvn.1	92010	91861	75.2995	7.56012
+uc021rvo.1	92010	91861	75.2995	7.56012
+uc001xmc.4	50595	50446	281.946	51.5475
+uc021rvr.1	14878	14729	11.0032	6.8899
+uc001xme.3	12655	12506	6	4.42487
+uc021rvs.1	2331	2182	0	0
+uc001xmf.3	16428	16279	73.5401	41.6643
+uc010tth.2	16428	16279	73.5401	41.6643
+uc010tti.2	16428	16279	73.5401	41.6643
+uc001xmg.1	8157	8008	0.0395872	0.0455931
+uc010ttj.2	8090	7941	108.34	125.829
+uc001xmh.1	32501	32352	0	0
+uc001xmk.3	55309	55160	244.45	40.8727
+uc010ttk.2	55309	55160	244.45	40.8727
+uc001xml.3	81035	80886	198.08	22.5858
+uc001xmm.3	81035	80886	198.08	22.5858
+uc010arh.1	4062	3913	0	0
+uc001xnc.2	274806	274657	3.87843	0.130237
+uc001xnd.1	62246	62097	2.12624	0.315798
+uc001xnf.2	232242	232093	0	0
+uc010ari.1	224150	224001	0	0
+uc010ttq.1	224150	224001	0	0
+uc001xnl.3	17506	17357	248.05	131.805
+uc001xnm.3	57762	57613	81.5764	13.0591
+uc010arj.3	57762	57613	81.5764	13.0591
+uc010ttv.2	556	407	0	0
+uc001xnx.3	1962	1813	0	0
+uc010ttz.1	9209	9060	999.086	1017.05
+uc010aro.1	91772	91623	83.7776	8.43318
+uc010arp.1	91772	91623	83.7776	8.43318
+uc010arq.1	91772	91623	83.7776	8.43318
+uc010arr.1	91772	91623	83.7776	8.43318
+uc001xny.1	183369	183220	0.00176669	8.89314e-05
+uc001xnz.1	183369	183220	0.00176669	8.89314e-05
+uc001xoa.1	183369	183220	0.00176669	8.89314e-05
+uc001xob.1	183369	183220	0.00176669	8.89314e-05
+uc001xoc.1	183369	183220	0.00176669	8.89314e-05
+uc001xod.1	183369	183220	0.00176669	8.89314e-05
+uc010ars.1	183369	183220	0.00176669	8.89314e-05
+uc001xoe.3	2704	2555	1247.9	4504.62
+uc001xof.1	174498	174349	94.0258	4.97388
+uc001xog.3	174318	174169	0.000496068	2.62686e-05
+uc001xoh.1	172354	172205	1.44779e-05	7.75403e-07
+uc021rwe.1	80463	80314	20.577	2.36297
+uc021rwf.2	80463	80314	20.577	2.36297
+uc010tub.1	33050	32901	32.2248	9.03336
+uc021rwg.1	73	73	0	0
+uc021rwh.1	97	97	0	0
+uc001xor.1	2643	2494	1249	4618.85
+uc001xos.3	14055	13906	2007.7	1331.57
+uc001xot.3	45177	45028	63.2711	12.9596
+uc001xou.3	72072	71923	37.439	4.80092
+uc010tud.1	21410	21261	0.00397741	0.00172538
+uc010arw.2	20951	20802	1827.53	810.267
+uc001xov.1	7577	7428	2	2.48328
+uc021rwj.1	105	105	0	0
+uc001xpd.3	17423	17274	16.3643	8.73718
+uc001xpi.3	57921	57772	571.352	91.2124
+uc010tuo.2	52846	52697	20.8464	3.6485
+uc001xpo.3	24325	24176	196.411	74.929
+uc010asa.3	24325	24176	196.411	74.929
+uc010tuq.2	24325	24176	196.411	74.929
+uc001xpr.2	17788	17639	126.233	66.0036
+uc001xps.2	17788	17639	126.233	66.0036
+uc010tur.2	16740	16591	698.533	388.313
+uc001xpu.2	12774	12625	0	0
+uc001xpv.2	10778	10629	0	0
+uc001xpx.2	20210	20061	0	0
+uc001xpy.3	13442	13293	1228.5	852.354
+uc010tus.2	13442	13293	1228.5	852.354
+uc021rwm.1	72	72	0	0
+uc001xqa.3	114149	114000	128	10.3555
+uc001xqb.3	51853	51704	1667	297.358
+uc010tut.1	49206	49057	0	0
+uc001xqd.1	29809	29660	0	0
+uc001xqq.2	10802	10653	4	3.46303
+uc031qpi.1	10802	10653	4	3.46303
+uc010tux.2	18532	18383	326.519	163.817
+uc010asd.2	16843	16694	98.587	54.4662
+uc001xqx.1	4505	4356	310.904	658.274
+uc001xqy.1	12366	12217	35.9901	27.1698
+uc001xqz.3	13935	13786	10	6.69005
+uc001xrb.3	13935	13786	10	6.69005
+uc010ase.2	7636	7487	0	0
+uc010asf.2	7636	7487	0	0
+uc001xrd.1	37769	37620	217	53.1996
+uc001xre.1	37769	37620	217	53.1996
+uc010tuy.1	26905	26756	0	0
+uc001xrf.3	10809	10660	160.5	138.863
+uc001xrg.3	10809	10660	160.5	138.863
+uc001xrj.3	9571	9422	679.24	664.887
+uc001xrk.3	35212	35063	464.654	122.222
+uc001xrl.3	44961	44812	2206.36	454.097
+uc010asg.1	16293	16144	6156.99	3517.42
+uc010tuz.1	16430	16281	4.97357	2.81744
+uc001xrm.1	45179	45030	1148.29	235.19
+uc010ash.1	45179	45030	1148.29	235.19
+uc021rwq.1	81	81	0	0
+uc001xrt.3	10306	10157	1459	1324.82
+uc001xsc.2	23651	23502	399	156.58
+uc001xsd.3	18689	18540	0	0
+uc031qpk.1	27	27	0	0
+uc021rwr.1	87	87	0	0
+uc001xsu.1	4985	4836	116.117	221.45
+uc001xsv.3	25698	25549	1671	603.212
+uc001xsy.4	4157	4008	963	2215.98
+uc001xsz.3	33084	32935	0	0
+uc001xta.1	7012	6863	2	2.68772
+uc001xtb.1	5084	4935	0	0
+uc010asp.3	10522	10373	0	0
+uc001xtg.1	5822	5673	0	0
+uc001xth.1	26208	26059	1644.41	581.997
+uc001xti.2	45927	45778	1325.59	267.066
+uc010asr.2	21428	21279	0	0
+uc001xtn.1	2626	2477	248.474	925.174
+uc001xto.1	36102	35953	80.5255	20.6569
+uc001xtr.3	29035	28886	4.592	1.46616
+uc010tvi.2	16454	16305	7.408	4.19032
+uc001xtt.2	30966	30817	104.389	31.2415
+uc001xtu.2	30966	30817	104.389	31.2415
+uc001xtv.2	30966	30817	104.389	31.2415
+uc010tvj.2	30966	30817	104.389	31.2415
+uc021rwu.1	30966	30817	104.389	31.2415
+uc001xty.3	24473	24324	0.666667	0.252779
+uc001xtz.3	24473	24324	0.666667	0.252779
+uc001xua.3	24473	24324	0.666667	0.252779
+uc001xub.3	110771	110622	2611.28	217.71
+uc001xuc.1	35608	35459	639	166.204
+uc001xuf.3	43554	43405	436.741	92.8009
+uc010tvm.2	43554	43405	436.741	92.8009
+uc010tvn.1	43202	43053	0	0
+uc021rwx.1	119	119	0	0
+uc021rwy.1	73	73	0	0
+uc001xuo.1	9296	9147	0	0
+uc001xut.3	14001	13852	153.321	102.084
+uc010asx.3	14001	13852	153.321	102.084
+uc021rxa.1	14001	13852	153.321	102.084
+uc021rxb.1	14103	13954	790.501	522.482
+uc010asy.3	33530	33381	18.0138	4.97706
+uc010asz.3	359356	359207	348.008	8.93536
+uc031qpo.1	464720	464571	6.72809	0.13357
+uc001xux.2	443064	442915	0	0
+uc001xuy.1	74767	74618	0	0
+uc001xva.1	59547	59398	0	0
+uc010ata.1	36231	36082	47.4745	12.1349
+uc001xve.2	45501	45352	350.305	71.239
+uc001xvf.2	45501	45352	350.305	71.239
+uc001xvg.2	45780	45631	162.39	32.8221
+uc001xvi.1	140	140	0	0
+uc010tvt.3	18169	18020	1732.06	886.494
+uc010tvu.3	166563	166414	0	0
+uc001xvk.2	166755	166606	138.14	7.64709
+uc010atc.1	23304	23155	139.801	55.6845
+uc010tvv.2	62315	62166	3056	453.386
+uc001xvo.4	35052	34903	0	0
+uc001xvp.3	17715	17566	0	0
+uc001xvq.1	4856	4707	0	0
+uc010tvw.1	142829	142680	0	0
+uc001xvt.3	60258	60109	1.32664e-07	2.03554e-08
+uc010tvy.2	60258	60109	1.32664e-07	2.03554e-08
+uc010tvx.2	60652	60503	0	0
+uc010tvz.1	59037	58888	33	5.16839
+uc001xvu.2	29956	29807	0	0
+uc021rxg.1	104	104	0	0
+uc001xvx.3	29	29	0	0
+uc031qpr.1	28	28	0	0
+uc010twa.1	31	31	0	0
+uc021rxi.1	70	70	0	0
+uc021rxj.1	34	34	0	0
+uc031qps.1	45	45	0	0
+uc021rxk.1	28	28	0	0
+uc021rxl.1	40	40	0	0
+uc021rxm.1	30	30	0	0
+uc031qpt.1	45	45	0	0
+uc001xwa.3	31	31	0	0
+uc021rxo.1	30	30	0	0
+uc001xwb.3	52	52	0	0
+uc001xwc.3	39	39	0	0
+uc001xwd.1	30	30	0	0
+uc021rxp.1	31	31	0	0
+uc021rxq.1	46	46	0	0
+uc021rxr.1	37	37	0	0
+uc021rxs.1	34	34	0	0
+uc031qpu.1	30	30	0	0
+uc021rxu.1	31	31	0	0
+uc031qpv.1	30	30	0	0
+uc021rxv.1	34	34	0	0
+uc031qpw.1	30	30	0	0
+uc021rxw.1	30	30	0	0
+uc021rxx.1	30	30	0	0
+uc010twb.2	35	35	0	0
+uc001xwh.3	36	36	0	0
+uc031qpx.1	31	31	0	0
+uc021rxy.1	31	31	0	0
+uc021rxz.1	30	30	0	0
+uc001xwi.3	32	32	0	0
+uc031qpy.1	32	32	0	0
+uc021rya.1	35	35	0	0
+uc021ryb.1	1236	1087	0	0
+uc001xwm.3	90804	90655	1	0.101736
+uc001xwn.3	143142	142993	0	0
+uc001xwo.3	146805	146656	0	0
+uc001xwp.1	2185	2036	0	0
+uc010twc.2	84842	84693	1497.92	163.121
+uc001xwv.4	89002	88853	64.0767	6.65113
+uc010atf.1	58590	58441	0	0
+uc001xxd.3	4883	4734	16.2671	31.6921
+uc001xxe.3	6590	6441	33.9107	48.557
+uc001xxf.3	50660	50511	24.795	4.52737
+uc021ryf.1	177923	177774	9.11298	0.472781
+uc021ryg.1	177923	177774	9.11298	0.472781
+uc001xxh.1	93439	93290	16.9708	1.67778
+uc001xxn.4	260939	260790	1352.41	47.8285
+uc001xxo.4	462979	462830	15.6576	0.312012
+uc010atk.3	462979	462830	15.6576	0.312012
+uc031qqb.1	2152	2003	0	0
+uc001xxp.2	207217	207068	30.9709	1.37946
+uc001xxs.3	157399	157250	0	0
+uc001xxt.3	157621	157472	56.7012	3.32091
+uc001xxu.3	6832	6683	0	0
+uc001xxv.1	117725	117576	160.736	12.6084
+uc001xxw.2	31198	31049	0	0
+uc001xxx.2	31420	31271	0	0
+uc010atp.1	34490	34341	461.7	123.998
+uc001xyi.2	54084	53935	26.15	4.47165
+uc001xyj.2	54084	53935	26.15	4.47165
+uc001xyo.3	103621	103472	0	0
+uc010ats.3	149125	148976	0	0
+uc001xyp.3	275830	275681	1491.34	49.8929
+uc010twi.1	189312	189163	0	0
+uc001xys.2	189827	189678	44.0493	2.14185
+uc001xyt.3	166675	166526	0	0
+uc010att.1	160039	159890	0	0
+uc001xzg.3	11977	11828	0	0
+uc001xzh.3	21349	21200	0	0
+uc021ryk.1	1098	949	0	0
+uc001xzi.3	12301	12152	518.264	393.343
+uc001xzj.3	14340	14191	0	0
+uc010aty.3	146522	146373	1574.74	99.2235
+uc010twk.1	77729	77580	0	0
+uc021ryl.1	38706	38557	0	0
+uc001xzl.4	39204	39055	0	0
+uc001xzm.3	52689	52540	7.04557e-08	1.23678e-08
+uc001xzn.3	52858	52709	404.942	70.8559
+uc001xzo.3	52858	52709	404.942	70.8559
+uc010atz.3	52858	52709	404.942	70.8559
+uc001xzp.1	47656	47507	0	0
+uc001xzq.1	7553	7404	121.354	151.167
+uc010aua.3	2331	2182	0	0
+uc010aub.1	89199	89050	41.5083	4.29901
+uc001xzs.1	151296	151147	0	0
+uc001xzt.4	56583	56434	13.3333	2.17904
+uc001xzu.4	56583	56434	13.3333	2.17904
+uc010auc.3	56583	56434	13.3333	2.17904
+uc001xzv.4	87614	87465	0	0
+uc021rym.1	113	113	0	0
+uc001xzw.3	5406	5257	23.946	42.011
+uc010aud.3	77363	77214	4.20202e-06	5.01914e-07
+uc001xzx.4	78292	78143	186.208	21.9774
+uc010aue.3	78292	78143	186.208	21.9774
+uc010auf.2	47963	47814	107.398	20.7162
+uc001xzy.3	72161	72012	440.44	56.4092
+uc001xzz.4	9675	9526	0	0
+uc001yaa.3	5762	5613	14	23.0039
+uc001yab.3	5872	5723	1.60801e-07	2.59139e-07
+uc001yac.4	48070	47921	3.72641	0.717187
+uc001yad.4	48070	47921	3.72641	0.717187
+uc001yae.4	48070	47921	3.72641	0.717187
+uc010aug.3	48070	47921	3.72641	0.717187
+uc010twl.2	48070	47921	3.72641	0.717187
+uc021ryo.1	48070	47921	3.72641	0.717187
+uc021ryp.1	48070	47921	3.72641	0.717187
+uc021ryq.1	48070	47921	3.72641	0.717187
+uc021ryr.1	48070	47921	3.72641	0.717187
+uc021rys.1	48070	47921	3.72641	0.717187
+uc021ryt.1	48070	47921	3.72641	0.717187
+uc021ryu.1	48070	47921	3.72641	0.717187
+uc021ryv.1	48070	47921	3.72641	0.717187
+uc021ryw.1	48070	47921	3.72641	0.717187
+uc021ryx.1	48070	47921	3.72641	0.717187
+uc021ryy.1	48070	47921	3.72641	0.717187
+uc021ryz.2	48070	47921	3.72641	0.717187
+uc021rza.1	48070	47921	3.72641	0.717187
+uc021rzb.1	48070	47921	3.72641	0.717187
+uc021rzc.1	48070	47921	3.72641	0.717187
+uc021rzd.1	48070	47921	3.72641	0.717187
+uc021rze.1	48070	47921	3.72641	0.717187
+uc021rzf.1	48070	47921	3.72641	0.717187
+uc021rzg.1	48070	47921	3.72641	0.717187
+uc021rzh.1	48070	47921	3.72641	0.717187
+uc021rzi.1	48070	47921	3.72641	0.717187
+uc021rzj.1	48070	47921	3.72641	0.717187
+uc021rzk.1	48070	47921	3.72641	0.717187
+uc021rzl.1	48070	47921	3.72641	0.717187
+uc021rzm.1	48070	47921	3.72641	0.717187
+uc021rzn.1	48070	47921	3.72641	0.717187
+uc021rzo.1	35860	35711	0	0
+uc021rzp.1	25216	25067	0	0
+uc021rzq.1	35687	35538	0	0
+uc021rzr.1	35687	35538	0	0
+uc021rzs.1	35687	35538	0	0
+uc021rzt.1	35687	35538	0	0
+uc021rzu.1	35687	35538	0	0
+uc021rzv.1	35687	35538	0	0
+uc021rzw.1	35687	35538	0	0
+uc021rzx.1	35687	35538	0	0
+uc021rzy.1	35687	35538	0	0
+uc021rzz.1	35687	35538	0	0
+uc021saa.1	35687	35538	0	0
+uc021sab.1	35687	35538	0	0
+uc021sac.1	35687	35538	0	0
+uc021sad.1	35687	35538	0	0
+uc021sae.1	35687	35538	0	0
+uc021saf.2	35687	35538	0	0
+uc021sag.1	35687	35538	0	0
+uc021sah.1	35687	35538	0	0
+uc021sai.1	35687	35538	0	0
+uc021saj.1	35687	35538	0	0
+uc021sak.1	35687	35538	0	0
+uc021sal.1	35687	35538	0	0
+uc021sam.1	35687	35538	0	0
+uc021san.1	35687	35538	0	0
+uc021sao.1	35687	35538	0	0
+uc021sap.1	35687	35538	0	0
+uc021saq.1	35687	35538	0	0
+uc021sar.1	35687	35538	0	0
+uc021sas.1	35687	35538	0	0
+uc021sat.1	35687	35538	0	0
+uc021sau.2	35687	35538	0	0
+uc021sav.1	25669	25520	36.4813	13.1843
+uc001yaf.3	5686	5537	479	797.864
+uc001yag.1	2931	2782	0	0
+uc001yal.1	813	664	0	0
+uc001yam.1	871	722	0	0
+uc001yat.3	29022	28873	1177.47	376.119
+uc001yau.3	29022	28873	1177.47	376.119
+uc001yav.3	44896	44747	124.031	25.5643
+uc001yaw.3	44896	44747	124.031	25.5643
+uc001ybe.2	179005	178856	250.632	12.9241
+uc001ybf.3	175583	175434	1515.01	79.6472
+uc001ybg.3	176196	176047	704.677	36.9172
+uc001ybh.3	176196	176047	704.677	36.9172
+uc001ybj.3	2709	2560	431	1552.76
+uc021saw.1	1056	907	0	0
+uc001ybl.1	4223	4074	220	498.046
+uc010aur.3	57388	57239	546.013	87.979
+uc010two.2	57388	57239	546.013	87.979
+uc001ybo.3	95490	95341	8.98455	0.869129
+uc001ybp.3	95490	95341	8.98455	0.869129
+uc001ybq.4	39418	39269	0	0
+uc001ybr.3	45412	45263	19.0045	3.87241
+uc001ybw.1	70123	69974	0	0
+uc001ybx.1	70123	69974	0	0
+uc001yby.2	21643	21494	0	0
+uc001ycb.2	6343	6194	0	0
+uc001ycc.2	23269	23120	0	0
+uc001ycd.3	42578	42429	0	0
+uc001yce.1	17882	17733	0	0
+uc001ycj.3	30291	30142	1906.33	583.303
+uc010twq.2	30291	30142	1906.33	583.303
+uc010twr.2	30291	30142	1906.33	583.303
+uc001ycq.3	1840	1691	10	54.5411
+uc001yct.3	9712	9563	0	0
+uc001ycu.5	9959	9810	0	0
+uc001ycv.3	19104	18955	0	0
+uc010auv.3	19104	18955	0	0
+uc001ycw.4	6495	6346	0	0
+uc001ycx.4	12070	11921	0	0
+uc001ycy.4	13946	13797	0	0
+uc001ycz.4	13946	13797	0	0
+uc001ydb.4	13946	13797	0	0
+uc001ydc.4	13946	13797	0	0
+uc010auw.3	13946	13797	0	0
+uc010aux.3	13946	13797	0	0
+uc010auy.3	13946	13797	0	0
+uc010auz.3	13946	13797	0	0
+uc010ava.3	13946	13797	0	0
+uc010avb.3	13946	13797	0	0
+uc001yda.1	9548	9399	0	0
+uc001ydd.1	10322	10173	0	0
+uc001yde.3	13613	13464	0	0
+uc001ydf.3	13613	13464	0	0
+uc001ydg.3	13613	13464	0	0
+uc010avc.3	13613	13464	0	0
+uc001ydh.1	11708	11559	0	0
+uc001ydi.1	11708	11559	0	0
+uc001ydj.3	30562	30413	0	0
+uc001ydu.3	1940	1791	0	0
+uc010avh.1	19996	19847	263.865	122.618
+uc021sbc.1	47276	47127	986.316	193.025
+uc001ydv.3	50583	50434	0	0
+uc001ydw.2	55521	55372	0	0
+uc001ydx.2	71195	71046	0	0
+uc001ydy.1	8702	8553	0	0
+uc021sbd.1	11671	11522	73.4508	58.7945
+uc001ydz.1	24908	24759	0.0278167	0.0103619
+uc001yea.1	24908	24759	0.0278167	0.0103619
+uc001yeb.1	24908	24759	0.0278167	0.0103619
+uc001yec.1	24696	24547	13.5041	5.0738
+uc021sbe.1	68	68	0	0
+uc001yef.2	137970	137821	66.0216	4.41813
+uc001yeh.4	2824	2675	56	193.078
+uc001yei.4	58343	58194	138.62	21.9692
+uc010avi.3	58343	58194	138.62	21.9692
+uc001yej.1	31685	31536	53.761	15.7227
+uc001yek.3	1961	1812	98.5	501.355
+uc001yel.3	1961	1812	98.5	501.355
+uc001yfb.4	4230	4081	0	0
+uc001yfc.4	4230	4081	0	0
+uc031qqd.1	4230	4081	0	0
+uc001yfi.3	82084	81935	571	64.2739
+uc001yfv.2	54012	53863	1.00161	0.171505
+uc001yfw.2	52515	52366	0	0
+uc001yfx.2	45063	44914	0	0
+uc001yfy.2	20195	20046	0	0
+uc010avq.2	20195	20046	0	0
+uc021sbl.1	41	41	0	0
+uc001yga.3	102198	102049	0	0
+uc001ygb.3	102198	102049	0	0
+uc031qqh.1	102198	102049	0	0
+uc031qqi.1	102198	102049	0	0
+uc031qqj.1	82499	82350	590.547	66.1391
+uc001ygc.3	83144	82995	387.453	43.0561
+uc001ygd.3	71086	70937	0	0
+uc021sbn.1	70794	70645	0	0
+uc001ygf.3	69611	69462	0	0
+uc010avr.3	93125	92976	4125.51	409.237
+uc001ygx.2	13260	13111	13	9.14482
+uc010avv.3	4619	4470	2595.1	5354.43
+uc001yha.3	15408	15259	528.952	319.711
+uc010twx.2	15408	15259	528.952	319.711
+uc010avw.3	10866	10717	5.84164e-06	5.02724e-06
+uc001yhg.2	41803	41654	1238.21	274.161
+uc001yhh.1	41803	41654	1238.21	274.161
+uc001yhi.1	41803	41654	1238.21	274.161
+uc001yhk.1	42556	42407	1154.51	251.089
+uc001yhl.1	42556	42407	1154.51	251.089
+uc010twz.1	21398	21249	0	0
+uc001yhp.3	9633	9484	1191.89	1159.08
+uc010txa.2	30924	30775	1880.75	563.638
+uc001yhq.3	32648	32499	207.36	58.8468
+uc010txj.1	4193	4044	0	0
+uc031qqm.1	21	21	0	0
+uc001ykb.1	3454	3305	6.27637	17.5148
+uc001ykd.1	8181	8032	9.04937	10.3911
+uc001yke.3	3105	2956	1.57537	4.91525
+uc031qqn.1	3105	2956	1.57537	4.91525
+uc001ykf.3	3100	2951	7.76176	24.2582
+uc001ykg.3	3100	2951	7.76176	24.2582
+uc001ykh.3	3096	2947	0	0
+uc021sdw.1	136	136	0	0
+uc001yku.4	6438	6289	24671.2	36180.6
+uc001ykv.4	59012	58863	35.8363	5.61498
+uc001ykw.1	3714	3565	0	0
+uc001ykx.1	3387	3238	0	0
+uc001ylh.4	16125	15976	51.7262	29.8614
+uc001ylj.4	11801	11652	37.4979	29.6807
+uc001ylk.4	11801	11652	37.4979	29.6807
+uc001yll.4	11801	11652	37.4979	29.6807
+uc001ylm.4	76380	76231	12.6053	1.52507
+uc001yln.4	76380	76231	12.6053	1.52507
+uc010txv.3	76380	76231	12.6053	1.52507
+uc001ylu.1	16977	16828	511.38	280.271
+uc021sea.1	14436	14287	0	0
+uc001ylv.1	14638	14489	18.1323	11.542
+uc021seb.1	14638	14489	18.1323	11.542
+uc001ylx.1	1957	1808	23.2597	118.652
+uc001ylz.1	2931	2782	148.526	492.393
+uc001yma.1	2931	2782	148.526	492.393
+uc021sec.1	954	805	407.689	4670.9
+uc001ymi.1	125027	124878	6070.82	448.362
+uc001ymj.1	20760	20611	1504.02	673.01
+uc001ymn.3	1808	1659	0	0
+uc001ymp.1	694	545	2	33.8455
+uc001ynf.2	3202	3053	31419	94914.7
+uc001ynh.2	5775	5626	622.317	1020.19
+uc001yni.2	5775	5626	622.317	1020.19
+uc001ynj.2	6271	6122	49.371	74.3783
+uc021seg.1	1344	1195	291.994	2253.59
+uc001ynu.1	1647	1498	0	0
+uc001ynv.1	1660	1511	0	0
+uc001ynx.4	17870	17721	398.153	207.219
+uc001yny.4	17870	17721	398.153	207.219
+uc001ynz.4	17870	17721	398.153	207.219
+uc001yoa.4	17870	17721	398.153	207.219
+uc021sei.1	20	20	0	0
+uc010awv.1	12803	12654	633.353	461.621
+uc001yof.1	113840	113691	86.6785	7.03158
+uc001yog.1	107062	106913	0	0
+uc001yoi.4	9279	9130	1393.61	1407.8
+uc001yoj.4	9279	9130	1393.61	1407.8
+uc001yok.3	9057	8908	0	0
+uc010aww.2	9057	8908	0	0
+uc031qqp.1	1883	1734	0	0
+uc021sej.1	86	86	0	0
+uc001you.2	2237	2088	0	0
+uc001yov.1	1201	1052	0	0
+uc001yox.1	10678	10529	0	0
+uc021sek.1	56	56	1	164.695
+uc001ypj.3	2372	2223	592.883	2459.79
+uc010tyk.2	8329	8180	4174.05	4706.22
+uc001ypk.3	24252	24103	33.3262	12.7521
+uc001ypl.3	24252	24103	33.3262	12.7521
+uc010axa.3	24842	24693	463.371	173.07
+uc001ypm.3	26394	26245	271.02	95.2405
+uc001ypn.3	26394	26245	271.02	95.2405
+uc021sen.1	4440	4291	30.1699	64.846
+uc021seo.1	16652	16503	8304.66	4641.16
+uc001ypx.2	33230	33081	951.349	265.234
+uc010axc.1	41104	40955	98.8246	22.2549
+uc001yqa.2	11516	11367	422.97	343.188
+uc001yqb.2	11516	11367	422.97	343.188
+uc021sep.1	726	577	1148.06	18350.9
+uc001yqc.3	6767	6618	2	2.78722
+uc001yqd.3	16018	15869	0	0
+uc001yqe.3	16018	15869	0	0
+uc010axe.1	10031	9882	0	0
+uc001yqf.4	10423	10274	5162.34	4634.2
+uc001yqg.4	27844	27695	3313.83	1103.56
+uc001yqh.4	27844	27695	3313.83	1103.56
+uc001yqi.4	8387	8238	214	239.585
+uc010tyn.3	8387	8238	214	239.585
+uc001yqk.2	13107	12958	493.271	351.087
+uc001yql.2	38600	38451	0.696621	0.167092
+uc001yqo.2	40119	39970	161.141	37.1825
+uc001yqp.2	91707	91558	248.197	25.0016
+uc010axg.1	91707	91558	248.197	25.0016
+uc010tyo.1	106292	106143	6.41266e-05	5.57204e-06
+uc010typ.1	106292	106143	6.41266e-05	5.57204e-06
+uc001yqn.2	38457	38308	7.53597e-08	1.81434e-08
+uc010axh.1	38457	38308	7.53597e-08	1.81434e-08
+uc010axi.1	10793	10644	0	0
+uc010axj.1	21252	21103	0	0
+uc001yqr.3	44807	44658	0	0
+uc031qqx.1	1288830	1.28868e+06	1857.4	13.2932
+uc001yrs.3	277245	277096	0	0
+uc001yrt.3	277622	277473	0	0
+uc010axp.1	290	141	0	0
+uc001yru.2	2323	2174	0	0
+uc001yrw.1	263185	263036	0	0
+uc001yrx.2	264192	264043	0	0
+uc001yry.1	180	31	0	0
+uc001yrz.2	224573	224424	0	0
+uc001ysb.2	4706	4557	0	0
+uc031qqy.1	3257	3108	0	0
+uc001ysc.3	639	490	0	0
+uc001ysd.1	290	141	0	0
+uc001yse.3	127790	127641	0	0
+uc001ysg.1	5201	5052	0	0
+uc001ysh.1	8273	8124	0	0
+uc001ysi.2	8273	8124	0	0
+uc001ysj.3	26364	26215	0	0
+uc001ysk.1	24815	24666	0	0
+uc001ysl.1	24815	24666	0	0
+uc001ysm.2	25822	25673	0	0
+uc001ysn.1	26820	26671	0	0
+uc021set.1	2474	2325	0	0
+uc001ysu.1	2540	2391	0	0
+uc001ysv.3	21198	21049	0	0
+uc001ysw.1	741	592	0	0
+uc001ysx.1	4114	3965	0	0
+uc001ysz.3	1023	874	0	0
+uc001yta.1	1088	939	0	0
diff --git a/inst/extdata/kallisto/abundance.txt b/inst/extdata/kallisto/abundance.txt
new file mode 100644
index 0000000..91a23bd
--- /dev/null
+++ b/inst/extdata/kallisto/abundance.txt
@@ -0,0 +1,16 @@
+target_id	length	eff_length	est_counts	tpm
+NM_001168316	2283	2105.9	164.133	12856.9
+NM_174914	2385	2207.9	1495.6	111741
+NR_031764	1853	1675.9	104.27	10263.4
+NM_004503	1681	1503.9	332.001	36416.5
+NM_006897	1541	1363.9	664	80308.9
+NM_014212	2037	1859.9	55	4878.11
+NM_014620	2300	2122.9	592.584	46046.7
+NM_017409	1959	1781.9	47	4351.04
+NM_017410	2396	2218.9	42	3122.41
+NM_018953	1612	1434.9	227.995	26210.8
+NM_022658	2288	2110.9	4881	381434
+NM_153633	1666	1488.9	359.898	39874.2
+NM_153693	2072	1894.9	72.5147	6312.74
+NM_173860	849	671.903	962	236182
+NR_003084	1640	1462.9	0.00787013	0.887453
diff --git a/inst/extdata/kallisto/run_info.json b/inst/extdata/kallisto/run_info.json
new file mode 100644
index 0000000..d5eb080
--- /dev/null
+++ b/inst/extdata/kallisto/run_info.json
@@ -0,0 +1,8 @@
+{
+	"n_targets": 2858,
+	"n_bootstraps": 100,
+	"kallisto_version": "0.42.2",
+	"index_version": 10,
+	"start_time": "Wed Jun 10 15:03:26 2015",
+	"call": "../kallisto/build/src/kallisto quant -i hg19chr14transcripts.idx -o output -b 100 --single -l 150 /dev/fd/63"
+}
diff --git a/inst/scripts/Find_and_update_objects/README b/inst/scripts/Find_and_update_objects/README
new file mode 100644
index 0000000..e51f3de
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/README
@@ -0,0 +1,68 @@
+Find and update objects
+=======================
+
+This document describes the procedure for finding and updating serialized
+objects in the rda files located in a directory hierarchy. This procedure
+consists of 4 STEPS, as described below.
+
+Note that this procedure was developped and used to update all "old"
+serialized SummarizedExperiment objects located in the data-experiment svn
+repository. It should be easy to adapt to update other types of objects in
+other locations.
+
+Also note that the purpose of STEPS 1 & 2 & 3 below is to collect the list
+of rda objects to update. Since this can take a long time, the 2 lists
+obtained for the "old" serialized SummarizedExperiment objects located
+in https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/pkgs and
+https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/data_store were saved
+to the pkgs_RDA_OBJECTS_TO_UPDATE and data_store_RDA_OBJECTS_TO_UPDATE
+files, respectively, and these 2 files placed in this folder. So in case
+these objects need to be updated again, these 2 files can be re-used to run
+STEP 4 directly without the need to re-run STEPS 1 & 2 & 3.
+
+STEP 1: Prepare list of rda files to scan.
+
+  cd <dir/you/want/to/search>
+  find . -type d -name '.svn' -prune -o -type f -print | \
+      grep -Ei '\.(rda|RData)$' >RDA_FILES
+
+STEP 2: Scan the rda files.
+
+  cd <dir/you/want/to/search>
+
+  R="$HOME/bin/R-3.2"
+  R_SCRIPT="scriptfile <- system.file('scripts', 'Find_and_update_objects', "
+  R_SCRIPT="$R_SCRIPT 'scan_rda_files.R', "
+  R_SCRIPT="$R_SCRIPT package='SummarizedExperiment', mustWork=TRUE)"
+  R_SCRIPT="$R_SCRIPT; source(scriptfile)"
+  echo "$R_SCRIPT" | $R --vanilla >scan_rda_files.log 2>&1 &
+
+STEP 3: Collect rda objects to update.
+
+  cd <dir/you/want/to/search>
+
+  R="$HOME/bin/R-3.2"
+  R_SCRIPT="scriptfile <- system.file('scripts', 'Find_and_update_objects', "
+  R_SCRIPT="$R_SCRIPT 'collect_rda_objects_to_update.R', "
+  R_SCRIPT="$R_SCRIPT package='SummarizedExperiment', mustWork=TRUE)"
+  R_SCRIPT="$R_SCRIPT; source(scriptfile)"
+  echo "$R_SCRIPT" | $R --vanilla >collect_rda_objects_to_update.log 2>&1 &
+
+STEP 4: Update rda objects.
+
+  cd <dir/you/want/to/search>
+
+  #To update the "old" serialized SummarizedExperiment objects located in 
+  #  https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/pkgs
+  #replace the above command with
+  #  svn co https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/pkgs
+  #  cp path/to/pkgs_RDA_OBJECTS_TO_UPDATE pkgs/RDA_OBJECTS_TO_UPDATE
+  #  cd pkgs
+
+  R="$HOME/bin/R-3.2"
+  R_SCRIPT="scriptfile <- system.file('scripts', 'Find_and_update_objects', "
+  R_SCRIPT="$R_SCRIPT 'update_rda_objects.R', "
+  R_SCRIPT="$R_SCRIPT package='SummarizedExperiment', mustWork=TRUE)"
+  R_SCRIPT="$R_SCRIPT; source(scriptfile)"
+  echo "$R_SCRIPT" | $R --vanilla >update_rda_objects.log 2>&1 &
+
diff --git a/inst/scripts/Find_and_update_objects/collect_rda_objects_to_update.R b/inst/scripts/Find_and_update_objects/collect_rda_objects_to_update.R
new file mode 100644
index 0000000..0d07e43
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/collect_rda_objects_to_update.R
@@ -0,0 +1,133 @@
+### =========================================================================
+### collect_rda_objects_to_update.R
+### -------------------------------------------------------------------------
+###
+### This script performs STEP 3 of the "Find and update objects" procedure
+### described in the README file located in the same folder.
+###
+### Before you run this script, make sure you performed STEPS 1 & 2.
+### See README file for more information.
+###
+### Then to run STEP 3 in "batch" mode:
+###
+###   cd <dir/you/want/to/search>  # RDA_OBJECTS file should be here
+###   R CMD BATCH collect_rda_objects_to_update.R \
+###              >collect_rda_objects_to_update.log 2>&1 &
+###
+### The output of STEP 3 is a file created in the current directory and named
+### RDA_OBJECTS_TO_UPDATE. It is a subset of input file RDA_OBJECTS.
+###
+
+INFILE <- "RDA_OBJECTS"
+OUTFILE <- "RDA_OBJECTS_TO_UPDATE"
+
+library(BiocInstaller)
+library(SummarizedExperiment)
+
+if (FALSE) {
+### Unfortunately, loading all the required packages in the main process will
+### sometimes hit the maximal number of DLLs that can be loaded ("maximal
+### number of DLLs reached..." infamous error).
+.check_classes <- function(classes, package)
+{
+    suppressWarnings(suppressPackageStartupMessages(
+        library(package, character.only=TRUE, quietly=TRUE)
+    ))
+    sapply(classes, function(class) {
+           extends(class, "SummarizedExperiment") ||
+           extends(class, "RangedSummarizedExperiment")
+    })
+}
+}
+
+### We check the classes in a subprocess to work around the "maximal number
+### of DLLs reached..." infamous error.
+.check_classes <- function(classes, package)
+{
+    classes_in1string <- paste0("\"", classes, "\"")
+    classes_in1string <- paste0("c(",
+                                paste(classes_in1string, collapse=", "),
+                                ")")
+    outfile <- file.path(tempdir(), paste0(package, "_class_summary"))
+    input <- c("suppressWarnings(suppressPackageStartupMessages(",
+       sprintf("    library(%s)", "SummarizedExperiment"),
+               "))",
+               "suppressWarnings(suppressPackageStartupMessages(",
+       sprintf("    library(%s)", package),
+               "))",
+       sprintf("classes <- %s", classes_in1string),
+               "ok <- sapply(classes, function(class) {",
+               "    extends(class, \"SummarizedExperiment\") ||",
+               "    extends(class, \"RangedSummarizedExperiment\")",
+               "})",
+               "class_summary <- data.frame(class=classes, ok=unname(ok))",
+       sprintf("write.table(class_summary, file=\"%s\", sep=\"\t\")", outfile)
+    )
+    command <- file.path(R.home("bin"), "R")
+    args <- c("--vanilla", "--slave")
+    system2(command, args=args, input=input)
+    class_summary <- read.table(outfile, stringsAsFactors=FALSE)
+    file.remove(outfile)
+    stopifnot(identical(class_summary[ , "class"], classes))  # sanity check
+    setNames(class_summary[ , "ok"], classes)
+}
+
+collectRdaObjectsToUpdate <- function(rda_objects, outfile="")
+{
+    rda_objects2 <- unique(rda_objects[ , c("objclass", "objclass_pkg")])
+    objclass2 <- rda_objects2[ , "objclass"]
+    objclass_pkg2 <- rda_objects2[ , "objclass_pkg"]
+    idx <- which(duplicated(objclass2))
+    if (length(idx) != 0L) {
+        msg <- c("the following classes are defined in more than 1 package: ",
+                 paste0(unique(objclass2[idx]), collapse=", "))
+        warning(msg)
+    }
+    pkg2class <- split(objclass2, objclass_pkg2)
+    pkg2class[c(".", ".GlobalEnv")] <- NULL
+    pkgs <- names(pkg2class)
+
+    ## Install missing packages.
+    installed_pkgs <- rownames(installed.packages())
+    missing_pkgs <- setdiff(pkgs, installed_pkgs)
+    if (length(missing_pkgs) != 0L) {
+        biocLite(missing_pkgs)
+        installed_pkgs <- rownames(installed.packages())
+        missing_pkgs <- setdiff(pkgs, installed_pkgs)
+        if (length(missing_pkgs) != 0L) {
+            ## Some packages could not be installed.
+            pkgs <- intersect(pkgs, installed_pkgs)
+            pkg2class <- pkg2class[pkgs]
+        }
+    }
+
+    ## Check classes, one package at a time.
+    class2ok <- unlist(
+        lapply(seq_along(pkgs),
+            function(i) {
+                pkg <- pkgs[[i]]
+                cat("[", i , "/", length(pkgs), "] Check classes defined ",
+                    "in package ", pkg, " ... ", sep="")
+                ans <- .check_classes(pkg2class[[pkg]], pkg)
+                cat("OK\n")
+                ans
+            }
+        )
+    )
+
+    ## Write output to file.
+    objclass <- rda_objects[ , "objclass"]
+    ok <- class2ok[objclass]
+    ok[is.na(ok)] <- FALSE
+    rda_objects_to_update <- rda_objects[ok, , drop=FALSE]
+    rda_objects_to_update <- do.call(
+        paste,
+        c(as.list(rda_objects_to_update), list(sep="\t"))
+    )
+    writeLines(rda_objects_to_update, con=outfile)
+}
+
+rda_objects <- read.table(INFILE, stringsAsFactors=FALSE)
+colnames(rda_objects) <- c("rda_file", "objname", "objclass", "objclass_pkg")
+collectRdaObjectsToUpdate(rda_objects, outfile=OUTFILE)
+
diff --git a/inst/scripts/Find_and_update_objects/data_store_RDA_OBJECTS_TO_UPDATE b/inst/scripts/Find_and_update_objects/data_store_RDA_OBJECTS_TO_UPDATE
new file mode 100644
index 0000000..d9e6e4f
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/data_store_RDA_OBJECTS_TO_UPDATE
@@ -0,0 +1,30 @@
+# This file contains the list of rda objects to update located in
+#   https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/data_store
+# It was obtained by running STEPS 1 & 2 & 3 of the "Find and update objects"
+# procedure on May 26, 2015. See README file for more information.
+# To update the objects listed in this file:
+#   1. Get a working copy of the above URL.
+#   2. Copy this file to the working copy and rename it RDA_OBJECTS_TO_UPDATE.
+#   3. Run STEP 4 (see README file for more information).
+./geuvPack/data/geuFPKM.rda	geuFPKM	SummarizedExperiment	GenomicRanges
+./bsseqData/data/BS.cancer.ex.fit.rda	BS.cancer.ex.fit	BSseq	bsseq
+./bsseqData/data/BS.cancer.ex.rda	BS.cancer.ex	BSseq	bsseq
+./fission/data/fission.RData	fission	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_010_04.RData	dream4_010_04	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_100_01.RData	dream4_100_01	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_010_01.RData	dream4_010_01	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_010_05.RData	dream4_010_05	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_010_02.RData	dream4_010_02	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_100_04.RData	dream4_100_04	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_010_03.RData	dream4_010_03	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_100_05.RData	dream4_100_05	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_100_02.RData	dream4_100_02	SummarizedExperiment	GenomicRanges
+./DREAM4/data/dream4_100_03.RData	dream4_100_03	SummarizedExperiment	GenomicRanges
+./COSMIC.67/data/cosmic_67.rda	cosmic_67	CollapsedVCF	VariantAnnotation
+./parathyroidSE/data/parathyroidGenesSE.RData	parathyroidGenesSE	SummarizedExperiment	GenomicRanges
+./parathyroidSE/data/parathyroidExonsSE.RData	parathyroidExonsSE	SummarizedExperiment	GenomicRanges
+./RRBSdata/data/rrbs.RData	rrbs	BSraw	BiSeq
+./airway/data/airway.RData	airway	SummarizedExperiment	GenomicRanges
+./dsQTL/data/DSQ_2.rda	DSQ_2	SummarizedExperiment	GenomicRanges
+./dsQTL/data/DSQ_17.rda	DSQ_17	SummarizedExperiment	GenomicRanges
+./dsQTL/data/DHStop5_hg19.rda	DHStop5_hg19	SummarizedExperiment	GenomicRanges
diff --git a/inst/scripts/Find_and_update_objects/pkgs_RDA_OBJECTS_TO_UPDATE b/inst/scripts/Find_and_update_objects/pkgs_RDA_OBJECTS_TO_UPDATE
new file mode 100644
index 0000000..d10769a
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/pkgs_RDA_OBJECTS_TO_UPDATE
@@ -0,0 +1,9 @@
+# This file contains the list of rda objects to update located in
+#   https://hedgehog.fhcrc.org/bioc-data/trunk/experiment/pkgs
+# It was obtained by running STEPS 1 & 2 & 3 of the "Find and update objects"
+# procedure on May 26, 2015. See README file for more information.
+# To update the objects listed in this file:
+#   1. Get a working copy of the above URL.
+#   2. Copy this file to the working copy and rename it RDA_OBJECTS_TO_UPDATE.
+#   3. Run STEP 4 (see README file for more information).
+./pasilla/data/pasillaDEXSeqDataSet.RData	dxd	DEXSeqDataSet	DEXSeq
diff --git a/inst/scripts/Find_and_update_objects/scan_rda_files.R b/inst/scripts/Find_and_update_objects/scan_rda_files.R
new file mode 100644
index 0000000..5bcd019
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/scan_rda_files.R
@@ -0,0 +1,68 @@
+### =========================================================================
+### scan_rda_files.R
+### -------------------------------------------------------------------------
+###
+### This script performs STEP 2 of the "Find and update objects" procedure
+### described in the README file located in the same folder.
+###
+### Before you run this script, make sure you performed STEP 1, that is, you
+### need to generate input file RDA_FILES. This can be achieved with
+### something like:
+###
+###   cd <dir/you/want/to/search>
+###   find . -type d -name '.svn' -prune -o -type f -print | \
+###       grep -Ei '\.(rda|RData)$' >RDA_FILES
+###
+### See README file for more information.
+###
+### Then to run STEP 2 in "batch" mode:
+###
+###   cd <dir/you/want/to/search>  # RDA_FILES file should be here
+###   R CMD BATCH scan_rda_files.R >scan_rda_files.log 2>&1 &
+###
+### This can take a couple of hours to complete...
+###
+### The output of STEP 2 is a file created in the current directory and named
+### RDA_OBJECTS. It has 1 line per serialized object and the 4 following
+### fields (separated by tabs):
+###   1. Path to rda file (as found in input file RDA_FILES).
+###   2. Name of object in rda file.
+###   3. Class of object in rda file.
+###   4. Package where class of object is defined.
+###
+
+INFILE <- "RDA_FILES"
+OUTFILE <- "RDA_OBJECTS"
+
+scanRdaFiles <- function(rda_files, outfile="")
+{
+    cat("", file=outfile)  # create (or overwrite) empty output file
+    for (i in seq_along(rda_files)) {
+        rda_file <- rda_files[[i]]
+
+        cat("[", i , "/", length(rda_files), "] Loading ", rda_file, " ... ",
+            sep="")
+        envir <- new.env(parent=emptyenv())
+        load(rda_file, envir=envir)
+        cat("OK\n")
+
+        for (objname in names(envir)) {
+            obj <- get(objname, envir=envir)
+            objclass <- class(obj)
+            objclass_pkg <- attr(objclass, "package")
+
+            ## Fix 'objclass' and 'objclass_pkg' (they both need to be
+            ## character vectors of length 1 before we pass them to paste()).
+            objclass <- objclass[[1L]]
+            if (is.null(objclass_pkg))
+                objclass_pkg <- "."
+            outline <- paste(rda_file, objname, objclass, objclass_pkg,
+                             sep="\t")
+            cat(outline, "\n", sep="", file=OUTFILE, append=TRUE)
+        }
+    }
+}
+
+rda_files <- read.table(INFILE, stringsAsFactors=FALSE)[[1L]]
+scanRdaFiles(rda_files, outfile=OUTFILE)
+
diff --git a/inst/scripts/Find_and_update_objects/update_rda_objects.R b/inst/scripts/Find_and_update_objects/update_rda_objects.R
new file mode 100644
index 0000000..fd9aa14
--- /dev/null
+++ b/inst/scripts/Find_and_update_objects/update_rda_objects.R
@@ -0,0 +1,70 @@
+### =========================================================================
+### update_rda_objects.R
+### -------------------------------------------------------------------------
+###
+### This script performs STEP 4 of the "Find and update objects" procedure
+### described in the README file located in the same folder.
+###
+### Before you run this script, make sure you performed STEPS 1 & 2 & 3.
+### See README file for more information.
+###
+### Then to run STEP 4 in "batch" mode:
+###
+###   cd <dir/you/want/to/search>  # RDA_OBJECTS_TO_UPDATE file should be here
+###   R CMD BATCH update_rda_objects.R >update_rda_objects.log 2>&1 &
+###
+
+INFILE <- "RDA_OBJECTS_TO_UPDATE"
+
+library(SummarizedExperiment)
+
+.update_objects <- function(envir)
+{
+    updated <- FALSE
+    for (objname in names(envir)) {
+        obj <- get(objname, envir=envir, inherits=FALSE)
+        objclass <- class(obj)
+        objclass_pkg <- attr(objclass, "package")
+        if (!is.null(objclass_pkg)) {
+            suppressWarnings(suppressPackageStartupMessages(
+                library(objclass_pkg, character.only=TRUE, quietly=TRUE)
+            ))
+        }
+        if (!SummarizedExperiment:::.has_SummarizedExperiment_internal_structure(obj))
+            next()
+
+        cat("  Updating ", objname, " ... ", sep="")
+        obj <- updateObject(obj)
+        validObject(obj, complete=TRUE)
+        assign(objname, obj, envir=envir, inherits=FALSE)
+        cat("OK\n")
+        updated <- TRUE
+    }
+    updated
+}
+
+updateRdaObjects <- function(rda_objects)
+{
+    rda_files <- unique(rda_objects[ , "rda_file"])
+    for (i in seq_along(rda_files)) {
+        rda_file <- rda_files[[i]]
+
+        cat("[", i , "/", length(rda_files), "] Loading ", rda_file, " ... ",
+            sep="")
+        envir <- new.env(parent=emptyenv())
+        load(rda_file, envir=envir)
+        cat("OK\n")
+
+        if (.update_objects(envir)) {
+            cat("  Saving updated objects to ", rda_file, " ... ", sep="")
+            save(list=names(envir), file=rda_file, envir=envir, compress="xz")
+            cat("OK\n")
+        }
+    }
+}
+
+rda_objects_to_update <- read.table(INFILE, stringsAsFactors=FALSE)
+colnames(rda_objects_to_update) <- c("rda_file", "objname",
+                                     "objclass", "objclass_pkg")
+updateRdaObjects(rda_objects_to_update)
+
diff --git a/inst/unitTests/test_Assays-class.R b/inst/unitTests/test_Assays-class.R
new file mode 100644
index 0000000..1376417
--- /dev/null
+++ b/inst/unitTests/test_Assays-class.R
@@ -0,0 +1,88 @@
+test_bind_Assays <- function() {
+    ## unnamed -- map by position
+    l1 <- list(matrix(1, 3, 4), matrix(2, 3, 4))
+    l2 <- list(matrix(3, 3, 4), matrix(4, 3, 4))
+    a1 <- Assays(l1)
+    a2 <- Assays(l2)
+
+    target <- Map(rbind, l1, l2)
+    current <- rbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    target <- Map(cbind, l1, l2)
+    current <- cbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    ## named -- map by name
+    l1 <- list(x=matrix(1, 3, 4), y=matrix(2, 3, 4))
+    l2 <- list(y=matrix(4, 3, 4), x=matrix(3, 3, 4))
+    a1 <- Assays(l1)
+    a2 <- Assays(l2)
+
+    target <- Map(rbind, l1, l2[match(names(l2), names(l1))])
+    current <- rbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    target <- Map(cbind, l1, l2[match(names(l2), names(l1))])
+    current <- cbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+}
+
+test_bind_higher_order_Assays <- function() {
+    ## unnamed -- map by position
+    l1 <- list(array(1, dim = c(3, 4, 5, 6)),
+               array(2, dim = c(3, 4, 5, 6)))
+    l2 <- list(array(4, dim = c(3, 4, 5, 6)),
+               array(3, dim = c(3, 4, 5, 6)))
+    a1 <- Assays(l1)
+    a2 <- Assays(l2)
+
+    target <- Map(arbind, l1, l2)
+    current <- rbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    target <- Map(acbind, l1, l2)
+    current <- cbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    ## named -- map by name
+    l1 <- list(x = array(1, dim = c(3, 4, 5, 6)),
+               y = array(2, dim = c(3, 4, 5, 6)))
+    l2 <- list(y = array(4, dim = c(3, 4, 5, 6)),
+               x = array(3, dim = c(3, 4, 5, 6)))
+    a1 <- Assays(l1)
+    a2 <- Assays(l2)
+
+    target <- Map(arbind, l1, l2[match(names(l2), names(l1))])
+    current <- rbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+
+    target <- Map(acbind, l1, l2[match(names(l2), names(l1))])
+    current <- cbind(a1, a2)
+    checkTrue(is(current, "ShallowSimpleListAssays"))
+    checkIdentical(as(target, "SimpleList"), as(current, "SimpleList"))
+}
+
+test_bind_error_on_incompatible_dimension_Assays <- function() {
+    l1 <- list(x = array(1, dim = c(3, 4, 5, 6)),
+               y = array(2, dim = c(3, 4, 5, 6)))
+    l2 <- list(y = matrix(4, 3, 4), x = matrix(3, 3, 4))
+    a1 <- Assays(l1)
+    a2 <- Assays(l2)
+
+    ## arbind
+    checkException(rbind(a1, a2), silent = TRUE)
+    checkException(arbind(l1[[1]], l2[[1]]), silent = TRUE)
+
+    ## acbind
+    checkException(cbind(a1, a2), silent = TRUE)
+    checkException(acbind(l1[[1]], l2[[1]]), silent = TRUE)
+}
+
diff --git a/inst/unitTests/test_RangedSummarizedExperiment-class.R b/inst/unitTests/test_RangedSummarizedExperiment-class.R
new file mode 100644
index 0000000..88a1ced
--- /dev/null
+++ b/inst/unitTests/test_RangedSummarizedExperiment-class.R
@@ -0,0 +1,375 @@
+library(digest)
+
+.singleDispatch <-
+    c("duplicated", "end", "end<-", "granges", "ranges", 
+      "seqinfo", "seqinfo<-", "seqnames", "start", "start<-",
+      "strand", "width", "width<-")
+
+.twoDispatch <- c("pcompare", "Compare")
+
+.otherFuns <- c("is.unsorted", "order", "rank", "sort")
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+mList <- list(M1, M2)
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <- 
+    list(gr=GRanges("chr1", IRanges(1:5, 10)), 
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <- 
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]], 
+           rowRanges=rowRangesList[["gr"]], 
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]], 
+           rowRanges=rowRangesList[["grl"]], 
+           colData=colData))
+
+
+test_RangedSummarizedExperiment_construction <- function()
+{
+    ## empty-ish
+    m1 <- matrix(0, 0, 0)
+    checkTrue(validObject(new("RangedSummarizedExperiment")))
+
+    ## substance
+    for (i in seq_along(rseList)) {
+        rse <- rseList[[i]]
+        checkTrue(validObject(rse))
+        checkIdentical(SimpleList(m=mList[[i]]), assays(rse))
+        checkIdentical(rowRangesList[[i]], rowRanges(rse))
+        checkIdentical(DataFrame(x=letters[1:3]), colData(rse))
+    }
+
+    ## array in assays slot
+    ss <- rseList[[1]]
+    assays(ss) <- SimpleList(array(1:5, c(5,3,2)))
+    checkTrue(validObject(ss))
+    checkTrue(all(dim(assays(ss[1:3,1:2])[[1]]) == c(3, 2, 2)))
+}
+
+test_RangedSummarizedExperiment_getters <- function()
+{
+    for (i in seq_along(rseList)) {
+        rse <- rseList[[i]]
+        rowRanges <- rowRangesList[[i]]
+
+        ## dim, dimnames
+        checkIdentical(c(length(rowRanges), nrow(colData)), dim(rse))
+        checkIdentical(list(NULL, NULL), dimnames(rse))
+
+        ## row / col / metadata
+        checkIdentical(rowRanges, rowRanges(rse))
+        checkIdentical(colData, colData(rse))
+        checkIdentical(list(), metadata(rse))
+    }
+}
+
+test_RangedSummarizedExperiment_setters <- function()
+{
+    for (i in seq_along(rseList)) {
+        rse <- rseList[[i]]
+        rowRanges <- rowRangesList[[i]]
+
+        ## row / col / metadata<-
+        ss1 <- rse
+        revData <- rev(rowRanges)
+        rowRanges(ss1) <- revData
+        checkIdentical(revData, rowRanges(ss1))
+        checkException(rowRanges(ss1) <- rowRanges(rse)[1:2,,drop=FALSE],
+                       "incorrect row dimensions", TRUE)
+        revData <- colData[rev(seq_len(nrow(colData))),,drop=FALSE]
+        colData(ss1) <- revData
+        checkIdentical(revData, colData(ss1))
+        checkException(colData(ss1) <- colData(rse)[1:2,,drop=FALSE],
+                       "incorrect col dimensions", TRUE)
+        lst <- list("foo", "bar")
+        metadata(ss1) <- lst
+        checkIdentical(lst, metadata(ss1))
+
+        ## assay / assays
+        ss1 <- rse
+        assay(ss1) <- assay(ss1)+1
+        checkIdentical(assay(rse)+1, assay(ss1))
+        ss1 <- rse
+        assay(ss1, 1) <- assay(ss1, 1) + 1
+        checkIdentical(assay(rse, "m") + 1, assay(ss1, "m"))
+        ss1 <- rse
+        assay(ss1, "m") <- assay(ss1, "m") + 1
+        checkIdentical(assay(rse, "m")+1, assay(ss1, "m"))
+
+        ## dimnames<-
+        ss1 <- rse
+        dimnames <- list(letters[seq_len(nrow(ss1))],
+                         LETTERS[seq_len(ncol(ss1))])
+        rownames(ss1) <- dimnames[[1]]
+        colnames(ss1) <- dimnames[[2]]
+        checkIdentical(dimnames, dimnames(ss1))
+        rowRanges1 <- rowRanges
+        names(rowRanges1) <- dimnames[[1]]
+        checkIdentical(rowRanges1, rowRanges(ss1))
+        colData1 <- colData
+        row.names(colData1) <- dimnames[[2]]
+        checkIdentical(colData1, colData(ss1))
+        ss1 <- rse
+        dimnames(ss1) <- dimnames
+        checkIdentical(dimnames, dimnames(ss1))
+        dimnames(ss1) <- NULL
+        checkIdentical(list(NULL, NULL), dimnames(ss1))
+    }
+}
+
+test_RangedSummarizedExperiment_subset <- function()
+{
+    for (i in seq_along(rseList)) {
+        rse <- rseList[[i]]
+        rowRanges <- rowRangesList[[i]]
+
+        ## numeric
+        ss1 <- rse[2:3,]
+        checkIdentical(c(2L, ncol(rse)), dim(ss1))
+        checkIdentical(rowRanges(ss1), rowRanges(rse)[2:3,])
+        checkIdentical(colData(ss1), colData(rse))
+        ss1 <- rse[,2:3]
+        checkIdentical(c(nrow(rse), 2L), dim(ss1))
+        checkIdentical(rowRanges(ss1), rowRanges(rse))
+        checkIdentical(colData(ss1), colData(rse)[2:3,,drop=FALSE])
+        ss1 <- rse[2:3, 2:3]
+        checkIdentical(c(2L, 2L), dim(ss1))
+        checkIdentical(rowRanges(ss1), rowRanges(rse)[2:3,,drop=FALSE])
+        checkIdentical(colData(ss1), colData(rse)[2:3,,drop=FALSE])
+
+        ## character
+        ss1 <- rse
+        dimnames(ss1) <- list(LETTERS[seq_len(nrow(ss1))],
+                              letters[seq_len(ncol(ss1))])
+        ridx <- c("B", "C")
+        checkIdentical(rowRanges(ss1[ridx,]), rowRanges(ss1)[ridx,])
+        checkIdentical(rowRanges(ss1["C",]), rowRanges(ss1)["C",,drop=FALSE])
+        checkException(ss1[LETTERS,], "i-index out of bounds", TRUE)
+        cidx <- c("b", "c")
+        checkIdentical(colData(ss1[,cidx]), colData(ss1)[cidx,,drop=FALSE])
+        checkIdentical(colData(ss1[,"a"]), colData(ss1)["a",,drop=FALSE])
+        checkException(ss1[,letters], "j-index out of bounds", TRUE)
+
+        ## logical
+        ss1 <- rse
+        dimnames(ss1) <- list(LETTERS[seq_len(nrow(ss1))],
+                              letters[seq_len(ncol(ss1))])
+        checkEquals(ss1, ss1[TRUE,])
+        checkIdentical(c(0L, ncol(ss1)), dim(ss1[FALSE,]))
+        checkEquals(ss1, ss1[,TRUE])
+        checkIdentical(c(nrow(ss1), 0L), dim(ss1[,FALSE]))
+        idx <- c(TRUE, FALSE)               # recycling
+        ss2 <- ss1[idx,]
+        checkIdentical(rowRanges(ss1)[idx,,drop=FALSE], rowRanges(ss2))
+        ss2 <- ss1[,idx]
+        checkIdentical(colData(ss1)[idx,,drop=FALSE], colData(ss2))
+
+        ## Rle
+        ss1 <- rse
+        rle <- rep(c(TRUE, FALSE), each=3, length.out=nrow(ss1))
+        checkIdentical(rowRanges(ss1[rle]), rowRanges(ss1[Rle(rle)]))
+        checkIdentical(assays(ss1[rle]), assays(ss1[Rle(rle)]))
+    }
+
+    ## 0 columns
+    se <- SummarizedExperiment(rowRanges=GRanges("chr1", IRanges(1:10, width=1)))
+    checkIdentical(dim(se[1:5, ]), c(5L, 0L))
+    ## 0 rows 
+    se <- SummarizedExperiment(colData=DataFrame(samples=1:10))
+    checkIdentical(dim(se[ ,1:5]), c(0L, 5L))
+}
+
+test_RangedSummarizedExperiment_subsetassign <- function()
+{
+    for (i in seq_along(rseList)) {
+        rse <- rseList[[i]]
+        dimnames(rse) <- list(LETTERS[seq_len(nrow(rse))],
+                              letters[seq_len(ncol(rse))])
+        ## rows
+        ss1 <- rse
+        ss1[1:2,] <- ss1[2:1,]
+        checkIdentical(rowRanges(rse)[2:1,], rowRanges(ss1)[1:2,])
+        checkIdentical(rowRanges(rse[-(1:2),]), rowRanges(ss1)[-(1:2),])
+        checkIdentical(colData(rse), colData(ss1))
+        checkIdentical(c(metadata(rse), metadata(rse)), metadata(ss1))
+        ## Rle
+        ss1rle <- ss1Rle <- rse
+        rle <- rep(c(TRUE, FALSE), each=3, length.out=nrow(ss1))
+        ss1rle[rle,] <- ss1rle[rle,]
+        ss1Rle[Rle(rle),] <- ss1Rle[Rle(rle),]
+        checkIdentical(rowRanges(ss1rle), rowRanges(ss1Rle))
+        checkIdentical(assays(ss1rle), assays(ss1Rle))
+        ## cols
+        ss1 <- rse
+        ss1[,1:2] <- ss1[,2:1,drop=FALSE]
+        checkIdentical(colData(rse)[2:1,,drop=FALSE],
+                       colData(ss1)[1:2,,drop=FALSE])
+        checkIdentical(colData(rse)[-(1:2),,drop=FALSE],
+                       colData(ss1)[-(1:2),,drop=FALSE])
+        checkIdentical(rowRanges(rse), rowRanges(ss1))
+        checkIdentical(c(metadata(rse), metadata(rse)), metadata(ss1))
+    }
+
+    ## full replacement
+    ss1 <- ss2 <- rseList[[1]]
+    rowRanges(ss2) <- rev(rowRanges(ss2))
+    ss1[,] <- ss2
+    checkIdentical(ss1, ss2)
+}
+
+quiet <- suppressWarnings
+test_RangedSummarizedExperiment_cbind <- function()
+## requires matching ranges
+{
+    ## empty
+    se <- SummarizedExperiment()
+    empty <- cbind(se, se)
+    checkTrue(all.equal(se, empty))
+
+    ## different ranges 
+    se1 <- rseList[[1]]
+    se2 <- se1[2:4]
+    rownames(se2) <- month.name[seq_len(nrow(se2))]
+    checkException(quiet(cbind(se1, se2)), silent=TRUE)
+
+    ## same ranges 
+    se1 <- rseList[[1]]
+    se2 <- se1[,1:2]
+    colnames(se2) <- month.name[seq_len(ncol(se2))]
+    res <- cbind(se1, se2)
+    checkTrue(nrow(res) == 5)
+    checkTrue(ncol(res) == 5)
+    ## rowRanges
+    rowData(se1) <- DataFrame("one"=1:5)
+    rowData(se2) <- DataFrame("two"=6:10)
+    res <- quiet(cbind(se1, se2))
+    checkIdentical(names(mcols(rowRanges(res))), c("one", "two"))
+    rowData(se2) <- DataFrame("one"=6:10, "two"=6:10)
+    checkException(cbind(se1, se2), silent=TRUE)
+    ## colData
+    checkTrue(nrow(colData(res)) == 5)
+    ## assays 
+    se1 <- rseList[[1]]
+    se2 <- se1[,1:2]
+    assays(se1) <- SimpleList("m"=matrix(rep("m", 15), nrow=5),
+                              "a"=array(rep("a", 30), c(5,3,2)))
+    assays(se2) <- SimpleList("m"=matrix(LETTERS[1:10], nrow=5),
+                              "a"=array(LETTERS[1:20], c(5,2,2)))
+    res <- cbind(se1, se2) ## same variables
+    checkTrue(nrow(res) == 5)
+    checkTrue(ncol(res) == 5)
+    checkTrue(all.equal(dim(assays(res)$m), c(5L, 5L)))
+    checkTrue(all.equal(dim(assays(res)$a), c(5L, 5L, 2L)))
+    names(assays(se1)) <- c("mm", "aa")
+    checkException(cbind(se1, se2), silent=TRUE) ## different variables
+}
+
+test_RangedSummarizedExperiment_rbind <- function()
+## requires matching samples 
+{
+    ## empty
+    se <- SummarizedExperiment()
+    empty <- rbind(se, se)
+    checkTrue(all.equal(se, empty))
+
+    ## different samples 
+    se1 <- rseList[[1]]
+    se2 <- se1[,1]
+    checkException(quiet(rbind(se1, se2)), silent=TRUE)
+
+    ## same samples 
+    se1 <- rseList[[1]]
+    se2 <- se1
+    rownames(se2) <- LETTERS[seq_len(nrow(se2))]
+    res <- rbind(se1, se2)
+    checkTrue(nrow(res) == 10)
+    checkTrue(ncol(res) == 3)
+    ## rowRanges
+    rowData(se1) <- DataFrame("one"=1:5)
+    rowData(se2) <- DataFrame("two"=6:10)
+    checkException(rbind(se1, se2), silent=TRUE)
+    ## colDat
+    se1 <- rseList[[1]]
+    se2 <- se1
+    colData(se2) <- DataFrame("one"=1:3, "two"=4:6)
+    res <- quiet(rbind(se1, se2))
+    checkTrue(ncol(colData(res)) == 3)
+    ## assays 
+    se1 <- rseList[[1]]
+    se2 <- se1
+    assays(se1) <- SimpleList("m"=matrix(rep("m", 15), nrow=5),
+                              "a"=array(rep("a", 30), c(5,3,2)))
+    assays(se2) <- SimpleList("m"=matrix(LETTERS[1:15], nrow=5),
+                              "a"=array(LETTERS[1:30], c(5,3,2)))
+    res <- rbind(se1, se2) ## same variables
+    checkTrue(nrow(res) == 10)
+    checkTrue(ncol(res) == 3)
+    checkTrue(all.equal(dim(assays(res)$m), c(10L, 3L)))
+    checkTrue(all.equal(dim(assays(res)$a), c(10L, 3L, 2L)))
+    names(assays(se1)) <- c("mm", "aa")
+    checkException(rbind(se1, se2), silent=TRUE) ## different variables
+}
+
+test_RangedSummarizedExperiment_GRanges_API <- function()
+{
+    ## are we targetting the correct API? signature for
+    ## RangedSummarizedExperiment method should match signature for
+    ## GenomicRanges or similar, as in each test below
+
+    for (.fun in .singleDispatch) {
+        generic <- getGeneric(.fun)
+        method <- getMethod(.fun, "RangedSummarizedExperiment")
+        checkIdentical("x", generic at signature)
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }
+
+    ## FIXME: pcompare, Compare
+
+    .sig <- "RangedSummarizedExperiment"
+    for (.fun in .otherFuns) {
+        generic <- getGeneric(.fun)
+        method <- getMethod(.fun, "RangedSummarizedExperiment")
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }        
+}
+
+test_RangedSummarizedExperiment_GRanges_values <- function()
+{
+    x <- rseList[[1]]
+    isAssign <- grep("<-$", .singleDispatch, value=TRUE)
+    .funs <- setdiff(.singleDispatch, isAssign)
+    ## 'exp' created after manual inspection of results
+    exp <- setNames(c("02dde", "80339", "49a3f", "86757", "77198",
+                      "ec53a", "35e2c", "625d9", "3c90a"), .funs)
+    obs <- sapply(.funs, function(.fun) {
+        substr(digest(getGeneric(.fun)(x)), 1, 5)
+    })
+    checkIdentical(exp, obs)
+
+    .funs <- isAssign
+    .gets <- sub("<-$", "", isAssign)
+    for (i in seq_along(isAssign)) {
+        ## self-assignment isomorphism
+        value <- getGeneric(.gets[[i]])(x)
+        x1 <- do.call(isAssign[[i]], list(x, value=value))
+        checkIdentical(x, x1)
+    }
+}
+
+test_RangedSummarizedExperiment_split <- function()
+{
+    gr <- GRanges(Rle(c("A", "B"), c(2, 3)), IRanges(1:5, 10))
+    se <- SummarizedExperiment(M1, rowRanges=gr, colData=colData)
+    ## FIXME: unname should not be necessary
+    obs <- split(se, seqnames(se))
+    exp <- SimpleList(A=se[1:2], B=se[3:5])
+    checkEquals(obs, exp)
+}
+
diff --git a/inst/unitTests/test_SummarizedExperiment-class.R b/inst/unitTests/test_SummarizedExperiment-class.R
new file mode 100644
index 0000000..3d590d8
--- /dev/null
+++ b/inst/unitTests/test_SummarizedExperiment-class.R
@@ -0,0 +1,339 @@
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+mList <- list(M1, M2)
+assaysList <- list(M1=SimpleList(m=M1), M2=SimpleList(m=M2))
+rowData1 <- DataFrame(id1=LETTERS[1:5])
+rowData2 <- S4Vectors:::make_zero_col_DataFrame(3L)
+rowDataList <- list(rowData1, rowData2)
+colData0 <- DataFrame(x=letters[1:3])
+
+se0List <-
+    list(SummarizedExperiment(
+           assays=assaysList[["M1"]],
+           rowData=rowData1,
+           colData=colData0),
+         SummarizedExperiment(
+           assays=assaysList[["M2"]],
+           colData=colData0))
+
+
+test_SummarizedExperiment_construction <- function()
+{
+    ## empty-ish
+    m1 <- matrix(0, 0, 0)
+    checkTrue(validObject(new("SummarizedExperiment")))
+    checkTrue(validObject(SummarizedExperiment()), "empty constructor")
+    checkTrue(validObject(SummarizedExperiment(SimpleList())))
+    checkTrue(validObject(SummarizedExperiment(assays=SimpleList(m1))),
+              "0x0 constructor")
+    checkException(SummarizedExperiment(assays=SimpleList(m1, matrix())),
+                   "assays dim mismatch", TRUE)
+
+    ## substance
+    for (i in seq_along(se0List)) {
+        se0 <- se0List[[i]] 
+        checkTrue(validObject(se0))
+        checkIdentical(SimpleList(m=mList[[i]]), assays(se0))
+        checkIdentical(rowDataList[[i]], rowData(se0))
+        checkIdentical(colData0, colData(se0))
+    }
+
+    ## array in assays slot
+    ss <- se0List[[1]]
+    assays(ss) <- SimpleList(array(1:5, c(5,3,2)))
+    checkTrue(validObject(ss))
+    checkTrue(all(dim(assays(ss[1:3,1:2])[[1]]) == c(3, 2, 2)))
+
+    ## matrix-of-list in assay slot
+    m <- matrix(list(), 2, 3, dimnames=list(LETTERS[1:2], letters[1:3]))
+    checkTrue(validObject(se <- SummarizedExperiment(m)))
+    checkIdentical(m, assay(se))
+    checkIdentical(m[,1:2], assay(se[,1:2]))
+
+    ## DataFrame in assay slot
+    df <- DataFrame(a=1:3, b=1:3, row.names=LETTERS[1:3])
+    checkTrue(validObject(SummarizedExperiment(list(df))))
+}
+
+test_SummarizedExperiment_construction_colnames <- function()
+{
+    colnames <- LETTERS[1:3]
+
+    checkException(SummarizedExperiment(
+        assays=matrix(0, 2, 3, dimnames=list(NULL, colnames)),
+        colData=DataFrame(row.names=letters[1:3])),
+        "assay colnames() differ from colData rownames()", TRUE)
+
+    checkTrue(validObject(SummarizedExperiment(matrix(0, 2, 3))),
+              "NULL dimnames on assays-only construction")
+    se <- SummarizedExperiment(matrix(0, 2, 3))
+    checkTrue(is.null(colnames(se)))
+
+    checkTrue(validObject(SummarizedExperiment(
+        matrix(0, 2, 3), colData=DataFrame(x=1:3)[,FALSE])),
+        "NULL dimnames on assays and colData")
+    se <- SummarizedExperiment(matrix(0, 2, 3),
+                               colData=DataFrame(x=1:3)[,FALSE])
+    checkTrue(is.null(colnames(se)))
+
+    ## dimnames from colData rownames
+    se <- SummarizedExperiment(matrix(0, 2, 3),
+                               colData=DataFrame(row.names=colnames))
+    checkIdentical(colnames(se), colnames)
+    checkTrue(is.null(colnames(assay(se, withDimnames=FALSE))),
+              "don't replace NULL colnames")
+
+    ## when colData rownames == NULL, take dimnames from assay colnames
+    colnames <- LETTERS[1:3]
+    se <- SummarizedExperiment(matrix(0, 2, 3, dimnames=list(NULL, colnames)),
+                               colData=DataFrame(x=colnames)[,FALSE])
+    checkIdentical(colnames(se), colnames)
+    checkIdentical(colnames(assay(se, withDimnames=FALSE)), colnames,
+                   "don't remove non-NULL colnames")
+
+    ## matching colData rownames and assay colnames
+    se <- SummarizedExperiment(matrix(0, 2, 3, dimnames=list(NULL, colnames)),
+                               colData=DataFrame(row.names=colnames))
+    checkIdentical(colnames(se), colnames)
+    checkIdentical(colnames(assay(se, withDimnames=FALSE)), colnames)
+}
+
+test_SummarizedExperiment_getters <- function()
+{
+    for (i in seq_along(se0List)) {
+        se0 <- se0List[[i]] 
+
+        ## dim, dimnames
+        checkIdentical(c(nrow(mList[[i]]), nrow(colData0)), dim(se0))
+        checkIdentical(list(NULL, NULL), dimnames(se0))
+
+        ## col / metadata
+        checkIdentical(rowDataList[[i]], rowData(se0))
+        checkIdentical(colData0, colData(se0))
+        checkIdentical(list(), metadata(se0))
+    }
+
+    ## assays
+    m0 <- matrix(0L, 0, 0, dimnames=list(NULL, NULL))
+    m1 <- matrix(0, 0, 0, dimnames=list(NULL, NULL))
+    a <- SimpleList(a=m0, b=m1)
+    checkIdentical(a, assays(SummarizedExperiment(assays=a)))
+    ## assay
+    checkException(
+        assay(SummarizedExperiment()), "0-length assay", TRUE)
+    checkIdentical(m0,
+        assay(SummarizedExperiment(assays=a)), "default assay")
+    checkIdentical(m1,
+        assay(SummarizedExperiment(assays=a), 2),
+        "assay, numeric index")
+    checkException(
+        assay(SummarizedExperiment(assays=a), 3),
+        "invalid assay index", TRUE)
+    checkIdentical(m1,
+        assay(SummarizedExperiment(assays=a), "b"),
+        "assay, character index")
+    checkException(
+        assay(SummarizedExperiment(assays=a), "c"),
+        "invalid assay name", TRUE)
+}
+
+test_SummarizedExperiment_setters <- function()
+{
+    for (i in seq_along(se0List)) {
+        se0 <- se0List[[i]] 
+
+        ## row / col / metadata<-
+        se1 <- se0
+        rowData <- rowDataList[[i]]
+
+        rowData <- rowData[rev(seq_len(nrow(rowData))),,drop=FALSE]
+        rowData(se1) <- rowData
+        checkIdentical(rowData, rowData(se1))
+
+        colData <- colData0[rev(seq_len(nrow(colData0))),,drop=FALSE]
+        colData(se1) <- colData
+        checkIdentical(colData, colData(se1))
+
+        ## The rowData (alias for mcols) setter recycles the supplied
+        ## DataFrame. This is consistent with what the mcols/elementMetadata
+        ## setter does on Vector objects in general.
+        rowData(se1) <- rowData(se0)[1:2,,drop=FALSE]
+        idx <- rep(1:2, length.out=length(se1))
+        target_se1_rowData <- rowData(se0)[idx,,drop=FALSE]
+        checkIdentical(target_se1_rowData, rowData(se1))
+
+        ## The colData setter does NOT recycle the supplied DataFrame.
+        checkException(colData(se1) <- colData(se0)[1:2,,drop=FALSE],
+                       "incorrect col dimensions", TRUE)
+
+        lst <- list("foo", "bar")
+        metadata(se1) <- lst
+        checkIdentical(lst, metadata(se1))
+
+        ## assay / assays
+        se1 <- se0
+        assay(se1) <- assay(se1)+1
+        checkIdentical(assay(se0)+1, assay(se1))
+        se1 <- se0
+        assay(se1, 1) <- assay(se1, 1) + 1
+        checkIdentical(assay(se0, "m") + 1, assay(se1, "m"))
+        se1 <- se0
+        assay(se1, "m") <- assay(se1, "m") + 1
+        checkIdentical(assay(se0, "m")+1, assay(se1, "m"))
+
+        ## dimnames<-
+        se1 <- se0
+        dimnames <- list(letters[seq_len(nrow(se1))],
+                         LETTERS[seq_len(ncol(se1))])
+        rownames(se1) <- dimnames[[1]]
+        colnames(se1) <- dimnames[[2]]
+        checkIdentical(dimnames, dimnames(se1))
+        colData1 <- colData0
+        row.names(colData1) <- dimnames[[2]]
+        checkIdentical(colData1, colData(se1))
+        se1 <- se0
+        dimnames(se1) <- dimnames
+        checkIdentical(dimnames, dimnames(se1))
+        dimnames(se1) <- NULL
+        checkIdentical(list(NULL, NULL), dimnames(se1))
+    }
+}
+
+test_SummarizedExperiment_subset <- function()
+{
+    for (i in seq_along(se0List)) {
+        se0 <- se0List[[i]] 
+
+        ## numeric
+        se1 <- se0[2:3,]
+        checkIdentical(c(2L, ncol(se0)), dim(se1))
+        checkIdentical(rowData(se1), rowData(se0)[2:3,,drop=FALSE])
+        checkIdentical(colData(se1), colData(se0))
+        se1 <- se0[,2:3]
+        checkIdentical(c(nrow(se0), 2L), dim(se1))
+        checkIdentical(rowData(se1), rowData(se0))
+        checkIdentical(colData(se1), colData(se0)[2:3,,drop=FALSE])
+        se1 <- se0[2:3, 2:3]
+        checkIdentical(c(2L, 2L), dim(se1))
+        checkIdentical(colData(se1), colData(se0)[2:3,,drop=FALSE])
+
+        ## character
+        se1 <- se0
+        dimnames(se1) <- list(LETTERS[seq_len(nrow(se1))],
+                               letters[seq_len(ncol(se1))])
+        ridx <- c("B", "C")
+        checkException(se1[LETTERS,], "i-index out of bounds", TRUE)
+        cidx <- c("b", "c")
+        checkIdentical(colData(se1[,cidx]), colData(se1)[cidx,,drop=FALSE])
+        checkIdentical(colData(se1[,"a"]), colData(se1)["a",,drop=FALSE])
+        checkException(se1[,letters], "j-index out of bounds", TRUE)
+
+        ## logical
+        se1 <- se0
+        dimnames(se1) <- list(LETTERS[seq_len(nrow(se1))],
+                               letters[seq_len(ncol(se1))])
+        checkEquals(se1, se1[TRUE,])
+        checkIdentical(c(0L, ncol(se1)), dim(se1[FALSE,]))
+        checkEquals(se1, se1[,TRUE])
+        checkIdentical(c(nrow(se1), 0L), dim(se1[,FALSE]))
+        idx <- c(TRUE, FALSE)               # recycling
+        se2 <- se1[idx,]
+        se2 <- se1[,idx]
+        checkIdentical(colData(se1)[idx,,drop=FALSE], colData(se2))
+
+        ## Rle
+        se1 <- se0
+        rle <- rep(c(TRUE, FALSE), each=3, length.out=nrow(se1))
+        checkIdentical(assays(se1[rle]), assays(se1[Rle(rle)]))
+    }
+
+    ## 0 columns
+    se <- SummarizedExperiment(matrix(integer(0), nrow=5))
+    checkIdentical(dim(se[1:5, ]), c(5L, 0L)) 
+    ## 0 rows 
+    se <- SummarizedExperiment(colData=DataFrame(samples=1:10))
+    checkIdentical(dim(se[ ,1:5]), c(0L, 5L)) 
+}
+
+test_SummarizedExperiment_subsetassign <- function()
+{
+    for (i in seq_along(se0List)) {
+        se0 <- se0List[[i]] 
+        dimnames(se0) <- list(LETTERS[seq_len(nrow(se0))],
+                               letters[seq_len(ncol(se0))])
+        ## rows
+        se1 <- se0
+        se1[1:2,] <- se1[2:1,]
+        checkIdentical(colData(se0), colData(se1))
+        checkIdentical(c(metadata(se0), metadata(se0)), metadata(se1))
+        ## Rle
+        se1rle <- se1Rle <- se0
+        rle <- rep(c(TRUE, FALSE), each=3, length.out=nrow(se1))
+        se1rle[rle,] <- se1rle[rle,]
+        se1Rle[Rle(rle),] <- se1Rle[Rle(rle),]
+        checkIdentical(assays(se1rle), assays(se1Rle))
+        ## cols
+        se1 <- se0
+        se1[,1:2] <- se1[,2:1,drop=FALSE]
+        checkIdentical(colData(se0)[2:1,,drop=FALSE],
+                       colData(se1)[1:2,,drop=FALSE])
+        checkIdentical(colData(se0)[-(1:2),,drop=FALSE],
+                       colData(se1)[-(1:2),,drop=FALSE])
+        checkIdentical(c(metadata(se0), metadata(se0)), metadata(se1))
+    }
+
+    ## full replacement
+    se1 <- se2 <- se0List[[1]]
+    se1[,] <- se2
+    checkIdentical(se1, se2)
+}
+
+test_SummarizedExperiment_assays_4d <- function()
+{
+    ## construction/validation
+    A <- array(0, c(3, 2, 5, 4), list(c("a1", "a2", "a3"),
+                                      c("b1", "b2"),
+                                      NULL,
+                                      c("d1", "d2", "d3", "d4")))
+    B <- array(0, c(3, 2, 6), list(c("a1", "a2", "a3"),
+                                   c("b1", "oops"),
+                                   NULL))
+    assays0 <- SimpleList(A=A, B=B)
+    checkException(SummarizedExperiment(assays0))
+
+    dimnames(B)[1:2] <- dimnames(A)[1:2]
+    C <- array(0, c(3, 2, 4), list(NULL,
+                                   c("b1", "b2"),
+                                   c("z1", "z2", "z3", "z4")))
+
+    assays0 <- SimpleList(A=A, B=B, C=C)
+    se <- SummarizedExperiment(assays0)
+    checkTrue(validObject(se, complete=TRUE))
+
+    ## dimnames
+    checkIdentical(dimnames(A)[1:2], dimnames(se))
+    checkIdentical(dimnames(B)[1:2], dimnames(se))
+    for (i in seq_along(assays(se))) {
+        checkIdentical(assays0[[i]], assay(se, i, withDimnames=FALSE))
+        checkIdentical(dimnames(se), dimnames(assay(se, i))[1:2])
+    }
+
+    ## [
+    se2 <- se[3:2, ]
+    checkIdentical(A[3:2, , , , drop=FALSE], assay(se2, 1, withDimnames=FALSE))
+    checkIdentical(B[3:2, , , drop=FALSE], assay(se2, 2, withDimnames=FALSE))
+    checkIdentical(C[3:2, , , drop=FALSE], assay(se2, 3, withDimnames=FALSE))
+
+    ## [<-
+    A1 <- A; A1[1, , , ] <- A[1, , , , drop=FALSE] + 1
+    assays(se[1, ])[[1]] <- 1 + assays(se[1, ])[[1]]
+    checkIdentical(assays(se)[[1]], A1)
+
+    ## [, [<- don't support more than 4 dimensions
+    a <- array(0, c(3, 3, 3, 3, 3),
+               list(LETTERS[1:3], letters[1:3], NULL, NULL, NULL))
+    assays <- SimpleList(a=a)
+    se <- SummarizedExperiment(assays)
+    checkException(se[1,], silent=TRUE)
+}
+
diff --git a/inst/unitTests/test_coverage-methods.R b/inst/unitTests/test_coverage-methods.R
new file mode 100644
index 0000000..6300188
--- /dev/null
+++ b/inst/unitTests/test_coverage-methods.R
@@ -0,0 +1,56 @@
+###
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <-
+    list(gr=GRanges("chr1", IRanges(1:5, 10)),
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <-
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]],
+           rowRanges=rowRangesList[["gr"]],
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]],
+           rowRanges=rowRangesList[["grl"]],
+           colData=colData))
+
+
+test_interfaces <- function()
+{
+    generic_functions <- "coverage"
+    for (fun in generic_functions) {
+        generic <- getGeneric(fun)
+        method <- getMethod(fun, "RangedSummarizedExperiment")
+        checkIdentical("x", generic at signature)
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }
+}
+
+test_coverage_RangedSummarizedExperiment <- function()
+{
+    for (i in 1:2) {
+        x <- rseList[[i]]
+
+        target <- coverage(rowRanges(x))
+        current <- coverage(x)
+        checkIdentical(target, current)
+
+        weight <- runif(length(x))
+        ## Issues a warning (in BioC 3.3) when rowRanges(x) is a GRangesList
+        ## object, which reveals a problem with how the "coverage" method for
+        ## GRangesList objects handles the 'weight' argument. The warning is
+        ## expected and healthy, don't try to suppress it here. It will go
+        ## away when we fix the "coverage" method for GRangesList objects
+        ## (defined in the GenomicRanges package). 
+        target <- coverage(rowRanges(x), weight=weight)
+        current <- coverage(x, weight=weight)
+        checkIdentical(target, current)
+    }
+}
+
diff --git a/inst/unitTests/test_findOverlaps-methods.R b/inst/unitTests/test_findOverlaps-methods.R
new file mode 100644
index 0000000..edcd3ce
--- /dev/null
+++ b/inst/unitTests/test_findOverlaps-methods.R
@@ -0,0 +1,92 @@
+###
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <-
+    list(gr=GRanges("chr1", IRanges(1:5, 10)),
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <-
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]],
+           rowRanges=rowRangesList[["gr"]],
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]],
+           rowRanges=rowRangesList[["grl"]],
+           colData=colData))
+
+
+test_interfaces <- function()
+{
+    fun <- "findOverlaps"
+    signatures <- list(
+        c("RangedSummarizedExperiment", "Vector"),
+        c("Vector", "RangedSummarizedExperiment"),
+        c("RangedSummarizedExperiment", "RangedSummarizedExperiment")
+    )
+    generic <- getGeneric(fun)
+    for (sig in signatures) {
+        method <- getMethod(fun, sig)
+        checkIdentical(c("query", "subject"), generic at signature)
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }
+}
+
+test_findOverlaps_methods <- function()
+{
+    identical_SummarizedExperiment <- function(x, y) {
+        x at assays <- as(assays(x), "SimpleListAssays")
+        y at assays <- as(assays(y), "SimpleListAssays")
+        identical(x, y)
+    }
+    for (i in 1:2) {
+        x <- rseList[[i]]
+        for (j in 1:2) {
+            y <- rseList[[j]]
+
+            ## findOverlaps
+            target <- findOverlaps(rowRanges(x), rowRanges(y))
+            current <- findOverlaps(x, rowRanges(y))
+            checkIdentical(target, current)
+            current <- findOverlaps(rowRanges(x), y)
+            checkIdentical(target, current)
+            current <- findOverlaps(x, y)
+            checkIdentical(target, current)
+
+            ## countOverlaps
+            target <- countOverlaps(rowRanges(x), rowRanges(y))
+            current <- countOverlaps(x, rowRanges(y))
+            checkIdentical(target, current)
+            current <- countOverlaps(rowRanges(x), y)
+            checkIdentical(target, current)
+            current <- countOverlaps(x, y)
+            checkIdentical(target, current)
+
+            ## overlapsAny
+            target <- overlapsAny(rowRanges(x), rowRanges(y))
+            current <- overlapsAny(x, rowRanges(y))
+            checkIdentical(target, current)
+            current <- overlapsAny(rowRanges(x), y)
+            checkIdentical(target, current)
+            current <- overlapsAny(x, y)
+            checkIdentical(target, current)
+
+            ## subsetByOverlaps
+            target <- subsetByOverlaps(x, rowRanges(y))
+            current <- subsetByOverlaps(x, rowRanges(y))
+            checkTrue(identical_SummarizedExperiment(target, current))
+            current <- subsetByOverlaps(x, y)
+            checkTrue(identical_SummarizedExperiment(target, current))
+
+            target <- subsetByOverlaps(rowRanges(x), rowRanges(y))
+            current <- subsetByOverlaps(rowRanges(x), y)
+            checkIdentical(target, current)
+        }
+    }
+}
+
diff --git a/inst/unitTests/test_inter-range-methods.R b/inst/unitTests/test_inter-range-methods.R
new file mode 100644
index 0000000..cee69db
--- /dev/null
+++ b/inst/unitTests/test_inter-range-methods.R
@@ -0,0 +1,52 @@
+###
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <-
+    list(gr=GRanges("chr1", IRanges(1:5, 10), Rle(c("+", "-"), 3:2)),
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <-
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]],
+           rowRanges=rowRangesList[["gr"]],
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]],
+           rowRanges=rowRangesList[["grl"]],
+           colData=colData))
+
+
+test_interfaces <- function()
+{
+    generic_functions <- c("isDisjoint", "disjointBins")
+    for (fun in generic_functions) {
+        generic <- getGeneric(fun)
+        method <- getMethod(fun, "RangedSummarizedExperiment")
+        checkIdentical("x", generic at signature)
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }
+}
+
+test_inter_range_methods <- function()
+{
+    #for (i in 1:2) {
+    for (i in 1L) {
+        x <- rseList[[i]]
+
+        ## isDisjoint
+        target <- isDisjoint(rowRanges(x))
+        current <- isDisjoint(x)
+        checkIdentical(target, current)
+
+        ## disjointBins
+        target <- disjointBins(rowRanges(x))
+        current <- disjointBins(x)
+        checkIdentical(target, current)
+    }
+}
+
diff --git a/inst/unitTests/test_intra-range-methods.R b/inst/unitTests/test_intra-range-methods.R
new file mode 100644
index 0000000..ff6087f
--- /dev/null
+++ b/inst/unitTests/test_intra-range-methods.R
@@ -0,0 +1,94 @@
+###
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <-
+    list(gr=GRanges("chr1", IRanges(1:5, 10), Rle(c("+", "-"), 3:2)),
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <-
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]],
+           rowRanges=rowRangesList[["gr"]],
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]],
+           rowRanges=rowRangesList[["grl"]],
+           colData=colData))
+
+
+test_interfaces <- function()
+{
+    generic_functions <- c("shift", "narrow", "resize",
+                           "flank", "promoters",
+                           "restrict", "trim")
+    for (fun in generic_functions) {
+        generic <- getGeneric(fun)
+        method <- getMethod(fun, "RangedSummarizedExperiment")
+        checkIdentical("x", generic at signature)
+        checkIdentical(formals(generic at .Data), formals(method at .Data))
+    }
+}
+
+test_intra_range_methods <- function()
+{
+    identical_SummarizedExperiment <- function(x, y) {
+        x at assays <- as(assays(x), "SimpleListAssays")
+        y at assays <- as(assays(y), "SimpleListAssays")
+        identical(x, y)
+    }
+    #for (i in 1:2) {
+    for (i in 1L) {
+        ## shift
+        target <- rseList[[i]]
+        rowRanges(target) <- shift(rowRanges(target), 50)
+        current <- shift(rseList[[i]], 50)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## narrow
+        target <- rseList[[i]]
+        rowRanges(target) <- narrow(rowRanges(target), 2, -2)
+        current <- narrow(rseList[[i]], 2, -2)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## resize
+        target <- rseList[[i]]
+        rowRanges(target) <- resize(rowRanges(target), 8)
+        current <- resize(rseList[[i]], 8)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## flank
+        target <- rseList[[i]]
+        rowRanges(target) <- flank(rowRanges(target), 5, both=TRUE)
+        current <- flank(rseList[[i]], 5, both=TRUE)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## promoters
+        target <- rseList[[i]]
+        rowRanges(target) <- promoters(rowRanges(target),
+                                       upstream=20, downstream=5)
+        current <- promoters(rseList[[i]], upstream=20, downstream=5)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## restrict
+        target <- rseList[[i]]
+        rowRanges(target) <- restrict(rowRanges(target), start=2, end=3,
+                                      keep.all.ranges=TRUE)
+        current <- restrict(rseList[[i]], start=2, end=3,
+                            keep.all.ranges=TRUE)
+        checkTrue(identical_SummarizedExperiment(target, current))
+
+        ## trim
+        suppressWarnings(seqlengths(rseList[[i]]) <- 8)
+        target <- rseList[[i]]
+        rowRanges(target) <- trim(rowRanges(target))
+        current <- trim(rseList[[i]])
+        checkTrue(identical_SummarizedExperiment(target, current))
+        seqlengths(rseList[[i]]) <- NA
+    }
+}
+
diff --git a/inst/unitTests/test_makeSummarizedExperimentFromDataFrame.R b/inst/unitTests/test_makeSummarizedExperimentFromDataFrame.R
new file mode 100644
index 0000000..a16aca2
--- /dev/null
+++ b/inst/unitTests/test_makeSummarizedExperimentFromDataFrame.R
@@ -0,0 +1,56 @@
+##
+
+rowNames <- paste0("GENE", letters[5:1])
+
+range_info <- list(chr="chr2", start = 11:15, end = 12:16,
+                      strand = c("+", "-", "+", "*", "."))
+expr_info <- list(expr0 = 3:7, expr1 = 8:12, expr2 = 12:16)
+
+df <- as.data.frame(c(range_info, expr_info), row.names = rowNames)
+DF <- DataFrame(c(range_info, expr_info), row.names = rowNames)
+
+test_makeSummarizedExperimentFromDataFrame <- function()
+{
+    validObject(makeSummarizedExperimentFromDataFrame(df))
+    validObject(makeSummarizedExperimentFromDataFrame(DF))
+
+    rangesA <- GRanges(as.data.frame(range_info, row.names = rowNames))
+    rangesB <- rowRanges(makeSummarizedExperimentFromDataFrame(df))
+    # Check rowRanges to be identical
+    checkIdentical(rangesA, rangesB)
+    # Check assay matrix and expr_info matrix are identical
+    checkIdentical(assay(makeSummarizedExperimentFromDataFrame(df)),
+                   as.matrix(as.data.frame(expr_info, row.names = rowNames)))
+    checkIdentical(assay(makeSummarizedExperimentFromDataFrame(DF)),
+                   as.matrix(as.data.frame(expr_info, row.names = rowNames)))
+
+    checkEquals(makeSummarizedExperimentFromDataFrame(df),
+                makeSummarizedExperimentFromDataFrame(DF))
+
+    checkException(
+        makeSummarizedExperimentFromDataFrame(
+            cbind(df, expr3 = letters[seq_len(nrow(df))])))
+
+    checkException(
+        makeSummarizedExperimentFromDataFrame(
+            cbind(DF, DataFrame(expr3 = letters[seq_len(nrow(df))]))))
+
+    checkIdentical(nrow(df),
+                   length(rowRanges(
+                       makeSummarizedExperimentFromDataFrame(df))))
+
+    checkIdentical(nrow(DF),
+                   length(rowRanges(
+                       makeSummarizedExperimentFromDataFrame(DF))))
+
+    checkIdentical(colnames(makeSummarizedExperimentFromDataFrame(df)),
+                   names(expr_info))
+    checkIdentical(rownames(makeSummarizedExperimentFromDataFrame(df)),
+                   rowNames)
+
+    checkIdentical(colnames(makeSummarizedExperimentFromDataFrame(DF)),
+                   names(expr_info))
+    checkIdentical(rownames(makeSummarizedExperimentFromDataFrame(DF)),
+                   rowNames)
+}
+
diff --git a/inst/unitTests/test_makeSummarizedExperimentFromExpressionSet.R b/inst/unitTests/test_makeSummarizedExperimentFromExpressionSet.R
new file mode 100644
index 0000000..711b4d7
--- /dev/null
+++ b/inst/unitTests/test_makeSummarizedExperimentFromExpressionSet.R
@@ -0,0 +1,187 @@
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <- 
+    list(gr=GRanges("chr1", IRanges(1:5, 10)), 
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <- 
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]], 
+           rowRanges=rowRangesList[["gr"]], 
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]], 
+           rowRanges=rowRangesList[["grl"]], 
+           colData=colData))
+
+
+test_SummarizedExperiment_GenomicRanges_coercion <- function()
+{
+        eset1 <- ExpressionSet()
+
+        checkTrue(validObject(eset1))
+
+        se1 <- as(eset1, "RangedSummarizedExperiment")
+
+        checkTrue(validObject(se1))
+
+        data("sample.ExpressionSet", package = "Biobase")
+
+        eset2 <- sample.ExpressionSet
+        checkTrue(validObject(eset2))
+
+        se2 <- as(eset2, "RangedSummarizedExperiment")
+
+        checkTrue(validObject(se2))
+
+        checkIdentical(experimentData(eset2),
+                       metadata(se2)$experimentData)
+
+        checkIdentical(annotation(eset2),
+                       metadata(se2)$annotation)
+
+        checkIdentical(protocolData(eset2),
+                       metadata(se2)$protocolData)
+
+        eset2Assays <- SimpleList(as.list(assayData(eset2)))
+        se2Assays <- assays(se2)
+        checkIdentical(eset2Assays$exprs, se2Assays$exprs)
+        checkIdentical(eset2Assays$se.exprs, se2Assays$se.exprs)
+
+        checkIdentical(featureNames(eset2), rownames(se2))
+
+        checkIdentical(sampleNames(eset2), colnames(se2))
+}
+
+test_GenomicRanges_SummarizedExperiment_coercion <- function()
+{
+        ## empty SE
+        simpleSE <- SummarizedExperiment()
+
+        eset1 <- as(simpleSE, "ExpressionSet")
+
+        checkTrue(validObject(eset1))
+
+        ## Back and forth empty ES
+        simpleES <- ExpressionSet()
+
+        simpleES2 <- as(as(simpleES, "RangedSummarizedExperiment"),
+                        "ExpressionSet")
+
+        checkTrue(validObject(simpleES2))
+
+        checkEquals(as.list(assayData(simpleES)),
+                    as.list(assayData(simpleES2)))
+
+        ## Simple SE
+        simpleSE <- rseList[[1]]
+        assayNames(simpleSE) <- "exprs" # No warning 'No assay named exprs..."
+        eset2 <- as(simpleSE, "ExpressionSet")
+        checkTrue(validObject(eset2))
+
+        ## The ExpressionSet features should have the data from the
+        ## SummarizedExperiment rows if they are from GRanges.
+        checkIdentical(pData(featureData(eset2)),
+                       as.data.frame(rowRanges(rseList[[1]])))
+
+        # the rowRanges are retained if the object has them to begin with.
+        se2_2 <- as(eset2, "RangedSummarizedExperiment")
+        rr_se2_2 <- unname(rowRanges(se2_2))
+        rr_eset2 <- rowRanges(rseList[[1]])
+        checkEquals(rr_se2_2, rr_eset2)
+
+        simpleSE <- rseList[[2]]
+        assayNames(simpleSE) <- "exprs" # No warning 'No assay named exprs..."
+        eset3 <- as(simpleSE, "ExpressionSet")
+        checkTrue(validObject(eset3))
+
+        ## The ExpressionSet features should not have the data from the
+        ## SummarizedExperiment rows if they are from GRangesList, but they
+        ## should be empty and the same length as the number of ranges.
+        checkEquals(unname(NROW(featureData(eset3))),
+                    unname(length(rowRanges(rseList[[2]]))))
+
+        data("sample.ExpressionSet", package = "Biobase")
+        eset4 <- sample.ExpressionSet
+
+        eset5 <- as(as(eset4, "RangedSummarizedExperiment"), "ExpressionSet")
+
+        checkTrue(validObject(eset5))
+
+        ## this is necessary because the order in environments is undefined.
+        compareLists <- function(x, y) {
+            nmsX <- names(x)
+            nmsY <- names(y)
+
+            reorderY <- match(nmsY, nmsX)
+
+            checkIdentical(x, y[reorderY])
+        }
+
+        compareLists(as.list(assayData(eset4)),
+                       as.list(assayData(eset5)))
+
+        checkIdentical(experimentData(eset4),
+                       experimentData(eset5))
+
+        checkIdentical(annotation(eset4),
+                       annotation(eset5))
+
+        checkIdentical(protocolData(eset4),
+                       protocolData(eset5))
+
+        checkIdentical(featureNames(eset4),
+                       featureNames(eset5))
+
+        checkIdentical(sampleNames(eset4),
+                       sampleNames(eset5))
+}
+
+test_GenomicRanges_SummarizedExperiment_coercion_mappingFunctions <- function()
+{
+    ## naiveRangeMapper
+    ## valid object from empty object
+    checkTrue(validObject(makeSummarizedExperimentFromExpressionSet(ExpressionSet())))
+
+    ## valid object from sample ExpressionSet
+    data("sample.ExpressionSet", package = "Biobase")
+    eset1 <- sample.ExpressionSet
+    checkTrue(validObject(makeSummarizedExperimentFromExpressionSet(eset1)))
+
+    ## makeSummarizedExperimentFromExpressionSet should be the same as `as`
+    ## with default args
+    checkEquals(makeSummarizedExperimentFromExpressionSet(eset1),
+                as(eset1, "RangedSummarizedExperiment"))
+
+    ## probeRangeMapper
+    ## valid object from empty object
+    checkTrue(validObject(
+            makeSummarizedExperimentFromExpressionSet(ExpressionSet(),
+                probeRangeMapper)))
+
+    ## valid object from sample ExpressionSet
+    se1 <- makeSummarizedExperimentFromExpressionSet(eset1, probeRangeMapper)
+    checkTrue(validObject(se1))
+
+    ## Granges returned have rownames that were from the featureNames
+    checkTrue(all(rownames(rowRanges(se1)) %in% featureNames(eset1)))
+
+    ## geneRangeMapper
+    ## valid object from empty object
+    checkTrue(validObject(
+            makeSummarizedExperimentFromExpressionSet(ExpressionSet(),
+                geneRangeMapper(NULL))))
+
+    ## valid object from sample ExpressionSet
+    se2 <- makeSummarizedExperimentFromExpressionSet(eset1,
+        geneRangeMapper("TxDb.Hsapiens.UCSC.hg19.knownGene"))
+    checkTrue(validObject(se2))
+
+    ## Granges returned have rownames that were from the featureNames
+    checkTrue(all(rownames(rowRanges(se2)) %in% featureNames(eset1)))
+}
+
diff --git a/inst/unitTests/test_nearest-methods.R b/inst/unitTests/test_nearest-methods.R
new file mode 100644
index 0000000..38aa74e
--- /dev/null
+++ b/inst/unitTests/test_nearest-methods.R
@@ -0,0 +1,70 @@
+###
+
+M1 <- matrix(1, 5, 3, dimnames=list(NULL, NULL))
+M2 <- matrix(1, 3, 3, dimnames=list(NULL, NULL))
+assaysList <- list(gr=SimpleList(m=M1), grl=SimpleList(m=M2))
+rowRangesList <-
+    list(gr=GRanges("chr1", IRanges(1:5, 10)),
+         grl=split(GRanges("chr1", IRanges(1:5, 10)), c(1,1,2,2,3)))
+names(rowRangesList[["grl"]]) <- NULL
+colData <- DataFrame(x=letters[1:3])
+
+## a list of one SE with GRanges and one with GRangesList
+rseList <-
+    list(SummarizedExperiment(
+           assays=assaysList[["gr"]],
+           rowRanges=rowRangesList[["gr"]],
+           colData=colData),
+         SummarizedExperiment(
+           assays=assaysList[["grl"]],
+           rowRanges=rowRangesList[["grl"]],
+           colData=colData))
+
+
+.GENERIC_SIGNATURES <- list(
+    precede=c("x", "subject"),
+    follow=c("x", "subject"),
+    nearest=c("x", "subject"),
+    distance=c("x", "y"),
+    distanceToNearest=c("x", "subject")
+)
+
+test_interfaces <- function()
+{
+    method_signatures <- list(
+        c("RangedSummarizedExperiment", "ANY"),
+        c("ANY", "RangedSummarizedExperiment"),
+        c("RangedSummarizedExperiment", "RangedSummarizedExperiment")
+    )
+    for (fun in names(.GENERIC_SIGNATURES)) {
+        generic <- getGeneric(fun)
+        checkIdentical(.GENERIC_SIGNATURES[[fun]], generic at signature)
+        for (sig in method_signatures) {
+            method <- getMethod(fun, sig)
+            checkIdentical(formals(generic at .Data), formals(method at .Data))
+        }
+    }
+}
+
+test_nearest_methods <- function()
+{
+    #for (i in 1:2) {
+    for (i in 1L) {
+        x <- rseList[[i]]
+        #for (j in 1:2) {
+        for (j in 1L) {
+            y <- rseList[[j]]
+            for (fun in names(.GENERIC_SIGNATURES)) {
+                fun <- get(fun)
+                target <- fun(rowRanges(x), rowRanges(y))
+                current <- fun(x, rowRanges(y))
+                checkIdentical(target, current)
+                current <- fun(rowRanges(x), y)
+                checkIdentical(target, current)
+                current <- fun(x, y)
+                checkIdentical(target, current)
+            }
+        }
+    }
+}
+
diff --git a/man/Assays-class.Rd b/man/Assays-class.Rd
new file mode 100644
index 0000000..063c706
--- /dev/null
+++ b/man/Assays-class.Rd
@@ -0,0 +1,172 @@
+\name{Assays-class}
+\docType{class}
+
+\alias{class:Assays}
+\alias{Assays-class}
+\alias{Assays}
+\alias{length,Assays-method}
+\alias{names,Assays-method}
+\alias{names<-,Assays-method}
+\alias{[[,Assays,ANY,ANY-method}
+\alias{[[<-,Assays,ANY,ANY-method}
+\alias{dim,Assays-method}
+\alias{[,Assays,ANY-method}
+\alias{[,Assays,ANY,ANY,ANY-method}
+\alias{[<-,Assays,ANY,ANY,ANY-method}
+\alias{rbind,Assays-method}
+\alias{cbind,Assays-method}
+\alias{arbind,Matrix-method}
+\alias{acbind,Matrix-method}
+
+\alias{class:SimpleListAssays}
+\alias{SimpleListAssays-class}
+\alias{SimpleListAssays}
+
+\alias{class:ShallowData}
+\alias{ShallowData-class}
+\alias{ShallowData}
+
+\alias{class:ShallowSimpleListAssays}
+\alias{ShallowSimpleListAssays-class}
+\alias{ShallowSimpleListAssays}
+\alias{coerce,SimpleList,ShallowSimpleListAssays-method}
+\alias{coerce,ShallowSimpleListAssays,SimpleList-method}
+
+\alias{class:AssaysInEnv}
+\alias{AssaysInEnv-class}
+\alias{AssaysInEnv}
+\alias{length,AssaysInEnv-method}
+\alias{names,AssaysInEnv-method}
+\alias{names<-,AssaysInEnv-method}
+\alias{[[,AssaysInEnv,ANY,ANY-method}
+\alias{[[<-,AssaysInEnv,ANY,ANY-method}
+\alias{coerce,SimpleList,AssaysInEnv-method}
+\alias{coerce,AssaysInEnv,SimpleList-method}
+
+\title{Assays objects}
+
+\description{
+  The Assays virtual class and its methods provide a formal abstraction
+  of the assays slot of \link{SummarizedExperiment} objects.
+
+  SimpleListAssays and ShallowSimpleListAssays are concrete subclasses of
+  Assays with the latter being currently the default implementation of Assays
+  objects. Other implementations (e.g. disk-based) could easily be added.
+
+  Note that these classes are not meant to be used directly by the end-user
+  and the material in this man page is aimed at package developers.
+}
+
+\details{
+  Assays objects have a list-like semantics with elements having matrix- or
+  array-like semantics (e.g., \code{dim}, \code{dimnames}).
+
+  The Assays API consists of:
+  \itemize{
+    \item (a) The \code{Assays()} constructor function.
+    \item (b) Lossless back and forth coercion from/to \link{SimpleList}.
+              The coercion method from \link{SimpleList} doesn't need (and
+              should not) validate the returned object.
+    \item (c) \code{length}, \code{names}, \code{`names<-`},
+              \code{[[}, \code{`[[<-`},
+              \code{dim}, \code{[}, \code{`[<-`}, \code{rbind}, \code{cbind}.
+  }
+  An Assays concrete subclass needs to implement (b) (required) plus,
+  optionally any of the methods in (c).
+
+  IMPORTANT: Methods that return a modified Assays object (a.k.a.
+  endomorphisms), that is, \code{[} as well as replacement methods
+  \code{names<-}, \code{[[<-}, and \code{[<-}, must respect the
+  \emph{copy-on-change contract}.
+  With objects that don't make use of references internally, the developer
+  doesn't need to take any special action for that because it's automatically
+  taken care of by R itself. However, for objects that do make use of
+  references internally (e.g. environments, external pointers, pointer to a
+  file on disk, etc...), the developer needs to be careful to implement
+  endomorphisms with copy-on-change semantics.
+  This can easily be achieved (and is what the default methods for Assays
+  objects do) by performaing a full (deep) copy of the object before modifying
+  it instead of trying to modify it in-place. Note that the full (deep) copy
+  is not always necessary in order to achieve copy-on-change semantics: it's
+  enough (and often preferrable for performance reasons) to copy only the
+  parts of the objects that need to be modified.
+
+  Assays has currently 3 implementations which are formalized by concrete
+  subclasses SimpleListAssays, ShallowSimpleListAssays, and AssaysInEnv.
+  ShallowSimpleListAssays is the default. AssaysInEnv is a \emph{broken}
+  alternative to ShallowSimpleListAssays that does NOT respect the
+  \emph{copy-on-change contract}. It is only provided for illustration
+  purposes (see source file Assays-class.R for the details).
+
+  A little more detail about ShallowSimpleListAssays: a small reference
+  class hierarchy (not exported from the \pkg{GenomicRanges} name space)
+  defines a reference class ShallowData with a single field \code{data}
+  of type \code{ANY}, and a derived class ShallowSimpleListAssays
+  that specializes the type of \code{data} as \link{SimpleList}, and
+  \code{contains=c("ShallowData", "Assays")}. The assays slot of a
+  \link{SummarizedExperiment} object contains an instance of
+  ShallowSimpleListAssays.
+}
+
+\author{Martin Morgan, \url{mtmorgan at fhcrc.org}}
+
+\seealso{
+  \itemize{
+    \item \link{SummarizedExperiment} objects.
+
+    \item \link[S4Vectors]{SimpleList} objects in the \pkg{S4Vectors} package.
+  }
+}
+
+\examples{
+## ---------------------------------------------------------------------
+## DIRECT MANIPULATION OF Assays OBJECTS
+## ---------------------------------------------------------------------
+m1 <- matrix(runif(24), ncol=3)
+m2 <- matrix(runif(24), ncol=3)
+a <- Assays(SimpleList(m1, m2))
+a
+
+as(a, "SimpleList")
+
+length(a)
+a[[2]]
+dim(a)
+
+b <- a[-4, 2]
+b
+length(b)
+b[[2]]
+dim(b)
+
+names(a)
+names(a) <- c("a1", "a2")
+names(a)
+a[["a2"]]
+
+rbind(a, a)
+cbind(a, a)
+
+## ---------------------------------------------------------------------
+## COPY-ON-CHANGE CONTRACT
+## ---------------------------------------------------------------------
+
+## ShallowSimpleListAssays objects have copy-on-change semantics but not
+## AssaysInEnv objects. For example:
+ssla <- as(SimpleList(m1, m2), "ShallowSimpleListAssays")
+aie <- as(SimpleList(m1, m2), "AssaysInEnv")
+
+## No names on 'ssla' and 'aie':
+names(ssla)
+names(aie)
+
+ssla2 <- ssla
+aie2 <- aie
+names(ssla2) <- names(aie2) <- c("A1", "A2")
+
+names(ssla)  # still NULL (as expected)
+
+names(aie)   # changed! (because the names<-,AssaysInEnv method is not
+             # implemented in a way that respects the copy-on-change
+             # contract)
+}
diff --git a/man/RangedSummarizedExperiment-class.Rd b/man/RangedSummarizedExperiment-class.Rd
new file mode 100644
index 0000000..061fd68
--- /dev/null
+++ b/man/RangedSummarizedExperiment-class.Rd
@@ -0,0 +1,335 @@
+\name{RangedSummarizedExperiment-class}
+\docType{class}
+
+% Class
+\alias{class:RangedSummarizedExperiment}
+\alias{RangedSummarizedExperiment-class}
+\alias{RangedSummarizedExperiment}
+
+% Constructor
+\alias{SummarizedExperiment}
+\alias{SummarizedExperiment,SimpleList-method}
+\alias{SummarizedExperiment,ANY-method}
+\alias{SummarizedExperiment,list-method}
+\alias{SummarizedExperiment,missing-method}
+
+% Coercion
+\alias{coerce,RangedSummarizedExperiment,SummarizedExperiment-method}
+\alias{coerce,SummarizedExperiment,RangedSummarizedExperiment-method}
+
+% Accessors
+\alias{rowRanges}
+\alias{rowRanges,RangedSummarizedExperiment-method}
+\alias{rowRanges<-}
+\alias{rowRanges<-,SummarizedExperiment,GenomicRanges-method}
+\alias{rowRanges<-,SummarizedExperiment,GRangesList-method}
+\alias{names,RangedSummarizedExperiment-method}
+\alias{names<-,RangedSummarizedExperiment-method}
+\alias{dimnames,RangedSummarizedExperiment-method}
+\alias{dimnames<-,RangedSummarizedExperiment,list-method}
+
+% GenomicRanges compatibility methods
+\alias{Compare,ANY,RangedSummarizedExperiment-method}
+\alias{Compare,RangedSummarizedExperiment,ANY-method}
+\alias{Compare,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+\alias{pcompare,ANY,RangedSummarizedExperiment-method}
+\alias{pcompare,RangedSummarizedExperiment,ANY-method}
+\alias{pcompare,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+\alias{duplicated,RangedSummarizedExperiment-method}
+\alias{elementMetadata,RangedSummarizedExperiment-method}
+\alias{elementMetadata<-,RangedSummarizedExperiment-method}
+\alias{end,RangedSummarizedExperiment-method}
+\alias{end<-,RangedSummarizedExperiment-method}
+\alias{granges,RangedSummarizedExperiment-method}
+\alias{is.unsorted,RangedSummarizedExperiment-method}
+\alias{mcols,RangedSummarizedExperiment-method}
+\alias{mcols<-,RangedSummarizedExperiment-method}
+\alias{order,RangedSummarizedExperiment-method}
+\alias{ranges,RangedSummarizedExperiment-method}
+\alias{ranges<-,RangedSummarizedExperiment-method}
+\alias{rank,RangedSummarizedExperiment-method}
+\alias{seqinfo,RangedSummarizedExperiment-method}
+\alias{seqinfo<-,RangedSummarizedExperiment-method}
+\alias{seqnames,RangedSummarizedExperiment-method}
+\alias{sort,RangedSummarizedExperiment-method}
+\alias{split,RangedSummarizedExperiment-method}
+\alias{split,RangedSummarizedExperiment,ANY-method}
+\alias{start,RangedSummarizedExperiment-method}
+\alias{start<-,RangedSummarizedExperiment-method}
+\alias{strand,RangedSummarizedExperiment-method}
+\alias{strand<-,RangedSummarizedExperiment,ANY-method}
+\alias{subset,RangedSummarizedExperiment-method}
+\alias{width,RangedSummarizedExperiment-method}
+\alias{width<-,RangedSummarizedExperiment-method}
+
+\alias{updateObject,SummarizedExperiment-method}
+
+\title{RangedSummarizedExperiment objects}
+
+\description{
+
+  The RangedSummarizedExperiment class is a matrix-like container where rows
+  represent ranges of interest (as a \link{GRanges} or \link{GRangesList}
+  object) and columns represent samples (with sample data summarized as a
+  \link{DataFrame}). A RangedSummarizedExperiment contains one or more
+  assays, each represented by a matrix-like object of numeric or other mode.
+
+  RangedSummarizedExperiment is a subclass of \link{SummarizedExperiment} and,
+  as such, all the methods documented in \code{?\link{SummarizedExperiment}}
+  also work on a RangedSummarizedExperiment object. The methods documented
+  below are additional methods that are specific to RangedSummarizedExperiment
+  objects.
+}
+
+\usage{
+
+## Constructor
+
+SummarizedExperiment(assays, ...)
+\S4method{SummarizedExperiment}{SimpleList}(assays, rowData=NULL, rowRanges=GRangesList(),
+    colData=DataFrame(), metadata=list())
+\S4method{SummarizedExperiment}{ANY}(assays, ...)
+\S4method{SummarizedExperiment}{list}(assays, ...)
+\S4method{SummarizedExperiment}{missing}(assays, ...)
+
+## Accessors
+
+rowRanges(x, ...)
+rowRanges(x, ...) <- value
+
+## Subsetting
+
+\S4method{subset}{RangedSummarizedExperiment}(x, subset, select, ...)
+
+## rowRanges access
+## see 'GRanges compatibility', below
+}
+
+\arguments{
+
+  \item{assays}{A \code{list} or \code{SimpleList} of matrix-like elements,
+    or a matrix-like object. All elements of the list must have the same
+    dimensions, and dimension names (if present) must be consistent
+    across elements and with the row names of \code{rowRanges} and
+    \code{colData}.}
+
+  \item{rowData}{A \link[S4Vectors]{DataFrame} object describing 
+    the rows. Row names, if present, become the row names of the
+    SummarizedExperiment object. The number of rows of the
+    \link[S4Vectors]{DataFrame} must equal the number of rows of the
+    matrices in \code{assays}.}
+
+  \item{rowRanges}{A \link[GenomicRanges]{GRanges} or
+    \link[GenomicRanges]{GRangesList} object describing the ranges of
+    interest. Names, if present, become the row names of the
+    SummarizedExperiment object. The length of the
+    \link[GenomicRanges]{GRanges} or \link[GenomicRanges]{GRangesList}
+    must equal the number of rows of the matrices in \code{assays}.
+    If \code{rowRanges} is missing, a \link{SummarizedExperiment}
+    instance is returned.}
+
+  \item{colData}{An optional \link{DataFrame} describing the
+    samples. Row names, if present, become the column names of the
+    RangedSummarizedExperiment.}
+
+  \item{metadata}{An optional \code{list} of arbitrary content
+    describing the overall experiment.}
+
+  \item{...}{For \code{SummarizedExperiment}, S4 methods \code{list}
+    and \code{matrix}, arguments identical to those of the
+    \code{SimpleList} method.
+
+    For \code{rowRanges}, ignored.
+
+  }
+
+  \item{x}{A RangedSummarizedExperiment object. The \code{rowRanges} setter
+    will also accept a \link{SummarizedExperiment} object and will first
+    coerce it to RangedSummarizedExperiment before it sets \code{value} on
+    it.}
+
+  \item{value}{A \link[GenomicRanges]{GRanges} or
+    \link[GenomicRanges]{GRangesList} object.}
+
+  \item{subset}{An expression which, when evaluated in the
+    context of \code{rowRanges(x)}, is a logical vector indicating
+    elements or rows to keep: missing values are taken as false.}
+
+  \item{select}{An expression which, when evaluated in the
+    context of \code{colData(x)}, is a logical vector indicating
+    elements or rows to keep: missing values are taken as false.}
+
+}
+
+\details{
+
+  The rows of a RangedSummarizedExperiment object represent ranges
+  (in genomic coordinates) of interest. The ranges of interest are
+  described by a \link{GRanges} or a \link{GRangesList} object, accessible
+  using the \code{rowRanges} function, described below. The \link{GRanges}
+  and \link{GRangesList} classes contains sequence (e.g., chromosome) name,
+  genomic coordinates, and strand information. Each range can be
+  annotated with additional data; this data might be used to describe
+  the range or to summarize results (e.g., statistics of differential
+  abundance) relevant to the range. Rows may or may not have row names;
+  they often will not.
+
+}
+
+\section{Constructor}{
+
+  RangedSummarizedExperiment instances are constructed using the
+  \code{SummarizedExperiment} function with arguments outlined above.
+
+}
+
+\section{Accessors}{
+
+  In the following code snippets, \code{x} is a RangedSummarizedExperiment
+  object.
+
+  \describe{
+
+    \item{\code{rowRanges(x)}, \code{rowRanges(x) <- value}:}{Get or set the
+      row data. \code{value} is a \code{GenomicRanges} object. Row
+      names of \code{value} must be NULL or consistent with the existing
+      row names of \code{x}.}
+   
+  }
+}
+
+\section{GRanges compatibility (rowRanges access)}{
+
+  Many \link{GRanges} and \link{GRangesList} operations are supported on
+  RangedSummarizedExperiment objects, using \code{rowRanges}.
+
+  Supported operations include: \code{\link{pcompare}},
+  \code{\link{duplicated}}, \code{\link{end}}, \code{\link{end<-}}, 
+  \code{\link{granges}}, \code{\link{is.unsorted}}, \code{\link{match}},
+  \code{\link{mcols}}, \code{\link{mcols<-}}, \code{\link{order}},
+  \code{\link{ranges}}, \code{\link{ranges<-}}, \code{\link{rank}},
+  \code{\link{seqinfo}}, \code{\link{seqinfo<-}}, \code{\link{seqnames}},
+  \code{\link{sort}}, \code{\link{start}}, \code{\link{start<-}},
+  \code{\link{strand}}, \code{\link{strand<-}},
+  \code{\link{width}}, \code{\link{width<-}}.
+
+  See also \code{?\link[SummarizedExperiment]{shift}},
+  \code{?\link[SummarizedExperiment]{isDisjoint}},
+  \code{?\link[SummarizedExperiment]{coverage}},
+  \code{?\link[SummarizedExperiment]{findOverlaps}}, and
+  \code{?\link[SummarizedExperiment]{nearest}} for more
+  \emph{GRanges compatibility methods}.
+
+  Not all \link{GRanges} operations are supported, because
+  they do not make sense for RangedSummarizedExperiment objects
+  (e.g., length, name, as.data.frame, c, splitAsList), involve
+  non-trivial combination or splitting of rows (e.g., disjoin, gaps,
+  reduce, unique), or have not yet been implemented (Ops, map, window,
+  window<-).
+
+}
+
+\section{Subsetting}{
+
+  In the code snippets below, \code{x} is a RangedSummarizedExperiment
+  object.
+
+  \describe{
+
+    \item{\code{subset(x, subset, select)}:}{Create a subset of \code{x}
+      using an expression \code{subset} referring to columns of
+      \code{rowRanges(x)} (including \sQuote{seqnames}, \sQuote{start},
+      \sQuote{end}, \sQuote{width}, \sQuote{strand}, and
+      \code{names(rowData(x))}) and / or \code{select} referring to
+      column names of \code{colData(x)}.}
+
+  }
+
+}
+
+\section{Extension}{
+
+  RangedSummarizedExperiment is implemented as an S4 class, and can be
+  extended in the usual way, using \code{contains="RangedSummarizedExperiment"}
+  in the new class definition.
+
+}
+
+\author{Martin Morgan, \url{mtmorgan at fhcrc.org}}
+
+\seealso{
+  \itemize{
+    \item \link{SummarizedExperiment} objects.
+
+    \item \link[SummarizedExperiment]{shift},
+          \link[SummarizedExperiment]{isDisjoint},
+          \link[SummarizedExperiment]{coverage},
+          \link[SummarizedExperiment]{findOverlaps}, and
+          \link[SummarizedExperiment]{nearest} for more
+          \emph{GRanges compatibility methods}.
+
+    \item \link[GenomicRanges]{GRanges} objects in the \pkg{GenomicRanges}
+          package.
+  }
+}
+
+\examples{
+nrows <- 200; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(50, 150)),
+                     IRanges(floor(runif(200, 1e5, 1e6)), width=100),
+                     strand=sample(c("+", "-"), 200, TRUE),
+                     feature_id=sprintf("ID\%03d", 1:200))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                            rowRanges=rowRanges, colData=colData)
+rse
+dim(rse)
+dimnames(rse)
+assayNames(rse)
+head(assay(rse))
+assays(rse) <- endoapply(assays(rse), asinh)
+head(assay(rse))
+
+rowRanges(rse)
+rowData(rse)  # same as 'mcols(rowRanges(rse))'
+colData(rse)
+
+rse[, rse$Treatment == "ChIP"]
+
+## cbind() combines objects with the same ranges but different samples:
+rse1 <- rse
+rse2 <- rse1[,1:3]
+colnames(rse2) <- letters[1:ncol(rse2)] 
+cmb1 <- cbind(rse1, rse2)
+dim(cmb1)
+dimnames(cmb1)
+
+## rbind() combines objects with the same samples but different ranges:
+rse1 <- rse
+rse2 <- rse1[1:50,]
+rownames(rse2) <- letters[1:nrow(rse2)] 
+cmb2 <- rbind(rse1, rse2)
+dim(cmb2)
+dimnames(cmb2)
+
+## Coercion to/from SummarizedExperiment:
+se0 <- as(rse, "SummarizedExperiment")
+se0
+
+as(se0, "RangedSummarizedExperiment")
+
+## Setting rowRanges on a SummarizedExperiment object turns it into a
+## RangedSummarizedExperiment object:
+se <- se0
+rowRanges(se) <- rowRanges
+se  # RangedSummarizedExperiment
+
+## Sanity checks:
+stopifnot(identical(assays(se0), assays(rse)))
+stopifnot(identical(dim(se0), dim(rse)))
+stopifnot(identical(dimnames(se0), dimnames(rse)))
+stopifnot(identical(rowData(se0), rowData(rse)))
+stopifnot(identical(colData(se0), colData(rse)))
+}
diff --git a/man/SummarizedExperiment-class.Rd b/man/SummarizedExperiment-class.Rd
new file mode 100644
index 0000000..0d49063
--- /dev/null
+++ b/man/SummarizedExperiment-class.Rd
@@ -0,0 +1,454 @@
+\name{SummarizedExperiment-class}
+\docType{class}
+
+% Class
+\alias{class:SummarizedExperiment}
+\alias{SummarizedExperiment-class}
+
+% Accessors
+\alias{length,SummarizedExperiment-method}
+\alias{names,SummarizedExperiment-method}
+\alias{names<-,SummarizedExperiment-method}
+\alias{rowData}
+\alias{rowData,SummarizedExperiment-method}
+\alias{rowData<-}
+\alias{rowData<-,SummarizedExperiment-method}
+\alias{colData}
+\alias{colData,SummarizedExperiment-method}
+\alias{colData<-}
+\alias{colData<-,SummarizedExperiment,DataFrame-method}
+\alias{assays}
+\alias{assays,SummarizedExperiment-method}
+\alias{assays<-}
+\alias{assays<-,SummarizedExperiment,SimpleList-method}
+\alias{assays<-,SummarizedExperiment,list-method}
+\alias{assay}
+\alias{assay,SummarizedExperiment,missing-method}
+\alias{assay,SummarizedExperiment,numeric-method}
+\alias{assay,SummarizedExperiment,character-method}
+\alias{assay<-}
+\alias{assay<-,SummarizedExperiment,missing-method}
+\alias{assay<-,SummarizedExperiment,numeric-method}
+\alias{assay<-,SummarizedExperiment,character-method}
+\alias{assayNames}
+\alias{assayNames,SummarizedExperiment-method}
+\alias{assayNames<-}
+\alias{assayNames<-,SummarizedExperiment,character-method}
+\alias{dim,SummarizedExperiment-method}
+\alias{dimnames,SummarizedExperiment-method}
+\alias{dimnames<-,SummarizedExperiment,list-method}
+\alias{dimnames<-,SummarizedExperiment,NULL-method}
+
+% Subsetting
+\alias{[,SummarizedExperiment-method}
+\alias{[,SummarizedExperiment,ANY-method}
+\alias{[,SummarizedExperiment,ANY,ANY,ANY-method}
+\alias{[<-,SummarizedExperiment,ANY,ANY,SummarizedExperiment-method}
+\alias{extractROWS,SummarizedExperiment,ANY-method}
+\alias{replaceROWS,SummarizedExperiment-method}
+
+% Quick colData access
+\alias{[[,SummarizedExperiment,ANY,missing-method}
+\alias{[[<-,SummarizedExperiment,ANY,missing-method}
+\alias{$,SummarizedExperiment-method}
+\alias{$<-,SummarizedExperiment-method}
+
+% Display
+\alias{show,SummarizedExperiment-method}
+
+% Combine 
+\alias{rbind,SummarizedExperiment-method}
+\alias{cbind,SummarizedExperiment-method}
+
+% On-disk realization
+\alias{realize,SummarizedExperiment-method}
+
+\title{SummarizedExperiment objects}
+
+\description{
+
+  The SummarizedExperiment class is a matrix-like container where rows
+  represent features of interest (e.g. genes, transcripts, exons, etc...)
+  and columns represent samples (with sample data summarized as a
+  \link{DataFrame}). A SummarizedExperiment object contains one or more
+  assays, each represented by a matrix-like object of numeric or other mode.
+
+  Note that SummarizedExperiment is the parent of the
+  \link{RangedSummarizedExperiment} class which means that all the methods
+  documented below also work on a \link{RangedSummarizedExperiment} object.
+}
+
+\usage{
+
+## Constructor
+
+# See ?RangedSummarizedExperiment for the constructor function.
+
+## Accessors
+
+assayNames(x, ...)
+assayNames(x, ...) <- value
+assays(x, ..., withDimnames=TRUE)
+assays(x, ..., withDimnames=TRUE) <- value
+assay(x, i, ...)
+assay(x, i, ...) <- value
+rowData(x, ...)
+rowData(x, ...) <- value
+colData(x, ...)
+colData(x, ...) <- value
+#dim(x)
+#dimnames(x)
+#dimnames(x) <- value
+
+## Quick colData access
+
+\S4method{$}{SummarizedExperiment}(x, name)
+\S4method{$}{SummarizedExperiment}(x, name) <- value
+\S4method{[[}{SummarizedExperiment,ANY,missing}(x, i, j, ...)
+\S4method{[[}{SummarizedExperiment,ANY,missing}(x, i, j, ...) <- value
+
+## Subsetting
+
+\S4method{[}{SummarizedExperiment}(x, i, j, ..., drop=TRUE)
+\S4method{[}{SummarizedExperiment,ANY,ANY,SummarizedExperiment}(x, i, j) <- value
+
+## Combining 
+
+\S4method{cbind}{SummarizedExperiment}(..., deparse.level=1)
+\S4method{rbind}{SummarizedExperiment}(..., deparse.level=1)
+
+## On-disk realization
+\S4method{realize}{SummarizedExperiment}(x)
+}
+
+\arguments{
+
+  \item{x}{A SummarizedExperiment object.}
+
+  \item{...}{
+    For \code{assay}, \code{...} may contain \code{withDimnames}, which is
+    forwarded to \code{assays}.
+
+    For \code{rowData}, arguments passed thru \code{...} are forwarded to
+    \code{\link[S4Vectors]{mcols}}.
+
+    For \code{cbind}, \code{rbind}, \code{...} contains SummarizedExperiment
+    objects to be combined.
+
+    For other accessors, ignored.
+  }
+
+  \item{i, j}{
+    For \code{assay}, \code{assay<-}, \code{i} is an integer or
+    numeric scalar; see \sQuote{Details} for additional constraints.
+
+    For \code{[,SummarizedExperiment},
+    \code{[,SummarizedExperiment<-}, \code{i}, \code{j} are subscripts
+    that can act to subset the rows and columns of \code{x}, that is the
+    \code{matrix} elements of \code{assays}.
+
+    For \code{[[,SummarizedExperiment},
+    \code{[[<-,SummarizedExperiment}, \code{i} is a scalar index (e.g.,
+    \code{character(1)} or \code{integer(1)}) into a column of
+    \code{colData}.
+  }
+
+  \item{name}{A symbol representing the name of a column of
+    \code{colData}.}
+
+  \item{withDimnames}{A \code{logical(1)}, indicating whether dimnames
+    should be applied to extracted assay elements. Setting
+    \code{withDimnames=FALSE} increases the speed and memory efficiency
+    with which assays are extracted. \code{withDimnames=TRUE} in the
+    getter \code{assays<-} allows efficient complex assignments (e.g.,
+    updating names of assays, \code{names(assays(x, withDimnames=FALSE))
+    = ...} is more efficient than \code{names(assays(x)) = ...}); it
+    does not influence actual assignment of dimnames to assays.}
+
+  \item{drop}{A \code{logical(1)}, ignored by these methods.}
+
+  \item{value}{An object of a class specified in the S4 method
+    signature or as outlined in \sQuote{Details}.}
+
+  \item{deparse.level}{See \code{?base::\link[base]{cbind}} for a description of
+    this argument.}
+
+}
+
+\details{
+
+  The SummarizedExperiment class is meant for numeric and other
+  data types derived from a sequencing experiment. The structure is
+  rectangular like a \code{matrix}, but with additional annotations on
+  the rows and columns, and with the possibility to manage several
+  assays simultaneously.
+
+  The rows of a SummarizedExperiment object represent features
+  of interest. Information about these features is stored in a
+  \link{DataFrame} object, accessible using the function
+  \code{rowData}. The \link{DataFrame} must have as many rows
+  as there are rows in the SummarizedExperiment object, with each row
+  of the \link{DataFrame} providing information on the feature in the
+  corresponding row of the SummarizedExperiment object. Columns of the
+  \link{DataFrame} represent different attributes of the features
+  of interest, e.g., gene or transcript IDs, etc.
+
+  Each column of a SummarizedExperiment object represents a sample.
+  Information about the samples are stored in a \link{DataFrame},
+  accessible using the function \code{colData}, described below.
+  The \link{DataFrame} must have as many rows as there are
+  columns in the SummarizedExperiment object, with each row of the
+  \link{DataFrame} providing information on the sample in the
+  corresponding column of the SummarizedExperiment object.
+  Columns of the \link{DataFrame} represent different sample
+  attributes, e.g., tissue of origin, etc. Columns of the
+  \link{DataFrame} can themselves be annotated (via the
+  \code{\link[S4Vectors]{mcols}} function). Column names typically
+  provide a short identifier unique to each sample.
+
+  A SummarizedExperiment object can also contain information about
+  the overall experiment, for instance the lab in which it was conducted,
+  the publications with which it is associated, etc. This information is
+  stored as a \code{list} object, accessible using the \code{metadata}
+  function. The form of the data associated with the experiment is left to
+  the discretion of the user.
+
+  The SummarizedExperiment container is appropriate for matrix-like
+  data. The data are accessed using the \code{assays} function,
+  described below. This returns a \link{SimpleList} object. Each
+  element of the list must itself be a matrix (of any mode) and must
+  have dimensions that are the same as the dimensions of the
+  SummarizedExperiment in which they are stored. Row and column
+  names of each matrix must either be \code{NULL} or match those of the
+  SummarizedExperiment during construction. It is convenient for
+  the elements of \link{SimpleList} of assays to be named.
+
+}
+
+\section{Constructor}{
+
+  SummarizedExperiment instances are constructed using the
+  \code{SummarizedExperiment} function documented in
+  \code{?\link{RangedSummarizedExperiment}}.
+
+}
+
+\section{Accessors}{
+
+  In the following code snippets, \code{x} is a SummarizedExperiment
+  object.
+
+  \describe{
+
+    \item{\code{assays(x)}, \code{assays(x) <- value}:}{Get or set the
+      assays. \code{value} is a \code{list} or \code{SimpleList}, each
+      element of which is a matrix with the same dimensions as
+      \code{x}.}
+
+    \item{\code{assay(x, i)}, \code{assay(x, i) <- value}:}{A convenient
+      alternative (to \code{assays(x)[[i]]}, \code{assays(x)[[i]] <-
+      value}) to get or set the \code{i}th (default first) assay
+      element. \code{value} must be a matrix of the same dimension as
+      \code{x}, and with dimension names \code{NULL} or consistent with
+      those of \code{x}.}
+
+    \item{\code{assayNames(x)}, \code{assayNames(x) <- value}:}{Get or
+     set the names of \code{assay()} elements.}
+
+    \item{\code{rowData(x)}, \code{rowData(x) <- value}:}{Get or set the
+      row data. \code{value} is a \link{DataFrame} object. Row
+      names of \code{value} must be NULL or consistent with the existing
+      row names of \code{x}.}
+
+    \item{\code{colData(x)}, \code{colData(x) <- value}:}{Get or set the
+      column data. \code{value} is a \link{DataFrame} object. Row
+      names of \code{value} must be NULL or consistent with the existing
+      column names of \code{x}.}
+
+    \item{\code{metadata(x)}, \code{metadata(x) <- value}:}{Get or set
+      the experiment data. \code{value} is a \code{list} with arbitrary
+      content.}
+
+    \item{\code{dim(x)}:}{Get the dimensions (features of interest x samples)
+      of the SummarizedExperiment.}
+
+    \item{\code{dimnames(x)}, \code{dimnames(x) <- value}:}{Get or set
+      the dimension names. \code{value} is usually a list of length 2,
+      containing elements that are either \code{NULL} or vectors of
+      appropriate length for the corresponding dimension. \code{value}
+      can be \code{NULL}, which removes dimension names. This method
+      implies that \code{rownames}, \code{rownames<-}, \code{colnames},
+      and \code{colnames<-} are all available.}
+
+  }
+}
+
+\section{Subsetting}{
+
+  In the code snippets below, \code{x} is a SummarizedExperiment object.
+
+  \describe{
+
+    \item{\code{x[i,j]}, \code{x[i,j] <- value}:}{Create or replace a
+      subset of \code{x}. \code{i}, \code{j} can be \code{numeric},
+      \code{logical}, \code{character}, or \code{missing}. \code{value}
+      must be a SummarizedExperiment object with dimensions,
+      dimension names, and assay elements consistent with the subset
+      \code{x[i,j]} being replaced.}
+
+  }
+
+  Additional subsetting accessors provide convenient access to
+  \code{colData} columns
+
+  \describe{
+
+    \item{\code{x$name}, \code{x$name <- value}}{Access or replace
+    column \code{name} in \code{x}.}
+
+    \item{\code{x[[i, ...]]}, \code{x[[i, ...]] <- value}}{Access or
+    replace column \code{i} in \code{x}.}
+
+  }
+
+}
+
+\section{Combining}{
+
+  In the code snippets below, \code{...} are SummarizedExperiment objects
+  to be combined.
+
+  \describe{
+
+    \item{\code{cbind(...)}:}{
+      \code{cbind} combines objects with the same features of interest
+      but different samples (columns in \code{assays}).
+      The colnames in \code{colData(SummarizedExperiment)} must match or
+      an error is thrown.
+      Duplicate columns of \code{rowData(SummarizedExperiment)} must
+      contain the same data.
+
+      Data in \code{assays} are combined by name matching; if all assay
+      names are NULL matching is by position. A mixture of names and NULL
+      throws an error.
+
+      \code{metadata} from all objects are combined into a \code{list}
+      with no name checking.
+    }
+
+    \item{\code{rbind(...)}:}{
+      \code{rbind} combines objects with the same samples
+      but different features of interest (rows in \code{assays}).
+      The colnames in \code{rowData(SummarizedExperiment)} must match or
+      an error is thrown.
+      Duplicate columns of \code{colData(SummarizedExperiment)} must
+      contain the same data. 
+
+      Data in \code{assays} are combined by name matching; if all assay
+      names are NULL matching is by position. A mixture of names and NULL
+      throws an error.
+
+      \code{metadata} from all objects are combined into a \code{list}
+      with no name checking.
+    }
+
+  }
+
+}
+
+\section{Implementation and Extension}{
+
+  This section contains advanced material meant for package developers.
+
+  SummarizedExperiment is implemented as an S4 class, and can be extended in
+  the usual way, using \code{contains="SummarizedExperiment"} in the new
+  class definition.
+
+  In addition, the representation of the \code{assays} slot of
+  SummarizedExperiment is as a virtual class Assays. This
+  allows derived classes (\code{contains="Assays"}) to easily implement
+  alternative requirements for the assays, e.g., backed by file-based
+  storage like NetCDF or the \code{ff} package, while re-using the existing
+  SummarizedExperiment class without modification.
+  See \link{Assays} for more information.
+
+  The current \code{assays} slot is implemented as a reference class
+  that has copy-on-change semantics. This means that modifying non-assay
+  slots does not copy the (large) assay data, and at the same time the
+  user is not surprised by reference-based semantics. Updates to
+  non-assay slots are very fast; updating the assays slot itself can be
+  5x or more faster than with an S4 instance in the slot. One useful
+  technique when working with \code{assay} or \code{assays} function is
+  use of the \code{withDimnames=FALSE} argument, which benefits speed
+  and memory use by not copying dimnames from the row- and colData
+  elements to each assay.
+}
+
+\author{Martin Morgan, \url{mtmorgan at fhcrc.org}}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item \link[S4Vectors]{DataFrame}, \link[S4Vectors]{SimpleList}, and
+          \link[S4Vectors]{Annotated} objects in the \pkg{S4Vectors} package.
+
+    \item The \code{\link[S4Vectors]{metadata}} and
+          \code{\link[S4Vectors]{mcols}} accessors in the \pkg{S4Vectors}
+          package.
+
+    \item \code{\link{saveHDF5SummarizedExperiment}} and
+          \code{\link{loadHDF5SummarizedExperiment}} for saving/loading a
+          HDF5-based SummarizedExperiment object to/from disk.
+
+    \item The \code{\link[DelayedArray]{realize}} generic function in the
+          \pkg{DelayedArray} package for more information about on-disk
+          realization of objects carrying delayed operations.
+  }
+}
+
+\examples{
+nrows <- 200; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+se0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                            colData=colData)
+se0
+dim(se0)
+dimnames(se0)
+assayNames(se0)
+head(assay(se0))
+assays(se0) <- endoapply(assays(se0), asinh)
+head(assay(se0))
+
+rowData(se0)
+colData(se0)
+
+se0[, se0$Treatment == "ChIP"]
+
+## cbind() combines objects with the same features of interest
+## but different samples:
+se1 <- se0
+se2 <- se1[,1:3]
+colnames(se2) <- letters[1:ncol(se2)] 
+cmb1 <- cbind(se1, se2)
+dim(cmb1)
+dimnames(cmb1)
+
+## rbind() combines objects with the same samples but different
+## features of interest:
+se1 <- se0
+se2 <- se1[1:50,]
+rownames(se2) <- letters[1:nrow(se2)] 
+cmb2 <- rbind(se1, se2)
+dim(cmb2)
+dimnames(cmb2)
+
+## ---------------------------------------------------------------------
+## ON-DISK REALIZATION
+## ---------------------------------------------------------------------
+setRealizationBackend("HDF5Array")
+cmb3 <- realize(cmb2)
+assay(cmb3, withDimnames=FALSE)  # an HDF5Matrix object
+}
diff --git a/man/coverage-methods.Rd b/man/coverage-methods.Rd
new file mode 100644
index 0000000..186da4f
--- /dev/null
+++ b/man/coverage-methods.Rd
@@ -0,0 +1,80 @@
+\name{coverage-methods}
+
+\alias{coverage-methods}
+
+\alias{coverage}
+\alias{coverage,RangedSummarizedExperiment-method}
+
+
+\title{Coverage of a RangedSummarizedExperiment object}
+
+\description{
+  This man page documents the \code{coverage} method for
+  \link{RangedSummarizedExperiment} objects.
+}
+
+\usage{
+\S4method{coverage}{RangedSummarizedExperiment}(x, shift=0L, width=NULL, weight=1L,
+            method=c("auto", "sort", "hash"))
+}
+
+\arguments{
+  \item{x}{
+    A \link{RangedSummarizedExperiment} object.
+  }
+  \item{shift, width, weight, method}{
+    See \code{?\link[GenomicRanges]{coverage}} in the \pkg{GenomicRanges}
+    package.
+  }
+}
+
+\details{
+  This method operates on the \code{rowRanges} component of the
+  \link{RangedSummarizedExperiment} object, which can be a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+
+  More precisely, on \link{RangedSummarizedExperiment} object \code{x},
+  \code{coverage(x, ...)} is equivalent to \code{coverage(rowRanges(x), ...)}.
+
+  See \code{?\link[GenomicRanges]{coverage}} in the \pkg{GenomicRanges}
+  package for the details of how \code{coverage} operates on a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+}
+
+\value{
+  See \code{?\link[GenomicRanges]{coverage}} in the \pkg{GenomicRanges}
+  package.
+}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item The \link[GenomicRanges]{coverage} man page in the
+          \pkg{GenomicRanges} package where the \code{coverage} methods
+          for \link[GenomicRanges]{GenomicRanges} and
+          \link[GenomicRanges]{GRangesList} objects are documented.
+  }
+}
+
+\examples{
+nrows <- 20; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(5, 15)),
+                     IRanges(sample(1000L, 20), width=100),
+                     strand=Rle(c("+", "-"), c(12, 8)),
+                     seqlengths=c(chr1=1800, chr2=1300))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                            rowRanges=rowRanges, colData=colData)
+
+cvg <- coverage(rse)
+cvg
+stopifnot(identical(cvg, coverage(rowRanges(rse))))
+}
+
+\keyword{methods}
+\keyword{utilities}
diff --git a/man/findOverlaps-methods.Rd b/man/findOverlaps-methods.Rd
new file mode 100644
index 0000000..ef0fe83
--- /dev/null
+++ b/man/findOverlaps-methods.Rd
@@ -0,0 +1,105 @@
+\name{findOverlaps-methods}
+
+\alias{findOverlaps-methods}
+
+\alias{findOverlaps}
+\alias{findOverlaps,RangedSummarizedExperiment,Vector-method}
+\alias{findOverlaps,Vector,RangedSummarizedExperiment-method}
+\alias{findOverlaps,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+
+\title{Finding overlapping ranges in RangedSummarizedExperiment objects}
+
+\description{
+  This man page documents the \code{findOverlaps} methods for
+  \link{RangedSummarizedExperiment} objects.
+
+  \link{RangedSummarizedExperiment} objects also support
+  \code{countOverlaps}, \code{overlapsAny}, and \code{subsetByOverlaps}
+  thanks to the default methods defined in the \pkg{IRanges} package and
+  to the \code{findOverlaps} methods defined in this package and documented
+  below.
+}
+
+\usage{
+\S4method{findOverlaps}{RangedSummarizedExperiment,Vector}(query, subject,
+    maxgap=0L, minoverlap=1L,
+    type=c("any", "start", "end", "within", "equal"),
+    select=c("all", "first", "last", "arbitrary"),
+    ignore.strand=FALSE)
+\S4method{findOverlaps}{Vector,RangedSummarizedExperiment}(query, subject,
+    maxgap=0L, minoverlap=1L,
+    type=c("any", "start", "end", "within", "equal"),
+    select=c("all", "first", "last", "arbitrary"),
+    ignore.strand=FALSE)
+}
+
+\arguments{
+  \item{query, subject}{
+    One of these two arguments must be a \link{RangedSummarizedExperiment}
+    object.
+  }
+  \item{maxgap, minoverlap, type}{
+    See \code{?\link[GenomicRanges]{findOverlaps}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{select, ignore.strand}{
+    See \code{?\link[GenomicRanges]{findOverlaps}} in the \pkg{GenomicRanges}
+    package.
+  }
+}
+
+\details{
+  These methods operate on the \code{rowRanges} component of the
+  \link{RangedSummarizedExperiment} object, which can be a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+
+  More precisely, if any of the above functions is passed a
+  \link{RangedSummarizedExperiment} object thru the \code{query} and/or
+  \code{subject} argument, then it behaves as if \code{rowRanges(query)}
+  and/or \code{rowRanges(subject)} had been passed instead.
+
+  See \code{?\link[GenomicRanges]{findOverlaps}} in the \pkg{GenomicRanges}
+  package for the details of how \code{findOverlaps} and family operate on
+  \link[GenomicRanges]{GenomicRanges} and \link[GenomicRanges]{GRangesList}
+  objects.
+}
+
+\value{
+  See \code{?\link[GenomicRanges]{findOverlaps}} in the \pkg{GenomicRanges}
+  package.
+}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item The \link[GenomicRanges]{findOverlaps} man page in the
+          \pkg{GenomicRanges} package where the \code{findOverlaps} family
+          of methods for \link[GenomicRanges]{GenomicRanges} and
+          \link[GenomicRanges]{GRangesList} objects is documented.
+  }
+}
+
+\examples{
+nrows <- 20; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(5, 15)),
+                     IRanges(sample(1000L, 20), width=100),
+                     strand=Rle(c("+", "-"), c(12, 8)))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                             rowRanges=rowRanges, colData=colData)
+rse1 <- shift(rse0, 100)
+
+hits <- findOverlaps(rse0, rse1)
+hits
+stopifnot(identical(hits, findOverlaps(rowRanges(rse0), rowRanges(rse1))))
+stopifnot(identical(hits, findOverlaps(rse0, rowRanges(rse1))))
+stopifnot(identical(hits, findOverlaps(rowRanges(rse0), rse1)))
+}
+
+\keyword{methods}
+\keyword{utilities}
diff --git a/man/inter-range-methods.Rd b/man/inter-range-methods.Rd
new file mode 100644
index 0000000..e2cf611
--- /dev/null
+++ b/man/inter-range-methods.Rd
@@ -0,0 +1,95 @@
+\name{inter-range-methods}
+
+\alias{inter-range-methods}
+
+\alias{isDisjoint}
+\alias{isDisjoint,RangedSummarizedExperiment-method}
+
+\alias{disjointBins}
+\alias{disjointBins,RangedSummarizedExperiment-method}
+
+
+\title{Inter range transformations of a RangedSummarizedExperiment object}
+
+\description{
+  This man page documents the \emph{inter range transformations} that are
+  supported on \link{RangedSummarizedExperiment} objects.
+}
+
+\usage{
+\S4method{isDisjoint}{RangedSummarizedExperiment}(x, ignore.strand=FALSE)
+
+\S4method{disjointBins}{RangedSummarizedExperiment}(x, ignore.strand=FALSE)
+}
+
+\arguments{
+  \item{x}{
+    A \link{RangedSummarizedExperiment} object.
+  }
+  \item{ignore.strand}{
+    See \code{?\link[GenomicRanges]{isDisjoint}} in the
+    \pkg{GenomicRanges} package.
+  }
+}
+
+\details{
+  These transformations operate on the \code{rowRanges} component of the
+  \link{RangedSummarizedExperiment} object, which can be a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+
+  More precisely, any of the above functions performs the following
+  transformation on \link{RangedSummarizedExperiment} object \code{x}:
+\preformatted{    f(rowRanges(x), ...)
+}
+  where \code{f} is the name of the function and \code{...} any additional
+  arguments passed to it.
+
+  See \code{?\link[GenomicRanges]{isDisjoint}} in the \pkg{GenomicRanges}
+  package for the details of how these transformations operate on a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+}
+
+\value{
+  See \code{?\link[GenomicRanges]{isDisjoint}} in the
+  \pkg{GenomicRanges} package.
+}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item The \link[GenomicRanges]{isDisjoint} man page in the
+          \pkg{GenomicRanges} package where \emph{inter range transformations}
+          of a \link[GenomicRanges]{GenomicRanges} or
+          \link[GenomicRanges]{GRangesList} object are documented.
+  }
+}
+
+\examples{
+nrows <- 20; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(5, 15)),
+                     IRanges(sample(1000L, 20), width=100),
+                     strand=Rle(c("+", "-"), c(12, 8)))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                             rowRanges=rowRanges, colData=colData)
+rse1 <- shift(rse0, 99*start(rse0))
+
+isDisjoint(rse0)  # FALSE
+isDisjoint(rse1)  # TRUE
+
+bins0 <- disjointBins(rse0)
+bins0
+stopifnot(identical(bins0, disjointBins(rowRanges(rse0))))
+
+bins1 <- disjointBins(rse1)
+bins1
+stopifnot(all(bins1 == bins1[1]))
+}
+
+\keyword{methods} 
+\keyword{utilities}
diff --git a/man/intra-range-methods.Rd b/man/intra-range-methods.Rd
new file mode 100644
index 0000000..5dc7956
--- /dev/null
+++ b/man/intra-range-methods.Rd
@@ -0,0 +1,151 @@
+\name{intra-range-methods}
+
+\alias{intra-range-methods}
+
+\alias{shift}
+\alias{shift,RangedSummarizedExperiment-method}
+
+\alias{narrow}
+\alias{narrow,RangedSummarizedExperiment-method}
+
+\alias{resize}
+\alias{resize,RangedSummarizedExperiment-method}
+
+\alias{flank}
+\alias{flank,RangedSummarizedExperiment-method}
+
+\alias{promoters}
+\alias{promoters,RangedSummarizedExperiment-method}
+
+\alias{restrict}
+\alias{restrict,RangedSummarizedExperiment-method}
+
+\alias{trim,RangedSummarizedExperiment-method}
+
+
+\title{Intra range transformations of a RangedSummarizedExperiment object}
+
+\description{
+  This man page documents the \emph{intra range transformations} that are
+  supported on \link{RangedSummarizedExperiment} objects.
+}
+
+\usage{
+\S4method{shift}{RangedSummarizedExperiment}(x, shift=0L, use.names=TRUE)
+
+\S4method{narrow}{RangedSummarizedExperiment}(x, start=NA, end=NA, width=NA, use.names=TRUE)
+
+\S4method{resize}{RangedSummarizedExperiment}(x, width, fix="start", use.names=TRUE,
+       ignore.strand=FALSE)
+
+\S4method{flank}{RangedSummarizedExperiment}(x, width, start=TRUE, both=FALSE,
+      use.names=TRUE, ignore.strand=FALSE)
+
+\S4method{promoters}{RangedSummarizedExperiment}(x, upstream=2000, downstream=200)
+
+\S4method{restrict}{RangedSummarizedExperiment}(x, start=NA, end=NA, keep.all.ranges=FALSE,
+         use.names=TRUE)
+
+\S4method{trim}{RangedSummarizedExperiment}(x, use.names=TRUE)
+}
+
+\arguments{
+  \item{x}{
+    A \link{RangedSummarizedExperiment} object.
+  }
+  \item{shift, use.names}{
+    See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{start, end, width, fix}{
+    See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{ignore.strand, both}{
+    See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{upstream, downstream}{
+    See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{keep.all.ranges}{
+    See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+    package.
+  }
+}
+
+\details{
+  These transformations operate on the \code{rowRanges} component of the
+  \link{RangedSummarizedExperiment} object, which can be a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+
+  More precisely, any of the above functions performs the following
+  transformation on \link{RangedSummarizedExperiment} object \code{x}:
+\preformatted{    rowRanges(x) <- f(rowRanges(x), ...)
+}
+  where \code{f} is the name of the function and \code{...} any additional
+  arguments passed to it.
+
+  See \code{?\link[GenomicRanges]{shift}} in the \pkg{GenomicRanges}
+  package for the details of how these transformations operate on a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item The \link[GenomicRanges]{shift} man page in the
+          \pkg{GenomicRanges} package where \emph{intra range transformations}
+          of a \link[GenomicRanges]{GenomicRanges} or
+          \link[GenomicRanges]{GRangesList} object are documented.
+  }
+}
+
+\examples{
+nrows <- 20; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(5, 15)),
+                     IRanges(sample(1000L, 20), width=100),
+                     strand=Rle(c("+", "-"), c(12, 8)))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                             rowRanges=rowRanges, colData=colData)
+
+rse1 <- shift(rse0, 1)
+stopifnot(identical(
+  rowRanges(rse1),
+  shift(rowRanges(rse0), 1)
+))
+
+se2 <- narrow(rse0, start=10, end=-15)
+stopifnot(identical(
+  rowRanges(se2),
+  narrow(rowRanges(rse0), start=10, end=-15)
+))
+
+se3 <- resize(rse0, width=75)
+stopifnot(identical(
+  rowRanges(se3),
+  resize(rowRanges(rse0), width=75)
+))
+
+se4 <- flank(rse0, width=20)
+stopifnot(identical(
+  rowRanges(se4),
+  flank(rowRanges(rse0), width=20)
+))
+
+se5 <- restrict(rse0, start=200, end=700, keep.all.ranges=TRUE)
+stopifnot(identical(
+  rowRanges(se5),
+  restrict(rowRanges(rse0), start=200, end=700, keep.all.ranges=TRUE)
+))
+}
+
+\keyword{methods}
+\keyword{utilities}
diff --git a/man/makeSummarizedExperimentFromDataFrame.Rd b/man/makeSummarizedExperimentFromDataFrame.Rd
new file mode 100644
index 0000000..b3087b8
--- /dev/null
+++ b/man/makeSummarizedExperimentFromDataFrame.Rd
@@ -0,0 +1,87 @@
+\name{makeSummarizedExperimentFromDataFrame}
+
+\alias{makeSummarizedExperimentFromDataFrame}
+
+\title{Make a RangedSummarizedExperiment from a data.frame or DataFrame}
+
+\description{
+    \code{makeSummarizedExperimentFromDataFrame} uses \code{data.frame}
+    or \code{DataFrame} column names to create a \link{GRanges} object for the
+    \code{rowRanges} of the resulting \link{SummarizedExperiment} object.
+    It requires that non-range data columns be coercible into a \code{numeric}
+    \code{matrix} for the \link{SummarizedExperiment} constructor. All columns
+    that are not part of the row ranges attribute are assumed to be experiment
+    data; thus, keeping metadata columns will not be supported. Note that this
+    function only returns \link{SummarizedExperiment} objects with a single
+    assay.
+
+    If metadata columns are to be kept, one can first construct the row ranges
+    attribute by using the \link{makeGRangesFromDataFrame} function and
+    subsequently creating the \link{SummarizedExperiment}.
+}
+
+\usage{
+makeSummarizedExperimentFromDataFrame(df,
+                                    ...,
+                                    seqinfo = NULL,
+                                    starts.in.df.are.0based = FALSE)
+}
+\arguments{
+    \item{df}{
+        A data.frame or \link[S4Vectors]{DataFrame} object. If not, then
+        the function first tries to turn \code{df} into a data frame with
+        \code{as.data.frame(df)}.
+    }
+    \item{...}{
+        Additional arguments passed on to \link{makeGRangesFromDataFrame}
+    }
+    \item{seqinfo}{
+        Either \code{NULL}, or a \link{Seqinfo} object, or a character vector
+        of seqlevels, or a named numeric vector of sequence lengths.
+        When not \code{NULL}, it must be compatible with the genomic ranges
+        in \code{df} i.e. it must include at least the sequence levels
+        represented in \code{df}.
+    }
+    \item{starts.in.df.are.0based}{
+        \code{TRUE} or \code{FALSE} (the default).
+        If \code{TRUE}, then the start positions of the genomic ranges in
+        \code{df} are considered to be \emph{0-based} and are converted to
+        \emph{1-based} in the returned \link{GRanges} object.
+        This feature is intended to make it more convenient to handle input
+        that contains data obtained from resources using the "0-based
+        start" convention. A notorious example of such resource is the UCSC
+        Table Browser (\url{http://genome.ucsc.edu/cgi-bin/hgTables}).
+    }
+}
+\value{
+A \link{RangedSummarizedExperiment} object with rowRanges and a single assay
+}
+\author{
+    M. Ramos
+}
+\seealso{
+  \itemize{
+      \item \link{makeGRangesFromDataFrame} 
+  }
+}
+
+\examples{
+## ---------------------------------------------------------------------
+## BASIC EXAMPLES
+## ---------------------------------------------------------------------
+
+# Note that rownames of the data.frame are also rownames of the result
+df <- data.frame(chr="chr2", start = 11:15, end = 12:16,
+                 strand = c("+", "-", "+", "*", "."), expr0 = 3:7,
+                 expr1 = 8:12, expr2 = 12:16,
+                 row.names = paste0("GENE", letters[5:1]))
+df
+
+exRSE <- makeSummarizedExperimentFromDataFrame(df)
+
+exRSE
+
+assay(exRSE)
+
+rowRanges(exRSE)
+}
diff --git a/man/makeSummarizedExperimentFromExpressionSet.Rd b/man/makeSummarizedExperimentFromExpressionSet.Rd
new file mode 100644
index 0000000..28d175e
--- /dev/null
+++ b/man/makeSummarizedExperimentFromExpressionSet.Rd
@@ -0,0 +1,112 @@
+\name{makeSummarizedExperimentFromExpressionSet}
+
+\alias{makeSummarizedExperimentFromExpressionSet}
+\alias{naiveRangeMapper}
+\alias{probeRangeMapper}
+\alias{geneRangeMapper}
+\alias{coerce,ExpressionSet,RangedSummarizedExperiment-method}
+\alias{coerce,RangedSummarizedExperiment,ExpressionSet-method}
+\alias{coerce,SummarizedExperiment,ExpressionSet-method}
+
+
+\title{Make a RangedSummarizedExperiment object from an ExpressionSet and
+       vice-versa}
+
+\description{
+  Coercion between \link{RangedSummarizedExperiment} and
+  \link[Biobase]{ExpressionSet} is supported in both directions.
+
+  For going from \link[Biobase]{ExpressionSet} to
+  \link{RangedSummarizedExperiment}, the
+  \code{makeSummarizedExperimentFromExpressionSet} function is also
+  provided to let the user control how to map features to ranges.
+}
+
+\usage{
+makeSummarizedExperimentFromExpressionSet(from,
+                                          mapFun=naiveRangeMapper,
+                                          ...)
+
+## range mapping functions
+naiveRangeMapper(from)
+probeRangeMapper(from)
+geneRangeMapper(txDbPackage, key = "ENTREZID")
+}
+
+\arguments{
+  \item{from}{
+    An \link[Biobase]{ExpressionSet} object.
+  }
+  \item{mapFun}{
+    A function which takes an \link[Biobase]{ExpressionSet} object and
+    returns a \link{GRanges}, or \link{GRangesList} object which
+    corresponds to the genomic ranges used in the ExpressionSet.  The
+    \link[base]{rownames} of the returned \link[GenomicRanges]{GRanges}
+    are used to match the \link[Biobase]{featureNames} of the
+    \link[Biobase]{ExpressionSet}.
+
+    The \code{naiveRangeMapper} function is used by default.
+  }
+  \item{...}{
+    Additional arguments passed to \code{mapFun}.
+  }
+  \item{txDbPackage}{
+    A character string with the Transcript Database to use for the mapping.
+  }
+  \item{key}{
+    A character string with the Gene key to use for the mapping.
+  }
+}
+
+\value{
+  \code{makeSummarizedExperimentFromExpressionSet} takes an
+  \link[Biobase]{ExpressionSet} object as input and a \emph{range mapping
+  function} that maps the features to ranges.  It then returns a
+  \link{RangedSummarizedExperiment} object that corresponds to the input.
+
+  The range mapping functions return a \link{GRanges} object, with the
+  \code{rownames} corresponding to the \link[Biobase]{featureNames} of
+  the \link[Biobase]{ExpressionSet} object.
+}
+
+\author{Jim Hester, \url{james.f.hester at gmail.com}}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item \link[Biobase]{ExpressionSet} objects in the \pkg{Biobase} package.
+
+    \item \link[GenomicFeatures]{TxDb} objects in the \pkg{GenomicFeatures}
+          package.
+  }
+}
+
+\examples{
+## ---------------------------------------------------------------------
+## GOING FROM ExpressionSet TO RangedSummarizedExperiment
+## ---------------------------------------------------------------------
+
+data(sample.ExpressionSet, package="Biobase")
+
+# 2 equivalent ways of doing the naive coercion
+makeSummarizedExperimentFromExpressionSet(sample.ExpressionSet)
+as(sample.ExpressionSet, "RangedSummarizedExperiment")
+
+# using probe range mapper
+makeSummarizedExperimentFromExpressionSet(sample.ExpressionSet, probeRangeMapper)
+
+# using the gene range mapper
+makeSummarizedExperimentFromExpressionSet(sample.ExpressionSet,
+                                          geneRangeMapper("TxDb.Hsapiens.UCSC.hg19.knownGene"))
+
+## ---------------------------------------------------------------------
+## GOING FROM RangedSummarizedExperiment TO ExpressionSet
+## ---------------------------------------------------------------------
+
+example(RangedSummarizedExperiment)  # to create 'rse'
+rse
+as(rse, "ExpressionSet")
+}
+
+\keyword{manip}
diff --git a/man/nearest-methods.Rd b/man/nearest-methods.Rd
new file mode 100644
index 0000000..ce4ba46
--- /dev/null
+++ b/man/nearest-methods.Rd
@@ -0,0 +1,149 @@
+\name{nearest-methods}
+
+\alias{nearest-methods}
+
+\alias{precede}
+\alias{precede,RangedSummarizedExperiment,ANY-method}
+\alias{precede,ANY,RangedSummarizedExperiment-method}
+\alias{precede,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+\alias{follow}
+\alias{follow,RangedSummarizedExperiment,ANY-method}
+\alias{follow,ANY,RangedSummarizedExperiment-method}
+\alias{follow,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+\alias{nearest}
+\alias{nearest,RangedSummarizedExperiment,ANY-method}
+\alias{nearest,ANY,RangedSummarizedExperiment-method}
+\alias{nearest,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+\alias{distance}
+\alias{distance,RangedSummarizedExperiment,ANY-method}
+\alias{distance,ANY,RangedSummarizedExperiment-method}
+\alias{distance,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+\alias{distanceToNearest}
+\alias{distanceToNearest,RangedSummarizedExperiment,ANY-method}
+\alias{distanceToNearest,ANY,RangedSummarizedExperiment-method}
+\alias{distanceToNearest,RangedSummarizedExperiment,RangedSummarizedExperiment-method}
+
+
+\title{Finding the nearest range neighbor in RangedSummarizedExperiment objects}
+
+\description{
+  This man page documents the \code{nearest} methods and family (i.e.
+  \code{precede}, \code{follow}, \code{distance}, and \code{distanceToNearest}
+  methods) for \link{RangedSummarizedExperiment} objects.
+}
+
+\usage{
+\S4method{precede}{RangedSummarizedExperiment,ANY}(x, subject, select=c("arbitrary", "all"),
+        ignore.strand=FALSE)
+\S4method{precede}{ANY,RangedSummarizedExperiment}(x, subject, select=c("arbitrary", "all"),
+        ignore.strand=FALSE)
+
+\S4method{follow}{RangedSummarizedExperiment,ANY}(x, subject, select=c("arbitrary", "all"),
+        ignore.strand=FALSE)
+\S4method{follow}{ANY,RangedSummarizedExperiment}(x, subject, select=c("arbitrary", "all"),
+        ignore.strand=FALSE)
+
+\S4method{nearest}{RangedSummarizedExperiment,ANY}(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+\S4method{nearest}{ANY,RangedSummarizedExperiment}(x, subject, select=c("arbitrary", "all"), ignore.strand=FALSE)
+
+\S4method{distance}{RangedSummarizedExperiment,ANY}(x, y, ignore.strand=FALSE, ...)
+\S4method{distance}{ANY,RangedSummarizedExperiment}(x, y, ignore.strand=FALSE, ...)
+
+\S4method{distanceToNearest}{RangedSummarizedExperiment,ANY}(x, subject, ignore.strand=FALSE, ...)
+\S4method{distanceToNearest}{ANY,RangedSummarizedExperiment}(x, subject, ignore.strand=FALSE, ...)
+}
+
+\arguments{
+  \item{x, subject}{
+    One of these two arguments must be a \link{RangedSummarizedExperiment}
+    object.
+  }
+  \item{select, ignore.strand}{
+    See \code{?\link[GenomicRanges]{nearest}} in the \pkg{GenomicRanges}
+    package.
+  }
+  \item{y}{
+    For the \code{distance} methods, one of \code{x} or \code{y} must be a
+    \link{RangedSummarizedExperiment} object.
+  }
+  \item{...}{Additional arguments for methods.}
+}
+
+\details{
+  These methods operate on the \code{rowRanges} component of the
+  \link{RangedSummarizedExperiment} object, which can be a
+  \link[GenomicRanges]{GenomicRanges} or \link[GenomicRanges]{GRangesList}
+  object.
+
+  More precisely, if any of the above functions is passed a
+  \link{RangedSummarizedExperiment} object thru the \code{x}, \code{subject},
+  and/or \code{y} argument, then it behaves as if \code{rowRanges(x)},
+  \code{rowRanges(subject)}, and/or \code{rowRanges(y)} had been passed
+  instead.
+
+  See \code{?\link[GenomicRanges]{nearest}} in the \pkg{GenomicRanges}
+  package for the details of how \code{nearest} and family operate on
+  \link[GenomicRanges]{GenomicRanges} and \link[GenomicRanges]{GRangesList}
+  objects.
+}
+
+\value{
+  See \code{?\link[GenomicRanges]{nearest}} in the \pkg{GenomicRanges}
+  package.
+}
+
+\seealso{
+  \itemize{
+    \item \link{RangedSummarizedExperiment} objects.
+
+    \item The \link[GenomicRanges]{nearest} man page in the
+          \pkg{GenomicRanges} package where the \code{nearest} family
+          of methods for \link[GenomicRanges]{GenomicRanges} and
+          \link[GenomicRanges]{GRangesList} objects is documented.
+  }
+}
+
+\examples{
+nrows <- 20; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(5, 15)),
+                     IRanges(sample(1000L, 20), width=100),
+                     strand=Rle(c("+", "-"), c(12, 8)))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+rse0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                             rowRanges=rowRanges, colData=colData)
+rse1 <- shift(rse0, 100)
+
+res <- nearest(rse0, rse1)
+res
+stopifnot(identical(res, nearest(rowRanges(rse0), rowRanges(rse1))))
+stopifnot(identical(res, nearest(rse0, rowRanges(rse1))))
+stopifnot(identical(res, nearest(rowRanges(rse0), rse1)))
+
+res <- nearest(rse0)  # missing subject
+res
+stopifnot(identical(res, nearest(rowRanges(rse0))))
+
+hits <- nearest(rse0, rse1, select="all")
+hits
+stopifnot(identical(
+  hits,
+  nearest(rowRanges(rse0), rowRanges(rse1), select="all")
+))
+stopifnot(identical(
+  hits,
+  nearest(rse0, rowRanges(rse1), select="all")
+))
+stopifnot(identical(
+  hits,
+  nearest(rowRanges(rse0), rse1, select="all")
+))
+}
+
+\keyword{methods} 
+\keyword{utilities}
diff --git a/man/readKallisto.Rd b/man/readKallisto.Rd
new file mode 100644
index 0000000..c2627f4
--- /dev/null
+++ b/man/readKallisto.Rd
@@ -0,0 +1,120 @@
+\name{readKallisto}
+\alias{readKallisto}
+\alias{readKallistoBootstrap}
+\alias{KALLISTO_ASSAYS}
+
+\title{
+  Input kallisto or kallisto bootstrap results.
+}
+
+\description{
+  \code{readKallisto} inputs several kallisto output files into a single
+  \code{SummarizedExperiment} instance, with rows corresponding to
+  estimated transcript abundance and columns to
+  samples. \code{readKallistoBootstrap} inputs kallisto bootstrap
+  replicates of a single sample into a matrix of transcript x bootstrap
+  abundance estimates.
+}
+
+\usage{
+readKallisto(files,
+    json = file.path(dirname(files), "run_info.json"), 
+    h5 = any(grepl("\\\\.h5$", files)), what = KALLISTO_ASSAYS,
+    as = c("SummarizedExperiment", "list", "matrix"))
+
+readKallistoBootstrap(file, i, j)
+}
+
+\arguments{
+
+  \item{files}{character() paths to kallisto \sQuote{abundance.tsv}
+    output files. The assumption is that files are organized in the way
+    implied by kallisto, with each sample in a distinct directory, and
+    the directory containing files abundance.tsv, run_info.json, and
+    perhaps abundance.h5.}
+
+  \item{json}{character() vector of the same length as \code{files}
+    specifying the location of JSON files produced by kallisto and
+    containing information on the run. The default assumes that json
+    files are in the same directory as the corresponding abundance
+    file.}
+
+  \item{h5}{character() vector of the same length as \code{files}
+    specifying the location of HDF5 files produced by kallisto and
+    containing bootstrap estimates. The default assumes that HDF5 files
+    are in the same directory as the corresponding abundance file.}
+
+  \item{what}{character() vector of kallisto per-sample outputs to be
+    input. See KALLISTO_ASSAYS for available values.}
+
+  \item{as}{character(1) specifying the output format. See \code{Value}
+    for additional detail.}
+
+  \item{file}{character(1) path to a single HDF5 output file.}
+
+  \item{i, j}{integer() vector of row (\code{i}) and column (\code{j})
+    indexes to input.}
+
+}
+
+\value{
+
+  A \code{SummarizedExperiment}, \code{list}, or \code{matrix},
+  depending on the value of argument \code{as}; by default a
+  \code{SummarizedExperiment}. The \code{as="SummarizedExperiment"}
+  \code{rowData(se)} the length of each transcript;
+  \code{colData(se)} includes summary information on each sample,
+  including the number of targets and bootstraps, the kallisto and index
+  version, the start time and operating system call used to create the
+  file. \code{assays()} contains one or more transcript x sample
+  matrices of parameters estimated by kallisto (see
+  \code{KALLISTO_ASSAYS}).
+
+  \code{as="list"} return value contains information simillar to
+  \code{SummarizedExperiment} with row, column and assay data as
+  elements of the list without coordination of row and column
+  annotations into an integrated data container. \code{as="matrix"}
+  returns the specified assay as a simple \emph{R} matrix.
+
+}
+
+\references{
+  \url{http://pachterlab.github.io/kallisto} software for quantifying
+  transcript abundance.
+}
+
+\author{
+  Martin Morgan \url{martin.morgan at roswellpark.org}
+}
+
+\examples{
+outputs <- system.file(package="SummarizedExperiment", "extdata",
+    "kallisto")
+files <- dir(outputs, pattern="abundance.tsv", full=TRUE, recursive=TRUE)
+stopifnot(all(file.exists(files)))
+
+## default: input 'est_counts'
+(se <- readKallisto(files, as="SummarizedExperiment"))
+str(readKallisto(files, as="list"))
+str(readKallisto(files, as="matrix"))
+
+## available assays
+KALLISTO_ASSAYS
+## one or more assay
+readKallisto(files, what=c("tpm", "eff_length"))
+
+## alternatively: read hdf5 files
+files <- sub(".tsv", ".h5", files, fixed=TRUE)
+readKallisto(files)
+
+## input all bootstraps
+xx <- readKallistoBootstrap(files[1])
+ridx <- head(which(rowSums(xx) != 0), 3)
+cidx <- c(1:5, 96:100)
+xx[ridx, cidx]
+
+## selective input of rows (transcripts) and/or bootstraps
+readKallistoBootstrap(files[1], i=c(ridx, rev(ridx)), j=cidx)
+}
+
+\keyword{file}
diff --git a/man/saveHDF5SummarizedExperiment.Rd b/man/saveHDF5SummarizedExperiment.Rd
new file mode 100644
index 0000000..05e4cfd
--- /dev/null
+++ b/man/saveHDF5SummarizedExperiment.Rd
@@ -0,0 +1,144 @@
+\name{saveHDF5SummarizedExperiment}
+
+\alias{saveHDF5SummarizedExperiment}
+\alias{loadHDF5SummarizedExperiment}
+
+\title{Save/load a HDF5-based SummarizedExperiment object}
+
+\description{
+  \code{saveHDF5SummarizedExperiment} and \code{loadHDF5SummarizedExperiment}
+  can be used to save/load a HDF5-based \link{SummarizedExperiment} object
+  to/from disk.
+}
+
+\usage{
+saveHDF5SummarizedExperiment(x, dir="my_h5_se", replace=FALSE,
+                             chunk_dim=NULL, level=NULL, verbose=FALSE)
+loadHDF5SummarizedExperiment(dir="my_h5_se")
+}
+
+\arguments{
+  \item{x}{
+    A \link{SummarizedExperiment} object.
+  }
+  \item{dir}{
+    The path (as a single string) to the directory where to save the
+    HDF5-based \link{SummarizedExperiment} object or to load it from.
+    When saving, the directory will be created so should not already exist,
+    unless \code{replace} is set to \code{TRUE}.
+  }
+  \item{replace}{
+    If directory \code{dir} already exists, should it be replaced with a
+    new one? The content of the existing directory will be lost!
+  }
+  \item{chunk_dim, level}{
+    The dimensions of the chunks and the compression level to use for
+    writting the assay data to disk.
+    Passed to the internal calls to \code{HDF5Array::writeHDF5Array}.
+    See \code{?HDF5Array::\link[HDF5Array]{writeHDF5Array}} for more
+    information.
+  }
+  \item{verbose}{
+    Set to \code{TRUE} to make the function display progress.
+  }
+}
+
+\details{
+  These functions use functionalities from the \pkg{rhdf5} and \pkg{HDF5Array}
+  packages internally and so require these packages to be installed.
+
+  \code{saveHDF5SummarizedExperiment} creates the directory specified
+  thru the \code{dir} argument and then populates it with the HDF5 datasets
+  (one per assay in \code{x}) plus a serialized version of \code{x} that
+  contains pointers to these datasets. This directory provides a
+  self-contained HDF5-based representation of \code{x} that can then
+  be loaded back in R with \code{loadHDF5SummarizedExperiment}.
+  Note that this directory is \emph{relocatable} i.e. it can be moved
+  (or copied) to a different place, on the same or a different computer,
+  before calling \code{loadHDF5SummarizedExperiment} on it. For convenient
+  sharing with collaborators, it is suggested to turn it into a tarball
+  (with Unix command \code{tar}), or zip file, before the transfer.
+  Please keep in mind that \code{saveHDF5SummarizedExperiment} and
+  \code{loadHDF5SummarizedExperiment} don't know how to produce/read
+  tarballs or zip files at the moment, so the process of packaging/extracting
+  the tarball or zip file is entirely the user responsibility. It is
+  typically done from outside R.
+
+  Finally please note that, depending on the size of the data to write to
+  disk and the performance of the disk, \code{saveHDF5SummarizedExperiment}
+  can take a long time to complete. Use \code{verbose=TRUE} to see its
+  progress.
+
+  \code{loadHDF5SummarizedExperiment} is generally very fast, even if
+  the assay data is big, because all the assays in the returned object
+  are \link[HDF5Array]{HDF5Array} objects pointing to the on-disk HDF5
+  datasets located in \code{dir}. \link[HDF5Array]{HDF5Array} objects are
+  typically light-weight in memory.
+}
+
+\value{
+  \code{saveHDF5SummarizedExperiment} returns an invisible
+  \link{SummarizedExperiment} object where all the assays are
+  \link[HDF5Array]{HDF5Array} objects pointing to the HDF5 datasets
+  saved in \code{dir}. It's in fact the same obect as the object that
+  would be returned by calling \code{loadHDF5SummarizedExperiment} on
+  \code{dir}.
+}
+
+\author{Hervé Pagès}
+
+\seealso{
+  \itemize{
+    \item \link{SummarizedExperiment} and \link{RangedSummarizedExperiment}
+          objects.
+
+    \item \link[HDF5Array]{HDF5Array} objects in the \pkg{HDF5Array} package.
+
+    \item The \code{\link[HDF5Array]{writeHDF5Array}} function in the
+          \pkg{HDF5Array} package, which \code{saveHDF5SummarizedExperiment}
+          uses internally to write the assay data to disk.
+  }
+}
+
+\examples{
+nrows <- 200; ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+se0 <- SummarizedExperiment(assays=SimpleList(counts=counts),
+                            colData=colData)
+se0
+
+## Save 'se0' as an HDF5-based SummarizedExperiment object:
+dir <- sub("file", "h5_se0_", tempfile())
+h5_se0 <- saveHDF5SummarizedExperiment(se0, dir)
+h5_se0
+assay(h5_se0, withDimnames=FALSE)  # HDF5Matrix object
+
+h5_se0b <- loadHDF5SummarizedExperiment(dir)
+h5_se0b
+assay(h5_se0b, withDimnames=FALSE)  # HDF5Matrix object
+
+## Sanity checks:
+stopifnot(is(assay(h5_se0, withDimnames=FALSE), "HDF5Matrix"))
+stopifnot(all(DelayedArray(assay(se0)) == assay(h5_se0)))
+stopifnot(is(assay(h5_se0b, withDimnames=FALSE), "HDF5Matrix"))
+stopifnot(all(DelayedArray(assay(se0)) == assay(h5_se0b)))
+
+## ---------------------------------------------------------------------
+## More sanity checks
+## ---------------------------------------------------------------------
+
+## Make a copy of directory 'dir':
+somedir <- sub("file", "somedir", tempfile())
+dir.create(somedir)
+file.copy(dir, somedir, recursive=TRUE)
+dir2 <- list.files(somedir, full.names=TRUE)
+
+## 'dir2' contains a copy of 'dir'. Call loadHDF5SummarizedExperiment()
+## on it.
+h5_se0c <- loadHDF5SummarizedExperiment(dir2)
+
+stopifnot(is(assay(h5_se0c, withDimnames=FALSE), "HDF5Matrix"))
+stopifnot(all(DelayedArray(assay(se0)) == assay(h5_se0c)))
+}
diff --git a/tests/run_unitTests.R b/tests/run_unitTests.R
new file mode 100644
index 0000000..eabf7db
--- /dev/null
+++ b/tests/run_unitTests.R
@@ -0,0 +1,2 @@
+require("SummarizedExperiment") || stop("unable to load SummarizedExperiment package")
+SummarizedExperiment:::.test()
diff --git a/vignettes/SummarizedExperiment.Rmd b/vignettes/SummarizedExperiment.Rmd
new file mode 100644
index 0000000..5702f6b
--- /dev/null
+++ b/vignettes/SummarizedExperiment.Rmd
@@ -0,0 +1,345 @@
+---
+title: "_SummarizedExperiment_ for Coordinating Experimental Assays, Samples, and Regions of Interest"
+author: "Martin Morgan, Valerie Obenchain, Jim Hester, Hervé Pagès"
+date: "Revised: 22 June, 2016"
+output:
+  BiocStyle::html_document:
+    toc: true
+vignette: >
+  %\VignetteIndexEntry{SummarizedExperiment}
+  %\VignetteEngine{knitr::rmarkdown}
+  \usepackage[utf8]{inputenc}
+---
+
+```{r style, echo=FALSE, results='asis'}
+BiocStyle::markdown()
+```
+
+
+# Introduction 
+
+The `SummarizedExperiment` class is used to store rectangular matrices of
+experimental results, which are commonly produced by sequencing and microarray
+experiments.  Each object stores observations of one or more samples, along
+with additional meta-data describing both the observations (features) and
+samples (phenotypes).
+
+A key aspect of the `SummarizedExperiment` class is the coordination of the
+meta-data and assays when subsetting. For example, if you want to exclude a
+given sample you can do for both the meta-data and assay in one operation,
+which ensures the meta-data and observed data will remain in sync.  Improperly
+accounting for meta and observational data has resulted in a number of
+incorrect results and retractions so this is a very desirable
+property.
+
+`SummarizedExperiment` is in many ways similar to the historical
+`ExpressionSet`, the main distinction being that `SummarizedExperiment` is more
+flexible in it's row information, allowing both `GRanges` based as well as those
+described by arbitrary `DataFrame`s.  This makes it ideally suited to a variety
+of experiments, particularly sequencing based experiments such as RNA-Seq and
+ChIp-Seq.
+
+#  Anatomy of a `SummarizedExperiment`
+
+The _SummarizedExperiment_ package contains two classes: 
+`SummarizedExperiment` and `RangedSummarizedExperiment`.
+
+`SummarizedExperiment` is a matrix-like container where rows represent features
+of interest (e.g. genes, transcripts, exons, etc.) and columns represent
+samples. The objects contain one or more assays, each represented by a
+matrix-like object of numeric or other mode. The rows of a
+`SummarizedExperiment` object represent features of interest.  Information
+about these features is stored in a `DataFrame` object, accessible using the
+function `rowData()`. Each row of the `DataFrame` provides information on the
+feature in the corresponding row of the `SummarizedExperiment` object. Columns
+of the DataFrame represent different attributes of the features of interest,
+e.g., gene or transcript IDs, etc.
+
+`RangedSummarizedExperiment` is the child of the `SummarizedExperiment` class
+which means that all the methods on `SummarizedExperiment` also work on a
+`RangedSummarizedExperiment`.
+
+The fundamental difference between the two classes is that the rows of a
+`RangedSummarizedExperiment` object represent genomic ranges of interest
+instead of a `DataFrame` of features. The `RangedSummarizedExperiment` ranges
+are described by a `GRanges` or a `GRangesList` object, accessible using the
+`rowRanges()` function.
+
+The following graphic displays the class geometry and highlights the
+vertical (column) and horizontal (row) relationships.
+
+
+```{r include = FALSE}
+# download current version of SE diagram
+#download.file("https://docs.google.com/feeds/download/drawings/Export?id=18OcDb80FpvSGRYnFl-8vUqwNNLaNHrG1I9SWKHCselo&exportFormat=svg", "SE.svg")
+download.file("https://docs.google.com/feeds/download/drawings/Export?id=1kiC8Qlo1mhSnLDqkGiRNPSo6GWn3C2duBszCFbJCB-g&exportFormat=svg", "SE.svg")
+```
+
+![Summarized Experiment](SE.svg)
+
+## Assays
+
+The `airway` package contains an example dataset from an RNA-Seq experiment of
+read counts per gene for airway smooth muscles.  These data are stored
+in a `RangedSummarizedExperiment` object which contains 8 different
+experimental and assays 64,102 gene transcripts.
+
+```{r, echo=FALSE}
+suppressPackageStartupMessages(library(SummarizedExperiment))
+suppressPackageStartupMessages(data(airway, package="airway"))
+```
+
+```{r}
+library(SummarizedExperiment)
+data(airway, package="airway")
+se <- airway
+se
+```
+
+To retrieve the experiment data from a `SummarizedExperiment` object one can
+use the `assays()` accessor.  An object can have multiple assay datasets
+each of which can be accessed using the `$` operator.
+The `airway` dataset contains only one assay (`counts`).  Here each row
+represents a gene transcript and each column one of the samples.
+
+```{r assays, eval = FALSE}
+assays(se)$counts
+```
+
+```{r assays_table, echo = FALSE}
+knitr::kable(assays(se)$counts[1:10,])
+```
+
+## 'Row' (regions-of-interest) data
+The `rowRanges()` accessor is used to view the range information for a
+`RangedSummarizedExperiment`. (Note if this were the parent 
+`SummarizedExperiment` class we'd use `rowData()`). The data are stored in a 
+`GRangesList` object, where each list element corresponds to one gene 
+transcript and the ranges in each `GRanges` correspond to the exons in the
+transcript.
+
+```{r rowRanges}
+rowRanges(se)
+```
+
+## 'Column' (sample) data
+
+Sample meta-data describing the samples can be accessed using `colData()`, and
+is a `DataFrame` that can store any number of descriptive columns for each
+sample row.
+
+```{r colData}
+colData(se)
+```
+
+This sample metadata can be accessed using the `$` accessor which makes it 
+easy to subset the entire object by a given phenotype.
+
+```{r columnSubset}
+# subset for only those samples treated with dexamethasone
+se[, se$dex == "trt"]
+```
+
+## Experiment-wide metadata
+
+Meta-data describing the experimental methods and publication references can be
+accessed using `metadata()`.
+
+```{r metadata}
+metadata(se)
+```
+
+Note that `metadata()` is just a simple list, so it is appropriate for _any_
+experiment wide metadata the user wishes to save, such as storing model
+formulas.
+
+```{r metadata-formula}
+metadata(se)$formula <- counts ~ dex + albut
+
+metadata(se)
+```
+
+# Constructing a `SummarizedExperiment` 
+
+Often, `SummarizedExperiment` or `RangedSummarizedExperiment` objects are 
+returned by functions written by other packages. However it is possible to 
+create them by hand with a call to the `SummarizedExperiment()` constructor.
+
+Constructing a `RangedSummarizedExperiment` with a `GRanges` as the
+_rowRanges_ argument:
+
+```{r constructRSE}
+nrows <- 200
+ncols <- 6
+counts <- matrix(runif(nrows * ncols, 1, 1e4), nrows)
+rowRanges <- GRanges(rep(c("chr1", "chr2"), c(50, 150)),
+                     IRanges(floor(runif(200, 1e5, 1e6)), width=100),
+                     strand=sample(c("+", "-"), 200, TRUE),
+                     feature_id=sprintf("ID%03d", 1:200))
+colData <- DataFrame(Treatment=rep(c("ChIP", "Input"), 3),
+                     row.names=LETTERS[1:6])
+
+SummarizedExperiment(assays=list(counts=counts),
+                     rowRanges=rowRanges, colData=colData)
+```
+
+A `SummarizedExperiment` can be constructed with or without supplying
+a `DataFrame` for the _rowData_ argument:
+
+```{r constructSE}
+SummarizedExperiment(assays=list(counts=counts), colData=colData)
+```
+
+# Common operations on `SummarizedExperiment`
+
+## Subsetting
+
+- `[` Performs two dimensional subsetting, just like subsetting a matrix
+    or data frame.
+```{r 2d}
+# subset the first five transcripts and first three samples
+se[1:5, 1:3]
+```
+- `$` operates on `colData()` columns, for easy sample extraction.
+```{r colDataExtraction}
+se[, se$cell == "N61311"]
+```
+
+## Getters and setters
+
+- `rowRanges()` / (`rowData()`), `colData()`, `metadata()`
+```{r getSet}
+counts <- matrix(1:15, 5, 3, dimnames=list(LETTERS[1:5], LETTERS[1:3]))
+
+dates <- SummarizedExperiment(assays=list(counts=counts),
+                              rowData=DataFrame(month=month.name[1:5], day=1:5))
+
+# Subset all January assays
+dates[rowData(dates)$month == "January", ]
+```
+
+- `assay()` versus `assays()`
+There are two accessor functions for extracting the assay data from a
+`SummarizedExperiment` object.  `assays()` operates on the entire list of assay
+data as a whole, while `assay()` operates on only one assay at a time.
+`assay(x, i)` is simply a convenience function which is equivalent to
+`assays(x)[[i]]`.
+
+```{r assay_assays}
+assays(se)
+
+assays(se)[[1]][1:5, 1:5]
+
+# assay defaults to the first assay if no i is given
+assay(se)[1:5, 1:5]
+
+assay(se, 1)[1:5, 1:5]
+```
+
+## Range-based operations
+
+- `subsetByOverlaps()`
+`SummarizedExperiment` objects support all of the `findOverlaps()` methods and
+associated functions.  This includes `subsetByOverlaps()`, which makes it easy
+to subset a `SummarizedExperiment` object by an interval.
+
+```{r overlap}
+# Subset for only rows which are in the interval 100,000 to 110,000 of
+# chromosome 1
+roi <- GRanges(seqnames="1", ranges=100000:1100000)
+subsetByOverlaps(se, roi)
+```
+
+# Advanced: Extending `RangedSummarizedExperiment`
+
+For representing and manipulating data in their own package, Bioconductor
+developers are encouraged to re-use existing classes defined in other
+packages like the `RangedSummarizedExperiment` or `GRanges` containers
+defined in the `SummarizedExperiment` or `GenomicRanges` infrastructure
+packages, respectively. Many Bioconductor packages are designed around
+these basic containers, that is, they define functions that take and/or
+return a `RangedSummarizedExperiment` or `GRanges` object.
+For example the `csaw` package defines various functions that operate
+on `RangedSummarizedExperiment` objects, which are used to represent the
+number of ChIP-seq reads from each BAM file overlapping pre-specified
+regions.
+
+However, sometimes re-using the `RangedSummarizedExperiment` class as-is
+does not satisfy the needs of the package and the developer makes the choice
+to extend the class in order to accomodate the special needs of the package
+and/or the specificities of the data that it deals with. For example the
+`DESeq2` package defines the `DESeqDataSet` class which extends
+`RangedSummarizedExperiment` to add the `design` and `dispersionFunction`
+slots to it.
+
+The following subsections describe in a nutshell how the developer would
+typically proceed for extending `RangedSummarizedExperiment` in his/her
+own package. Some familiarity with the S4 class system is required. Readers
+not familiar with the S4 class system are encouraged to consult the vignette
+`A quick overview of the S4 class system` located in the `S4Vectors` package
+for the basics of implementing and extending S4 classes.
+
+The approach described below allows the developer to extend
+`RangedSummarizedExperiment` it in a way that remains agnostic of its
+internals. Keeping this separation between the responsibilities of the owners
+of the parent and child classes facilitate maintenance in the long run.
+In particular, the implementation of the child class won't be affected by
+changes in the internals of the parent class.
+
+## Depend on, and import, the `SummarizedExperiment` package
+
+Add `SummarizedExperiment` to the Depends field of the DESCRIPTION file
+of the package and the `import(SummarizedExperiment)` directive to its
+NAMESPACE file.
+
+## Define and export the `RangedSummarizedExperiment` subclass
+
+Define the subclass with something like:
+```{r rseSubclass}
+setClass("MyRSESubclass",
+    contains="RangedSummarizedExperiment",
+    representation=representation(
+        slot1="integer",
+        slot2="function"
+        ## ... maybe more ...
+    )
+)
+```
+
+Export it by adding the `exportClasses(MyRSESubclass)` directive to the
+NAMESPACE file.
+
+## Construct `MyRSESubclass` instances
+
+When calling `new()` for constructing a `MyRSESubclass` instance, specify
+only the MyRSESubclass-specific slots:
+`new("MyRSESubclass", rse, slot1=value1, slot2=value2)`,
+where `rse` is a `RangedSummarizedExperiment` object.
+
+Providing a `MyRSESubclass` constructor function (named as the class itself)
+is recommended.
+
+## Define a validity method
+
+The validity method for `MyRSESubclass` only needs to take care of what's
+new in `MyRSESubclass` with respect to `RangedSummarizedExperiment`, that is,
+of the aspects of `MyRSESubclass` objects that are not already covered by the
+validity method for `RangedSummarizedExperiment` objects. This is because
+calling `validObject()` on a `MyRSESubclass` object automatically validates
+it as a `RangedSummarizedExperiment` object first and then calls the validity
+method for `MyRSESubclass` objects. In other words, validation works
+incrementally starting from the root of the class hierarchy and going in the
+parent-to-child direction.
+
+## Use the `RangedSummarizedExperiment` accessors on `MyRSESubclass` objects
+
+Like any user of `RangedSummarizedExperiment` objects, the developer of
+`MyRSESubclass` should always use the `RangedSummarizedExperiment` accessors
+to access the `RangedSummarizedExperiment`-specific parts of his/her
+`MyRSESubclass` objects.
+
+## Use `callNextMethod`
+
+In case some of the methods defined for `RangedSummarizedExperiment` objects
+need to be overwritten, the new methods should call `callNextMethod`
+internally.

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/debian-med/r-bioc-summarizedexperiment.git



More information about the debian-med-commit mailing list