Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lh3/yak
Yet another k-mer analyzer
https://github.com/lh3/yak
bioinformatics k-mer
Last synced: about 2 months ago
JSON representation
Yet another k-mer analyzer
- Host: GitHub
- URL: https://github.com/lh3/yak
- Owner: lh3
- License: mit
- Created: 2019-10-11T14:22:16.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-04-01T21:39:44.000Z (9 months ago)
- Last Synced: 2024-11-16T05:31:59.629Z (about 2 months ago)
- Topics: bioinformatics, k-mer
- Language: C
- Size: 85.9 KB
- Stars: 115
- Watchers: 8
- Forks: 9
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- top-life-sciences - **lh3/yak** - mer analyzer<br>`bioinformatics`, `k-mer`<br><img src='https://github.com/HubTou/topgh/blob/main/icons/gstars.png'> 108 <img src='https://github.com/HubTou/topgh/blob/main/icons/forks.png'> 8 <img src='https://github.com/HubTou/topgh/blob/main/icons/code.png'> C <img src='https://github.com/HubTou/topgh/blob/main/icons/license.png'> MIT License <img src='https://github.com/HubTou/topgh/blob/main/icons/last.png'> 2024-04-01 21:39:44 | (Ranked by starred repositories)
README
**IMPORTANT: Since 3ace4ff, the format of binary k-mer dump is incompatible
with the previous versions. You have to rerun `yak count` to generate k-mer
dump in the new format.**## Getting Started
```sh
# Download and compile
git clone https://github.com/lh3/yak
cd yak && make# build k-mer hash table for assembly; count singletons
./yak count -K1.5g -t32 -o asm.yak asm.fa.gz
# build k-mer hash tables for high-coverage reads; discard singletons
./yak count -b37 -t32 -o ccs.yak ccs-reads.fq.gz
# for paired end: to provide two identical streams
./yak count -b37 -t32 -o sr.yak <(zcat sr*.fq.gz) <(zcat sr*.fq.gz)# compute assembly or reads QV
./yak qv -t32 -p -K3.2g -l100k sr.yak asm.fa.gz > asm-sr.qv.txt
./yak qv -t32 -p sr.yak ccs-reads.fq.gz > ccs-sr.qv.txt
# compute k-mer QV for reads
./yak inspect ccs.yak sr.yak > ccs-sr.kqv.txt
# evaluate the completeness of assembly
./yak inspect sr.yak asm.yak > sr-asm.kqv.txt# print k-mer histogram
./yak inspect sr.yak > sr.hist# partition chrX/Y in human de novo assembly
wget -O- 'https://zenodo.org/record/7882299/files/human-chrXY-yak.tar?download=1' | tar tf -
./yak sexchr -K2g -t16 chrY-no-par.yak chrX-no-par.yak par.yak hap1.fa hap2.fa > cnt.txt
./groupxy.pl cnt.txt|awk '$4==1'|cut -f2|seqtk subseq -l80 <(cat hap1.fa hap2.fa) - > new-hap1.fa
./groupxy.pl cnt.txt|awk '$4==2'|cut -f2|seqtk subseq -l80 <(cat hap1.fa hap2.fa) - > new-hap2.fa
```## Introduction
Yak is initially developed for two specific use cases: 1) to robustly estimate
the base accuracy of CCS reads and assembly contigs, and 2) to investigate the
systematic error rate of CCS reads. It achieves the goals by comparing
sequences to the k-mer spectrum of short reads or by comparing spectra. No
reference genome or truth data is needed.It is worth noting that estimating base accuracy is tricky. When the accuracy
approaches Q50, both unsampled and erroneous k-mers in short reads may
interfere with a naive estimator. Yak introduces an empirical model to address
this issue. Its estimate is less affected by the coverage and the quality of
short reads.