-
Notifications
You must be signed in to change notification settings - Fork 184
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Support for custom evaluators (#1275)
## Support for custom evaluators * Move evaluation registration out of OliveEvaluator into its own class * Evaluators are registered using both the Framework and the class name * Add "type", "type_args", "user_script" and "script_dir" to OliveEvaluationConfig to support user specific custom implementation * Remove some dead code ## Checklist before requesting a review - [x] Add unit tests for this change. - [x] Make sure all tests can pass. - [ ] Update documents if necessary. - [x] Lint and apply fixes to your code by running `lintrunner -a` - [ ] Is this a user-facing change? If yes, give a description of this change to be included in the release notes. - [ ] Is this PR including examples changes? If yes, please remember to update [example documentation](https://github.com/microsoft/Olive/blob/main/docs/source/examples.md) in a follow-up PR. ## (Optional) Issue link
- Loading branch information
Showing
31 changed files
with
425 additions
and
258 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
# ------------------------------------------------------------------------- | ||
# Copyright (c) Microsoft Corporation. All rights reserved. | ||
# Licensed under the MIT License. | ||
# -------------------------------------------------------------------------- | ||
import inspect | ||
import logging | ||
from typing import ClassVar, Dict | ||
|
||
logger = logging.getLogger(__name__) | ||
|
||
|
||
class Registry: | ||
"""Registry for olive model evaluators.""" | ||
|
||
_REGISTRY: ClassVar[Dict] = {} | ||
|
||
@classmethod | ||
def register(cls, name: str = None): | ||
"""Register an evaluator to the registry. | ||
Args: | ||
name (str): the name of the evaluator, if name is None, uses the class name | ||
Returns: | ||
Callable: the decorator function | ||
""" | ||
|
||
def decorator(component): | ||
component_name = name if name is not None else component.__name__ | ||
if component_name in cls._REGISTRY: | ||
component_1 = cls._REGISTRY[component_name] | ||
component_2 = component | ||
|
||
component_file_1 = inspect.getfile(component_1) | ||
component_file_2 = inspect.getfile(component_2) | ||
|
||
_, component_line_no_1 = inspect.getsourcelines(component_1) | ||
_, component_line_no_2 = inspect.getsourcelines(component_2) | ||
|
||
if (component_file_1 != component_file_2) or (component_line_no_1 != component_line_no_2): | ||
logger.critical( | ||
"%s: Duplicate evaluator registration.\n" | ||
"\tPrevious Registration: %s:%d\n" | ||
"\tCurrent Registration: %s:%d.", | ||
component_name, | ||
component_file_1, | ||
component_line_no_1, | ||
component_file_2, | ||
component_line_no_2, | ||
) | ||
cls._REGISTRY[component_name] = component | ||
return component | ||
|
||
return decorator | ||
|
||
@classmethod | ||
def get(cls, name: str): | ||
"""Get an evaluator, by name, from the registry. | ||
Args: | ||
name (str): the name of the evaluator | ||
Returns: | ||
Type: the OliveEvaluator class | ||
""" | ||
return cls._REGISTRY.get(name) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.