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 * Created on 10-18-2010 021 * 022 * @author Andy Yates 023 */ 024package org.biojava.nbio.core.sequence.views; 025 026import org.biojava.nbio.core.exceptions.CompoundNotFoundException; 027import org.biojava.nbio.core.sequence.compound.NucleotideCompound; 028import org.biojava.nbio.core.sequence.compound.RNACompoundSet; 029import org.biojava.nbio.core.sequence.template.*; 030 031import java.util.HashMap; 032import java.util.Map; 033 034/** 035 * Attempts to do on the fly translation of RNA by not requesting the compounds 036 * until asked. 037 * 038 * @author ayates 039 */ 040public class RnaSequenceView extends SequenceProxyView<NucleotideCompound> implements ProxySequenceReader<NucleotideCompound> { 041 042 private CompoundSet<NucleotideCompound> rnaCompounds; 043 private Map<NucleotideCompound, NucleotideCompound> dnaToRna = null; 044 private Map<NucleotideCompound, NucleotideCompound> rnaToDna = null; 045 046 public RnaSequenceView(Sequence<NucleotideCompound> sourceDna) { 047 this(sourceDna, RNACompoundSet.getRNACompoundSet()); 048 } 049 050 public RnaSequenceView(Sequence<NucleotideCompound> sourceDna, 051 CompoundSet<NucleotideCompound> rnaCompounds) { 052 super(sourceDna); 053 this.rnaCompounds = rnaCompounds; 054 } 055 056 @Override 057 public String getSequenceAsString() { 058 return SequenceMixin.toString(this); 059 } 060 061 @Override 062 public NucleotideCompound getCompoundAt(int position) { 063 NucleotideCompound dna = getViewedSequence().getCompoundAt(position); 064 return getDnaToRna().get(dna); 065 } 066 067 @Override 068 public int getIndexOf(NucleotideCompound compound) { 069 return getViewedSequence().getIndexOf(getRnaToDna().get(compound)); 070 } 071 072 @Override 073 public int getLastIndexOf(NucleotideCompound compound) { 074 return getViewedSequence().getLastIndexOf(getRnaToDna().get(compound)); 075 } 076 077 public Map<NucleotideCompound, NucleotideCompound> getRnaToDna() { 078 if(rnaToDna == null) { 079 buildTranslators(); 080 } 081 return rnaToDna; 082 } 083 084 public Map<NucleotideCompound, NucleotideCompound> getDnaToRna() { 085 if(dnaToRna == null) { 086 buildTranslators(); 087 } 088 return dnaToRna; 089 } 090 091 protected void buildTranslators() { 092 Map<NucleotideCompound, NucleotideCompound> localDnaToRna = 093 new HashMap<>(); 094 Map<NucleotideCompound, NucleotideCompound> localRnaToDna = 095 new HashMap<>(); 096 097 NucleotideCompound thymine = 098 getViewedSequence().getCompoundSet().getCompoundForString("T"); 099 NucleotideCompound lowerThymine = 100 getViewedSequence().getCompoundSet().getCompoundForString("t"); 101 102 for (NucleotideCompound dnaBase : getViewedSequence().getCompoundSet().getAllCompounds()) { 103 NucleotideCompound equivalent; 104 if (dnaBase.equals(thymine)) { 105 equivalent = rnaCompounds.getCompoundForString("U"); 106 } 107 else if (dnaBase.equals(lowerThymine)) { 108 equivalent = rnaCompounds.getCompoundForString("u"); 109 } 110 else { 111 equivalent = rnaCompounds.getCompoundForString( 112 dnaBase.toString()); 113 } 114 localDnaToRna.put(dnaBase, equivalent); 115 localRnaToDna.put(equivalent, dnaBase); 116 } 117 this.dnaToRna = localDnaToRna; 118 this.rnaToDna = localRnaToDna; 119 } 120 121 @Override 122 public void setCompoundSet(CompoundSet<NucleotideCompound> compoundSet) { 123 throw new UnsupportedOperationException("Unsupported operation; create a new viewed sequence"); 124 } 125 126 @Override 127 public void setContents(String sequence) throws CompoundNotFoundException { 128 throw new UnsupportedOperationException("Unsupported operation; create a new viewed sequence"); 129 } 130}