| """Mapping instance_id to resource_factor.
|
|
|
| Different instances may have different resource requirements.
|
| e.g., some instances may require more memory/CPU to run inference.
|
| This file tracks the resource requirements of different instances.
|
| """
|
|
|
| import json
|
| import os
|
| from openhands.core.logger import openhands_logger as logger
|
|
|
| CUR_DIR = os.path.dirname(os.path.abspath(__file__))
|
| DEFAULT_RUNTIME_RESOURCE_FACTOR = int(
|
| os.environ.get('DEFAULT_RUNTIME_RESOURCE_FACTOR', 1)
|
| )
|
|
|
|
|
| _global_resource_mapping: dict[str, dict[str, float]] = {}
|
|
|
|
|
| def get_resource_mapping(dataset_name: str) -> dict[str, float]:
|
| if dataset_name not in _global_resource_mapping:
|
| file_path = os.path.join(CUR_DIR, f'{dataset_name}.json')
|
| if not os.path.exists(file_path):
|
| logger.warning(f'Resource mapping for {dataset_name} not found.')
|
| return None
|
|
|
| with open(file_path, 'r') as f:
|
| _global_resource_mapping[dataset_name] = json.load(f)
|
| logger.info(f'Loaded resource mapping for {dataset_name}')
|
| return _global_resource_mapping[dataset_name]
|
|
|
|
|
| def get_instance_resource_factor(dataset_name: str, instance_id: str) -> int:
|
| resource_mapping = get_resource_mapping(dataset_name)
|
| if resource_mapping is None:
|
| return DEFAULT_RUNTIME_RESOURCE_FACTOR
|
| return int(resource_mapping.get(instance_id, DEFAULT_RUNTIME_RESOURCE_FACTOR))
|
|
|