-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathsequence.py
More file actions
38 lines (25 loc) · 1.1 KB
/
sequence.py
File metadata and controls
38 lines (25 loc) · 1.1 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
from src.markov_probability_model.base.base_sequence_id_resolver import SequenceId, BaseSequenceIdResolver, \
SimpleBaseSequenceIdResolver
from src.markov_probability_model.base.alphabet import Aminoacid, ScoredAminoacid, AlignedAminoacid, \
AlignedScoredAminoacid
from typing import List, Optional, Generic, TypeVar
S = TypeVar('S')
class Sequence(Generic[S]):
def __init__(self, sequence_id: SequenceId, symbols: List[S],
base_seq_id_resolver: Optional[BaseSequenceIdResolver] = SimpleBaseSequenceIdResolver()):
self.sequence_id = sequence_id
self.symbols = symbols
self._base_seq_id_resolver = base_seq_id_resolver
@property
def base_sequence_id(self):
return self._base_seq_id_resolver.resolve(self.sequence_id)
def __len__(self):
return len(self.symbols)
class AminoacidSequence(Sequence[Aminoacid]):
pass
class ScoredAminoacidSequence(Sequence[ScoredAminoacid]):
pass
class AlignedAminoacidSequence(Sequence[AlignedAminoacid]):
pass
class AlignedScoredAminoacidSequence(Sequence[AlignedScoredAminoacid]):
pass