X-Git-Url: https://git.donarmstrong.com/?p=mothur.git;a=blobdiff_plain;f=onegapignore.h;h=fdbc196e9f2f7ff539a9b61bf35a8120483ac66b;hp=ee6cc5267931816a654c99f4e748d19bb2940901;hb=cf9987b67aa49777a4c91c2d21f96e58bf17aa82;hpb=b01e4c8527e66f227eff16cf296eeadf060306b6 diff --git a/onegapignore.h b/onegapignore.h index ee6cc52..fdbc196 100644 --- a/onegapignore.h +++ b/onegapignore.h @@ -9,6 +9,7 @@ * */ + #include "dist.h" /**************************************************************************************************/ @@ -16,6 +17,9 @@ class oneGapIgnoreTermGapDist : public Dist { public: + + oneGapIgnoreTermGapDist() {} + void calcDist(Sequence A, Sequence B){ int difference = 0; @@ -24,28 +28,33 @@ public: int minLength = 0; int start = 0; int end = 0; + bool overlap = false; - for(int i=0;i=0;i--){ - if(A.getAligned()[i] == '.' || B.getAligned()[i] == '.' || A.getAligned()[i] == '-' || B.getAligned()[i] == '-'){ - } - else{ + for(int i=alignLength-1;i>=0;i--){ + if(seqA[i] != '.' && seqB[i] != '.' && seqA[i] != '-' && seqB[i] != '-' ){ end = i; +// cout << "end: " << end << endl; + overlap = true; break; } } - for(int i=start;i<=end;i++){ - if(A.getAligned()[i] == '-' && B.getAligned()[i] == '-'){} - else if(A.getAligned()[i] == '-' && B.getAligned()[i] != '-'){ + if(seqA[i] == '-' && seqB[i] == '-'){ ; } + else if(seqB[i] != '-' && seqA[i] == '-'){ if(openGapA == 0){ difference++; minLength++; @@ -53,7 +62,7 @@ public: openGapB = 0; } } - else if(A.getAligned()[i] != '-' && B.getAligned()[i] == '-'){ + else if(seqA[i] != '-' && seqB[i] == '-'){ if(openGapB == 0){ difference++; minLength++; @@ -61,20 +70,19 @@ public: openGapB = 1; } } - else if(A.getAligned()[i] != '-' && B.getAligned()[i] != '-'){ - if(A.getAligned()[i] != B.getAligned()[i]){ + else if(seqA[i] != '-' && seqB[i] != '-'){ + if(seqA[i] != seqB[i]){ difference++; - minLength++; - openGapA = 0; - openGapB = 0; - } - else{ - minLength++; - openGapA = 0; - openGapB = 0; } + minLength++; + openGapA = 0; + openGapB = 0; } } + + //non-overlapping sequences + if (!overlap) { minLength = 0; } + if(minLength == 0) { dist = 1.0000; } else { dist = (double)difference / minLength; } }