forked from ANGSD/angsd
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathabcFilter.cpp
164 lines (143 loc) · 4.87 KB
/
abcFilter.cpp
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
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
/*
Thorfinn 31oct 2014
refactored version of old code.
indexing and reading of binary representation is now in prep_sites.cpp
Code can be optimized by skipping rest of filereading for remainer of chr
osome if we have reached the last position from the keep list.
Maybe there are some memleaks. This will have to be fixed later.
*/
#include <cassert>
#include <sys/stat.h>
#include "shared.h"
#include "abc.h"
#include "analysisFunction.h"
#include "abcFilter.h"
abcFilter::~abcFilter(){
if(fl!=NULL){
filt_dalloc(fl);
}
free(fname);
}
abcFilter::abcFilter(argStruct *arguments){
//below if shared for all analysis classes
strict =1;
shouldRun[index] = 1;
header = arguments->hd;
revMap = arguments->revMap;
setMinIndDepth=1;
fl = NULL;
//his is used by this class
keepsChr = NULL;
curChr = -1;
fp = NULL;
minInd = 0;
fname = NULL;
doMajorMinor =0;
capDepth = -1;
if(arguments->argc==2){
if(!strcasecmp(arguments->argv[1],"-sites")){
printArg(stdout);
exit(0);
}else
return;
}
//get options and print them
getOptions(arguments);
printArg(arguments->argumentFile);
}
void abcFilter::printArg(FILE *argFile){
fprintf(argFile,"--------------\n%s:\n",__FILE__);
fprintf(argFile,"\t-sites\t\t%s\t(File containing sites to keep (chr pos))\n",fname);
fprintf(argFile,"\t-sites\t\t%s\t(File containing sites to keep (chr regStart regStop))\n",fname);
fprintf(argFile,"\t-sites\t\t%s\t(File containing sites to keep (chr pos major minor))\n",fname);
fprintf(argFile,"\t-sites\t\t%s\t(File containing sites to keep (chr pos major minor af ac an))\n",fname);
fprintf(argFile,"\t-minInd\t\t%d\tOnly use site if atleast minInd of samples has data\n",minInd);
fprintf(argFile,"\t-setMinDepthInd\t%d\tOnly use site if atleast minInd of samples has this minimum depth \n",setMinIndDepth);
fprintf(argFile,"\t-capDepth\t%d\tOnly use the first capDepth bases\n",capDepth);
fprintf(argFile,"\t-strict\t%d\t (experimental)\n",strict);
fprintf(argFile,"\t1) You can force major/minor by -doMajorMinor 3\n\tAnd make sure file contains 4 columns (chr tab pos tab major tab minor)\n");
}
void abcFilter::getOptions(argStruct *arguments){
fname=angsd::getArg("-sites",fname,arguments);
if(fname!=NULL)
fl = filt_read(fname);
if(fl!=NULL)
fprintf(stderr,"\t-> [%s] -sites is still beta, use at own risk...\n",__FILE__);
//1=bim 2=keep
doMajorMinor = angsd::getArg("-doMajorMinor",doMajorMinor,arguments);
if(doMajorMinor==3 && fl!=NULL&& fl->hasExtra!=1){
fprintf(stderr,"\t-> Must supply -sites with a file containing major and minor if -doMajorMinor 3\n");
}
if(doMajorMinor!=3 && fl!=NULL&& fl->hasExtra==1){
fprintf(stderr,"\t-> Filter file contains major/minor information to use these in analysis supper \'-doMajorMinor 3\'\n");
}
capDepth = angsd::getArg("-capDepth",capDepth,arguments);
minInd = angsd::getArg("-minInd",minInd,arguments);
setMinIndDepth = angsd::getArg("-setMinDepthInd",setMinIndDepth,arguments);
strict = angsd::getArg("-strict",strict,arguments);
if(minInd >arguments->nInd){
fprintf(stderr,"\t-> Potential problem you filter -minInd %d but you only have %d samples?\n",minInd,arguments->nInd);
exit(0);
}
}
void abcFilter::run(funkyPars *p){
//if we are comping form BAM/CRAM then we dont need to set the below
if(p->keepSites==NULL){
p->keepSites=new int[p->numSites];
for(int s=0;s<p->numSites;s++)
p->keepSites[s]=p->nInd;
}
if(capDepth!=-1){
for(int s=0;s<p->numSites;s++)
for(int i=0;i<p->nInd;i++)
if(p->chk->nd[s][i]&&p->chk->nd[s][i]->l>capDepth)
p->chk->nd[s][i]->l=capDepth;
}
if(fl!=NULL) {
if(fl->keeps==NULL){
for(int s=0;s<p->numSites;s++)
p->keepSites[s] =0;
}else{
for(int s=0;s<p->numSites;s++){
// fprintf(stderr,"p->posi:%d keeppre:%d\n",p->posi[s]+1,p->keepSites[s]);
if(strict&&fl->keeps[p->posi[s]]==0){
// fprintf(stderr,"never here\n");
p->keepSites[s] =0;
}
//fprintf(stderr,"p->posi:%d keeppost:%d\n",p->posi[s]+1,p->keepSites[s]);
}
}
}
//how set the keepsites according the effective sample size persite
//if(0!=minInd){
if(p->chk!=NULL){
//loop over sites;
for(int s=0;s<p->numSites;s++){
if(p->keepSites[s]==0)
continue;
int nInfo =0;
tNode **tn = p->chk->nd[s];
//loop over samples;
for(int i=0;i<p->nInd;i++){
if(tn[i]&&tn[i]->l>=setMinIndDepth)
nInfo++;
}
p->keepSites[s] =nInfo;
if(0!=minInd){
if(minInd>nInfo)
p->keepSites[s] =0;
}
// fprintf(stderr,"p->posi:%d keeppost2:%d\n",p->posi[s]+1,p->keepSites[s]);
}
}
}
void abcFilter::print(funkyPars *p){
}
void abcFilter::clean(funkyPars *p){
}
void abcFilter::readSites(int refId) {
//fprintf(stderr,"[%s].%s():%d -> refId:%d\n",__FILE__,__FUNCTION__,__LINE__,refId);
if(fl==NULL)
return;
filt_readSites(fl,header->target_name[refId],header->target_len[refId]);
}