Apply an edit to the ISymbolList as specified by the edit object.

Namespace:  BioSharp.Core.Bio.Symbol
Assembly:  BioSharp.Core (in BioSharp.Core.dll) Version: 0.1.3191.26120 (0.1.0.0)

Syntax

C#
public virtual void Edit(
	Edit edit
)

Parameters

edit
Type: BioSharp.Core.Bio.Symbol..::.Edit
the Edit to perform

Implements

ISymbolList..::.Edit(Edit)

Remarks

Description

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:

  • be edited (between 0 and symL.length()+1).
  • To append to a sequence, pos=symL.length()+1, pos=0.
  • To insert something at the beginning of the sequence, set pos=1 and length=0.

Examples

CopyC#
ISymbolList seq = DNATools.CreateDNA("atcaaaaacgctagc");
Console.WriteLine(seq.seqString());

// delete 5 bases from position 4
Edit ed = new Edit(4, 5, SymbolList.EMPTY_LIST);
seq.Edit(ed);
Console.WriteLine(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);
Console.WriteLine(seq.SeqString);

// overwrite 2 bases from position 3 with "tt"
ed = new Edit(3, 2, DNATools.CreateDNA("tt"));
seq.Edit(ed);
Console.WriteLine(seq.SeqString);

// add 6 bases to the start
ed = new Edit(1, 0, DNATools.CreateDNA("aattgg");
seq.Edit(ed);
Console.WriteLine(seq.SeqString);

// add 4 bases to the end
ed = new Edit(seq.length() + 1, 0, DNATools.CreateDNA("tttt"));
seq.Edit(ed);
Console.WriteLine(seq.SeqString);

// full edit
ed = new Edit(3, 2, DNATools.CreateDNA("aatagaa");
seq.Edit(ed);
Console.WriteLine(seq.SeqString);

See Also