[BioC] [Bioc-devel] granges() method for GenomicRanges objects akin to ranges()...
Martin Morgan
mtmorgan at fhcrc.org
Mon May 5 16:22:30 CEST 2014
On 05/05/2014 06:55 AM, Michael Lawrence wrote:
> The in-line usage makes sense. How about dropmcols() or something, at least
> for removing the mcols?
generalize as setMcols, like setNames? setMcols(x, NULL)
>
>
> On Mon, May 5, 2014 at 1:25 AM, Julian Gehring <julian.gehring at embl.de>wrote:
>
>> Hi Tim,
>>
>> I was looking for a similar function a while ago, and created the
>> 'grangesPlain' function in 'SomaticSignatures':
>>
>> grangesPlain <-
>> function (x)
>> {
>> mcols(x) = NULL
>> x = as(x, "GRanges")
>> return(x)
>> }
>>
>> It removes the metadata columns, as Michael described. Further, it
>> performs an explicit conversion to a 'GRanges' object - in case that 'x'
>> has a derived class like a 'VRanges'.
>>
>> The main motivation for an extra function is that you can use it inline,
>> e.g
>>
>> resize(sort(grangesPlain(x)), ...)
>>
>> works. It would be great to have such functionality as part of the bioc
>> core.
>>
>> Best wishes
>> Julian
>>
>>
>>
>> On 05.05.2014 01:56, Michael Lawrence wrote:
>>
>>> Why not just do
>>>
>>> mcols(gr) <- NULL
>>>
>>> It's way more obvious than granges(gr). And that should happen virtually
>>> instantaneously in R 3.1, regardless of the length.
>>>
>>>
>>>
>>>
>>> On Sun, May 4, 2014 at 3:55 PM, Tim Triche, Jr. <tim.triche at gmail.com
>>>> wrote:
>>>
>>> Right, what I was wondering however is whether it's possible not to
>>>> create
>>>> or modify the object at all, but rather access only the necessary bits.
>>>>
>>>> It seems like a slightly different structure that puts all the location
>>>> in
>>>> one place (say @granges) and the metadata in another (as it presently is)
>>>> might be handy to avoid this hoohah. That's rather a larger change.
>>>>
>>>> --t
>>>>
>>>> On May 4, 2014, at 3:23 PM, "Johnston, Jeffrey" <jjj at stowers.org>
>>>>> wrote:
>>>>>
>>>>>
>>>>> On May 4, 2014, at 3:50 PM, Tim Triche, Jr. <tim.triche at gmail.com>
>>>>>>
>>>>> wrote:
>>>>
>>>>>
>>>>>> I wanted something to extract @ranges from a GRanges object along with
>>>>>>
>>>>> its
>>>>
>>>>> @seqnames, @strand, and @seqinfo. Essentially, everything but the
>>>>>>
>>>>> mcols.
>>>>
>>>>>
>>>>>> Does this make sense? Is there a lighter-weight way to avoid any
>>>>>>
>>>>> copying
>>>>
>>>>> in-flight?
>>>>>>
>>>>>>
>>>>>> setMethod("granges", "GRanges", function(x) {
>>>>>> GRanges(seqnames=seqnames(x),
>>>>>> ranges=ranges(x),
>>>>>> strand=strand(x),
>>>>>> seqinfo=seqinfo(x))
>>>>>> })
>>>>>>
>>>>>>
>>>>>> The fact that I'm constructing an entire new GRanges makes me a little
>>>>>> queasy... that said, it has turned out to be useful when I just want a
>>>>>> short list of locations, as for debugging plotting functions, profile
>>>>>> plots, or what have you.
>>>>>>
>>>>>
>>>>>
>>>>> Perhaps just this:
>>>>>
>>>>> setMethod("granges", "GRanges", function(x) {
>>>>> mcols(x) <- NULL
>>>>> x
>>>>> })
>>>>>
>>>>>
>>>>>
>>>>>
>>>> _______________________________________________
>>>> Bioc-devel at r-project.org mailing list
>>>> https://stat.ethz.ch/mailman/listinfo/bioc-devel
>>>>
>>>>
>>> [[alternative HTML version deleted]]
>>>
>>>
>>> _______________________________________________
>>> Bioc-devel at r-project.org mailing list
>>> https://stat.ethz.ch/mailman/listinfo/bioc-devel
>>>
>>>
>
> [[alternative HTML version deleted]]
>
> _______________________________________________
> Bioc-devel at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/bioc-devel
>
--
Computational Biology / Fred Hutchinson Cancer Research Center
1100 Fairview Ave. N.
PO Box 19024 Seattle, WA 98109
Location: Arnold Building M1 B861
Phone: (206) 667-2793
More information about the Bioconductor
mailing list