htslib C API: getting reads from region
1
0
Entering edit mode
9.5 years ago

I want to use the htslib C API to perform this task

my $pos = "1:100-1000";
my $bam_file = "in.bam";
my @reads = get_reads_from_htslib($bam_file,$pos)

foreach(@reads) {
    # do stuff...
}

I wrote it in perl but you get the idea. I can't find an example anywhere online. Does anyone have experience with htslib and getting reads from a region?

samtools htslib C API • 7.4k views
ADD COMMENT
7
Entering edit mode
9.5 years ago

here is a C code:

#include <stdlib.h>
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <math.h>
#include <inttypes.h>
#include <stdbool.h>
#include <assert.h>
#include "htslib/sam.h"
#include "htslib/faidx.h"
#include "htslib/kstring.h"
#include "htslib/khash.h"
#include "samtools.h"
int main(int argc,char** argv)
{
hts_itr_t *iter=NULL;
hts_idx_t *idx=NULL;
samFile *in = NULL;
bam1_t *b= NULL;
bam_hdr_t *header = NULL;
if(argc!=3) return -1;
in = sam_open(argv[1], "r");
if(in==NULL) return -1;
if ((header = sam_hdr_read(in)) == 0) return -1;
idx = sam_index_load(in, argv[1]);
if(idx==NULL) return -1;
iter = sam_itr_querys(idx, header, argv[2]);
if(iter==NULL) return -1;
b = bam_init1();
while ( sam_itr_next(in, iter, b) >= 0)
{
fputs("DO STUFF\n",stdout);
}
hts_itr_destroy(iter);
bam_destroy1(b);
bam_hdr_destroy(header);
sam_close(in);
return 0;
}
view raw biostar151053.c hosted with ❤ by GitHub

Compilation:

gcc -Isamtools -Ihtslib -Lsamtools -Lhtslib biostar151053.c htslib/libhts.a samtools/libbam.a -lz -lpthread
ADD COMMENT
1
Entering edit mode

Livesaver thanks!

ADD REPLY
0
Entering edit mode

What function calls here come from samtools.h?

ADD REPLY
0
Entering edit mode

may be none :-)

ADD REPLY
0
Entering edit mode

Dear Pierre, I have another question. Now I have a sam file without the index file, and I want to iterate all the reads of the sam file, how can I make it? Thanks in advance.

ADD REPLY
0
Entering edit mode

It seems that I have to compress the sam file to bam file, and get the index file then I can make it..

ADD REPLY
0
Entering edit mode

Dear Pierre I used the exact code and bash line but I face an error. I've downloaded htslib and samtools and put them in the same folder as the .c file.

.... "_lzma_stream_decoder", referenced from: _cram_uncompress_block in libhts.a(cram_io.o) ld: symbol(s) not found for architecture x86_64 clang: error: linker command failed with exit code 1 (use -v to see invocation)

Should I build samtools and htslib as mentioned here ?

ADD REPLY
1
Entering edit mode

I think so, furthermore, the code above is ~5 years old, the htslib has since much changed.

ADD REPLY
0
Entering edit mode

Thanks for fast respond.

ADD REPLY

Login before adding your answer.

Traffic: 3365 users visited in the last hour
Help About
FAQ
Access RSS
API
Stats

Use of this site constitutes acceptance of our User Agreement and Privacy Policy.

Powered by the version 2.3.6