annotate pyPRADA_1.2/tools/samtools-0.1.16/glf.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 GLF_H_
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
2 #define GLF_H_
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
3
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
4 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
5 unsigned char ref_base:4, dummy:4; /** "XACMGRSVTWYHKDBN"[ref_base] gives the reference base */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
6 unsigned char max_mapQ; /** maximum mapping quality */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
7 unsigned char lk[10]; /** log likelihood ratio, capped at 255 */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
8 unsigned min_lk:8, depth:24; /** minimum lk capped at 255, and the number of mapped reads */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
9 } glf1_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
10
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
11 #include <stdint.h>
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
12 #include "bgzf.h"
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
13 typedef BGZF *glfFile;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
14
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
15 #define GLF3_RTYPE_END 0
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
16 #define GLF3_RTYPE_SUB 1
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
17 #define GLF3_RTYPE_INDEL 2
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
18
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
19 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
20 uint8_t ref_base:4, rtype:4; /** "XACMGRSVTWYHKDBN"[ref_base] gives the reference base */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
21 uint8_t rms_mapQ; /** RMS mapping quality */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
22 uint8_t lk[10]; /** log likelihood ratio, capped at 255 */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
23 uint32_t min_lk:8, depth:24; /** minimum lk capped at 255, and the number of mapped reads */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
24 int32_t offset; /** the first base in a chromosome has offset zero. */
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
25 // for indel (lkHom1, lkHom2 and lkHet are the first three elements in lk[10])
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
26 int16_t indel_len[2];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
27 int32_t max_len; // maximum indel len; will be modified by glf3_read1()
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
28 char *indel_seq[2];
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
29 } glf3_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
30
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
31 typedef struct {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
32 int32_t l_text;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
33 uint8_t *text;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
34 } glf3_header_t;
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
35
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
36 #ifdef __cplusplus
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
37 extern "C" {
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
38 #endif
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
39
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
40 #define glf3_init1() ((glf3_t*)calloc(1, sizeof(glf3_t)))
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
41 #define glf3_destroy1(g3) do { free((g3)->indel_seq[0]); free((g3)->indel_seq[1]); free(g3); } while (0)
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
42
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
43 glf3_header_t *glf3_header_init();
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
44 glf3_header_t *glf3_header_read(glfFile fp);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
45 void glf3_header_write(glfFile fp, const glf3_header_t *h);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
46 void glf3_header_destroy(glf3_header_t *h);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
47 char *glf3_ref_read(glfFile fp, int *len);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
48 void glf3_ref_write(glfFile fp, const char *name, int len);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
49 int glf3_write1(glfFile fp, const glf3_t *g3);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
50 int glf3_read1(glfFile fp, glf3_t *g3);
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
51
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
52 #ifdef __cplusplus
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
53 }
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
54 #endif
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
55
acc2ca1a3ba4 Uploaded
siyuan
parents:
diff changeset
56 #endif