- public static float compare(SequenceI ii, SequenceI jj, int start, int end) {\r
-\r
- String si = ii.getSequence();\r
- String sj = jj.getSequence();\r
-\r
- int ilen = end-start+1;\r
- int jlen = end-start+1;\r
-\r
- if ( si.substring(start + ilen).equals("-") ||\r
- si.substring(start + ilen).equals(".") ||\r
- si.substring(start + ilen).equals(" ")) {\r
-\r
- ilen--;\r
-\r
- while (si.substring(start + ilen,start + ilen+1).equals("-") ||\r
- si.substring(start + ilen,start + ilen+1).equals(".") ||\r
- si.substring(start + ilen,start + ilen+1).equals(" ")) {\r
- ilen--;\r
- }\r
- }\r
-\r
- if ( sj.substring(start + jlen).equals("-") ||\r
- sj.substring(start + jlen).equals(".") ||\r
- sj.substring(start + jlen).equals(" ")) {\r
- jlen--;\r
-\r
- while (sj.substring(start + jlen,start + jlen+1).equals("-") ||\r
- sj.substring(start + jlen,start + jlen+1).equals(".") ||\r
- sj.substring(start + jlen,start + jlen+1).equals(" ")) {\r
- jlen--;\r
- }\r
- }\r
-\r
- int count = 0;\r
- int match = 0;\r
- float pid = -1;\r
-\r
- if (ilen > jlen) {\r
-\r
- for (int j = 0; j < jlen; j++) {\r
- if (si.substring(start + j,start + j+1).equals(sj.substring(start + j,start + j+1))) {\r
- match++;\r
- }\r
- count++;\r
- }\r
- pid = (float)match/(float)ilen * 100;\r
- } else {\r
- for (int j = 0; j < jlen; j++) {\r
- if (si.substring(start + j,start + j+1).equals(sj.substring(start + j,start + j+1))) {\r
- match++;\r
- }\r
- count++;\r
- }\r
- pid = (float)match/(float)jlen * 100;\r
- }\r
+\r
+ /**\r
+ * this was supposed to be an ungapped pid calculation\r
+ * @param ii SequenceI\r
+ * @param jj SequenceI\r
+ * @param start int\r
+ * @param end int\r
+ * @return float\r
+ */\r
+ public static float compare(SequenceI ii, SequenceI jj, int start, int end)\r
+ {\r
+ String si = ii.getSequence();\r
+ String sj = jj.getSequence();\r
+\r
+ int ilen = si.length() - 1;\r
+ int jlen = sj.length() - 1;\r
+\r
+ while (jalview.util.Comparison.isGap(si.charAt(start + ilen)))\r
+ {\r
+ ilen--;\r
+ }\r
+\r
+ while (jalview.util.Comparison.isGap(sj.charAt(start + jlen)))\r
+ {\r
+ jlen--;\r
+ }\r
+\r
+ int count = 0;\r
+ int match = 0;\r
+ float pid = -1;\r
+\r
+ if (ilen > jlen)\r
+ {\r
+ for (int j = 0; j < jlen; j++)\r
+ {\r
+ if (si.substring(start + j, start + j + 1).equals(sj.substring(start +\r
+ j, start + j + 1)))\r
+ {\r
+ match++;\r
+ }\r
+\r
+ count++;\r
+ }\r
+\r
+ pid = (float) match / (float) ilen * 100;\r
+ }\r
+ else\r
+ {\r
+ for (int j = 0; j < jlen; j++)\r
+ {\r
+ if (si.substring(start + j, start + j + 1).equals(sj.substring(start +\r
+ j, start + j + 1)))\r
+ {\r
+ match++;\r
+ }\r
+\r
+ count++;\r
+ }\r
+\r
+ pid = (float) match / (float) jlen * 100;\r
+ }\r