{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b92a2254",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import time\n",
    "import os\n",
    "\n",
    "from google import genai\n",
    "from google.genai import types\n",
    "from dotenv import load_dotenv\n",
    "from openai import OpenAI\n",
    "from pathlib import Path\n",
    "\n",
    "import concurrent.futures\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3c1c12fe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Load .env file from the parent directory\n",
    "env_path = \".env\"\n",
    "load_dotenv(dotenv_path=env_path)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "014cd7fe",
   "metadata": {},
   "source": [
    "# Gemini"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c17e6aef",
   "metadata": {},
   "outputs": [],
   "source": [
    "# os.environ.get(\"GEMINI_API_KEY\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "ce1f7808",
   "metadata": {},
   "outputs": [],
   "source": [
    "client = genai.Client(api_key=os.environ.get(\"GEMINI_API_KEY\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "```python\n",
      "import pandas as pd\n",
      "from datetime import datetime, timedelta\n",
      "\n",
      "# Create a sample DataFrame for demonstration\n",
      "data = {\n",
      "    'OrderID': [1, 2, 3, 4, 5, 6, 7, 8, 9, 10],\n",
      "    'CustomerID': [101, 102, 101, 103, 102, 104, 105, 101, 103, 106],\n",
      "    'OrderDate': [\n",
      "        datetime(2023, 1, 5),\n",
      "        datetime(2023, 1, 10),\n",
      "        datetime(2023, 1, 15),\n",
      "        datetime(2023, 2, 1),\n",
      "        datetime(2023, 2, 5),\n",
      "        datetime(2023, 2, 10),\n",
      "        datetime(2023, 2, 15),\n",
      "        datetime(2023, 3, 1),\n",
      "        datetime(2023, 3, 5),\n",
      "        datetime(2023, 3, 10),\n",
      "    ],\n",
      "    'TotalAmount': [100.50, 200.00, 150.75, 50.00, 300.00, 75.25, 120.00, 180.50, 250.00, 90.00],\n",
      "    'OrderStatus': ['Completed', 'Pending', 'Completed', 'Completed', 'Pending', 'Completed', 'Completed', 'Pending', 'Completed', 'Completed']\n",
      "}\n",
      "df = pd.DataFrame(data)\n",
      "\n",
      "print(\"Original DataFrame:\")\n",
      "print(df)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 1. Filter rows where 'TotalAmount' is greater than 150\n",
      "filtered_df_amount = df[df['TotalAmount'] > 150]\n",
      "print(\"1. Orders with TotalAmount > 150:\")\n",
      "print(filtered_df_amount)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 2. Filter rows where 'OrderStatus' is 'Completed'\n",
      "filtered_df_status = df[df['OrderStatus'] == 'Completed']\n",
      "print(\"2. Orders with OrderStatus 'Completed':\")\n",
      "print(filtered_df_status)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 3. Filter rows based on multiple conditions (e.g., 'TotalAmount' > 100 AND 'OrderStatus' == 'Completed')\n",
      "filtered_df_multiple = df[(df['TotalAmount'] > 100) & (df['OrderStatus'] == 'Completed')]\n",
      "print(\"3. Orders with TotalAmount > 100 AND OrderStatus 'Completed':\")\n",
      "print(filtered_df_multiple)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 4. Filter rows where 'CustomerID' is either 101 or 103\n",
      "filtered_df_customers = df[df['CustomerID'].isin([101, 103])]\n",
      "print(\"4. Orders from CustomerID 101 or 103:\")\n",
      "print(filtered_df_customers)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 5. Filter rows based on a date range (e.g., orders in February 2023)\n",
      "start_date = datetime(2023, 2, 1)\n",
      "end_date = datetime(2023, 2, 28, 23, 59, 59) # To include the entire last day\n",
      "filtered_df_date_range = df[(df['OrderDate'] >= start_date) & (df['OrderDate'] <= end_date)]\n",
      "print(\"5. Orders in February 2023:\")\n",
      "print(filtered_df_date_range)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 6. Filter rows where a string column contains a specific substring (if applicable)\n",
      "# Let's add a 'Product' column to demonstrate this\n",
      "df['Product'] = ['Laptop', 'Keyboard', 'Mouse', 'Monitor', 'Laptop', 'Webcam', 'Headphones', 'Laptop', 'Desk', 'Chair']\n",
      "filtered_df_product = df[df['Product'].str.contains('Laptop', na=False)]\n",
      "print(\"6. Orders containing 'Laptop' in the Product name:\")\n",
      "print(filtered_df_product)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 7. Filter rows based on negation (e.g., 'OrderStatus' is NOT 'Pending')\n",
      "filtered_df_not_pending = df[df['OrderStatus'] != 'Pending']\n",
      "print(\"7. Orders where OrderStatus is NOT 'Pending':\")\n",
      "print(filtered_df_not_pending)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 8. Filter rows with a null or non-null value (let's introduce some NaNs)\n",
      "df_with_nan = df.copy()\n",
      "df_with_nan.loc[2, 'TotalAmount'] = None\n",
      "df_with_nan.loc[7, 'OrderStatus'] = None\n",
      "\n",
      "print(\"DataFrame with NaNs:\")\n",
      "print(df_with_nan)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Filter rows where 'TotalAmount' is not null\n",
      "filtered_df_not_null = df_with_nan[df_with_nan['TotalAmount'].notna()]\n",
      "print(\"8a. Orders where TotalAmount is NOT null:\")\n",
      "print(filtered_df_not_null)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Filter rows where 'OrderStatus' is null\n",
      "filtered_df_is_null = df_with_nan[df_with_nan['OrderStatus'].isna()]\n",
      "print(\"8b. Orders where OrderStatus IS null:\")\n",
      "print(filtered_df_is_null)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Using `query()` method for more readable filtering (especially with complex conditions)\n",
      "# 9. Filter using query() method for TotalAmount > 150\n",
      "filtered_df_query_amount = df.query('TotalAmount > 150')\n",
      "print(\"9. Orders with TotalAmount > 150 (using query()):\")\n",
      "print(filtered_df_query_amount)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 10. Filter using query() for multiple conditions\n",
      "filtered_df_query_multiple = df.query('TotalAmount > 100 and OrderStatus == \"Completed\"')\n",
      "print(\"10. Orders with TotalAmount > 100 AND OrderStatus 'Completed' (using query()):\")\n",
      "print(filtered_df_query_multiple)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 11. Filtering by index (e.g., getting specific rows by integer location)\n",
      "# Get the first 3 rows\n",
      "filtered_df_iloc = df.iloc[0:3]\n",
      "print(\"11. First 3 rows using iloc:\")\n",
      "print(filtered_df_iloc)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Get rows with specific indices (e.g., 1, 5, 8)\n",
      "filtered_df_iloc_specific = df.iloc[[1, 5, 8]]\n",
      "print(\"11a. Rows with specific integer locations (1, 5, 8) using iloc:\")\n",
      "print(filtered_df_iloc_specific)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# 12. Filtering by label (if using a non-default index)\n",
      "# Let's set 'OrderID' as the index\n",
      "df_indexed = df.set_index('OrderID')\n",
      "print(\"DataFrame with OrderID as index:\")\n",
      "print(df_indexed)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Get rows where index labels are 2, 7, 9\n",
      "filtered_df_loc_specific = df_indexed.loc[[2, 7, 9]]\n",
      "print(\"12. Rows with specific index labels (2, 7, 9) using loc:\")\n",
      "print(filtered_df_loc_specific)\n",
      "print(\"-\" * 30)\n",
      "\n",
      "# Get a range of index labels (inclusive)\n",
      "filtered_df_loc_range = df_indexed.loc[3:7] # Includes index 3, 4, 5, 6, 7\n",
      "print(\"12a. Rows with index labels from 3 to 7 (inclusive) using loc:\")\n",
      "print(filtered_df_loc_range)\n",
      "print(\"-\" * 30)\n",
      "```"
     ]
    }
   ],
   "source": [
    "model = \"gemini-2.5-flash\"\n",
    "contents = [\n",
    "    types.Content(\n",
    "        role=\"user\",\n",
    "        parts=[\n",
    "            types.Part.from_text(text=\"\"\"INSERT_INPUT_HERE\"\"\"),\n",
    "        ],\n",
    "    ),\n",
    "]\n",
    "generate_content_config = types.GenerateContentConfig(\n",
    "    thinking_config = types.ThinkingConfig(\n",
    "        thinking_budget=0,\n",
    "    ),\n",
    ")\n",
    "\n",
    "for chunk in client.models.generate_content_stream(\n",
    "    model=model,\n",
    "    contents=contents,\n",
    "    config=generate_content_config,\n",
    "):\n",
    "    print(chunk.text, end=\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "f064f9dc",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'Markdown' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[8], line 12\u001b[0m\n\u001b[1;32m      1\u001b[0m prompt \u001b[38;5;241m=\u001b[39m \u001b[38;5;124m\"\"\"\u001b[39m\n\u001b[1;32m      2\u001b[0m \u001b[38;5;124m    You are playing the 20 question game. You know that what you are looking for\u001b[39m\n\u001b[1;32m      3\u001b[0m \u001b[38;5;124m    is a aquatic mammal that doesn\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mt live in the sea, is venomous and that\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124ms\u001b[39m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;124m    smaller than a cat. What could that be and how could you make sure?\u001b[39m\n\u001b[1;32m      5\u001b[0m \u001b[38;5;124m\"\"\"\u001b[39m\n\u001b[1;32m      7\u001b[0m response \u001b[38;5;241m=\u001b[39m client\u001b[38;5;241m.\u001b[39mmodels\u001b[38;5;241m.\u001b[39mgenerate_content(\n\u001b[1;32m      8\u001b[0m     model\u001b[38;5;241m=\u001b[39mmodel,\n\u001b[1;32m      9\u001b[0m     contents\u001b[38;5;241m=\u001b[39mprompt\n\u001b[1;32m     10\u001b[0m )\n\u001b[0;32m---> 12\u001b[0m \u001b[43mMarkdown\u001b[49m(response\u001b[38;5;241m.\u001b[39mtext)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'Markdown' is not defined"
     ]
    }
   ],
   "source": [
    "prompt = \"\"\"\n",
    "    You are playing the 20 question game. You know that what you are looking for\n",
    "    is a aquatic mammal that doesn't live in the sea, is venomous and that's\n",
    "    smaller than a cat. What could that be and how could you make sure?\n",
    "\"\"\"\n",
    "\n",
    "response = client.models.generate_content(\n",
    "    model=model,\n",
    "    contents=prompt\n",
    ")\n",
    "\n",
    "Markdown(response.text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "322a74a5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt tokens: 62\n",
      "Thoughts tokens: 1680\n",
      "Output tokens: 726\n",
      "Total tokens: 2468\n"
     ]
    }
   ],
   "source": [
    "print(\"Prompt tokens:\",response.usage_metadata.prompt_token_count)\n",
    "print(\"Thoughts tokens:\",response.usage_metadata.thoughts_token_count)\n",
    "print(\"Output tokens:\",response.usage_metadata.candidates_token_count)\n",
    "print(\"Total tokens:\",response.usage_metadata.total_token_count)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b624a0e",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7542f224",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a30c8cfc",
   "metadata": {},
   "outputs": [],
   "source": [
    "def generate(model_id, tokens_limit, system_instruction, user_instruction):\n",
    "    client = genai.Client(\n",
    "        api_key=os.environ.get(\"GEMINI_API_KEY\"),\n",
    "    )\n",
    "\n",
    "    contents = [\n",
    "        types.Content(\n",
    "            role=\"user\",\n",
    "            parts=[\n",
    "                types.Part.from_text(text=user_instruction)\n",
    "            ],\n",
    "        ),\n",
    "    ]\n",
    "    generate_content_config = types.GenerateContentConfig(\n",
    "        thinking_config = types.ThinkingConfig(\n",
    "            thinking_budget=tokens_limit,\n",
    "        ),\n",
    "        response_mime_type=\"text/plain\",\n",
    "        system_instruction=[\n",
    "            types.Part.from_text(text=system_instruction),\n",
    "        ],\n",
    "    )\n",
    "\n",
    "    response = client.models.generate_content(\n",
    "        model=model_id,\n",
    "        contents=contents,\n",
    "        config=generate_content_config,\n",
    "    )\n",
    "    \n",
    "    return response.text"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8414b3e1",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7e9b9cd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_jsonl(file_path):\n",
    "    with open(file_path, \"r\") as file:\n",
    "        for line in file:\n",
    "            yield json.loads(line.strip())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "67d18a48",
   "metadata": {},
   "outputs": [],
   "source": [
    "base_input_path = \"/home/rodionfa/FloorplanQA/qa_jsonl/{dataset}/{room_type}/{model_id}_{max_tokens}.jsonl\"\n",
    "base_gemini_path = \"/home/rodionfa/FloorplanQA/qa_jsonl/{dataset}/{room_type}/{model_id}_{max_tokens}_gemini.jsonl\"\n",
    "base_output_path = \"/home/rodionfa/FloorplanQA/qa_response/{dataset}/{room_type}/{model_id}_{max_tokens}.jsonl\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "c8e86069",
   "metadata": {},
   "outputs": [],
   "source": [
    "models_list = [\n",
    "    # (12288 ,\"gemini-2.5-flash\")\n",
    "    (12288, \"gemini-2.5-pro\"),\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "362638e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# room_types = [\"hssd_data\"]\n",
    "room_types = [\"living_rooms\", \"bedrooms\", \"kitchens\", \"hssd_data_simplified\"]\n",
    "\n",
    "datasets = [\n",
    "    # \"shortest_path\",\n",
    "    # \"obstruction\",\n",
    "    # \"view_angle\",\n",
    "    # \"max_box\",\n",
    "    \"free_space\",\n",
    "    # \"pair_distance\",\n",
    "    \"placement\",\n",
    "    # \"repositioning\",\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "a04bee1c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Processing dataset: pair_distance, room type: living_rooms, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/living_rooms/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/living_rooms/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: pair_distance, room type: bedrooms, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/bedrooms/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/bedrooms/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: pair_distance, room type: kitchens, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/kitchens/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/kitchens/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: pair_distance, room type: hssd_data_simplified, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/hssd_data_simplified/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/hssd_data_simplified/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: repositioning, room type: living_rooms, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/living_rooms/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/living_rooms/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: repositioning, room type: bedrooms, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/bedrooms/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/bedrooms/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: repositioning, room type: kitchens, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/kitchens/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/kitchens/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n",
      "Processing dataset: repositioning, room type: hssd_data_simplified, model: gemini-2.5-pro, tokens limit: 12288\n",
      "12288 12288 0.0\n",
      "Converted '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/hssd_data_simplified/gemini-2.5-pro_12288.jsonl' to '/home/rodionfa/FloorplanQA/qa_jsonl/repositioning/hssd_data_simplified/gemini-2.5-pro_12288_gemini.jsonl' for Gemini batch processing.\n"
     ]
    }
   ],
   "source": [
    "def convert_openai_to_gemini_batch_input(input_filepath, output_filepath):\n",
    "    with open(input_filepath, 'r') as infile, open(output_filepath, 'w') as outfile:\n",
    "        for line in infile:\n",
    "            openai_request = json.loads(line)\n",
    "            \n",
    "            gemini_request_body = {}\n",
    "            \n",
    "            # Extract custom_id\n",
    "            if 'custom_id' in openai_request:\n",
    "                gemini_request_body['key'] = openai_request['custom_id']\n",
    "            \n",
    "            gemini_generate_content_request = {}\n",
    "            \n",
    "            # Extract messages and separate system instruction\n",
    "            messages = openai_request['body']['messages']\n",
    "            user_contents = []\n",
    "            system_instruction_text = None\n",
    "            \n",
    "            for message in messages:\n",
    "                if message['role'] == 'system':\n",
    "                    system_instruction_text = message['content']\n",
    "                elif message['role'] == 'user':\n",
    "                    user_contents.append({'parts': [{'text': message['content']}]})\n",
    "            \n",
    "            if system_instruction_text:\n",
    "                gemini_generate_content_request['system_instruction'] = {\n",
    "                    'parts': [{'text': system_instruction_text}]\n",
    "                }\n",
    "\n",
    "            gemini_generate_content_request['contents'] = user_contents\n",
    "\n",
    "            max_tokens = openai_request['body']['max_tokens']\n",
    "            temperature = openai_request['body']['temperature']\n",
    "\n",
    "            # thinking_budget = 5 / 6 * max_tokens\n",
    "            # max_output_tokens = 1 / 6 * max_tokens\n",
    "\n",
    "            gemini_generate_content_request['generation_config'] = {\n",
    "                # This is the fix: max_output_tokens should be your desired output length.\n",
    "                'max_output_tokens': max_tokens,\n",
    "                'temperature': temperature,\n",
    "                # 'thinking_config': {\n",
    "                #     'thinking_budget': thinking_budget\n",
    "                # }\n",
    "            }\n",
    "            # Final wrapping\n",
    "            gemini_request_body['request'] = gemini_generate_content_request\n",
    "            \n",
    "            outfile.write(json.dumps(gemini_request_body) + '\\n')\n",
    "        # print(max_tokens, thinking_budget, max_output_tokens, temperature)\n",
    "        print(max_tokens, max_tokens, temperature)\n",
    "\n",
    "for tokens_limit, model_id in models_list:\n",
    "    for dataset in datasets:\n",
    "        for room_type in room_types:\n",
    "            print(f\"Processing dataset: {dataset}, room type: {room_type}, model: {model_id}, tokens limit: {tokens_limit}\")\n",
    "\n",
    "            input_file = base_input_path.format(\n",
    "                dataset=dataset,\n",
    "                room_type=room_type,\n",
    "                model_id=model_id,\n",
    "                max_tokens=tokens_limit\n",
    "            )\n",
    "\n",
    "            output_file = base_gemini_path.format(\n",
    "                dataset=dataset,\n",
    "                room_type=room_type,\n",
    "                model_id=model_id,\n",
    "                max_tokens=tokens_limit\n",
    "            )\n",
    "            convert_openai_to_gemini_batch_input(input_file, output_file)\n",
    "            print(f\"Converted '{input_file}' to '{output_file}' for Gemini batch processing.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6964ce53",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "id": "d97b3a7e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# input_file = base_input_path.format(\n",
    "#     dataset=dataset,\n",
    "#     room_type=room_type,\n",
    "#     model_id=model_id,\n",
    "#     max_tokens=tokens_limit\n",
    "# )\n",
    "\n",
    "# output_file = base_gemini_path.format(\n",
    "#     dataset=dataset,\n",
    "#     room_type=room_type,\n",
    "#     model_id=model_id,\n",
    "#     max_tokens=tokens_limit\n",
    "# )\n",
    "# convert_openai_to_gemini_batch_input(input_file, output_file)\n",
    "# print(f\"Converted '{input_file}' to '{output_file}' for Gemini batch processing.\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "ce598ac2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Uploaded file: files/onpr82qiit0l\n",
      "Created batch job: batches/harn2y5f81ak5nphg4pce3ipbx1nraau5y8s\n",
      "Uploaded file: files/mjuoas8pj2sk\n",
      "Created batch job: batches/9n4lqjowdmlxrljv09z7tylmtl1vro2kcgfe\n",
      "Uploaded file: files/47uuv4wp8i7v\n",
      "Created batch job: batches/dzm5ndy7um65u92nhvbiyab98xcb0na8vg5n\n",
      "Uploaded file: files/2eykdehm19o6\n",
      "Created batch job: batches/h4yfkvpc00ezn96hg8l86qp59e0nmi9t7ra1\n",
      "Uploaded file: files/qrqxs52gsvgw\n",
      "Created batch job: batches/dyixk9tef5kraiop6tldlhdpxmh72079ub4h\n",
      "Uploaded file: files/292bnprwd1k6\n",
      "Created batch job: batches/o91eiy1zvkxxx1qejm5qenyz3ezxngvpfuj7\n",
      "Uploaded file: files/8ofh6xi37824\n",
      "Created batch job: batches/6asy5ziwqrn21ujfqbk6nzzbfxo40ut9qtzj\n",
      "Uploaded file: files/sbnxidcz06fl\n",
      "Created batch job: batches/p3onbhtrfk50kcve2m7qdij99arvgtg4j2ss\n"
     ]
    }
   ],
   "source": [
    "counter = 0\n",
    "file_batch_job_list = []\n",
    "\n",
    "for tokens_limit, model_id in models_list:\n",
    "    for dataset in datasets:\n",
    "        for room_type in room_types:\n",
    "\n",
    "            output_file = base_gemini_path.format(\n",
    "                dataset=dataset,\n",
    "                room_type=room_type,\n",
    "                model_id=model_id,\n",
    "                max_tokens=tokens_limit\n",
    "            )\n",
    "\n",
    "            uploaded_file = client.files.upload(\n",
    "                file=output_file,\n",
    "                config=types.UploadFileConfig(display_name='my-batch-requests', mime_type='jsonl')\n",
    "            )\n",
    "\n",
    "            print(f\"Uploaded file: {uploaded_file.name}\")\n",
    "\n",
    "            # Assumes `uploaded_file` is the file object from the previous step\n",
    "            file_batch_job = client.batches.create(\n",
    "                model=model_id,\n",
    "                src=uploaded_file.name,\n",
    "                config={\n",
    "                    'display_name': f\"file-upload-job-{counter}\",\n",
    "                },\n",
    "            )\n",
    "\n",
    "            file_batch_job_list.append(file_batch_job)\n",
    "\n",
    "            print(f\"Created batch job: {file_batch_job.name}\")\n",
    "\n",
    "            counter += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "9c13ca20",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "8"
      ]
     },
     "execution_count": 14,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(file_batch_job_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "40987e7c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 23, 973546, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-0',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/harn2y5f81ak5nphg4pce3ipbx1nraau5y8s',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 23, 973546, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 29, 309906, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-1',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/9n4lqjowdmlxrljv09z7tylmtl1vro2kcgfe',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 29, 309906, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 34, 256832, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-2',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/dzm5ndy7um65u92nhvbiyab98xcb0na8vg5n',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 34, 256832, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 38, 735456, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-3',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/h4yfkvpc00ezn96hg8l86qp59e0nmi9t7ra1',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 38, 735456, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 43, 283671, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-4',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/dyixk9tef5kraiop6tldlhdpxmh72079ub4h',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 43, 283671, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 48, 340795, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-5',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/o91eiy1zvkxxx1qejm5qenyz3ezxngvpfuj7',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 48, 340795, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 53, 431062, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-6',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/6asy5ziwqrn21ujfqbk6nzzbfxo40ut9qtzj',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 53, 431062, tzinfo=TzInfo(UTC))\n",
       " ),\n",
       " BatchJob(\n",
       "   create_time=datetime.datetime(2025, 9, 23, 13, 56, 58, 768866, tzinfo=TzInfo(UTC)),\n",
       "   display_name='file-upload-job-7',\n",
       "   model='models/gemini-2.5-pro',\n",
       "   name='batches/p3onbhtrfk50kcve2m7qdij99arvgtg4j2ss',\n",
       "   state=<JobState.JOB_STATE_PENDING: 'JOB_STATE_PENDING'>,\n",
       "   update_time=datetime.datetime(2025, 9, 23, 13, 56, 58, 768866, tzinfo=TzInfo(UTC))\n",
       " )]"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "file_batch_job_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "4d210d21",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Polling status for job: batches/harn2y5f81ak5nphg4pce3ipbx1nraau5y8s\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/9n4lqjowdmlxrljv09z7tylmtl1vro2kcgfe\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/dzm5ndy7um65u92nhvbiyab98xcb0na8vg5n\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/h4yfkvpc00ezn96hg8l86qp59e0nmi9t7ra1\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/dyixk9tef5kraiop6tldlhdpxmh72079ub4h\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/o91eiy1zvkxxx1qejm5qenyz3ezxngvpfuj7\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/6asy5ziwqrn21ujfqbk6nzzbfxo40ut9qtzj\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Polling status for job: batches/p3onbhtrfk50kcve2m7qdij99arvgtg4j2ss\n",
      "Job state: JOB_STATE_SUCCEEDED\n"
     ]
    }
   ],
   "source": [
    "for file_batch_job in file_batch_job_list:\n",
    "    job_name = file_batch_job.name\n",
    "    print(f\"Polling status for job: {job_name}\")\n",
    "\n",
    "    batch_job_file = client.batches.get(name=job_name)\n",
    "    print(f\"Job state: {batch_job_file.state.name}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "fd50fba7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Polling status for job: batches/harn2y5f81ak5nphg4pce3ipbx1nraau5y8s\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-harn2y5f81ak5nphg4pce3ipbx1nraau5y8s\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/pair_distance/living_rooms/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/9n4lqjowdmlxrljv09z7tylmtl1vro2kcgfe\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-9n4lqjowdmlxrljv09z7tylmtl1vro2kcgfe\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/pair_distance/bedrooms/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/dzm5ndy7um65u92nhvbiyab98xcb0na8vg5n\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-dzm5ndy7um65u92nhvbiyab98xcb0na8vg5n\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/pair_distance/kitchens/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/h4yfkvpc00ezn96hg8l86qp59e0nmi9t7ra1\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-h4yfkvpc00ezn96hg8l86qp59e0nmi9t7ra1\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/pair_distance/hssd_data_simplified/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/dyixk9tef5kraiop6tldlhdpxmh72079ub4h\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-dyixk9tef5kraiop6tldlhdpxmh72079ub4h\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/repositioning/living_rooms/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/o91eiy1zvkxxx1qejm5qenyz3ezxngvpfuj7\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-o91eiy1zvkxxx1qejm5qenyz3ezxngvpfuj7\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/repositioning/bedrooms/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/6asy5ziwqrn21ujfqbk6nzzbfxo40ut9qtzj\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-6asy5ziwqrn21ujfqbk6nzzbfxo40ut9qtzj\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/repositioning/kitchens/gemini-2.5-pro_12288.jsonl\n",
      "Polling status for job: batches/p3onbhtrfk50kcve2m7qdij99arvgtg4j2ss\n",
      "Job state: JOB_STATE_SUCCEEDED\n",
      "Results are in file: files/batch-p3onbhtrfk50kcve2m7qdij99arvgtg4j2ss\n",
      "Downloading result file content...\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/repositioning/hssd_data_simplified/gemini-2.5-pro_12288.jsonl\n"
     ]
    }
   ],
   "source": [
    "index = 0\n",
    "\n",
    "for tokens_limit, model_id in models_list:\n",
    "    for dataset in datasets:\n",
    "        for room_type in room_types:\n",
    "\n",
    "            file_batch_job = file_batch_job_list[index]\n",
    "\n",
    "            job_name = file_batch_job.name\n",
    "            print(f\"Polling status for job: {job_name}\")\n",
    "\n",
    "            batch_job_file = client.batches.get(name=job_name)\n",
    "            print(f\"Job state: {batch_job_file.state.name}\")\n",
    "\n",
    "            if batch_job_file.state.name == 'JOB_STATE_SUCCEEDED':\n",
    "\n",
    "                # If batch job was created with a file\n",
    "                if batch_job_file.dest and batch_job_file.dest.file_name:\n",
    "                    # Results are in a file\n",
    "                    result_file_name = batch_job_file.dest.file_name\n",
    "                    print(f\"Results are in file: {result_file_name}\")\n",
    "\n",
    "                    print(\"Downloading result file content...\")\n",
    "                    file_content = client.files.download(file=result_file_name)\n",
    "                    # Process file_content (bytes) as needed\n",
    "                    # print(file_content.decode('utf-8'))\n",
    "\n",
    "                    output_file = base_output_path.format(\n",
    "                        dataset=dataset,\n",
    "                        room_type=room_type,\n",
    "                        model_id=model_id,\n",
    "                        max_tokens=tokens_limit\n",
    "                    )\n",
    "\n",
    "                        # Convert to JSONL format\n",
    "                    with open(output_file, \"w\") as f:\n",
    "                        for line in file_content.decode('utf-8').splitlines():\n",
    "                            if line.strip():\n",
    "                                f.write(json.dumps(json.loads(line)) + \"\\n\")\n",
    "                    print(f\"Results saved to {output_file}\")\n",
    "            \n",
    "            index += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c6d0dd4f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b31f97fa",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22aa8798",
   "metadata": {},
   "outputs": [],
   "source": [
    "# wait for the job to finish\n",
    "job_name = file_batch_job.name\n",
    "print(f\"Polling status for job: {job_name}\")\n",
    "\n",
    "while True:\n",
    "    batch_job_file = client.batches.get(name=job_name)\n",
    "    if batch_job_file.state.name in ('JOB_STATE_SUCCEEDED', 'JOB_STATE_FAILED', 'JOB_STATE_CANCELLED'):\n",
    "        break\n",
    "    print(f\"Job not finished. Current state: {batch_job_file.state.name}. Waiting 60 seconds...\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21e41588",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2bae3529",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "4eb61d2d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/home/rodionfa/FloorplanQA/qa_jsonl/pair_distance/hssd_data_simplified/gemini-2.5-flash_12288_gemini.jsonl'"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output_file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "3163ebf0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Uploaded file: files/o56b2yobad1d\n"
     ]
    }
   ],
   "source": [
    "# Upload the file to the File API\n",
    "uploaded_file = client.files.upload(\n",
    "    file=output_file,\n",
    "    config=types.UploadFileConfig(display_name='my-batch-requests', mime_type='jsonl')\n",
    ")\n",
    "\n",
    "print(f\"Uploaded file: {uploaded_file.name}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "016c6678",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created batch job: batches/6zucqaacp4j4j2cck73sfqdps26sgl0vqltk\n"
     ]
    }
   ],
   "source": [
    "# Assumes `uploaded_file` is the file object from the previous step\n",
    "file_batch_job = client.batches.create(\n",
    "    model=model_id,\n",
    "    src=uploaded_file.name,\n",
    "    config={\n",
    "        'display_name': \"file-upload-job-1\",\n",
    "    },\n",
    ")\n",
    "\n",
    "print(f\"Created batch job: {file_batch_job.name}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "b5b3331e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Polling status for job: batches/6zucqaacp4j4j2cck73sfqdps26sgl0vqltk\n",
      "Job not finished. Current state: JOB_STATE_PENDING. Waiting 60 seconds...\n",
      "Job not finished. Current state: JOB_STATE_PENDING. Waiting 60 seconds...\n",
      "Job not finished. Current state: JOB_STATE_PENDING. Waiting 60 seconds...\n",
      "Job not finished. Current state: JOB_STATE_PENDING. Waiting 60 seconds...\n",
      "Job not finished. Current state: JOB_STATE_PENDING. Waiting 60 seconds...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/rodionfa/mambaforge/envs/plan_b/lib/python3.10/site-packages/google/genai/_common.py:473: UserWarning: BATCH_STATE_RUNNING is not a valid JobState\n",
      "  warnings.warn(f\"{value} is not a valid {cls.__name__}\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Job not finished. Current state: BATCH_STATE_RUNNING. Waiting 60 seconds...\n",
      "Job not finished. Current state: BATCH_STATE_RUNNING. Waiting 60 seconds...\n",
      "Job not finished. Current state: BATCH_STATE_RUNNING. Waiting 60 seconds...\n",
      "Job not finished. Current state: BATCH_STATE_RUNNING. Waiting 60 seconds...\n"
     ]
    }
   ],
   "source": [
    "# wait for the job to finish\n",
    "job_name = file_batch_job.name\n",
    "print(f\"Polling status for job: {job_name}\")\n",
    "\n",
    "while True:\n",
    "    batch_job_file = client.batches.get(name=job_name)\n",
    "    if batch_job_file.state.name in ('JOB_STATE_SUCCEEDED', 'JOB_STATE_FAILED', 'JOB_STATE_CANCELLED'):\n",
    "        break\n",
    "    print(f\"Job not finished. Current state: {batch_job_file.state.name}. Waiting 120 seconds...\")\n",
    "    time.sleep(120)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d43483c0",
   "metadata": {},
   "outputs": [],
   "source": [
    "1+1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Job finished with state: JOB_STATE_SUCCEEDED\n"
     ]
    }
   ],
   "source": [
    "print(f\"Job finished with state: {batch_job_file.state.name}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "d2272ebe",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'/home/rodionfa/FloorplanQA/qa_response/pair_distance/hssd_data_simplified/gemini-2.5-flash_12288.jsonl'"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "output_file = base_output_path.format(\n",
    "    dataset=dataset,\n",
    "    room_type=room_type,\n",
    "    model_id=model_id,\n",
    "    max_tokens=tokens_limit\n",
    ")\n",
    "output_file"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Results are in file: files/batch-6zucqaacp4j4j2cck73sfqdps26sgl0vqltk\n",
      "Downloading result file content...\n",
      "{\"key\":\"request-0\",\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"2hnRaPzKLvzQ1MkP2oq06Qs\",\"usageMetadata\":{\"totalTokenCount\":7503,\"promptTokenCount\":5456,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5456}]}}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2280}],\"promptTokenCount\":2280,\"totalTokenCount\":4327,\"thoughtsTokenCount\":2047},\"responseId\":\"2hnRaMeuAoG_1MkP7pHRkA0\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-1\"}\n",
      "{\"response\":{\"responseId\":\"VBnRaLDCL76q1MkPgebKgQQ\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokenCount\":3384,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3384}],\"totalTokenCount\":5431,\"thoughtsTokenCount\":2047}},\"key\":\"request-2\"}\n",
      "{\"key\":\"request-3\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"VBnRaKylKp2VjMcPmKysmAw\",\"usageMetadata\":{\"promptTokenCount\":3063,\"promptTokensDetails\":[{\"tokenCount\":3063,\"modality\":\"TEXT\"}],\"totalTokenCount\":5110,\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4372,\"promptTokenCount\":2325,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2325}]},\"responseId\":\"VBnRaJK7L7qMjMcP1Le7mAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-4\"}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":10031,\"promptTokenCount\":7984,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":7984}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"responseId\":\"VBnRaLKtB76NjMcPt6OZwAw\"},\"key\":\"request-5\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":5041,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5041}],\"totalTokenCount\":7088},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"VBnRaLHrD8mk1MkPqN3X0Qw\"},\"key\":\"request-6\"}\n",
      "{\"key\":\"request-7\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"UxnRaKucB8Ks1MkPrICBsQw\",\"usageMetadata\":{\"promptTokenCount\":3196,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3196}],\"totalTokenCount\":5243},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"key\":\"request-8\",\"response\":{\"usageMetadata\":{\"totalTokenCount\":4100,\"promptTokenCount\":2053,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2053}]},\"responseId\":\"VRnRaIPUGM6xjMcP1sOhgQk\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]}}\n",
      "{\"response\":{\"responseId\":\"VBnRaIzfCu2J-sAPg9GiyQk\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4167,\"promptTokensDetails\":[{\"tokenCount\":2120,\"modality\":\"TEXT\"}],\"promptTokenCount\":2120},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]},\"key\":\"request-9\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4240}],\"promptTokenCount\":4240,\"totalTokenCount\":6287},\"responseId\":\"2hnRaIGID_Of1MkP1fu7sAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]},\"key\":\"request-10\"}\n",
      "{\"response\":{\"responseId\":\"VRnRaPjgFMnfjMcPkP3c8Ag\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3161}],\"promptTokenCount\":3161,\"totalTokenCount\":5208}},\"key\":\"request-11\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"totalTokenCount\":5257,\"promptTokenCount\":3210,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3210}]},\"responseId\":\"UxnRaOCWMLat1MkPrYKMgQQ\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-12\"}\n",
      "{\"response\":{\"responseId\":\"VBnRaKy-Cr6y1MkPi9qJKA\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":4302,\"promptTokenCount\":2255,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2255}],\"thoughtsTokenCount\":2047},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-13\"}\n",
      "{\"key\":\"request-14\",\"response\":{\"usageMetadata\":{\"totalTokenCount\":4245,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2198,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2198}]},\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"VBnRaLrjMrGMjMcPmue3kQk\",\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"key\":\"request-15\",\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2715}],\"promptTokenCount\":2715,\"totalTokenCount\":4762},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"UxnRaPSaJouhjMcPwYnVoA4\"}}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4638,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2591}],\"promptTokenCount\":2591},\"responseId\":\"2RnRaJmFBvzQ1MkP2oq06Qs\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-16\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2172}],\"totalTokenCount\":4219,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2172},\"responseId\":\"2RnRaM7sMPum1MkPjarGwQM\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-17\"}\n",
      "{\"response\":{\"responseId\":\"VBnRaJj2IKOa1MkP9uqOiA8\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2257}],\"promptTokenCount\":2257,\"thoughtsTokenCount\":2047,\"totalTokenCount\":4304},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-18\"}\n",
      "{\"response\":{\"responseId\":\"2BnRaL6-J9C01MkPhdjVSQ\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":2591,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":2591,\"modality\":\"TEXT\"}],\"totalTokenCount\":4638}},\"key\":\"request-19\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3616}],\"promptTokenCount\":3616,\"totalTokenCount\":5663,\"thoughtsTokenCount\":2047},\"responseId\":\"VBnRaNjBFfSd1MkPt7mP4Q4\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-20\"}\n",
      "{\"key\":\"request-21\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":1778,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1778}],\"totalTokenCount\":3825},\"responseId\":\"2BnRaMv4BpHrugeS1PeADA\"}}\n",
      "{\"response\":{\"responseId\":\"VRnRaIqIJbqMjMcP1Le7mAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":5109,\"promptTokenCount\":3062,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3062}]}},\"key\":\"request-22\"}\n",
      "{\"key\":\"request-23\",\"response\":{\"responseId\":\"2BnRaNm3N9Cu1MkP4Pa02AM\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":3167,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":5214,\"promptTokenCount\":3167},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokenCount\":3201,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3201}],\"totalTokenCount\":5248,\"thoughtsTokenCount\":2047},\"responseId\":\"XRnRaKOlF7-o1MkP29jx8As\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-24\"}\n",
      "{\"response\":{\"responseId\":\"2BnRaKSMDMeu1MkPsLjosQM\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2219,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2219,\"totalTokenCount\":4266},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-25\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2386}],\"totalTokenCount\":4433,\"promptTokenCount\":2386},\"responseId\":\"2hnRaKDzJPqk1MkPm5jdwAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-26\"}\n",
      "{\"key\":\"request-27\",\"response\":{\"responseId\":\"VBnRaMz_GdOm1MkPss6KkA0\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2470}],\"promptTokenCount\":2470,\"totalTokenCount\":4517}}}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"VRnRaKSqFdCs1MkP9JXh4Aw\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2285,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2285}],\"totalTokenCount\":4332}},\"key\":\"request-28\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2815,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":4862,\"promptTokenCount\":2815},\"responseId\":\"2RnRaI2uB9Om1MkPq86KkA0\"},\"key\":\"request-29\"}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":5318,\"promptTokenCount\":3271,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3271}]},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"VBnRaJyMBOGe1MkP8oX-MA\"},\"key\":\"request-30\"}\n",
      "{\"key\":\"request-31\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2002,\"promptTokensDetails\":[{\"tokenCount\":2002,\"modality\":\"TEXT\"}],\"totalTokenCount\":4049},\"responseId\":\"2BnRaIelPPKw1MkP6IuHgAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"key\":\"request-32\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":6213,\"promptTokenCount\":4166,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4166}]},\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"VBnRaOeFGL-o1MkP29jx8As\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":5756,\"thoughtsTokenCount\":2047,\"promptTokenCount\":3709,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3709}]},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"2hnRaLuyA96q1MkPk4GcAQ\"},\"key\":\"request-33\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":2626,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2626}],\"totalTokenCount\":4673,\"thoughtsTokenCount\":2047},\"responseId\":\"VBnRaMOfKPXXjMcP-tq_8Qg\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-34\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"UxnRaM_zMrLpjMcPj8XCyQk\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":3624,\"promptTokensDetails\":[{\"tokenCount\":3624,\"modality\":\"TEXT\"}],\"totalTokenCount\":5671}},\"key\":\"request-35\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3865}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3865,\"totalTokenCount\":5912},\"responseId\":\"VBnRaK3FLrOx1MkPmamicQ\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-36\"}\n",
      "{\"key\":\"request-37\",\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":3739,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1692}],\"promptTokenCount\":1692},\"responseId\":\"VBnRaJK-Iu2J-sAPg9GiyQk\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"key\":\"request-38\",\"response\":{\"responseId\":\"UxnRaPufHOvVjMcP6IuV4Qc\",\"usageMetadata\":{\"totalTokenCount\":4142,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2095,\"promptTokensDetails\":[{\"tokenCount\":2095,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":4527,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2480}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2480},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"UxnRaL37PNOm1MkPss6KkA0\"},\"key\":\"request-39\"}\n",
      "{\"key\":\"request-40\",\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4313,\"promptTokenCount\":2266,\"promptTokensDetails\":[{\"tokenCount\":2266,\"modality\":\"TEXT\"}]},\"responseId\":\"2RnRaND0Lbqj1MkP2Znz6Qs\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":4661,\"modality\":\"TEXT\"}],\"promptTokenCount\":4661,\"thoughtsTokenCount\":2047,\"totalTokenCount\":6708},\"responseId\":\"VBnRaKe2A4uhjMcPwYnVoA4\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-41\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2098}],\"totalTokenCount\":4145,\"promptTokenCount\":2098},\"responseId\":\"VRnRaOSFAuGt1MkP7eiMqAM\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]},\"key\":\"request-42\"}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":4400,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2353}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2353},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"VBnRaL8svNGMxw-VgZrZCw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-43\"}\n",
      "{\"response\":{\"responseId\":\"2RnRaNbuLoqd1MkP792HiAQ\",\"usageMetadata\":{\"totalTokenCount\":4212,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2165,\"promptTokensDetails\":[{\"tokenCount\":2165,\"modality\":\"TEXT\"}]},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-44\"}\n",
      "{\"response\":{\"responseId\":\"XhnRaPjbCouhjMcPwYnVoA4\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokenCount\":5602,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5602}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":7649},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-45\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":6888,\"promptTokenCount\":4841,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":4841,\"modality\":\"TEXT\"}]},\"responseId\":\"XRnRaPTeEL6q1MkPgebKgQQ\"},\"key\":\"request-46\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4687}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":6734,\"promptTokenCount\":4687},\"responseId\":\"XRnRaNzhKLzRjMcPlYGa2Qs\"},\"key\":\"request-47\"}\n",
      "{\"key\":\"request-48\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"XhnRaOi9CdH0jMcP95z1iQw\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2855,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":4902,\"promptTokenCount\":2855}}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3423}],\"totalTokenCount\":5470,\"promptTokenCount\":3423,\"thoughtsTokenCount\":2047},\"responseId\":\"XRnRaLWHNLqMjMcP1Le7mAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-49\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":6641,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4594}],\"promptTokenCount\":4594,\"thoughtsTokenCount\":2047},\"responseId\":\"XRnRaPXlFMnfjMcPkP3c8Ag\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-50\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":1376,\"totalTokenCount\":3423,\"promptTokensDetails\":[{\"tokenCount\":1376,\"modality\":\"TEXT\"}]},\"responseId\":\"XRnRaO6zB46s1MkP9JnK6Qs\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-51\"}\n",
      "{\"key\":\"request-52\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2361}],\"totalTokenCount\":4408,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2361},\"responseId\":\"XRnRaI2cOOTVjMcP55-kgAw\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"responseId\":\"XhnRaOq2AfXXjMcP-tq_8Qg\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3049}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":5096,\"promptTokenCount\":3049},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-53\"}\n",
      "{\"key\":\"request-54\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2190,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2190}],\"totalTokenCount\":4237},\"responseId\":\"YBnRaNORBLLpjMcPj8XCyQk\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":4229,\"totalTokenCount\":6276,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4229}]},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"XRnRaJ6YLvySjMcPz92XgQw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-55\"}\n",
      "{\"key\":\"request-56\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3721}],\"totalTokenCount\":5768,\"thoughtsTokenCount\":2047,\"promptTokenCount\":3721},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"YxnRaOjpDe2J-sAPg9GiyQk\",\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"XhnRaPerN8Ks1MkPrICBsQw\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2334}],\"totalTokenCount\":4381,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2334},\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-57\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":3547,\"totalTokenCount\":5594,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3547}]},\"responseId\":\"XRnRaLHBLZ2VjMcPmKysmAw\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-58\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":3717,\"totalTokenCount\":5764,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3717}]},\"responseId\":\"YBnRaImUILGMjMcPmue3kQk\"},\"key\":\"request-59\"}\n",
      "{\"key\":\"request-60\",\"response\":{\"usageMetadata\":{\"promptTokenCount\":5601,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5601}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":7648},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"XhnRaI6wGO_hjMcPq7CY-AY\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]}}\n",
      "{\"response\":{\"responseId\":\"XxnRaPeQC4G_1MkP7pHRkA0\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3988}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3988,\"totalTokenCount\":6035},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-61\"}\n",
      "{\"key\":\"request-62\",\"response\":{\"responseId\":\"XhnRaJusOLqMjMcP1Le7mAw\",\"usageMetadata\":{\"totalTokenCount\":4414,\"promptTokenCount\":2367,\"promptTokensDetails\":[{\"tokenCount\":2367,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokenCount\":2388,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2388}],\"totalTokenCount\":4435,\"thoughtsTokenCount\":2047},\"responseId\":\"XxnRaJn8KsqTjMcPipCy-As\"},\"key\":\"request-63\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2685}],\"promptTokenCount\":2685,\"totalTokenCount\":4732},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"responseId\":\"XxnRaPyzDPXRjMcPn8X_6Ag\"},\"key\":\"request-64\"}\n",
      "{\"response\":{\"responseId\":\"XxnRaODqEevVjMcP6IuV4Qc\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3573}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3573,\"totalTokenCount\":5620},\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]},\"key\":\"request-65\"}\n",
      "{\"response\":{\"responseId\":\"ZRnRaNHCEZ2w1MkPvfCK2AQ\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":3232,\"totalTokenCount\":5279,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3232}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-66\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3341}],\"totalTokenCount\":5388,\"promptTokenCount\":3341},\"responseId\":\"XhnRaN_CCOGe1MkP8oX-MA\"},\"key\":\"request-67\"}\n",
      "{\"key\":\"request-68\",\"response\":{\"responseId\":\"YBnRaPV35JmMxw_z4cDoCw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokenCount\":5554,\"thoughtsTokenCount\":2047,\"totalTokenCount\":7601,\"promptTokensDetails\":[{\"tokenCount\":5554,\"modality\":\"TEXT\"}]}}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4604}],\"totalTokenCount\":6651,\"promptTokenCount\":4604,\"thoughtsTokenCount\":2047},\"responseId\":\"ZRnRaJiGK76NjMcPt6OZwAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-69\"}\n",
      "{\"response\":{\"responseId\":\"XxnRaLPzLbOx1MkPmamicQ\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"totalTokenCount\":6183,\"thoughtsTokenCount\":2047,\"promptTokenCount\":4136,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4136}]}},\"key\":\"request-70\"}\n",
      "{\"key\":\"request-71\",\"response\":{\"usageMetadata\":{\"totalTokenCount\":11521,\"promptTokenCount\":9475,\"candidatesTokenCount\":561,\"thoughtsTokenCount\":1485,\"promptTokensDetails\":[{\"tokenCount\":9475,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"XxnRaNvfIOGt1MkP7eiMqAM\",\"candidates\":[{\"content\":{\"role\":\"model\",\"parts\":[{\"text\":\"layout_id: 71\\n\\n*   Identify the coordinates for 'table_2'.\\n*   Calculate the centroid of 'table_2'.\\n*   Identify the coordinates for 'window_3'.\\n*   Calculate the centroid of 'window_3'.\\n*   Calculate the Euclidean distance between the two centroids.\\n\\n**Step 1: Identify the coordinates for 'table_2'.**\\nThe points for 'table_2' are:\\n[{\\\"x\\\": -16.878, \\\"y\\\": -13.226}, {\\\"x\\\": -17.488, \\\"y\\\": -13.226}, {\\\"x\\\": -17.488, \\\"y\\\": -12.616}, {\\\"x\\\": -16.878, \\\"y\\\": -12.616}]\\nThese points define a rectangle.\\n\\n**Step 2: Calculate the centroid of 'table_2'.**\\nFor a rectangle, the centroid is the average of the minimum and maximum x-coordinates and the minimum and maximum y-coordinates.\\nMin X = -17.488\\nMax X = -16.878\\nMin Y = -13.226\\nMax Y = -12.616\\n\\nCentroid X (Cx_table_2) = (Min X + Max X) / 2 = (-17.488 + -16.878) / 2 = -34.366 / 2 = -17.183\\nCentroid Y (Cy_table_2) = (Min Y + Max Y) / 2 = (-13.226 + -12.616) / 2 = -25.842 / 2 = -12.921\\nCentroid of 'table_2' = (-17.183, -12.921)\\n\\n**Step 3: Identify the coordinates for 'window_3'.**\\nThe points for 'window_3' are:\\n[{\\\"x\\\": -19.578, \\\"y\\\": -15.389}, {\\\"x\\\": -19.578, \\\"y\\\": -13.309}, {\\\"x\\\": -19.497999999999998, \\\"y\\\": -13.309}, {\\\"x\\\": -19.497999999999998, \\\"y\\\": -1\"}]},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"responseId\":\"YBnRaJS4JrGMjMcPmue3kQk\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8129}],\"promptTokenCount\":8129,\"totalTokenCount\":10176,\"thoughtsTokenCount\":2047},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-72\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":8572,\"promptTokenCount\":6525,\"promptTokensDetails\":[{\"tokenCount\":6525,\"modality\":\"TEXT\"}]},\"responseId\":\"YBnRaNfxBrqMjMcP1Le7mAw\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-73\"}\n",
      "{\"response\":{\"responseId\":\"ZhnRaImoNfSd1MkPt7mP4Q4\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8321}],\"promptTokenCount\":8321,\"thoughtsTokenCount\":2047,\"totalTokenCount\":10368}},\"key\":\"request-74\"}\n",
      "{\"key\":\"request-75\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":6316}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":6316,\"totalTokenCount\":8363},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"ZxnRaIDzLPXXjMcP-tq_8Qg\"}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"responseId\":\"ZhnRaOOMNp2w1MkPvfCK2AQ\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5469}],\"promptTokenCount\":5469,\"totalTokenCount\":7516}},\"key\":\"request-76\"}\n",
      "{\"key\":\"request-77\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"totalTokenCount\":9779,\"thoughtsTokenCount\":2047,\"promptTokenCount\":7732,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":7732}]},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"ZhnRaPWvHuGe1MkP8oX-MA\"}}\n",
      "{\"key\":\"request-78\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"ZhnRaIC_N7LpjMcPj8XCyQk\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"totalTokenCount\":6807,\"promptTokenCount\":4760,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":4760,\"modality\":\"TEXT\"}]}}}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"ZxnRaNrdKvySjMcPz92XgQw\",\"usageMetadata\":{\"totalTokenCount\":11346,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":9299}],\"promptTokenCount\":9299,\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-79\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"aRnRaPeWCrOx1MkPmamicQ\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":7769,\"promptTokenCount\":5722,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5722}]}},\"key\":\"request-80\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"ZhnRaM6vOeWr1MkP4Lyd6Qs\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2902,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2902,\"totalTokenCount\":4949},\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]},\"key\":\"request-81\"}\n",
      "{\"key\":\"request-82\",\"response\":{\"responseId\":\"ZxnRaOG-ENCs1MkP9JXh4Aw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"totalTokenCount\":7566,\"promptTokenCount\":5519,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5519}]}}}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":13737,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":11690}],\"promptTokenCount\":11690},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"responseId\":\"ZhnRaMLGNe2J-sAPg9GiyQk\"},\"key\":\"request-83\"}\n",
      "{\"response\":{\"responseId\":\"ZhnRaJHoMuvVjMcP6IuV4Qc\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":8103,\"promptTokenCount\":6056,\"promptTokensDetails\":[{\"tokenCount\":6056,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-84\"}\n",
      "{\"response\":{\"responseId\":\"aBnRaN-3DLat1MkPrYKMgQQ\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":9571,\"promptTokenCount\":7524,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":7524}]}},\"key\":\"request-85\"}\n",
      "{\"key\":\"request-86\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":11446}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":13493,\"promptTokenCount\":11446},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"responseId\":\"aBnRaOb5Numm1MkP4f-nsAM\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokenCount\":9466,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":9466,\"modality\":\"TEXT\"}],\"totalTokenCount\":11513},\"responseId\":\"ZxnRaNvAMY6s1MkP9JnK6Qs\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-87\"}\n",
      "{\"key\":\"request-88\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"ahnRaK_IEeSZjMcP8-HA6As\",\"usageMetadata\":{\"promptTokenCount\":8111,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8111}],\"totalTokenCount\":10158,\"thoughtsTokenCount\":2047},\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]}}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":5372,\"totalTokenCount\":7419,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5372}]},\"responseId\":\"aRnRaMGIIYWJ-sAPqpSHyAk\"},\"key\":\"request-89\"}\n",
      "{\"key\":\"request-90\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":10980,\"promptTokenCount\":8933,\"promptTokensDetails\":[{\"tokenCount\":8933,\"modality\":\"TEXT\"}]},\"responseId\":\"aRnRaNqKDcKs1MkPrICBsQw\"}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"aBnRaNjRMY-t1MkP6qyg0AM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5220}],\"promptTokenCount\":5220,\"totalTokenCount\":7267}},\"key\":\"request-91\"}\n",
      "{\"key\":\"request-92\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":9107,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":11154,\"promptTokenCount\":9107},\"responseId\":\"aBnRaJ7gHr6NjMcPt6OZwAw\"}}\n",
      "{\"response\":{\"responseId\":\"aRnRaNmUBYuhjMcPwYnVoA4\",\"usageMetadata\":{\"totalTokenCount\":14149,\"promptTokenCount\":12102,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":12102}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-93\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":11925,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":11925}],\"totalTokenCount\":13972},\"responseId\":\"bxnRaNT8EYG_1MkP7pHRkA0\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-94\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":6368,\"modality\":\"TEXT\"}],\"totalTokenCount\":8415,\"thoughtsTokenCount\":2047,\"promptTokenCount\":6368},\"responseId\":\"aRnRaKOoOb6y1MkPi9qJKA\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-95\"}\n",
      "{\"response\":{\"responseId\":\"axnRaPmcDM6xjMcP1sOhgQk\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":14623,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":14623}],\"totalTokenCount\":16670},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-96\"}\n",
      "{\"key\":\"request-97\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8131}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":10178,\"promptTokenCount\":8131},\"responseId\":\"2hnRaOvrC_aw1MkPzbHNuAM\"}}\n",
      "{\"response\":{\"responseId\":\"2BnRaLr7Evum1MkPjarGwQM\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokenCount\":6533,\"totalTokenCount\":8580,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":6533}],\"thoughtsTokenCount\":2047}},\"key\":\"request-98\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":15352,\"promptTokenCount\":13305,\"promptTokensDetails\":[{\"tokenCount\":13305,\"modality\":\"TEXT\"}]},\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"2hnRaLSzCMeu1MkPsLjosQM\"},\"key\":\"request-99\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"2BnRaJDnDe-g1MkPqbar8As\",\"usageMetadata\":{\"promptTokenCount\":8311,\"totalTokenCount\":10358,\"promptTokensDetails\":[{\"tokenCount\":8311,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-100\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"2RnRaM3KGpHrugeS1PeADA\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":11252}],\"promptTokenCount\":11252,\"totalTokenCount\":13299}},\"key\":\"request-101\"}\n",
      "{\"key\":\"request-102\",\"response\":{\"responseId\":\"2RnRaPzQEfaw1MkPzbHNuAM\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":6060,\"modality\":\"TEXT\"}],\"promptTokenCount\":6060,\"totalTokenCount\":8107}}}\n",
      "{\"key\":\"request-103\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"2RnRaICFK8mm1MkPt87E6AM\",\"usageMetadata\":{\"totalTokenCount\":6952,\"thoughtsTokenCount\":2047,\"promptTokenCount\":4905,\"promptTokensDetails\":[{\"tokenCount\":4905,\"modality\":\"TEXT\"}]}}}\n",
      "{\"response\":{\"responseId\":\"2BnRaKPeDY2m1MkP-dXW8A0\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":4812,\"totalTokenCount\":6859,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4812}]},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-104\"}\n",
      "{\"key\":\"request-105\",\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"2hnRaIGMF4qd1MkP792HiAQ\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":4217,\"modality\":\"TEXT\"}],\"totalTokenCount\":6264,\"thoughtsTokenCount\":2047,\"promptTokenCount\":4217}}}\n",
      "{\"key\":\"request-106\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":5635,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":7682,\"promptTokenCount\":5635},\"responseId\":\"2hnRaL-VEeej1MkPw-CmsQM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8108}],\"totalTokenCount\":10155,\"thoughtsTokenCount\":2047,\"promptTokenCount\":8108},\"responseId\":\"2BnRaJnvD7qj1MkP2Znz6Qs\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-107\"}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":11121,\"totalTokenCount\":13168,\"promptTokensDetails\":[{\"tokenCount\":11121,\"modality\":\"TEXT\"}]},\"responseId\":\"1xnRaKHCPPKw1MkP6IuHgAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-108\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":9083,\"promptTokensDetails\":[{\"tokenCount\":9083,\"modality\":\"TEXT\"}],\"totalTokenCount\":11130},\"responseId\":\"2BnRaLy3C42m1MkP-dXW8A0\"},\"key\":\"request-109\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":9332}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":11379,\"promptTokenCount\":9332},\"responseId\":\"2RnRaLSvHe-g1MkPqbar8As\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-110\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4499}],\"promptTokenCount\":4499,\"totalTokenCount\":6546},\"responseId\":\"2RnRaL-8E9Wd1MkPjL-hgQk\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-111\"}\n",
      "{\"key\":\"request-112\",\"response\":{\"responseId\":\"4RnRaPGYI4qd1MkP792HiAQ\",\"usageMetadata\":{\"promptTokenCount\":5270,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5270}],\"totalTokenCount\":7317,\"thoughtsTokenCount\":2047},\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"4hnRaMPqDdCu1MkP4Pa02AM\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":4454,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4454}],\"totalTokenCount\":6501,\"thoughtsTokenCount\":2047}},\"key\":\"request-113\"}\n",
      "{\"response\":{\"responseId\":\"4RnRaJGSCvum1MkPjarGwQM\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":5454,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":7501,\"promptTokenCount\":5454},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-114\"}\n",
      "{\"key\":\"request-115\",\"response\":{\"responseId\":\"4xnRaM2vHYG_1MkP7pHRkA0\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":9523}],\"totalTokenCount\":11570,\"thoughtsTokenCount\":2047,\"promptTokenCount\":9523}}}\n",
      "{\"key\":\"request-116\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5454}],\"totalTokenCount\":7501,\"promptTokenCount\":5454},\"responseId\":\"4RnRaOr4Gvaw1MkPzbHNuAM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"key\":\"request-117\",\"response\":{\"usageMetadata\":{\"promptTokenCount\":8021,\"totalTokenCount\":10068,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8021}],\"thoughtsTokenCount\":2047},\"responseId\":\"4RnRaLLkO42m1MkP-dXW8A0\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"responseId\":\"4hnRaNCsB96q1MkPk4GcAQ\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":7642,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":7642}],\"totalTokenCount\":9689}},\"key\":\"request-118\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":7522,\"promptTokenCount\":5475,\"promptTokensDetails\":[{\"tokenCount\":5475,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047},\"responseId\":\"4hnRaMb4A8mm1MkPt87E6AM\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-119\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"4hnRaMHwKZHrugeS1PeADA\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":5309,\"promptTokensDetails\":[{\"tokenCount\":5309,\"modality\":\"TEXT\"}],\"totalTokenCount\":7356},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-120\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":5925,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5925}],\"totalTokenCount\":7972},\"responseId\":\"6BnRaIaREfum1MkPjarGwQM\"},\"key\":\"request-121\"}\n",
      "{\"key\":\"request-122\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":7022,\"promptTokensDetails\":[{\"tokenCount\":7022,\"modality\":\"TEXT\"}],\"totalTokenCount\":9069},\"responseId\":\"4xnRaLAZ76DUyQ-ptqvwCw\",\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"responseId\":\"4hnRaIr2C96q1MkPk4GcAQ\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":6992,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4945}],\"promptTokenCount\":4945},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-123\"}\n",
      "{\"key\":\"request-124\",\"response\":{\"responseId\":\"5BnRaLHVDPKw1MkP6IuHgAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":10245}],\"totalTokenCount\":12292,\"thoughtsTokenCount\":2047,\"promptTokenCount\":10245},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":16530,\"thoughtsTokenCount\":2047,\"promptTokenCount\":14483,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":14483}]},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"4xnRaO-5Brqj1MkP2Znz6Qs\"},\"key\":\"request-125\"}\n",
      "{\"key\":\"request-126\",\"response\":{\"usageMetadata\":{\"promptTokenCount\":7473,\"promptTokensDetails\":[{\"tokenCount\":7473,\"modality\":\"TEXT\"}],\"totalTokenCount\":9520,\"thoughtsTokenCount\":2047},\"responseId\":\"4xnRaN3mOZHrugeS1PeADA\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"responseId\":\"5BnRaNXuA_Of1MkP1fu7sAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":14279}],\"promptTokenCount\":14279,\"totalTokenCount\":16326},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-127\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"4xnRaID3Nvqk1MkPm5jdwAw\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4914,\"promptTokenCount\":2867,\"promptTokensDetails\":[{\"tokenCount\":2867,\"modality\":\"TEXT\"}]}},\"key\":\"request-128\"}\n",
      "{\"key\":\"request-129\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4708}],\"totalTokenCount\":6755,\"thoughtsTokenCount\":2047,\"promptTokenCount\":4708},\"responseId\":\"4xnRaOvvCdC01MkPhdjVSQ\"}}\n",
      "{\"response\":{\"responseId\":\"5BnRaOHEDNWd1MkPjL-hgQk\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":3169,\"promptTokensDetails\":[{\"tokenCount\":3169,\"modality\":\"TEXT\"}],\"totalTokenCount\":5216,\"thoughtsTokenCount\":2047}},\"key\":\"request-130\"}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":2239,\"promptTokensDetails\":[{\"tokenCount\":2239,\"modality\":\"TEXT\"}],\"totalTokenCount\":4286,\"thoughtsTokenCount\":2047},\"responseId\":\"5BnRaI29BPum1MkPjarGwQM\"},\"key\":\"request-131\"}\n",
      "{\"response\":{\"responseId\":\"5BnRaNbSG42m1MkP-dXW8A0\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2110}],\"totalTokenCount\":4157,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2110},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-132\"}\n",
      "{\"key\":\"request-133\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"5BnRaKH-PNOm1MkPq86KkA0\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":2052,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":2052,\"modality\":\"TEXT\"}],\"totalTokenCount\":4099}}}\n",
      "{\"response\":{\"responseId\":\"5BnRaLK2IPaw1MkPzbHNuAM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"totalTokenCount\":10914,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":8867}],\"promptTokenCount\":8867,\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-134\"}\n",
      "{\"key\":\"request-135\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":6009}],\"promptTokenCount\":6009,\"totalTokenCount\":8056,\"thoughtsTokenCount\":2047},\"responseId\":\"5BnRaMT1LPKw1MkP6IuHgAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":4465,\"modality\":\"TEXT\"}],\"totalTokenCount\":6512,\"promptTokenCount\":4465},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"5RnRaJ6cFPzQ1MkP2oq06Qs\"},\"key\":\"request-136\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":3932,\"thoughtsTokenCount\":2047,\"totalTokenCount\":5979,\"promptTokensDetails\":[{\"tokenCount\":3932,\"modality\":\"TEXT\"}]},\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"5BnRaKu2LpHrugeS1PeADA\"},\"key\":\"request-137\"}\n",
      "{\"response\":{\"responseId\":\"5RnRaOyeFvOf1MkP1fu7sAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokenCount\":4954,\"promptTokensDetails\":[{\"tokenCount\":4954,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":7001},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-138\"}\n",
      "{\"key\":\"request-139\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokenCount\":4770,\"totalTokenCount\":6817,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":4770,\"modality\":\"TEXT\"}]},\"responseId\":\"5RnRaM23Aceu1MkPsLjosQM\"}}\n",
      "{\"key\":\"request-140\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"5hnRaIOsD--g1MkPqbar8As\",\"usageMetadata\":{\"totalTokenCount\":6388,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4341}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":4341},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"key\":\"request-141\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"totalTokenCount\":5343,\"thoughtsTokenCount\":2047,\"promptTokenCount\":3296,\"promptTokensDetails\":[{\"tokenCount\":3296,\"modality\":\"TEXT\"}]},\"responseId\":\"5BnRaL75JI2m1MkP-dXW8A0\"}}\n",
      "{\"key\":\"request-142\",\"response\":{\"responseId\":\"7RnRaPODIdCu1MkP4Pa02AM\",\"usageMetadata\":{\"promptTokenCount\":2605,\"totalTokenCount\":4652,\"promptTokensDetails\":[{\"tokenCount\":2605,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2932}],\"promptTokenCount\":2932,\"thoughtsTokenCount\":2047,\"totalTokenCount\":4979},\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"responseId\":\"6xnRaJLsMdOm1MkPq86KkA0\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-143\"}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"6xnRaLuxHt6q1MkPk4GcAQ\",\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":5126,\"promptTokenCount\":3079,\"promptTokensDetails\":[{\"tokenCount\":3079,\"modality\":\"TEXT\"}]}},\"key\":\"request-144\"}\n",
      "{\"response\":{\"responseId\":\"7RnRaMO8AfzQ1MkP2oq06Qs\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2703}],\"promptTokenCount\":2703,\"thoughtsTokenCount\":2047,\"totalTokenCount\":4750}},\"key\":\"request-145\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3786}],\"totalTokenCount\":5833,\"promptTokenCount\":3786,\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"6xnRaNT0OJHrugeS1PeADA\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-146\"}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4210,\"promptTokenCount\":2163,\"promptTokensDetails\":[{\"tokenCount\":2163,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"7BnRaKmgHIqd1MkP792HiAQ\"},\"key\":\"request-147\"}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":1639,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":3686,\"promptTokenCount\":1639},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"7BnRaImeCfOf1MkP1fu7sAw\"},\"key\":\"request-148\"}\n",
      "{\"key\":\"request-149\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3030}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":5077,\"promptTokenCount\":3030},\"responseId\":\"7BnRaLiyHdC01MkPhdjVSQ\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]}}\n",
      "{\"key\":\"request-150\",\"response\":{\"responseId\":\"7BnRaPjDO_Kw1MkP6IuHgAw\",\"usageMetadata\":{\"totalTokenCount\":4756,\"promptTokenCount\":2709,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":2709,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]}}\n",
      "{\"key\":\"request-151\",\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2842,\"modality\":\"TEXT\"}],\"promptTokenCount\":2842,\"totalTokenCount\":4889,\"thoughtsTokenCount\":2047},\"responseId\":\"7BnRaJfcNIqd1MkP792HiAQ\"}}\n",
      "{\"response\":{\"responseId\":\"7RnRaInBC8eu1MkPsLjosQM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2054,\"promptTokensDetails\":[{\"tokenCount\":2054,\"modality\":\"TEXT\"}],\"totalTokenCount\":4101}},\"key\":\"request-152\"}\n",
      "{\"response\":{\"responseId\":\"7RnRaMytJ_qk1MkPm5jdwAw\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3484}],\"totalTokenCount\":5531,\"thoughtsTokenCount\":2047,\"promptTokenCount\":3484}},\"key\":\"request-153\"}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"totalTokenCount\":5554,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3507}],\"promptTokenCount\":3507,\"thoughtsTokenCount\":2047},\"responseId\":\"7RnRaKmoAYG_1MkP7pHRkA0\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-154\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"-BnRaO_FFdOm1MkPq86KkA0\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4382}],\"totalTokenCount\":6429,\"promptTokenCount\":4382,\"thoughtsTokenCount\":2047}},\"key\":\"request-155\"}\n",
      "{\"key\":\"request-156\",\"response\":{\"responseId\":\"7hnRaIDuDd6q1MkPk4GcAQ\",\"candidates\":[{\"content\":{\"role\":\"model\",\"parts\":[{\"text\":\"layout_id: 156\\n\\n*   Identify the coordinates for the 'cabinet' object.\\n*   Calculate the centroid of the 'cabinet' object.\\n*   Identify the coordinates for the 'shower' object.\\n*   Calculate the centroid of the 'shower' object.\\n*   Calculate the Euclidean distance between the two centroids.\\n\\n**Step 1: Identify the coordinates for the 'cabinet' object.**\\nThe coordinates for the 'cabinet' are:\\nP_cabinet = [(-6.929, -1.303), (-7.229, -1.303), (-7.229, -1.003), (-6.929, -1.003)]\\n\\n**Step 2: Calculate the centroid of the 'cabinet' object.**\\nSince 'cabinet' is a rectangle\"}]},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2063,\"modality\":\"TEXT\"}],\"promptTokenCount\":2063,\"totalTokenCount\":4109,\"candidatesTokenCount\":184,\"thoughtsTokenCount\":1862}}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"7RnRaPDpGvKw1MkP6IuHgAw\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2349}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2349,\"totalTokenCount\":4396}},\"key\":\"request-157\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokenCount\":3671,\"totalTokenCount\":5718,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":3671,\"modality\":\"TEXT\"}]},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"7xnRaNHJBsmm1MkPt87E6AM\"},\"key\":\"request-158\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":3634,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3634}],\"totalTokenCount\":5681,\"thoughtsTokenCount\":2047},\"responseId\":\"7hnRaKiRCOej1MkPw-CmsQM\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]},\"key\":\"request-159\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"7hnRaMjrGfzQ1MkP2oq06Qs\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2163}],\"promptTokenCount\":2163,\"totalTokenCount\":4210,\"thoughtsTokenCount\":2047}},\"key\":\"request-160\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2905}],\"promptTokenCount\":2905,\"thoughtsTokenCount\":2047,\"totalTokenCount\":4952},\"responseId\":\"7hnRaKaTDJHrugeS1PeADA\"},\"key\":\"request-161\"}\n",
      "{\"key\":\"request-162\",\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":2552,\"modality\":\"TEXT\"}],\"promptTokenCount\":2552,\"totalTokenCount\":4599,\"thoughtsTokenCount\":2047},\"responseId\":\"7hnRaNv2EfOf1MkP1fu7sAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]}}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2849}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2849,\"totalTokenCount\":4896},\"responseId\":\"7xnRaP3uM_qk1MkPm5jdwAw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]},\"key\":\"request-163\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":1942,\"modality\":\"TEXT\"}],\"totalTokenCount\":3989,\"thoughtsTokenCount\":2047,\"promptTokenCount\":1942},\"responseId\":\"8BnRaNP4Ge-g1MkPqbar8As\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-164\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4890}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":6937,\"promptTokenCount\":4890},\"responseId\":\"7hnRaIS3MoG_1MkP7pHRkA0\"},\"key\":\"request-165\"}\n",
      "{\"response\":{\"responseId\":\"7xnRaLoH3qrUyQ-TgZwB\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":3327,\"modality\":\"TEXT\"}],\"promptTokenCount\":3327,\"thoughtsTokenCount\":2047,\"totalTokenCount\":5374},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]},\"key\":\"request-166\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5439}],\"promptTokenCount\":5439,\"thoughtsTokenCount\":2047,\"totalTokenCount\":7486},\"responseId\":\"7hnRaNj8G7qj1MkP2Znz6Qs\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-167\"}\n",
      "{\"response\":{\"responseId\":\"7hnRaMLeOe-g1MkPqbar8As\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokenCount\":1886,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1886}],\"totalTokenCount\":3933,\"thoughtsTokenCount\":2047}},\"key\":\"request-168\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":4042,\"promptTokenCount\":1995,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1995}]},\"responseId\":\"8BnRaMbALYG_1MkP7pHRkA0\"},\"key\":\"request-169\"}\n",
      "{\"key\":\"request-170\",\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"8BnRaPOsIbqj1MkP2Znz6Qs\",\"usageMetadata\":{\"promptTokenCount\":1683,\"totalTokenCount\":3730,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1683}],\"thoughtsTokenCount\":2047},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":3636,\"totalTokenCount\":5683,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3636}]},\"responseId\":\"8xnRaLu_CPaw1MkPzbHNuAM\",\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-171\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"9RnRaN_CE5HrugeS1PeADA\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2669,\"totalTokenCount\":4716,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2669}]}},\"key\":\"request-172\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"khvRaM-iBtGe1MkP2fSSsQM\",\"usageMetadata\":{\"promptTokenCount\":2235,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2235}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":4282},\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-173\"}\n",
      "{\"response\":{\"responseId\":\"9RnRaPeZBtWd1MkPjL-hgQk\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1588}],\"promptTokenCount\":1588,\"totalTokenCount\":3635,\"thoughtsTokenCount\":2047},\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-174\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1865}],\"totalTokenCount\":3912,\"thoughtsTokenCount\":2047,\"promptTokenCount\":1865},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"-hnRaJayF96q1MkPk4GcAQ\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}]},\"key\":\"request-175\"}\n",
      "{\"key\":\"request-176\",\"response\":{\"responseId\":\"-BnRaLq0Abqj1MkP2Znz6Qs\",\"usageMetadata\":{\"totalTokenCount\":5827,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3780}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3780},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"totalTokenCount\":7178,\"promptTokenCount\":5131,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":5131}]},\"responseId\":\"kRvRaI7CIYHpugfP3oaJDA\"},\"key\":\"request-177\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokenCount\":2234,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2234}],\"totalTokenCount\":4281,\"thoughtsTokenCount\":2047},\"responseId\":\"9hnRaOjFCfzQ1MkP2oq06Qs\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}]},\"key\":\"request-178\"}\n",
      "{\"key\":\"request-179\",\"response\":{\"responseId\":\"9xnRaN36K5HrugeS1PeADA\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"totalTokenCount\":5503,\"promptTokenCount\":3456,\"promptTokensDetails\":[{\"tokenCount\":3456,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":2975,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2975}],\"totalTokenCount\":5022},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"responseId\":\"9xnRaPuTLtC01MkPhdjVSQ\"},\"key\":\"request-180\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2622}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":2622,\"totalTokenCount\":4669},\"responseId\":\"9xnRaJCHOvum1MkPjarGwQM\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}]},\"key\":\"request-181\"}\n",
      "{\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"9xnRaIb5DO-g1MkPqbar8As\",\"usageMetadata\":{\"promptTokenCount\":2648,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2648}],\"totalTokenCount\":4695,\"thoughtsTokenCount\":2047}},\"key\":\"request-182\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\",\"parts\":[{\"text\":\"layout_id: 183\\n\\n*   Identify the coordinates for 'door_2'.\\n*   Calculate the centroid of 'door_2'.\\n*   Identify the coordinates for 'door_3'.\\n*   Calculate the centroid of 'door_3'.\\n*   Compute the Euclidean distance between the two centroids.\\n*   Round the final distance to three decimal places.\\n\\n**Step 1: Extract coordinates for 'door_2'**\\nThe points for 'door_2' are:\\nP1 = {\\\"x\\\": -9.547\"}]},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":4156,\"modality\":\"TEXT\"}],\"candidatesTokenCount\":119,\"totalTokenCount\":6202,\"promptTokenCount\":4156,\"thoughtsTokenCount\":1927},\"responseId\":\"kRvRaNiEBvWx1MkPwc_C-Qs\"},\"key\":\"request-183\"}\n",
      "{\"response\":{\"usageMetadata\":{\"totalTokenCount\":5580,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3533}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3533},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"responseId\":\"9xnRaLmfG42m1MkP-dXW8A0\"},\"key\":\"request-184\"}\n",
      "{\"key\":\"request-185\",\"response\":{\"responseId\":\"9hnRaL3lPPaw1MkPzbHNuAM\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":1817,\"totalTokenCount\":3864,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1817}],\"thoughtsTokenCount\":2047},\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"index\":0,\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1891}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":3938,\"promptTokenCount\":1891},\"responseId\":\"9xnRaKeyGvKw1MkP6IuHgAw\"},\"key\":\"request-186\"}\n",
      "{\"key\":\"request-187\",\"response\":{\"responseId\":\"9hnRaKLMN_zQ1MkP2oq06Qs\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"promptTokenCount\":2357,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2357}],\"thoughtsTokenCount\":2047,\"totalTokenCount\":4404}}}\n",
      "{\"response\":{\"responseId\":\"jRvRaLLkFt6q1MkPk4GcAQ\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"usageMetadata\":{\"promptTokenCount\":3733,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3733}],\"totalTokenCount\":5780}},\"key\":\"request-188\"}\n",
      "{\"key\":\"request-189\",\"response\":{\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3994}],\"promptTokenCount\":3994,\"thoughtsTokenCount\":2047,\"totalTokenCount\":6041},\"responseId\":\"9xnRaIK3HdCu1MkP4Pa02AM\",\"modelVersion\":\"gemini-2.5-flash\"}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokenCount\":4007,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4007}],\"totalTokenCount\":6054},\"responseId\":\"kRvRaKflJr-x1MkPvcz0qQM\"},\"key\":\"request-190\"}\n",
      "{\"response\":{\"responseId\":\"9xnRaLfnOvum1MkPjarGwQM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"usageMetadata\":{\"promptTokenCount\":4675,\"thoughtsTokenCount\":2047,\"totalTokenCount\":6722,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":4675}]},\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-191\"}\n",
      "{\"response\":{\"responseId\":\"-BnRaN3LG4G_1MkP7pHRkA0\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"totalTokenCount\":3642,\"promptTokenCount\":1595,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":1595,\"modality\":\"TEXT\"}]}},\"key\":\"request-192\"}\n",
      "{\"key\":\"request-193\",\"response\":{\"responseId\":\"9xnRaPTsK_WSjMcPjq-26Qg\",\"usageMetadata\":{\"totalTokenCount\":5076,\"promptTokensDetails\":[{\"tokenCount\":3029,\"modality\":\"TEXT\"}],\"thoughtsTokenCount\":2047,\"promptTokenCount\":3029},\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"},\"index\":0}]}}\n",
      "{\"response\":{\"candidates\":[{\"index\":0,\"finishReason\":\"MAX_TOKENS\",\"content\":{\"role\":\"model\"}}],\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"totalTokenCount\":4413,\"thoughtsTokenCount\":2047,\"promptTokenCount\":2366,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":2366}]},\"responseId\":\"-BnRaNaEBdOm1MkPq86KkA0\"},\"key\":\"request-194\"}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"usageMetadata\":{\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"tokenCount\":2400,\"modality\":\"TEXT\"}],\"totalTokenCount\":4447,\"promptTokenCount\":2400},\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"responseId\":\"-BnRaK6wMN6q1MkPk4GcAQ\"},\"key\":\"request-195\"}\n",
      "{\"key\":\"request-196\",\"response\":{\"usageMetadata\":{\"promptTokenCount\":3115,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3115}],\"totalTokenCount\":5162,\"thoughtsTokenCount\":2047},\"responseId\":\"9xnRaJnJL4LHjMcP2tbGuQw\",\"modelVersion\":\"gemini-2.5-flash\",\"candidates\":[{\"index\":0,\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\"}]}}\n",
      "{\"response\":{\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"-BnRaPGWDLqj1MkP2Znz6Qs\",\"usageMetadata\":{\"promptTokensDetails\":[{\"tokenCount\":1985,\"modality\":\"TEXT\"}],\"promptTokenCount\":1985,\"totalTokenCount\":4032,\"thoughtsTokenCount\":2047},\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}]},\"key\":\"request-197\"}\n",
      "{\"response\":{\"usageMetadata\":{\"promptTokenCount\":1948,\"thoughtsTokenCount\":2047,\"totalTokenCount\":3995,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":1948}]},\"responseId\":\"-BnRaMHgKeej1MkPw-CmsQM\",\"candidates\":[{\"content\":{\"role\":\"model\"},\"finishReason\":\"MAX_TOKENS\",\"index\":0}],\"modelVersion\":\"gemini-2.5-flash\"},\"key\":\"request-198\"}\n",
      "{\"key\":\"request-199\",\"response\":{\"candidates\":[{\"content\":{\"role\":\"model\"},\"index\":0,\"finishReason\":\"MAX_TOKENS\"}],\"usageMetadata\":{\"totalTokenCount\":5518,\"promptTokenCount\":3471,\"thoughtsTokenCount\":2047,\"promptTokensDetails\":[{\"modality\":\"TEXT\",\"tokenCount\":3471}]},\"modelVersion\":\"gemini-2.5-flash\",\"responseId\":\"kRvRaO6WO_Kw1MkP6IuHgAw\"}}\n",
      "\n",
      "Results saved to /home/rodionfa/FloorplanQA/qa_response/pair_distance/hssd_data_simplified/gemini-2.5-flash_12288.jsonl\n"
     ]
    }
   ],
   "source": [
    "if batch_job_file.state.name == 'JOB_STATE_SUCCEEDED':\n",
    "\n",
    "    # If batch job was created with a file\n",
    "    if batch_job_file.dest and batch_job_file.dest.file_name:\n",
    "        # Results are in a file\n",
    "        result_file_name = batch_job_file.dest.file_name\n",
    "        print(f\"Results are in file: {result_file_name}\")\n",
    "\n",
    "        print(\"Downloading result file content...\")\n",
    "        file_content = client.files.download(file=result_file_name)\n",
    "        # Process file_content (bytes) as needed\n",
    "        print(file_content.decode('utf-8'))\n",
    "\n",
    "        output_file = base_output_path.format(\n",
    "            dataset=dataset,\n",
    "            room_type=room_type,\n",
    "            model_id=model_id,\n",
    "            max_tokens=tokens_limit\n",
    "        )\n",
    "\n",
    "            # Convert to JSONL format\n",
    "        with open(output_file, \"w\") as f:\n",
    "            for line in file_content.decode('utf-8').splitlines():\n",
    "                if line.strip():\n",
    "                    f.write(json.dumps(json.loads(line)) + \"\\n\")\n",
    "        print(f\"Results saved to {output_file}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc4532cb",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "plan_b",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
