read_bigwig()
now uses cpp11bigwig on CRAN. The set_strand
param was removed to be
more consistent with expected bigWig contents.
read_gtf()
was deprecated. The rtracklayer package used
for this functionality is no longer a dependency of valr due to errors from
CRAN AddressSantizer checks of the UCSC c-library code vendored in rtracklayer.
valr now depends on R >= 4.0.0.
Address NOTE on CRAN about Rd link targets.
Change maintainer email address.
bed_genomecov()
to compute interval coverage across a genome.read_bed
and related functions now automatically calculate the fields. Use of n_fields
was deprecated.bed_closest()
now reports all x intervals, even when there are no closest y intervals (e.g. when there is no matching chromosome in y intervals). These intervals are returned populated with NA
for .overlap
, .dist
and y interval locations.
Reimplemented bed_closest()
to use binary search rather than an interval tree search. The closest y interval can be missed with the previous search strategy in high depth interval trees.
Fix off by one error when using max_dist
argument in bed_cluster()
(#401).
Removed SystemRequirements
from DESCRIPTION to eliminate a NOTE on CRAN.
bed_coverage()
now reports intervals from x
with no matching group in y
(#395).
Updated intervalTree header to commit f0c4046
valr now uses cli for more consistent errors and messages during interactive use.
deprecated genome
argument to bed_makewindows()
was removed.
max_dist
for first intervals in bed_cluster()
(#388)Fixed intron score numbering error in create_introns
(#377 @sheridar)
Fixed bug in handling of list inputs for bed_intersect()
(#380 @sheridar)
Added read_bigwig
and read_gtf
functions to import data into valr compatible tibbles (#379)
Kent Riemondy is now maintainer.
RMariaDB
has replaced the deprecated RMySQL
package as the database backend.
valr now imports Rcpp, which should have always been the case, but was masked by its Import by readr, which recently dropped use of Rcpp.
trbl_interval()
and trbl_genome()
custom tibble
subclasses have been deemed unnecessary and have been removed from the package.
coercing GRanges
to a valr
compatible data.frame now uses the gr_to_bed()
function rather than as.trbl_interal()
methods.
dplyr version < 0.8.0 is no longer supported due to unnecessary code bloat and challenges with handling multiple grouping structures (#359).
The sort_by
argument of bed_random()
has been changed to sorted
, and will now by default
use bed_sort()
to sort the output, rather than rely on naming the sorting columns. Sorting can
be suppressed by using sorted = FALSE
.
bed_sort()
now uses base R sorting with the radix
method for increased speed. (#353)
tbls
processed by bed_merge()
or bed_sort()
no longer store either merged
or sorted
as attributes, due to these attributes being rarely checked in the codebase and potential sources of unexpected behavior.
Fixed bed_closest()
to prevent erroneous intervals being reported when adjacent closest intervals are present in the y
table. (#348)
Factor columns that are not used for grouping are returned as factors rather than inappropriately being coerced to integer vectors (#360)
Rcpp
functions have been reorganized to remove all dependencies on dplyr
C++ functions.Due to internal refactoring of Rcpp functions, only data.frames containing Numeric, Logical, Integer, Character, and List column types are supported. Columns containing Raw, Complex, or other R classes are not supported and will issue an error.
Factors are now disallowed from grouping variables in multiset operations to avoid sort order discrepancies, and compatibility with factor handling in dplyr
v.0.8.0. Factors will now be internally type-converted to character and a warning is issued.
as.tbl_interval()
to call as_tibble()
only on non-tibble input, which prevents groups from being stripped from tibble()
input (#338).Added new function, bed_partition()
, which is similar to bed_merge()
but collapses intervals to elemental intervals rather than the maximal overlapping region. bed_partition()
also can compute summaries of data from overlapping intervals. See examples in bed_partition()
and timings in vignette('benchmarks')
@kriemo.
Several explicit comparisons to the Bioconductor GenomicRanges library are included for users considering using valr. See examples in as.tbl_interval()
and timings in vignette('benchmarks')
.
All relevant tests from bedtool2 were ported into valr. Bugs identified in corner cases by new tests were fixed (#328 @raysinesis)
bed_jaccard()
now works with grouped inputs (#216)
Update dplyr header files to v0.7
bed_intersect()
and internal intersect_impl
were refactored to enable return of non-intersecting intervals.
The genome argument to bed_makewindows()
was deprecated and will produce a warning if used. Also error handling was added to check and warn if there are intervals smaller than the requested window size in makewindows_impl()
(#312 @kriemo)
Fixed off by one error in reported distances from bed_closest()
. Distances reported now are the same as bedtools closest
behavior (#311).
bed_glyph()
accepts trbl_intervals
named other than x
and y
(#318).
bed_makewindows()
now returns the number of windows specified by num_win
when the input intervals are not evenly divisble into num_win
, consistent with bedtools
behavior.
The output of findOverlaps()
is now sorted in subtract_impl()
to prevent reporting intervals that should have been dropped when calling bed_subtract()
(#316 @kriemo)
A manuscript describing valr has been published in F1000Research.
New S3 generic as.tbl_interval()
converts GenomicRanges::GRanges
objects to tbl_interval
.
New create_tss()
for creating transcription start sites.
Improve documentation of interval statistics with more complex examples.
bed_sort()
has been de-deprecated to reduce arrange
calls in library code.bed_merge()
now reports start/end columns if spec is provided (#288)New create_introns()
, create_utrs5()
and create_utrs3()
functions for generating features from BED12 files.
Speed-ups in bed_makewindows()
(~50x), bed_merge()
(~4x), and bed_flank()
(~4x) (thanks to @kriemo and @sheridar). Thanks to the sponsors of the Biofrontiers Hackathon for the caffeine underlying these improvements.
bed_random()
are now sorted properly.Package dplyr v0.5.0 headers with valr to remove dplyr LinkingTo dependency.
bed_intersect()
now accepts multiple tbls for intersection (#220 @kriemo).
new tbl_interval()
and tbl_genome()
that wrap tibbles and enforce strict column naming. trbl_interval()
and trbl_genome()
are constructors that take tibble::tribble()
formatting and is.tbl_interval()
and is.tbl_genome()
are used to check for valid classes.
bed_random()
are sorted by chrom
and start
by default.bed_jaccard()
and use numeric values for calculation (fixes #204).bed_sort()
in favor of using dplyr::arrange()
explicitly (fixes #134).add src/init.c
that calls R_registerRoutines
and R_useDynamicSymbols
to address NOTE in r-devel
Deprecate dist
parameter in bed_closest()
in favor of using user supplied functions (#182 @kriemo)
Make .id
values sequential across chroms in bed_cluster()
output (#171)
Transfer repository to http://github.com/rnabioco/valr, update links and docs.
Move shiny app to new repo (http://github.com/rnabioco/valrdata).
Add Kent Riemondy to LICENSE file.
bed_merge()
now merges contained intervals (#177)test / vignette guards for Suggested RMySQL
fixed memory leak in absdist.cpp
fixed vignette entry names