{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import necessary lab\n",
    "from src.graph.builder import umls_mapping_graph\n",
    "import requests\n",
    "import pandas as pd\n",
    "import logging\n",
    "from src.config.agents import AGENT_LLM_MAP\n",
    "from src.prompts.template import apply_prompt_template"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get more data for model performance evaluation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "1.Get CUI code data through ‘HPO code’ and 'agent_code'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "   Unnamed: 0             Section  \\\n",
      "0           0  Mother's Pregnancy   \n",
      "1           1  Mother's Pregnancy   \n",
      "2           2  Mother's Pregnancy   \n",
      "3           3  Mother's Pregnancy   \n",
      "4           4  Mother's Pregnancy   \n",
      "\n",
      "                                            Question  \\\n",
      "0  Amniotic fluid issue - Too much fluid (polyhyd...   \n",
      "1                           Decreased fetal movement   \n",
      "2                              Delivery complication   \n",
      "3                            Maternal health problem   \n",
      "4                                    Placental issue   \n",
      "\n",
      "                           true_term    HPO_code  true_CUI  \\\n",
      "0  Abnormality of the amniotic fluid  HP:0001560  C0266781   \n",
      "1           Decreased fetal movement  HP:0001558  C0235659   \n",
      "2                  Abnormal delivery  HP:0001787  C0549629   \n",
      "3      Prenatal maternal abnormality  HP:0002686  C4531020   \n",
      "4        Abnormality of the placenta  HP:0100767  C1306893   \n",
      "\n",
      "                          agent_term  agent_code agent_CUI  confidence  ...  \\\n",
      "0  Abnormality of the amniotic fluid  HP:0001560  C0266781         0.9  ...   \n",
      "1           Decreased fetal movement  HP:0001558  C0235659         1.0  ...   \n",
      "2              Delivery complication  HP:0001787  C0549629         1.0  ...   \n",
      "3      Prenatal maternal abnormality  HP:0002686  C4531020         1.0  ...   \n",
      "4        Abnormality of the placenta  HP:0100767  C1306893         0.9  ...   \n",
      "\n",
      "   BERT_CUI overmapping.1                                          meta_term  \\\n",
      "0  C0266781           2.0  Oligohydramnios, Polyhydramnios, Problem, Too ...   \n",
      "1  C0235659           NaN                             Reduced fetal movement   \n",
      "2  C0549629           NaN                           Complication of delivery   \n",
      "3  C4531020           NaN                            Maternal health problem   \n",
      "4  C1306893           NaN                                Anomaly of placenta   \n",
      "\n",
      "   meta_CUI overmapping.2 ctake_CUI overmapping.3  \\\n",
      "0  C0079924           4.0  C0037313           2.0   \n",
      "1  C0235659           NaN  C0235659           3.0   \n",
      "2  C0852962           NaN  C0009566           NaN   \n",
      "3  C4531020           NaN  C0033213           NaN   \n",
      "4  C1306893           NaN  C0033213           NaN   \n",
      "\n",
      "                                      GPT5_term   GPT5_code  GPT5_CUI  \n",
      "0             Abnormality of the amniotic fluid  HP:0001560  C0266781  \n",
      "1                      Decreased fetal movement  HP:0001558  C0235659  \n",
      "2  Abnormality of prenatal development or birth  HP:0001197  C4025797  \n",
      "3                                           NaN         NaN       NaN  \n",
      "4                   Abnormality of the placenta  HP:0011410  C0007876  \n",
      "\n",
      "[5 rows x 26 columns]\n"
     ]
    }
   ],
   "source": [
    "# Read the excel mapping results data\n",
    "excel_file_path = \"mapped_gc.xlsx\"\n",
    "df = pd.read_excel(excel_file_path)\n",
    "print(df.head())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# getting CUI code from HPO code\n",
    "def get_cui_from_ontology(hpo_code):\n",
    "    \"\"\" Get CUI from a specific ontology term. \"\"\"\n",
    "    response = requests.get(f\"{API_BASE_URL}/hpo_to_cui/{hpo_code}\")\n",
    "    print(f\"Response content for HPO code {hpo_code}:\", response.text)\n",
    "    try:\n",
    "        return response.json()[\"cui\"]\n",
    "    except KeyError:\n",
    "        print(\"Key 'cui' not found in response.\")\n",
    "        return None  # or raise an error/log as needed\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get CUI for agent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Response content for HPO code HP:0001560: {\"hpo_code\":\"HP:0001560\",\"cui\":\"C0266781\"}\n",
      "Response content for HPO code HP:0001558: {\"hpo_code\":\"HP:0001558\",\"cui\":\"C0235659\"}\n",
      "Response content for HPO code HP:0001787: {\"hpo_code\":\"HP:0001787\",\"cui\":\"C0549629\"}\n",
      "Response content for HPO code HP:0002686: {\"hpo_code\":\"HP:0002686\",\"cui\":\"C4531020\"}\n",
      "Response content for HPO code HP:0100767: {\"hpo_code\":\"HP:0100767\",\"cui\":\"C1306893\"}\n",
      "Response content for HPO code HP:0011438: {\"hpo_code\":\"HP:0011438\",\"cui\":\"C4023357\"}\n",
      "Response content for HPO code HP:0001622: {\"hpo_code\":\"HP:0001622\",\"cui\":\"C0151526\"}\n",
      "Response content for HPO code HP:0010881: {\"hpo_code\":\"HP:0010881\",\"cui\":\"C0266785\"}\n",
      "Response content for HPO code HP:0001548: {\"hpo_code\":\"HP:0001548\",\"cui\":\"C1849265\"}\n",
      "Response content for HPO code HP:0001513: {\"hpo_code\":\"HP:0001513\",\"cui\":\"C0028754\"}\n",
      "Response content for HPO code HP:0012743: {\"hpo_code\":\"HP:0012743\",\"cui\":\"C0311277\"}\n",
      "Response content for HPO code HP:0001528: {\"hpo_code\":\"HP:0001528\",\"cui\":\"C0332890\"}\n",
      "Response content for HPO code HP:0004322: {\"hpo_code\":\"HP:0004322\",\"cui\":\"C0349588\"}\n",
      "Response content for HPO code HP:0008929: {\"hpo_code\":\"HP:0008929\",\"cui\":\"C4024614\"}\n",
      "Response content for HPO code HP:0001508: {\"hpo_code\":\"HP:0001508\",\"cui\":\"C2315100\"}\n",
      "Response content for HPO code HP:0034323: {\"hpo_code\":\"HP:0034323\",\"cui\":\"C0271561\"}\n",
      "Response content for HPO code HP:0000845: {\"hpo_code\":\"HP:0000845\",\"cui\":\"C0235986\"}\n",
      "Response content for HPO code HP:0000098: {\"hpo_code\":\"HP:0000098\",\"cui\":\"C0241240\"}\n",
      "Response content for HPO code HP:0005978: {\"hpo_code\":\"HP:0005978\",\"cui\":\"C0011860\"}\n",
      "Response content for HPO code HP:0100651: {\"hpo_code\":\"HP:0100651\",\"cui\":\"C0011854\"}\n",
      "Response content for HPO code HP:0000823: {\"hpo_code\":\"HP:0000823\",\"cui\":\"C0034012\"}\n",
      "Response content for HPO code HP:0000873: {\"hpo_code\":\"HP:0000873\",\"cui\":\"C0011848\"}\n",
      "Response content for HPO code HP:0034323: {\"hpo_code\":\"HP:0034323\",\"cui\":\"C0271561\"}\n",
      "Response content for HPO code HP:0000826: {\"hpo_code\":\"HP:0000826\",\"cui\":\"C0034013\"}\n",
      "Response content for HPO code HP:0000135: {\"hpo_code\":\"HP:0000135\",\"cui\":\"C0020619\"}\n",
      "Response content for HPO code HP:0008221: {\"hpo_code\":\"HP:0008221\",\"cui\":\"C1621895\"}\n",
      "Response content for HPO code HP:0000836: {\"hpo_code\":\"HP:0000836\",\"cui\":\"C0020550\"}\n",
      "Response content for HPO code HP:0000821: {\"hpo_code\":\"HP:0000821\",\"cui\":\"C0020676\"}\n",
      "Response content for HPO code HP:0008191: {\"hpo_code\":\"HP:0008191\",\"cui\":\"C4020805\"}\n",
      "Response content for HPO code HP:0000853: {\"hpo_code\":\"HP:0000853\",\"cui\":\"C0018021\"}\n",
      "Response content for HPO code HP:0011767: {\"hpo_code\":\"HP:0011767\",\"cui\":\"C4023198\"}\n",
      "Response content for HPO code HP:0000828: {\"hpo_code\":\"HP:0000828\",\"cui\":\"C4025822\"}\n",
      "Response content for HPO code HP:0003002: {\"hpo_code\":\"HP:0003002\",\"cui\":\"C0678222\"}\n",
      "Response content for HPO code HP:0100615: {\"hpo_code\":\"HP:0100615\",\"cui\":\"C0919267\"}\n",
      "Response content for HPO code HP:0010784: {\"hpo_code\":\"HP:0010784\",\"cui\":\"C0153567\"}\n",
      "Response content for HPO code HP:0030079: {\"hpo_code\":\"HP:0030079\",\"cui\":\"C4048328\"}\n",
      "Response content for HPO code HP:0100787: {\"hpo_code\":\"HP:0100787\",\"cui\":\"C0033578\"}\n",
      "Response content for HPO code HP:0012125: {\"hpo_code\":\"HP:0012125\",\"cui\":\"C0376358\"}\n",
      "Response content for HPO code HP:0100526: {\"hpo_code\":\"HP:0100526\",\"cui\":\"C0242379\"}\n",
      "Response content for HPO code HP:0003003: {\"hpo_code\":\"HP:0003003\",\"cui\":\"C0007102\"}\n",
      "Response content for HPO code HP:0100834: {\"hpo_code\":\"HP:0100834\",\"cui\":\"C0009404\"}\n",
      "Response content for HPO code HP:0002894: {\"hpo_code\":\"HP:0002894\",\"cui\":\"C0346647\"}\n",
      "Response content for HPO code HP:0009725: {\"hpo_code\":\"HP:0009725\",\"cui\":\"C0005695\"}\n",
      "Response content for HPO code HP:0009726: {\"hpo_code\":\"HP:0009726\",\"cui\":\"C1378703\"}\n",
      "Response content for HPO code HP:0100031: {\"hpo_code\":\"HP:0100031\",\"cui\":\"C0040136\"}\n",
      "Response content for HPO code HP:0040198: {\"hpo_code\":\"HP:0040198\",\"cui\":\"C3501843\"}\n",
      "Response content for HPO code HP:0002861: {\"hpo_code\":\"HP:0002861\",\"cui\":\"C0025202\"}\n",
      "Response content for HPO code HP:0012056: {\"hpo_code\":\"HP:0012056\",\"cui\":\"C0151779\"}\n",
      "Response content for HPO code HP:0012288: {\"hpo_code\":\"HP:0012288\",\"cui\":\"C0278996\"}\n",
      "Response content for HPO code HP:0100006: {\"hpo_code\":\"HP:0100006\",\"cui\":\"C0085136\"}\n",
      "Response content for HPO code HP:0012126: {\"hpo_code\":\"HP:0012126\",\"cui\":\"C0024623\"}\n",
      "Response content for HPO code HP:0000306: {\"hpo_code\":\"HP:0000306\",\"cui\":\"C4025864\"}\n",
      "Response content for HPO code HP:0000202: {\"hpo_code\":\"HP:0000202\",\"cui\":\"C0158646\"}\n",
      "Response content for HPO code HP:0001999: {\"hpo_code\":\"HP:0001999\",\"cui\":\"C0424503\"}\n",
      "Response content for HPO code HP:0001595: {\"hpo_code\":\"HP:0001595\",\"cui\":\"C0157733\"}\n",
      "Response content for HPO code HP:0000163: {\"hpo_code\":\"HP:0000163\",\"cui\":\"C4025887\"}\n",
      "Response content for HPO code HP:0000153: {\"hpo_code\":\"HP:0000153\",\"cui\":\"C0026633\"}\n",
      "Response content for HPO code HP:0000464: {\"hpo_code\":\"HP:0000464\",\"cui\":\"C0266623\"}\n",
      "Response content for HPO code HP:0000366: {\"hpo_code\":\"HP:0000366\",\"cui\":\"C0265736\"}\n",
      "Response content for HPO code HP:0000929: {\"hpo_code\":\"HP:0000929\",\"cui\":\"C0235942\"}\n",
      "Response content for HPO code HP:0200136: {\"hpo_code\":\"HP:0200136\",\"cui\":\"C0267071\"}\n",
      "Response content for HPO code HP:0002015: {\"hpo_code\":\"HP:0002015\",\"cui\":\"C0011168\"}\n",
      "Response content for HPO code HP:0000496: {\"hpo_code\":\"HP:0000496\",\"cui\":\"C0497202\"}\n",
      "Response content for HPO code HP:0100887: {\"hpo_code\":\"HP:0100887\",\"cui\":\"C4021945\"}\n",
      "Response content for HPO code HP:0000525: {\"hpo_code\":\"HP:0000525\",\"cui\":\"C4025845\"}\n",
      "Response content for HPO code HP:0000517: {\"hpo_code\":\"HP:0000517\",\"cui\":\"C0549651\"}\n",
      "Response content for HPO code HP:0000504: {\"hpo_code\":\"HP:0000504\",\"cui\":\"C4025846\"}\n",
      "Response content for HPO code HP:0000540: {\"hpo_code\":\"HP:0000540\",\"cui\":\"C0020490\"}\n",
      "Response content for HPO code HP:0000545: {\"hpo_code\":\"HP:0000545\",\"cui\":\"C0027092\"}\n",
      "Response content for HPO code HP:0000587: {\"hpo_code\":\"HP:0000587\",\"cui\":\"C0029131\"}\n",
      "Response content for HPO code HP:0000479: {\"hpo_code\":\"HP:0000479\",\"cui\":\"C0035300\"}\n",
      "Response content for HPO code HP:0000508: {\"hpo_code\":\"HP:0000508\",\"cui\":\"C0005745\"}\n",
      "Response content for HPO code HP:0001488: {\"hpo_code\":\"HP:0001488\",\"cui\":\"C1865916\"}\n",
      "Response content for HPO code HP:0000589: {\"hpo_code\":\"HP:0000589\",\"cui\":\"C0009363\"}\n",
      "Response content for HPO code HP:0000356: {\"hpo_code\":\"HP:0000356\",\"cui\":\"C1846460\"}\n",
      "Response content for HPO code HP:0000405: {\"hpo_code\":\"HP:0000405\",\"cui\":\"C0018777\"}\n",
      "Response content for HPO code HP:0000407: {\"hpo_code\":\"HP:0000407\",\"cui\":\"C0018784\"}\n",
      "Response content for HPO code HP:0000410: {\"hpo_code\":\"HP:0000410\",\"cui\":\"C0155552\"}\n",
      "Response content for HPO code HP:0000365: {\"hpo_code\":\"HP:0000365\",\"cui\":\"C0011053\"}\n",
      "Response content for HPO code HP:0000360: {\"hpo_code\":\"HP:0000360\",\"cui\":\"C0040264\"}\n",
      "Response content for HPO code HP:0010780: {\"hpo_code\":\"HP:0010780\",\"cui\":\"C0034880\"}\n",
      "Response content for HPO code HP:0002321: {\"hpo_code\":\"HP:0002321\",\"cui\":\"C0012833\"}\n",
      "Response content for HPO code HP:0002011: {\"hpo_code\":\"HP:0002011\",\"cui\":\"C4021765\"}\n",
      "Response content for HPO code HP:0100021: {\"hpo_code\":\"HP:0100021\",\"cui\":\"C0007789\"}\n",
      "Response content for HPO code HP:0100543: {\"hpo_code\":\"HP:0100543\",\"cui\":\"C0683322\"}\n",
      "Response content for HPO code HP:0011443: {\"hpo_code\":\"HP:0011443\",\"cui\":\"C4023353\"}\n",
      "Response content for HPO code HP:0002353: {\"hpo_code\":\"HP:0002353\",\"cui\":\"C0151611\"}\n",
      "Response content for HPO code HP:0001298: {\"hpo_code\":\"HP:0001298\",\"cui\":\"C0085584\"}\n",
      "Response content for HPO code HP:0006846: {\"hpo_code\":\"HP:0006846\",\"cui\":\"C1306587\"}\n",
      "Response content for HPO code HP:0001276: {\"hpo_code\":\"HP:0001276\",\"cui\":\"C0026826\"}\n",
      "Response content for HPO code HP:0001290: {\"hpo_code\":\"HP:0001290\",\"cui\":\"C1858120\"}\n",
      "Response content for HPO code HP:0002354: {\"hpo_code\":\"HP:0002354\",\"cui\":\"C0542476\"}\n",
      "Response content for HPO code HP:0100022: {\"hpo_code\":\"HP:0100022\",\"cui\":\"C0026650\"}\n",
      "Response content for HPO code HP:0001300: {\"hpo_code\":\"HP:0001300\",\"cui\":\"C0242422\"}\n",
      "Response content for HPO code HP:0001250: {\"hpo_code\":\"HP:0001250\",\"cui\":\"C0014544\"}\n",
      "Response content for HPO code HP:0000729: {\"hpo_code\":\"HP:0000729\",\"cui\":\"C0856975\"}\n",
      "Response content for HPO code HP:0007302: {\"hpo_code\":\"HP:0007302\",\"cui\":\"C0005586\"}\n",
      "Response content for HPO code HP:0100753: {\"hpo_code\":\"HP:0100753\",\"cui\":\"C0036341\"}\n",
      "Response content for HPO code HP:0000733: {\"hpo_code\":\"HP:0000733\",\"cui\":\"C0038271\"}\n",
      "Response content for HPO code HP:0006919: {\"hpo_code\":\"HP:0006919\",\"cui\":\"C4024963\"}\n",
      "Response content for HPO code HP:0000718: {\"hpo_code\":\"HP:0000718\",\"cui\":\"C0001807\"}\n",
      "Response content for HPO code HP:0000739: {\"hpo_code\":\"HP:0000739\",\"cui\":\"C0003467\"}\n",
      "Response content for HPO code HP:0000716: {\"hpo_code\":\"HP:0000716\",\"cui\":\"C0011581\"}\n",
      "Response content for HPO code HP:0000746: {\"hpo_code\":\"HP:0000746\",\"cui\":\"C0011253\"}\n",
      "Response content for HPO code HP:0000738: {\"hpo_code\":\"HP:0000738\",\"cui\":\"C0018524\"}\n",
      "Response content for HPO code HP:0000722: {\"hpo_code\":\"HP:0000722\",\"cui\":\"C0600104\"}\n",
      "Response content for HPO code HP:0000709: {\"hpo_code\":\"HP:0000709\",\"cui\":\"C0033975\"}\n",
      "Response content for HPO code HP:0000736: {\"hpo_code\":\"HP:0000736\",\"cui\":\"C0262630\"}\n",
      "Response content for HPO code HP:0001075: {\"hpo_code\":\"HP:0001075\",\"cui\":\"C0162154\"}\n",
      "Response content for HPO code HP:0000957: {\"hpo_code\":\"HP:0000957\",\"cui\":\"C0265974\"}\n",
      "Response content for HPO code HP:0000953: {\"hpo_code\":\"HP:0000953\",\"cui\":\"C0162834\"}\n",
      "Response content for HPO code HP:0001010: {\"hpo_code\":\"HP:0001010\",\"cui\":\"C0162835\"}\n",
      "Response content for HPO code HP:0000966: {\"hpo_code\":\"HP:0000966\",\"cui\":\"C0553721\"}\n",
      "Response content for HPO code HP:0000975: {\"hpo_code\":\"HP:0000975\",\"cui\":\"C0700590\"}\n",
      "Response content for HPO code HP:0001030: {\"hpo_code\":\"HP:0001030\",\"cui\":\"C0241181\"}\n",
      "Response content for HPO code HP:0000992: {\"hpo_code\":\"HP:0000992\",\"cui\":\"C0349506\"}\n",
      "Response content for HPO code HP:0001072: {\"hpo_code\":\"HP:0001072\",\"cui\":\"C4020878\"}\n",
      "Response content for HPO code HP:0000974: {\"hpo_code\":\"HP:0000974\",\"cui\":\"C0241074\"}\n",
      "Response content for HPO code HP:0000973: {\"hpo_code\":\"HP:0000973\",\"cui\":\"C0010495\"}\n",
      "Response content for HPO code HP:0002813: {\"hpo_code\":\"HP:0002813\",\"cui\":\"C4082761\"}\n",
      "Response content for HPO code HP:0010674: {\"hpo_code\":\"HP:0010674\",\"cui\":\"C4023747\"}\n",
      "Response content for HPO code HP:0001382: {\"hpo_code\":\"HP:0001382\",\"cui\":\"C1862377\"}\n",
      "Response content for HPO code HP:0002659: {\"hpo_code\":\"HP:0002659\",\"cui\":\"C1390474\"}\n",
      "Response content for HPO code HP:0011297: {\"hpo_code\":\"HP:0011297\",\"cui\":\"C3550704\"}\n",
      "Response content for HPO code HP:0001155: {\"hpo_code\":\"HP:0001155\",\"cui\":\"C0018564\"}\n",
      "Response content for HPO code HP:0001760: {\"hpo_code\":\"HP:0001760\",\"cui\":\"C5399834\"}\n",
      "Response content for HPO code HP:0001385: {\"hpo_code\":\"HP:0001385\",\"cui\":\"C4732734\"}\n",
      "Response content for HPO code HP:0000768: {\"hpo_code\":\"HP:0000768\",\"cui\":\"C0158731\"}\n",
      "Response content for HPO code HP:0000767: {\"hpo_code\":\"HP:0000767\",\"cui\":\"C2051831\"}\n",
      "Response content for HPO code HP:0002652: {\"hpo_code\":\"HP:0002652\",\"cui\":\"C4280567\"}\n",
      "Response content for HPO code HP:0000301: {\"hpo_code\":\"HP:0000301\",\"cui\":\"C4025865\"}\n",
      "Response content for HPO code HP:0011804: {\"hpo_code\":\"HP:0011804\",\"cui\":\"C4023182\"}\n",
      "Response content for HPO code HP:0011805: {\"hpo_code\":\"HP:0011805\",\"cui\":\"C4023181\"}\n",
      "Response content for HPO code HP:0410009: {\"hpo_code\":\"HP:0410009\",\"cui\":\"C4073188\"}\n",
      "Response content for HPO code HP:0009830: {\"hpo_code\":\"HP:0009830\",\"cui\":\"C0442874\"}\n",
      "Response content for HPO code HP:0009127: {\"hpo_code\":\"HP:0009127\",\"cui\":\"C4024582\"}\n",
      "Response content for HPO code HP:0009131: {\"hpo_code\":\"HP:0009131\",\"cui\":\"C4024580\"}\n",
      "Response content for HPO code HP:0011006: {\"hpo_code\":\"HP:0011006\",\"cui\":\"C4023601\"}\n",
      "Response content for HPO code HP:0002617: {\"hpo_code\":\"HP:0002617\",\"cui\":\"C0002940\"}\n",
      "Response content for HPO code HP:0011675: {\"hpo_code\":\"HP:0011675\",\"cui\":\"C1744601\"}\n",
      "Response content for HPO code HP:0003115: {\"hpo_code\":\"HP:0003115\",\"cui\":\"C0522055\"}\n",
      "Response content for HPO code HP:0005294: {\"hpo_code\":\"HP:0005294\",\"cui\":\"C0002949\"}\n",
      "Response content for HPO code HP:0001638: {\"hpo_code\":\"HP:0001638\",\"cui\":\"C0878544\"}\n",
      "Response content for HPO code HP:0001254: {\"hpo_code\":\"HP:0001254\",\"cui\":\"C0541911\"}\n",
      "Response content for HPO code HP:0001627: {\"hpo_code\":\"HP:0001627\",\"cui\":\"C0018798\"}\n",
      "Response content for HPO code HP:0000822: {\"hpo_code\":\"HP:0000822\",\"cui\":\"C0020538\"}\n",
      "Response content for HPO code HP:0003124: {\"hpo_code\":\"HP:0003124\",\"cui\":\"C0595929\"}\n",
      "Response content for HPO code HP:0001297: {\"hpo_code\":\"HP:0001297\",\"cui\":\"C0038454\"}\n",
      "Response content for HPO code HP:0002099: {\"hpo_code\":\"HP:0002099\",\"cui\":\"C0004096\"}\n",
      "Response content for HPO code HP:0006528: {\"hpo_code\":\"HP:0006528\",\"cui\":\"C0746102\"}\n",
      "Response content for HPO code HP:0005952: {\"hpo_code\":\"HP:0005952\",\"cui\":\"C0235063\"}\n",
      "Response content for HPO code HP:0002795: {\"hpo_code\":\"HP:0002795\",\"cui\":\"C1260922\"}\n",
      "Response content for HPO code HP:0000775: {\"hpo_code\":\"HP:0000775\",\"cui\":\"C1848873\"}\n",
      "Response content for HPO code HP:0002093: {\"hpo_code\":\"HP:0002093\",\"cui\":\"C4020855\"}\n",
      "Response content for HPO code HP:0002091: {\"hpo_code\":\"HP:0002091\",\"cui\":\"C3277226\"}\n",
      "Response content for HPO code HP:0002793: {\"hpo_code\":\"HP:0002793\",\"cui\":\"C1837388\"}\n",
      "Response content for HPO code HP:0002795: {\"hpo_code\":\"HP:0002795\",\"cui\":\"C1260922\"}\n",
      "Response content for HPO code HP:0002087: {\"hpo_code\":\"HP:0002087\",\"cui\":\"C4025727\"}\n",
      "Response content for HPO code HP:0011968: {\"hpo_code\":\"HP:0011968\",\"cui\":\"C0232466\"}\n",
      "Response content for HPO code HP:0002031: {\"hpo_code\":\"HP:0002031\",\"cui\":\"C0266126\"}\n",
      "Response content for HPO code HP:0025270: {\"hpo_code\":\"HP:0025270\",\"cui\":\"C4476684\"}\n",
      "Response content for HPO code HP:0002577: {\"hpo_code\":\"HP:0002577\",\"cui\":\"C4025699\"}\n",
      "Response content for HPO code HP:0001732: {\"hpo_code\":\"HP:0001732\",\"cui\":\"C4025751\"}\n",
      "Response content for HPO code HP:0001392: {\"hpo_code\":\"HP:0001392\",\"cui\":\"C4021780\"}\n",
      "Response content for HPO code HP:0002579: {\"hpo_code\":\"HP:0002579\",\"cui\":\"C1836923\"}\n",
      "Response content for HPO code HP:0002242: {\"hpo_code\":\"HP:0002242\",\"cui\":\"C4316788\"}\n",
      "Response content for HPO code HP:0002250: {\"hpo_code\":\"HP:0002250\",\"cui\":\"C4025715\"}\n",
      "Response content for HPO code HP:0004378: {\"hpo_code\":\"HP:0004378\",\"cui\":\"C4025329\"}\n",
      "Response content for HPO code HP:0000014: {\"hpo_code\":\"HP:0000014\",\"cui\":\"C0149632\"}\n",
      "Response content for HPO code HP:0012244: {\"hpo_code\":\"HP:0012244\",\"cui\":\"C4022996\"}\n",
      "Response content for HPO code HP:0000078: {\"hpo_code\":\"HP:0000078\",\"cui\":\"C0744356\"}\n",
      "Response content for HPO code HP:0000083: {\"hpo_code\":\"HP:0000083\",\"cui\":\"C0035078\"}\n",
      "Response content for HPO code HP:0011735: {\"hpo_code\":\"HP:0011735\",\"cui\":\"C4023211\"}\n",
      "Response content for HPO code HP:0012210: {\"hpo_code\":\"HP:0012210\",\"cui\":\"C4551596\"}\n",
      "Response content for HPO code HP:0010460: {\"hpo_code\":\"HP:0010460\",\"cui\":\"C4023820\"}\n",
      "Response content for HPO code HP:0000080: {\"hpo_code\":\"HP:0000080\",\"cui\":\"C4020896\"}\n",
      "Response content for HPO code HP:0010461: {\"hpo_code\":\"HP:0010461\",\"cui\":\"C4023819\"}\n",
      "Response content for HPO code HP:0000795: {\"hpo_code\":\"HP:0000795\",\"cui\":\"C4025826\"}\n",
      "Response content for HPO code HP:0000069: {\"hpo_code\":\"HP:0000069\",\"cui\":\"C1840382\"}\n",
      "Response content for HPO code HP:0003110: {\"hpo_code\":\"HP:0003110\",\"cui\":\"C4025655\"}\n",
      "Response content for HPO code HP:0002960: {\"hpo_code\":\"HP:0002960\",\"cui\":\"C0004364\"}\n",
      "Response content for HPO code HP:0002721: {\"hpo_code\":\"HP:0002721\",\"cui\":\"C0021051\"}\n",
      "Response content for HPO code HP:0012647: {\"hpo_code\":\"HP:0012647\",\"cui\":\"C4022805\"}\n",
      "Response content for HPO code HP:0012649: {\"hpo_code\":\"HP:0012649\",\"cui\":\"C4022803\"}\n",
      "Response content for HPO code HP:0002719: {\"hpo_code\":\"HP:0002719\",\"cui\":\"C0239998\"}\n",
      "Response content for HPO code HP:0001370: {\"hpo_code\":\"HP:0001370\",\"cui\":\"C0003873\"}\n",
      "Response content for HPO code HP:0001977: {\"hpo_code\":\"HP:0001977\",\"cui\":\"C4025731\"}\n",
      "Response content for HPO code HP:0001928: {\"hpo_code\":\"HP:0001928\",\"cui\":\"C1846821\"}\n",
      "Response content for HPO code HP:0003256: {\"hpo_code\":\"HP:0003256\",\"cui\":\"C0005779\"}\n",
      "Response content for HPO code HP:0011889: {\"hpo_code\":\"HP:0011889\",\"cui\":\"C4023143\"}\n",
      "Response content for HPO code HP:0001892: {\"hpo_code\":\"HP:0001892\",\"cui\":\"C1458140\"}\n",
      "Response content for HPO code HP:0000978: {\"hpo_code\":\"HP:0000978\",\"cui\":\"C0423798\"}\n",
      "Response content for HPO code HP:0001934: {\"hpo_code\":\"HP:0001934\",\"cui\":\"C1844374\"}\n",
      "Response content for HPO code HP:0001978: {\"hpo_code\":\"HP:0001978\",\"cui\":\"C1292120\"}\n",
      "Response content for HPO code HP:0004406: {\"hpo_code\":\"HP:0004406\",\"cui\":\"C3809715\"}\n",
      "Response content for HPO code HP:0011873: {\"hpo_code\":\"HP:0011873\",\"cui\":\"C0580317\"}\n",
      "Response content for HPO code HP:0001877: {\"hpo_code\":\"HP:0001877\",\"cui\":\"C0391870\"}\n",
      "Response content for HPO code HP:0011893: {\"hpo_code\":\"HP:0011893\",\"cui\":\"C0580531\"}\n",
      "Response content for HPO code HP:0000704: {\"hpo_code\":\"HP:0000704\",\"cui\":\"C0017563\"}\n",
      "Response content for HPO code HP:0011058: {\"hpo_code\":\"HP:0011058\",\"cui\":\"C4280345\"}\n",
      "Response content for HPO code HP:0000230: {\"hpo_code\":\"HP:0000230\",\"cui\":\"C0017574\"}\n",
      "Response content for HPO code HP:0410028: {\"hpo_code\":\"HP:0410028\",\"cui\":\"C1274321\"}\n",
      "Response content for HPO code HP:0025124: {\"hpo_code\":\"HP:0025124\",\"cui\":\"C2674620\"}\n",
      "Response content for HPO code HP:0006483: {\"hpo_code\":\"HP:0006483\",\"cui\":\"C1290508\"}\n",
      "Response content for HPO code HP:0006482: {\"hpo_code\":\"HP:0006482\",\"cui\":\"C0040427\"}\n",
      "Response content for HPO code HP:0000164: {\"hpo_code\":\"HP:0000164\",\"cui\":\"C0262444\"}\n",
      "Response content for HPO code HP:0006481: {\"hpo_code\":\"HP:0006481\",\"cui\":\"C4021596\"}\n",
      "Response content for HPO code HP:0006486: {\"hpo_code\":\"HP:0006486\",\"cui\":\"C1291070\"}\n",
      "Response content for HPO code HP:0006479: {\"hpo_code\":\"HP:0006479\",\"cui\":\"C4025042\"}\n",
      "Response content for HPO code HP:0000692: {\"hpo_code\":\"HP:0000692\",\"cui\":\"C1852504\"}\n",
      "   true_CUI agent_CUI\n",
      "0  C0266781  C0266781\n",
      "1  C0235659  C0235659\n",
      "2  C0549629  C0549629\n",
      "3  C4531020  C4531020\n",
      "4  C1306893  C1306893\n"
     ]
    }
   ],
   "source": [
    "API_BASE_URL = \"http://localhost:8000/\"  # UMLS API Base URL\n",
    "\n",
    "df['true_CUI'] = None\n",
    "df['agent_CUI'] = None\n",
    "# Run the code\n",
    "for idx, row in df.iterrows():\n",
    "    hpo_code = row['HPO_code']\n",
    "    agent_code = row['agent_code']\n",
    "    \n",
    "    # Get True CUI \n",
    "    true_cui = get_cui_from_ontology(hpo_code)\n",
    "    df.at[idx, 'true_CUI'] = true_cui\n",
    "\n",
    "    # Get agent_CUI \n",
    "    if hpo_code == agent_code:\n",
    "        # If hpo_code = predicted hpo_code，then True_CUI = Predicted CUI\n",
    "        df.at[idx, 'agent_CUI'] = true_cui\n",
    "    else:\n",
    "        agent_cui = get_cui_from_ontology(agent_code)\n",
    "        df.at[idx, 'agent_CUI'] = agent_cui\n",
    "\n",
    "# Check the results\n",
    "print(df[['true_CUI', 'agent_CUI']].head())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get CUI for phenotagger"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code HP:0012125: {\"hpo_code\":\"HP:0012125\",\"cui\":\"C0376358\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0002664: {\"hpo_code\":\"HP:0002664\",\"cui\":\"C4732738\"}\n",
      "Response content for HPO code HP:0008069: {\"hpo_code\":\"HP:0008069\",\"cui\":\"C0037286\"}\n",
      "Response content for HPO code HP:0010302: {\"hpo_code\":\"HP:0010302\",\"cui\":\"C0037930\"}\n",
      "Response content for HPO code HP:0001909: {\"hpo_code\":\"HP:0001909\",\"cui\":\"C0376545\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0410030: {\"hpo_code\":\"HP:0410030\",\"cui\":\"C4321245\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000710: {\"hpo_code\":\"HP:0000710\",\"cui\":\"C1838320\"}\n",
      "Response content for HPO code HP:0009794: {\"hpo_code\":\"HP:0009794\",\"cui\":\"C1862066\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000252: {\"hpo_code\":\"HP:0000252\",\"cui\":\"C4551563\"}\n",
      "Response content for HPO code HP:0002015: {\"hpo_code\":\"HP:0002015\",\"cui\":\"C0011168\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000707: {\"hpo_code\":\"HP:0000707\",\"cui\":\"C0497552\"}\n",
      "Response content for HPO code HP:0001252: {\"hpo_code\":\"HP:0001252\",\"cui\":\"C1842364\"}\n",
      "Response content for HPO code HP:0100716: {\"hpo_code\":\"HP:0100716\",\"cui\":\"C0085271\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001171: {\"hpo_code\":\"HP:0001171\",\"cui\":\"C2699510\"}\n",
      "Response content for HPO code HP:0001839: {\"hpo_code\":\"HP:0001839\",\"cui\":\"C0432028\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0410167: {\"hpo_code\":\"HP:0410167\",\"cui\":\"C4703654\"}\n",
      "Response content for HPO code HP:0007185: {\"hpo_code\":\"HP:0007185\",\"cui\":\"C0039070\"}\n",
      "Response content for HPO code HP:0002089: {\"hpo_code\":\"HP:0002089\",\"cui\":\"C0265783\"}\n",
      "Response content for HPO code HP:0004389: {\"hpo_code\":\"HP:0004389\",\"cui\":\"C0021847\"}\n",
      "Response content for HPO code HP:0040183: {\"hpo_code\":\"HP:0040183\",\"cui\":\"C2945606\"}\n",
      "Response content for HPO code HP:0012732: {\"hpo_code\":\"HP:0012732\",\"cui\":\"C3495676\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0012211: {\"hpo_code\":\"HP:0012211\",\"cui\":\"C0151746\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000789: {\"hpo_code\":\"HP:0000789\",\"cui\":\"C0021359\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0012649: {\"hpo_code\":\"HP:0012649\",\"cui\":\"C4022803\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000421: {\"hpo_code\":\"HP:0000421\",\"cui\":\"C0014591\"}\n",
      "Response content for HPO code HP:0001872: {\"hpo_code\":\"HP:0001872\",\"cui\":\"C0151854\"}\n",
      "Response content for HPO code HP:0001901: {\"hpo_code\":\"HP:0001901\",\"cui\":\"C0032461\"}\n",
      "Response content for HPO code HP:0000689: {\"hpo_code\":\"HP:0000689\",\"cui\":\"C4280614\"}\n",
      "   true_CUI phenotagger_CUI\n",
      "0  C0266781        C0266781\n",
      "1  C0235659        C0235659\n",
      "2  C0549629        C0549629\n",
      "3  C4531020            None\n",
      "4  C1306893        C1306893\n"
     ]
    }
   ],
   "source": [
    "# Run the code\n",
    "for idx, row in df.iterrows():\n",
    "    phetag_code = row['phetag_code']\n",
    "    HPO_code = row['HPO_code']\n",
    "    true_cui = row['true_CUI']\n",
    "\n",
    "    # Get phetag_CUI \n",
    "    if phetag_code == HPO_code:\n",
    "        # If phetag_code = HPO_code，then phetag_CUI = true_CUI\n",
    "        df.at[idx, 'phetag_CUI'] = true_cui\n",
    "    else:\n",
    "        phetag_cui = get_cui_from_ontology(phetag_code)\n",
    "        df.at[idx, 'phetag_CUI'] = phetag_cui\n",
    "\n",
    "# Check the results\n",
    "print(df[['true_CUI', 'phetag_CUI']].head())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get CUI for phenoBERT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/nb/4qmmwm7j43x3py5_nzg7b6w40000gn/T/ipykernel_28507/1783458182.py:10: FutureWarning: Setting an item of incompatible dtype is deprecated and will raise an error in a future version of pandas. Value 'C0266781' has dtype incompatible with float64, please explicitly cast to a compatible dtype first.\n",
      "  df.at[idx, 'BERT_CUI'] = true_cui\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Response content for HPO code HP:0031437: {\"hpo_code\":\"HP:0031437\",\"cui\":\"C3544104\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code HP:0100651: {\"hpo_code\":\"HP:0100651\",\"cui\":\"C0011854\"}\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code HP:0012125: {\"hpo_code\":\"HP:0012125\",\"cui\":\"C0376358\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0002890: {\"hpo_code\":\"HP:0002890\",\"cui\":\"C0549473\"}\n",
      "Response content for HPO code HP:0008069: {\"hpo_code\":\"HP:0008069\",\"cui\":\"C0037286\"}\n",
      "Response content for HPO code HP:0030692: {\"hpo_code\":\"HP:0030692\",\"cui\":\"C0006118\"}\n",
      "Response content for HPO code HP:0001909: {\"hpo_code\":\"HP:0001909\",\"cui\":\"C0376545\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0410030: {\"hpo_code\":\"HP:0410030\",\"cui\":\"C4321245\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0009794: {\"hpo_code\":\"HP:0009794\",\"cui\":\"C1862066\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001363: {\"hpo_code\":\"HP:0001363\",\"cui\":\"C0010278\"}\n",
      "Response content for HPO code HP:0002015: {\"hpo_code\":\"HP:0002015\",\"cui\":\"C0011168\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000707: {\"hpo_code\":\"HP:0000707\",\"cui\":\"C0497552\"}\n",
      "Response content for HPO code HP:0100716: {\"hpo_code\":\"HP:0100716\",\"cui\":\"C0085271\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0002650: {\"hpo_code\":\"HP:0002650\",\"cui\":\"C5937607\"}\n",
      "Response content for HPO code HP:0001780: {\"hpo_code\":\"HP:0001780\",\"cui\":\"C2674738\"}\n",
      "Response content for HPO code HP:0001839: {\"hpo_code\":\"HP:0001839\",\"cui\":\"C0432028\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0410167: {\"hpo_code\":\"HP:0410167\",\"cui\":\"C4703654\"}\n",
      "Response content for HPO code HP:0011006,: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001279: {\"hpo_code\":\"HP:0001279\",\"cui\":\"C0039070\"}\n",
      "Response content for HPO code HP:0030680: {\"hpo_code\":\"HP:0030680\",\"cui\":\"C4049796\"}\n",
      "Response content for HPO code HP:0100790: {\"hpo_code\":\"HP:0100790\",\"cui\":\"C0019270\"}\n",
      "Response content for HPO code HP:0001733: {\"hpo_code\":\"HP:0001733\",\"cui\":\"C0030305\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0002595: {\"hpo_code\":\"HP:0002595\",\"cui\":\"C1258215\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0012211: {\"hpo_code\":\"HP:0012211\",\"cui\":\"C0151746\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000789: {\"hpo_code\":\"HP:0000789\",\"cui\":\"C0021359\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0012649: {\"hpo_code\":\"HP:0012649\",\"cui\":\"C4022803\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000421: {\"hpo_code\":\"HP:0000421\",\"cui\":\"C0014591\"}\n",
      "Response content for HPO code HP:0001872: {\"hpo_code\":\"HP:0001872\",\"cui\":\"C0151854\"}\n",
      "Response content for HPO code H+M163P:0001877: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "   true_CUI  BERT_CUI\n",
      "0  C0266781  C0266781\n",
      "1  C0235659  C0235659\n",
      "2  C0549629  C0549629\n",
      "3  C4531020  C4531020\n",
      "4  C1306893  C1306893\n"
     ]
    }
   ],
   "source": [
    "# Run the code\n",
    "for idx, row in df.iterrows():\n",
    "    BERT_code = row['BERT_code']\n",
    "    HPO_code = row['HPO_code']\n",
    "    true_cui = row['true_CUI']\n",
    "\n",
    "    # Get BERT_CUI \n",
    "    if BERT_code == HPO_code:\n",
    "        # If BERT_code = HPO_code，then BERT_CUI = true_CUI\n",
    "        df.at[idx, 'BERT_CUI'] = true_cui\n",
    "    else:\n",
    "        BERT_cui = get_cui_from_ontology(BERT_code)\n",
    "        df.at[idx, 'BERT_CUI'] = BERT_cui\n",
    "\n",
    "# Check the results\n",
    "print(df[['true_CUI', 'BERT_CUI']].head())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get CUI for GPT-5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/nb/4qmmwm7j43x3py5_nzg7b6w40000gn/T/ipykernel_28507/317336054.py:10: FutureWarning: Setting an item of incompatible dtype is deprecated and will raise an error in a future version of pandas. Value 'C0266781' has dtype incompatible with float64, please explicitly cast to a compatible dtype first.\n",
      "  df.at[idx, 'GPT5_CUI'] = true_cui\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Response content for HPO code HP:0001197: {\"hpo_code\":\"HP:0001197\",\"cui\":\"C4025797\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0011410: {\"hpo_code\":\"HP:0011410\",\"cui\":\"C0007876\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001191: {\"hpo_code\":\"HP:0001191\",\"cui\":\"C1840535\"}\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000819: {\"hpo_code\":\"HP:0000819\",\"cui\":\"C0011849\"}\n",
      "Response content for HPO code HP:0000824: {\"hpo_code\":\"HP:0000824\",\"cui\":\"C5539399\"}\n",
      "Response content for HPO code HP:0000823: {\"hpo_code\":\"HP:0000823\",\"cui\":\"C0034012\"}\n",
      "Response content for HPO code HP:0000848: {\"hpo_code\":\"HP:0000848\",\"cui\":\"C0240783\"}\n",
      "Response content for HPO code HP:0000821: {\"hpo_code\":\"HP:0000821\",\"cui\":\"C0020676\"}\n",
      "Response content for HPO code HP:0000855: {\"hpo_code\":\"HP:0000855\",\"cui\":\"C0021655\"}\n",
      "Response content for HPO code HP:0000858: {\"hpo_code\":\"HP:0000858\",\"cui\":\"C0156404\"}\n",
      "Response content for HPO code HP:0100613: {\"hpo_code\":\"HP:0100613\",\"cui\":\"C4022012\"}\n",
      "Response content for HPO code HP:0100685: {\"hpo_code\":\"HP:0100685\",\"cui\":\"C4021997\"}\n",
      "Response content for HPO code HP:0100612: {\"hpo_code\":\"HP:0100612\",\"cui\":\"C0028880\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0006727: {\"hpo_code\":\"HP:0006727\",\"cui\":\"C1961099\"}\n",
      "Response content for HPO code HP:0100515: {\"hpo_code\":\"HP:0100515\",\"cui\":\"C4477056\"}\n",
      "Response content for HPO code HP:0002896: {\"hpo_code\":\"HP:0002896\",\"cui\":\"C0345904\"}\n",
      "Response content for HPO code nan: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0004375: {\"hpo_code\":\"HP:0004375\",\"cui\":\"C0027766\"}\n",
      "Response content for HPO code HP:0002664: {\"hpo_code\":\"HP:0002664\",\"cui\":\"C4732738\"}\n",
      "Response content for HPO code HP:0000305: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0000153: {\"hpo_code\":\"HP:0000153\",\"cui\":\"C0026633\"}\n",
      "Response content for HPO code HP:0000159: {\"hpo_code\":\"HP:0000159\",\"cui\":\"C2183966\"}\n",
      "Response content for HPO code HP:0002015: {\"hpo_code\":\"HP:0002015\",\"cui\":\"C0011168\"}\n",
      "Response content for HPO code HP:0000568: {\"hpo_code\":\"HP:0000568\",\"cui\":\"C4280808\"}\n",
      "Response content for HPO code HP:0001100: {\"hpo_code\":\"HP:0001100\",\"cui\":\"C0423318\"}\n",
      "Response content for HPO code HP:0000539: {\"hpo_code\":\"HP:0000539\",\"cui\":\"C4025843\"}\n",
      "Response content for HPO code HP:0000612: {\"hpo_code\":\"HP:0000612\",\"cui\":\"C0240063\"}\n",
      "Response content for HPO code HP:0000429: {\"hpo_code\":\"HP:0000429\",\"cui\":\"C4021804\"}\n",
      "Response content for HPO code HP:0000406: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001251: {\"hpo_code\":\"HP:0001251\",\"cui\":\"C0007758\"}\n",
      "Response content for HPO code HP:0001252: {\"hpo_code\":\"HP:0001252\",\"cui\":\"C1842364\"}\n",
      "Response content for HPO code HP:0000717: {\"hpo_code\":\"HP:0000717\",\"cui\":\"C0004352\"}\n",
      "Response content for HPO code HP:0000718: {\"hpo_code\":\"HP:0000718\",\"cui\":\"C0001807\"}\n",
      "Response content for HPO code HP:0007018: {\"hpo_code\":\"HP:0007018\",\"cui\":\"C1263846\"}\n",
      "Response content for HPO code HP:0000980: {\"hpo_code\":\"HP:0000980\",\"cui\":\"C0241137\"}\n",
      "Response content for HPO code HP:0000981: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0001050: {\"hpo_code\":\"HP:0001050\",\"cui\":\"C0232370\"}\n",
      "Response content for HPO code HP:0033127: {\"hpo_code\":\"HP:0033127\",\"cui\":\"C3825027\"}\n",
      "Response content for HPO code HP:0002656: {\"hpo_code\":\"HP:0002656\",\"cui\":\"C4280566\"}\n",
      "Response content for HPO code HP:0001388: {\"hpo_code\":\"HP:0001388\",\"cui\":\"C0086437\"}\n",
      "Response content for HPO code HP:0005518: {\"hpo_code\":\"HP:0005518\",\"cui\":\"C0302845\"}\n",
      "Response content for HPO code HP:0010674: {\"hpo_code\":\"HP:0010674\",\"cui\":\"C4023747\"}\n",
      "Response content for HPO code HP:0001839: {\"hpo_code\":\"HP:0001839\",\"cui\":\"C0432028\"}\n",
      "Response content for HPO code HP:0000924: {\"hpo_code\":\"HP:0000924\",\"cui\":\"C4021790\"}\n",
      "Response content for HPO code HP:0010623: {\"detail\":\"404: CUI not found for the given HPO code\"}\n",
      "Key 'cui' not found in response.\n",
      "Response content for HPO code HP:0003011: {\"hpo_code\":\"HP:0003011\",\"cui\":\"C4021745\"}\n",
      "Response content for HPO code HP:0003201: {\"hpo_code\":\"HP:0003201\",\"cui\":\"C0035410\"}\n",
      "Response content for HPO code HP:0003450: {\"hpo_code\":\"HP:0003450\",\"cui\":\"C1854454\"}\n",
      "Response content for HPO code HP:0001324: {\"hpo_code\":\"HP:0001324\",\"cui\":\"C0151786\"}\n",
      "Response content for HPO code HP:0003326: {\"hpo_code\":\"HP:0003326\",\"cui\":\"C0231528\"}\n",
      "Response content for HPO code HP:0000473: {\"hpo_code\":\"HP:0000473\",\"cui\":\"C0152116\"}\n",
      "Response content for HPO code HP:0003114: {\"hpo_code\":\"HP:0003114\",\"cui\":\"C4020686\"}\n",
      "Response content for HPO code HP:0002647: {\"hpo_code\":\"HP:0002647\",\"cui\":\"C0340643\"}\n",
      "Response content for HPO code HP:0001279: {\"hpo_code\":\"HP:0001279\",\"cui\":\"C0039070\"}\n",
      "Response content for HPO code HP:0002088: {\"hpo_code\":\"HP:0002088\",\"cui\":\"C4021760\"}\n",
      "Response content for HPO code HP:0002878: {\"hpo_code\":\"HP:0002878\",\"cui\":\"C1145670\"}\n",
      "Response content for HPO code HP:0000776: {\"hpo_code\":\"HP:0000776\",\"cui\":\"C0235833\"}\n",
      "Response content for HPO code HP:0002795: {\"hpo_code\":\"HP:0002795\",\"cui\":\"C1260922\"}\n",
      "Response content for HPO code HP:0002086: {\"hpo_code\":\"HP:0002086\",\"cui\":\"C4018871\"}\n",
      "Response content for HPO code HP:0002020: {\"hpo_code\":\"HP:0002020\",\"cui\":\"C4317146\"}\n",
      "Response content for HPO code HP:0001738: {\"hpo_code\":\"HP:0001738\",\"cui\":\"C0267963\"}\n",
      "Response content for HPO code HP:0004383: {\"hpo_code\":\"HP:0004383\",\"cui\":\"C0344906\"}\n",
      "Response content for HPO code HP:0002607: {\"hpo_code\":\"HP:0002607\",\"cui\":\"C0015732\"}\n",
      "Response content for HPO code HP:0002020: {\"hpo_code\":\"HP:0002020\",\"cui\":\"C4317146\"}\n",
      "Response content for HPO code HP:0000015: {\"hpo_code\":\"HP:0000015\",\"cui\":\"C0156273\"}\n",
      "Response content for HPO code HP:0000119: {\"hpo_code\":\"HP:0000119\",\"cui\":\"C0042063\"}\n",
      "Response content for HPO code HP:0000077: {\"hpo_code\":\"HP:0000077\",\"cui\":\"C0266292\"}\n",
      "Response content for HPO code HP:0000119: {\"hpo_code\":\"HP:0000119\",\"cui\":\"C0042063\"}\n",
      "Response content for HPO code HP:0000789: {\"hpo_code\":\"HP:0000789\",\"cui\":\"C0021359\"}\n",
      "Response content for HPO code HP:0000768: {\"hpo_code\":\"HP:0000768\",\"cui\":\"C0158731\"}\n",
      "Response content for HPO code HP:0000047: {\"hpo_code\":\"HP:0000047\",\"cui\":\"C0848558\"}\n",
      "Response content for HPO code HP:0000076: {\"hpo_code\":\"HP:0000076\",\"cui\":\"C0042580\"}\n",
      "Response content for HPO code HP:0011030: {\"hpo_code\":\"HP:0011030\",\"cui\":\"C4023584\"}\n",
      "Response content for HPO code HP:0002715: {\"hpo_code\":\"HP:0002715\",\"cui\":\"C4021753\"}\n",
      "Response content for HPO code HP:0001907: {\"hpo_code\":\"HP:0001907\",\"cui\":\"C0040038\"}\n",
      "Response content for HPO code HP:0001892: {\"hpo_code\":\"HP:0001892\",\"cui\":\"C1458140\"}\n",
      "Response content for HPO code HP:0001892: {\"hpo_code\":\"HP:0001892\",\"cui\":\"C1458140\"}\n",
      "Response content for HPO code HP:0001971: {\"hpo_code\":\"HP:0001971\",\"cui\":\"C0020532\"}\n",
      "Response content for HPO code HP:0000421: {\"hpo_code\":\"HP:0000421\",\"cui\":\"C0014591\"}\n",
      "Response content for HPO code HP:0000169: {\"hpo_code\":\"HP:0000169\",\"cui\":\"C0016049\"}\n",
      "Response content for HPO code HP:0000234: {\"hpo_code\":\"HP:0000234\",\"cui\":\"C4021812\"}\n",
      "Response content for HPO code HP:0000155: {\"hpo_code\":\"HP:0000155\",\"cui\":\"C0149745\"}\n",
      "Response content for HPO code HP:0006483: {\"hpo_code\":\"HP:0006483\",\"cui\":\"C1290508\"}\n",
      "Response content for HPO code HP:0011069: {\"hpo_code\":\"HP:0011069\",\"cui\":\"C0040457\"}\n",
      "Response content for HPO code HP:0011062: {\"hpo_code\":\"HP:0011062\",\"cui\":\"C4023556\"}\n",
      "Response content for HPO code HP:0006487: {\"hpo_code\":\"HP:0006487\",\"cui\":\"C1855340\"}\n",
      "Response content for HPO code HP:0011087: {\"hpo_code\":\"HP:0011087\",\"cui\":\"C0266034\"}\n",
      "Response content for HPO code HP:0000687: {\"hpo_code\":\"HP:0000687\",\"cui\":\"C1844813\"}\n",
      "   true_CUI  GPT5_CUI\n",
      "0  C0266781  C0266781\n",
      "1  C0235659  C0235659\n",
      "2  C0549629  C4025797\n",
      "3  C4531020      None\n",
      "4  C1306893  C0007876\n"
     ]
    }
   ],
   "source": [
    "# Run the code\n",
    "for idx, row in df.iterrows():\n",
    "    GPT5_code = row['GPT5_code']\n",
    "    HPO_code = row['HPO_code']\n",
    "    true_cui = row['true_CUI']\n",
    "\n",
    "    # Get GPT5_CUI \n",
    "    if GPT5_code == HPO_code:\n",
    "        # If GPT5_code = HPO_code，then GPT5_CUI = true_CUI\n",
    "        df.at[idx, 'GPT5_CUI'] = true_cui\n",
    "    else:\n",
    "        GPT5_cui = get_cui_from_ontology(GPT5_code)\n",
    "        df.at[idx, 'GPT5_CUI'] = GPT5_cui\n",
    "\n",
    "# Check the results\n",
    "print(df[['true_CUI', 'GPT5_CUI']].head())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Output the result and check it \n",
    "df.to_excel(\"mapped_gc.xlsx\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "2. Get the LLM score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define the calculate method\n",
    "def rank_evaluate_with_llm(predicted_label, true_label, predicted_code, true_code, agent_llm_map):\n",
    "    if is_null(predicted_code) or is_null(true_code):\n",
    "        return None\n",
    "\n",
    "    try:\n",
    "        llm = agent_llm_map[\"rank_evaluate_with_llm\"]\n",
    "        prompt = apply_prompt_template(\n",
    "    \"rank_evaluate_with_llm\", \n",
    "    {\n",
    "        \"predicted_label\": predicted_label,\n",
    "        \"true_label\": true_label,\n",
    "        \"predicted_code\": predicted_code,\n",
    "        \"true_code\": true_code\n",
    "    }\n",
    ")\n",
    "        response = llm.invoke(prompt)\n",
    "\n",
    "        if hasattr(response, \"choices\"):\n",
    "            score_text = response.choices[0].message.content.strip()\n",
    "        elif hasattr(response, \"content\"):\n",
    "            score_text = response.content.strip()\n",
    "        else:\n",
    "            logging.error(\"LLM response structure not recognized.\")\n",
    "            return None\n",
    "\n",
    "        try:\n",
    "            score = float(score_text)\n",
    "            if score < 1 or score > 10:\n",
    "                logging.warning(f\"LLM returned out-of-range score: {score_text}\")\n",
    "                return None\n",
    "            return score\n",
    "\n",
    "        except ValueError:\n",
    "            logging.error(f\"LLM returned invalid score: {score_text}\")\n",
    "            return None\n",
    "\n",
    "    except Exception as e:\n",
    "        logging.error(f\"Error calling LLM agent for ranking evaluation: {e}\")\n",
    "        return None"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get LLM score for agent"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from functools import partial\n",
    "# define is_null\n",
    "def is_null(value):\n",
    "    return pd.isna(value) or value is None or value == ''\n",
    "    \n",
    "evaluate_func = partial(rank_evaluate_with_llm, agent_llm_map=AGENT_LLM_MAP)\n",
    "\n",
    "# Filter out rows without none values\n",
    "filtered_df = df.dropna(subset=['true_CUI', 'agent_CUI']).query('true_CUI != agent_CUI')\n",
    "\n",
    "# Apply the function\n",
    "df['agent_LLM_Score'] = filtered_df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['agent_term'], \n",
    "        row['true_term'], \n",
    "        row['agent_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Get LLM score for phenotagger, phenoBERT, metamap, cTAKES, GPT-5"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "phetag_df = df.dropna(subset=['phetag_CUI', 'true_CUI']).query('true_CUI != phetag_CUI')\n",
    "BERT_df = df.dropna(subset=['BERT_CUI', 'true_CUI']).query('true_CUI != BERT_CUI')\n",
    "meta_df = df.dropna(subset=['meta_CUI', 'true_CUI']).query('true_CUI != meta_CUI')\n",
    "# Apply the function\n",
    "df['phetag_LLM_Score'] = df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['phetag_term'], \n",
    "        row['true_term'],\n",
    "        row['phetag_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")\n",
    "df['BERT_LLM_Score'] = df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['BERT_term'], \n",
    "        row['true_term'],\n",
    "        row['BERT_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")\n",
    "df['meta_LLM_Score'] = df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['meta_term'], \n",
    "        row['true_term'],\n",
    "        row['meta_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ctakes_df = df.dropna(subset=['ctakes_CUI', 'true_CUI']).query('true_CUI != ctakes_CUI')\n",
    "df['ctakes_LLM_Score'] = df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['ctakes_term'], \n",
    "        row['true_term'],\n",
    "        row['ctakes_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "GPT5_df = df.dropna(subset=['GPT5_CUI', 'true_CUI']).query('true_CUI != GPT5_CUI')\n",
    "df['GPT5_LLM_Score'] = df.apply(\n",
    "    lambda row: evaluate_func(\n",
    "        row['GPT5_term'], \n",
    "        row['true_term'],\n",
    "        row['GPT5_CUI'], \n",
    "        row['true_CUI']\n",
    "    ),\n",
    "    axis=1\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Output the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'df' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mNameError\u001b[39m                                 Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[1]\u001b[39m\u001b[32m, line 2\u001b[39m\n\u001b[32m      1\u001b[39m \u001b[38;5;66;03m# Output the results\u001b[39;00m\n\u001b[32m----> \u001b[39m\u001b[32m2\u001b[39m \u001b[43mdf\u001b[49m.to_csv(\u001b[33m\"\u001b[39m\u001b[33mLLM score2.csv\u001b[39m\u001b[33m\"\u001b[39m, index=\u001b[38;5;28;01mFalse\u001b[39;00m)\n",
      "\u001b[31mNameError\u001b[39m: name 'df' is not defined"
     ]
    }
   ],
   "source": [
    "# Output the results\n",
    "df.to_csv(\"LLM score2.csv\", index=False)"
   ]
  }
 ],
 "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.11.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
