Class AbstractSequence<C extends Compound>
- java.lang.Object
- 
- org.biojava.nbio.core.sequence.template.AbstractSequence<C>
 
- 
- Type Parameters:
- C-
 - All Implemented Interfaces:
- Iterable<C>,- Accessioned,- Sequence<C>
 - Direct Known Subclasses:
- BasicSequence,- DNASequence,- ProteinSequence,- RNASequence
 
 public abstract class AbstractSequence<C extends Compound> extends Object implements Sequence<C> The base class for DNA, RNA and Protein sequences.
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classAbstractSequence.AnnotationType
 - 
Constructor SummaryConstructors Constructor Description AbstractSequence()AbstractSequence(String seqString, CompoundSet<C> compoundSet)Create a Sequence from a simple string where the values should be found in compoundSetAbstractSequence(SequenceReader<C> proxyLoader, CompoundSet<C> compoundSet)A ProxySequenceReader allows abstraction of both the storage of the sequence data and the location of the sequence data.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddFeature(int bioStart, int bioEnd, FeatureInterface<AbstractSequence<C>,C> feature)Method to help set the proper details for a feature as it relates to a sequence where the feature needs to have a location on the sequencevoidaddFeature(FeatureInterface<AbstractSequence<C>,C> feature)Add a feature to this sequence.voidaddNote(String note)Add notes about this sequence that will get exported for GFF3intcountCompounds(C... compounds)Returns the number of times we found a compound in the Sequencebooleanequals(Object o)AccessionIDgetAccession()Returns the AccessionID this location is currently bound withAbstractSequence.AnnotationTypegetAnnotationType()List<C>getAsList()Returns the Sequence as a List of compoundsIntegergetBioBegin()IntegergetBioEnd()List<String>getComments()CgetCompoundAt(int position)Returns the Compound at the given biological indexCompoundSet<C>getCompoundSet()Gets the compound set used to back this SequenceDatabaseReferenceInterfacegetDatabaseReferences()StringgetDescription()FeatureRetrievergetFeatureRetriever()List<FeatureInterface<AbstractSequence<C>,C>>getFeatures()List<FeatureInterface<AbstractSequence<C>,C>>getFeatures(int bioSequencePosition)Return features at a sequence positionList<FeatureInterface<AbstractSequence<C>,C>>getFeatures(String featureType, int bioSequencePosition)Return features at a sequence position by typeList<FeatureInterface<AbstractSequence<C>,C>>getFeaturesByType(String type)FeaturesKeyWordInterfacegetFeaturesKeyWord()intgetIndexOf(C compound)Scans through the Sequence looking for the first occurrence of the given compoundSequenceView<C>getInverse()Does the right thing to get the inverse of the current Sequence.intgetLastIndexOf(C compound)Scans through the Sequence looking for the last occurrence of the given compoundintgetLength()Returns the length of the SequenceArrayList<String>getNotesList()StringgetOriginalHeader()AbstractSequence<?>getParentSequence()SequenceReader<C>getProxySequenceReader()List<AbstractReference>getReferences()StringgetSequenceAsString()Default case is to assume strand is positive because only CDSSequence can be either positive or negative Strand.StringgetSequenceAsString(Integer bioStart, Integer bioEnd, Strand strand)DoublegetSequenceScore()Provide place holder for a metric that indicate a score associated with the sequenceStringgetSource()Added support for the source of this sequence for GFF3 export If a sub sequence doesn't have source then check for parent sourceSequenceView<C>getSubSequence(Integer bioStart, Integer bioEnd)Returns a portion of the sequence from the different positions.TaxonomyIDgetTaxonomy()Collection<Object>getUserCollection()Provided for convince if the developer needs to associate data with a sequenceinthashCode()Iterator<C>iterator()voidremoveFeature(FeatureInterface<AbstractSequence<C>,C> feature)Remove a feature from the sequencevoidremoveNote(String note)voidsetAccession(AccessionID accession)voidsetAnnotationType(AbstractSequence.AnnotationType annotationType)voidsetBioBegin(Integer bioBegin)voidsetBioEnd(Integer bioEnd)voidsetComments(List<String> comments)Set comments.voidsetCompoundSet(CompoundSet<C> compoundSet)voidsetDatabaseReferences(DatabaseReferenceInterface databaseReferences)voidsetDescription(String description)voidsetFeatureRetriever(FeatureRetriever featureRetriever)voidsetFeaturesKeyWord(FeaturesKeyWordInterface featuresKeyWord)voidsetNotesList(ArrayList<String> notesList)voidsetOriginalHeader(String originalHeader)voidsetParentSequence(AbstractSequence<?> parentSequence)voidsetProxySequenceReader(SequenceReader<C> proxyLoader)Very important method that allows external mappings of sequence data and features.voidsetReferences(List<AbstractReference> references)Set the list ofAbstractReferencevoidsetSequenceScore(Double sequenceScore)voidsetSource(String source)Added support for the source of this sequence for GFF3 exportvoidsetTaxonomy(TaxonomyID taxonomy)voidsetUserCollection(Collection<Object> userCollection)StringtoString()- 
Methods inherited from class java.lang.Objectclone, finalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface java.lang.IterableforEach, spliterator
 
