X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fschemes%2FResidueProperties.java;h=7ec9e1c15c10a28b18e3e22e9f8c323c55a99bf3;hb=7ab5d6b0ba5fec1ea4a4239e79c476d841622485;hp=1780a4acf50bcdbac7b3e09768eeb69aed95a065;hpb=1889827c44c51f6353fe8619e5d44b421158af23;p=jalview.git diff --git a/src/jalview/schemes/ResidueProperties.java b/src/jalview/schemes/ResidueProperties.java index 1780a4a..7ec9e1c 100755 --- a/src/jalview/schemes/ResidueProperties.java +++ b/src/jalview/schemes/ResidueProperties.java @@ -29,7 +29,7 @@ import java.awt.*; public class ResidueProperties { - public static Hashtable scoreMatrices = new Hashtable(); + public static Hashtable scoreMatrices = new Hashtable(); // Stores residue codes/names and colours and other things public static final int[] aaIndex; // aaHash version 2.1.1 and below @@ -697,19 +697,20 @@ public class ResidueProperties } /** - * Nucleotide Ambiguity Codes + * Nucleotide Ambiguity Codes */ - public static final Hashtable ambiguityCodes=new Hashtable(); + public static final Hashtable ambiguityCodes = new Hashtable(); + /** - * Codon triplets with additional symbols for unambiguous codons that include ambiguity codes + * Codon triplets with additional symbols for unambiguous codons that include + * ambiguity codes */ - public static final Hashtable codonHash2 = new Hashtable(); - + public static final Hashtable codonHash2 = new Hashtable(); + /** * all ambiguity codes for a given base */ - public final static Hashtable> _ambiguityCodes = new Hashtable>(); - + public final static Hashtable> _ambiguityCodes = new Hashtable>(); static { @@ -894,10 +895,10 @@ public class ResidueProperties codonHash2.put("TTC", "F"); codonHash2.put("TTT", "F"); - + buildAmbiguityCodonSet(); } - + /** * programmatic generation of codons including ambiguity codes */ @@ -933,7 +934,8 @@ public class ResidueProperties } // and programmatically add in the ambiguity codes that yield the same amino // acid - String[] unambcodons = codonHash2.keySet().toArray(new String[codonHash2.size()]); + String[] unambcodons = codonHash2.keySet().toArray( + new String[codonHash2.size()]); for (String codon : unambcodons) { String residue = codonHash2.get(codon); @@ -968,7 +970,7 @@ public class ResidueProperties char _anuc; for (ipos = 0; ipos < tpos.length; ipos++) { - if (acodon[ipos].length==0 || tpos[ipos] < 0) + if (acodon[ipos].length == 0 || tpos[ipos] < 0) { _acodon += codon.charAt(ipos); allres[ipos] = new char[] @@ -1000,7 +1002,7 @@ public class ResidueProperties _codon += allres[j][cpos[j]]; } String tr = codonHash2.get(_codon); - if (valid = (tr!=null && tr.equals(residue))) + if (valid = (tr != null && tr.equals(residue))) { // advance to next combination ipos = acodon.length - 1; @@ -1014,14 +1016,14 @@ public class ResidueProperties if (valid) { // Add this to the set of codons we will translate -// System.out.println("Adding ambiguity codon: " + _acodon + " for " -// + residue); + // System.out.println("Adding ambiguity codon: " + _acodon + " for " + // + residue); codonHash2.put(_acodon, residue); } else { -// System.err.println("Rejecting ambiguity codon: " + _acodon -// + " for " + residue); + // System.err.println("Rejecting ambiguity codon: " + _acodon + // + " for " + residue); } // next combination ipos = acodon.length - 1; @@ -1422,62 +1424,75 @@ public class ResidueProperties } static { - int[][] propMatrixF = new int[maxProteinIndex][maxProteinIndex], - propMatrixPos = new int[maxProteinIndex][maxProteinIndex], - propMatrixEpos = new int[maxProteinIndex][maxProteinIndex]; - for (int i=0;ii) { - ic+=aa[i]; + int maxF = 0, maxP = 0, maxEP = 0; + String ic = ""; + if (aa.length > i) + { + ic += aa[i]; } - else {ic = "-";} - for (int j=i+1;jj) { - jc+=aa[j]; + ic = "-"; + } + for (int j = i + 1; j < maxProteinIndex; j++) + { + String jc = ""; + if (aa.length > j) + { + jc += aa[j]; } - else {jc = "-";} - propMatrixF[i][j]=0; - propMatrixPos[i][j]=0; - propMatrixEpos[i][j]=0; - for (Enumeration en= (Enumeration)propHash.keys(); en.hasMoreElements(); ) + else + { + jc = "-"; + } + propMatrixF[i][j] = 0; + propMatrixPos[i][j] = 0; + propMatrixEpos[i][j] = 0; + for (Enumeration en = (Enumeration) propHash.keys(); en + .hasMoreElements();) { String ph = en.nextElement(); - Map pph=(Map)propHash.get(ph); - if (pph.get(ic)!=null && pph.get(jc)!=null) { - int icp=pph.get(ic).intValue(),jcp=pph.get(jc).intValue(); + Map pph = (Map) propHash + .get(ph); + if (pph.get(ic) != null && pph.get(jc) != null) + { + int icp = pph.get(ic).intValue(), jcp = pph.get(jc).intValue(); // Still working on these definitions. - propMatrixPos[i][j] += icp == jcp && icp>0 ? 2 : 0; - propMatrixPos[j][i] += icp == jcp && icp>0 ? 2 : 0; + propMatrixPos[i][j] += icp == jcp && icp > 0 ? 2 : 0; + propMatrixPos[j][i] += icp == jcp && icp > 0 ? 2 : 0; propMatrixF[i][j] += icp == jcp ? 2 : 0; propMatrixF[j][i] += icp == jcp ? 2 : 0; - propMatrixEpos[i][j] += icp == jcp ? (1+icp * 2) : 0; - propMatrixEpos[j][i] += icp == jcp ? (1+icp * 2) : 0; - }} - if (maxF(); + toRNAssState = new Hashtable(); toRNAssState.put(")", "("); toRNAssState.put("(", "("); toRNAssState.put("]", "["); @@ -1742,7 +1759,7 @@ public class ResidueProperties toRNAssState.put("y", "Y"); toRNAssState.put("Z", "Z"); toRNAssState.put("z", "Z"); - + } /**