forked from slyrus/cl-bio
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathbio-sequence0.lisp
39 lines (28 loc) · 1.13 KB
/
bio-sequence0.lisp
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
;; bio-sequence0 is a set of routines for working with 0-based
;; indices. The routines provided here are analogous to those in the
;; bio-sequence1 package, but use 0-based indexing and are generally
;; just wrappers for routines the bio-sequence package.
;;
(defpackage #:bio-sequence0
(:use #:cl #:bio)
(:nicknames #:seq0)
(:shadow #:elt
#:subseq
#:translate)
(:export #:elt
#:subseq
#:substring
#:translate))
(in-package :seq0)
(defun elt (sequence index)
(residue sequence index))
(defun (setf elt) (val sequence index)
(setf (residue sequence index) val))
(defun subseq (sequence start &optional (end (seq-length sequence)))
(copy-sequence-range sequence (range start end)))
(defun substring (sequence start &optional (end (seq-length sequence)))
(residues-string-range sequence (range start end)))
(defun (setf substring) (str sequence start &optional (end (seq-length sequence)))
(setf (residues-string-range sequence (range start end)) str))
(defun translate (sequence &key (start 0) (end (seq-length sequence)))
(bio:translate sequence :range (range start end)))