def generate_unanswerable_prompts():
    prompts = {
        "v2": {
            "qs":  "Generate multiple-choice questions based on this picture that cannot be answered by any external knowledge or inference beyond the image itself. Consider the following guidelines:\n \
        (1) The question theme should be highly relevant to the picture, but no external knowledge or information outside the image can help answer it.\n \
        (2) The question should be framed in a way that the answer cannot be inferred from context, historical knowledge, or common assumptions.\n \
        (3) All options should have no basis in the image.\n \
        (4) The correct option must be impossible to verify or answer, even with external knowledge.\n \
        (5) Avoid including options such as \"cannot determine\", \"unclear\", \"Unanswerable\", \"unknow\" or any ambiguous terms.\n \
        (6) The question should not contain words like \"possible\", \"likely\" or imply uncertainty in any way.", 

            "context": "Format example: \n Question: [The question related to the picture but unsolvable]\n A. [Option with no basis]\n B. [Option with no basis]\n C. [Option with no basis]\n D. [Option with no basis] \
                Please generate 10 questions and corresponding options but do not answer:"
        },
        "v4": {
            "qs" : "Given an image, generate several questions that satisfy all of the following conditions:\
                    (1) Clearly relate to the content of the image.\
                    (2) Are clear and easy to understand.\
                    (3) You are completely unable to answer these questions, even using the image content, external knowledge, or any additional context.\
                    (4)  The question should not contain words like \"possible\", \"likely\" or imply uncertainty in any way.\
                    ",
            "context":"Please provide 10 high-quality questions but do not answer:"
            }
    }
    return prompts

def generate_answerable_prompts():
    prompts = {
        "v2": { 
            "qs": "Generate multiple-choice questions based on a picture that can be answered by analyzing the image itself or by applying well-known facts. Follow these guidelines:\
                    (1) The question theme should be highly relevant to the picture, and the answer must be deducible directly from the image details or common knowledge.\
                    (2) The question should be framed so that the answer is clearly inferable from observable features, historical context, or widely accepted facts.\
                    (3) All options should be grounded in observable elements of the image or in universally recognized information.\
                    (4) The correct option must be verifiable through direct observation of the image or through standard external knowledge.\
                    ",

            "context": "Format example: \n Question: [The question related to the picture with an answer derivable from it] \n \
                        A. [Option clearly supported by the image or known facts]\n \
                        B. [Option clearly supported by the image or known facts]\n \
                        C. [Option clearly supported by the image or known facts]\n \
                        D. [Option clearly supported by the image or known facts]\n \
                       Please generate 10 questions and corresponding options but do not answer."
        },
        "v4": { 
           "qs": "Given an image, your task is to produce several clear and specific questions that can be answered directly from observing the details within the image.\
                Make sure each question you generate meets the following criteria:\
                (1) Clearly relates to visible elements, such as objects, people, scenes, actions, or events depicted.\
                (2) Can be answered exclusively using the image itself, without external knowledge or assumptions.\
                (3) Is precise, understandable, and well-formulated.\
                (4) Varies in type, such as object attributes, actions, spatial relationships, quantities, colors, or plausible events occurring in the scene.",
            "context": "Please provide 10 high-quality questions but do not answer."
        }
    }
    return prompts



def generate_k_unanswerable_prompts(k):   
    prompts = {
        "v2": {
            "qs":  "Generate multiple-choice questions based on this picture that cannot be answered by any external knowledge or inference beyond the image itself. Consider the following guidelines:\n \
        (1) The question theme should be highly relevant to the picture, but no external knowledge or information outside the image can help answer it.\n \
        (2) The question should be framed in a way that the answer cannot be inferred from context, historical knowledge, or common assumptions.\n \
        (3) All options should have no basis in the image.\n \
        (4) The correct option must be impossible to verify or answer, even with external knowledge.\n \
        (5) Avoid including options such as \"cannot determine\", \"unclear\", \"unknow\" or any ambiguous terms.\n \
        (6) The question should not contain words like \"possible\", \"likely\" or imply uncertainty in any way.", 

            "context": f"Format example: \n Question: [The question related to the picture but unsolvable]\n A. [Option with no basis]\n B. [Option with no basis]\n C. [Option with no basis]\n D. [Option with no basis] \
                Please generate {k} questions and corresponding four options but do not answer:"
        },
        "v4": {
            "qs" : "Given an image, generate several questions that satisfy all of the following conditions:\
                    (1) Clearly relate to the content of the image.\
                    (2) Are clear and easy to understand.\
                    (3) You are completely unable to answer these questions, even using the image content, external knowledge, or any additional context.\
                    (4)  The question should not contain words like \"possible\", \"likely\" or imply uncertainty in any way.\
                    ",
            "context":f"Please provide {k} high-quality questions but do not answer:"
            } 
    }
    return prompts

def generate_k_answerable_prompts(k):
    prompts = {
        "v2": { 
            "qs": "Generate multiple-choice questions based on a picture that can be answered by analyzing the image itself or by applying well-known facts. Follow these guidelines:\
                    (1) The question theme should be highly relevant to the picture, and the answer must be deducible directly from the image details or common knowledge.\
                    (2) The question should be framed so that the answer is clearly inferable from observable features, historical context, or widely accepted facts.\
                    (3) All options should be grounded in observable elements of the image or in universally recognized information.\
                    (4) The correct option must be verifiable through direct observation of the image or through standard external knowledge.\
                    ",

            "context": f"Format example: \n Question: [The question related to the picture with an answer derivable from it] \n \
                        A. [Option clearly supported by the image or known facts]\n \
                        B. [Option clearly supported by the image or known facts]\n \
                        C. [Option clearly supported by the image or known facts]\n \
                        D. [Option clearly supported by the image or known facts]\n \
                       Please generate {k} questions and corresponding four options but do not answer."
        },
        "v4": {
           "qs": "Given an image, your task is to produce several clear and specific questions that can be answered directly from observing the details within the image.\
                Make sure each question you generate meets the following criteria:\
                (1) Clearly relates to visible elements, such as objects, people, scenes, actions, or events depicted.\
                (2) Can be answered exclusively using the image itself, without external knowledge or assumptions.\
                (3) Is precise, understandable, and well-formulated.\
                (4) Varies in type, such as object attributes, actions, spatial relationships, quantities, colors, or plausible events occurring in the scene.",
            "context": f"Please provide {k} high-quality questions but do not answer"
        }
    }
    return prompts