/usr/lib/R/site-library/rtracklayer/notes/design.org is in r-bioc-rtracklayer 1.38.0-1build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 | * Data integration
** Track data structure
*** trackSet class
* Contains eSet, location info in featureData, data in assayData.
* Accessors for "built-in" featureData columns and data values.
* Convertible to a data frame for e.g. plotting.
*** GenomeRanges class
The trackSet class approaches the problem from the experimental data
perspective. Alternatively, could represent tracks as information,
using IRanges + chromosome/strand information, scores, etc. This would
probably be more efficient than trackSet, and avoid Biobase dependency.
**** Components
* IRanges for start/stop on chromosome
* Chromosome index (possibly one IRanges per chromosome?)
* Strand index (IRanges for each strand?)
* Scores, factors, etc (multiple variables)
* Species of the genome
**** Implementation
TrackRanges could extend RangesCollection, with IRanges per
chrom/strand. But where does the data go?
* Each IRanges could have an attached environment of data
- strange, why split the data unnecessarily?
* GenomeRanges itself could have a data environment
Following the second path, GenomeRanges would extend the RangeData
container, and thus it would have the following slots:
* a RangesCollection, holding the IRanges for each chrom/strand
* an environment for storing genome-wide variables
* the species
In fact, the species slot is the only genome-specific slot. Otherwise
it's just a RangeData with a RangesCollection in its 'ranges' slot.
*** Import/export
**** Formats
* GFF: general feature format - widely used, three versions
* UCSC: meta format where lines are proceeded by 'track' lines
* Auto-detect line format when importing
* WIG: wiggle - for representing quantitative data (plots)
* Subset of UCSC (separated by special track lines)
* BED: browser extended display - UCSC-specific, visuals
* Unsupported:
* PSL: alignment specific
**** Extensible driver-based framework
* S3-style dispatch using format parameter (export.gff)
*** Subsetting
Supports the '[' syntax, for subsetting by:
* Conventional means (indices, logical, names, etc)
* Genome segment
* Chromosome ID (chrid)
* GenomeSegment
*** Creation from experimental datasets
At first glance, one wants to simply map the experimental dataset -
e.g. the ExpressionSet. But genome visualizations are limited in
capability - one may only be able to represent a small number of variables effectively. Experimental datasets often have extremely high
dimensionality - may need to reduce information to high-level
observations on the data. For example, in a gene expression
experiment, color-code the genes that are overexpressed, unchanged,
and underexpressed.
Perhaps both modes should be facilitated: low-level data values and
high-level findings. The user may choose based on needs of the
analysis, as well as capabilities of the browser. Switching between
browsers should thus be facilitated, as well.
The bottom-line is that the user is trying to relate data/findings to
other annotations (often qualitative annotations that are easily
communicated via a browser). Different browsers have different levels
of access to canonical annotations. UCSC and Ensembl are loaded but
limited as they are web-based. GenomeGraphs has powerful
visualizations but is (initially) empty of tracks. Need to
facilitate/optimize the retrieval of tracks.
**** Considering data type
***** From categorical data (e.g. genes of interest)
The browserSessions should recognize factors and handle them in an
optimal way. This may require a special parameter for color scales
(e.g. provide a color scheme).
***** From quantitative data (e.g. expression values)
A quantitative variable should be visualized appropriately (e.g. bars
where feature lengths differ, else points).
**** From ExpressionSet and possibly other eSets
Simply take the fields from the other eSet, reorganizing the assayData
and adding information from the annotation to the featureData. Need to
figure out the details on a per-use-case basis, but the basic
low-level mapping should prove useful.
**** From other existing data structures
Conversion routine should probably be provided by the package defining
the data structure. The rtracklayer package exists at the
infrastructure level - it is not specific to a data source.
**** Direct from sequence analysis
Data structures like those derived from eSet are normally generated as
the result of preprocessing. When analyzing sequence data directly,
however, one can calculate any arbitrary measure on the sequence. In
this case, the trackSet is the natural data structure. How can this be
facilitated?
The hard part is the featureData and its required fields: chromosome,
start and end. The start/end coordinates are known when working with a
BStringViews object. If each feature corresponds to a view, the view
coordinates could be translated directly to the featureData. There
would need to be one additional parameter for the chromosome and
(optionally) strand.
At a lower level, there needs to be a systematic way of creating the
featureData slot, to avoid typos for example in naming of the columns
and to annotate the variables. This is somewhat inspired by the R
seq() function.
*** Storing
Rather than constantly retrieve track information for display in local
browsers, why not create a storage system.
Requirements:
**** An efficient means of storing tabular data
Formats:
* NetCDF (for storing large tabular data, good R support)
* DAS (possibly overkill)
* GFF files (not very efficient, but standard)
**** A convenient interface to the database
Should use the trackSet() generic as with browserSession. Arguments
should support subsetting, because tracks will likely be large.
** Sequence data
*** Retrieval
Browsers are clients to sequence data sources. Thus, R can use the
browsers to retrieve sequences. There is no common interface defined
in R for accessing sequence databases, though we could define one. Retrieved sequences should be stored as DNAString instances.
*** Loading
Some browsers may support loading custom sequences. Should accept
data from the Biostrings package.
*** Integration with track data
Each track contains a set of features, each of which are
associated with a sequence. The sequence name must match the name of
the sequence in the database used by the browser. Often the sequence
name exists within a larger context, such as a genome. The sequence
IDs must be qualified by that context. Should this context be
specified by:
* Each feature in a trackSet
- Often will be an annoyance / unneeded complication
* A slot in the trackSet
+ Almost always, the features belong to same context
A context slot should be provided for convenience. How that is
interpreted will depend on the genome browser interface.
*** Storing
Large sequences (i.e. genomes) need to be stored for use in local
genome browsers. The BSgenome package should provide this.
* Software integration
** Browsers
*** UCSC
+ popular
+ easy to control
- web-based (slow)
*** GenomeGraphs
+ R-based (simple interface)
+ Local (fast)
+ Could layer on additional information
+ Could make interactive
*** Hilbert curves
- Strange, unfamiliar
+ Integrated with R/GTK+
+ Fast (Local, C++/GTK+ based)
+ High interactivity - generic callback to R
*** Argo
+ runs on local machine (responsive)
+ clean, intuitive interface
+ actively maintained
- not that popular
*** Apollo
+ runs on local machine
+ actively maintained
- interface not as intuitive as Argo
- not that popular
*** IGB
+ local machine (responsive)
- hard to control and query
- unmaintained
*** Ensembl
+ popular
- hard to query
- web-based (slow)
- requires DAS server or strange upload format
** Classes
*** View
A genome view, with a position and track visibility settings.
This could masquerade as a vector of 'browserTrackView's if that
class existed. But would it be useful? It would hold properties like
'selected' and 'visible'. Right now those are just vectors (simpler).
*** Session
Holds settings, tracks and views for a single session.
Should this masquerade as a vector of tracks?
- How often is a track retrieved?
* More often if it had more than just data, i.e. visual props
* This suggests a 'browserTrack' class with visual info
Do we need a representation of a sequence data source? Probably, but
that belongs in a separate package. We just need to tell a browser
which sequence to retrieve from a given database. The browser is the
client to the DB.
But we are the client to the browser - could we not view the browser
as a database? If such a structure existed, yes, we could have a
method that extracts a data source from a browser. However, the genome
should only be extracted when explicitly requested - most of the time
we only need a light-weight handle.
** Using multiple browsers
Users may want to:
* Pass track information between browsers
* Coordinate views between browsers
Both of these are possible, but could they be made easier?
* Tracks are already easy - one simple line to get/set track
* Views by browserView() with sig c("someSession", "browserView")
** Other packages
*** Biostrings
**** XString
Sequence data accessed via getSeq()
**** IRanges/BStringViews
Ranges occur in two places in rtracklayer:
* genomeSegment (only a single range)
Use genomeSegment() and genomeViews() for coercion
* start/end in track feature data
Use trackViews() and trackFeatureData() for coercion
|