学位论文详细信息
Distributed memory building blocks for massive biological sequence analysis
High performance computing;Bioinformatics;K-mer index;K-mer counting;De bruijn graph;Next generation sequencing;Parallel algorithms;Distributed memory;Distributed algorithms;SIMD vectorization;Cache friendly algorithms;MPI
Pan, Tony C. ; Bader, David Aluru, Srinivas Computational Science and Engineering Catalyurek, Umit Vuduc, Richard Jordan, King Vannberg, Fredrick ; Bader, David
University:Georgia Institute of Technology
Department:Computational Science and Engineering
关键词: High performance computing;    Bioinformatics;    K-mer index;    K-mer counting;    De bruijn graph;    Next generation sequencing;    Parallel algorithms;    Distributed memory;    Distributed algorithms;    SIMD vectorization;    Cache friendly algorithms;    MPI;   
Others  :  https://smartech.gatech.edu/bitstream/1853/59894/1/PAN-DISSERTATION-2018.pdf
美国|英语
来源: SMARTech Repository
PDF
【 摘 要 】

K-mer indices and de Bruijn graphs are important data structures inbioinformatics with multiple applications ranging from foundational tasks such as error correction, alignment, and genome assembly, to knowledge discovery tasks including repeat detection and SNP identification. While advances in nextgeneration sequencing technologies have dramatically reduced the cost and improved latency and throughput, few bioinformatics tools can efficientlyprocess the data sets at the current generation rate of 1.8 terabases every 3 days. The volume and velocity with which sequencing data is generated necessitate efficient algorithms and implementation of k-mer indices and de Bruijn graphs, two central components in bioinformatic applications. Existing applications that utilize k-mer counting and de Bruijn graphs, however, tend to provide embedded, specialized implementations. The research presented here represents efforts toward the creation of the first reusable, flexible, and extensible distributed memory parallel libraries for k-mer indexing and de Bruijn graphs. These libraries are intended for simplifying the development of bioinformatics applications for distributed memory environments. For each library, our goals are to create a set of API that are simple to use, and provide optimized implementations based on efficient parallel algorithms. We designed algorithms that minimize communication volume and latency, and developed implementations with better cache utilization and SIMD vectorization. We developed Kmerind, a k-mer counting and indexing library based on distributed memory hash table and distributed sorted arrays, that provide efficient insert, find, count, and erase operations. For de Bruijn graphs, we developed Bruno by leveraging Kmerind functionalities to support parallel de Bruijn graph construction, chain compaction, error removal, and graph traversal and element query. Our performance evaluations showed that Kmerind is scalable and high performance. Kmerind counted k-mers in a 120GB data set in less than 13 seconds on 1024 cores, and indexing the k-mer positions in 17 seconds. Using the Cori supercomputer and incorporating architecture aware optimizations as well as MPI-OpenMP hybrid computation and overlapped communication, Kmerind was able to count a 350GB data set in 4.1 seconds using 4096 cores. Kmerind has been shown to out-perform the state-of-the-art k-mer counting tools at 32 to 64 cores on a shared memory system. The Bruno library is built on Kmerind and implements efficient algorithms for construction, compaction, and error removal.It is capable of constructing, compacting,and generating unitigs for a 694GB human read data set in 7.3 seconds on 7680 Edison cores. It is 1.4X and 3.7X faster than its state-of-the-art alternatives in shared and distributed memory environments, respectively. Error removal in a graph constructed from an 162 GB data set completed in 13.1 and 3.91 seconds with frequency filter of 2 and 4 respectively on 16 nodes, totaling 512 cores. While our target domain is bioinformatics, we approached algorithm design and implementation with the aim for broader applicabilities in computer science and other application domains. As a result, our chain compaction and cycle detection algorithms can feasibly be applied to general graphs, and our distributed and sequential cache friendly hash tables as well as vectorized hash functions are generic and application neutral.

【 预 览 】
附件列表
Files Size Format View
Distributed memory building blocks for massive biological sequence analysis 4639KB PDF download
  文献评价指标  
  下载次数:26次 浏览次数:16次