public class InfinitelyAmbiguousSymbolList extends Object implements SymbolList
Integer.MAX_VALUE
long, never gives index out of
bounds and always returns ambiguity symbols for everything.EDIT, EMPTY_LIST
Constructor and Description |
---|
InfinitelyAmbiguousSymbolList(FiniteAlphabet fa)
Creates a new instance of InfinitelyAmbiguousSymbolList
|
Modifier and Type | Method and Description |
---|---|
void |
addChangeListener(ChangeListener cl)
Add a listener that will be informed of all changes.
|
void |
addChangeListener(ChangeListener cl,
ChangeType ct)
Add a listener that will be informed of changes of a given type.
|
void |
edit(Edit edit)
Apply an edit to the SymbolList as specified by the edit object.
|
Alphabet |
getAlphabet()
The alphabet that this SymbolList is over.
|
boolean |
isUnchanging(ChangeType ct)
A particular ChangeType can never be raised by this Changeable.
|
Iterator |
iterator()
An Iterator over all Symbols in this SymbolList.
|
int |
length()
The number of symbols in this SymbolList.
|
void |
removeChangeListener(ChangeListener cl)
Remove a listener that was interested in all types of changes.
|
void |
removeChangeListener(ChangeListener cl,
ChangeType ct)
Remove a listener that was interested in a specific types of changes.
|
String |
seqString()
Stringify this symbol list.
|
SymbolList |
subList(int start,
int end)
Return a new SymbolList for the symbols start to end inclusive.
|
String |
subStr(int start,
int end)
Return a region of this symbol list as a String.
|
Symbol |
symbolAt(int index)
Return the symbol at index, counting from 1.
|
List |
toList()
Returns a List of symbols.
|
public InfinitelyAmbiguousSymbolList(FiniteAlphabet fa)
fa
- the finite alphabet to return ambiguous symbols from.public void addChangeListener(ChangeListener cl)
addChangeListener
in interface Changeable
cl
- the ChangeListener to addpublic void addChangeListener(ChangeListener cl, ChangeType ct)
addChangeListener
in interface Changeable
cl
- the ChangeListenerct
- the ChangeType it is to be informed ofpublic void edit(Edit edit) throws IndexOutOfBoundsException, IllegalAlphabetException, ChangeVetoException
All edits can be broken down into a series of operations that change contiguous blocks of the sequence. This represent a one of those operations.
When applied, this Edit will replace 'length' number of symbols starting a position 'pos' by the SymbolList 'replacement'. This allow to do insertions (length=0), deletions (replacement=SymbolList.EMPTY_LIST) and replacements (length>=1 and replacement.length()>=1).
The pos and pos+length should always be valid positions on the SymbolList to:
SymbolList seq = DNATools.createDNA("atcaaaaacgctagc");
System.out.println(seq.seqString());
// delete 5 bases from position 4
Edit ed = new Edit(4, 5, SymbolList.EMPTY_LIST);
seq.edit(ed);
System.out.println(seq.seqString());
// delete one base from the start
ed = new Edit(1, 1, SymbolList.EMPTY_LIST);
seq.edit(ed);
// delete one base from the end
ed = new Edit(seq.length(), 1, SymbolList.EMPTY_LIST);
seq.edit(ed);
System.out.println(seq.seqString());
// overwrite 2 bases from position 3 with "tt"
ed = new Edit(3, 2, DNATools.createDNA("tt"));
seq.edit(ed);
System.out.println(seq.seqString());
// add 6 bases to the start
ed = new Edit(1, 0, DNATools.createDNA("aattgg");
seq.edit(ed);
System.out.println(seq.seqString());
// add 4 bases to the end
ed = new Edit(seq.length() + 1, 0, DNATools.createDNA("tttt"));
seq.edit(ed);
System.out.println(seq.seqString());
// full edit
ed = new Edit(3, 2, DNATools.createDNA("aatagaa");
seq.edit(ed);
System.out.println(seq.seqString());
IGNOREDedit
in interface SymbolList
edit
- the Edit to performIndexOutOfBoundsException
- if the edit does not lie within the
SymbolListIllegalAlphabetException
- if the SymbolList to insert has an
incompatible alphabetChangeVetoException
- if either the SymboList does not support the
edit, or if the change was vetoedpublic Alphabet getAlphabet()
Every symbol within this SymbolList is a member of this alphabet.
alphabet.contains(symbol) == true
for each symbol that is within this sequence.
getAlphabet
in interface SymbolList
public boolean isUnchanging(ChangeType ct)
A particular ChangeType can never be raised by this Changeable.
If this returns true, then it is guaranteed that change events of this type (and all child types) can never under any circumstances be fired by this Changeable instance. If it returns false, that does not mean that this type of event will or even can be raised, but that it is worth registering listeners incase.
ALWAYS RETURNS TRUEisUnchanging
in interface Changeable
ct
- the ChangeType to checkpublic Iterator iterator()
This is an ordered iterator over the Symbols. It cannot be used to edit the underlying symbols. ALWAYS RETURNS AN ITERATOR OVER A SINGLE AMBIGUITY SYMBOL
iterator
in interface SymbolList
public int length()
Integer.MAX_VALUE
length
in interface SymbolList
public void removeChangeListener(ChangeListener cl)
removeChangeListener
in interface Changeable
cl
- a ChangeListener to removepublic void removeChangeListener(ChangeListener cl, ChangeType ct)
removeChangeListener
in interface Changeable
cl
- a ChangeListener to removect
- the ChangeType that it was interested inpublic String seqString()
It is expected that this will use the symbol's token to render each symbol. It should be parsable back into a SymbolList using the default token parser for this alphabet. ALWAYS RETURNS THE AMBIGUITY SYMBOL REPRESENTED AS A STRING
seqString
in interface SymbolList
public SymbolList subList(int start, int end) throws IndexOutOfBoundsException
The resulting SymbolList will count from 1 to (end-start + 1) inclusive, and refer to the symbols start to end of the original sequence. ALWAYS RETURNS SELF
subList
in interface SymbolList
start
- the first symbol of the new SymbolListend
- the last symbol (inclusive) of the new SymbolListIndexOutOfBoundsException
public String subStr(int start, int end) throws IndexOutOfBoundsException
This should use the same rules as seqString. ALWAYS RETURNS THE CORRECT LENGTH STRING MADE UP OF AMBIGUITY SYMBOLS
subStr
in interface SymbolList
start
- the first symbol to includeend
- the last symbol to includeIndexOutOfBoundsException
- if either start or end are not within the
SymbolListpublic Symbol symbolAt(int index) throws IndexOutOfBoundsException
symbolAt
in interface SymbolList
index
- the offset into this SymbolListIndexOutOfBoundsException
- if index is less than 1, or greater than
the length of the symbol listpublic List toList()
This is an immutable list of symbols. Do not edit it. ALWAYS RETURNS A LIST CONTAINING THE AMBIGUITY SYMBOL
toList
in interface SymbolList
Copyright © 2020 BioJava. All rights reserved.