from openai import OpenAI
import pandas as pd
import re
import time
from concurrent.futures import ThreadPoolExecutor, as_completed
import os
import random
import tqdm

Model_name = "deepseek-ai/DeepSeek-R1-0528"

def clean_response(text):
    # Remove <think> tags and their content
    return re.sub(r'<think>.*?</think>', '', text, flags=re.DOTALL)

def get_features(s):
    # remove consecutive spaces, newlines, tabs in the middle and in the beginning / end
    s = re.sub(r"\s+", " ", s.strip())
    return s

def extract_triple_single_quote_code(text):
    # Regex pattern to match content inside ''' '''
    pattern = r"```python\n(.*?)```"
    matches = re.findall(pattern, text, re.DOTALL)
    return matches

def extract_triple_single_quote_json(text):
    # Regex pattern to match content inside ''' '''
    pattern = r"```json\n(.*?)```"
    matches = re.findall(pattern, text, re.DOTALL)
    return matches


def get_prompt(content, index):
    system_prompt = f"""
You are an expert computational physicist specializing in scientific visualization and simulation. 
You also an excellent programmer.
Your expertise includes creating educational physics simulations that effectively communicate complex physical phenomena to diverse audiences.
"""

    
    user_prompt = f"""

Your task is to create a Python script that generates an educational physics simulation video. This video will be used in educational settings to help students visualize and understand physical processes.

Given a description of a physical process in { content }, write a Python script that creates a simulation video. The video will be saved as "{ index }.mp4" in the current working directory. Return the code only.

The video should meet the following requirements:

1. Use clear and distinct colors to represent different objects, trajectories, or forces.
2. Overlay a real-time timestamp that updates continuously throughout the simulation.
3. Display all relevant parameter values (e.g., gravity, speed, angle) clearly on the screen.
4. Ensure the camera view is wide enough to fully capture the entire motion, adjusting dynamically if needed. Ensure the camera view is the best view for the simulation to let the viewer see the whole process.
5. Provide smooth and continuous animation at a consistent frame rate (30 FPS).
6. Maintain a clean, uncluttered visual style with minimal distractions and a neutral background.
7. Keep the video duration between 10 and 20 seconds, slow enough to allow viewers to observe and understand the key transitions.
8. Save the output as an MP4 video in a suitable resolution (at least 360p).
9. When the process is finish, the video should finish also.
10. Use OpenCV to generate the video, and ensure the code is correct, complete, and runnable without any errors.

Focus on clarity, interpretability, and visual appeal to make the video intuitive and easy to understand for both technical and non-technical audiences.

Physics Simulation:
- Implement precise physical equations
- Use appropriate time steps for smooth motion
- Include relevant force vectors and trajectories

The final code should:
1. Initialize all necessary libraries and variables
2. Set up the video writer with specified parameters
3. Implement the physics calculations
4. Create and save the animation
5. Include error handling and resource cleanup

Ensure the code follows PEP 8 style guidelines and includes comments explaining key components. The simulation should prioritize educational value while maintaining scientific accuracy.
"""

    
    return system_prompt, user_prompt
    
def get_model_response(model,content,index):
    system_prompt, user_prompt = get_prompt(content,index)
    try:
        completion = client.chat.completions.create(
            model=Model_name,
            messages=[
                {"role": "system", "content": system_prompt},
                {"role": "user", "content": user_prompt}
            ]
            
        )
        response = completion.choices[0].message.content
        cleaned_response = get_features(clean_response(response))
        code = extract_triple_single_quote_code(response)
        questions = extract_triple_single_quote_json(response)
        return index, model, content, response, code, questions 
    except Exception as e:
        print(f"Error getting response from {model} for row {index}: {str(e)}")
        return index, model, content, "", ""


content = 'Inside a transparent rectangular acrylic container,\
            a vivid yellow steel ball weighing 1.2 kg is released from the top of a 2-meter-long inclined\
            copper plane set at a 35-degree angle. The container is placed just 100 meters from a massive\
            underground iron ore deposit, increasing the local gravitational acceleration slightly to 9.92 m/s².\
            The ball begins its descent on the polished, nearly frictionless copper surface, producing no resistance.\
            As it accelerates, its motion is tracked by thin blue trajectory lines, clearly diverging from a standard parabolic\
            curve due to the stronger gravitational pull. Midway down the plane, the ball passes over a sensor embedded in the slope that\
            lights up as the speed crosses 5 m/s. The process unfolds slowly enough to observe how gravity enhancement subtly alters the\
            timing and velocity at key checkpoints.'
index, model, content_return, response,code,questions = get_model_response(Model_name, content,  0)
print(response)
print("--------------------------------")
print(questions)

exec(code[0])