- 
 
- 
- 
- 
Constructor Detail- 
AbstractSequencepublic AbstractSequence() 
 - 
AbstractSequencepublic AbstractSequence(String seqString, CompoundSet<C> compoundSet) throws CompoundNotFoundException Create a Sequence from a simple string where the values should be found in compoundSet- Parameters:
- seqString-
- compoundSet-
- Throws:
- CompoundNotFoundException
 
 - 
AbstractSequencepublic AbstractSequence(SequenceReader<C> proxyLoader, CompoundSet<C> compoundSet) A ProxySequenceReader allows abstraction of both the storage of the sequence data and the location of the sequence data. A variety of use cases are possible. A ProxySequenceReader that knows the offset and of the sequence in a large fasta file. A ProxySequenceReader that can pull Sequence data from UniProt, NCBI or a custom database. If the ProxySequenceReader implements various interfaces then the sequence will set those interfaces so that calls to various methods will be valid.- Parameters:
- proxyLoader-
- compoundSet-
 
 
- 
 - 
Method Detail- 
setProxySequenceReaderpublic void setProxySequenceReader(SequenceReader<C> proxyLoader) Very important method that allows external mappings of sequence data and features. This method will gain additional interface inspection that allows external data sources with knowledge of features for a sequence to be supported.- Parameters:
- proxyLoader-
 
 - 
getProxySequenceReaderpublic SequenceReader<C> getProxySequenceReader() 
 - 
getBioBeginpublic Integer getBioBegin() - Returns:
- the bioBegin
 
 - 
setBioBeginpublic void setBioBegin(Integer bioBegin) - Parameters:
- bioBegin- the bioBegin to set
 
 - 
getUserCollectionpublic Collection<Object> getUserCollection() Provided for convince if the developer needs to associate data with a sequence- Returns:
 
 - 
setUserCollectionpublic void setUserCollection(Collection<Object> userCollection) - Parameters:
- userCollection-
 
 - 
getAnnotationTypepublic AbstractSequence.AnnotationType getAnnotationType() - Returns:
- the annotation
 
 - 
setAnnotationTypepublic void setAnnotationType(AbstractSequence.AnnotationType annotationType) - Parameters:
- annotationType- the annotation to set
 
 - 
getDescriptionpublic String getDescription() - Returns:
- the description
 
 - 
setDescriptionpublic void setDescription(String description) - Parameters:
- description- the description to set
 
 - 
getOriginalHeaderpublic String getOriginalHeader() - Returns:
- the originalHeader
 
 - 
