Mercurial > repos > imgteam > detection_viz
comparison detection_viz.py @ 0:3f738d5d91bf draft
planemo upload for repository https://github.com/BMCV/galaxy-image-analysis/tools/detection_viz/ commit c3f4b766f03770f094fda6bda0a5882c0ebd4581
| author | imgteam |
|---|---|
| date | Sat, 09 Feb 2019 14:35:39 -0500 |
| parents | |
| children | ec1ca4d62192 |
comparison
equal
deleted
inserted
replaced
| -1:000000000000 | 0:3f738d5d91bf |
|---|---|
| 1 import argparse | |
| 2 import sys | |
| 3 import os | |
| 4 import csv | |
| 5 | |
| 6 import matplotlib | |
| 7 matplotlib.use('Agg') | |
| 8 import matplotlib.pyplot as plt | |
| 9 | |
| 10 import skimage.io | |
| 11 | |
| 12 def plot_circles(file_name, ax, color, stroke_size, radius): | |
| 13 resfile = open(file_name, 'rb') | |
| 14 rd = csv.reader(resfile, delimiter=',') | |
| 15 for row in rd: | |
| 16 circ = plt.Circle((int(row[1]), int(row[0])), lw=stroke_size, radius=radius, color=color, fill=False) | |
| 17 ax.add_patch(circ) | |
| 18 resfile.close() | |
| 19 | |
| 20 def detection_viz(input_file, output_file, tp=None, fn=None, fp=None, stroke_size=3, circle_radius=50): | |
| 21 img = skimage.io.imread(input_file) | |
| 22 | |
| 23 fig = plt.figure(figsize=(40, 40)) | |
| 24 ax = fig.add_axes([0, 0, 1, 1]) | |
| 25 ax.axis('off') | |
| 26 | |
| 27 plt.imshow(img) | |
| 28 if tp is not None: | |
| 29 plot_circles(tp, ax, '#00FF00', stroke_size, circle_radius) | |
| 30 if fn is not None: | |
| 31 plot_circles(fn, ax, 'red', stroke_size, circle_radius) | |
| 32 if fp is not None: | |
| 33 plot_circles(fp, ax, 'darkorange', stroke_size, circle_radius) | |
| 34 | |
| 35 fig.canvas.print_png(output_file, dpi=1800) | |
| 36 | |
| 37 if __name__ == "__main__": | |
| 38 parser = argparse.ArgumentParser() | |
| 39 parser.add_argument('input_file', type=argparse.FileType('r'), help='original file') | |
| 40 # output file should not be of type argparse.FileType('w') sine it is created immediately in this case which leads to an error in renaming | |
| 41 parser.add_argument('out_file_str', type=str, help='string of output file name') | |
| 42 parser.add_argument('--tp', dest='input_tp_file', type=argparse.FileType('r'), help='input TP file') | |
| 43 parser.add_argument('--fn', dest='input_fn_file', type=argparse.FileType('r'), help='input FN file') | |
| 44 parser.add_argument('--fp', dest='input_fp_file', type=argparse.FileType('r'), help='input FP file') | |
| 45 parser.add_argument('--stroke_size', dest='thickness', default=3, type=float, help='stroke thickness') | |
| 46 parser.add_argument('--circle_radius', dest='circle_radius', type=float, default=50, help='circle radius') | |
| 47 args = parser.parse_args() | |
| 48 | |
| 49 tp=None | |
| 50 if args.input_tp_file: | |
| 51 tp=args.input_tp_file.name | |
| 52 fn=None | |
| 53 if args.input_fn_file: | |
| 54 fn=args.input_fn_file.name | |
| 55 fp=None | |
| 56 if args.input_fp_file: | |
| 57 fp=args.input_fp_file.name | |
| 58 | |
| 59 detection_viz(args.input_file.name, args.out_file_str, tp=tp, fn=fn, fp=fp, stroke_size=args.thickness, circle_radius=args.circle_radius) |
