-
Notifications
You must be signed in to change notification settings - Fork 2
/
make-otus.sh
executable file
·49 lines (44 loc) · 1 KB
/
make-otus.sh
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
#!/bin/bash
if [ -z "$3" ]; then
echo "syntax: $( basename $0 ) <alignedseqs.sto> <mergefile.sl> <threshold>";
exit -1;
fi
awk -v "joinfile=$2" -v "seqfile=$1" -v "thres=$3" '
BEGIN {
seqcount=0;
fasta=0;
while (getline<seqfile > 0){
if (/^(#|$)/) continue;
if (substr($0,1,1)==">") fasta=1;
if (fasta==1 && /^>/){
$1=substr($1,2);
seqs[seqcount++]=$1;
}else if (fasta==0)
seqs[seqcount++]=$1;
}
}
/^(#|$)/ { next; }
$2 >= thres {
seqs[$3]=seqs[$3] SUBSEP seqs[$4];
delete seqs[$4];
next;
}
END {
print "# date: " strftime();
print "# fasta: " (fasta==1?"yes":"no");
print "# merge file: " joinfile;
print "# sequences file: " seqfile;
print "# threshold: " thres;
print "# seqcount: " seqcount;
otucount=0;
for (i=0; i<seqcount; ++i) {
if (i in seqs) {
split(seqs[i],a,SUBSEP);
otusize=length(a);
print ">OTU" otucount "\tsize=" otusize;
for (j=1; j<=length(a); ++j)
print a[j];
++otucount;
}
}
}' $2