-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMAnalysis.h
131 lines (107 loc) · 5.19 KB
/
MAnalysis.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/*
Copyright 2018, Michael R. Hoopmann, Institute for Systems Biology
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef _MANALYSIS_H
#define _MANALYSIS_H
#include "MDB.h"
#include "MData.h"
#include "MIons.h"
#include "Threading.h"
#include "ThreadPool.h"
#include "CometDecoys.h"
//=============================
// Structures for threading
//=============================
struct mAnalysisStruct {
bool* bKIonsMem; //Pointer to the memory manager array to mark memory is in use
Mutex* mutex; //Pointer to a mutex for protecting memory
mPeptide* pep;
int pepIndex;
mAnalysisStruct(Mutex* m, mPeptide* p, int i){
mutex=m;
pep=p;
pepIndex=i;
}
~mAnalysisStruct(){
//Mark that memory is not being used, but do not delete it here.
Threading::LockMutex(*mutex);
if(bKIonsMem!=NULL) *bKIonsMem=false;
bKIonsMem=NULL;
Threading::UnlockMutex(*mutex);
mutex=NULL; //release mutex
pep=NULL;
}
};
class MAnalysis{
public:
//Constructors & Destructors
MAnalysis (mParams& p, MDatabase* d, MData* dat);
~MAnalysis ();
//Master Functions
bool doPeptideAnalysis ();
bool doEValuePrecalc();
private:
//Thread-start functions
static void analyzePeptideProc(mAnalysisStruct* s);
static void analyzeEValuePrecalcProc(MSpectrum* s);
//Analysis functions
static bool analyzePeptide(mPeptide* p, int pepIndex, int iIndex);
//Private Functions
bool allocateMemory (int threads);
static bool analyzeSinglets (mPeptide& pep, int index, int iIndex);
static void checkXLMotif (int motifA, char* motifB, std::vector<int>& v);
void deallocateMemory (int threads);
//static void scoreSingletSpectra (int index, int sIndex, double mass, int len, int pep, char k, double minMass, double maxMass, int iIndex, bool bSiteless=false);
//static void scoreSpectra (std::vector<int>& index, int sIndex, int len, double modMass, int pep1, int pep2, int k1, int k2, int link, int iIndex);
//static float magnumScoring (int specIndex, double modMass, int sIndex, int iIndex, int& match, int& conFrag, int z=0);
//Data Members
//static bool bEcho;
//static int sCounter;
static bool* bKIonsManager;
static MDatabase* db;
static MIons* ions;
static double maxMass;
static double minMass;
static mParams params;
static MData* spec;
static bool* adductSites;
static bool** scanBuffer;
static int numIonSeries;
static int* pepMassSize;
static double** pepMass;
static bool** pepBin;
static int* pepBinSize;
static int skipCount;
static int nonSkipCount;
static MDecoys decoys;
//static bool scoreSingletSpectra2(int index, int sIndex, double mass, double xlMass, int counterMotif, int len, int pep, char k, double minMass, int iIndex, char linkSite, int linkIndex);
static Mutex mutexKIonsManager;
static Mutex* mutexSpecScore; //these signal PSM list reads/additions/deleteions
static Mutex** mutexSingletScore; //these signal singlet list reads/additions/deletions
//For new search
static double dummy[10];
static int dummyM[10];
static int* maxZ2;
static size_t* bufSize2;
static char magnumScoring2(MSpectrum* s, double mass);
static void scoreSingletSpectra2(int index, double mass, int len, int pep, double minMass, double maxMass, int iIndex);
static void scoreSpectra2(std::vector<int>& index, double mass, int len, int pep1, int iIndex);
static void score6(MSpectrum* s, sNode2* node, sLink2* link, double* score, double* scoreNL, int depth, sScoreSet* v, std::vector<sPrecursor>* pre, int iIndex/*, double minMass, double maxMass*/);
static void score7(MSpectrum* s, std::vector<sNode2>* peakSet, sNode2* node, sLink2* link, double* score, double* scoreNL, int depth, sScoreSet* v, std::vector<sPrecursor>* pre, int iIndex/*, double minMass, double maxMass*/);
static void score8(MSpectrum* s, std::vector<sNode2>* peakSet, sNode2* node, sLink2* link, sScoreSet* v, std::vector<sPrecursor>* pre, int iIndex);
static void score6solo(MSpectrum* s, sNode2* node, sLink2* link, double* score, double* scoreNL, sScoreSet* v, sPrecursor& pre, int iIndex, double maxMass);
static void score7solo(MSpectrum* s, std::vector<sNode2>* peakSet, sNode2* node, sLink2* link, double* score, double* scoreNL, sScoreSet* v, sPrecursor& pre, int iIndex, double maxMass);
//static void score7(MSpectrum* s, sNode2* node, sLink2* link, double* score, double* scoreNL, int* match, int* matchNL, int depth, sScoreSet* v, std::vector<sPrecursor>* pre, int iIndex, int maxZ, size_t bufSize, size_t bufSizeM/*, double minMass, double maxMass*/);
//Utilities
static int compareD (const void *p1,const void *p2);
};
#endif