setOriginalHeaderpublic void setOriginalHeader(String originalHeader) - Parameters:
- originalHeader- the originalHeader to set
 
 - 
getParentSequencepublic AbstractSequence<?> getParentSequence() - Returns:
- the parentSequence
 
 - 
setParentSequencepublic void setParentSequence(AbstractSequence<?> parentSequence) - Parameters:
- parentSequence- the parentSequence to set
 
 - 
getSourcepublic String getSource() Added support for the source of this sequence for GFF3 export If a sub sequence doesn't have source then check for parent source- Returns:
- the source
 
 - 
setSourcepublic void setSource(String source) Added support for the source of this sequence for GFF3 export- Parameters:
- source- the source to set
 
 - 
addNotepublic void addNote(String note) Add notes about this sequence that will get exported for GFF3- Parameters:
- note-
 
 - 
removeNotepublic void removeNote(String note) 
 - 
getNotesListpublic ArrayList<String> getNotesList() - Returns:
- the notesList
 
 - 
setNotesListpublic void setNotesList(ArrayList<String> notesList) - Parameters:
- notesList- the notesList to set
 
 - 
getSequenceScorepublic Double getSequenceScore() Provide place holder for a metric that indicate a score associated with the sequence- Returns:
- the sequenceScore
 
 - 
setSequenceScorepublic void setSequenceScore(Double sequenceScore) - Parameters:
- sequenceScore- the sequenceScore to set
 
 - 
getReferencespublic List<AbstractReference> getReferences() - Returns:
- the list of AbstractReference
- Since:
- 5.0.0
 
 - 
setReferencespublic void setReferences(List<AbstractReference> references) Set the list ofAbstractReference- Parameters:
- references-
- Since:
- 5.0.0
 
 - 
getFeaturespublic List<FeatureInterface<AbstractSequence<C>,C>> getFeatures(String featureType, int bioSequencePosition) Return features at a sequence position by type- Parameters:
- featureType-
- bioSequencePosition-
- Returns:
 
 - 
getFeaturespublic List<FeatureInterface<AbstractSequence<C>,C>> getFeatures(int bioSequencePosition) Return features at a sequence position- Parameters:
- bioSequencePosition-
- Returns:
 
 - 
getFeaturespublic List<FeatureInterface<AbstractSequence<C>,C>> getFeatures() - Returns:
 
 - 
addFeaturepublic void addFeature(int bioStart, int bioEnd, FeatureInterface<AbstractSequence<C>,C> feature) Method to help set the proper details for a feature as it relates to a sequence where the feature needs to have a location on the sequence- Parameters:
- bioStart-
- bioEnd-
- feature-
 
 - 
addFeaturepublic void addFeature(FeatureInterface<AbstractSequence<C>,C> feature) Add a feature to this sequence. The feature will be added to the collection where the order is start position and if more than one feature at the same start position then longest is added first. This helps on doing feature layout for displaying features in SequenceFeaturePanel- Parameters:
- feature-
 
 - 
removeFeaturepublic void removeFeature(FeatureInterface<AbstractSequence<C>,C> feature) Remove a feature from the sequence- Parameters:
- feature-
 
 - 
getFeaturesByTypepublic List<FeatureInterface<AbstractSequence<C>,C>> getFeaturesByType(String type) - Parameters:
- type-
- Returns:
 
 - 
getCommentspublic List<String> getComments() - Returns:
- comments
 
 - 
setCommentspublic void setComments(List<String> comments) Set comments.- Parameters:
- comments-
 
 - 
getFeaturesKeyWordpublic FeaturesKeyWordInterface getFeaturesKeyWord() - Returns:
- the featuresKeyWord
 
 - 
setFeaturesKeyWordpublic void setFeaturesKeyWord(FeaturesKeyWordInterface featuresKeyWord) - Parameters:
- featuresKeyWord- the featuresKeyWord to set
 
 - 
getDatabaseReferencespublic DatabaseReferenceInterface getDatabaseReferences() - Returns:
- the databaseReferences
 
 - 
