Source code for checkQC.handlers.error_rate_handler


from checkQC.handlers.qc_handler import QCHandler, QCErrorFatal, QCErrorWarning
from checkQC.parsers.interop_parser import InteropParser
from checkQC.exceptions import ConfigurationError


[docs]class ErrorRateHandler(QCHandler): """ This handler will check that the error rate per lane and read are below the specified threshold. Sometimes an error rate estimate is not available, e.g. when no PhiX has been included on the lane which is being analyzed. If you want to allow this to pass anyway, ensure that the ErrorRateHandler has 'allow_missing_error_rate' set to 'True'. """ ALLOW_MISSING_ERROR_RATE = "allow_missing_error_rate" def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.error_results = []
[docs] def parser(self): """ The ErrorRateHandler fetches its data from the Interop files. :returns: an InteropParser callable """ return InteropParser
[docs] def collect(self, signal): key, value = signal if key == "error_rate": self.error_results.append(value)
[docs] def custom_configuration_validation(self): try: value = self.qc_config[self.ALLOW_MISSING_ERROR_RATE] except KeyError as e: raise ConfigurationError("Did not find key '{}' in configuration for ErrorRate handler".format(e.args[0])) if not isinstance(value, bool): raise ConfigurationError("Only True/False are allowed as values for 'allow_missing_error_rate' in the " "ErrorRate handler config. Value was: {}".format(value))
[docs] def check_qc(self): for error_dict in self.error_results: lane_nbr = int(error_dict["lane"]) read = error_dict["read"] error_rate = error_dict["error_rate"] if error_rate == 0 and not self.qc_config[self.ALLOW_MISSING_ERROR_RATE]: yield QCErrorFatal("Error rate was found to be 0 on lane: {} for read: {}, this is probably " "because there was no PhiX loaded on this lane. If do not use PhiX for your " "runs you can set 'allow_missing_error_rate' in the config to True, which will " "remove the messages in the future.".format(lane_nbr, read)) elif self.error() != self.UNKNOWN and error_rate > self.error(): yield QCErrorFatal("Error rate {} was to high on lane: {} for read: {}".format(error_rate, lane_nbr, read), ordering=lane_nbr, data={"lane": lane_nbr, "read": read, "error_rate": error_rate, "threshold": self.error()}) elif self.warning() != self.UNKNOWN and error_rate > self.warning(): yield QCErrorWarning("Error rate {} was to high on lane: {} for read: {}".format(error_rate, lane_nbr, read), ordering=lane_nbr, data={"lane": lane_nbr, "read": read, "error_rate": error_rate, "threshold": self.warning()}) else: continue