001/* 002 * BioJava development code 003 * 004 * This code may be freely distributed and modified under the 005 * terms of the GNU Lesser General Public Licence. This should 006 * be distributed with the code. If you do not have a copy, 007 * see: 008 * 009 * http://www.gnu.org/copyleft/lesser.html 010 * 011 * Copyright for this code is held jointly by the individual 012 * authors. These should be listed in @author doc comments. 013 * 014 * For more information on the BioJava project and its aims, 015 * or to join the biojava-l mailing list, visit the home page 016 * at: 017 * 018 * http://www.biojava.org/ 019 * 020 */ 021package org.biojava.nbio.structure.symmetry.misc; 022 023import org.biojava.nbio.structure.symmetry.utils.BlastClustReader; 024 025import java.util.*; 026import java.util.Map.Entry; 027 028public class ProteinComplexSignature { 029 private BlastClustReader blastClust = null; 030 private String pdbId = ""; 031 private List<String> chainIds = null; 032 private List<ChainSignature> chainSignatures = new ArrayList<>(); 033 034 035 public ProteinComplexSignature(String pdbId, List<String> chainIds, BlastClustReader blastClust) { 036 this.pdbId = pdbId; 037 this.chainIds = chainIds; 038 this.blastClust = blastClust; 039 040 getChainSignatures(); 041 } 042 043 public String getComplexSignature() { 044 StringBuilder builder = new StringBuilder(); 045 for (ChainSignature s: chainSignatures) { 046 builder.append(s.toString()); 047 } 048 return builder.toString(); 049 } 050 051 public String getCompositionId(String chainId) { 052 for (ChainSignature s: chainSignatures) { 053 if (s.getChainIds().contains(chainId)) { 054 return s.getCompositionId(); 055 } 056 } 057 return ""; 058 } 059 060 public String getComplexStoichiometry() { 061 StringBuilder s = new StringBuilder(); 062 for (ChainSignature c: chainSignatures) { 063 s.append(c.getCompositionId()); 064 if (c.getChainIds().size() >1) { 065 s.append(c.getChainIds().size()); 066 } 067 } 068 return s.toString(); 069 } 070 071 public int getSubunitTypeCount() { 072 return chainSignatures.size(); 073 } 074 075 private List<ChainSignature> getChainSignatures() { 076 String alpha = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; 077 078 Map<String,Integer> mapCounts = new TreeMap<>(); 079 Map<String,List<String>> mapChainIds = new TreeMap<>(); 080 081 for (String chainId: chainIds) { 082 String rep = blastClust.getRepresentativeChain(pdbId, chainId); 083 Integer value = mapCounts.get(rep); 084 if (value == null) { 085 mapCounts.put(rep, 1); 086 List<String> list = new ArrayList<>(); 087 list.add(chainId); 088 mapChainIds.put(rep, list); 089 } else { 090 value+=1; 091 mapCounts.put(rep, value); 092 List<String> list = mapChainIds.get(rep); 093 list.add(chainId); 094 } 095 } 096 097 098 for (Entry<String, Integer> entry: mapCounts.entrySet()) { 099 List<String> chainIds = mapChainIds.get(entry.getKey()); 100 ChainSignature chainSignature = new ChainSignature(entry.getKey(), entry.getValue(), chainIds); 101 chainSignatures.add(chainSignature); 102 } 103 104 Collections.sort(chainSignatures); 105 for (int i = 0; i < chainSignatures.size(); i++) { 106 ChainSignature c = chainSignatures.get(i); 107 if (i < alpha.length()) { 108 c.setCompositionId(alpha.substring(i,i+1)); 109 } else { 110 c.setCompositionId("?"); 111 } 112 } 113 114 return chainSignatures; 115 } 116 117}