Seqanswers Leaderboard Ad

Collapse

Announcement

Collapse
No announcement yet.
X
 
  • Filter
  • Time
  • Show
Clear All
new posts

  • Understanding DESeq2 dispersion estimates

    I construct a toy dataset with
    Code:
    > m
          Control  Case
    GeneA    3891  4591
    GeneB   69543 72122
    > colData
                 cc
    Case       Case
    Control Control
    > d <- DESeqDataSetFromMatrix(m, colData=colData, design =~cc)
    Then, I get the gene-wise dispersion
    Code:
    > d <- estimateSizeFactors(d)
    > d <- estimateDispersionsGeneEst(d)
    > mcols(d)
    DataFrame with 2 rows and 5 columns
       baseMean     baseVar   allZero dispGeneEst dispGeneEstConv
      <numeric>   <numeric> <logical>   <numeric>       <logical>
    1  4228.732    37181.63     FALSE 0.001842478            TRUE
    2 70857.604 10439534.06     FALSE 0.002065126            TRUE
    Now, I want to check i the dispersion estimates are just fitting a negative binomial on each gene's count (pooled conditions).
    Code:
    > fitdistr(as.vector(round(counts(d, normalize=T)[1,])),"negative binomial")
         size         mu    
      1207.3898   4228.5000 
     (1543.6506) (  97.5636)
    > fitdistr(as.vector(round(counts(d, normalize=T)[2,])),"negative binomial")
          size          mu    
        970.5831   70857.5000 
     (  982.6550) ( 1616.2617)

    Now the dispersion is the inverse of size, so it should be
    Code:
    > c(1/1207.3898, 1/970.5831)
    [1] 0.0008282329 0.0010303085
    But this is different from
    Code:
    > mcols(d)$dispGeneEst
    [1] 0.001842478 0.002065126

  • #2
    No, it does not work like that. First of all, DESeq2's model is that the counts are NB-distributed. You have fit an NB distribution to the rounded normalized counts instead. Why would you do that? Also, you don't have any residual degrees of freedom in your setting, so your example is ill-defined anyway.

    Maybe have a look at our preprint, with all the mathematical details in the Methods section: http://doi.org/10.1101/002832

    Comment


    • #3
      Last month, Gordon Smyth wrote on the Bioconductor list that edgeR with rounded counts would be an acceptable input for the analysis. EBseq, however, handles this kind of data without rounding.

      Comment


      • #4
        Of course, all these tools will accept any kind of integer data, no matter whether it is real counts or some other data that has been rounded to make it look like counts. Whether the latter makes any sense depends a lot on circumstances. (By definition of the English word, a "count" is an integer. If you need to round it first, it was not a count in the first place. Hence, "rounded counts" is a contradiction in terms -- what Gordon meant is simply that if you have non-integer data which are for some reason more or less close to the counts that you should have if you had counted correctly, the rounding is fine.)

        But what does all this have to do with the OP's question, and with my answer, neither of which was about using rounded something as input?

        Comment


        • #5
          Thank you for clarifying that. I hadn't read the code.

          Comment

          Latest Articles

          Collapse

          • seqadmin
            Essential Discoveries and Tools in Epitranscriptomics
            by seqadmin




            The field of epigenetics has traditionally concentrated more on DNA and how changes like methylation and phosphorylation of histones impact gene expression and regulation. However, our increased understanding of RNA modifications and their importance in cellular processes has led to a rise in epitranscriptomics research. “Epitranscriptomics brings together the concepts of epigenetics and gene expression,” explained Adrien Leger, PhD, Principal Research Scientist...
            04-22-2024, 07:01 AM
          • seqadmin
            Current Approaches to Protein Sequencing
            by seqadmin


            Proteins are often described as the workhorses of the cell, and identifying their sequences is key to understanding their role in biological processes and disease. Currently, the most common technique used to determine protein sequences is mass spectrometry. While still a valuable tool, mass spectrometry faces several limitations and requires a highly experienced scientist familiar with the equipment to operate it. Additionally, other proteomic methods, like affinity assays, are constrained...
            04-04-2024, 04:25 PM

          ad_right_rmr

          Collapse

          News

          Collapse

          Topics Statistics Last Post
          Started by seqadmin, Today, 08:47 AM
          0 responses
          12 views
          0 likes
          Last Post seqadmin  
          Started by seqadmin, 04-11-2024, 12:08 PM
          0 responses
          60 views
          0 likes
          Last Post seqadmin  
          Started by seqadmin, 04-10-2024, 10:19 PM
          0 responses
          59 views
          0 likes
          Last Post seqadmin  
          Started by seqadmin, 04-10-2024, 09:21 AM
          0 responses
          54 views
          0 likes
          Last Post seqadmin  
          Working...
          X