This file is indexed.

/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