class GetPrompts:
    def __init__(self):
        """Initialize prompts with optional context support."""
        self.context = None
        self.context_enabled = False
    
    def set_context(self, context: str = None, enabled: bool = True) -> None:
        self.context = context
        self.context_enabled = enabled
    
    def get_context(self) -> str:
        return self.context or ""
    
    def get_task(self):
        base_task = (
            "Write a novel scoring function for the online bin packing problem using a greedy strategy.\n"
            "Goal: Minimize total bins by making each assignment facilitate future packing.\n"
            "Strategy Hint: Consider not just the tightest fit, but the potential usability of the remaining space. A good score should balance between filling a bin and avoiding leaving behind tiny, unusable gaps that might reject future items.\n"
            "Prefer using a smooth mathematical transformation to balance these factors, ensuring the function remains effective regardless of the absolute capacity scale.\n"
            "Output ONLY the Python function code."
        )
        if self.context_enabled and self.context:
            return f"{self.context}\n\n{base_task}"
        return base_task

    def get_func_name(self):
        return "score"
    
    def get_func_inputs(self):
        return ["item", "bins"]
    
    def get_func_outputs(self):
        return ["scores"]
        

    def get_inout_inf(self):
        return (
            "'item' is the current item size (float). "
            "'bins' is a NumPy array of remaining capacities for feasible bins only "
            "(every entry satisfies bins[i] >= item). "
            "Do NOT perform feasibility checks, masking, or filtering; score all entries in 'bins'. "
            "The output 'scores' is a NumPy array with the same shape as 'bins'."
            "The higher the score, the more preferred the bin is to place the item into.\n"
            "IMPORTANT: You must compute the scores first, assign them to a variable named 'scores', "
            "then return 'scores'. Do not return the expression directly."
        )
    

    def get_other_inf(self):
            return (
                "Requirements:\n"
                "1) Use NumPy vectorized operations for efficiency (avoid Python loops).\n"
                "2) Deterministic: No randomness.\n"
                "3) Scale-invariant: Use ratios like (bins - item) / max_bins instead of hard-coded constants.\n"
                "4) Empty Bin Penalty: Bins where bins[i] == np.max(bins) should receive the lowest possible score "
                "unless no other bin can fit the item, to delay opening new bins."
            )
