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 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582
|
\name{edgeRnews}
\title{edgeR News}
\encoding{UTF-8}
\section{Version 3.14.0}{\itemize{
\item
estimateDisp(), estimateCommonDisp(), estimateTrendedDisp(), estimateTagwiseDisp(), splitIntoGroups() and equalizeLibSizes() are now S3 generic functions.
\item
The default method of estimateGLMTrendedDisp() and estimateGLMTagwiseDisp() now only return dispersion estimates instead of a list.
\item
Add fry method for DGEList objects.
\item
Import R core packages explicitly.
\item
New function gini() to compute Gini coefficients.
\item
New argument poisson.bound for glmQLFTest().
If TRUE (default), the p-value returned by glmQLFTest() will never be less than what would be obtained for a likelihood ratio test with NB dispersion equal to zero.
\item
New argument samples for DGEList(). It takes a data frame containing information for each sample.
\item
glmFit() now protects against zero library sizes and infinite offset values.
\item
glmQLFit.default() now avoids passing a NULL design to .residDF().
\item
cpm.default() now outputs a matrix of the same dimensions as the input even when the input has 0 row or 0 column.
\item
DGEList() pops up a warning message when zero lib.size is detected.
\item
Bug fix to calcNormFactors(method="TMM") when two libraries have identical counts but the lib.sizes have been set unequal.
\item
Add a CRISPR-Cas9 screen case study to the users' guide and rename Nigerian case study to Yoruba.
}}
\section{Version 3.12.0}{\itemize{
\item
New argument tagwise for estimateDisp(), allowing users not to estimate tagwise dispersions.
\item
estimateTrendedDisp() has more stable performance and does not return negative trended dispersion estimates.
\item
New plotMD methods for DGEList, DGEGLM, DGEExact and DGELRT objects to make a mean-difference plot (aka MA plot).
\item
readDGE() now recognizes HTSeq style meta genes.
\item
Remove the F-test in glmLRT().
\item
New argument contrast for diffSpliceDGE(), allowing users to specify the testing contrast.
\item
glmTreat() returns both logFC and unshrunk.logFC in the output table.
\item
New method implemented in glmTreat() to increase the power of the test.
\item
New kegga methods for DGEExact and DGELRT objects to perform KEGG pathway analysis of differentially expressed genes using Entrez Gene IDs.
\item
New dimnames<- methods for DGEExact and DGELRT objects.
\item
Bug fix to dimnames<- method for DGEGLM objects.
\item
User's Guide updated. Three old case studies are replaced by two new comprehensive case studies.
}}
\section{Version 3.10.0}{\itemize{
\item
An DGEList method for romer() has been added, allowing access to rotation gene set enrichment analysis.
\item
New function dropEmptyLevels() to remove unused levels from a factor.
\item
New argument p.value for topTags(), allowing users to apply a p-value or FDR cutoff for the results.
\item
New argument prior.count for aveLogCPM().
\item
New argument pch for the plotMDS method for DGEList objects.
Old argument col is now removed, but can be passed using ....
Various other improvements to the plotMDS method for DGEList objects, better labelling of the axes and protection against degenerate dimensions.
\item
treatDGE() is renamed as glmTreat().
It can now optionally work with either likelihood ratio tests or with quasi-likelihood F-tests.
\item
glmQLFit() is now an S3 generic function.
\item
glmQLFit() now breaks the output component s2.fit into three separate components: df.prior, var.post and var.prior.
\item
estimateDisp() now protects against fitted values of zeros, giving more accurate dispersion estimates.
\item
DGEList() now gives a message rather than an error when the count matrix has non-unique column names.
\item
Minor corrections to User's Guide.
\item
requireNamespace() is now used internally instead of require() to access functions in suggested packages.
}}
\section{Version 3.8.0}{\itemize{
\item
New goana() methods for DGEExact and DGELRT objects to perform Gene Ontology analysis of differentially expressed genes using Entrez Gene IDs.
\item
New functions diffSpliceDGE(), topSpliceDGE() and plotSpliceDGE() for detecting differential exon usage and displaying results.
\item
New function treatDGE() that tests for DE relative to a specified log2-FC threshold.
\item
glmQLFTest() is split into three functions: glmQLFit() for fitting quasi-likelihood GLMs, glmQLFTest() for performing quasi-likelihood F-tests and plotQLDisp() for plotting quasi-likelihood dispersions.
\item
processHairpinReads() renamed to processAmplicons() and allows for paired end data.
\item
glmFit() now stores unshrunk.coefficients from prior.count=0 as well as shrunk coefficients.
\item
estimateDisp() now has a min.row.sum argument to protect against all zero counts.
\item
APL calculations in estimateDisp() are hot-started using fitted values from previous dispersions, to avoid discontinuous APL landscapes.
\item
adjustedProfileLik() is modified to accept starting coefficients. glmFit() now passes starting coefficients to mglmOneGroup().
\item
calcNormFactors() is now a S3 generic function.
\item
The SAGE datasets from Zhang et al (1997) are no longer included with the edgeR package.
}}
\section{Version 3.6.0}{\itemize{
\item
Improved treatment of fractional counts.
Previously the classic edgeR pipeline permitted fractional counts but the glm pipeline did not.
edgeR now permits fractional counts throughout.
\item
All glm-based functions in edgeR now accept quantitative observation-level weights.
The glm fitting function mglmLS() and mglmSimple() are retired, and all glm fitting is now done by either mglmLevenberg() or mglmOneWay().
\item
New capabilities for robust estimation allowing for observation-level outliers.
In particular, the new function estimateGLMRobustDisp() computes a robust dispersion estimate for each gene.
\item
More careful calculation of residual df in the presence of exactly zero fitted values for glmQLFTest() and estimateDisp().
The new code allows for deflation of residual df for more complex experimental designs.
\item
New function processHairpinReads() for analyzing data from shRNA-seq screens.
\item
New function sumTechReps() to collapse counts over technical replicate libraries.
\item
New functions nbinomDeviance() and nbinomUnitDeviance.
Old function deviances.function() removed.
\item
New function validDGEList().
\item
rpkm() is now a generic function, and it now tries to find the gene lengths automatically if available from the annotation information in a DGEList object.
\item
Subsetting a DGEList object now has the option of resetting to the library sizes to the new column sums.
Internally, the subsetting code for DGEList, DGEExact, DGEGLM, DGELRT and TopTags data objects has been simplified using the new utility function subsetListOfArrays in the limma package.
\item
To strengthen the interface and to strengthen the object-orientated nature of the functions, the DGEList methods for estimateDisp(), estimateGLMCommonDisp(), estimateGLMTrendedDisp() and estimateGLMTagwiseDisp no longer accept offset, weights or AveLogCPM as arguments.
These quantities are now always taken from the DGEList object.
\item
The User's Guide has new sections on read alignment, producing a table of counts, and on how to translate scientific questions into contrasts when using a glm.
\item
camera.DGEList(), roast.DGEList() and mroast.DGEList() now include ... argument.
\item
The main computation of exactTestByDeviance() now implemented in C++ code.
\item
The big.count argument has been removed from functions exactTestByDeviance() and exactTestBySmallP().
\item
New default value for offset in dispCoxReid.
\item
More tolerant error checking for dispersion value when computing aveLogCPM().
\item
aveLogCPM() now returns a value even when all the counts are zero.
\item
The functions is.fullrank and nonEstimable are now imported from limma.
}}
\section{Version 3.4.0}{\itemize{
\item
estimateDisp() now creates the design matrix correctly when the design matrix is not given as an argument and there is only one group. Previously this case gave an error.
\item
plotMDS.DGEList now gives a friendly error message when there are fewer than 3 data columns.
\item
Updates to DGEList() so that arguments lib.size, group and norm.factors are now set to their defaults in the function definition rather than set to NULL.
However NULL is still accepted as a possible value for these arguments in the function call, in which case the default value is used as if the argument was missing.
\item
Refinement to cutWithMinN() to make the bin numbers more equal in the worst case.
Also a bug fix so that cutWithMinN() does not fail even when there are many repeated x values.
\item
Refinement to computation for nbins in dispBinTrend. Now changes more smoothly with the number of genes. trace argument is retired.
\item
Updates to help pages for the data classes.
\item
Fixes to calcNormFactors with method="TMM" so that it takes account of lib.size and refCol if these are preset.
\item
Bug fix to glmQLFTest when plot=TRUE but abundance.trend=FALSE.
\item
predFC() with design=NULL now uses normalization factors correctly.
However this use of predFC() to compute counts per million is being phased out in favour of cpm().
}}
\section{Version 3.2.0}{\itemize{
\item
The User's Guide has a new section on between and within subject designs and a new case study on RNA-seq profiling of unrelated Nigerian individuals.
Section 2.9 (item 2) now gives a code example of how to pre-specify the dispersion value.
\item
New functions estimateDisp() and WLEB() to automate the estimation
of common, trended and tagwise dispersions.
The function estimateDisp() provides a simpler alternative pipeline and in principle replaces all the other dispersion estimation functions, for both glms and for classic edgeR.
It can also incorporate automatic estimation of the prior degrees of freedom, and can do this in a robust fashion.
\item
glmLRT() now permits the contrast argument to be a matrix with multiple columns, making the treatment of this argument analogous to that of the coef argument.
\item
glmLRT() now has a new F-test option.
This option takes into account the uncertainty with which the dispersion is estimated and is more conservative than the default chi-square test.
\item
glmQLFTest() has a number of important improvements.
It now has a simpler alternative calling sequence: it can take either a fitted model object as before, or it can take a DGEList object and design matrix and do the model fit itself.
If provided with a fitted model object, it now checks whether the dispersion is of a suitable type (common or trended).
It now optionally produces a plot of the raw and shrunk residual mean deviances versus AveLogCPM.
It now has the option of robustifying the empirical Bayes step.
It now has a more careful calculation of residual df that takes special account of cases where all replicates in a group are identically zero.
\item
The gene set test functions roast(), mroast() and camera() now have methods defined for DGEList data objects.
This facilitates gene set testing and pathway analysis of expression profiles within edgeR.
\item
The default method of plotMDS() for DGEList objects has changed.
The new default forms log-counts-per-million and computes Euclidean distances.
The old method based on BCV-distances is available by setting method="BCV".
The annotation of the plot axes has been improved so that the distance method used is apparent from the plot.
\item
The argument prior.count.total used for shrinking log-fold-changes has been changed to prior.count in various functions throughout the package, and now refers to the average prior.count per observation rather than the total prior count across a transcript.
The treatment of prior.counts has also been changed very slightly in cpm() when log=TRUE.
\item
New function aveLogCPM() to compute the average log count per million for each transcript across all libraries.
This is now used by all functions in the package to set AveLogCPM, which is now the standard measure of abundance.
The value for AveLogCPM is now computed just once, and not updated when the dispersion is estimated or when a linear model is fitted.
glmFit() now preserves the AveLogCPM vector found in the DGEList object rather than recomputing it.
The use of the old abundance measure is being phased out.
\item
The glm dispersion estimation functions are now much faster.
\item
New function rpkm() to compute reads per kilobase per million (RPKM).
\item
New option method="none" for calcNormFactors().
\item
The default span used by dispBinTrend() has been reduced.
\item
Various improvements to internal C++ code.
\item
Functions binCMLDispersion() and bin.dispersion() have been removed as obsolete.
\item
Bug fix to subsetting for DGEGLM objects.
\item
Bug fix to plotMDS.DGEList to make consistent use of norm.factors.
}}
\section{Version 3.0.0}{\itemize{
\item
New chapter in the User's Guide covering a number of common types of experimental designs, including multiple groups, multiple factors and additive models.
New sections in the User's Guide on clustering and on making tables of read counts.
Many other updates to the User's Guide and to the help pages.
\item
New function edgeRUsersGuide() to open the User's Guide in a pdf viewer.
\item
Many functions have made faster by rewriting the core computations in C++.
This includes adjustedProfileLik(), mglmLevenberg(), maximizeInterpolant() and goodTuring().
\item
New argument verbose for estimateCommonDisp() and estimateGLMCommonDisp().
\item
The trended dispersion methods based on binning and interpolation have been rewritten to give more stable results when the number of genes is not large.
\item
The amount by which the tagwise dispersion estimates are squeezed towards the global value is now specified in estimateTagwiseDisp(), estimateGLMTagwiseDisp() and dispCoxReidInterpolateTagwise() by specifying the prior degrees of freedom prior.df instead of the prior number of samples prior.n.
\item
The weighted likelihood empirical Bayes code has been simplified or developed in a number of ways.
The old functions weightedComLik() and weightedComLikMA() are now removed as no longer required.
\item
The functions estimateSmoothing() and approx.expected.info() have been removed as no longer recommended.
\item
The span used by estimateGLMTagwiseDisp() is now chosen by default as a decreasing function of the number of tags in the dataset.
\item
New method "loess" for the trend argument of estimateTagwiseDisp, with "tricube" now treated as a synonym.
\item
New functions loessByCol() and locfitByCol() for smoothing columns of matrix by non-robust loess curves.
These functions are used in the weighted likelihood empirical Bayes procedures to compute local common likelihood.
\item
glmFit now shrinks the estimated fold-changes towards zero.
The default shrinkage is as for exactTest().
\item
predFC output is now on the natural log scale instead of log2.
\item
mglmLevenberg() is now the default glm fitting algorithm, avoiding the occasional errors that occurred previously with mglmLS().
\item
The arguments of glmLRT() and glmQLFTest() have been simplified so that the argument y, previously the first argument of glmLRT, is no longer required.
\item
glmQLFTest() now ensures that no p-value is smaller than what would be obtained by treating the likelihood ratio test statistic as chisquare.
\item
glmQLFTest() now treats tags with all zero counts in replicate arrays as having zero residual df.
\item
gof() now optionally produces a qq-plot of the genewise goodness of fit statistics.
\item
Argument null.hypothesis removed from equalizeLibSizes().
\item
DGEList no longer outputs a component called all.zeros.
\item
goodTuring() no longer produces a plot.
Instead there is a new function goodTuringPlot() for plotting log-probability versus log-frequency.
goodTuring() has a new argument 'conf' giving the confidence factor for the linear regression approximation.
\item
Added plot.it argument to maPlot().
}}
\section{Version 2.6.0}{\itemize{
\item
edgeR now depends on limma.
\item
Considerable work on the User's Guide.
New case study added on Pathogen inoculated arabidopsis illustrating a two group comparison with batch effects.
All the other case studies have been updated and streamlined.
New section explaining why adjustments for GC content and mappability are not necessary in a differential expression context.
\item
New and more intuitive column headings for topTags() output.
'logFC' is now the first column.
Log-concentration is now replaced by log-counts-per-million ('logCPM').
'PValue' replaces 'P.Value'.
These column headings are now inserted in the table of results by
exactTest() and glmLRT() instead of being modified by the show method for the TopTags object generated by topTags().
This means that the column names will be correct even when users access the fitted model objects
directly instead of using the show method.
\item
plotSmear() and plotMeanVar() now use logCPM instead of logConc.
\item
New function glmQLFTest() provides quasi-likelihood hypothesis testing using F-tests, as an alternative to likelihood ratio tests using the chisquare distribution.
\item
New functions normalizeChIPtoInput() and calcNormOffsetsforChIP()
for normalization of ChIP-Seq counts relative to input control.
\item
New capabilities for formal shrinkage of the logFC.
exactTest() now incorporates formal shrinkage of the logFC, controlled by argument 'prior.count.total'.
predFC() provides similar shrinkage capability for glms.
\item
estimateCommonDisp() and estimateGLMCommonDisp() now set the dispersion to NA when there is no replication,
instead of setting the dispersion to zero.
This means that users will need to set a dispersion value explicitly to use functions further down the analysis pipeline.
\item
New function estimateTrendedDisp() analogous to estimateGLMTrendedDisp() but for classic edgeR.
\item
The algorithms implemented in estimateTagwiseDisp() now uses fewer grid points but interpolates, similar to estimateGLMTagwiseDisp().
\item
The power trend fitted by dispCoxReidPowerTrend() now includes a positive asymptote.
This greatly improves the fit on real data sets.
This now becomes the default method for estimateGLMTrendedDisp() when the number of genes is less than 200.
\item
New user-friendly function plotBCV() displays estimated dispersions.
\item
New argument target.size for thinCounts().
\item
New utility functions getDispersion() and zscoreNBinom().
\item
dimnames() methods for DGEExact, DGELRT and TopTags classes.
\item
Function pooledVar() removed as no longer necessary.
\item
Minor fixes to various functions to ensure correct results in special cases.
}}
\section{Version 2.4.0}{\itemize{
\item New function spliceVariants() for detecting alternative exon usage
from exon-level count data.
\item A choice of rejection regions is now implemented for exactTest(),
and the default is changed from one based on small probabilities
to one based on doubling the smaller of the tail probabilities.
This gives better results than the original conditional test when
the dispersion is large (especially > 1). A Beta distribution
approximation to the tail probability is also implemented when
the counts are large, making exactTest() much faster and
less memory hungry.
\item estimateTagwiseDisp() now includes an abundance trend on the
dispersions by default.
\item exactTest() now uses tagwise.dispersion by default if found in the
object.
\item estimateCRDisp() is removed. It is now replaced by
estimateGLMCommonDisp(), estimateGLMTrendedDisp() and
estimateGLMTagwiseDisp().
\item Changes to glmFit() so that it automatically detects dispersion
estimates if in data object. It uses tagwise if available, then
trended, then common.
\item Add getPriorN() to calculate the weight given to the common
parameter likelihood in order to smooth (or stabilize) the
dispersion estimates. Used as default for estimateTagwiseDisp and
estimateGLMTagwiseDisp().
\item New function cutWithMinN() used in binning methods.
\item glmFit() now S3 generic function, and glmFit() has new method
argument specifying fitting algorithm.
\item DGEGLM objects now subsettable.
\item plotMDS.dge() is retired, instead a DGEList method is now defined for
plotMDS() in the limma package. One advantage is that the plot can
be repeated with different graphical parameters without recomputing
the distances. The MDS method is also now much faster.
\item Add as.data.frame method for TopTags objects.
\item New function cpm() to calculate counts per million conveniently.
\item Adding args to dispCoxReidInterpolateTagwise() to give more access to
tuning parameters.
\item estimateGLMTagwiseDisp() now uses trended.dispersion by default if
trended.dispersion is found.
\item Change to glmLRT() to ensure character coefficient argument will work.
\item Change to maPlot() so that any really extreme logFCs are brought back
to a more reasonable scale.
\item estimateGLMCommonDisp() now returns NA when there are no residual
df rather than returning dispersion of zero.
\item The trend computation of the local common likelihood in
dispCoxReidInterpolateTagwise() is now based on moving averages
rather than lowess.
\item Changes to binGLMDispersion() to allow trended dispersion for data
sets with small numbers of genes, but with extra warnings.
\item dispDeviance() and dispPearson() now give graceful estimates and
messages when the dispersion is outside the specified interval.
\item Bug fix to mglmOneWay(), which was confusing parametrizations when
the design matrix included negative values.
\item mglmOneWay() (and hence glmFit) no longer produces NA coefficients
when some of the fitted values were exactly zero.
\item Changes to offset behaviour in estimateGLMCommonDisp(),
estimateGLMTrendedDisp() and estimateGLMTagwiseDisp() to fix bug.
Changes to several other functions on the way to fixing bugs
when computing dispersions in data sets with genes that have all
zero counts.
\item Bug fix to mglmSimple() with matrix offset.
\item Bug fix to adjustedProfLik() when there are fitted values exactly
at zero for one or more groups.
}}
|