setDatabaseReferencespublic void setDatabaseReferences(DatabaseReferenceInterface databaseReferences) - Parameters:
- databaseReferences- the databaseReferences to set
 
 - 
getFeatureRetrieverpublic FeatureRetriever getFeatureRetriever() 
 - 
setFeatureRetrieverpublic void setFeatureRetriever(FeatureRetriever featureRetriever) 
 - 
getAccessionpublic AccessionID getAccession() Description copied from interface:AccessionedReturns the AccessionID this location is currently bound with- Specified by:
- getAccessionin interface- Accessioned
- Returns:
- the accession
 
 - 
setAccessionpublic void setAccession(AccessionID accession) - Parameters:
- accession- the accession to set
 
 - 
getTaxonomypublic TaxonomyID getTaxonomy() - Returns:
- the species
 
 - 
setTaxonomypublic void setTaxonomy(TaxonomyID taxonomy) - Parameters:
- taxonomy- the species to set
 
 - 
getCompoundSetpublic CompoundSet<C> getCompoundSet() Description copied from interface:SequenceGets the compound set used to back this Sequence- Specified by:
- getCompoundSetin interface- Sequence<C extends Compound>
 
 - 
setCompoundSetpublic void setCompoundSet(CompoundSet<C> compoundSet) 
 - 
getSequenceAsStringpublic String getSequenceAsString(Integer bioStart, Integer bioEnd, Strand strand) - Parameters:
- bioStart-
- bioEnd-
- strand-
- Returns:
 
 - 
getSequenceAsStringpublic String getSequenceAsString() Default case is to assume strand is positive because only CDSSequence can be either positive or negative Strand.- Specified by:
- getSequenceAsStringin interface- Sequence<C extends Compound>
- Returns:
 
 - 
getAsListpublic List<C> getAsList() Description copied from interface:SequenceReturns the Sequence as a List of compounds
 - 
getCompoundAtpublic C getCompoundAt(int position) Description copied from interface:SequenceReturns the Compound at the given biological index- Specified by:
- getCompoundAtin interface- Sequence<C extends Compound>
- Parameters:
- position- The 1-indexed position of the amino acid
- Returns:
 
 - 
getIndexOfpublic int getIndexOf(C compound) Description copied from interface:SequenceScans through the Sequence looking for the first occurrence of the given compound- Specified by:
- getIndexOfin interface- Sequence<C extends Compound>
- Parameters:
- compound-
- Returns:
- The first index of compound in this sequence (1-based)
 
 - 
getLastIndexOfpublic int getLastIndexOf(C compound) Description copied from interface:SequenceScans through the Sequence looking for the last occurrence of the given compound- Specified by:
- getLastIndexOfin interface- Sequence<C extends Compound>
- Parameters:
- compound-
- Returns:
- The last index of compound in this sequence (1-based)
 
 - 
getLengthpublic int getLength() Description copied from interface:SequenceReturns the length of the Sequence
 - 
getSubSequencepublic SequenceView<C> getSubSequence(Integer bioStart, Integer bioEnd) Description copied from interface:SequenceReturns a portion of the sequence from the different positions. This is indexed from 1- Specified by:
- getSubSequencein interface- Sequence<C extends Compound>
- Parameters:
- bioStart-
- bioEnd-
- Returns:
 
 - 
countCompoundspublic int countCompounds(C... compounds) Description copied from interface:SequenceReturns the number of times we found a compound in the Sequence- Specified by:
- countCompoundsin interface- Sequence<C extends Compound>
- Parameters:
- compounds-
- Returns:
 
 - 
getInversepublic SequenceView<C> getInverse() Description copied from interface:SequenceDoes the right thing to get the inverse of the current Sequence. This means either reversing the Sequence and optionally complementing the Sequence.- Specified by:
- getInversein interface- Sequence<C extends Compound>
- Returns:
 
 
- 
 
-