X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fws%2Fdatamodel%2Falphafold%2FPAEContactMatrix.java;h=cefdbd21b7a68edc6d24bcd9f2fa5d1d1ef3b9b5;hb=d42b7588a34477b24ce97ba75788536e74e6cf86;hp=79ad45807933f792fe2a681c7f3c10588e39ee51;hpb=c2dd443026847395d0c9dc824c6c90457de9a675;p=jalview.git diff --git a/src/jalview/ws/datamodel/alphafold/PAEContactMatrix.java b/src/jalview/ws/datamodel/alphafold/PAEContactMatrix.java index 79ad458..cefdbd2 100644 --- a/src/jalview/ws/datamodel/alphafold/PAEContactMatrix.java +++ b/src/jalview/ws/datamodel/alphafold/PAEContactMatrix.java @@ -29,16 +29,21 @@ public class PAEContactMatrix implements ContactMatrixI float maxscore; - @SuppressWarnings("unchecked") - public PAEContactMatrix(SequenceI _refSeq, Map pae_obj) + private void setRefSeq(SequenceI _refSeq) { refSeq = _refSeq; while (refSeq.getDatasetSequence() != null) { refSeq = refSeq.getDatasetSequence(); } - // convert the lists to primitive arrays and store length = _refSeq.getEnd() - _refSeq.getStart() + 1; + } + + @SuppressWarnings("unchecked") + public PAEContactMatrix(SequenceI _refSeq, Map pae_obj) + { + setRefSeq(_refSeq); + // convert the lists to primitive arrays and store if (!MapUtils.containsAKey(pae_obj, "predicted_aligned_error", "pae")) { @@ -52,26 +57,60 @@ public class PAEContactMatrix implements ContactMatrixI } /** + * construct a sequence associated PAE matrix directly from a float array + * + * @param _refSeq + * @param matrix + */ + public PAEContactMatrix(SequenceI _refSeq, float[][] matrix) + { + setRefSeq(_refSeq); + maxcol = 0; + for (float[] row : matrix) + { + if (row.length > maxcol) + { + maxcol = row.length; + } + maxscore = row[0]; + for (float f : row) + { + if (maxscore < f) + { + maxscore = f; + } + } + } + maxrow = matrix.length; + elements = matrix; + + } + + /** * parse a sane JSON representation of the pAE * * @param pae_obj */ + @SuppressWarnings("unchecked") private void parse_version_2_pAE(Map pae_obj) { - elements = new float[length][length]; // this is never going to be reached by the integer rounding.. or is it ? maxscore = ((Double) MapUtils.getFirst(pae_obj, "max_predicted_aligned_error", "max_pae")).floatValue(); - Iterator> scoreRows = ((List>) MapUtils - .getFirst(pae_obj, "predicted_aligned_error", "pae")) - .iterator(); + List> scoreRows = ((List>) MapUtils + .getFirst(pae_obj, "predicted_aligned_error", "pae")); + elements = new float[scoreRows.size()][scoreRows.size()]; int row = 0, col = 0; - while (scoreRows.hasNext()) + for (List scoreRow : scoreRows) { - Iterator scores = scoreRows.next().iterator(); + Iterator scores = scoreRow.iterator(); while (scores.hasNext()) { - elements[row][col++] = scores.next(); + Object d = scores.next(); + if (d instanceof Double) + elements[row][col++] = ((Double) d).longValue(); + else + elements[row][col++] = (float) ((Long) d).longValue(); } row++; col = 0; @@ -86,6 +125,7 @@ public class PAEContactMatrix implements ContactMatrixI * * @param pae_obj */ + @SuppressWarnings("unchecked") private void parse_version_1_pAE(Map pae_obj) { // assume indices are with respect to range defined by _refSeq on the @@ -94,7 +134,7 @@ public class PAEContactMatrix implements ContactMatrixI Iterator cols = ((List) pae_obj.get("residue2")).iterator(); Iterator scores = ((List) pae_obj.get("distance")) .iterator(); - + // assume square matrix elements = new float[length][length]; while (scores.hasNext()) { @@ -145,7 +185,6 @@ public class PAEContactMatrix implements ContactMatrixI { return -1; } - // TODO Auto-generated method stub return elements[_column][column]; } }); @@ -184,13 +223,29 @@ public class PAEContactMatrix implements ContactMatrixI @Override public String getAnnotLabel() { - return "pAE Matrix"; + StringBuilder label = new StringBuilder("pAE Matrix"); + // if (this.getReferenceSeq() != null) + // label.append(":").append(this.getReferenceSeq().getDisplayId(false)); + return label.toString(); } - public static final String PAEMATRIX="PAE_MATRIX"; + public static final String PAEMATRIX = "PAE_MATRIX"; + @Override public String getType() { return PAEMATRIX; } + + @Override + public int getWidth() + { + return length; + } + + @Override + public int getHeight() + { + return length; + } }