"""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) ) # dataset to resource mapping _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))