mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-07-29 07:14:20 +00:00
registry refactor
This commit is contained in:
parent
78cb88c3c4
commit
18fe966e96
9 changed files with 60 additions and 106 deletions
|
@ -6,8 +6,13 @@
|
||||||
|
|
||||||
# TODO: make these import config based
|
# TODO: make these import config based
|
||||||
from llama_stack.apis.dataset import * # noqa: F403
|
from llama_stack.apis.dataset import * # noqa: F403
|
||||||
|
from ..registry import Registry
|
||||||
from .dataset import CustomDataset, HuggingfaceDataset
|
from .dataset import CustomDataset, HuggingfaceDataset
|
||||||
from .dataset_registry import DatasetRegistry
|
|
||||||
|
|
||||||
|
class DatasetRegistry(Registry[BaseDataset]):
|
||||||
|
_REGISTRY: Dict[str, BaseDataset] = {}
|
||||||
|
|
||||||
|
|
||||||
DATASETS_REGISTRY = [
|
DATASETS_REGISTRY = [
|
||||||
CustomDataset(
|
CustomDataset(
|
||||||
|
|
|
@ -1,32 +0,0 @@
|
||||||
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
|
||||||
# the root directory of this source tree.
|
|
||||||
from typing import AbstractSet, Dict
|
|
||||||
|
|
||||||
from llama_stack.apis.dataset import BaseDataset
|
|
||||||
|
|
||||||
|
|
||||||
class DatasetRegistry:
|
|
||||||
_REGISTRY: Dict[str, BaseDataset] = {}
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def names() -> AbstractSet[str]:
|
|
||||||
return DatasetRegistry._REGISTRY.keys()
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def register(name: str, task: BaseDataset) -> None:
|
|
||||||
if name in DatasetRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Dataset {name} already exists.")
|
|
||||||
DatasetRegistry._REGISTRY[name] = task
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def get_dataset(name: str) -> BaseDataset:
|
|
||||||
if name not in DatasetRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Dataset {name} not found.")
|
|
||||||
return DatasetRegistry._REGISTRY[name]
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def reset() -> None:
|
|
||||||
DatasetRegistry._REGISTRY = {}
|
|
|
@ -0,0 +1,12 @@
|
||||||
|
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# This source code is licensed under the terms described in the LICENSE file in
|
||||||
|
# the root directory of this source tree.
|
||||||
|
from llama_stack.apis.evals import * # noqa: F403
|
||||||
|
|
||||||
|
from ..registry import Registry
|
||||||
|
|
||||||
|
|
||||||
|
class GeneratorProcessorRegistry(Registry[BaseGeneratorProcessor]):
|
||||||
|
_REGISTRY: Dict[str, BaseGeneratorProcessor] = {}
|
32
llama_stack/distribution/registry/registry.py
Normal file
32
llama_stack/distribution/registry/registry.py
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
||||||
|
# All rights reserved.
|
||||||
|
#
|
||||||
|
# This source code is licensed under the terms described in the LICENSE file in
|
||||||
|
# the root directory of this source tree.
|
||||||
|
from typing import AbstractSet, Dict, Generic, TypeVar
|
||||||
|
|
||||||
|
TRegistry = TypeVar("TRegistry")
|
||||||
|
|
||||||
|
|
||||||
|
class Registry(Generic[TRegistry]):
|
||||||
|
_REGISTRY: Dict[str, TRegistry] = {}
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def names() -> AbstractSet[str]:
|
||||||
|
return Registry._REGISTRY.keys()
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def register(name: str, task: TRegistry) -> None:
|
||||||
|
if name in Registry._REGISTRY:
|
||||||
|
raise ValueError(f"Dataset {name} already exists.")
|
||||||
|
Registry._REGISTRY[name] = task
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def get(name: str) -> TRegistry:
|
||||||
|
if name not in Registry._REGISTRY:
|
||||||
|
raise ValueError(f"Dataset {name} not found.")
|
||||||
|
return Registry._REGISTRY[name]
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def reset() -> None:
|
||||||
|
Registry._REGISTRY = {}
|
|
@ -4,3 +4,10 @@
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
# This source code is licensed under the terms described in the LICENSE file in
|
||||||
# the root directory of this source tree.
|
# the root directory of this source tree.
|
||||||
# TODO: make these import config based
|
# TODO: make these import config based
|
||||||
|
from llama_stack.apis.evals import * # noqa: F403
|
||||||
|
|
||||||
|
from ..registry import Registry
|
||||||
|
|
||||||
|
|
||||||
|
class ScorerRegistry(Registry[BaseScorer]):
|
||||||
|
_REGISTRY: Dict[str, BaseScorer] = {}
|
||||||
|
|
|
@ -1,32 +0,0 @@
|
||||||
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
|
||||||
# the root directory of this source tree.
|
|
||||||
from typing import AbstractSet, Dict
|
|
||||||
|
|
||||||
from llama_stack.apis.evals import BaseScorer
|
|
||||||
|
|
||||||
|
|
||||||
class ScorerRegistry:
|
|
||||||
_REGISTRY: Dict[str, BaseScorer] = {}
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def names() -> AbstractSet[str]:
|
|
||||||
return ScorerRegistry._REGISTRY.keys()
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def register(name: str, scorer: BaseScorer) -> None:
|
|
||||||
if name in ScorerRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Task {name} already exists.")
|
|
||||||
ScorerRegistry._REGISTRY[name] = task
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def get_scorer(name: str) -> BaseScorer:
|
|
||||||
if name not in ScorerRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Task {name} not found.")
|
|
||||||
return ScorerRegistry._REGISTRY[name]
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def reset() -> None:
|
|
||||||
ScorerRegistry._REGISTRY = {}
|
|
|
@ -1,5 +0,0 @@
|
||||||
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
|
||||||
# the root directory of this source tree.
|
|
|
@ -1,32 +0,0 @@
|
||||||
# Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
|
||||||
# the root directory of this source tree.
|
|
||||||
from typing import AbstractSet, Dict
|
|
||||||
|
|
||||||
from llama_stack.apis.evals import BaseTask
|
|
||||||
|
|
||||||
|
|
||||||
class TaskRegistry:
|
|
||||||
_REGISTRY: Dict[str, BaseTask] = {}
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def names() -> AbstractSet[str]:
|
|
||||||
return TaskRegistry._REGISTRY.keys()
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def register(name: str, task: BaseTask) -> None:
|
|
||||||
if name in TaskRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Task {name} already exists.")
|
|
||||||
TaskRegistry._REGISTRY[name] = task
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def get_task(name: str) -> BaseTask:
|
|
||||||
if name not in TaskRegistry._REGISTRY:
|
|
||||||
raise ValueError(f"Task {name} not found.")
|
|
||||||
return TaskRegistry._REGISTRY[name]
|
|
||||||
|
|
||||||
@staticmethod
|
|
||||||
def reset() -> None:
|
|
||||||
TaskRegistry._REGISTRY = {}
|
|
|
@ -3,7 +3,7 @@
|
||||||
#
|
#
|
||||||
# This source code is licensed under the terms described in the LICENSE file in
|
# This source code is licensed under the terms described in the LICENSE file in
|
||||||
# the root directory of this source tree.
|
# the root directory of this source tree.
|
||||||
from llama_stack.distribution.registry.datasets.dataset_registry import DatasetRegistry
|
from llama_stack.distribution.registry.datasets import DatasetRegistry
|
||||||
from llama_stack.providers.impls.meta_reference.evals.scorer.basic_scorers import * # noqa: F403
|
from llama_stack.providers.impls.meta_reference.evals.scorer.basic_scorers import * # noqa: F403
|
||||||
from llama_stack.providers.impls.meta_reference.evals.generator.inference_generator import (
|
from llama_stack.providers.impls.meta_reference.evals.generator.inference_generator import (
|
||||||
InferenceGenerator,
|
InferenceGenerator,
|
||||||
|
@ -38,9 +38,8 @@ class RunEvalTask(BaseTask):
|
||||||
) -> EvalResult:
|
) -> EvalResult:
|
||||||
print(f"Running eval task w/ {eval_task_config}")
|
print(f"Running eval task w/ {eval_task_config}")
|
||||||
|
|
||||||
dataset = DatasetRegistry.get_dataset(
|
print(DatasetRegistry.names())
|
||||||
eval_task_config.dataset_config.dataset_name
|
dataset = DatasetRegistry.get(eval_task_config.dataset_config.dataset_name)
|
||||||
)
|
|
||||||
dataset.load(n_samples=eval_task_config.dataset_config.row_limit)
|
dataset.load(n_samples=eval_task_config.dataset_config.row_limit)
|
||||||
print(f"Running on {len(dataset)} samples")
|
print(f"Running on {len(dataset)} samples")
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue