annotate pyPRADA_1.2/tools/samtools-0.1.16/bam_maqcns.h @ 0:acc2ca1a3ba4

Uploaded
author siyuan
date Thu, 20 Feb 2014 00:44:58 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
1 #ifndef BAM_MAQCNS_H
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
2 #define BAM_MAQCNS_H
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
3
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
4 #include "glf.h"
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
5
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
6 #define BAM_ERRMOD_MAQ2 0
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
7 #define BAM_ERRMOD_MAQ 1
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
8 #define BAM_ERRMOD_SOAP 2
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
9
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
10 struct __bmc_aux_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
11
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
12 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
13 float het_rate, theta;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
14 int n_hap, cap_mapQ, errmod, min_baseQ;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
15
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
16 float eta, q_r;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
17 double *fk, *coef;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
18 double *lhet;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
19 struct __bmc_aux_t *aux;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
20 } bam_maqcns_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
21
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
22 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
23 int q_indel; // indel sequencing error, phred scaled
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
24 float r_indel; // indel prior
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
25 float r_snp; // snp prior
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
26 // hidden parameters, unchangeable from command line
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
27 int mm_penalty, indel_err, ambi_thres;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
28 } bam_maqindel_opt_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
29
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
30 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
31 int indel1, indel2;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
32 int cnt1, cnt2, cnt_anti;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
33 int cnt_ref, cnt_ambi;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
34 char *s[2];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
35 //
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
36 int gt, gl[2];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
37 int q_cns, q_ref;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
38 } bam_maqindel_ret_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
39
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
40 #ifdef __cplusplus
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
41 extern "C" {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
42 #endif
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
43
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
44 bam_maqcns_t *bam_maqcns_init();
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
45 void bam_maqcns_prepare(bam_maqcns_t *bm);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
46 void bam_maqcns_destroy(bam_maqcns_t *bm);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
47 glf1_t *bam_maqcns_glfgen(int n, const bam_pileup1_t *pl, uint8_t ref_base, bam_maqcns_t *bm);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
48 uint32_t bam_maqcns_call(int n, const bam_pileup1_t *pl, bam_maqcns_t *bm);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
49 // return: cns<<28 | cns2<<24 | mapQ<<16 | cnsQ<<8 | cnsQ2
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
50 uint32_t glf2cns(const glf1_t *g, int q_r);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
51
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
52 bam_maqindel_opt_t *bam_maqindel_opt_init();
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
53 bam_maqindel_ret_t *bam_maqindel(int n, int pos, const bam_maqindel_opt_t *mi, const bam_pileup1_t *pl, const char *ref,
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
54 int _n_types, int *_types);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
55 void bam_maqindel_ret_destroy(bam_maqindel_ret_t*);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
56
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
57 #ifdef __cplusplus
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
58 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
59 #endif
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
60
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
61 #endif