File: bisulfite.rst

package info (click to toggle)
last-align 1645-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 14,684 kB
  • sloc: cpp: 44,403; python: 5,212; ansic: 1,938; sh: 710; makefile: 457
file content (65 lines) | stat: -rw-r--r-- 2,452 bytes parent folder | download | duplicates (2)
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
Aligning bisulfite-converted DNA reads to a genome
==================================================

Bisulfite is used to detect methylated cytosines.  It converts
unmethylated Cs to Ts, but it leaves methylated Cs intact.  If we then
sequence the DNA and align it to a reference genome, we can infer
cytosine methylation.

We developed a recipe_ for this in 2011, used in Bisulfighter_.  Since
then, computer memories have gotten bigger, allowing simpler recipes.

Suppose we have bisulfite-converted DNA reads in a file "reads.fastq",
and the genome in "mygenome.fa".  Assume all the reads are from
converted DNA strands, not reverse strands (so they have C→T
conversions and not G→A conversions).  We can align the reads like this::

   lastdb -P8 -uBISF -S2 mydb mygenome.fa
   last-train -P8 -S0 -Q1 mydb reads.fastq > my.train
   lastal -P8 --split -p my.train mydb reads.fastq > out.maf

* ``-uBISF`` selects a `seeding scheme`_ that tolerates c:t mismatches.

* ``-S2`` uses both strands of the genome.  (So we can use just the
  forward strands of the reads).

* ``-S0`` makes no difference here, but matters for reverse-strand reads.

If the DNA reads are from the reverse of converted strands (so they
have G→A conversions), add ``-s0`` to the ``last-train`` options.

Paired DNA reads
----------------

Suppose we have paired reads in 2 files: ``reads1.fastq`` from
converted strands, and ``reads2.fastq`` from the reverse of converted
strands.  We can align the reads like this::

   lastdb -P8 -uBISF -S2 mydb mygenome.fa
   last-train -P8 -S0 -Q1 mydb reads1.fastq > my.train
   lastal -P8 --split -p my.train -sFR mydb reads1.fastq reads2.fastq > out.maf

* ``-sFR`` makes it use forward strands of reads1 and reverse strands
  of reads2.


Avoiding bias
-------------

There is a potential bias: unconverted Cs are easier to align
unambiguously.  We can avoid this bias by converting all Cs in the
reads to Ts::

   perl -pe 'y/Cca-z/ttA-Z/ if $. % 4 == 2' reads.fastq |

   lastal -P8 --split -p my.train mydb |

   perl -F'(\s+)' -ane '$F[12] =~ y/ta/CG/ if /^s/ and $s++ % 2; print @F' > out.maf

The first line converts C to lowercase t, and all other letters to
uppercase.  The last line un-converts lowercase letters in the DNA reads.

.. _recipe: https://doi.org/10.1093/nar/gks275
.. _Bisulfighter: https://github.com/yutaka-saito/Bisulfighter
.. _cookbook: doc/last-cookbook.rst
.. _seeding scheme: doc/last-seeds.rst