MultiInferenceReport¶
-
class
pyinfer.
MultiInferenceReport
(models: List[Callable], inputs: List[Any], n_seconds: Optional[Union[int, float]] = None, n_iterations: Optional[int] = None, exit_on_inputs_exhausted: bool = False, infer_failure_point: Optional[Union[int, float]] = None, model_names: Optional[List[str]] = None, drop_stats: Optional[List[str]] = None)[source]¶ A model agnostic report of inference related stats for any list of callable models
-
__init__
(models: List[Callable], inputs: List[Any], n_seconds: Optional[Union[int, float]] = None, n_iterations: Optional[int] = None, exit_on_inputs_exhausted: bool = False, infer_failure_point: Optional[Union[int, float]] = None, model_names: Optional[List[str]] = None, drop_stats: Optional[List[str]] = None)[source]¶ - Parameters
models (List[Callable]) – A list of the callable methods or functions for the models.
inputs (List[Any]) – The input(s) parameters each of the models receives. If only one input is given then it is assumed each model takes the same shape/type of input and that input will be passed to each model.
n_seconds (Union[int, float, None], optional) – Number of seconds to run model inferences. If this is None it is expected that n_iterations will be set. Defaults to None.
n_iterations (int, optional) – Number of iterations to run model inferences for. If this is None it is expected that n_seconds will be set. Defaults to None.
exit_on_inputs_exhausted (bool, optional) – If inputs are a iterable of inputs exit on completion. This feature is not yet implemented. Defaults to False.
infer_failure_point (Union[int, float, None], optional) – Time in seconds (int or float) at which an inference. is to be considered a failure in the reporting stats. Defaults to None.
model_names (List[str], optional) – The names to give to the models for the report. Must be the same length as number of models provided. Defaults to None.
drop_stats (List[str], optional) – List of keys to drop from the report. Defaults to None.
- Raises
ModelIsNotCallableError – Will raise if the model provided is not callable.
NamesNotEqualsModelsLengthError – Will raise if the number of models names does not match the number of model callables provided.
MeasurementIntervalNotSetError – Will raise if neither n_seconds or n_iterations are set.
-
run
(print_report: bool = True) → List[dict][source]¶ Runs the multi inference report for self.models with input(s) self.inputs
- Parameters
print_report (bool, optional) – If true a table representation of the report will be printed to console. Defaults to True.
- Returns
- A list of dictionaries containing all the report stats created during the run
for each model callable.
- Return type
List[dict]
-
report
(results_list: List[dict])[source]¶ Prints a report to console based on the values found in results_list
- Parameters
results_list (dict) – A list of dictionaries containing compiled stats from the runs.
-
plot
(show: bool = True, save_location: Optional[str] = None)[source]¶ Creates a simple plot of self.models_runs. For each run it plots run number on the x-axis and run time in milliseconds on the y-axis.
- Parameters
show (bool, optional) – Whether to show the plot after calling method. Defaults to True.
save_location (str, optional) – Location to save plot at. If None the plot will not be saved. Defaults to None.
- Raises
MatplotlibNotInstalledError – Raise if matplotlib is not installed in python environment.
ValueError – Raise if the model_runs have not yet been calculated but plot is called.
-