Mercurial > repos > dereeper > pangenome_explorer
view SkewIT/src/plot_gcskew.py @ 13:152d7c43478b draft
Uploaded
author | dereeper |
---|---|
date | Thu, 30 May 2024 20:07:55 +0000 |
parents | e42d30da7a74 |
children |
line wrap: on
line source
#! /usr/bin/env python ########################################################################## #plot_gcskew.py plots gcskew values for a given chromosome #Copyright (C) 2020 Jennifer Lu, jlu26@jhmi.edu # #This file is part of SkewIT # #SkewIT is free software; you can redistribute it and/or modify #it under the terms of the GNU General Public License as published by #the Free Software Foundation; either version 3 of the license, or #(at your option) any later version. #This program is distributed in the hope that it will be useful, #but WITHOUT ANY WARRANTY; without even the implied warranty of #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #GNU General Public License for more details. #You should have received a copy of the GNU General Public License #along with this program; if not, see <http://www.gnu.org/licenses/>. ############################################################################## #Jennifer Lu, jlu26@jhmi.edu #2019/01/15 # #This program plots gc_skew for a genome provided to this program #By default, the program will calculate gc-skew for 20kb windows every 20kb #(adjacent/non-overlapping windows of 20kb) # #Users can specify window size and frequency of the calculation. If a specified #frequency is less than the window size, windows will be overlapping ###################################################################### import sys, os, argparse from time import gmtime from time import strftime from Bio import SeqIO import numpy as np import matplotlib import matplotlib.pyplot as plt import matplotlib.ticker as tick def reformat_bp(tick_val, pos): val = round(tick_val/1000000,1) new_tick = '{:} Mb'.format(val) new_tick = str(new_tick) return new_tick def main(): parser = argparse.ArgumentParser() parser.add_argument("-i","--input","-s","--seq", dest="in_file", required=True, help="Sequence for which to calculate gc_skew") parser.add_argument("-k","-l","--window_len", default=20000, dest="window_size", required=False, type=int, help="Window size for which to calculate each g-c/g+c [default: 20Kbp]") parser.add_argument("--freq",required=False,type=int, dest="freq", default=1000, help="Frequency at which to calculate GC skew [default: 1Kbp]") parser.add_argument("-o","--output", required=False, default="curr.png", dest="out_file", help="Name of GC Skew Plot to Save to (default: curr.png)") args=parser.parse_args() #Start program time = strftime("%m-%d-%Y %H:%M:%S", gmtime()) sys.stdout.write(" PROGRAM START TIME: " + time + '\n') if args.freq == 0: freq = args.window_size else: freq = args.freq #Process sequence file id2string = {} id2name = {} count_seqs = 0 sys.stdout.write("\t>> Processing sequence file\n") sys.stdout.write("\t\t%i seqs found" % (count_seqs)) sys.stdout.flush() for record in SeqIO.parse(args.in_file,'fasta'): count_seqs += 1 if count_seqs % 100 == 0: sys.stdout.write("\r\t\t%i seqs found" % (count_seqs)) sys.stdout.flush() #Save string id2name[count_seqs] = record.id id2string[count_seqs] = str(record.seq) sys.stdout.write("\r\t\t%i seqs found\n" % (count_seqs)) sys.stdout.flush() #Calculate and plot gc skew tot = count_seqs count_seqs = 0 sys.stdout.write("\t>> Plotting GC Skew for %i seqs\n" % tot) sys.stdout.write("\t\t%i sequences processed" % (count_seqs)) sys.stdout.flush() plot_filename = args.out_file fig,ax = plt.subplots(nrows=tot, ncols=1,figsize=(10,3*tot),squeeze=False) for i in range(1,tot+1): #Calculate/plot skew my_seq = id2string[i] my_description = id2name[i] count = 0 #Calculate skew g = 0.0 c = 0.0 curr_seq = "" indices = [] skews = [] for j in range(0, len(my_seq), freq): if (j+args.window_size) >= len(my_seq): break curr_seq = my_seq[j:j+args.window_size] g = float(curr_seq.count("G")) c = float(curr_seq.count("C")) if (g+c) > 0: new_calc = (g-c)/(g+c) else: new_calc = 0.0 #Save values indices.append(j) skews.append(new_calc) #Final print count_seqs += 1 sys.stdout.write("\r\t\t%i sequences processed" % (count_seqs)) sys.stdout.flush() #Split to pos/neg s = np.array(skews) pos = np.ma.masked_where(s <= 0, s) neg = np.ma.masked_where(s >= 0, s) mid = np.ma.masked_where(s != 0, s) #Print to file lines = ax[i-1,0].plot(indices,pos, 'deepskyblue', indices,mid, 'g', indices,neg,'k') ax[i-1,0].set(xlabel='Genome Position', ylabel='GC Skew', title=my_description) ax[i-1,0].xaxis.set_major_formatter(tick.FuncFormatter(reformat_bp)) ax[i-1,0].grid() #Font Sizes plt.setp(lines,linewidth=0.3) plt.xticks(fontsize=8) plt.yticks(fontsize=8) plt.tight_layout() fig.savefig(plot_filename) sys.stdout.write("\r\t\t%i sequences processed (all finished)\n" % (count_seqs)) sys.stdout.flush() #End program time = strftime("%m-%d-%Y %H:%M:%S", gmtime()) sys.stdout.write(" PROGRAM FINISH TIME: " + time + '\n') if __name__== "__main__": main()