mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-07-28 15:02:37 +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
|
||||
from llama_stack.apis.dataset import * # noqa: F403
|
||||
from ..registry import Registry
|
||||
from .dataset import CustomDataset, HuggingfaceDataset
|
||||
from .dataset_registry import DatasetRegistry
|
||||
|
||||
|
||||
class DatasetRegistry(Registry[BaseDataset]):
|
||||
_REGISTRY: Dict[str, BaseDataset] = {}
|
||||
|
||||
|
||||
DATASETS_REGISTRY = [
|
||||
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
|
||||
# the root directory of this source tree.
|
||||
# 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
|
||||
# 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.generator.inference_generator import (
|
||||
InferenceGenerator,
|
||||
|
@ -38,9 +38,8 @@ class RunEvalTask(BaseTask):
|
|||
) -> EvalResult:
|
||||
print(f"Running eval task w/ {eval_task_config}")
|
||||
|
||||
dataset = DatasetRegistry.get_dataset(
|
||||
eval_task_config.dataset_config.dataset_name
|
||||
)
|
||||
print(DatasetRegistry.names())
|
||||
dataset = DatasetRegistry.get(eval_task_config.dataset_config.dataset_name)
|
||||
dataset.load(n_samples=eval_task_config.dataset_config.row_limit)
|
||||
print(f"Running on {len(dataset)} samples")
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue