from enum import Enum


class ModelFamily(Enum):
    """Enum representing different model families"""
    TINYLLAMA = "TinyLlama"
    LLAMA2 = "llama2"
    LLAMA3 = "Llama-3"
    LLAMA31 = "Llama-3.1"
    LLAMA32 = "Llama-3.2"
    BLOOMZ = "Bloomz"
    GPT2 = "GPT2"
    OPT = "OPT"
    
class ModelSize(Enum):
    """Enum representing model sizes with actual parameter counts"""
    M125 = "125M"    # Opt 125M size
    M350 = "350M"    # Opt 350M size
    B1 = "1B"      # TinyLlama and Llama-3.2 tiny size
    B1_3 = "1.3B"   # Opt 1.3B size
    B2_7 = "2.7B"   # Opt 2.7B size
    B3 = "3B"      # Llama-3.2 small size
    B6_7 = "6.7B"   # Opt 6.7B size
    B7 = "7b"      # Llama-2 size
    B8 = "8B"      # Llama-3 and Llama-3.2 medium size
    B13 = "13B"    # Opt 13B size
    B70 = "70B"    # Llama-3 large size

    @classmethod
    def from_size(cls, size_str: str) -> 'ModelSize':
        """Get enum member from size string (e.g., '1B' -> B1)"""
        size_map = {
            "125M": cls.M125,
            "350M": cls.M350,
            "1B": cls.B1,
            "1.3B": cls.B1_3,
            "2.7B": cls.B2_7,
            "3B": cls.B3,
            "6.7B": cls.B6_7,
            "7B": cls.B7,
            "8B": cls.B8,
            "13B": cls.B13,
            "70B": cls.B70
        }
        return size_map.get(size_str)

    def to_string(self) -> str:
        """Convert to string format for model names (e.g., B1 -> '1b')"""
        string_map = {
            self.M125: "125m",
            self.M350: "350m",
            self.B1: "1b",
            self.B1_3: "1.3b",
            self.B2_7: "2.7b",
            self.B3: "3b",
            self.B6_7: "6.7b",
            self.B7: "7b",
            self.B8: "8b",
            self.B13: "13b",
            self.B70: "70b"
        }
        return string_map[self]

class QuantizationMethod(Enum):
    """Enum representing different quantization methods"""
    NONE = "NONE"
    AWQ = "AWQ"
    GPTQ = "GPTQ"
    AQLM = "AQLM"
    AQLM_PV = "AQLM-PV"
    HQQ = "HQQ"
    QUANTO = "QUANTO"
    BNB = "BNB"
    QUAROT = "QUAROT"
    QOQ = "QOQ"

class BitPrecision(Enum):
    """Enum representing different bit precisions for quantization"""
    FP32 = 32
    FP16 = 16
    INT8 = 8
    INT4 = 4
    INT3 = 3
    INT2 = 2
    INT1 = 1
    MIXED = 0  # For mixed precision
