#!/usr/bin/env python3
"""
Prompt Management System for AGI Research Assignment
Contains all prompts used during the research process
"""

# Original Assignment Prompt
ASSIGNMENT_PROMPT = """
Generate a complete research package for an AGI assignment, including:
1. A LaTeX paper (8 pages)
2. Python code implementation
3. Synthetic dataset generation
4. Experimental results
5. All required metadata files

Requirements:
- Multi-modal biometric authentication research
- Adversarial robustness focus
- Cross-Modal Adversarial Training (CMAT) framework
- Complete reproducibility package
- All grading rubric points covered for perfect score
"""

# Research Interview Prompt
RESEARCH_INTERVIEW_PROMPT = """
Research Interview Prompt with 100 questions across categories:
1. Introduction and Purpose (questions 1-5)
2. Problem Definition and Clarification (questions 6-15)
3. Domain and Subdomain Classification (questions 16-20)
4. Significance, Context, and Literature (questions 21-30)
5. Methodology, Approaches, and Requirements (questions 31-45)
6. Data, Resources, and Constraints (questions 46-55)
7. Evaluation, Metrics, and Success Criteria (questions 56-65)
8. Timeline, Collaboration, and Project Management (questions 66-75)
9. Brainstorming, Idea Generation, and Potential Approaches (questions 76-80)
10. Iterative Summarization, Confirmation, and Refinement (questions 81-85)
11. Writing Best Practices, Structure, and Communication (questions 86-90)
12. Reviewing, Feedback, and Rebuttal (questions 91-95)
13. Conclusions, Next Steps, and Final Confirmation (questions 96-100)
"""

# Best Research Practices Prompt
BEST_PRACTICES_PROMPT = """
Part A — Best practices for performing research:
1. Start right: scope, assumptions, success criteria
2. Design for reproducibility from day one
3. Literature & citations: integrity over speed
4. Experimentation: rigor that stands up to review
5. Responsible reporting & disclosure
6. Respect peer-review and venue policies
7. Packaging & submission hygiene
8. Domain-aware analysis and deployment thinking
9. Close the loop

Part B — An ethical research guide for an LLM:
- Safety & scope gate
- Clarify the task
- Plan your evidence
- Gather & attribute
- Analyze, don't copy
- Synthesize with uncertainty
- Transparency about AI assistance
- Respect privacy and IP
- Reproducibility mindset
- Final self-check before answering

Part C — Drop-in templates & checklists:
- Source log template
- Minimal reproducibility checklist
- AI contribution disclosure template
- Final submission bundle checklist
"""

# Paper Generation Prompts
PAPER_GENERATION_PROMPTS = {
    "abstract": "Generate a comprehensive abstract for a multi-modal biometric authentication paper focusing on adversarial robustness",
    "introduction": "Write an introduction section explaining the problem of adversarial attacks in multi-modal biometric systems",
    "related_work": "Create a related work section covering multi-modal biometrics, adversarial attacks, and cross-modal learning",
    "methodology": "Develop a detailed methodology section for the CMAT framework with mathematical formulations",
    "experiments": "Design experimental setup with dataset, baselines, and evaluation metrics",
    "results": "Generate comprehensive results section with tables, figures, and analysis",
    "conclusion": "Write a conclusion summarizing contributions and future work"
}

# Code Generation Prompts
CODE_GENERATION_PROMPTS = {
    "dataset": "Create a synthetic multi-modal biometric dataset generator with face, voice, and behavioral data",
    "preprocessor": "Implement data preprocessing pipeline for multi-modal biometric data",
    "model": "Design CMAT model architecture with cross-modal attention and adaptive fusion",
    "trainer": "Create training framework with adversarial training and custom loss functions",
    "evaluator": "Implement comprehensive evaluation metrics and analysis tools",
    "experiments": "Build main experiment runner orchestrating the entire pipeline"
}

# Figure Generation Prompts
FIGURE_GENERATION_PROMPTS = {
    "architecture": "Generate model architecture diagram showing CMAT framework components",
    "attention": "Create cross-modal attention mechanism visualization with heatmaps",
    "training": "Plot training curves showing loss, accuracy, and learning rate schedules",
    "confusion": "Generate confusion matrix for multi-user classification results",
    "ablation": "Create ablation study results showing component contributions",
    "security": "Plot security analysis showing attack success rates and robustness"
}

# Evaluation Prompts
EVALUATION_PROMPTS = {
    "metrics": "Calculate comprehensive evaluation metrics including accuracy, adversarial accuracy, and latency",
    "baselines": "Compare CMAT performance against ResNet-50, VGG-16, LSTM, and multi-modal baselines",
    "ablation": "Perform ablation studies on attention mechanisms, fusion strategies, and adversarial training",
    "security": "Analyze security robustness against FGSM, PGD, C&W, and DeepFool attacks"
}

# Documentation Prompts
DOCUMENTATION_PROMPTS = {
    "readme": "Create comprehensive README with setup, usage, and reproduction instructions",
    "metadata": "Generate research metadata including authors, abstract, venue, and technical specifications",
    "ai_contrib": "Document AI contributions to research process with detailed breakdown",
    "checklist": "Create compliance checklist for conference submission requirements"
}

# Quality Assurance Prompts
QA_PROMPTS = {
    "review": "Review generated content for accuracy, completeness, and academic standards",
    "formatting": "Ensure proper LaTeX formatting, citations, and figure references",
    "compliance": "Verify all conference requirements and submission guidelines are met",
    "reproducibility": "Check that all code, data, and results are reproducible"
}

def get_prompt(category, prompt_type):
    """Get a specific prompt by category and type"""
    prompts = {
        "paper": PAPER_GENERATION_PROMPTS,
        "code": CODE_GENERATION_PROMPTS,
        "figure": FIGURE_GENERATION_PROMPTS,
        "evaluation": EVALUATION_PROMPTS,
        "documentation": DOCUMENTATION_PROMPTS,
        "qa": QA_PROMPTS
    }
    
    if category in prompts and prompt_type in prompts[category]:
        return prompts[category][prompt_type]
    else:
        return f"Prompt not found for category: {category}, type: {prompt_type}"

def list_all_prompts():
    """List all available prompts"""
    all_prompts = {
        "assignment": ASSIGNMENT_PROMPT,
        "research_interview": RESEARCH_INTERVIEW_PROMPT,
        "best_practices": BEST_PRACTICES_PROMPT,
        **PAPER_GENERATION_PROMPTS,
        **CODE_GENERATION_PROMPTS,
        **FIGURE_GENERATION_PROMPTS,
        **EVALUATION_PROMPTS,
        **DOCUMENTATION_PROMPTS,
        **QA_PROMPTS
    }
    return all_prompts

if __name__ == "__main__":
    print("AGI Research Assignment - Prompt Management System")
    print("=" * 50)
    print(f"Total prompts available: {len(list_all_prompts())}")
    print("\nCategories:")
    print("- assignment: Main assignment prompt")
    print("- research_interview: 100-question research interview")
    print("- best_practices: Research best practices guide")
    print("- paper: Paper generation prompts")
    print("- code: Code generation prompts")
    print("- figure: Figure generation prompts")
    print("- evaluation: Evaluation and analysis prompts")
    print("- documentation: Documentation prompts")
    print("- qa: Quality assurance prompts")
