From 62d6e55c525e27633d120d90b7a1671f1e9c9dc8 Mon Sep 17 00:00:00 2001 From: CaoTianze Date: Fri, 11 Aug 2023 08:31:35 +0800 Subject: [PATCH] zoom feature --- plotnineseqsuite/tool.py | 10 ++++++++++ tests/test_tool.py | 6 ++++++ tests/test_zoom.py | 22 ++++++++++++++++++++++ 3 files changed, 38 insertions(+) create mode 100644 plotnineseqsuite/tool.py create mode 100644 tests/test_tool.py create mode 100644 tests/test_zoom.py diff --git a/plotnineseqsuite/tool.py b/plotnineseqsuite/tool.py new file mode 100644 index 0000000..a2a43ed --- /dev/null +++ b/plotnineseqsuite/tool.py @@ -0,0 +1,10 @@ +from typing import List + + +def extract(data: List[str], start: int = None, end: int = None) -> List[str]: + complete_len = len(data[0]) + if start is None: + start = 0 + if end is None: + end = complete_len + return list(map(lambda x: x[start:end], data)) diff --git a/tests/test_tool.py b/tests/test_tool.py new file mode 100644 index 0000000..b15d29e --- /dev/null +++ b/tests/test_tool.py @@ -0,0 +1,6 @@ +from plotnineseqsuite.tool import extract + + +def test_extract(): + seqs = ['TTGTGAAAGAC', 'AAGTAAACTAA', 'TAATAAACAAA', 'TAATAAACAAA', 'CTGTAAATATT', 'TAGAAAGGTAT'] + result = extract(seqs, start=1, end=4) diff --git a/tests/test_zoom.py b/tests/test_zoom.py new file mode 100644 index 0000000..c4553e3 --- /dev/null +++ b/tests/test_zoom.py @@ -0,0 +1,22 @@ +from plotnine import ggplot, coord_fixed, ggtitle, theme, element_text, scale_x_continuous +from plotnineseqsuite.align import geom_alignedSeq, theme_seq, extract +from math import floor, ceil + +seqs = ['TTGTGAAAGAC', 'AAGTAAACTAA', 'TAATAAACAAA', 'TAATAAACAAA', 'CTGTAAATATT', 'TAGAAAGGTAT'] +result = extract(seqs, start=1, end=4) +a=ggplot() + geom_alignedSeq(data=seqs) + coord_fixed() + theme_seq()+ggtitle('Completed sequences') + theme(plot_title=element_text(size=30, ha='left')) +b=ggplot() + geom_alignedSeq(data=result) + scale_x_continuous(breaks=lambda x: range(floor(x[0]), ceil(x[1])), labels=lambda x:x+1, expand=(0,0)) + coord_fixed() + theme_seq()+ggtitle('Fragmented sequences') + theme(plot_title=element_text(size=30, ha='left')) +a.save('Fig. complete.png') +b.save('Fig. fragment.png') + +from PIL import Image +a_pic=Image.open('Fig. complete.png') +b_pic=Image.open('Fig. fragment.png') +a_width = a_pic.width +a_height = a_pic.height +b_width = b_pic.width +b_height = b_pic.height +dst = Image.new('RGB', (a_width+b_width, b_height), color='white') +dst.paste(a_pic, (0, 0)) +dst.paste(b_pic, (a_width, 0)) +dst.save('Fig. zoom.png') \ No newline at end of file