Mercurial > repos > devteam > kraken_filter
comparison README.md @ 0:60d9479c58d6 draft
Uploaded
author | devteam |
---|---|
date | Wed, 22 Apr 2015 13:03:54 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:60d9479c58d6 |
---|---|
1 Introduction | |
2 ============ | |
3 | |
4 [Kraken] is a taxonomic sequence classifier that assigns taxonomic | |
5 labels to short DNA reads. It does this by examining the $k$-mers | |
6 within a read and querying a database with those $k$-mers. This database | |
7 contains a mapping of every $k$-mer in [Kraken]'s genomic library to the | |
8 lowest common ancestor (LCA) in a taxonomic tree of all genomes that | |
9 contain that $k$-mer. The set of LCA taxa that correspond to the $k$-mers | |
10 in a read are then analyzed to create a single taxonomic label for the | |
11 read; this label can be any of the nodes in the taxonomic tree. | |
12 [Kraken] is designed to be rapid, sensitive, and highly precise. Our | |
13 tests on various real and simulated data have shown [Kraken] to have | |
14 sensitivity slightly lower than Megablast with precision being slightly | |
15 higher. On a set of simulated 100 bp reads, [Kraken] processed over 1.3 | |
16 million reads per minute on a single core in normal operation, and over | |
17 4.1 million reads per minute in quick operation. | |
18 | |
19 The latest released version of Kraken will be available at the | |
20 [Kraken website], and the latest updates to the Kraken source code | |
21 are available at the [Kraken GitHub repository]. | |
22 | |
23 If you use [Kraken] in your research, please cite the [Kraken paper]. | |
24 Thank you! | |
25 | |
26 [Kraken]: http://ccb.jhu.edu/software/kraken/ | |
27 [Kraken website]: http://ccb.jhu.edu/software/kraken/ | |
28 [Kraken paper]: http://genomebiology.com/2014/15/3/R46 | |
29 [Kraken GitHub repository]: https://github.com/DerrickWood/kraken | |
30 | |
31 | |
32 System Requirements | |
33 =================== | |
34 | |
35 Note: Users concerned about the disk or memory requirements should | |
36 read the paragraph about MiniKraken, below. | |
37 | |
38 * **Disk space**: Construction of Kraken's standard database will require at | |
39 least 160 GB of disk space. Customized databases may require | |
40 more or less space. Disk space used is linearly proportional | |
41 to the number of distinct $k$-mers; as of Feb. 2015, Kraken's | |
42 default database contains just under 6 billion (6e9) distinct $k$-mers. | |
43 | |
44 In addition, the disk used to store the database should be | |
45 locally-attached storage. Storing the database on a network | |
46 filesystem (NFS) partition can cause Kraken's operation to be | |
47 very slow, or to be stopped completely. As NFS accesses are | |
48 much slower than local disk accesses, both preloading and database | |
49 building will be slowed by use of NFS. | |
50 | |
51 * **Memory**: To run efficiently, Kraken requires enough free memory to | |
52 hold the database in RAM. While this can be accomplished using a | |
53 ramdisk, Kraken supplies a utility for loading the database into | |
54 RAM via the OS cache. The default database size is 75 GB (as of | |
55 Feb. 2015), and so you will need at least that much RAM if you want | |
56 to build or run with the default database. | |
57 | |
58 * **Dependencies**: Kraken currently makes extensive use of Linux utilities | |
59 such as sed, find, and wget. Many scripts are written using the | |
60 Bash shell, and the main scripts are written using Perl. Core | |
61 programs needed to build the database and run the classifier are | |
62 written in C++, and need to be compiled using g++. Multithreading | |
63 is handled using OpenMP. Downloads of NCBI data are performed by | |
64 wget and in some cases, by rsync. Most Linux systems that have any | |
65 sort of development package installed will have all of the above | |
66 listed programs and libraries available. | |
67 | |
68 Finally, if you want to build your own database, you will need to | |
69 install the [Jellyfish] $k$-mer counter. Note that Kraken only | |
70 supports use of Jellyfish version 1. Jellyfish version 2 is not | |
71 yet compatible with Kraken. | |
72 | |
73 * **Network connectivity**: Kraken's standard database build and download | |
74 commands expect unfettered FTP and rsync access to the NCBI FTP | |
75 server. If you're working behind a proxy, you may need to set | |
76 certain environment variables (such as `ftp_proxy` or `RSYNC_PROXY`) | |
77 in order to get these commands to work properly. | |
78 | |
79 * **MiniKraken**: To allow users with low-memory computing environments to | |
80 use Kraken, we supply a reduced standard database that can be | |
81 downloaded from the Kraken web site. When Kraken is run with a | |
82 reduced database, we call it MiniKraken. | |
83 | |
84 The database we make available is only 4 GB in size, and should | |
85 run well on computers with as little as 8 GB of RAM. Disk space | |
86 required for this database is also only 4 GB. | |
87 | |
88 [Jellyfish]: http://www.cbcb.umd.edu/software/jellyfish/ |