X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=test%2Fjalview%2Fanalysis%2Fscoremodels%2FScoreMatrixTest.java;h=90a718ac6eb651b971414bc3f6ee61e27b488eaa;hb=47f194aa2e9d43169ee06d61a697e1355d292b87;hp=1a5d43c98f91459a5effca9382d25029f9d2716f;hpb=e5c87d2dd1d3ebceea890ef92c8a6374c62d3c83;p=jalview.git diff --git a/test/jalview/analysis/scoremodels/ScoreMatrixTest.java b/test/jalview/analysis/scoremodels/ScoreMatrixTest.java index 1a5d43c..90a718a 100644 --- a/test/jalview/analysis/scoremodels/ScoreMatrixTest.java +++ b/test/jalview/analysis/scoremodels/ScoreMatrixTest.java @@ -13,6 +13,7 @@ import jalview.api.analysis.SimilarityParamsI; import jalview.io.DataSourceType; import jalview.io.FileParse; import jalview.io.ScoreMatrixFile; +import jalview.math.Matrix; import jalview.math.MatrixI; import jalview.schemes.ResidueProperties; @@ -22,6 +23,8 @@ import java.util.Arrays; import org.testng.annotations.Test; +import junit.extensions.PA; + public class ScoreMatrixTest { @Test(groups = "Functional") @@ -33,6 +36,7 @@ public class ScoreMatrixTest scores[1] = new float[] { -4f, 5f, 6f }; scores[2] = new float[] { 7f, 8f, 9f }; ScoreMatrix sm = new ScoreMatrix("Test", "ABC".toCharArray(), scores); + assertFalse(sm.isSymmetric()); assertEquals(sm.getSize(), 3); assertArrayEquals(scores, sm.getMatrix()); assertEquals(sm.getPairwiseScore('A', 'a'), 1f); @@ -395,6 +399,12 @@ public class ScoreMatrixTest verifySymmetric(ScoreModels.getInstance().getDefaultModel(false)); // dna } + /** + * A helper method that inspects a loaded matrix and reports any asymmetry as + * a test failure + * + * @param sm + */ private void verifySymmetric(ScoreMatrix sm) { float[][] m = sm.getMatrix(); @@ -585,4 +595,77 @@ public class ScoreMatrixTest + ""; assertEquals(html, expected); } + + @Test(groups = "Functional") + public void testIsSymmetric() + { + float[][] scores = new float[][] { { 1f, -2f }, { -2f, 3f } }; + ScoreMatrix sm = new ScoreMatrix("Test", "AB".toCharArray(), scores); + assertTrue(sm.isSymmetric()); + + /* + * verify that with a symmetric score matrix, + * pairwise similarity matrix is also symmetric + * seq1.seq1 = 5*A.A + 3*B.B = 5+9 = 14 + * seq1.seq2 = 3*A.A + 2*A.B + B.A + 2*B.B = 3 + -4 + -2 + 6 = 3 + * seq2.seq1 = 3*A.A + A.B + 2*B.A + 2*B.B = 3 + -2 + -4 + 6 = 3 + * seq2.seq2 = 4*A.A + 4*B.B = 4 + 12 = 16 + */ + SimilarityParamsI params = new SimilarityParams(true, true, true, + false); + String seq1 = "AAABBBAA"; + String seq2 = "AABBABBA"; + String[] seqs1 = new String[] { seq1, seq2 }; + MatrixI res1 = sm.findSimilarities(seqs1, params); + assertEquals(res1, + new Matrix(new double[][] + { { 14d, 3d }, { 3d, 16d } })); + + /* + * order of sequences affects diagonal, but not off-diagonal values + * [0, 0] is now seq2.seq2, [1, 1] is seq1.seq1 + * [0, 1] is now seq2.seq1 = seq1.seq2 by symmetry + */ + String[] seqs2 = new String[] { seq2, seq1 }; + MatrixI res2 = sm.findSimilarities(seqs2, params); + assertFalse(res1.equals(res2)); + assertEquals(res2, + new Matrix(new double[][] + { { 16d, 3d }, { 3d, 14d } })); + + /* + * now make the score matrix asymmetric + * seq1.seq1 = 5*A.A + 3*B.B = 5+9 = 14 + * seq1.seq2 = 3*A.A + 2*A.B + B.A + 2*B.B = 3 + -4 + 2 + 6 = 7 + * seq2.seq1 = 3*A.A + A.B + 2*B.A + 2*B.B = 3 + -2 + 4 + 6 = 11 + * seq2.seq2 = 4*A.A + 4*B.B = 4 + 12 = 16 + */ + scores = new float[][] { { 1f, -2f }, { 2f, 3f } }; + sm = new ScoreMatrix("Test", "AB".toCharArray(), scores); + assertFalse(sm.isSymmetric()); // [0, 1] != [1, 0] + res1 = sm.findSimilarities(seqs1, params); + assertEquals(res1, + new Matrix(new double[][] + { { 14d, 7d }, { 11d, 16d } })); + + /* + * reverse order of sequences + * - reverses order of main diagonal + * - reflects off-diagonal values + */ + res2 = sm.findSimilarities(seqs2, params); + assertFalse(res1.equals(res2)); + assertEquals(res2, + new Matrix(new double[][] + { { 16d, 11d }, { 7d, 14d } })); + + /* + * verify that forcing an asymmetric matrix to use + * symmetric calculation gives a different (wrong) result + */ + PA.setValue(sm, "symmetric", true); + assertTrue(sm.isSymmetric()); // it's not true! + res2 = sm.findSimilarities(seqs1, params); + assertFalse(res1.equals(res2)); + } }