-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathpssm.h
79 lines (70 loc) · 2.91 KB
/
pssm.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// PSSMSearcher: A library for searching with Position Specific Scoring Matrices
//
// Copyright (C) 2006, 2007 Jes Frellsen, Ida Moltke and Martin Thiim
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef PSSM_H_
#define PSSM_H_
#define MAXPSSMSIZE 1024
#define MAX_LINE_LENGTH 1024
#include "probs.h"
#ifndef BWA_UBYTE
#define BWA_UBYTE
typedef unsigned char ubyte_t;
#endif
struct PSSM
{
int id;
int length; // can be char
int order; // can be char
int alphabet_size;
char *alphabet;
char *alphabet_indexes;
int *scores;
int *offsets; //[MAXPSSMSIZE+1];
int *thresholds; //[MAXPSSMSIZE];
int *saved_scores; //e[MAXPSSMSIZE+1];
int *bi; //best inexact match score
int *be; //best exact match score
int maxHits;
};
typedef struct PSSM* PSSM;
// Mutators
PSSM init_matrix(int order, int length, int alphabetSize);
PSSM init_matrix_score(int order, int length, int alphabetSize, int *scores, int nScores, int threshold);
void release_matrix(PSSM pssm);
int maximum_score(PSSM pssm, int pos);
void calc_and_set_offsets(PSSM pssm, int order, int length, int alphabetSize);
void calc_and_set_thresholds(PSSM pssm, int threshold);
void calc_and_set_reverse_thresholds(PSSM mat, int start, int end, int threshold);
void set_score(PSSM pssm, const unsigned char *letters, int pos, int score);
static inline void set_length(PSSM pssm, int length) { pssm->length=length; }
void print_horizontalPSSM(PSSM pssm, int n);
void complement_pssm(PSSM mat);
// Acsessors
int get_score(PSSM pssm, const ubyte_t *baseLetter, int pos);
int get_threshold(PSSM pssm, int pos);
int get_global_threshold(PSSM pssm);
int get_length(PSSM pssm);
void calculate_reverse_best_inexact(PSSM mat, int *min_drops);
void calculate_reverse_best_exact(PSSM mat);
// Fast accessors
#define get_threshold_fast(pssm, pos) (pssm)->thresholds[pos]
#define get_global_threshold_fast(pssm) (pssm)->thresholds[(pssm)->length - 1]
#define get_length_fast(pssm) (pssm)->length
#define get_num_scores(pssm) (pssm)->offsets[(pssm)->length]
#define get_score_fast(pssm, base_letter, pos) ( (pssm)->order == 0 ? (pssm)->scores[(pssm)->offsets[pos] + (int)*(base_letter)] : get_score(pssm, base_letter, pos) )
#define get_saved_score(pssm, depth) (pssm)->saved_scores[depth]
#define set_saved_score(pssm, depth, score) (pssm)->saved_scores[depth] = score;
#endif