annotate SNV/SNVMix2_source/SNVMix2-v0.12.1-rc1/samtools-0.1.6/bam_mate.c @ 0:74f5ea818cea

Uploaded
author ryanmorin
date Wed, 12 Oct 2011 19:50:38 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
1 #include <stdlib.h>
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
2 #include <string.h>
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
3 #include "bam.h"
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
4
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
5 // currently, this function ONLY works if each read has one hit
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
6 void bam_mating_core(bamFile in, bamFile out)
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
7 {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
8 bam_header_t *header;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
9 bam1_t *b[2];
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
10 int curr, has_prev;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
11
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
12 header = bam_header_read(in);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
13 bam_header_write(out, header);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
14
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
15 b[0] = bam_init1();
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
16 b[1] = bam_init1();
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
17 curr = 0; has_prev = 0;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
18 while (bam_read1(in, b[curr]) >= 0) {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
19 bam1_t *cur = b[curr], *pre = b[1-curr];
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
20 if (has_prev) {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
21 if (strcmp(bam1_qname(cur), bam1_qname(pre)) == 0) { // identical pair name
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
22 cur->core.mtid = pre->core.tid; cur->core.mpos = pre->core.pos;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
23 pre->core.mtid = cur->core.tid; pre->core.mpos = cur->core.pos;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
24 if (pre->core.tid == cur->core.tid && !(cur->core.flag&(BAM_FUNMAP|BAM_FMUNMAP))
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
25 && !(pre->core.flag&(BAM_FUNMAP|BAM_FMUNMAP)))
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
26 {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
27 uint32_t cur5, pre5;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
28 cur5 = (cur->core.flag&BAM_FREVERSE)? bam_calend(&cur->core, bam1_cigar(cur)) : cur->core.pos;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
29 pre5 = (pre->core.flag&BAM_FREVERSE)? bam_calend(&pre->core, bam1_cigar(pre)) : pre->core.pos;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
30 cur->core.isize = pre5 - cur5; pre->core.isize = cur5 - pre5;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
31 } else cur->core.isize = pre->core.isize = 0;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
32 if (pre->core.flag&BAM_FREVERSE) cur->core.flag |= BAM_FMREVERSE;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
33 else cur->core.flag &= ~BAM_FMREVERSE;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
34 if (cur->core.flag&BAM_FREVERSE) pre->core.flag |= BAM_FMREVERSE;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
35 else pre->core.flag &= ~BAM_FMREVERSE;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
36 if (cur->core.flag & BAM_FUNMAP) { pre->core.flag |= BAM_FMUNMAP; pre->core.flag &= ~BAM_FPROPER_PAIR; }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
37 if (pre->core.flag & BAM_FUNMAP) { cur->core.flag |= BAM_FMUNMAP; cur->core.flag &= ~BAM_FPROPER_PAIR; }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
38 bam_write1(out, pre);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
39 bam_write1(out, cur);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
40 has_prev = 0;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
41 } else { // unpaired or singleton
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
42 pre->core.mtid = -1; pre->core.mpos = -1; pre->core.isize = 0;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
43 if (pre->core.flag & BAM_FPAIRED) {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
44 pre->core.flag |= BAM_FMUNMAP;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
45 pre->core.flag &= ~BAM_FMREVERSE & ~BAM_FPROPER_PAIR;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
46 }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
47 bam_write1(out, pre);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
48 }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
49 } else has_prev = 1;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
50 curr = 1 - curr;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
51 }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
52 if (has_prev) bam_write1(out, b[1-curr]);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
53 bam_header_destroy(header);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
54 bam_destroy1(b[0]);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
55 bam_destroy1(b[1]);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
56 }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
57
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
58 int bam_mating(int argc, char *argv[])
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
59 {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
60 bamFile in, out;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
61 if (argc < 3) {
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
62 fprintf(stderr, "samtools fixmate <in.nameSrt.bam> <out.nameSrt.bam>\n");
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
63 return 1;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
64 }
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
65 in = (strcmp(argv[1], "-") == 0)? bam_dopen(fileno(stdin), "r") : bam_open(argv[1], "r");
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
66 out = (strcmp(argv[2], "-") == 0)? bam_dopen(fileno(stdout), "w") : bam_open(argv[2], "w");
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
67 bam_mating_core(in, out);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
68 bam_close(in); bam_close(out);
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
69 return 0;
74f5ea818cea Uploaded
ryanmorin
parents:
diff changeset
70 }