{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "from dotenv import load_dotenv\n",
    "from src.llm_messenger.messengers.gpt_messenger import GPTMessenger\n",
    "from src.domain_translator.image_provider import PexelsImageProvider\n",
    "from src.domain_translator.translator import translate_from_geometric_concepts, query_images_for_translations, check_with_multimodal\n",
    "from src.domain_translator.translation_composer import generate_dataset_from_translations\n",
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "load_dotenv()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "translations_directory = \"../../bongard_translated_with_multimodal_check\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "gpt4turbo = GPTMessenger(api_key=os.environ[\"OPENAI_API_KEY\"], log_directory=translations_directory)\n",
    "gpt4o = GPTMessenger(model_name=\"gpt-4o\", api_key=os.environ[\"OPENAI_API_KEY\"], log_directory=translations_directory)\n",
    "pexels = PexelsImageProvider(api_key=os.environ[\"PEXELS_API_KEY\"])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "translate_from_geometric_concepts(\n",
    "    rows_to_translate=range(1, 101),\n",
    "    geometric_labels_csv_path=\"../data/raw/labels.csv\",\n",
    "    output_path=translations_directory,\n",
    "    model=gpt4o,\n",
    "    trials=10\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "query_images_for_translations(\n",
    "    translations_directory=translations_directory,\n",
    "    img_provider=pexels,\n",
    "    imgs_per_concept=15\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "check_with_multimodal(\n",
    "    problem_ids=range(1, 101),\n",
    "    translations_directory=translations_directory,\n",
    "    model=gpt4o,\n",
    "    stop_after_n_approved_images=7,\n",
    "    stop_after_n_approved_translations=4\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "generate_dataset_from_translations(translations_directory, \"../data/raw/translated_final\", 3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "problems_in_translated_dataset = os.listdir(\"../data/raw/translated_final\")\n",
    "geometric_labels = pd.read_csv(\"../data/raw/labels.csv\")\n",
    "problems_that_are_not_translated = pd.DataFrame(columns=geometric_labels.columns)\n",
    "\n",
    "\n",
    "for problem_id in range(1, 101):\n",
    "    if str(problem_id) in problems_in_translated_dataset:\n",
    "        continue\n",
    "    \n",
    "    row = geometric_labels.iloc[problem_id - 1]\n",
    "    problems_that_are_not_translated.loc[len(problems_that_are_not_translated)] = row"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   Bongard Problem #                                     Left-side Rule                                    Right-side Rule\n",
      "0              BP#12                    Convex hull of figure elongated                      Convex hull of figure compact\n",
      "1              BP#20             Points located on one side of the neck           Points located on both sides of the neck\n",
      "2              BP#25                         Black figure is a triangle                           Black figure is a circle\n",
      "3              BP#26                               Solid black triangle                            No solid black triangle\n",
      "4              BP#27                           More solid black figures                               More outline figures\n",
      "5              BP#29  There are more small circles inside the figure...  There are fewer small circles inside the figur...\n",
      "6              BP#35  The axis of the hole is parallel to the figure...  The axis of the hole is perpendicular to the f...\n",
      "7              BP#36                              Triangle above circle                              Circle above triangle\n",
      "8              BP#37                              Triangle above circle                              Circle above triangle\n",
      "9              BP#38                        Triangle larger than circle                       Triangle smaller than circle\n",
      "10             BP#41               Outline circles on one straight line           Outline circles not on one straight line\n",
      "11             BP#42  Points inside the figure outline are on a stra...  Points inside the figure outline are not on a ...\n",
      "12             BP#43  The vibration amplitude increases from left to...  The vibration amplitude decreases from left to...\n",
      "13             BP#44                    Small circles on different arcs                           Small circles on one arc\n",
      "14             BP#45        Outline figure on top of solid black figure              Black figure on top of outline figure\n",
      "15             BP#46                      Triangle on top of the circle                      Circle on top of the triangle\n",
      "16             BP#47                      Triangle inside of the circle                      Circle inside of the triangle\n",
      "17             BP#48       Solid dark figures above the outline figures       Outline figures above the solid dark figures\n",
      "18             BP#49  Points inside the figure outline are grouped m...  Points outside the figure contour are grouped ...\n",
      "19             BP#53  Inside figure has fewer angles than outside fi...  Inside figure has more angles than outside figure\n",
      "20             BP#54  A cross, circle, and triangle arranged counter...   A cross, circle, and triangle arranged clockwise\n",
      "21             BP#55  A circle is at the left of the cavity if you l...  A circle is at the right of the cavity if you ...\n",
      "22             BP#58               Solid dark quadrangles are identical               Solid dark quadrangles are different\n",
      "23             BP#60                               Some similar figures                                 No similar figures\n",
      "24             BP#61               A line separates the crosses in half       A line does not separate the crosses in half\n",
      "25             BP#64  A cross is located on the extension of the ell...  A circle is located on the extension of the el...\n",
      "26             BP#65          A set of triangles elongated horizontally            A set of triangles elongated vertically\n",
      "27             BP#66           Unconnected circles on a horizontal line             Unconnected circles on a vertical line\n",
      "28             BP#67  The right branch begins at a higher point than...  The right branch begins at a lower point than ...\n",
      "29             BP#68  The end of the right branch is higher than tha...  The end of the right branch is lower than that...\n",
      "30             BP#69                 Large black dot on the main branch                   Large black dot on a side branch\n",
      "31             BP#73  The long axes of the ellipse and rectangle are...  The long axes of the ellipse and rectangle are...\n",
      "32             BP#74                   A tail grows from the obtuse end                    A tail grows from the acute end\n",
      "33             BP#75     Triangle located at the concave side of an arc      Triangle located at the convex side of an arc\n",
      "34             BP#77                              Angle divided in half                          Angle not divided in half\n",
      "35             BP#78          Extensions of segments cross at one point   Extensions of segments do not cross at one point\n",
      "36             BP#79  A dark circle is closer to the outline circle ...  A dark circle is closer to the triangle than t...\n",
      "37             BP#80  Points located at the same distances from a cross  Points located at different distances from a c...\n",
      "38             BP#81  Dark figures can be divided from outline figur...  Dark figures are impossible to separate  alter...\n",
      "39             BP#82  The convex hull of the crosses forms an equila...  The convex hull of the crosses does not form a...\n",
      "40             BP#83     A circle is inside of a figure made by crosses    A circle is outside of a figure made by crosses\n",
      "41             BP#84  A quadrangle is outside of a figure made by ci...  A quadrangle is inside of a figure made by cir...\n",
      "42             BP#85                                        Three parts                                         Five parts\n",
      "43             BP#89                                        Three parts                                         Five parts\n",
      "44             BP#93                        Branches at outlined circle                      Branches at solid dark circle\n",
      "45             BP#94                       Solid dark circle not at end                           Solid dark circle at end\n",
      "46             BP#99   Outlines made by triangles and circles intersect  Outlines made by triangles and circles do not ...\n"
     ]
    }
   ],
   "source": [
    "with pd.option_context('expand_frame_repr', False):\n",
    "    print(problems_that_are_not_translated)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
