forked from ANGSD/angsd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
abcFreq.h
76 lines (65 loc) · 2.53 KB
/
abcFreq.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
//DRAGON fix degree of freedom in chisq unknown
#include "abc.h"
typedef struct{
double *freq_EM;
double *freq_EM_unknown;
double *lrt_tri;
double *lrt_EM;
double *lrt_EM_unknown;
double *freq;//can be copy of the two above, or the pp
double *lrt;//can be a copy of hte two above
double *phat; //counts based freq
}freqStruct;
class abcFreq:public abc{
private:
int underflowprotect;
kstring_t bufstr;
Chisqdist *chisq1;
Chisqdist *chisq2;
Chisqdist *chisq3;
int nInd;
char *refName;
char *ancName;
char *indFname;
static double EM_start;//static due to called from analysisEstErorr,analysisAsso
static int emIter;//static due to called from analysisEstErorr,analysisAsso
double eps;
void prepPrint(funkyPars *pars);
BGZF *outfileZ;
BGZF *outfileZ2;
int doMaf;
double rmTriallelic;
int doPost;
int doSNP;
int doMajorMinor;
int GL;
double minMaf;
double SNP_pval;
double SNP_pval_tri;
int beagleProb;
int minInd;
int inputIsBeagle;
public:
int algoGeno(double *liks,int major_offset,int minor_offset,int numInds,int underFlowProtect,double *pest,double *postp);
static double *indF;
void run(funkyPars *pars);
void likeFreq(funkyPars *pars,freqStruct *freq);
void postFreq(funkyPars *pars,freqStruct *freq);
void clean(funkyPars *pars);
void print(funkyPars *pars);
void openfile(const char *outfiles);
void getOptions(argStruct *arguments);
void printArg(FILE *argFile);
abcFreq(const char *outfiles,argStruct *arguments,int inputtype);
~abcFreq();
static double emFrequencyNoFixed_F(double *loglike,int numInds, int iter,double start,int *keep,int keepInd,int major,int posi);
static double emFrequencyNoFixed(double *loglike,int numInds, int iter,double start,int *keep,int keepInd,int major,int posi);
static double emFrequencyNoFixed_ext(double *loglike,int numInds,int *keep,int keepInd,int major,int posi);
static double likeNoFixedMinor(double p,double *logLikes,int numInds,int major);
static double emFrequency_F(double *loglike,int numInds, int iter,double start,int *keep,int keepInd);
static double emFrequency(double *loglike,int numInds, int iter,double start,int *keep,int keepInd);
static double emFrequency_ext(double *loglike,int numInds,int *keep,int keepInd);
static double likeFixedMinor(double p,double *logLikes,int numInds);
static double isMultiAllelic(double *loglike,int numInds, int iter,double start,int *keep,int keepInd,int major,int posi);
static double likeMultiAllelic(double *p,double *logLikes,int numInds,int *keep);
};