From 560d81849e2f5be0c943e6ea55522dacb378938b Mon Sep 17 00:00:00 2001 From: Andre Kahles Date: Mon, 6 Feb 2023 21:19:32 +0100 Subject: [PATCH] fixing coordinate bug in remove-short-exons mode #177 --- spladder/core/gen_graphs.py | 2 +- spladder/editgraph.py | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/spladder/core/gen_graphs.py b/spladder/core/gen_graphs.py index c01c926..dbd0755 100644 --- a/spladder/core/gen_graphs.py +++ b/spladder/core/gen_graphs.py @@ -125,7 +125,7 @@ def gen_graphs(genes, bam_fnames, options=None): print('Removing short exons ...', file=fd_log) genes = remove_short_exons(genes, options) for i in range(genes.shape[0]): - if np.any(genes[i].splicegraph.vertices[:, 1] - genes[i].splicegraph.vertices[:, 0] < options.remove_exons['min_exon_len_remove']): + if np.any(genes[i].splicegraph.vertices[1, :] - genes[i].splicegraph.vertices[0, :] < options.remove_exons['min_exon_len_remove']): print('WARNING: could not remove all short exons', file=sys.stderr) print('... done.\n', file=fd_log) diff --git a/spladder/editgraph.py b/spladder/editgraph.py index c7a4da4..24d7f43 100644 --- a/spladder/editgraph.py +++ b/spladder/editgraph.py @@ -31,11 +31,11 @@ def remove_short_exons(genes, options): ### extend terminal exons to terminal_short_extend if they are shorter than terminal_short_len if genes[i].splicegraph.vertices[1, 0] - genes[i].splicegraph.vertices[0, 0] < options.remove_exons['terminal_short_len']: - genes[i].splicegraph.vertices[0, 0] = genes[i].splicegraph.vertices[1, 0] - options.remove_exons['terminal_short_extend'] + genes[i].splicegraph.vertices[0, 0] -= options.remove_exons['terminal_short_extend'] genes[i].start = min(genes[i].start, genes[i].splicegraph.vertices[0, 0]) if genes[i].splicegraph.vertices[1, -1] - genes[i].splicegraph.vertices[0, -1] < options.remove_exons['terminal_short_len']: - genes[i].splicegraph.vertices[1, -1] = genes[i].splicegraph.vertices[1, -1] + options.remove_exons['terminal_short_extend'] + genes[i].splicegraph.vertices[1, -1] += options.remove_exons['terminal_short_extend'] genes[i].stop = max(genes[i].stop, genes[i].splicegraph.vertices[1, -1]) ### check for very short exons and insert an edge that allows skipping them @@ -67,7 +67,7 @@ def remove_short_exons(genes, options): keep_idx = np.where(~np.in1d(np.array(np.arange(genes[i].splicegraph.vertices.shape[1])), exons_remove_idx))[0] genes[i].splicegraph.subset(keep_idx) - keep_idx = np.where(~np.in1d(np.arange(len(genes[i])), rm_idx))[0] + keep_idx = np.where(~np.in1d(np.arange(len(genes)), rm_idx))[0] genes = genes[keep_idx] if options.verbose: