sileod's picture
Upload folder using huggingface_hub
5a10f7f verified
Raw
History Blame Contribute Delete
1.52 kB
"""Client for the Reasoning Core OpenEnv server."""
from typing import Any
from openenv.core import EnvClient
from openenv.core.client_types import StepResult
from openenv.core.env_server.types import State
from .models import ReasoningCoreAction, ReasoningCoreObservation
class ReasoningCoreEnv(
EnvClient[ReasoningCoreAction, ReasoningCoreObservation, State]
):
"""HTTP/WebSocket client for Reasoning Core."""
def _step_payload(self, action: ReasoningCoreAction) -> dict[str, Any]:
return {"answer": action.answer}
def _parse_result(
self,
payload: dict[str, Any],
) -> StepResult[ReasoningCoreObservation]:
obs_data = payload.get("observation", {})
observation = ReasoningCoreObservation(
prompt=obs_data.get("prompt"),
score=obs_data.get("score"),
correct_answer=obs_data.get("correct_answer"),
task_name=obs_data.get("task_name"),
dataset_metadata=obs_data.get("dataset_metadata"),
done=payload.get("done", False),
reward=payload.get("reward"),
metadata=obs_data.get("metadata", {}),
)
return StepResult(
observation=observation,
reward=payload.get("reward"),
done=payload.get("done", False),
)
def _parse_state(self, payload: dict[str, Any]) -> State:
return State(
episode_id=payload.get("episode_id"),
step_count=payload.get("step_count", 0),
)