from enum import Enum


class AdvantageEstimator(str, Enum):
    """
    Using an enumeration class to avoid spelling errors in adv_estimator
    """

    GAE = "gae"
    GRPO = "grpo"
    REINFORCE_PLUS_PLUS = "reinforce_plus_plus"
    REINFORCE_PLUS_PLUS_BASELINE = "reinforce_plus_plus_baseline"
    REMAX = "remax"
    RLOO = "rloo"
    OPO = "opo"
    GRPO_PASSK = "grpo_passk"
    CPGD = "cpgd"
    GAE_MARFT = "gae_marft"


class WorkflowType(str, Enum):
    DEFAULT = "default"
    DAPO = "dapo"
    EMBODIED = "embodied"


class Role(Enum):
    """
    To create more roles dynamically, you can subclass Role and add new members
    """

    Actor = 0
    Rollout = 1
    ActorRollout = 2
    Critic = 3
    RefPolicy = 4
    RewardModel = 5
    ActorRolloutRef = 6


class AlgorithmType(Enum):
    """
    Enum to represent different algorithm types.
    """

    PPO = "ppo"
    GRPO = "grpo"
    DAPO = "dapo"
    REINFORCE_PLUS_PLUS = "reinforce_plus_plus"
    REMAX = "remax"
    RLOO = "rloo"
    OPO = "opo"
    GRPO_PASSK = "grpo_passk"
    CPGD = "cpgd"
    REINFORCE_PLUS_PLUS_BASELINE = "reinforce_plus_plus_baseline"
