# rl_framework/algo/base.py
from abc import ABC, abstractmethod


class BaseAgent(ABC):
    """Common interface that all algorithms should implement."""

    def __init__(self, env, args):
        self.env = env
        self.args = args

    @abstractmethod
    def act(self, obs, evaluate: bool = False):
        """Select an action given a single observation."""
        raise NotImplementedError

    @abstractmethod
    def store_transition(self, obs, action, reward, next_obs, done):
        """Store one transition into the buffer / trajectory."""
        raise NotImplementedError

    @abstractmethod
    def update(self):
        """Perform one (potential) gradient update step."""
        raise NotImplementedError

    # Optional: save / load, etc.
    def save(self, path: str):
        pass

    def load(self, path: str):
        pass
