Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mckay/halt on plot fail #103

Merged
merged 14 commits into from
Oct 2, 2024
2 changes: 2 additions & 0 deletions CRISPResso2/CRISPRessoAggregateCORE.py
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ def main():

parser.add_argument('--debug', help='Show debug messages', action='store_true')
parser.add_argument('-v', '--verbosity', type=int, help='Verbosity level of output to the console (1-4), 4 is the most verbose', default=3)
parser.add_argument('--halt_on_plot_fail', action="store_true", help="Halt execution if a plot fails to generate")

# CRISPRessoPro params
parser.add_argument('--use_matplotlib', action='store_true',
Expand Down Expand Up @@ -131,6 +132,7 @@ def main():
num_processes=n_processes,
process_pool=process_pool,
process_futures=process_futures,
halt_on_plot_fail=args.halt_on_plot_fail,
)

#glob returns paths including the original prefix
Expand Down
1 change: 1 addition & 0 deletions CRISPResso2/CRISPRessoBatchCORE.py
Original file line number Diff line number Diff line change
Expand Up @@ -400,6 +400,7 @@ def main():
num_processes=n_processes_for_batch,
process_futures=process_futures,
process_pool=process_pool,
halt_on_plot_fail=args.halt_on_plot_fail,
)

window_nuc_pct_quilt_plot_names = []
Expand Down
5 changes: 5 additions & 0 deletions CRISPResso2/CRISPRessoCORE.py
Original file line number Diff line number Diff line change
Expand Up @@ -3746,6 +3746,7 @@ def count_alternate_alleles(sub_base_vectors, ref_name, ref_sequence, ref_total_
num_processes=n_processes,
process_pool=process_pool,
process_futures=process_futures,
halt_on_plot_fail=args.halt_on_plot_fail,
)
###############################################################################################################################################
### FIGURE 1: Alignment
Expand Down Expand Up @@ -5174,6 +5175,10 @@ def get_scaffold_len(row, scaffold_start_loc, scaffold_seq):
print_stacktrace_if_debug()
error('Filtering error, please check your input.\n\nERROR: %s' % e)
sys.exit(13)
except CRISPRessoShared.PlotException as e:
print_stacktrace_if_debug()
error(e)
sys.exit(14)
except Exception as e:
print_stacktrace_if_debug()
error('Unexpected error, please check your input.\n\nERROR: %s' % e)
Expand Down
10 changes: 9 additions & 1 deletion CRISPResso2/CRISPRessoMultiProcessing.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,9 @@
import pandas as pd
import traceback

from CRISPResso2.CRISPRessoShared import PlotException


def get_max_processes():
return mp.cpu_count()

Expand Down Expand Up @@ -284,7 +287,7 @@ def run_parallel_commands(commands_arr, n_processes=1, descriptor='CRISPResso2',
pool.join()


def run_plot(plot_func, plot_args, num_processes, process_futures, process_pool):
def run_plot(plot_func, plot_args, num_processes, process_futures, process_pool, halt_on_plot_fail):
"""Run a plot in parallel if num_processes > 1, otherwise in serial.

Parameters
Expand All @@ -299,6 +302,8 @@ def run_plot(plot_func, plot_args, num_processes, process_futures, process_pool)
The list of futures that submitting the parallel job will return.
process_pool: ProcessPoolExecutor or ThreadPoolExecutor
The pool to submit the job to.
halt_on_plot_fail: bool
If True, an exception will be raised if the plot fails

Returns
-------
Expand All @@ -311,5 +316,8 @@ def run_plot(plot_func, plot_args, num_processes, process_futures, process_pool)
else:
plot_func(**plot_args)
except Exception as e:
if halt_on_plot_fail:
logger.critical(f"Plot error, halting execution \n")
raise PlotException(f'There was an error generating plot {plot_func.__name__}.')
logger.warn(f"Plot error {e}, skipping plot \n")
logger.debug(traceback.format_exc())
1 change: 0 additions & 1 deletion CRISPResso2/CRISPRessoPlot.py
Original file line number Diff line number Diff line change
Expand Up @@ -2668,7 +2668,6 @@ def prep_alleles_table(df_alleles, reference_seq, MAX_N_ROWS, MIN_FREQUENCY):
"""
dna_to_numbers={'-':0,'A':1,'T':2,'C':3,'G':4,'N':5}
seq_to_numbers= lambda seq: [dna_to_numbers[x] for x in seq]

X=[]
annot=[]
y_labels=[]
Expand Down
6 changes: 6 additions & 0 deletions CRISPResso2/CRISPRessoShared.py
Original file line number Diff line number Diff line change
Expand Up @@ -80,9 +80,15 @@ class OutputFolderIncompleteException(Exception):
class InstallationException(Exception):
pass


class InputFileFormatException(Exception):
pass


class PlotException(Exception):
pass


#########################################

class StatusFormatter(logging.Formatter):
Expand Down
6 changes: 6 additions & 0 deletions CRISPResso2/args.json
Original file line number Diff line number Diff line change
Expand Up @@ -860,6 +860,12 @@
"help": "Use matplotlib for plotting instead of plotly/d3 when CRISPRessoPro is installed",
"action": "store_true",
"tools": ["Core", "Batch", "Pooled", "WGS", "Compare"]
},
"halt_on_plot_fail": {
"keys": ["--halt_on_plot_fail"],
"help": "Halt execution if a plot fails to generate",
"action": "store_true",
"tools": ["Core", "Batch", "Pooled", "WGS", "Compare"]
}
},
"Sections": {
Expand Down
Loading