From c59aae486cc657dc93e02833ba56fe25931494cb Mon Sep 17 00:00:00 2001 From: Sara Adkins Date: Tue, 20 Feb 2024 13:34:49 -0500 Subject: [PATCH] initial commit (#1608) (#1611) Co-authored-by: dbogunowicz <97082108+dbogunowicz@users.noreply.github.com> --- .../evaluation/integrations/lm_evaluation_harness.py | 9 +++++++-- src/deepsparse/evaluation/utils.py | 12 ++++++++++-- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/src/deepsparse/evaluation/integrations/lm_evaluation_harness.py b/src/deepsparse/evaluation/integrations/lm_evaluation_harness.py index 69934af37a..845fe062ac 100644 --- a/src/deepsparse/evaluation/integrations/lm_evaluation_harness.py +++ b/src/deepsparse/evaluation/integrations/lm_evaluation_harness.py @@ -25,7 +25,10 @@ from deepsparse import Pipeline from deepsparse.evaluation.registry import EvaluationRegistry from deepsparse.evaluation.results import Dataset, Evaluation, Metric, Result -from deepsparse.evaluation.utils import LM_EVALUATION_HARNESS +from deepsparse.evaluation.utils import ( + LM_EVALUATION_HARNESS, + LM_EVALUATION_HARNESS_ALIASES, +) from deepsparse.utils.data import numpy_log_softmax from lm_eval import evaluator, tasks, utils from lm_eval.api.instance import Instance @@ -39,7 +42,9 @@ __all__ = ["integration_eval"] -@EvaluationRegistry.register(name=LM_EVALUATION_HARNESS, alias="lm-eval-harness") +@EvaluationRegistry.register( + name=LM_EVALUATION_HARNESS, alias=LM_EVALUATION_HARNESS_ALIASES +) def integration_eval( pipeline: Pipeline, datasets: Union[List[str], str], diff --git a/src/deepsparse/evaluation/utils.py b/src/deepsparse/evaluation/utils.py index 6e5ade9344..15503f0553 100644 --- a/src/deepsparse/evaluation/utils.py +++ b/src/deepsparse/evaluation/utils.py @@ -18,6 +18,7 @@ from deepsparse import Pipeline from deepsparse.operators.engine_operator import DEEPSPARSE_ENGINE +from sparsezoo.utils.registry import standardize_lookup_name __all__ = [ @@ -29,20 +30,27 @@ _LOGGER = logging.getLogger(__name__) LM_EVALUATION_HARNESS = "lm-evaluation-harness" +LM_EVALUATION_HARNESS_ALIASES = ["lm-eval-harness", "lm-eval"] PERPLEXITY = "perplexity" def potentially_check_dependency_import(integration_name: str) -> bool: """ Check if the `integration_name` requires importing a dependency. + Checking involves comparing the `integration_name` to the known + integrations (e.g. 'lm-evaluation-harness') or their aliases. If so, check if the dependency is installed and return True if it is. Otherwise, return False. - :param integration_name: The name of the integration to check + :param integration_name: The name of the integration to check. The name + is standardized using `standardize_lookup_name` before checking. :return: True if the dependency is installed, False otherwise """ + integration_name = standardize_lookup_name(integration_name) - if integration_name == LM_EVALUATION_HARNESS: + if integration_name == LM_EVALUATION_HARNESS or any( + integration_name == alias for alias in LM_EVALUATION_HARNESS_ALIASES + ): from deepsparse.evaluation.integrations import try_import_lm_evaluation_harness try_import_lm_evaluation_harness()