JAL-2403 public static methods to convert distance/similarity matrices
authorgmungoc <g.m.carstairs@dundee.ac.uk>
Wed, 12 Apr 2017 13:41:45 +0000 (14:41 +0100)
committergmungoc <g.m.carstairs@dundee.ac.uk>
Wed, 12 Apr 2017 13:41:45 +0000 (14:41 +0100)
src/jalview/analysis/scoremodels/DistanceScoreModel.java
src/jalview/analysis/scoremodels/SimilarityScoreModel.java

index 14c9667..0dd7617 100644 (file)
@@ -15,14 +15,26 @@ public abstract class DistanceScoreModel implements ScoreModelI
   public MatrixI findSimilarities(AlignmentView seqData,
           SimilarityParamsI options)
   {
-    MatrixI result = findDistances(seqData, options);
+    MatrixI distances = findDistances(seqData, options);
 
-    /*
-     * reverse the range of score values so that 
-     * max becomes min and vice versa
-     */
-    result.reverseRange(false);
+    MatrixI similarities = distanceToSimilarity(distances);
 
-    return result;
+    return similarities;
+  }
+
+  /**
+   * Converts distance scores to similarity scores, by reversing the range of
+   * score values so that max becomes min and vice versa. The input matrix is
+   * not modified.
+   * 
+   * @param distances
+   */
+  public static MatrixI distanceToSimilarity(MatrixI distances)
+  {
+    MatrixI similarities = distances.copy();
+
+    similarities.reverseRange(false);
+
+    return similarities;
   }
 }
index d41e0ba..dae1f62 100644 (file)
@@ -17,14 +17,27 @@ public abstract class SimilarityScoreModel implements ScoreModelI
   public MatrixI findDistances(AlignmentView seqData,
           SimilarityParamsI options)
   {
-    MatrixI result = findSimilarities(seqData, options);
+    MatrixI similarities = findSimilarities(seqData, options);
 
-    /*
-     * reverse the range of the scores mapping the maximum to zero
-     */
-    result.reverseRange(true);
+    MatrixI distances = similarityToDistance(similarities);
 
-    return result;
+    return distances;
+  }
+
+  /**
+   * Converts a matrix of similarity scores to distance scores, by reversing the
+   * range of the scores, mapping the maximum to zero. The input matrix is not
+   * modified.
+   * 
+   * @param similarities
+   */
+  public static MatrixI similarityToDistance(MatrixI similarities)
+  {
+    MatrixI distances = similarities.copy();
+
+    distances.reverseRange(true);
+
+    return distances;
   }
 
 }