forked from ANGSD/angsd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathabcAsso.h
90 lines (79 loc) · 4.14 KB
/
abcAsso.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
#include "abc.h"
typedef struct{
double **stat;
double **statOther; //for likelihood of other model added by emil 14-11-2018
int **keepInd;
int *highHe;
int *highWt;
int *highHo;
double *betas; //for coefficients added by emil 07-11-2018
int *emIter; //number of iterations for EM algorithm in -doAsso 4
double *SEs; //for standard error estimates added by emil 20-03-2019
}assoStruct;
class abcAsso:public abc{
private:
kstring_t bufstr;
public:
//none optional stuff
BGZF **multiOutfile;
int doPrint;
int minCov; //not for users
int doMaf;
int dynCov;//not for users
int doAsso;
int doPost;
int GL;
int sitePerm; //not for users
int isBinary;
int isCount;
int isQuant;
int minHigh;
int minCount;
int adjust; //not for users
int model;
int emIter;
int assoIter;
double emThres;
double assoThres;
double hybridThres;
int doPriming;
void run(funkyPars *pars);
void print(funkyPars *pars);
void clean(funkyPars *pars);
void getOptions(argStruct *arguments);
void printArg(FILE *argFile);
abcAsso(const char *outfiles,argStruct *arguments,int inputtype);
~abcAsso();
//other stuff
char *covfile;
char *yfile1;
char *yfile2;
char *yfile3;
angsd::Matrix<double> ymat;
angsd::Matrix<double> covmat;
void check_pars(angsd::Matrix<double> &cov, angsd::Matrix<double> &phe, int isBinary);
void scoreAsso(funkyPars *pars,assoStruct *assoc);
double standardError(double* start, angsd::Matrix<double> *design, angsd::Matrix<double> *postAll, double *y, double *post, int isBinary, int isCount, int *keepList, int nInd);
double dosageAssoc(funkyPars *p,angsd::Matrix<double> *design,angsd::Matrix<double> *designNull,double *postOrg,double *yOrg,int keepInd,int *keepList,double freq,int s,assoStruct *assoc,int model, int isBinary, int isCount, double* start, int fullModel);
void dosageAsso(funkyPars *pars,assoStruct *assoc);
int getFitWLS(double* start, double* y, double** covMatrix, double* weights, int nInd3, int nEnv, int df);
int getFitWLSBin(double* start, double* y, double** covMatrix, double* weights, int nInd3, int nEnv, int df);
int getFitWLSPois(double* start, double* y, double** covMatrix, double* weights, int nInd3, int nEnv, int df);
double logLike(double *start,double* y,angsd::Matrix<double> *design,double *post,int isBinary, int isCount, int fullModel);
double logupdateEM(double* start,angsd::Matrix<double> *design,angsd::Matrix<double> *postAll,double* y,int keepInd,double* post,int isBinary, int isCount, int fullModel, int iter);
double sd(double* phe, int size );
double doEMasso(funkyPars *p,angsd::Matrix<double> *design,angsd::Matrix<double> *designNull,angsd::Matrix<double> *postAll,double *postOrg,double *yOrg,int keepInd,int *keepList,double freq,int s,assoStruct *assoc,int model, int isBinary, int isCount, double* start, int fullModel);
void emAsso(funkyPars *pars,assoStruct *assoc);
double doEMassoWald(funkyPars *p,angsd::Matrix<double> *design,angsd::Matrix<double> *postAll,double *postOrg,double *yOrg,int keepInd,int *keepList,double freq,int s,assoStruct *assoc,int model, int isBinary, int isCount, double* start, int fullModel);
void emAssoWald(funkyPars *pars,assoStruct *assoc);
void hybridAsso(funkyPars *pars,assoStruct *assoc);
void frequencyAsso(funkyPars *pars,assoStruct *assoc);
double doAssociation(funkyPars *pars,double *post,double *y,int keepInd,int *keepList,double freq,int s,assoStruct *assoc);
int getFit(double *res,double *Y,double *covMatrix,int nInd,int nEnv, double *start);
int getFitBin(double *res,double *Y,double *covMatrix,int nInd,int nEnv, double *start);
int getFitPois(double *res,double *Y,double *covMatrix,int nInd,int nEnv, double *start);
double normScoreEnv(double *post,int numInds, double *y, double *ytilde,double *cov,int nEnv,double freq,assoStruct *assoc,int s);
double binomScoreEnv(double *post,int numInds, double *y, double *ytilde,double *cov,int nEnv,double freq,assoStruct *assoc,int s);
double poisScoreEnv(double *post,int numInds, double *y, double *ytilde,double *cov,int nEnv,double freq,assoStruct *assoc,int s);
void printDoAsso(funkyPars *pars);
};