{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Genomeconnect(GC) dataset test: from survey to HPO "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ enter is_question_mappable_node \n",
      "✅ Extracted terms: ['Pancreatic cancer']\n",
      "🌐 [Pancreatic cancer] API Status: 200\n",
      "✅ Results for Pancreatic cancer: [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Pancreatic cancer', 'candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Pancreatic cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002894\",\n",
      "    \"matched_term\": \"increased risk of pancreatic cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Pancreatic cancer', 'field_type': 'short', 'extracted_terms': ['Pancreatic cancer'], 'umls_mappings': [{'original': 'Pancreatic cancer', 'candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]}], 'mappability_retry_count': 0, 'ranked_mappings': [{'original': 'Pancreatic cancer', 'ranked_candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Pancreatic cancer': {\n",
      "  \"best_match_code\": \"HP:0002894\",\n",
      "  \"best_match_term\": \"increased risk of pancreatic cancer\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Pancreatic cancer\",\n",
      "  \"field_type\": \"short\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Pancreatic cancer\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Pancreatic cancer\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002894\",\n",
      "          \"term\": \"increased risk of pancreatic cancer\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Pancreatic cancer\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002894\",\n",
      "          \"term\": \"increased risk of pancreatic cancer\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Pancreatic cancer\",\n",
      "      \"best_match_code\": \"HP:0002894\",\n",
      "      \"best_match_term\": \"increased risk of pancreatic cancer\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0346647\n",
      "🧩 CUI {'cui': 'C0346647', 'ancestors': ['C0012242', 'C0346617', 'C0153465', 'C5231095', 'C1290837', 'C0267771', 'C0012634', 'C0577077', 'C1302761', 'C0153662', 'C0030297', 'C0877425', 'C1882062', 'C1290306', 'C1263661', 'C0035358', 'C1333803', 'C0000735', 'C0577559', 'C0577573', 'C5231096', 'C1290864', 'C0012243', 'C0030286', 'C1320355', 'C3661974', 'C2720507', 'C0266806', 'C0577566', 'C0587047', 'C0006826', 'C0014132', 'C0579140', 'C0037088', 'C3164697', 'C1285159', 'C1290312', 'C0426683', 'C0751075', 'C0000734', 'C0345760', 'C0014130']}\n",
      "🧩 ancestor_cuis ['C0012242', 'C0346617', 'C0153465', 'C5231095', 'C1290837', 'C0267771', 'C0012634', 'C0577077', 'C1302761', 'C0153662', 'C0030297', 'C0877425', 'C1882062', 'C1290306', 'C1263661', 'C0035358', 'C1333803', 'C0000735', 'C0577559', 'C0577573', 'C5231096', 'C1290864', 'C0012243', 'C0030286', 'C1320355', 'C3661974', 'C2720507', 'C0266806', 'C0577566', 'C0587047', 'C0006826', 'C0014132', 'C0579140', 'C0037088', 'C3164697', 'C1285159', 'C1290312', 'C0426683', 'C0751075', 'C0000734', 'C0345760', 'C0014130']\n",
      "🧩 candidate_details [{'cui': 'C0012242', 'name': 'Disorder of digestive system'}, {'cui': 'C0346617', 'name': 'Malignant tumor of digestive organ'}, {'cui': 'C0153465', 'name': 'Malignant retroperitoneal tumor'}, {'cui': 'C5231095', 'name': 'Finding of abdominopelvic segment of trunk'}, {'cui': 'C1290837', 'name': 'Disorder of trunk'}, {'cui': 'C0267771', 'name': 'Retroperitoneal mass'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0577077', 'name': 'Finding of pancreas'}, {'cui': 'C1302761', 'name': 'Neoplasm and/or hamartoma'}, {'cui': 'C0153662', 'name': 'Malignant neoplasm of abdomen'}, {'cui': 'C0030297', 'name': 'Neoplasm of pancreas'}, {'cui': 'C0877425', 'name': 'Mass of pancreas'}, {'cui': 'C1882062', 'name': 'Neoplastic disease'}, {'cui': 'C1290306', 'name': 'Neoplasm of trunk'}, {'cui': 'C1263661', 'name': 'Disorder of retroperitoneal region, excluding major organs'}, {'cui': 'C0035358', 'name': 'Tumor of retroperitoneum'}, {'cui': 'C1333803', 'name': 'Digestive system observation'}, {'cui': 'C0000735', 'name': 'Neoplasm of abdomen'}, {'cui': 'C0577559', 'name': 'Mass of body structure'}, {'cui': 'C0577573', 'name': 'Mass of body region'}, {'cui': 'C5231096', 'name': 'Disorder of abdominopelvic segment of trunk'}, {'cui': 'C1290864', 'name': 'Disorder of abdomen'}, {'cui': 'C0012243', 'name': 'Neoplasm of digestive system'}, {'cui': 'C0030286', 'name': 'Disorder of pancreas'}, {'cui': 'C1320355', 'name': 'Viscus structure finding'}, {'cui': 'C3661974', 'name': 'Finding of abdomen'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0266806', 'name': 'Disorder of digestive organ'}, {'cui': 'C0577566', 'name': 'Mass of digestive structure'}, {'cui': 'C0587047', 'name': 'Mass of trunk'}, {'cui': 'C0006826', 'name': 'Neoplasms - malignant'}, {'cui': 'C0014132', 'name': 'Neoplasm of endocrine gland'}, {'cui': 'C0579140', 'name': 'Finding of trunk structure'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C3164697', 'name': 'Malignant neoplasm of intraabdominal organ'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C1290312', 'name': 'Neoplasm of intra-abdominal organs'}, {'cui': 'C0426683', 'name': 'Abdominal organ finding'}, {'cui': 'C0751075', 'name': 'Cancer of digestive system'}, {'cui': 'C0000734', 'name': 'Abdominal mass'}, {'cui': 'C0345760', 'name': 'Neoplasm of digestive organ'}, {'cui': 'C0014130', 'name': 'Endocrine system disease'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Pancreatic cancer\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Pancreatic cancer\"\n",
      "  \"best_match_code\": \"HP:0002894\",\n",
      "  \"best_match_term\": \"increased risk of pancreatic cancer\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012242 (Disorder of digestive system)\n",
      "- C0346617 (Malignant tumor of digestive organ)\n",
      "- C0153465 (Malignant retroperitoneal tumor)\n",
      "- C5231095 (Finding of abdominopelvic segment of trunk)\n",
      "- C1290837 (Disorder of trunk)\n",
      "- C0267771 (Retroperitoneal mass)\n",
      "- C0012634 (Disease)\n",
      "- C0577077 (Finding of pancreas)\n",
      "- C1302761 (Neoplasm and/or hamartoma)\n",
      "- C0153662 (Malignant neoplasm of abdomen)\n",
      "- C0030297 (Neoplasm of pancreas)\n",
      "- C0877425 (Mass of pancreas)\n",
      "- C1882062 (Neoplastic disease)\n",
      "- C1290306 (Neoplasm of trunk)\n",
      "- C1263661 (Disorder of retroperitoneal region, excluding major organs)\n",
      "- C0035358 (Tumor of retroperitoneum)\n",
      "- C1333803 (Digestive system observation)\n",
      "- C0000735 (Neoplasm of abdomen)\n",
      "- C0577559 (Mass of body structure)\n",
      "- C0577573 (Mass of body region)\n",
      "- C5231096 (Disorder of abdominopelvic segment of trunk)\n",
      "- C1290864 (Disorder of abdomen)\n",
      "- C0012243 (Neoplasm of digestive system)\n",
      "- C0030286 (Disorder of pancreas)\n",
      "- C1320355 (Viscus structure finding)\n",
      "- C3661974 (Finding of abdomen)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0266806 (Disorder of digestive organ)\n",
      "- C0577566 (Mass of digestive structure)\n",
      "- C0587047 (Mass of trunk)\n",
      "- C0006826 (Neoplasms - malignant)\n",
      "- C0014132 (Neoplasm of endocrine gland)\n",
      "- C0579140 (Finding of trunk structure)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C3164697 (Malignant neoplasm of intraabdominal organ)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C1290312 (Neoplasm of intra-abdominal organs)\n",
      "- C0426683 (Abdominal organ finding)\n",
      "- C0751075 (Cancer of digestive system)\n",
      "- C0000734 (Abdominal mass)\n",
      "- C0345760 (Neoplasm of digestive organ)\n",
      "- C0014130 (Endocrine system disease)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 1037, 'total_tokens': 1038, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CDaGoy32x8XCBwr2k00bAg5Y99ahx', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--3fbe31db-e164-42be-a3ee-97e559493592-0' usage_metadata={'input_tokens': 1037, 'output_tokens': 1, 'total_tokens': 1038, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "{'text': 'Pancreatic cancer', 'field_type': 'short', 'extracted_terms': ['Pancreatic cancer'], 'umls_mappings': [{'original': 'Pancreatic cancer', 'candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]}], 'mappability_retry_count': 0, 'ranked_mappings': [{'original': 'Pancreatic cancer', 'ranked_candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None, 'confidence': 1.0}]}], 'validated_mappings': [{'original': 'Pancreatic cancer', 'best_match_code': 'HP:0002894', 'best_match_term': 'increased risk of pancreatic cancer', 'confidence': 0.7}], 'refine_mapping': {}}\n"
     ]
    }
   ],
   "source": [
    "# Use a data to test before officially starting the running\n",
    "from src.graph.builder import umls_mapping_graph \n",
    "result = umls_mapping_graph.invoke({'text': 'Pancreatic cancer','field_type':'short'})\n",
    "print(result)"
   ]
  },
  {
   "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": [
    "1. Reading the test data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "              Section                                           Question  \\\n",
      "0  Mother's Pregnancy  Amniotic fluid issue - Too much fluid (polyhyd...   \n",
      "1  Mother's Pregnancy                           Decreased fetal movement   \n",
      "2  Mother's Pregnancy                              Delivery complication   \n",
      "3  Mother's Pregnancy                            Maternal health problem   \n",
      "4  Mother's Pregnancy                                    Placental issue   \n",
      "\n",
      "                            HPO term    HPO code  \n",
      "0  Abnormality of the amniotic fluid  HP:0001560  \n",
      "1           Decreased fetal movement  HP:0001558  \n",
      "2                  Abnormal delivery  HP:0001787  \n",
      "3      Prenatal maternal abnormality  HP:0002686  \n",
      "4        Abnormality of the placenta  HP:0100767  \n"
     ]
    }
   ],
   "source": [
    "# Load the excel test data\n",
    "excel_file_path = \"gc.xlsx\"\n",
    "df = pd.read_excel(excel_file_path)\n",
    "print(df.head())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "2. Batch process"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "✅ Extracted terms: ['Abnormal amniotic fluid volume']\n",
      "🌐 [Abnormal amniotic fluid volume] API Status: 404\n",
      "❌ Failed for term: Abnormal amniotic fluid volume\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal amniotic fluid volume', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the amniotic fluid']\n",
      "🌐 [Abnormality of the amniotic fluid] API Status: 200\n",
      "✅ Results for Abnormality of the amniotic fluid: [{'code': 'HP:0001560', 'term': 'Abnormality of the amniotic fluid', 'description': 'Abnormality of the amniotic fluid, which is the fluid contained in the amniotic sac surrounding the developing fetus. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the amniotic fluid', 'candidates': [{'code': 'HP:0001560', 'term': 'Abnormality of the amniotic fluid', 'description': 'Abnormality of the amniotic fluid, which is the fluid contained in the amniotic sac surrounding the developing fetus. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the amniotic fluid': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001560\",\n",
      "    \"matched_term\": \"Abnormality of the amniotic fluid\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Amniotic fluid issue - Too much fluid (polyhydramnios) or too little fluid (oligohydramnios)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the amniotic fluid'], 'umls_mappings': [{'original': 'Abnormality of the amniotic fluid', 'candidates': [{'code': 'HP:0001560', 'term': 'Abnormality of the amniotic fluid', 'description': 'Abnormality of the amniotic fluid, which is the fluid contained in the amniotic sac surrounding the developing fetus. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the amniotic fluid', 'Abnormal amniotic fluid volume'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the amniotic fluid', 'ranked_candidates': [{'code': 'HP:0001560', 'term': 'Abnormality of the amniotic fluid', 'description': 'Abnormality of the amniotic fluid, which is the fluid contained in the amniotic sac surrounding the developing fetus. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the amniotic fluid': {\n",
      "  \"best_match_code\": \"HP:0001560\",\n",
      "  \"best_match_term\": \"Abnormality of the amniotic fluid\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 1\n",
      "✅ Extracted terms: ['Decreased fetal movement']\n",
      "🌐 [Decreased fetal movement] API Status: 200\n",
      "✅ Results for Decreased fetal movement: [{'code': 'HP:0001558', 'term': 'Decreased fetal movement', 'description': 'An abnormal reduction in quantity or strength of fetal movements. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Decreased fetal movement', 'candidates': [{'code': 'HP:0001558', 'term': 'Decreased fetal movement', 'description': 'An abnormal reduction in quantity or strength of fetal movements. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Decreased fetal movement': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001558\",\n",
      "    \"matched_term\": \"Decreased fetal movement\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Decreased fetal movement', 'field_type': 'radio', 'extracted_terms': ['Decreased fetal movement'], 'umls_mappings': [{'original': 'Decreased fetal movement', 'candidates': [{'code': 'HP:0001558', 'term': 'Decreased fetal movement', 'description': 'An abnormal reduction in quantity or strength of fetal movements. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Decreased fetal movement', 'ranked_candidates': [{'code': 'HP:0001558', 'term': 'Decreased fetal movement', 'description': 'An abnormal reduction in quantity or strength of fetal movements. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Decreased fetal movement': {\n",
      "  \"best_match_code\": \"HP:0001558\",\n",
      "  \"best_match_term\": \"Decreased fetal movement\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 2\n",
      "✅ Extracted terms: ['Delivery complication']\n",
      "🌐 [Delivery complication] API Status: 200\n",
      "✅ Results for Delivery complication: [{'code': 'HP:0001787', 'term': 'Delivery complication', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Delivery complication', 'candidates': [{'code': 'HP:0001787', 'term': 'Delivery complication', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Delivery complication': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001787\",\n",
      "    \"matched_term\": \"Delivery complication\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Delivery complication', 'field_type': 'radio', 'extracted_terms': ['Delivery complication'], 'umls_mappings': [{'original': 'Delivery complication', 'candidates': [{'code': 'HP:0001787', 'term': 'Delivery complication', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Delivery complication', 'ranked_candidates': [{'code': 'HP:0001787', 'term': 'Delivery complication', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Delivery complication': {\n",
      "  \"best_match_code\": \"HP:0001787\",\n",
      "  \"best_match_term\": \"Delivery complication\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 3\n",
      "✅ Processed row 4\n",
      "✅ Extracted terms: ['Abnormality of the placenta']\n",
      "🌐 [Abnormality of the placenta] API Status: 200\n",
      "✅ Results for Abnormality of the placenta: [{'code': 'HP:0100767', 'term': 'Abnormality of the placenta', 'description': 'An abnormality of the placenta, the organ that connects the developing fetus to the uterine wall to enable nutrient uptake, waste elimination, and gas exchange. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the placenta', 'candidates': [{'code': 'HP:0100767', 'term': 'Abnormality of the placenta', 'description': 'An abnormality of the placenta, the organ that connects the developing fetus to the uterine wall to enable nutrient uptake, waste elimination, and gas exchange. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the placenta': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100767\",\n",
      "    \"matched_term\": \"Abnormality of the placenta\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Placental issue', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the placenta'], 'umls_mappings': [{'original': 'Abnormality of the placenta', 'candidates': [{'code': 'HP:0100767', 'term': 'Abnormality of the placenta', 'description': 'An abnormality of the placenta, the organ that connects the developing fetus to the uterine wall to enable nutrient uptake, waste elimination, and gas exchange. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the placenta', 'ranked_candidates': [{'code': 'HP:0100767', 'term': 'Abnormality of the placenta', 'description': 'An abnormality of the placenta, the organ that connects the developing fetus to the uterine wall to enable nutrient uptake, waste elimination, and gas exchange. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the placenta': {\n",
      "  \"best_match_code\": \"HP:0100767\",\n",
      "  \"best_match_term\": \"Abnormality of the placenta\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 5\n",
      "✅ Processed row 6\n",
      "✅ Extracted terms: ['Preterm birth']\n",
      "🌐 [Preterm birth] API Status: 200\n",
      "✅ Results for Preterm birth: [{'code': 'HP:0025665', 'term': 'Extremely preterm birth', 'description': 'Birth before 28 completed weeks of gestation (up to and including 27 weeks and 6 days of gestation). [https://orcid.org/0000-0002-6670-9157]'}, {'code': 'HP:0025664', 'term': 'Moderate to late preterm birth', 'description': 'Birth when a fetus is between 32 weeks and less than 37 weeks gestational age.'}, {'code': 'HP:0001622', 'term': 'Preterm birth', 'description': 'Narození dítěte před 37. týdnem těhotenství (259 dní od prvního dne poslední menstruace matky nebo 245 dní po oplodnění).'}, {'code': 'HP:0025666', 'term': 'Very preterm birth', 'description': 'Birth when a fetus is between 28 weeks and less than 32 weeks gestational age.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Preterm birth', 'candidates': [{'code': 'HP:0025665', 'term': 'Extremely preterm birth', 'description': 'Birth before 28 completed weeks of gestation (up to and including 27 weeks and 6 days of gestation). [https://orcid.org/0000-0002-6670-9157]'}, {'code': 'HP:0025664', 'term': 'Moderate to late preterm birth', 'description': 'Birth when a fetus is between 32 weeks and less than 37 weeks gestational age.'}, {'code': 'HP:0001622', 'term': 'Preterm birth', 'description': 'Narození dítěte před 37. týdnem těhotenství (259 dní od prvního dne poslední menstruace matky nebo 245 dní po oplodnění).'}, {'code': 'HP:0025666', 'term': 'Very preterm birth', 'description': 'Birth when a fetus is between 28 weeks and less than 32 weeks gestational age.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Preterm birth': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001622\",\n",
      "    \"matched_term\": \"Preterm birth\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025665\",\n",
      "    \"matched_term\": \"Extremely preterm birth\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025666\",\n",
      "    \"matched_term\": \"Very preterm birth\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025664\",\n",
      "    \"matched_term\": \"Moderate to late preterm birth\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Prematurity', 'field_type': 'radio', 'extracted_terms': ['Preterm birth'], 'umls_mappings': [{'original': 'Preterm birth', 'candidates': [{'code': 'HP:0025665', 'term': 'Extremely preterm birth', 'description': 'Birth before 28 completed weeks of gestation (up to and including 27 weeks and 6 days of gestation). [https://orcid.org/0000-0002-6670-9157]'}, {'code': 'HP:0025664', 'term': 'Moderate to late preterm birth', 'description': 'Birth when a fetus is between 32 weeks and less than 37 weeks gestational age.'}, {'code': 'HP:0001622', 'term': 'Preterm birth', 'description': 'Narození dítěte před 37. týdnem těhotenství (259 dní od prvního dne poslední menstruace matky nebo 245 dní po oplodnění).'}, {'code': 'HP:0025666', 'term': 'Very preterm birth', 'description': 'Birth when a fetus is between 28 weeks and less than 32 weeks gestational age.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Preterm birth', 'ranked_candidates': [{'code': 'HP:0001622', 'term': 'Preterm birth', 'description': 'Narození dítěte před 37. týdnem těhotenství (259 dní od prvního dne poslední menstruace matky nebo 245 dní po oplodnění).', 'confidence': 1.0}, {'code': 'HP:0025665', 'term': 'Extremely preterm birth', 'description': 'Birth before 28 completed weeks of gestation (up to and including 27 weeks and 6 days of gestation). [https://orcid.org/0000-0002-6670-9157]', 'confidence': 0.75}, {'code': 'HP:0025664', 'term': 'Moderate to late preterm birth', 'description': 'Birth when a fetus is between 32 weeks and less than 37 weeks gestational age.', 'confidence': 0.75}, {'code': 'HP:0025666', 'term': 'Very preterm birth', 'description': 'Birth when a fetus is between 28 weeks and less than 32 weeks gestational age.', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Preterm birth': {\n",
      "  \"best_match_code\": \"HP:0001622\",\n",
      "  \"best_match_term\": \"Preterm birth\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 7\n",
      "✅ Extracted terms: ['Abnormality of the umbilical cord']\n",
      "🌐 [Abnormality of the umbilical cord] API Status: 200\n",
      "✅ Results for Abnormality of the umbilical cord: [{'code': 'HP:0010881', 'term': 'Abnormality of the umbilical cord', 'description': 'An abnormality of the umbilical cord, which is the cord connecting the developing embryo or fetus to the placenta. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the umbilical cord', 'candidates': [{'code': 'HP:0010881', 'term': 'Abnormality of the umbilical cord', 'description': 'An abnormality of the umbilical cord, which is the cord connecting the developing embryo or fetus to the placenta. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the umbilical cord': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010881\",\n",
      "    \"matched_term\": \"Abnormality of the umbilical cord\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Umbilical cord issue', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the umbilical cord'], 'umls_mappings': [{'original': 'Abnormality of the umbilical cord', 'candidates': [{'code': 'HP:0010881', 'term': 'Abnormality of the umbilical cord', 'description': 'An abnormality of the umbilical cord, which is the cord connecting the developing embryo or fetus to the placenta. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the umbilical cord', 'ranked_candidates': [{'code': 'HP:0010881', 'term': 'Abnormality of the umbilical cord', 'description': 'An abnormality of the umbilical cord, which is the cord connecting the developing embryo or fetus to the placenta. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the umbilical cord': {\n",
      "  \"best_match_code\": \"HP:0010881\",\n",
      "  \"best_match_term\": \"Abnormality of the umbilical cord\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 8\n",
      "✅ Extracted terms: ['Overgrowth']\n",
      "🌐 [Overgrowth] API Status: 200\n",
      "✅ Results for Overgrowth: [{'code': 'HP:0033794', 'term': 'Acral overgrowth', 'description': 'Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]'}, {'code': 'HP:0009085', 'term': 'Alveolar ridge overgrowth', 'description': 'Increased width of the alveolar ridges. [PMID:19125428]'}, {'code': 'HP:0001528', 'term': 'Asymmetric overgrowth', 'description': None}, {'code': 'HP:0100774', 'term': 'Bone overgrowth', 'description': 'Increase in the mass of bone per unit volume.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Overgrowth', 'candidates': [{'code': 'HP:0033794', 'term': 'Acral overgrowth', 'description': 'Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]'}, {'code': 'HP:0009085', 'term': 'Alveolar ridge overgrowth', 'description': 'Increased width of the alveolar ridges. [PMID:19125428]'}, {'code': 'HP:0001528', 'term': 'Asymmetric overgrowth', 'description': None}, {'code': 'HP:0100774', 'term': 'Bone overgrowth', 'description': 'Increase in the mass of bone per unit volume.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Overgrowth': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0033794\",\n",
      "    \"matched_term\": \"Acral overgrowth\",\n",
      "    \"confidence\": \"25%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009085\",\n",
      "    \"matched_term\": \"Alveolar ridge overgrowth\",\n",
      "    \"confidence\": \"25%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001528\",\n",
      "    \"matched_term\": \"Asymmetric overgrowth\",\n",
      "    \"confidence\": \"25%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100774\",\n",
      "    \"matched_term\": \"Bone overgrowth\",\n",
      "    \"confidence\": \"25%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'General overgrowth', 'field_type': 'radio', 'extracted_terms': ['Overgrowth'], 'umls_mappings': [{'original': 'Overgrowth', 'candidates': [{'code': 'HP:0033794', 'term': 'Acral overgrowth', 'description': 'Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]'}, {'code': 'HP:0009085', 'term': 'Alveolar ridge overgrowth', 'description': 'Increased width of the alveolar ridges. [PMID:19125428]'}, {'code': 'HP:0001528', 'term': 'Asymmetric overgrowth', 'description': None}, {'code': 'HP:0100774', 'term': 'Bone overgrowth', 'description': 'Increase in the mass of bone per unit volume.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Overgrowth', 'ranked_candidates': [{'code': 'HP:0033794', 'term': 'Acral overgrowth', 'description': 'Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]', 'confidence': 0.25}, {'code': 'HP:0009085', 'term': 'Alveolar ridge overgrowth', 'description': 'Increased width of the alveolar ridges. [PMID:19125428]', 'confidence': 0.25}, {'code': 'HP:0001528', 'term': 'Asymmetric overgrowth', 'description': None, 'confidence': 0.25}, {'code': 'HP:0100774', 'term': 'Bone overgrowth', 'description': 'Increase in the mass of bone per unit volume.', 'confidence': 0.25}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Overgrowth': {\n",
      "  \"best_match_code\": \"HP:0033794\",\n",
      "  \"best_match_term\": \"Acral overgrowth\",\n",
      "  \"confidence\": \"50%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"General overgrowth\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Overgrowth\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Overgrowth\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0033794\",\n",
      "          \"term\": \"Acral overgrowth\",\n",
      "          \"description\": \"Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009085\",\n",
      "          \"term\": \"Alveolar ridge overgrowth\",\n",
      "          \"description\": \"Increased width of the alveolar ridges. [PMID:19125428]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001528\",\n",
      "          \"term\": \"Asymmetric overgrowth\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0100774\",\n",
      "          \"term\": \"Bone overgrowth\",\n",
      "          \"description\": \"Increase in the mass of bone per unit volume.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Overgrowth\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0033794\",\n",
      "          \"term\": \"Acral overgrowth\",\n",
      "          \"description\": \"Excessive growth of hands and feet (predominantly due to soft tissue swelling). Typical manifestations include shoe size increase, foot enlargement, glove tightness, and hand enlargement. [PMID:27477558, PMID:27812777, PMID:30853479]\",\n",
      "          \"confidence\": 0.25\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009085\",\n",
      "          \"term\": \"Alveolar ridge overgrowth\",\n",
      "          \"description\": \"Increased width of the alveolar ridges. [PMID:19125428]\",\n",
      "          \"confidence\": 0.25\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001528\",\n",
      "          \"term\": \"Asymmetric overgrowth\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.25\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0100774\",\n",
      "          \"term\": \"Bone overgrowth\",\n",
      "          \"description\": \"Increase in the mass of bone per unit volume.\",\n",
      "          \"confidence\": 0.25\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Overgrowth\",\n",
      "      \"best_match_code\": \"HP:0033794\",\n",
      "      \"best_match_term\": \"Acral overgrowth\",\n",
      "      \"confidence\": 0.5\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1735881\n",
      "✅ Processed row 9\n",
      "✅ Extracted terms: ['Obesity']\n",
      "🌐 [Obesity] API Status: 200\n",
      "✅ Results for Obesity: [{'code': 'HP:0012743', 'term': 'Abdominal obesity', 'description': 'A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Obesity', 'candidates': [{'code': 'HP:0012743', 'term': 'Abdominal obesity', 'description': 'A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Obesity': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012743\",\n",
      "    \"matched_term\": \"Abdominal obesity\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Obesity', 'field_type': 'radio', 'extracted_terms': ['Obesity'], 'umls_mappings': [{'original': 'Obesity', 'candidates': [{'code': 'HP:0012743', 'term': 'Abdominal obesity', 'description': 'A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Obesity', 'ranked_candidates': [{'code': 'HP:0012743', 'term': 'Abdominal obesity', 'description': 'A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Obesity': {\n",
      "  \"best_match_code\": \"HP:0012743\",\n",
      "  \"best_match_term\": \"Abdominal obesity\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Obesity\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Obesity\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Obesity\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012743\",\n",
      "          \"term\": \"Abdominal obesity\",\n",
      "          \"description\": \"A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Obesity\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012743\",\n",
      "          \"term\": \"Abdominal obesity\",\n",
      "          \"description\": \"A condition of having excess fat in the abdomen. Abdominal obesity is typically defined as waist circumferences of 40 inches or more in men and 35 inches or more in women. Abdominal obesity raises the risk of developing disorders, such as DIABETES; HYPERTENSION; and METABOLIC SYNDROME.\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Obesity\",\n",
      "      \"best_match_code\": \"HP:0012743\",\n",
      "      \"best_match_term\": \"Abdominal obesity\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0311277\n",
      "✅ Processed row 10\n",
      "✅ Extracted terms: ['Hemihyperplasia']\n",
      "🌐 [Hemihyperplasia] API Status: 200\n",
      "✅ Results for Hemihyperplasia: [{'code': 'HP:0005323', 'term': 'Facial hemihyperplasia', 'description': 'Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hemihyperplasia', 'candidates': [{'code': 'HP:0005323', 'term': 'Facial hemihyperplasia', 'description': 'Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hemihyperplasia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005323\",\n",
      "    \"matched_term\": \"Facial hemihyperplasia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Uneven growth (one side larger/longer)', 'field_type': 'radio', 'extracted_terms': ['Hemihyperplasia'], 'umls_mappings': [{'original': 'Hemihyperplasia', 'candidates': [{'code': 'HP:0005323', 'term': 'Facial hemihyperplasia', 'description': 'Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hemihyperplasia', 'ranked_candidates': [{'code': 'HP:0005323', 'term': 'Facial hemihyperplasia', 'description': 'Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hemihyperplasia': {\n",
      "  \"best_match_code\": \"HP:0005323\",\n",
      "  \"best_match_term\": \"Facial hemihyperplasia\",\n",
      "  \"confidence\": \"50%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Uneven growth (one side larger/longer)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Hemihyperplasia\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hemihyperplasia\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005323\",\n",
      "          \"term\": \"Facial hemihyperplasia\",\n",
      "          \"description\": \"Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hemihyperplasia\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005323\",\n",
      "          \"term\": \"Facial hemihyperplasia\",\n",
      "          \"description\": \"Unilateral overgrowth of facial tissues, including muscles, bones and skin. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hemihyperplasia\",\n",
      "      \"best_match_code\": \"HP:0005323\",\n",
      "      \"best_match_term\": \"Facial hemihyperplasia\",\n",
      "      \"confidence\": 0.5\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1399354\n",
      "🧩 ancestor_cuis ['C0575142', 'C1290857', 'C0012634', 'C1290856', 'C1320354', 'C2720507', 'C0037088', 'C0578002']\n",
      "🧩 candidate_details [{'cui': 'C0575142', 'name': 'Finding of head region'}, {'cui': 'C1290857', 'name': 'Disorder of face'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0578002', 'name': 'Finding of face'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Uneven growth (one side larger/longer)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Hemihyperplasia\"\n",
      "  \"best_match_code\": \"HP:0005323\",\n",
      "  \"best_match_term\": \"Facial hemihyperplasia\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0575142 (Finding of head region)\n",
      "- C1290857 (Disorder of face)\n",
      "- C0012634 (Disease)\n",
      "- C1290856 (Disorder of head)\n",
      "- C1320354 (Head finding)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0578002 (Finding of face)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 598, 'total_tokens': 599, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCdyypjg2z9vWOj4nWkqjq0b5tY7L', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--a0749219-9201-4989-ad9b-e7b0d85b5e45-0' usage_metadata={'input_tokens': 598, 'output_tokens': 1, 'total_tokens': 599, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 11\n",
      "✅ Extracted terms: ['Short stature']\n",
      "🌐 [Short stature] API Status: 200\n",
      "✅ Results for Short stature: [{'code': 'HP:0008929', 'term': 'Asymmetric short stature', 'description': None}, {'code': 'HP:0011405', 'term': 'Childhood onset short-limb short stature', 'description': None}, {'code': 'HP:0008922', 'term': 'Childhood-onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003498', 'term': 'Disproportionate short stature', 'description': 'A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008873', 'term': 'Disproportionate short-limb short stature', 'description': 'A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003521', 'term': 'Disproportionate short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011406', 'term': 'Infancy onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008909', 'term': 'Lethal short-limbed short stature', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Short stature', 'candidates': [{'code': 'HP:0008929', 'term': 'Asymmetric short stature', 'description': None}, {'code': 'HP:0011405', 'term': 'Childhood onset short-limb short stature', 'description': None}, {'code': 'HP:0008922', 'term': 'Childhood-onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003498', 'term': 'Disproportionate short stature', 'description': 'A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008873', 'term': 'Disproportionate short-limb short stature', 'description': 'A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003521', 'term': 'Disproportionate short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011406', 'term': 'Infancy onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008909', 'term': 'Lethal short-limbed short stature', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Short stature': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008929\",\n",
      "    \"matched_term\": \"Asymmetric short stature\",\n",
      "    \"confidence\": \"85%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003498\",\n",
      "    \"matched_term\": \"Disproportionate short stature\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011405\",\n",
      "    \"matched_term\": \"Childhood onset short-limb short stature\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008922\",\n",
      "    \"matched_term\": \"Childhood-onset short-trunk short stature\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008873\",\n",
      "    \"matched_term\": \"Disproportionate short-limb short stature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003521\",\n",
      "    \"matched_term\": \"Disproportionate short-trunk short stature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011406\",\n",
      "    \"matched_term\": \"Infancy onset short-trunk short stature\",\n",
      "    \"confidence\": \"65%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008909\",\n",
      "    \"matched_term\": \"Lethal short-limbed short stature\",\n",
      "    \"confidence\": \"60%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Short stature', 'field_type': 'radio', 'extracted_terms': ['Short stature'], 'umls_mappings': [{'original': 'Short stature', 'candidates': [{'code': 'HP:0008929', 'term': 'Asymmetric short stature', 'description': None}, {'code': 'HP:0011405', 'term': 'Childhood onset short-limb short stature', 'description': None}, {'code': 'HP:0008922', 'term': 'Childhood-onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003498', 'term': 'Disproportionate short stature', 'description': 'A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008873', 'term': 'Disproportionate short-limb short stature', 'description': 'A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003521', 'term': 'Disproportionate short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011406', 'term': 'Infancy onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008909', 'term': 'Lethal short-limbed short stature', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Short stature', 'ranked_candidates': [{'code': 'HP:0008929', 'term': 'Asymmetric short stature', 'description': None, 'confidence': 0.85}, {'code': 'HP:0003498', 'term': 'Disproportionate short stature', 'description': 'A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0011405', 'term': 'Childhood onset short-limb short stature', 'description': None, 'confidence': 0.75}, {'code': 'HP:0008922', 'term': 'Childhood-onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}, {'code': 'HP:0008873', 'term': 'Disproportionate short-limb short stature', 'description': 'A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0003521', 'term': 'Disproportionate short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0011406', 'term': 'Infancy onset short-trunk short stature', 'description': 'A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.65}, {'code': 'HP:0008909', 'term': 'Lethal short-limbed short stature', 'description': None, 'confidence': 0.6}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Short stature': {\n",
      "  \"best_match_code\": \"HP:0008929\",\n",
      "  \"best_match_term\": \"Asymmetric short stature\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Short stature\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Short stature\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short stature\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008929\",\n",
      "          \"term\": \"Asymmetric short stature\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011405\",\n",
      "          \"term\": \"Childhood onset short-limb short stature\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008922\",\n",
      "          \"term\": \"Childhood-onset short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0003498\",\n",
      "          \"term\": \"Disproportionate short stature\",\n",
      "          \"description\": \"A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008873\",\n",
      "          \"term\": \"Disproportionate short-limb short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0003521\",\n",
      "          \"term\": \"Disproportionate short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011406\",\n",
      "          \"term\": \"Infancy onset short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008909\",\n",
      "          \"term\": \"Lethal short-limbed short stature\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short stature\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008929\",\n",
      "          \"term\": \"Asymmetric short stature\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.85\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0003498\",\n",
      "          \"term\": \"Disproportionate short stature\",\n",
      "          \"description\": \"A kind of short stature in which different regions of the body are shortened to differing extents. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011405\",\n",
      "          \"term\": \"Childhood onset short-limb short stature\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008922\",\n",
      "          \"term\": \"Childhood-onset short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in childhood. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008873\",\n",
      "          \"term\": \"Disproportionate short-limb short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short limbs but an average-sized trunk. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0003521\",\n",
      "          \"term\": \"Disproportionate short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011406\",\n",
      "          \"term\": \"Infancy onset short-trunk short stature\",\n",
      "          \"description\": \"A type of disproportionate short stature characterized by a short trunk but a average-sized limbs with onset in infancy. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.65\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008909\",\n",
      "          \"term\": \"Lethal short-limbed short stature\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.6\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short stature\",\n",
      "      \"best_match_code\": \"HP:0008929\",\n",
      "      \"best_match_term\": \"Asymmetric short stature\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4024614\n",
      "✅ Processed row 12\n",
      "✅ Extracted terms: ['Failure to thrive']\n",
      "🌐 [Failure to thrive] API Status: 200\n",
      "✅ Results for Failure to thrive: [{'code': 'HP:0001508', 'term': 'Failure to thrive', 'description': 'Less than normal weight gain in an infant or child, which may include poor linear and head growth.'}, {'code': 'HP:0001531', 'term': 'Failure to thrive in first year of life', 'description': None}, {'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0001525', 'term': 'Marked failure to thrive', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Failure to thrive', 'candidates': [{'code': 'HP:0001508', 'term': 'Failure to thrive', 'description': 'Less than normal weight gain in an infant or child, which may include poor linear and head growth.'}, {'code': 'HP:0001531', 'term': 'Failure to thrive in first year of life', 'description': None}, {'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0001525', 'term': 'Marked failure to thrive', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Failure to thrive': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001508\",\n",
      "    \"matched_term\": \"Failure to thrive\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001525\",\n",
      "    \"matched_term\": \"Marked failure to thrive\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001531\",\n",
      "    \"matched_term\": \"Failure to thrive in first year of life\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008866\",\n",
      "    \"matched_term\": \"Failure to thrive secondary to recurrent infections\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Undergrowth (failure to thrive)', 'field_type': 'radio', 'extracted_terms': ['Failure to thrive'], 'umls_mappings': [{'original': 'Failure to thrive', 'candidates': [{'code': 'HP:0001508', 'term': 'Failure to thrive', 'description': 'Less than normal weight gain in an infant or child, which may include poor linear and head growth.'}, {'code': 'HP:0001531', 'term': 'Failure to thrive in first year of life', 'description': None}, {'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0001525', 'term': 'Marked failure to thrive', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Failure to thrive', 'ranked_candidates': [{'code': 'HP:0001508', 'term': 'Failure to thrive', 'description': 'Less than normal weight gain in an infant or child, which may include poor linear and head growth.', 'confidence': 1.0}, {'code': 'HP:0001531', 'term': 'Failure to thrive in first year of life', 'description': None, 'confidence': 0.75}, {'code': 'HP:0001525', 'term': 'Marked failure to thrive', 'description': None, 'confidence': 0.75}, {'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Failure to thrive': {\n",
      "  \"best_match_code\": \"HP:0001508\",\n",
      "  \"best_match_term\": \"Failure to thrive\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 13\n",
      "✅ Extracted terms: ['Growth hormone deficiency']\n",
      "🌐 [Growth hormone deficiency] API Status: 200\n",
      "✅ Results for Growth hormone deficiency: [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Growth hormone deficiency', 'candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Growth hormone deficiency': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0034323\",\n",
      "    \"matched_term\": \"Growth hormone deficiency\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008240\",\n",
      "    \"matched_term\": \"Secondary growth hormone deficiency\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Growth hormone deficiency', 'field_type': 'radio', 'extracted_terms': ['Growth hormone deficiency'], 'umls_mappings': [{'original': 'Growth hormone deficiency', 'candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Growth hormone deficiency', 'ranked_candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.', 'confidence': 1.0}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Growth hormone deficiency': {\n",
      "  \"best_match_code\": \"HP:0034323\",\n",
      "  \"best_match_term\": \"Growth hormone deficiency\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 14\n",
      "✅ Extracted terms: ['Growth hormone excess']\n",
      "🌐 [Growth hormone excess] API Status: 200\n",
      "✅ Results for Growth hormone excess: [{'code': 'HP:0000845', 'term': 'Growth hormone excess', 'description': 'Overproduction of growth hormone, a protein-based peptide that stimulates growth, cell reproduction, and cell regeneration.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Growth hormone excess', 'candidates': [{'code': 'HP:0000845', 'term': 'Growth hormone excess', 'description': 'Overproduction of growth hormone, a protein-based peptide that stimulates growth, cell reproduction, and cell regeneration.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Growth hormone excess': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000845\",\n",
      "    \"matched_term\": \"Growth hormone excess\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Growth hormone excess', 'field_type': 'radio', 'extracted_terms': ['Growth hormone excess'], 'umls_mappings': [{'original': 'Growth hormone excess', 'candidates': [{'code': 'HP:0000845', 'term': 'Growth hormone excess', 'description': 'Overproduction of growth hormone, a protein-based peptide that stimulates growth, cell reproduction, and cell regeneration.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Growth hormone excess', 'ranked_candidates': [{'code': 'HP:0000845', 'term': 'Growth hormone excess', 'description': 'Overproduction of growth hormone, a protein-based peptide that stimulates growth, cell reproduction, and cell regeneration.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Growth hormone excess': {\"best_match_code\": \"HP:0000845\", \"best_match_term\": \"Growth hormone excess\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 15\n",
      "✅ Extracted terms: ['Tall stature']\n",
      "🌐 [Tall stature] API Status: 200\n",
      "✅ Results for Tall stature: [{'code': 'HP:0001519', 'term': 'Disproportionate tall stature', 'description': 'A tall and slim body build with increased arm span to height ratio (>1.05) and a reduced upper-to-lower segment ratio (<0.85), i.e., unusually long arms and legs. The extremities as well as the hands and feet are unusually slim. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-6410-0882]'}, {'code': 'HP:0011407', 'term': 'Proportionate tall stature', 'description': None}, {'code': 'HP:0000098', 'term': 'Tall stature', 'description': 'Height greater than two standard deviations above the mean of the appropriate reference population for the age and sex of the individual.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Tall stature', 'candidates': [{'code': 'HP:0001519', 'term': 'Disproportionate tall stature', 'description': 'A tall and slim body build with increased arm span to height ratio (>1.05) and a reduced upper-to-lower segment ratio (<0.85), i.e., unusually long arms and legs. The extremities as well as the hands and feet are unusually slim. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-6410-0882]'}, {'code': 'HP:0011407', 'term': 'Proportionate tall stature', 'description': None}, {'code': 'HP:0000098', 'term': 'Tall stature', 'description': 'Height greater than two standard deviations above the mean of the appropriate reference population for the age and sex of the individual.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Tall stature': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000098\",\n",
      "    \"matched_term\": \"Tall stature\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011407\",\n",
      "    \"matched_term\": \"Proportionate tall stature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001519\",\n",
      "    \"matched_term\": \"Disproportionate tall stature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Tall stature', 'field_type': 'radio', 'extracted_terms': ['Tall stature'], 'umls_mappings': [{'original': 'Tall stature', 'candidates': [{'code': 'HP:0001519', 'term': 'Disproportionate tall stature', 'description': 'A tall and slim body build with increased arm span to height ratio (>1.05) and a reduced upper-to-lower segment ratio (<0.85), i.e., unusually long arms and legs. The extremities as well as the hands and feet are unusually slim. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-6410-0882]'}, {'code': 'HP:0011407', 'term': 'Proportionate tall stature', 'description': None}, {'code': 'HP:0000098', 'term': 'Tall stature', 'description': 'Height greater than two standard deviations above the mean of the appropriate reference population for the age and sex of the individual.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Tall stature', 'ranked_candidates': [{'code': 'HP:0000098', 'term': 'Tall stature', 'description': 'Height greater than two standard deviations above the mean of the appropriate reference population for the age and sex of the individual.', 'confidence': 1.0}, {'code': 'HP:0001519', 'term': 'Disproportionate tall stature', 'description': 'A tall and slim body build with increased arm span to height ratio (>1.05) and a reduced upper-to-lower segment ratio (<0.85), i.e., unusually long arms and legs. The extremities as well as the hands and feet are unusually slim. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-6410-0882]', 'confidence': 0.7}, {'code': 'HP:0011407', 'term': 'Proportionate tall stature', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Tall stature': {\n",
      "  \"best_match_code\": \"HP:0000098\",\n",
      "  \"best_match_term\": \"Tall stature\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 16\n",
      "✅ Extracted terms: ['Type II diabetes']\n",
      "🌐 [Type II diabetes] API Status: 200\n",
      "✅ Results for Type II diabetes: [{'code': 'HP:0005978', 'term': 'Type II diabetes', 'description': 'subclass of diabetes mellitus that is not insulin responsive or dependent; characterized initially by insulin resistance and hyperinsulinemia and eventually by glucose intolerance, hyperglycemia, and overt diabetes; type II diabetes mellitus is no longer considered a disease exclusively found in adults; patients seldom develop ketosis but often exhibit obesity.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Type II diabetes', 'candidates': [{'code': 'HP:0005978', 'term': 'Type II diabetes', 'description': 'subclass of diabetes mellitus that is not insulin responsive or dependent; characterized initially by insulin resistance and hyperinsulinemia and eventually by glucose intolerance, hyperglycemia, and overt diabetes; type II diabetes mellitus is no longer considered a disease exclusively found in adults; patients seldom develop ketosis but often exhibit obesity.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Type II diabetes': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005978\",\n",
      "    \"matched_term\": \"Type II diabetes\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Type 2 diabetes', 'field_type': 'radio', 'extracted_terms': ['Type II diabetes'], 'umls_mappings': [{'original': 'Type II diabetes', 'candidates': [{'code': 'HP:0005978', 'term': 'Type II diabetes', 'description': 'subclass of diabetes mellitus that is not insulin responsive or dependent; characterized initially by insulin resistance and hyperinsulinemia and eventually by glucose intolerance, hyperglycemia, and overt diabetes; type II diabetes mellitus is no longer considered a disease exclusively found in adults; patients seldom develop ketosis but often exhibit obesity.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Type II diabetes', 'ranked_candidates': [{'code': 'HP:0005978', 'term': 'Type II diabetes', 'description': 'subclass of diabetes mellitus that is not insulin responsive or dependent; characterized initially by insulin resistance and hyperinsulinemia and eventually by glucose intolerance, hyperglycemia, and overt diabetes; type II diabetes mellitus is no longer considered a disease exclusively found in adults; patients seldom develop ketosis but often exhibit obesity.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Type II diabetes': {\n",
      "  \"best_match_code\": \"HP:0005978\",\n",
      "  \"best_match_term\": \"Type II diabetes\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 17\n",
      "✅ Extracted terms: ['Type I diabetes']\n",
      "🌐 [Type I diabetes] API Status: 200\n",
      "✅ Results for Type I diabetes: [{'code': 'HP:0100651', 'term': 'Type I diabetes', 'description': 'subtype of diabetes mellitus that is characterized by insulin deficiency; it is manifested by the sudden onset of severe hyperglycemia, rapid progression to diabetic ketoacidosis, and death unless treated with insulin; the disease may occur at any age, but is most common in childhood or adolescence.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Type I diabetes', 'candidates': [{'code': 'HP:0100651', 'term': 'Type I diabetes', 'description': 'subtype of diabetes mellitus that is characterized by insulin deficiency; it is manifested by the sudden onset of severe hyperglycemia, rapid progression to diabetic ketoacidosis, and death unless treated with insulin; the disease may occur at any age, but is most common in childhood or adolescence.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Type I diabetes': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100651\",\n",
      "    \"matched_term\": \"Type I diabetes\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Type 1 diabetes', 'field_type': 'radio', 'extracted_terms': ['Type I diabetes'], 'umls_mappings': [{'original': 'Type I diabetes', 'candidates': [{'code': 'HP:0100651', 'term': 'Type I diabetes', 'description': 'subtype of diabetes mellitus that is characterized by insulin deficiency; it is manifested by the sudden onset of severe hyperglycemia, rapid progression to diabetic ketoacidosis, and death unless treated with insulin; the disease may occur at any age, but is most common in childhood or adolescence.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Type I diabetes', 'ranked_candidates': [{'code': 'HP:0100651', 'term': 'Type I diabetes', 'description': 'subtype of diabetes mellitus that is characterized by insulin deficiency; it is manifested by the sudden onset of severe hyperglycemia, rapid progression to diabetic ketoacidosis, and death unless treated with insulin; the disease may occur at any age, but is most common in childhood or adolescence.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Type I diabetes': {\n",
      "  \"best_match_code\": \"HP:0100651\",\n",
      "  \"best_match_term\": \"Type I diabetes\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 18\n",
      "✅ Extracted terms: ['Delayed puberty']\n",
      "🌐 [Delayed puberty] API Status: 200\n",
      "✅ Results for Delayed puberty: [{'code': 'HP:0000823', 'term': 'Delayed puberty', 'description': 'The lack of development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations above the mean age at onset of PUBERTY in a population. Delayed puberty can be classified by defects in the hypothalamic LHRH pulse generator, the PITUITARY GLAND, or the GONADS. These patients will undergo spontaneous but delayed puberty whereas patients with SEXUAL INFANTILISM will not.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Delayed puberty', 'candidates': [{'code': 'HP:0000823', 'term': 'Delayed puberty', 'description': 'The lack of development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations above the mean age at onset of PUBERTY in a population. Delayed puberty can be classified by defects in the hypothalamic LHRH pulse generator, the PITUITARY GLAND, or the GONADS. These patients will undergo spontaneous but delayed puberty whereas patients with SEXUAL INFANTILISM will not.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Delayed puberty': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000823\",\n",
      "    \"matched_term\": \"Delayed puberty\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Delayed puberty', 'field_type': 'radio', 'extracted_terms': ['Delayed puberty'], 'umls_mappings': [{'original': 'Delayed puberty', 'candidates': [{'code': 'HP:0000823', 'term': 'Delayed puberty', 'description': 'The lack of development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations above the mean age at onset of PUBERTY in a population. Delayed puberty can be classified by defects in the hypothalamic LHRH pulse generator, the PITUITARY GLAND, or the GONADS. These patients will undergo spontaneous but delayed puberty whereas patients with SEXUAL INFANTILISM will not.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Delayed puberty', 'ranked_candidates': [{'code': 'HP:0000823', 'term': 'Delayed puberty', 'description': 'The lack of development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations above the mean age at onset of PUBERTY in a population. Delayed puberty can be classified by defects in the hypothalamic LHRH pulse generator, the PITUITARY GLAND, or the GONADS. These patients will undergo spontaneous but delayed puberty whereas patients with SEXUAL INFANTILISM will not.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Delayed puberty': {\n",
      "  \"best_match_code\": \"HP:0000823\",\n",
      "  \"best_match_term\": \"Delayed puberty\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 19\n",
      "✅ Extracted terms: ['Diabetes insipidus']\n",
      "🌐 [Diabetes insipidus] API Status: 200\n",
      "✅ Results for Diabetes insipidus: [{'code': 'HP:0000863', 'term': 'Central diabetes insipidus', 'description': 'Bristfällig utsöndring av vasopressin från neurohypofysen. Kliniska symtom är extrem törst (polydipsi) och nedsatt serumosmolalitet. Tänkbara orsaker kan vara skallskada, sviter av nervkirurgi, hypotalamustumörer, hypofystumörer, infektioner i det centrala nervsystemet, hypofysapoplexi, cerebrovaskulära störningar, granulomatösa sjukdomar (t ex sarkoidos) och andra tillstånd. Sjukdomen kan också vara ärftlig, som ett autosomalt eller recessivt drag.'}, {'code': 'HP:0000873', 'term': 'Diabetes insipidus', 'description': 'A disease that is characterized by frequent urination, excretion of large amounts of dilute URINE, and excessive THIRST. Etiologies of diabetes insipidus include deficiency of antidiuretic hormone (also known as ADH or VASOPRESSIN) secreted by the NEUROHYPOPHYSIS, impaired KIDNEY response to ADH, and impaired hypothalamic regulation of thirst.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Diabetes insipidus', 'candidates': [{'code': 'HP:0000863', 'term': 'Central diabetes insipidus', 'description': 'Bristfällig utsöndring av vasopressin från neurohypofysen. Kliniska symtom är extrem törst (polydipsi) och nedsatt serumosmolalitet. Tänkbara orsaker kan vara skallskada, sviter av nervkirurgi, hypotalamustumörer, hypofystumörer, infektioner i det centrala nervsystemet, hypofysapoplexi, cerebrovaskulära störningar, granulomatösa sjukdomar (t ex sarkoidos) och andra tillstånd. Sjukdomen kan också vara ärftlig, som ett autosomalt eller recessivt drag.'}, {'code': 'HP:0000873', 'term': 'Diabetes insipidus', 'description': 'A disease that is characterized by frequent urination, excretion of large amounts of dilute URINE, and excessive THIRST. Etiologies of diabetes insipidus include deficiency of antidiuretic hormone (also known as ADH or VASOPRESSIN) secreted by the NEUROHYPOPHYSIS, impaired KIDNEY response to ADH, and impaired hypothalamic regulation of thirst.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Diabetes insipidus': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000873\",\n",
      "    \"matched_term\": \"Diabetes insipidus\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000863\",\n",
      "    \"matched_term\": \"Central diabetes insipidus\",\n",
      "    \"confidence\": \"80%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Diabetes insipidus', 'field_type': 'radio', 'extracted_terms': ['Diabetes insipidus'], 'umls_mappings': [{'original': 'Diabetes insipidus', 'candidates': [{'code': 'HP:0000863', 'term': 'Central diabetes insipidus', 'description': 'Bristfällig utsöndring av vasopressin från neurohypofysen. Kliniska symtom är extrem törst (polydipsi) och nedsatt serumosmolalitet. Tänkbara orsaker kan vara skallskada, sviter av nervkirurgi, hypotalamustumörer, hypofystumörer, infektioner i det centrala nervsystemet, hypofysapoplexi, cerebrovaskulära störningar, granulomatösa sjukdomar (t ex sarkoidos) och andra tillstånd. Sjukdomen kan också vara ärftlig, som ett autosomalt eller recessivt drag.'}, {'code': 'HP:0000873', 'term': 'Diabetes insipidus', 'description': 'A disease that is characterized by frequent urination, excretion of large amounts of dilute URINE, and excessive THIRST. Etiologies of diabetes insipidus include deficiency of antidiuretic hormone (also known as ADH or VASOPRESSIN) secreted by the NEUROHYPOPHYSIS, impaired KIDNEY response to ADH, and impaired hypothalamic regulation of thirst.'}]}], 'mappability_retry_count': 4, 'retries': 0, 'ranked_mappings': [{'original': 'Diabetes insipidus', 'ranked_candidates': [{'code': 'HP:0000873', 'term': 'Diabetes insipidus', 'description': 'A disease that is characterized by frequent urination, excretion of large amounts of dilute URINE, and excessive THIRST. Etiologies of diabetes insipidus include deficiency of antidiuretic hormone (also known as ADH or VASOPRESSIN) secreted by the NEUROHYPOPHYSIS, impaired KIDNEY response to ADH, and impaired hypothalamic regulation of thirst.', 'confidence': 1.0}, {'code': 'HP:0000863', 'term': 'Central diabetes insipidus', 'description': 'Bristfällig utsöndring av vasopressin från neurohypofysen. Kliniska symtom är extrem törst (polydipsi) och nedsatt serumosmolalitet. Tänkbara orsaker kan vara skallskada, sviter av nervkirurgi, hypotalamustumörer, hypofystumörer, infektioner i det centrala nervsystemet, hypofysapoplexi, cerebrovaskulära störningar, granulomatösa sjukdomar (t ex sarkoidos) och andra tillstånd. Sjukdomen kan också vara ärftlig, som ett autosomalt eller recessivt drag.', 'confidence': 0.8}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Diabetes insipidus': {\"best_match_code\": \"HP:0000873\", \"best_match_term\": \"Diabetes insipidus\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 20\n",
      "✅ Extracted terms: ['Growth hormone deficiency']\n",
      "🌐 [Growth hormone deficiency] API Status: 200\n",
      "✅ Results for Growth hormone deficiency: [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Growth hormone deficiency', 'candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Growth hormone deficiency': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0034323\",\n",
      "    \"matched_term\": \"Growth hormone deficiency\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008240\",\n",
      "    \"matched_term\": \"Secondary growth hormone deficiency\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Growth hormone deficiency', 'field_type': 'radio', 'extracted_terms': ['Growth hormone deficiency'], 'umls_mappings': [{'original': 'Growth hormone deficiency', 'candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.'}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Growth hormone deficiency', 'ranked_candidates': [{'code': 'HP:0034323', 'term': 'Growth hormone deficiency', 'description': 'Abnormally low levels of circulating somatotropin.', 'confidence': 1.0}, {'code': 'HP:0008240', 'term': 'Secondary growth hormone deficiency', 'description': None, 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Growth hormone deficiency': {\n",
      "  \"best_match_code\": \"HP:0034323\",\n",
      "  \"best_match_term\": \"Growth hormone deficiency\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 21\n",
      "✅ Extracted terms: ['Precocious puberty']\n",
      "🌐 [Precocious puberty] API Status: 200\n",
      "✅ Results for Precocious puberty: [{'code': 'HP:0008236', 'term': 'Isosexual precocious puberty', 'description': None}, {'code': 'HP:0008185', 'term': 'Male precocious puberty', 'description': 'The onset of puberty before the age of 9 years in boys. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000826', 'term': 'Precocious puberty', 'description': 'Development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations below the mean age at onset of PUBERTY in the population. This early maturation of the hypothalamic-pituitary-gonadal axis results in sexual precocity, elevated serum levels of GONADOTROPINS and GONADAL STEROID HORMONES such as ESTRADIOL and TESTOSTERONE.'}, {'code': 'HP:0010465', 'term': 'Precocious puberty in females', 'description': 'The onset of puberty before the age of 8 years in girls. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Precocious puberty', 'candidates': [{'code': 'HP:0008236', 'term': 'Isosexual precocious puberty', 'description': None}, {'code': 'HP:0008185', 'term': 'Male precocious puberty', 'description': 'The onset of puberty before the age of 9 years in boys. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000826', 'term': 'Precocious puberty', 'description': 'Development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations below the mean age at onset of PUBERTY in the population. This early maturation of the hypothalamic-pituitary-gonadal axis results in sexual precocity, elevated serum levels of GONADOTROPINS and GONADAL STEROID HORMONES such as ESTRADIOL and TESTOSTERONE.'}, {'code': 'HP:0010465', 'term': 'Precocious puberty in females', 'description': 'The onset of puberty before the age of 8 years in girls. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Precocious puberty': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000826\",\n",
      "    \"matched_term\": \"Precocious puberty\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008236\",\n",
      "    \"matched_term\": \"Isosexual precocious puberty\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008185\",\n",
      "    \"matched_term\": \"Male precocious puberty\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010465\",\n",
      "    \"matched_term\": \"Precocious puberty in females\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Early puberty', 'field_type': 'radio', 'extracted_terms': ['Precocious puberty'], 'umls_mappings': [{'original': 'Precocious puberty', 'candidates': [{'code': 'HP:0008236', 'term': 'Isosexual precocious puberty', 'description': None}, {'code': 'HP:0008185', 'term': 'Male precocious puberty', 'description': 'The onset of puberty before the age of 9 years in boys. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000826', 'term': 'Precocious puberty', 'description': 'Development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations below the mean age at onset of PUBERTY in the population. This early maturation of the hypothalamic-pituitary-gonadal axis results in sexual precocity, elevated serum levels of GONADOTROPINS and GONADAL STEROID HORMONES such as ESTRADIOL and TESTOSTERONE.'}, {'code': 'HP:0010465', 'term': 'Precocious puberty in females', 'description': 'The onset of puberty before the age of 8 years in girls. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Precocious puberty', 'ranked_candidates': [{'code': 'HP:0000826', 'term': 'Precocious puberty', 'description': 'Development of SEXUAL MATURATION in boys and girls at a chronological age that is 2.5 standard deviations below the mean age at onset of PUBERTY in the population. This early maturation of the hypothalamic-pituitary-gonadal axis results in sexual precocity, elevated serum levels of GONADOTROPINS and GONADAL STEROID HORMONES such as ESTRADIOL and TESTOSTERONE.', 'confidence': 1.0}, {'code': 'HP:0008236', 'term': 'Isosexual precocious puberty', 'description': None, 'confidence': 0.75}, {'code': 'HP:0008185', 'term': 'Male precocious puberty', 'description': 'The onset of puberty before the age of 9 years in boys. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}, {'code': 'HP:0010465', 'term': 'Precocious puberty in females', 'description': 'The onset of puberty before the age of 8 years in girls. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Precocious puberty': {\n",
      "  \"best_match_code\": \"HP:0000826\",\n",
      "  \"best_match_term\": \"Precocious puberty\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 22\n",
      "✅ Extracted terms: ['Hypogonadism']\n",
      "🌐 [Hypogonadism] API Status: 200\n",
      "✅ Results for Hypogonadism: [{'code': 'HP:0000134', 'term': 'Female hypogonadism', 'description': 'Decreased functionality of the female gonads, i.e., of the ovary. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000815', 'term': 'Hypergonadotrophic hypogonadism', 'description': 'Ovarian or testicular dysfunction associated with high levels of gonadotropins.'}, {'code': 'HP:0000135', 'term': 'Hypogonadism', 'description': 'Condition resulting from deficient gonadal functions, such as GAMETOGENESIS and the production of GONADAL STEROID HORMONES. It is characterized by delay in GROWTH, germ cell maturation, and development of secondary sex characteristics. Hypogonadism can be due to a deficiency of GONADOTROPINS (hypogonadotropic hypogonadism) or due to primary gonadal failure (hypergonadotropic hypogonadism).'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypogonadism', 'candidates': [{'code': 'HP:0000134', 'term': 'Female hypogonadism', 'description': 'Decreased functionality of the female gonads, i.e., of the ovary. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000815', 'term': 'Hypergonadotrophic hypogonadism', 'description': 'Ovarian or testicular dysfunction associated with high levels of gonadotropins.'}, {'code': 'HP:0000135', 'term': 'Hypogonadism', 'description': 'Condition resulting from deficient gonadal functions, such as GAMETOGENESIS and the production of GONADAL STEROID HORMONES. It is characterized by delay in GROWTH, germ cell maturation, and development of secondary sex characteristics. Hypogonadism can be due to a deficiency of GONADOTROPINS (hypogonadotropic hypogonadism) or due to primary gonadal failure (hypergonadotropic hypogonadism).'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypogonadism': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000135\",\n",
      "    \"matched_term\": \"Hypogonadism\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000815\",\n",
      "    \"matched_term\": \"Hypergonadotrophic hypogonadism\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000134\",\n",
      "    \"matched_term\": \"Female hypogonadism\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hypogonadism', 'field_type': 'radio', 'extracted_terms': ['Hypogonadism'], 'umls_mappings': [{'original': 'Hypogonadism', 'candidates': [{'code': 'HP:0000134', 'term': 'Female hypogonadism', 'description': 'Decreased functionality of the female gonads, i.e., of the ovary. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000815', 'term': 'Hypergonadotrophic hypogonadism', 'description': 'Ovarian or testicular dysfunction associated with high levels of gonadotropins.'}, {'code': 'HP:0000135', 'term': 'Hypogonadism', 'description': 'Condition resulting from deficient gonadal functions, such as GAMETOGENESIS and the production of GONADAL STEROID HORMONES. It is characterized by delay in GROWTH, germ cell maturation, and development of secondary sex characteristics. Hypogonadism can be due to a deficiency of GONADOTROPINS (hypogonadotropic hypogonadism) or due to primary gonadal failure (hypergonadotropic hypogonadism).'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypogonadism', 'ranked_candidates': [{'code': 'HP:0000135', 'term': 'Hypogonadism', 'description': 'Condition resulting from deficient gonadal functions, such as GAMETOGENESIS and the production of GONADAL STEROID HORMONES. It is characterized by delay in GROWTH, germ cell maturation, and development of secondary sex characteristics. Hypogonadism can be due to a deficiency of GONADOTROPINS (hypogonadotropic hypogonadism) or due to primary gonadal failure (hypergonadotropic hypogonadism).', 'confidence': 1.0}, {'code': 'HP:0000134', 'term': 'Female hypogonadism', 'description': 'Decreased functionality of the female gonads, i.e., of the ovary. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0000815', 'term': 'Hypergonadotrophic hypogonadism', 'description': 'Ovarian or testicular dysfunction associated with high levels of gonadotropins.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypogonadism': {\"best_match_code\": \"HP:0000135\", \"best_match_term\": \"Hypogonadism\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 23\n",
      "✅ Extracted terms: ['Adrenal hyperplasia']\n",
      "🌐 [Adrenal hyperplasia] API Status: 200\n",
      "✅ Results for Adrenal hyperplasia: [{'code': 'HP:0008221', 'term': 'Adrenal hyperplasia', 'description': 'condition of diffuse enlargement of the adrenal glands; it is also a congenital disorder resulting from a defect in the synthesis of corticosteroids; in most cases the defect is in the enzyme 21-hydroxylase, which results in aldosterone and cortisol deficiency and an overproduction of androgen; common features include early masculinization of males and virilization of females.'}, {'code': 'HP:0008258', 'term': 'Congenital adrenal hyperplasia', 'description': 'A group of inherited disorders of the ADRENAL GLANDS, caused by enzyme defects in the synthesis of cortisol (HYDROCORTISONE) and/or ALDOSTERONE leading to accumulation of precursors for ANDROGENS. Depending on the hormone imbalance, congenital adrenal hyperplasia can be classified as salt-wasting, hypertensive, virilizing, or feminizing. Defects in STEROID 21-HYDROXYLASE; STEROID 11-BETA-HYDROXYLASE; STEROID 17-ALPHA-HYDROXYLASE; 3-beta-hydroxysteroid dehydrogenase (3-HYDROXYSTEROID DEHYDROGENASES); TESTOSTERONE 5-ALPHA-REDUCTASE; or steroidogenic acute regulatory protein; among others, underlie these disorders.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Adrenal hyperplasia', 'candidates': [{'code': 'HP:0008221', 'term': 'Adrenal hyperplasia', 'description': 'condition of diffuse enlargement of the adrenal glands; it is also a congenital disorder resulting from a defect in the synthesis of corticosteroids; in most cases the defect is in the enzyme 21-hydroxylase, which results in aldosterone and cortisol deficiency and an overproduction of androgen; common features include early masculinization of males and virilization of females.'}, {'code': 'HP:0008258', 'term': 'Congenital adrenal hyperplasia', 'description': 'A group of inherited disorders of the ADRENAL GLANDS, caused by enzyme defects in the synthesis of cortisol (HYDROCORTISONE) and/or ALDOSTERONE leading to accumulation of precursors for ANDROGENS. Depending on the hormone imbalance, congenital adrenal hyperplasia can be classified as salt-wasting, hypertensive, virilizing, or feminizing. Defects in STEROID 21-HYDROXYLASE; STEROID 11-BETA-HYDROXYLASE; STEROID 17-ALPHA-HYDROXYLASE; 3-beta-hydroxysteroid dehydrogenase (3-HYDROXYSTEROID DEHYDROGENASES); TESTOSTERONE 5-ALPHA-REDUCTASE; or steroidogenic acute regulatory protein; among others, underlie these disorders.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Adrenal hyperplasia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008221\",\n",
      "    \"matched_term\": \"Adrenal hyperplasia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008258\",\n",
      "    \"matched_term\": \"Congenital adrenal hyperplasia\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Adrenal hyperplasia', 'field_type': 'radio', 'extracted_terms': ['Adrenal hyperplasia'], 'umls_mappings': [{'original': 'Adrenal hyperplasia', 'candidates': [{'code': 'HP:0008221', 'term': 'Adrenal hyperplasia', 'description': 'condition of diffuse enlargement of the adrenal glands; it is also a congenital disorder resulting from a defect in the synthesis of corticosteroids; in most cases the defect is in the enzyme 21-hydroxylase, which results in aldosterone and cortisol deficiency and an overproduction of androgen; common features include early masculinization of males and virilization of females.'}, {'code': 'HP:0008258', 'term': 'Congenital adrenal hyperplasia', 'description': 'A group of inherited disorders of the ADRENAL GLANDS, caused by enzyme defects in the synthesis of cortisol (HYDROCORTISONE) and/or ALDOSTERONE leading to accumulation of precursors for ANDROGENS. Depending on the hormone imbalance, congenital adrenal hyperplasia can be classified as salt-wasting, hypertensive, virilizing, or feminizing. Defects in STEROID 21-HYDROXYLASE; STEROID 11-BETA-HYDROXYLASE; STEROID 17-ALPHA-HYDROXYLASE; 3-beta-hydroxysteroid dehydrogenase (3-HYDROXYSTEROID DEHYDROGENASES); TESTOSTERONE 5-ALPHA-REDUCTASE; or steroidogenic acute regulatory protein; among others, underlie these disorders.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Adrenal hyperplasia', 'ranked_candidates': [{'code': 'HP:0008221', 'term': 'Adrenal hyperplasia', 'description': 'condition of diffuse enlargement of the adrenal glands; it is also a congenital disorder resulting from a defect in the synthesis of corticosteroids; in most cases the defect is in the enzyme 21-hydroxylase, which results in aldosterone and cortisol deficiency and an overproduction of androgen; common features include early masculinization of males and virilization of females.', 'confidence': 1.0}, {'code': 'HP:0008258', 'term': 'Congenital adrenal hyperplasia', 'description': 'A group of inherited disorders of the ADRENAL GLANDS, caused by enzyme defects in the synthesis of cortisol (HYDROCORTISONE) and/or ALDOSTERONE leading to accumulation of precursors for ANDROGENS. Depending on the hormone imbalance, congenital adrenal hyperplasia can be classified as salt-wasting, hypertensive, virilizing, or feminizing. Defects in STEROID 21-HYDROXYLASE; STEROID 11-BETA-HYDROXYLASE; STEROID 17-ALPHA-HYDROXYLASE; 3-beta-hydroxysteroid dehydrogenase (3-HYDROXYSTEROID DEHYDROGENASES); TESTOSTERONE 5-ALPHA-REDUCTASE; or steroidogenic acute regulatory protein; among others, underlie these disorders.', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Adrenal hyperplasia': {\"best_match_code\": \"HP:0008221\", \"best_match_term\": \"Adrenal hyperplasia\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 24\n",
      "✅ Extracted terms: ['Hyperthyroidism']\n",
      "🌐 [Hyperthyroidism] API Status: 200\n",
      "✅ Results for Hyperthyroidism: [{'code': 'HP:0000836', 'term': 'Hyperthyroidism', 'description': 'Hypersecretion of THYROID HORMONES from the THYROID GLAND. Elevated levels of thyroid hormones increase BASAL METABOLIC RATE.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hyperthyroidism', 'candidates': [{'code': 'HP:0000836', 'term': 'Hyperthyroidism', 'description': 'Hypersecretion of THYROID HORMONES from the THYROID GLAND. Elevated levels of thyroid hormones increase BASAL METABOLIC RATE.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hyperthyroidism': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000836\",\n",
      "    \"matched_term\": \"Hyperthyroidism\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hyperthyroidism', 'field_type': 'radio', 'extracted_terms': ['Hyperthyroidism'], 'umls_mappings': [{'original': 'Hyperthyroidism', 'candidates': [{'code': 'HP:0000836', 'term': 'Hyperthyroidism', 'description': 'Hypersecretion of THYROID HORMONES from the THYROID GLAND. Elevated levels of thyroid hormones increase BASAL METABOLIC RATE.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hyperthyroidism', 'ranked_candidates': [{'code': 'HP:0000836', 'term': 'Hyperthyroidism', 'description': 'Hypersecretion of THYROID HORMONES from the THYROID GLAND. Elevated levels of thyroid hormones increase BASAL METABOLIC RATE.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hyperthyroidism': {\n",
      "  \"best_match_code\": \"HP:0000836\",\n",
      "  \"best_match_term\": \"Hyperthyroidism\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 25\n",
      "✅ Extracted terms: ['Hypothyroidism']\n",
      "🌐 [Hypothyroidism] API Status: 200\n",
      "✅ Results for Hypothyroidism: [{'code': 'HP:0008191', 'term': 'Athyroidal hypothyroidism', 'description': None}, {'code': 'HP:0011787', 'term': 'Central hypothyroidism', 'description': 'Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.'}, {'code': 'HP:0008223', 'term': 'Compensated hypothyroidism', 'description': 'Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]'}, {'code': 'HP:0000851', 'term': 'Congenital hypothyroidism', 'description': 'condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypothyroidism', 'candidates': [{'code': 'HP:0008191', 'term': 'Athyroidal hypothyroidism', 'description': None}, {'code': 'HP:0011787', 'term': 'Central hypothyroidism', 'description': 'Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.'}, {'code': 'HP:0008223', 'term': 'Compensated hypothyroidism', 'description': 'Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]'}, {'code': 'HP:0000851', 'term': 'Congenital hypothyroidism', 'description': 'condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypothyroidism': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008191\",\n",
      "    \"matched_term\": \"Athyroidal hypothyroidism\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011787\",\n",
      "    \"matched_term\": \"Central hypothyroidism\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008223\",\n",
      "    \"matched_term\": \"Compensated hypothyroidism\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000851\",\n",
      "    \"matched_term\": \"Congenital hypothyroidism\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hypothyroidism', 'field_type': 'radio', 'extracted_terms': ['Hypothyroidism'], 'umls_mappings': [{'original': 'Hypothyroidism', 'candidates': [{'code': 'HP:0008191', 'term': 'Athyroidal hypothyroidism', 'description': None}, {'code': 'HP:0011787', 'term': 'Central hypothyroidism', 'description': 'Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.'}, {'code': 'HP:0008223', 'term': 'Compensated hypothyroidism', 'description': 'Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]'}, {'code': 'HP:0000851', 'term': 'Congenital hypothyroidism', 'description': 'condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.'}]}], 'mappability_retry_count': 1, 'retries': 0, 'ranked_mappings': [{'original': 'Hypothyroidism', 'ranked_candidates': [{'code': 'HP:0008191', 'term': 'Athyroidal hypothyroidism', 'description': None, 'confidence': 0.75}, {'code': 'HP:0011787', 'term': 'Central hypothyroidism', 'description': 'Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.', 'confidence': 0.75}, {'code': 'HP:0008223', 'term': 'Compensated hypothyroidism', 'description': 'Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]', 'confidence': 0.75}, {'code': 'HP:0000851', 'term': 'Congenital hypothyroidism', 'description': 'condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypothyroidism': {\n",
      "  \"best_match_code\": \"HP:0008191\",\n",
      "  \"best_match_term\": \"Athyroidal hypothyroidism\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Hypothyroidism\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Hypothyroidism\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hypothyroidism\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008191\",\n",
      "          \"term\": \"Athyroidal hypothyroidism\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011787\",\n",
      "          \"term\": \"Central hypothyroidism\",\n",
      "          \"description\": \"Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008223\",\n",
      "          \"term\": \"Compensated hypothyroidism\",\n",
      "          \"description\": \"Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000851\",\n",
      "          \"term\": \"Congenital hypothyroidism\",\n",
      "          \"description\": \"condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 1,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hypothyroidism\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008191\",\n",
      "          \"term\": \"Athyroidal hypothyroidism\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011787\",\n",
      "          \"term\": \"Central hypothyroidism\",\n",
      "          \"description\": \"Abnormally low levels of thyroid hormones due to a disorder originating within the hypothalamic-pituitary axis.\",\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008223\",\n",
      "          \"term\": \"Compensated hypothyroidism\",\n",
      "          \"description\": \"Condition associated with a raised serum concentration of thyroid stimulating hormone (TSH) but a normal serum free thyroxine (FT4). [PMID:28406057]\",\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000851\",\n",
      "          \"term\": \"Congenital hypothyroidism\",\n",
      "          \"description\": \"condition due to congenital lack of thyroid hormone, marked by arrested physical and mental development, dystrophy of the bones and soft parts, and lowered basal metabolism; it is the congenital form of thyroid deficiency, while myxedema is the acquired form.\",\n",
      "          \"confidence\": 0.75\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hypothyroidism\",\n",
      "      \"best_match_code\": \"HP:0008191\",\n",
      "      \"best_match_term\": \"Athyroidal hypothyroidism\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4020805\n",
      "✅ Processed row 26\n",
      "✅ Extracted terms: ['Goiter']\n",
      "🌐 [Goiter] API Status: 200\n",
      "✅ Results for Goiter: [{'code': 'HP:6000815', 'term': 'Amyloid goiter', 'description': 'Amyloidosis is defined as the accumulation of amorphous, proteinaceous material in different parts of the body. Amyloid can be deposited in the thyroid gland in such quantities to cause a clinically apparent enlargement of the gland known as Amyloid goiter. [PMID:19168408, PMID:19318742, PMID:32874558]'}, {'code': 'HP:0008251', 'term': 'Congenital goiter', 'description': 'An enlargement of the thyroid gland with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009798', 'term': 'Euthyroid goiter', 'description': 'A goiter that is not associated with functional thyroid abnormalities. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000866', 'term': 'Euthyroid multinodular goiter', 'description': None}, {'code': 'HP:0000853', 'term': 'Goiter', 'description': 'Enlargement of the THYROID GLAND that may increase from about 20 grams to hundreds of grams in human adults. Goiter is observed in individuals with normal thyroid function (euthyroidism), thyroid deficiency (HYPOTHYROIDISM), or hormone overproduction (HYPERTHYROIDISM). Goiter may be congenital or acquired, sporadic or endemic (GOITER, ENDEMIC).'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Goiter', 'candidates': [{'code': 'HP:6000815', 'term': 'Amyloid goiter', 'description': 'Amyloidosis is defined as the accumulation of amorphous, proteinaceous material in different parts of the body. Amyloid can be deposited in the thyroid gland in such quantities to cause a clinically apparent enlargement of the gland known as Amyloid goiter. [PMID:19168408, PMID:19318742, PMID:32874558]'}, {'code': 'HP:0008251', 'term': 'Congenital goiter', 'description': 'An enlargement of the thyroid gland with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009798', 'term': 'Euthyroid goiter', 'description': 'A goiter that is not associated with functional thyroid abnormalities. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000866', 'term': 'Euthyroid multinodular goiter', 'description': None}, {'code': 'HP:0000853', 'term': 'Goiter', 'description': 'Enlargement of the THYROID GLAND that may increase from about 20 grams to hundreds of grams in human adults. Goiter is observed in individuals with normal thyroid function (euthyroidism), thyroid deficiency (HYPOTHYROIDISM), or hormone overproduction (HYPERTHYROIDISM). Goiter may be congenital or acquired, sporadic or endemic (GOITER, ENDEMIC).'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Goiter': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000853\",\n",
      "    \"matched_term\": \"Goiter\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:6000815\",\n",
      "    \"matched_term\": \"Amyloid goiter\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008251\",\n",
      "    \"matched_term\": \"Congenital goiter\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009798\",\n",
      "    \"matched_term\": \"Euthyroid goiter\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000866\",\n",
      "    \"matched_term\": \"Euthyroid multinodular goiter\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Goiter', 'field_type': 'radio', 'extracted_terms': ['Goiter'], 'umls_mappings': [{'original': 'Goiter', 'candidates': [{'code': 'HP:6000815', 'term': 'Amyloid goiter', 'description': 'Amyloidosis is defined as the accumulation of amorphous, proteinaceous material in different parts of the body. Amyloid can be deposited in the thyroid gland in such quantities to cause a clinically apparent enlargement of the gland known as Amyloid goiter. [PMID:19168408, PMID:19318742, PMID:32874558]'}, {'code': 'HP:0008251', 'term': 'Congenital goiter', 'description': 'An enlargement of the thyroid gland with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009798', 'term': 'Euthyroid goiter', 'description': 'A goiter that is not associated with functional thyroid abnormalities. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000866', 'term': 'Euthyroid multinodular goiter', 'description': None}, {'code': 'HP:0000853', 'term': 'Goiter', 'description': 'Enlargement of the THYROID GLAND that may increase from about 20 grams to hundreds of grams in human adults. Goiter is observed in individuals with normal thyroid function (euthyroidism), thyroid deficiency (HYPOTHYROIDISM), or hormone overproduction (HYPERTHYROIDISM). Goiter may be congenital or acquired, sporadic or endemic (GOITER, ENDEMIC).'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Goiter', 'ranked_candidates': [{'code': 'HP:0000853', 'term': 'Goiter', 'description': 'Enlargement of the THYROID GLAND that may increase from about 20 grams to hundreds of grams in human adults. Goiter is observed in individuals with normal thyroid function (euthyroidism), thyroid deficiency (HYPOTHYROIDISM), or hormone overproduction (HYPERTHYROIDISM). Goiter may be congenital or acquired, sporadic or endemic (GOITER, ENDEMIC).', 'confidence': 1.0}, {'code': 'HP:6000815', 'term': 'Amyloid goiter', 'description': 'Amyloidosis is defined as the accumulation of amorphous, proteinaceous material in different parts of the body. Amyloid can be deposited in the thyroid gland in such quantities to cause a clinically apparent enlargement of the gland known as Amyloid goiter. [PMID:19168408, PMID:19318742, PMID:32874558]', 'confidence': 0.7}, {'code': 'HP:0008251', 'term': 'Congenital goiter', 'description': 'An enlargement of the thyroid gland with congenital onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0009798', 'term': 'Euthyroid goiter', 'description': 'A goiter that is not associated with functional thyroid abnormalities. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0000866', 'term': 'Euthyroid multinodular goiter', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Goiter': {\n",
      "  \"best_match_code\": \"HP:0000853\",\n",
      "  \"best_match_term\": \"Goiter\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 27\n",
      "✅ Extracted terms: ['Abnormality of the parathyroid gland']\n",
      "🌐 [Abnormality of the parathyroid gland] API Status: 200\n",
      "✅ Results for Abnormality of the parathyroid gland: [{'code': 'HP:0000828', 'term': 'Abnormality of the parathyroid gland', 'description': 'An abnormality of the parathyroid gland. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the parathyroid gland', 'candidates': [{'code': 'HP:0000828', 'term': 'Abnormality of the parathyroid gland', 'description': 'An abnormality of the parathyroid gland. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the parathyroid gland': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000828\",\n",
      "    \"matched_term\": \"Abnormality of the parathyroid gland\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Parathyroid issue', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the parathyroid gland'], 'umls_mappings': [{'original': 'Abnormality of the parathyroid gland', 'candidates': [{'code': 'HP:0000828', 'term': 'Abnormality of the parathyroid gland', 'description': 'An abnormality of the parathyroid gland. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the parathyroid gland', 'ranked_candidates': [{'code': 'HP:0000828', 'term': 'Abnormality of the parathyroid gland', 'description': 'An abnormality of the parathyroid gland. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the parathyroid gland': {\n",
      "  \"best_match_code\": \"HP:0000828\",\n",
      "  \"best_match_term\": \"Abnormality of the parathyroid gland\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 28\n",
      "✅ Extracted terms: ['Breast carcinoma']\n",
      "🌐 [Breast carcinoma] API Status: 200\n",
      "✅ Results for Breast carcinoma: [{'code': 'HP:0003002', 'term': 'Breast carcinoma', 'description': 'The presence of a carcinoma of the breast. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006625', 'term': 'Multifocal breast carcinoma', 'description': 'A breast carcinoma characterized by the presence of multiple cancerous tumors that originate from the same clone and are usually located in the same quadrant of the breast.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Breast carcinoma', 'candidates': [{'code': 'HP:0003002', 'term': 'Breast carcinoma', 'description': 'The presence of a carcinoma of the breast. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006625', 'term': 'Multifocal breast carcinoma', 'description': 'A breast carcinoma characterized by the presence of multiple cancerous tumors that originate from the same clone and are usually located in the same quadrant of the breast.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Breast carcinoma': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003002\",\n",
      "    \"matched_term\": \"Breast carcinoma\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006625\",\n",
      "    \"matched_term\": \"Multifocal breast carcinoma\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Breast cancer', 'field_type': 'radio', 'extracted_terms': ['Breast carcinoma'], 'umls_mappings': [{'original': 'Breast carcinoma', 'candidates': [{'code': 'HP:0003002', 'term': 'Breast carcinoma', 'description': 'The presence of a carcinoma of the breast. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006625', 'term': 'Multifocal breast carcinoma', 'description': 'A breast carcinoma characterized by the presence of multiple cancerous tumors that originate from the same clone and are usually located in the same quadrant of the breast.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Breast carcinoma', 'ranked_candidates': [{'code': 'HP:0003002', 'term': 'Breast carcinoma', 'description': 'The presence of a carcinoma of the breast. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0006625', 'term': 'Multifocal breast carcinoma', 'description': 'A breast carcinoma characterized by the presence of multiple cancerous tumors that originate from the same clone and are usually located in the same quadrant of the breast.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Breast carcinoma': {\n",
      "  \"best_match_code\": \"HP:0003002\",\n",
      "  \"best_match_term\": \"Breast carcinoma\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 29\n",
      "✅ Extracted terms: ['Ovarian cancer']\n",
      "🌐 [Ovarian cancer] API Status: 200\n",
      "✅ Results for Ovarian cancer: [{'code': 'HP:0100615', 'term': 'Ovarian cancer', 'description': 'What is ovarian cancer? Cancer is a disease in which abnormal cells in the body grow out of control and form a tumor. Ovarian cancer is a cancerous tumor that forms in the tissues of an ovary. The ovaries are a pair of female reproductive glands that make eggs and female hormones. What are the types of ovarian cancer? There are a few different types of ovarian cancer. The most common type is epithelial cancer. It begins in the cells that cover the ovary. There are also two related types of epithelial cancer that can spread to the ovaries:  Fallopian tube cancer forms in the tissue lining a fallopian tube. The fallopian tubes are a pair of long, slender tubes on each side of the uterus. The uterus is the female reproductive organ where a baby grows during pregnancy. Primary peritoneal cancer forms in the tissue lining the peritoneum. Your peritoneum is a tissue lining that covers the organs in the abdomen (belly).  These two cancers are similar to ovarian cancer, and they have the same treatments. So some medical experts also consider those two types as ovarian cancer. Some other rarer types of ovarian cancer are malignant germ cell tumors and stromal tumors. What causes ovarian cancer? Ovarian cancer happens when there are changes (mutations) in the genetic material (DNA). Often, the exact cause of these genetic changes is unknown. Most ovarian cancers are caused by genetic changes that happen during your lifetime. But sometimes these genetic changes are inherited, meaning that you are born with them. Ovarian cancer that is caused by inherited genetic changes is called hereditary ovarian cancer. There are also certain genetic changes that can raise your risk of ovarian cancer, including changes called BRCA1 and BRCA2. These two changes also raise your risk of breast and other cancers. Besides genetics, your lifestyle and the environment can affect your risk of ovarian cancer. Who is more likely to develop ovarian cancer? Certain people are more likely to develop ovarian cancer. They include those who:  Have a family history of ovarian cancer in a mother, daughter, or sister Have inherited changes in the BRCA1 or BRCA2 genes. Have certain other genetic conditions, such as Lynch syndrome Have endometriosis Took hormone replacement therapy Are overweight or have obesity Are tall Are older, especially those who have gone through menopause  What are the symptoms of ovarian cancer? Ovarian cancer may not cause early signs or symptoms. By the time you do have signs or symptoms, the cancer is often advanced. The signs and symptoms may include:  Pain, swelling, or a feeling of pressure in the abdomen or pelvis Sudden or frequent urge to urinate (pee) Trouble eating or feeling full A lump in the pelvic area Gastrointestinal problems, such as gas, bloating, or constipation  How is ovarian cancer diagnosed? To find out if you have ovarian cancer, your health care provider:  Will ask about your medical history, including your symptoms Will ask about your family health history, including relatives who have had ovarian cancer Will do a physical exam, including a pelvic exam Will likely do imaging tests May do blood tests such as a CA-125 blood test  Often the only way to know for sure that you have ovarian cancer is by having a biopsy of the tissue. A biopsy is done during surgery to remove the tumor. What are the treatments for ovarian cancer? Treatments for ovarian cancer may include:  Surgery to remove as much of the cancer as possible Chemotherapy Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells  Your provider may suggest that you have genetic testing to look for the gene changes that raise the risk for ovarian cancer. Knowing whether or not you have the gene change may help your provider decide on your treatment plan. NIH: National Cancer Institute'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Ovarian cancer', 'candidates': [{'code': 'HP:0100615', 'term': 'Ovarian cancer', 'description': 'What is ovarian cancer? Cancer is a disease in which abnormal cells in the body grow out of control and form a tumor. Ovarian cancer is a cancerous tumor that forms in the tissues of an ovary. The ovaries are a pair of female reproductive glands that make eggs and female hormones. What are the types of ovarian cancer? There are a few different types of ovarian cancer. The most common type is epithelial cancer. It begins in the cells that cover the ovary. There are also two related types of epithelial cancer that can spread to the ovaries:  Fallopian tube cancer forms in the tissue lining a fallopian tube. The fallopian tubes are a pair of long, slender tubes on each side of the uterus. The uterus is the female reproductive organ where a baby grows during pregnancy. Primary peritoneal cancer forms in the tissue lining the peritoneum. Your peritoneum is a tissue lining that covers the organs in the abdomen (belly).  These two cancers are similar to ovarian cancer, and they have the same treatments. So some medical experts also consider those two types as ovarian cancer. Some other rarer types of ovarian cancer are malignant germ cell tumors and stromal tumors. What causes ovarian cancer? Ovarian cancer happens when there are changes (mutations) in the genetic material (DNA). Often, the exact cause of these genetic changes is unknown. Most ovarian cancers are caused by genetic changes that happen during your lifetime. But sometimes these genetic changes are inherited, meaning that you are born with them. Ovarian cancer that is caused by inherited genetic changes is called hereditary ovarian cancer. There are also certain genetic changes that can raise your risk of ovarian cancer, including changes called BRCA1 and BRCA2. These two changes also raise your risk of breast and other cancers. Besides genetics, your lifestyle and the environment can affect your risk of ovarian cancer. Who is more likely to develop ovarian cancer? Certain people are more likely to develop ovarian cancer. They include those who:  Have a family history of ovarian cancer in a mother, daughter, or sister Have inherited changes in the BRCA1 or BRCA2 genes. Have certain other genetic conditions, such as Lynch syndrome Have endometriosis Took hormone replacement therapy Are overweight or have obesity Are tall Are older, especially those who have gone through menopause  What are the symptoms of ovarian cancer? Ovarian cancer may not cause early signs or symptoms. By the time you do have signs or symptoms, the cancer is often advanced. The signs and symptoms may include:  Pain, swelling, or a feeling of pressure in the abdomen or pelvis Sudden or frequent urge to urinate (pee) Trouble eating or feeling full A lump in the pelvic area Gastrointestinal problems, such as gas, bloating, or constipation  How is ovarian cancer diagnosed? To find out if you have ovarian cancer, your health care provider:  Will ask about your medical history, including your symptoms Will ask about your family health history, including relatives who have had ovarian cancer Will do a physical exam, including a pelvic exam Will likely do imaging tests May do blood tests such as a CA-125 blood test  Often the only way to know for sure that you have ovarian cancer is by having a biopsy of the tissue. A biopsy is done during surgery to remove the tumor. What are the treatments for ovarian cancer? Treatments for ovarian cancer may include:  Surgery to remove as much of the cancer as possible Chemotherapy Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells  Your provider may suggest that you have genetic testing to look for the gene changes that raise the risk for ovarian cancer. Knowing whether or not you have the gene change may help your provider decide on your treatment plan. NIH: National Cancer Institute'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Ovarian cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100615\",\n",
      "    \"matched_term\": \"Ovarian cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Ovarian cancer', 'field_type': 'radio', 'extracted_terms': ['Ovarian cancer'], 'umls_mappings': [{'original': 'Ovarian cancer', 'candidates': [{'code': 'HP:0100615', 'term': 'Ovarian cancer', 'description': 'What is ovarian cancer? Cancer is a disease in which abnormal cells in the body grow out of control and form a tumor. Ovarian cancer is a cancerous tumor that forms in the tissues of an ovary. The ovaries are a pair of female reproductive glands that make eggs and female hormones. What are the types of ovarian cancer? There are a few different types of ovarian cancer. The most common type is epithelial cancer. It begins in the cells that cover the ovary. There are also two related types of epithelial cancer that can spread to the ovaries:  Fallopian tube cancer forms in the tissue lining a fallopian tube. The fallopian tubes are a pair of long, slender tubes on each side of the uterus. The uterus is the female reproductive organ where a baby grows during pregnancy. Primary peritoneal cancer forms in the tissue lining the peritoneum. Your peritoneum is a tissue lining that covers the organs in the abdomen (belly).  These two cancers are similar to ovarian cancer, and they have the same treatments. So some medical experts also consider those two types as ovarian cancer. Some other rarer types of ovarian cancer are malignant germ cell tumors and stromal tumors. What causes ovarian cancer? Ovarian cancer happens when there are changes (mutations) in the genetic material (DNA). Often, the exact cause of these genetic changes is unknown. Most ovarian cancers are caused by genetic changes that happen during your lifetime. But sometimes these genetic changes are inherited, meaning that you are born with them. Ovarian cancer that is caused by inherited genetic changes is called hereditary ovarian cancer. There are also certain genetic changes that can raise your risk of ovarian cancer, including changes called BRCA1 and BRCA2. These two changes also raise your risk of breast and other cancers. Besides genetics, your lifestyle and the environment can affect your risk of ovarian cancer. Who is more likely to develop ovarian cancer? Certain people are more likely to develop ovarian cancer. They include those who:  Have a family history of ovarian cancer in a mother, daughter, or sister Have inherited changes in the BRCA1 or BRCA2 genes. Have certain other genetic conditions, such as Lynch syndrome Have endometriosis Took hormone replacement therapy Are overweight or have obesity Are tall Are older, especially those who have gone through menopause  What are the symptoms of ovarian cancer? Ovarian cancer may not cause early signs or symptoms. By the time you do have signs or symptoms, the cancer is often advanced. The signs and symptoms may include:  Pain, swelling, or a feeling of pressure in the abdomen or pelvis Sudden or frequent urge to urinate (pee) Trouble eating or feeling full A lump in the pelvic area Gastrointestinal problems, such as gas, bloating, or constipation  How is ovarian cancer diagnosed? To find out if you have ovarian cancer, your health care provider:  Will ask about your medical history, including your symptoms Will ask about your family health history, including relatives who have had ovarian cancer Will do a physical exam, including a pelvic exam Will likely do imaging tests May do blood tests such as a CA-125 blood test  Often the only way to know for sure that you have ovarian cancer is by having a biopsy of the tissue. A biopsy is done during surgery to remove the tumor. What are the treatments for ovarian cancer? Treatments for ovarian cancer may include:  Surgery to remove as much of the cancer as possible Chemotherapy Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells  Your provider may suggest that you have genetic testing to look for the gene changes that raise the risk for ovarian cancer. Knowing whether or not you have the gene change may help your provider decide on your treatment plan. NIH: National Cancer Institute'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Ovarian cancer', 'ranked_candidates': [{'code': 'HP:0100615', 'term': 'Ovarian cancer', 'description': 'What is ovarian cancer? Cancer is a disease in which abnormal cells in the body grow out of control and form a tumor. Ovarian cancer is a cancerous tumor that forms in the tissues of an ovary. The ovaries are a pair of female reproductive glands that make eggs and female hormones. What are the types of ovarian cancer? There are a few different types of ovarian cancer. The most common type is epithelial cancer. It begins in the cells that cover the ovary. There are also two related types of epithelial cancer that can spread to the ovaries:  Fallopian tube cancer forms in the tissue lining a fallopian tube. The fallopian tubes are a pair of long, slender tubes on each side of the uterus. The uterus is the female reproductive organ where a baby grows during pregnancy. Primary peritoneal cancer forms in the tissue lining the peritoneum. Your peritoneum is a tissue lining that covers the organs in the abdomen (belly).  These two cancers are similar to ovarian cancer, and they have the same treatments. So some medical experts also consider those two types as ovarian cancer. Some other rarer types of ovarian cancer are malignant germ cell tumors and stromal tumors. What causes ovarian cancer? Ovarian cancer happens when there are changes (mutations) in the genetic material (DNA). Often, the exact cause of these genetic changes is unknown. Most ovarian cancers are caused by genetic changes that happen during your lifetime. But sometimes these genetic changes are inherited, meaning that you are born with them. Ovarian cancer that is caused by inherited genetic changes is called hereditary ovarian cancer. There are also certain genetic changes that can raise your risk of ovarian cancer, including changes called BRCA1 and BRCA2. These two changes also raise your risk of breast and other cancers. Besides genetics, your lifestyle and the environment can affect your risk of ovarian cancer. Who is more likely to develop ovarian cancer? Certain people are more likely to develop ovarian cancer. They include those who:  Have a family history of ovarian cancer in a mother, daughter, or sister Have inherited changes in the BRCA1 or BRCA2 genes. Have certain other genetic conditions, such as Lynch syndrome Have endometriosis Took hormone replacement therapy Are overweight or have obesity Are tall Are older, especially those who have gone through menopause  What are the symptoms of ovarian cancer? Ovarian cancer may not cause early signs or symptoms. By the time you do have signs or symptoms, the cancer is often advanced. The signs and symptoms may include:  Pain, swelling, or a feeling of pressure in the abdomen or pelvis Sudden or frequent urge to urinate (pee) Trouble eating or feeling full A lump in the pelvic area Gastrointestinal problems, such as gas, bloating, or constipation  How is ovarian cancer diagnosed? To find out if you have ovarian cancer, your health care provider:  Will ask about your medical history, including your symptoms Will ask about your family health history, including relatives who have had ovarian cancer Will do a physical exam, including a pelvic exam Will likely do imaging tests May do blood tests such as a CA-125 blood test  Often the only way to know for sure that you have ovarian cancer is by having a biopsy of the tissue. A biopsy is done during surgery to remove the tumor. What are the treatments for ovarian cancer? Treatments for ovarian cancer may include:  Surgery to remove as much of the cancer as possible Chemotherapy Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells  Your provider may suggest that you have genetic testing to look for the gene changes that raise the risk for ovarian cancer. Knowing whether or not you have the gene change may help your provider decide on your treatment plan. NIH: National Cancer Institute', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Ovarian cancer': {\n",
      "  \"best_match_code\": \"HP:0100615\",\n",
      "  \"best_match_term\": \"Ovarian cancer\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 30\n",
      "✅ Extracted terms: ['Uterine cancer']\n",
      "🌐 [Uterine cancer] API Status: 200\n",
      "✅ Results for Uterine cancer: [{'code': 'HP:0010784', 'term': 'Uterine cancer', 'description': 'The uterus, or womb, is the place where a baby grows when a women is pregnant. There are different types of uterine cancer. The most common type starts in the endometrium, the lining of the uterus. This type is also called endometrial cancer. The symptoms of uterine cancer include: Abnormal vaginal bleeding or discharge Trouble urinating Pelvic pain Pain during intercourse  Uterine cancer usually happens after menopause. It is more common in women who have obesity. You also have a higher risk if you took estrogen-only hormone replacement therapy (menopausal hormone therapy) for many years. Tests to find uterine cancer include a pelvic exam, imaging tests, and a biopsy. The most common treatment is a hysterectomy, which is surgery to remove the uterus. Sometimes the surgery also removes the ovaries and fallopian tubes. Other treatments include hormone therapy, radiation therapy, and chemotherapy. Some women get more than one type of treatment. NIH: National Cancer Institute'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Uterine cancer', 'candidates': [{'code': 'HP:0010784', 'term': 'Uterine cancer', 'description': 'The uterus, or womb, is the place where a baby grows when a women is pregnant. There are different types of uterine cancer. The most common type starts in the endometrium, the lining of the uterus. This type is also called endometrial cancer. The symptoms of uterine cancer include: Abnormal vaginal bleeding or discharge Trouble urinating Pelvic pain Pain during intercourse  Uterine cancer usually happens after menopause. It is more common in women who have obesity. You also have a higher risk if you took estrogen-only hormone replacement therapy (menopausal hormone therapy) for many years. Tests to find uterine cancer include a pelvic exam, imaging tests, and a biopsy. The most common treatment is a hysterectomy, which is surgery to remove the uterus. Sometimes the surgery also removes the ovaries and fallopian tubes. Other treatments include hormone therapy, radiation therapy, and chemotherapy. Some women get more than one type of treatment. NIH: National Cancer Institute'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Uterine cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010784\",\n",
      "    \"matched_term\": \"Uterine cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Uterine cancer', 'field_type': 'radio', 'extracted_terms': ['Uterine cancer'], 'umls_mappings': [{'original': 'Uterine cancer', 'candidates': [{'code': 'HP:0010784', 'term': 'Uterine cancer', 'description': 'The uterus, or womb, is the place where a baby grows when a women is pregnant. There are different types of uterine cancer. The most common type starts in the endometrium, the lining of the uterus. This type is also called endometrial cancer. The symptoms of uterine cancer include: Abnormal vaginal bleeding or discharge Trouble urinating Pelvic pain Pain during intercourse  Uterine cancer usually happens after menopause. It is more common in women who have obesity. You also have a higher risk if you took estrogen-only hormone replacement therapy (menopausal hormone therapy) for many years. Tests to find uterine cancer include a pelvic exam, imaging tests, and a biopsy. The most common treatment is a hysterectomy, which is surgery to remove the uterus. Sometimes the surgery also removes the ovaries and fallopian tubes. Other treatments include hormone therapy, radiation therapy, and chemotherapy. Some women get more than one type of treatment. NIH: National Cancer Institute'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Uterine cancer', 'ranked_candidates': [{'code': 'HP:0010784', 'term': 'Uterine cancer', 'description': 'The uterus, or womb, is the place where a baby grows when a women is pregnant. There are different types of uterine cancer. The most common type starts in the endometrium, the lining of the uterus. This type is also called endometrial cancer. The symptoms of uterine cancer include: Abnormal vaginal bleeding or discharge Trouble urinating Pelvic pain Pain during intercourse  Uterine cancer usually happens after menopause. It is more common in women who have obesity. You also have a higher risk if you took estrogen-only hormone replacement therapy (menopausal hormone therapy) for many years. Tests to find uterine cancer include a pelvic exam, imaging tests, and a biopsy. The most common treatment is a hysterectomy, which is surgery to remove the uterus. Sometimes the surgery also removes the ovaries and fallopian tubes. Other treatments include hormone therapy, radiation therapy, and chemotherapy. Some women get more than one type of treatment. NIH: National Cancer Institute', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Uterine cancer': {\n",
      "  \"best_match_code\": \"HP:0010784\",\n",
      "  \"best_match_term\": \"Uterine cancer\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 31\n",
      "✅ Extracted terms: ['Cervical cancer']\n",
      "🌐 [Cervical cancer] API Status: 404\n",
      "❌ Failed for term: Cervical cancer\n",
      "🧪 Final UMLS mappings: [{'original': 'Cervical cancer', 'candidates': []}]\n",
      "✅ Revised terms: ['Cervical carcinoma']\n",
      "🌐 [Cervical carcinoma] API Status: 404\n",
      "❌ Failed for term: Cervical carcinoma\n",
      "🧪 Final UMLS mappings: [{'original': 'Cervical carcinoma', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the cervix uteri']\n",
      "🌐 [Neoplasm of the cervix uteri] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the cervix uteri\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the cervix uteri', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the cervix']\n",
      "🌐 [Abnormality of the cervix] API Status: 404\n",
      "❌ Failed for term: Abnormality of the cervix\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the cervix', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the uterus']\n",
      "🌐 [Neoplasm of the uterus] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the uterus\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the uterus', 'candidates': []}]\n",
      "✅ Revised terms: ['Malignant neoplasm of the cervix uteri']\n",
      "🌐 [Malignant neoplasm of the cervix uteri] API Status: 404\n",
      "❌ Failed for term: Malignant neoplasm of the cervix uteri\n",
      "🧪 Final UMLS mappings: [{'original': 'Malignant neoplasm of the cervix uteri', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the female genital tract']\n",
      "🌐 [Neoplasm of the female genital tract] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the female genital tract\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the female genital tract', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the uterine cervix']\n",
      "🌐 [Neoplasm of the uterine cervix] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the uterine cervix\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the uterine cervix', 'candidates': []}]\n",
      "✅ Revised terms: ['Malignant neoplasm of the female genital tract']\n",
      "🌐 [Malignant neoplasm of the female genital tract] API Status: 404\n",
      "❌ Failed for term: Malignant neoplasm of the female genital tract\n",
      "🧪 Final UMLS mappings: [{'original': 'Malignant neoplasm of the female genital tract', 'candidates': []}]\n",
      "✅ Revised terms: ['Carcinoma of the uterine cervix']\n",
      "🌐 [Carcinoma of the uterine cervix] API Status: 404\n",
      "❌ Failed for term: Carcinoma of the uterine cervix\n",
      "🧪 Final UMLS mappings: [{'original': 'Carcinoma of the uterine cervix', 'candidates': []}]\n",
      "✅ Revised terms: ['Malignant neoplasm']\n",
      "✅ Processed row 32\n",
      "✅ Extracted terms: ['Prostate cancer']\n",
      "🌐 [Prostate cancer] API Status: 200\n",
      "✅ Results for Prostate cancer: [{'code': 'HP:0012125', 'term': 'Prostate cancer', 'description': \"What is prostate cancer? Cancer is a disease in which cells in the body grow out of control. Prostate cancer begins in the cells of the prostate. The prostate is a gland in the male reproductive system. It lies just below the bladder. It makes fluid that is part of semen. Prostate cancer is one of the most common types of cancer. It often grows very slowly. If it does not spread to other parts of the body, it may not cause serious problems. But sometimes prostate cancer can grow quickly and spread to other parts of the body. This kind of prostate cancer is serious. What causes prostate cancer? Researchers don't know for sure what causes prostate cancer. They do know that it happens when there are changes in the genetic material (DNA). Sometimes these genetic changes are inherited, meaning that you are born with them. There are also certain genetic changes that happen during your lifetime that can raise your risk of prostate cancer. But often the exact cause of these genetic changes is unknown. Who is more likely to develop prostate cancer? Anyone who has a prostate can develop prostate cancer. But certain factors can make you more likely to develop it:  Age. Your chance of developing prostate cancer increases as you get older. Prostate cancer is rare in people under age 50. Family health history. Your risk of prostate cancer is higher if you have a parent, sibling, or child who has or has had prostate cancer. Race. African Americans are more likely to get prostate cancer. They're also more likely to:  Get prostate cancer at a younger age. Have more serious prostate cancer. Die from prostate cancer.    What are the symptoms of prostate cancer? Prostate cancer doesn't always cause symptoms, especially at first. If it does cause symptoms, they may include:  Problems urinating (peeing), such as:  A urine stream that's weak, hard to start, or starts and stops Suddenly needing to urinate right away Urinating often, especially at night Pain or burning when urinating Blood in your urine or semen   Pain in your lower back, hips, or pelvis that does not go away Painful ejaculation (the release of semen through the penis during orgasm)  But many of these symptoms may be from other common prostate problems that aren't cancer, such as an enlarged prostate. You should discuss your prostate health with your health care provider if you:  Have symptoms that could be prostate cancer Have a high risk for developing prostate cancer Had a screening test that suggests you could have prostate cancer  What are prostate tests and how is prostate cancer diagnosed? Tests which check for prostate cancer include:  A digital rectal exam (DRE). In this exam, your provider feels your prostate for lumps or anything unusual by inserting a lubricated, gloved finger into your rectum. A prostate-specific antigen (PSA) blood test. A high PSA blood level may be a sign of prostate cancer. But many other things can cause high PSA levels, too. Imaging tests. These tests may use ultrasound or MRI to make pictures of your prostate.  If these tests show that you might have prostate cancer, the next step is usually a prostate biopsy. A biopsy is the only way to diagnose prostate cancer. During a biopsy, a doctor uses a hollow needle to remove some prostate tissue. The tissue is studied under a microscope to look for cancer cells. What are the treatments for prostate cancer? Your treatment options usually depend on your age, your general health, and how serious the cancer is. Your treatment may include one or more of options:  Observation,which is mostly used if you are older, your prostate cancer isn't likely to grow quickly, and you don't have symptoms or you have other medical conditions. Your doctor will keep checking on your cancer over time so to see whether you will need to start treatment for the cancer. There are two types of observation:  Watchful waiting means having little or no testing. If symptoms begin or change, you will get treatment to relieve them, but not to treat the cancer. Active surveillance means having regular tests to see if your prostate cancer has changed. If the tests show the cancer is starting to grow or if you develop symptoms, then you will have treatment to try to cure the cancer.   Surgery to remove your prostate gland may be an option if your cancer hasn't spread outside of your prostate. Radiation therapy uses high energy to kill cancer cells or prevent them from growing. Hormone therapy blocks cancer cells from getting the hormones they need to grow. It may include taking medicines or having surgery to remove the testicles. Chemotherapy uses medicines to kill cancer cells, slow their growth, or stop them from spreading. You might take the drugs by mouth, as an injection (shot), as a cream, or intravenously (by IV). Targeted therapy uses drugs or other substances that attack specific cancer cells. This treatment causes less harm to healthy cells than radiation therapy or chemotherapy. Immunotherapy helps your own immune system to fight cancer.  Can prostate cancer be prevented? Making healthy lifestyle changes may help to prevent some prostate cancers. These changes include:  Being at a healthy weight Quitting smoking Getting enough exercise Eating healthy foods  NIH: National Cancer Institute\"}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Prostate cancer', 'candidates': [{'code': 'HP:0012125', 'term': 'Prostate cancer', 'description': \"What is prostate cancer? Cancer is a disease in which cells in the body grow out of control. Prostate cancer begins in the cells of the prostate. The prostate is a gland in the male reproductive system. It lies just below the bladder. It makes fluid that is part of semen. Prostate cancer is one of the most common types of cancer. It often grows very slowly. If it does not spread to other parts of the body, it may not cause serious problems. But sometimes prostate cancer can grow quickly and spread to other parts of the body. This kind of prostate cancer is serious. What causes prostate cancer? Researchers don't know for sure what causes prostate cancer. They do know that it happens when there are changes in the genetic material (DNA). Sometimes these genetic changes are inherited, meaning that you are born with them. There are also certain genetic changes that happen during your lifetime that can raise your risk of prostate cancer. But often the exact cause of these genetic changes is unknown. Who is more likely to develop prostate cancer? Anyone who has a prostate can develop prostate cancer. But certain factors can make you more likely to develop it:  Age. Your chance of developing prostate cancer increases as you get older. Prostate cancer is rare in people under age 50. Family health history. Your risk of prostate cancer is higher if you have a parent, sibling, or child who has or has had prostate cancer. Race. African Americans are more likely to get prostate cancer. They're also more likely to:  Get prostate cancer at a younger age. Have more serious prostate cancer. Die from prostate cancer.    What are the symptoms of prostate cancer? Prostate cancer doesn't always cause symptoms, especially at first. If it does cause symptoms, they may include:  Problems urinating (peeing), such as:  A urine stream that's weak, hard to start, or starts and stops Suddenly needing to urinate right away Urinating often, especially at night Pain or burning when urinating Blood in your urine or semen   Pain in your lower back, hips, or pelvis that does not go away Painful ejaculation (the release of semen through the penis during orgasm)  But many of these symptoms may be from other common prostate problems that aren't cancer, such as an enlarged prostate. You should discuss your prostate health with your health care provider if you:  Have symptoms that could be prostate cancer Have a high risk for developing prostate cancer Had a screening test that suggests you could have prostate cancer  What are prostate tests and how is prostate cancer diagnosed? Tests which check for prostate cancer include:  A digital rectal exam (DRE). In this exam, your provider feels your prostate for lumps or anything unusual by inserting a lubricated, gloved finger into your rectum. A prostate-specific antigen (PSA) blood test. A high PSA blood level may be a sign of prostate cancer. But many other things can cause high PSA levels, too. Imaging tests. These tests may use ultrasound or MRI to make pictures of your prostate.  If these tests show that you might have prostate cancer, the next step is usually a prostate biopsy. A biopsy is the only way to diagnose prostate cancer. During a biopsy, a doctor uses a hollow needle to remove some prostate tissue. The tissue is studied under a microscope to look for cancer cells. What are the treatments for prostate cancer? Your treatment options usually depend on your age, your general health, and how serious the cancer is. Your treatment may include one or more of options:  Observation,which is mostly used if you are older, your prostate cancer isn't likely to grow quickly, and you don't have symptoms or you have other medical conditions. Your doctor will keep checking on your cancer over time so to see whether you will need to start treatment for the cancer. There are two types of observation:  Watchful waiting means having little or no testing. If symptoms begin or change, you will get treatment to relieve them, but not to treat the cancer. Active surveillance means having regular tests to see if your prostate cancer has changed. If the tests show the cancer is starting to grow or if you develop symptoms, then you will have treatment to try to cure the cancer.   Surgery to remove your prostate gland may be an option if your cancer hasn't spread outside of your prostate. Radiation therapy uses high energy to kill cancer cells or prevent them from growing. Hormone therapy blocks cancer cells from getting the hormones they need to grow. It may include taking medicines or having surgery to remove the testicles. Chemotherapy uses medicines to kill cancer cells, slow their growth, or stop them from spreading. You might take the drugs by mouth, as an injection (shot), as a cream, or intravenously (by IV). Targeted therapy uses drugs or other substances that attack specific cancer cells. This treatment causes less harm to healthy cells than radiation therapy or chemotherapy. Immunotherapy helps your own immune system to fight cancer.  Can prostate cancer be prevented? Making healthy lifestyle changes may help to prevent some prostate cancers. These changes include:  Being at a healthy weight Quitting smoking Getting enough exercise Eating healthy foods  NIH: National Cancer Institute\"}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Prostate cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012125\",\n",
      "    \"matched_term\": \"Prostate cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Prostate cancer', 'field_type': 'radio', 'extracted_terms': ['Prostate cancer'], 'umls_mappings': [{'original': 'Prostate cancer', 'candidates': [{'code': 'HP:0012125', 'term': 'Prostate cancer', 'description': \"What is prostate cancer? Cancer is a disease in which cells in the body grow out of control. Prostate cancer begins in the cells of the prostate. The prostate is a gland in the male reproductive system. It lies just below the bladder. It makes fluid that is part of semen. Prostate cancer is one of the most common types of cancer. It often grows very slowly. If it does not spread to other parts of the body, it may not cause serious problems. But sometimes prostate cancer can grow quickly and spread to other parts of the body. This kind of prostate cancer is serious. What causes prostate cancer? Researchers don't know for sure what causes prostate cancer. They do know that it happens when there are changes in the genetic material (DNA). Sometimes these genetic changes are inherited, meaning that you are born with them. There are also certain genetic changes that happen during your lifetime that can raise your risk of prostate cancer. But often the exact cause of these genetic changes is unknown. Who is more likely to develop prostate cancer? Anyone who has a prostate can develop prostate cancer. But certain factors can make you more likely to develop it:  Age. Your chance of developing prostate cancer increases as you get older. Prostate cancer is rare in people under age 50. Family health history. Your risk of prostate cancer is higher if you have a parent, sibling, or child who has or has had prostate cancer. Race. African Americans are more likely to get prostate cancer. They're also more likely to:  Get prostate cancer at a younger age. Have more serious prostate cancer. Die from prostate cancer.    What are the symptoms of prostate cancer? Prostate cancer doesn't always cause symptoms, especially at first. If it does cause symptoms, they may include:  Problems urinating (peeing), such as:  A urine stream that's weak, hard to start, or starts and stops Suddenly needing to urinate right away Urinating often, especially at night Pain or burning when urinating Blood in your urine or semen   Pain in your lower back, hips, or pelvis that does not go away Painful ejaculation (the release of semen through the penis during orgasm)  But many of these symptoms may be from other common prostate problems that aren't cancer, such as an enlarged prostate. You should discuss your prostate health with your health care provider if you:  Have symptoms that could be prostate cancer Have a high risk for developing prostate cancer Had a screening test that suggests you could have prostate cancer  What are prostate tests and how is prostate cancer diagnosed? Tests which check for prostate cancer include:  A digital rectal exam (DRE). In this exam, your provider feels your prostate for lumps or anything unusual by inserting a lubricated, gloved finger into your rectum. A prostate-specific antigen (PSA) blood test. A high PSA blood level may be a sign of prostate cancer. But many other things can cause high PSA levels, too. Imaging tests. These tests may use ultrasound or MRI to make pictures of your prostate.  If these tests show that you might have prostate cancer, the next step is usually a prostate biopsy. A biopsy is the only way to diagnose prostate cancer. During a biopsy, a doctor uses a hollow needle to remove some prostate tissue. The tissue is studied under a microscope to look for cancer cells. What are the treatments for prostate cancer? Your treatment options usually depend on your age, your general health, and how serious the cancer is. Your treatment may include one or more of options:  Observation,which is mostly used if you are older, your prostate cancer isn't likely to grow quickly, and you don't have symptoms or you have other medical conditions. Your doctor will keep checking on your cancer over time so to see whether you will need to start treatment for the cancer. There are two types of observation:  Watchful waiting means having little or no testing. If symptoms begin or change, you will get treatment to relieve them, but not to treat the cancer. Active surveillance means having regular tests to see if your prostate cancer has changed. If the tests show the cancer is starting to grow or if you develop symptoms, then you will have treatment to try to cure the cancer.   Surgery to remove your prostate gland may be an option if your cancer hasn't spread outside of your prostate. Radiation therapy uses high energy to kill cancer cells or prevent them from growing. Hormone therapy blocks cancer cells from getting the hormones they need to grow. It may include taking medicines or having surgery to remove the testicles. Chemotherapy uses medicines to kill cancer cells, slow their growth, or stop them from spreading. You might take the drugs by mouth, as an injection (shot), as a cream, or intravenously (by IV). Targeted therapy uses drugs or other substances that attack specific cancer cells. This treatment causes less harm to healthy cells than radiation therapy or chemotherapy. Immunotherapy helps your own immune system to fight cancer.  Can prostate cancer be prevented? Making healthy lifestyle changes may help to prevent some prostate cancers. These changes include:  Being at a healthy weight Quitting smoking Getting enough exercise Eating healthy foods  NIH: National Cancer Institute\"}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Prostate cancer', 'ranked_candidates': [{'code': 'HP:0012125', 'term': 'Prostate cancer', 'description': \"What is prostate cancer? Cancer is a disease in which cells in the body grow out of control. Prostate cancer begins in the cells of the prostate. The prostate is a gland in the male reproductive system. It lies just below the bladder. It makes fluid that is part of semen. Prostate cancer is one of the most common types of cancer. It often grows very slowly. If it does not spread to other parts of the body, it may not cause serious problems. But sometimes prostate cancer can grow quickly and spread to other parts of the body. This kind of prostate cancer is serious. What causes prostate cancer? Researchers don't know for sure what causes prostate cancer. They do know that it happens when there are changes in the genetic material (DNA). Sometimes these genetic changes are inherited, meaning that you are born with them. There are also certain genetic changes that happen during your lifetime that can raise your risk of prostate cancer. But often the exact cause of these genetic changes is unknown. Who is more likely to develop prostate cancer? Anyone who has a prostate can develop prostate cancer. But certain factors can make you more likely to develop it:  Age. Your chance of developing prostate cancer increases as you get older. Prostate cancer is rare in people under age 50. Family health history. Your risk of prostate cancer is higher if you have a parent, sibling, or child who has or has had prostate cancer. Race. African Americans are more likely to get prostate cancer. They're also more likely to:  Get prostate cancer at a younger age. Have more serious prostate cancer. Die from prostate cancer.    What are the symptoms of prostate cancer? Prostate cancer doesn't always cause symptoms, especially at first. If it does cause symptoms, they may include:  Problems urinating (peeing), such as:  A urine stream that's weak, hard to start, or starts and stops Suddenly needing to urinate right away Urinating often, especially at night Pain or burning when urinating Blood in your urine or semen   Pain in your lower back, hips, or pelvis that does not go away Painful ejaculation (the release of semen through the penis during orgasm)  But many of these symptoms may be from other common prostate problems that aren't cancer, such as an enlarged prostate. You should discuss your prostate health with your health care provider if you:  Have symptoms that could be prostate cancer Have a high risk for developing prostate cancer Had a screening test that suggests you could have prostate cancer  What are prostate tests and how is prostate cancer diagnosed? Tests which check for prostate cancer include:  A digital rectal exam (DRE). In this exam, your provider feels your prostate for lumps or anything unusual by inserting a lubricated, gloved finger into your rectum. A prostate-specific antigen (PSA) blood test. A high PSA blood level may be a sign of prostate cancer. But many other things can cause high PSA levels, too. Imaging tests. These tests may use ultrasound or MRI to make pictures of your prostate.  If these tests show that you might have prostate cancer, the next step is usually a prostate biopsy. A biopsy is the only way to diagnose prostate cancer. During a biopsy, a doctor uses a hollow needle to remove some prostate tissue. The tissue is studied under a microscope to look for cancer cells. What are the treatments for prostate cancer? Your treatment options usually depend on your age, your general health, and how serious the cancer is. Your treatment may include one or more of options:  Observation,which is mostly used if you are older, your prostate cancer isn't likely to grow quickly, and you don't have symptoms or you have other medical conditions. Your doctor will keep checking on your cancer over time so to see whether you will need to start treatment for the cancer. There are two types of observation:  Watchful waiting means having little or no testing. If symptoms begin or change, you will get treatment to relieve them, but not to treat the cancer. Active surveillance means having regular tests to see if your prostate cancer has changed. If the tests show the cancer is starting to grow or if you develop symptoms, then you will have treatment to try to cure the cancer.   Surgery to remove your prostate gland may be an option if your cancer hasn't spread outside of your prostate. Radiation therapy uses high energy to kill cancer cells or prevent them from growing. Hormone therapy blocks cancer cells from getting the hormones they need to grow. It may include taking medicines or having surgery to remove the testicles. Chemotherapy uses medicines to kill cancer cells, slow their growth, or stop them from spreading. You might take the drugs by mouth, as an injection (shot), as a cream, or intravenously (by IV). Targeted therapy uses drugs or other substances that attack specific cancer cells. This treatment causes less harm to healthy cells than radiation therapy or chemotherapy. Immunotherapy helps your own immune system to fight cancer.  Can prostate cancer be prevented? Making healthy lifestyle changes may help to prevent some prostate cancers. These changes include:  Being at a healthy weight Quitting smoking Getting enough exercise Eating healthy foods  NIH: National Cancer Institute\", 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Prostate cancer': {\n",
      "  \"best_match_code\": \"HP:0012125\",\n",
      "  \"best_match_term\": \"Prostate cancer\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 33\n",
      "✅ Extracted terms: ['Lung cancer']\n",
      "🌐 [Lung cancer] API Status: 200\n",
      "✅ Results for Lung cancer: [{'code': 'HP:0100526', 'term': 'Lung cancer', 'description': \"What is lung cancer? Lung cancer is cancer that forms in tissues of the lung, usually in the cells that line the air passages. It is the leading cause of cancer death in both men and women. There are two main types: small cell lung cancer and non-small cell lung cancer. These two types grow differently and are treated differently. Non-small cell lung cancer is the more common type. Who more likely to develop lung cancer? Anyone can develop lung cancer, but certain factors raise your risk of getting it: Smoking. This is the most important risk factor for lung cancer. Tobacco smoking causes about 9 out of 10 cases of lung cancer in men and about 8 out of 10 cases of lung cancer in women. The more years you smoke and the more cigarettes you smoke each day, the more your risk goes up. Your risk is also greater if you smoke a lot and drink alcohol every day or take beta carotene supplements. If you have quit smoking, your risk will be lower than if you had kept smoking. But you will still have a higher risk than people who never smoked. Secondhand smoke, which is the combination of the smoke that comes from a cigarette and the smoke breathed out by a smoker. When you breathe in secondhand smoke, you are exposed to the same cancer-causing agents as smokers, although in smaller amounts. A family history of lung cancer. Being exposed to asbestos, arsenic, chromium, beryllium, nickel, soot, or tar in the workplace. Being exposed to radiation, for example from:  Radiation therapy to the breast or chest Radon in the home or workplace Certain imaging tests such as CT scans   HIV infection. Your risk is higher if you have HIV. However, smoking rates are higher in people who have HIV, so it's not clear whether the increased risk is from the HIV infection or from smoking. Air pollution. Studies show that living in areas with higher levels of air pollution increases your risk of lung cancer.  What are the symptoms of lung cancer? Lung cancer may not cause any signs or symptoms until the cancer is advanced. Sometimes the cancer is found during a chest x-ray done for another condition. The symptoms of lung cancer may include: Chest pain or discomfort A cough that doesn't go away or gets worse over time Coughing up blood Trouble breathing Wheezing Hoarseness Loss of appetite Weight loss for no known reason Feeling very tired Trouble swallowing Swelling in the face and/or veins in the neck  How is lung cancer diagnosed? To find out if you have lung cancer, your health care provider: Will take your medical history, which includes asking about your symptoms Will ask about your family history Will do a physical exam May order certain imaging tests, such as a chest x-ray or chest CT scan May order lab tests, including tests of your blood and sputum May do a procedure to take a biopsy of the lung  If you do have lung cancer, your provider will do other tests to find out if it has spread through the lungs, lymph nodes, and the rest of the body. This is called staging. Knowing the type and stage of lung cancer you have helps your provider decide what kind of treatment you need. If you have small-cell lung cancer, your provider may also do genetic testing to look for certain gene changes (variants) in your cancer cells. The results of the testing may help guide treatment. What are the treatments for lung cancer? For most patients with lung cancer, current treatments do not cure the cancer. Your treatment will depend on which type of lung cancer you have, how far it has spread, your overall health, and other factors. You may get more than one type of treatment. The treatments for small cell lung cancer may include: Surgery. Chemotherapy. Radiation therapy. Immunotherapy. Laser therapy, which uses a laser beam to kill cancer cells. Endoscopic stent placement. An endoscope is a thin, tube-like instrument used to look at tissues inside the body. It may be used to put in a device called a stent. The stent helps to open an airway that has been blocked by abnormal tissue.  The treatments for non-small cell lung cancer may include: Surgery. Radiation therapy. Chemotherapy. Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells. Immunotherapy. Laser therapy. Photodynamic therapy (PDT), which uses a medicine and a certain type of laser light to kill cancer cells. Cryosurgery, which uses an instrument to freeze and destroy abnormal tissue. Electrocautery, a treatment that uses a probe or needle heated by an electric current to destroy abnormal tissue.  Can lung cancer be prevented? Avoiding the risk factors may help prevent lung cancer. For example, you can: Quit smoking. And if you don't smoke, don't start. Lower your exposure to hazardous substances at work. Lower your exposure to radon. Radon tests can show whether your home has high levels of radon. You can buy a test kit yourself or hire a professional to do the test.  NIH: National Cancer Institute\"}, {'code': 'HP:0030358', 'term': 'Non-small cell lung cancer', 'description': 'A heterogeneous aggregate of at least three distinct histological types of lung cancer, including SQUAMOUS CELL CARCINOMA; ADENOCARCINOMA; and LARGE CELL CARCINOMA. They are dealt with collectively because of their shared treatment strategy.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Lung cancer', 'candidates': [{'code': 'HP:0100526', 'term': 'Lung cancer', 'description': \"What is lung cancer? Lung cancer is cancer that forms in tissues of the lung, usually in the cells that line the air passages. It is the leading cause of cancer death in both men and women. There are two main types: small cell lung cancer and non-small cell lung cancer. These two types grow differently and are treated differently. Non-small cell lung cancer is the more common type. Who more likely to develop lung cancer? Anyone can develop lung cancer, but certain factors raise your risk of getting it: Smoking. This is the most important risk factor for lung cancer. Tobacco smoking causes about 9 out of 10 cases of lung cancer in men and about 8 out of 10 cases of lung cancer in women. The more years you smoke and the more cigarettes you smoke each day, the more your risk goes up. Your risk is also greater if you smoke a lot and drink alcohol every day or take beta carotene supplements. If you have quit smoking, your risk will be lower than if you had kept smoking. But you will still have a higher risk than people who never smoked. Secondhand smoke, which is the combination of the smoke that comes from a cigarette and the smoke breathed out by a smoker. When you breathe in secondhand smoke, you are exposed to the same cancer-causing agents as smokers, although in smaller amounts. A family history of lung cancer. Being exposed to asbestos, arsenic, chromium, beryllium, nickel, soot, or tar in the workplace. Being exposed to radiation, for example from:  Radiation therapy to the breast or chest Radon in the home or workplace Certain imaging tests such as CT scans   HIV infection. Your risk is higher if you have HIV. However, smoking rates are higher in people who have HIV, so it's not clear whether the increased risk is from the HIV infection or from smoking. Air pollution. Studies show that living in areas with higher levels of air pollution increases your risk of lung cancer.  What are the symptoms of lung cancer? Lung cancer may not cause any signs or symptoms until the cancer is advanced. Sometimes the cancer is found during a chest x-ray done for another condition. The symptoms of lung cancer may include: Chest pain or discomfort A cough that doesn't go away or gets worse over time Coughing up blood Trouble breathing Wheezing Hoarseness Loss of appetite Weight loss for no known reason Feeling very tired Trouble swallowing Swelling in the face and/or veins in the neck  How is lung cancer diagnosed? To find out if you have lung cancer, your health care provider: Will take your medical history, which includes asking about your symptoms Will ask about your family history Will do a physical exam May order certain imaging tests, such as a chest x-ray or chest CT scan May order lab tests, including tests of your blood and sputum May do a procedure to take a biopsy of the lung  If you do have lung cancer, your provider will do other tests to find out if it has spread through the lungs, lymph nodes, and the rest of the body. This is called staging. Knowing the type and stage of lung cancer you have helps your provider decide what kind of treatment you need. If you have small-cell lung cancer, your provider may also do genetic testing to look for certain gene changes (variants) in your cancer cells. The results of the testing may help guide treatment. What are the treatments for lung cancer? For most patients with lung cancer, current treatments do not cure the cancer. Your treatment will depend on which type of lung cancer you have, how far it has spread, your overall health, and other factors. You may get more than one type of treatment. The treatments for small cell lung cancer may include: Surgery. Chemotherapy. Radiation therapy. Immunotherapy. Laser therapy, which uses a laser beam to kill cancer cells. Endoscopic stent placement. An endoscope is a thin, tube-like instrument used to look at tissues inside the body. It may be used to put in a device called a stent. The stent helps to open an airway that has been blocked by abnormal tissue.  The treatments for non-small cell lung cancer may include: Surgery. Radiation therapy. Chemotherapy. Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells. Immunotherapy. Laser therapy. Photodynamic therapy (PDT), which uses a medicine and a certain type of laser light to kill cancer cells. Cryosurgery, which uses an instrument to freeze and destroy abnormal tissue. Electrocautery, a treatment that uses a probe or needle heated by an electric current to destroy abnormal tissue.  Can lung cancer be prevented? Avoiding the risk factors may help prevent lung cancer. For example, you can: Quit smoking. And if you don't smoke, don't start. Lower your exposure to hazardous substances at work. Lower your exposure to radon. Radon tests can show whether your home has high levels of radon. You can buy a test kit yourself or hire a professional to do the test.  NIH: National Cancer Institute\"}, {'code': 'HP:0030358', 'term': 'Non-small cell lung cancer', 'description': 'A heterogeneous aggregate of at least three distinct histological types of lung cancer, including SQUAMOUS CELL CARCINOMA; ADENOCARCINOMA; and LARGE CELL CARCINOMA. They are dealt with collectively because of their shared treatment strategy.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Lung cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100526\",\n",
      "    \"matched_term\": \"Lung cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0030358\",\n",
      "    \"matched_term\": \"Non-small cell lung cancer\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Lung cancer', 'field_type': 'radio', 'extracted_terms': ['Lung cancer'], 'umls_mappings': [{'original': 'Lung cancer', 'candidates': [{'code': 'HP:0100526', 'term': 'Lung cancer', 'description': \"What is lung cancer? Lung cancer is cancer that forms in tissues of the lung, usually in the cells that line the air passages. It is the leading cause of cancer death in both men and women. There are two main types: small cell lung cancer and non-small cell lung cancer. These two types grow differently and are treated differently. Non-small cell lung cancer is the more common type. Who more likely to develop lung cancer? Anyone can develop lung cancer, but certain factors raise your risk of getting it: Smoking. This is the most important risk factor for lung cancer. Tobacco smoking causes about 9 out of 10 cases of lung cancer in men and about 8 out of 10 cases of lung cancer in women. The more years you smoke and the more cigarettes you smoke each day, the more your risk goes up. Your risk is also greater if you smoke a lot and drink alcohol every day or take beta carotene supplements. If you have quit smoking, your risk will be lower than if you had kept smoking. But you will still have a higher risk than people who never smoked. Secondhand smoke, which is the combination of the smoke that comes from a cigarette and the smoke breathed out by a smoker. When you breathe in secondhand smoke, you are exposed to the same cancer-causing agents as smokers, although in smaller amounts. A family history of lung cancer. Being exposed to asbestos, arsenic, chromium, beryllium, nickel, soot, or tar in the workplace. Being exposed to radiation, for example from:  Radiation therapy to the breast or chest Radon in the home or workplace Certain imaging tests such as CT scans   HIV infection. Your risk is higher if you have HIV. However, smoking rates are higher in people who have HIV, so it's not clear whether the increased risk is from the HIV infection or from smoking. Air pollution. Studies show that living in areas with higher levels of air pollution increases your risk of lung cancer.  What are the symptoms of lung cancer? Lung cancer may not cause any signs or symptoms until the cancer is advanced. Sometimes the cancer is found during a chest x-ray done for another condition. The symptoms of lung cancer may include: Chest pain or discomfort A cough that doesn't go away or gets worse over time Coughing up blood Trouble breathing Wheezing Hoarseness Loss of appetite Weight loss for no known reason Feeling very tired Trouble swallowing Swelling in the face and/or veins in the neck  How is lung cancer diagnosed? To find out if you have lung cancer, your health care provider: Will take your medical history, which includes asking about your symptoms Will ask about your family history Will do a physical exam May order certain imaging tests, such as a chest x-ray or chest CT scan May order lab tests, including tests of your blood and sputum May do a procedure to take a biopsy of the lung  If you do have lung cancer, your provider will do other tests to find out if it has spread through the lungs, lymph nodes, and the rest of the body. This is called staging. Knowing the type and stage of lung cancer you have helps your provider decide what kind of treatment you need. If you have small-cell lung cancer, your provider may also do genetic testing to look for certain gene changes (variants) in your cancer cells. The results of the testing may help guide treatment. What are the treatments for lung cancer? For most patients with lung cancer, current treatments do not cure the cancer. Your treatment will depend on which type of lung cancer you have, how far it has spread, your overall health, and other factors. You may get more than one type of treatment. The treatments for small cell lung cancer may include: Surgery. Chemotherapy. Radiation therapy. Immunotherapy. Laser therapy, which uses a laser beam to kill cancer cells. Endoscopic stent placement. An endoscope is a thin, tube-like instrument used to look at tissues inside the body. It may be used to put in a device called a stent. The stent helps to open an airway that has been blocked by abnormal tissue.  The treatments for non-small cell lung cancer may include: Surgery. Radiation therapy. Chemotherapy. Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells. Immunotherapy. Laser therapy. Photodynamic therapy (PDT), which uses a medicine and a certain type of laser light to kill cancer cells. Cryosurgery, which uses an instrument to freeze and destroy abnormal tissue. Electrocautery, a treatment that uses a probe or needle heated by an electric current to destroy abnormal tissue.  Can lung cancer be prevented? Avoiding the risk factors may help prevent lung cancer. For example, you can: Quit smoking. And if you don't smoke, don't start. Lower your exposure to hazardous substances at work. Lower your exposure to radon. Radon tests can show whether your home has high levels of radon. You can buy a test kit yourself or hire a professional to do the test.  NIH: National Cancer Institute\"}, {'code': 'HP:0030358', 'term': 'Non-small cell lung cancer', 'description': 'A heterogeneous aggregate of at least three distinct histological types of lung cancer, including SQUAMOUS CELL CARCINOMA; ADENOCARCINOMA; and LARGE CELL CARCINOMA. They are dealt with collectively because of their shared treatment strategy.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Lung cancer', 'ranked_candidates': [{'code': 'HP:0100526', 'term': 'Lung cancer', 'description': \"What is lung cancer? Lung cancer is cancer that forms in tissues of the lung, usually in the cells that line the air passages. It is the leading cause of cancer death in both men and women. There are two main types: small cell lung cancer and non-small cell lung cancer. These two types grow differently and are treated differently. Non-small cell lung cancer is the more common type. Who more likely to develop lung cancer? Anyone can develop lung cancer, but certain factors raise your risk of getting it: Smoking. This is the most important risk factor for lung cancer. Tobacco smoking causes about 9 out of 10 cases of lung cancer in men and about 8 out of 10 cases of lung cancer in women. The more years you smoke and the more cigarettes you smoke each day, the more your risk goes up. Your risk is also greater if you smoke a lot and drink alcohol every day or take beta carotene supplements. If you have quit smoking, your risk will be lower than if you had kept smoking. But you will still have a higher risk than people who never smoked. Secondhand smoke, which is the combination of the smoke that comes from a cigarette and the smoke breathed out by a smoker. When you breathe in secondhand smoke, you are exposed to the same cancer-causing agents as smokers, although in smaller amounts. A family history of lung cancer. Being exposed to asbestos, arsenic, chromium, beryllium, nickel, soot, or tar in the workplace. Being exposed to radiation, for example from:  Radiation therapy to the breast or chest Radon in the home or workplace Certain imaging tests such as CT scans   HIV infection. Your risk is higher if you have HIV. However, smoking rates are higher in people who have HIV, so it's not clear whether the increased risk is from the HIV infection or from smoking. Air pollution. Studies show that living in areas with higher levels of air pollution increases your risk of lung cancer.  What are the symptoms of lung cancer? Lung cancer may not cause any signs or symptoms until the cancer is advanced. Sometimes the cancer is found during a chest x-ray done for another condition. The symptoms of lung cancer may include: Chest pain or discomfort A cough that doesn't go away or gets worse over time Coughing up blood Trouble breathing Wheezing Hoarseness Loss of appetite Weight loss for no known reason Feeling very tired Trouble swallowing Swelling in the face and/or veins in the neck  How is lung cancer diagnosed? To find out if you have lung cancer, your health care provider: Will take your medical history, which includes asking about your symptoms Will ask about your family history Will do a physical exam May order certain imaging tests, such as a chest x-ray or chest CT scan May order lab tests, including tests of your blood and sputum May do a procedure to take a biopsy of the lung  If you do have lung cancer, your provider will do other tests to find out if it has spread through the lungs, lymph nodes, and the rest of the body. This is called staging. Knowing the type and stage of lung cancer you have helps your provider decide what kind of treatment you need. If you have small-cell lung cancer, your provider may also do genetic testing to look for certain gene changes (variants) in your cancer cells. The results of the testing may help guide treatment. What are the treatments for lung cancer? For most patients with lung cancer, current treatments do not cure the cancer. Your treatment will depend on which type of lung cancer you have, how far it has spread, your overall health, and other factors. You may get more than one type of treatment. The treatments for small cell lung cancer may include: Surgery. Chemotherapy. Radiation therapy. Immunotherapy. Laser therapy, which uses a laser beam to kill cancer cells. Endoscopic stent placement. An endoscope is a thin, tube-like instrument used to look at tissues inside the body. It may be used to put in a device called a stent. The stent helps to open an airway that has been blocked by abnormal tissue.  The treatments for non-small cell lung cancer may include: Surgery. Radiation therapy. Chemotherapy. Targeted therapy, which uses drugs or other substances that attack specific cancer cells with less harm to normal cells. Immunotherapy. Laser therapy. Photodynamic therapy (PDT), which uses a medicine and a certain type of laser light to kill cancer cells. Cryosurgery, which uses an instrument to freeze and destroy abnormal tissue. Electrocautery, a treatment that uses a probe or needle heated by an electric current to destroy abnormal tissue.  Can lung cancer be prevented? Avoiding the risk factors may help prevent lung cancer. For example, you can: Quit smoking. And if you don't smoke, don't start. Lower your exposure to hazardous substances at work. Lower your exposure to radon. Radon tests can show whether your home has high levels of radon. You can buy a test kit yourself or hire a professional to do the test.  NIH: National Cancer Institute\", 'confidence': 1.0}, {'code': 'HP:0030358', 'term': 'Non-small cell lung cancer', 'description': 'A heterogeneous aggregate of at least three distinct histological types of lung cancer, including SQUAMOUS CELL CARCINOMA; ADENOCARCINOMA; and LARGE CELL CARCINOMA. They are dealt with collectively because of their shared treatment strategy.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Lung cancer': {\n",
      "  \"best_match_code\": \"HP:0100526\",\n",
      "  \"best_match_term\": \"Lung cancer\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 34\n",
      "✅ Extracted terms: ['Abnormality of the large intestine']\n",
      "🌐 [Abnormality of the large intestine] API Status: 200\n",
      "✅ Results for Abnormality of the large intestine: [{'code': 'HP:0002250', 'term': 'Abnormality of the large intestine', 'description': 'Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the large intestine', 'candidates': [{'code': 'HP:0002250', 'term': 'Abnormality of the large intestine', 'description': 'Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the large intestine': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002250\",\n",
      "    \"matched_term\": \"Abnormality of the large intestine\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Colon and rectum (including polyps)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the large intestine'], 'umls_mappings': [{'original': 'Abnormality of the large intestine', 'candidates': [{'code': 'HP:0002250', 'term': 'Abnormality of the large intestine', 'description': 'Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the large intestine', 'ranked_candidates': [{'code': 'HP:0002250', 'term': 'Abnormality of the large intestine', 'description': 'Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the large intestine': {\n",
      "  \"best_match_code\": \"HP:0002250\",\n",
      "  \"best_match_term\": \"Abnormality of the large intestine\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Colon and rectum (including polyps)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the large intestine\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the large intestine\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002250\",\n",
      "          \"term\": \"Abnormality of the large intestine\",\n",
      "          \"description\": \"Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the large intestine\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002250\",\n",
      "          \"term\": \"Abnormality of the large intestine\",\n",
      "          \"description\": \"Any abnormality of the large intestine. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the large intestine\",\n",
      "      \"best_match_code\": \"HP:0002250\",\n",
      "      \"best_match_term\": \"Abnormality of the large intestine\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4025715\n",
      "✅ Processed row 35\n",
      "✅ Extracted terms: ['Pancreatic cancer']\n",
      "🌐 [Pancreatic cancer] API Status: 200\n",
      "✅ Results for Pancreatic cancer: [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Pancreatic cancer', 'candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Pancreatic cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002894\",\n",
      "    \"matched_term\": \"increased risk of pancreatic cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Pancreatic cancer', 'field_type': 'radio', 'extracted_terms': ['Pancreatic cancer'], 'umls_mappings': [{'original': 'Pancreatic cancer', 'candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None}]}], 'mappability_retry_count': 1, 'retries': 0, 'ranked_mappings': [{'original': 'Pancreatic cancer', 'ranked_candidates': [{'code': 'HP:0002894', 'term': 'increased risk of pancreatic cancer', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Pancreatic cancer': {\n",
      "  \"best_match_code\": \"HP:0002894\",\n",
      "  \"best_match_term\": \"increased risk of pancreatic cancer\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 36\n",
      "✅ Extracted terms: ['Urinary bladder cancer']\n",
      "🌐 [Urinary bladder cancer] API Status: 404\n",
      "❌ Failed for term: Urinary bladder cancer\n",
      "🧪 Final UMLS mappings: [{'original': 'Urinary bladder cancer', 'candidates': []}]\n",
      "✅ Revised terms: ['Malignant neoplasm of the urinary bladder']\n",
      "🌐 [Malignant neoplasm of the urinary bladder] API Status: 404\n",
      "❌ Failed for term: Malignant neoplasm of the urinary bladder\n",
      "🧪 Final UMLS mappings: [{'original': 'Malignant neoplasm of the urinary bladder', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the urinary bladder']\n",
      "🌐 [Neoplasm of the urinary bladder] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the urinary bladder\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the urinary bladder', 'candidates': []}]\n",
      "✅ Revised terms: ['Carcinoma of the urinary bladder']\n",
      "🌐 [Carcinoma of the urinary bladder] API Status: 404\n",
      "❌ Failed for term: Carcinoma of the urinary bladder\n",
      "🧪 Final UMLS mappings: [{'original': 'Carcinoma of the urinary bladder', 'candidates': []}]\n",
      "✅ Revised terms: ['Urinary bladder neoplasm']\n",
      "🌐 [Urinary bladder neoplasm] API Status: 404\n",
      "❌ Failed for term: Urinary bladder neoplasm\n",
      "🧪 Final UMLS mappings: [{'original': 'Urinary bladder neoplasm', 'candidates': []}]\n",
      "✅ Revised terms: ['Bladder carcinoma']\n",
      "🌐 [Bladder carcinoma] API Status: 200\n",
      "✅ Results for Bladder carcinoma: [{'code': 'HP:0002862', 'term': 'Bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006740', 'term': 'Transitional cell bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder with origin in a transitional epithelial cell. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Bladder carcinoma', 'candidates': [{'code': 'HP:0002862', 'term': 'Bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006740', 'term': 'Transitional cell bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder with origin in a transitional epithelial cell. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Bladder carcinoma': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002862\",\n",
      "    \"matched_term\": \"Bladder carcinoma\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006740\",\n",
      "    \"matched_term\": \"Transitional cell bladder carcinoma\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Bladder cancer', 'field_type': 'radio', 'extracted_terms': ['Bladder carcinoma'], 'umls_mappings': [{'original': 'Bladder carcinoma', 'candidates': [{'code': 'HP:0002862', 'term': 'Bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006740', 'term': 'Transitional cell bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder with origin in a transitional epithelial cell. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 5, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Malignant neoplasm of the urinary bladder', 'Urinary bladder cancer', 'Bladder carcinoma', 'Carcinoma of the urinary bladder', 'Urinary bladder neoplasm', 'Neoplasm of the urinary bladder'], 'retries': 0, 'ranked_mappings': [{'original': 'Bladder carcinoma', 'ranked_candidates': [{'code': 'HP:0002862', 'term': 'Bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0006740', 'term': 'Transitional cell bladder carcinoma', 'description': 'The presence of a carcinoma of the urinary bladder with origin in a transitional epithelial cell. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Bladder carcinoma': {\n",
      "  \"best_match_code\": \"HP:0002862\",\n",
      "  \"best_match_term\": \"Bladder carcinoma\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 37\n",
      "✅ Extracted terms: ['Kidney cancer']\n",
      "🌐 [Kidney cancer] API Status: 200\n",
      "✅ Results for Kidney cancer: [{'code': 'HP:0009726', 'term': 'Kidney cancer', 'description': 'A carcinoma arising from the epithelium of the renal parenchyma or the renal pelvis. The majority are renal cell carcinomas. Kidney carcinomas usually affect middle aged and elderly adults. Hematuria, abdominal pain, and a palpable mass are common symptoms.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Kidney cancer', 'candidates': [{'code': 'HP:0009726', 'term': 'Kidney cancer', 'description': 'A carcinoma arising from the epithelium of the renal parenchyma or the renal pelvis. The majority are renal cell carcinomas. Kidney carcinomas usually affect middle aged and elderly adults. Hematuria, abdominal pain, and a palpable mass are common symptoms.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Kidney cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009726\",\n",
      "    \"matched_term\": \"Kidney cancer\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Kidney cancer', 'field_type': 'radio', 'extracted_terms': ['Kidney cancer'], 'umls_mappings': [{'original': 'Kidney cancer', 'candidates': [{'code': 'HP:0009726', 'term': 'Kidney cancer', 'description': 'A carcinoma arising from the epithelium of the renal parenchyma or the renal pelvis. The majority are renal cell carcinomas. Kidney carcinomas usually affect middle aged and elderly adults. Hematuria, abdominal pain, and a palpable mass are common symptoms.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Kidney cancer', 'ranked_candidates': [{'code': 'HP:0009726', 'term': 'Kidney cancer', 'description': 'A carcinoma arising from the epithelium of the renal parenchyma or the renal pelvis. The majority are renal cell carcinomas. Kidney carcinomas usually affect middle aged and elderly adults. Hematuria, abdominal pain, and a palpable mass are common symptoms.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Kidney cancer': {\n",
      "  \"best_match_code\": \"HP:0009726\",\n",
      "  \"best_match_term\": \"Kidney cancer\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 38\n",
      "✅ Extracted terms: ['Thyroid cancer']\n",
      "🌐 [Thyroid cancer] API Status: 200\n",
      "✅ Results for Thyroid cancer: [{'code': 'HP:0002865', 'term': 'Medullary thyroid cancer', 'description': 'two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.'}, {'code': 'HP:0006780', 'term': 'Parathyroid Cancer', 'description': 'A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.'}, {'code': 'HP:0040198', 'term': 'Thyroid cancer, nonmedullary', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Thyroid cancer', 'candidates': [{'code': 'HP:0002865', 'term': 'Medullary thyroid cancer', 'description': 'two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.'}, {'code': 'HP:0006780', 'term': 'Parathyroid Cancer', 'description': 'A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.'}, {'code': 'HP:0040198', 'term': 'Thyroid cancer, nonmedullary', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Thyroid cancer': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0040198\",\n",
      "    \"matched_term\": \"Thyroid cancer, nonmedullary\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002865\",\n",
      "    \"matched_term\": \"Medullary thyroid cancer\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006780\",\n",
      "    \"matched_term\": \"Parathyroid Cancer\",\n",
      "    \"confidence\": \"0%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Thyroid cancer', 'field_type': 'radio', 'extracted_terms': ['Thyroid cancer'], 'umls_mappings': [{'original': 'Thyroid cancer', 'candidates': [{'code': 'HP:0002865', 'term': 'Medullary thyroid cancer', 'description': 'two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.'}, {'code': 'HP:0006780', 'term': 'Parathyroid Cancer', 'description': 'A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.'}, {'code': 'HP:0040198', 'term': 'Thyroid cancer, nonmedullary', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Thyroid cancer', 'ranked_candidates': [{'code': 'HP:0040198', 'term': 'Thyroid cancer, nonmedullary', 'description': None, 'confidence': 1.0}, {'code': 'HP:0002865', 'term': 'Medullary thyroid cancer', 'description': 'two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.', 'confidence': 0.75}, {'code': 'HP:0006780', 'term': 'Parathyroid Cancer', 'description': 'A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.', 'confidence': 0.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Thyroid cancer': {\n",
      "  \"best_match_code\": \"HP:0040198\",\n",
      "  \"best_match_term\": \"Thyroid cancer, nonmedullary\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Thyroid cancer\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Thyroid cancer\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Thyroid cancer\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002865\",\n",
      "          \"term\": \"Medullary thyroid cancer\",\n",
      "          \"description\": \"two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006780\",\n",
      "          \"term\": \"Parathyroid Cancer\",\n",
      "          \"description\": \"A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0040198\",\n",
      "          \"term\": \"Thyroid cancer, nonmedullary\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Thyroid cancer\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0040198\",\n",
      "          \"term\": \"Thyroid cancer, nonmedullary\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0002865\",\n",
      "          \"term\": \"Medullary thyroid cancer\",\n",
      "          \"description\": \"two types are found, familial and sporadic; if familial, the carcinoma is bilateral and may be associated with other benign or malignant endocrine organ tumors; if sporadic, it is unilateral; thyroidectomy and radiation therapy are treatments of choice.\",\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006780\",\n",
      "          \"term\": \"Parathyroid Cancer\",\n",
      "          \"description\": \"A malignant tumor arising from the parenchymal cells of the parathyroid gland. It is associated with the symptoms of primary hyperparathyroidism, resulting from the excessive production of parathyroid hormone. Morphologically, the differential diagnosis from parathyroid gland adenoma may be difficult. A definitive diagnosis of carcinoma is made only in the presence of capsular invasion, vascular invasion, and/or perineural invasion.\",\n",
      "          \"confidence\": 0.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Thyroid cancer\",\n",
      "      \"best_match_code\": \"HP:0040198\",\n",
      "      \"best_match_term\": \"Thyroid cancer, nonmedullary\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C3501843\n",
      "✅ Processed row 39\n",
      "✅ Extracted terms: ['Cutaneous melanoma']\n",
      "🌐 [Cutaneous melanoma] API Status: 200\n",
      "✅ Results for Cutaneous melanoma: [{'code': 'HP:0012056', 'term': 'Cutaneous melanoma', 'description': 'The presence of a melanoma of the skin. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Cutaneous melanoma', 'candidates': [{'code': 'HP:0012056', 'term': 'Cutaneous melanoma', 'description': 'The presence of a melanoma of the skin. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Cutaneous melanoma': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012056\",\n",
      "    \"matched_term\": \"Cutaneous melanoma\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Melanoma of skin', 'field_type': 'radio', 'extracted_terms': ['Cutaneous melanoma'], 'umls_mappings': [{'original': 'Cutaneous melanoma', 'candidates': [{'code': 'HP:0012056', 'term': 'Cutaneous melanoma', 'description': 'The presence of a melanoma of the skin. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Cutaneous melanoma', 'ranked_candidates': [{'code': 'HP:0012056', 'term': 'Cutaneous melanoma', 'description': 'The presence of a melanoma of the skin. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Cutaneous melanoma': {\n",
      "  \"best_match_code\": \"HP:0012056\",\n",
      "  \"best_match_term\": \"Cutaneous melanoma\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 40\n",
      "✅ Extracted terms: ['Non-melanoma skin cancer']\n",
      "🌐 [Non-melanoma skin cancer] API Status: 404\n",
      "❌ Failed for term: Non-melanoma skin cancer\n",
      "🧪 Final UMLS mappings: [{'original': 'Non-melanoma skin cancer', 'candidates': []}]\n",
      "✅ Revised terms: ['Carcinoma of the skin']\n",
      "🌐 [Carcinoma of the skin] API Status: 200\n",
      "✅ Results for Carcinoma of the skin: [{'code': 'HP:0030447', 'term': 'Anaplastic carcinoma of the skin', 'description': 'A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Carcinoma of the skin', 'candidates': [{'code': 'HP:0030447', 'term': 'Anaplastic carcinoma of the skin', 'description': 'A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Carcinoma of the skin': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0030447\",\n",
      "    \"matched_term\": \"Anaplastic carcinoma of the skin\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Non-melanoma skin cancer', 'field_type': 'radio', 'extracted_terms': ['Carcinoma of the skin'], 'umls_mappings': [{'original': 'Carcinoma of the skin', 'candidates': [{'code': 'HP:0030447', 'term': 'Anaplastic carcinoma of the skin', 'description': 'A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Non-melanoma skin cancer', 'Carcinoma of the skin'], 'retries': 0, 'ranked_mappings': [{'original': 'Carcinoma of the skin', 'ranked_candidates': [{'code': 'HP:0030447', 'term': 'Anaplastic carcinoma of the skin', 'description': 'A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Carcinoma of the skin': {\n",
      "  \"best_match_code\": \"HP:0030447\",\n",
      "  \"best_match_term\": \"Anaplastic carcinoma of the skin\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Non-melanoma skin cancer\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Carcinoma of the skin\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Carcinoma of the skin\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0030447\",\n",
      "          \"term\": \"Anaplastic carcinoma of the skin\",\n",
      "          \"description\": \"A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retry_count\": 1,\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"history_rewritten_terms\": [\n",
      "    \"Non-melanoma skin cancer\",\n",
      "    \"Carcinoma of the skin\"\n",
      "  ],\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Carcinoma of the skin\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0030447\",\n",
      "          \"term\": \"Anaplastic carcinoma of the skin\",\n",
      "          \"description\": \"A carcinoma arising from MERKEL CELLS located in the basal layer of the epidermis and occurring most commonly as a primary neuroendocrine carcinoma of the skin. Merkel cells are tactile cells of neuroectodermal origin and histologically show neurosecretory granules. The skin of the head and neck are a common site of Merkel cell carcinoma, occurring generally in elderly patients. (Holland et al., Cancer Medicine, 3d ed, p1245)\",\n",
      "          \"confidence\": 0.75\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Carcinoma of the skin\",\n",
      "      \"best_match_code\": \"HP:0030447\",\n",
      "      \"best_match_term\": \"Anaplastic carcinoma of the skin\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0007129\n",
      "🧩 ancestor_cuis ['C0037579', 'C0012634', 'C0410013', 'C0206754', 'C0206695', 'C1285159', 'C1266150', 'C0333949', 'C1268086', 'C0345976', 'C0037284', 'C0334094', 'C0007114', 'C1882062', 'C0577573', 'C1260954', 'C1291044', 'C0281981', 'C0027651', 'C0037274', 'C0455205', 'C1562176', 'C4074927', 'C0424722', 'C0007097', 'C2367165', 'C1302872', 'C1368683', 'C0037286', 'C1290011', 'C0332447', 'C4551686', 'C1302761', 'C0423767', 'C0577559', 'C0345977', 'C0263978', 'C2720507', 'C1532269', 'C0037088', 'C0221198', 'C0178298', 'C0003650', 'C0006826', 'C0457193']\n",
      "🧩 candidate_details [{'cui': 'C0037579', 'name': 'Neoplasm of soft tissues'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0410013', 'name': 'Lesion of soft tissue'}, {'cui': 'C0206754', 'name': 'Neuroendocrine tumor'}, {'cui': 'C0206695', 'name': 'Neuroendocrine carcinoma'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C1266150', 'name': 'Malignant epithelial neuroendocrine neoplasm'}, {'cui': 'C0333949', 'name': 'Disturbance of growth'}, {'cui': 'C1268086', 'name': 'Body structure'}, {'cui': 'C0345976', 'name': 'Epithelial neoplasm of skin'}, {'cui': 'C0037284', 'name': 'Skin lesion'}, {'cui': 'C0334094', 'name': 'Proliferation (morphologic abnormality)'}, {'cui': 'C0007114', 'name': 'Malignant neoplasm of skin'}, {'cui': 'C1882062', 'name': 'Neoplastic disease'}, {'cui': 'C0577573', 'name': 'Mass of body region'}, {'cui': 'C1260954', 'name': 'Morphologically altered structure'}, {'cui': 'C1291044', 'name': 'Integumentary system finding'}, {'cui': 'C0281981', 'name': 'Mass of skin'}, {'cui': 'C0027651', 'name': 'Neoplasms'}, {'cui': 'C0037274', 'name': 'Disease of skin, NOS'}, {'cui': 'C0455205', 'name': 'Skin finding'}, {'cui': 'C1562176', 'name': 'Proliferative mass'}, {'cui': 'C4074927', 'name': 'Lesion of skin and/or skin-associated mucous membrane'}, {'cui': 'C0424722', 'name': 'General finding of soft tissue'}, {'cui': 'C0007097', 'name': 'Carcinoma'}, {'cui': 'C2367165', 'name': 'Malignant neuroendocrine neoplasm'}, {'cui': 'C1302872', 'name': 'Neoplasm of integumentary system'}, {'cui': 'C1368683', 'name': 'Epithelioma'}, {'cui': 'C0037286', 'name': 'Neoplasm of skin'}, {'cui': 'C1290011', 'name': 'Disorder of integument'}, {'cui': 'C0332447', 'name': 'Morphologically abnormal structure (morphologic abnormality)'}, {'cui': 'C4551686', 'name': 'Malignant neoplasm of soft tissue'}, {'cui': 'C1302761', 'name': 'Neoplasm and/or hamartoma'}, {'cui': 'C0423767', 'name': 'Skin or mucosa lesion'}, {'cui': 'C0577559', 'name': 'Mass of body structure'}, {'cui': 'C0345977', 'name': 'Malignant epithelial neoplasm of skin'}, {'cui': 'C0263978', 'name': 'Disorder of soft tissue'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C1532269', 'name': 'Skin AND/OR mucosa finding'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0221198', 'name': 'Lesion'}, {'cui': 'C0178298', 'name': 'Disorder of skin and subcutaneous tissue'}, {'cui': 'C0003650', 'name': 'Apudoma'}, {'cui': 'C0006826', 'name': 'Neoplasms - malignant'}, {'cui': 'C0457193', 'name': 'Soft tissue mass'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Non-melanoma skin cancer\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Carcinoma of the skin\"\n",
      "  \"best_match_code\": \"HP:0030447\",\n",
      "  \"best_match_term\": \"Anaplastic carcinoma of the skin\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0037579 (Neoplasm of soft tissues)\n",
      "- C0012634 (Disease)\n",
      "- C0410013 (Lesion of soft tissue)\n",
      "- C0206754 (Neuroendocrine tumor)\n",
      "- C0206695 (Neuroendocrine carcinoma)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C1266150 (Malignant epithelial neuroendocrine neoplasm)\n",
      "- C0333949 (Disturbance of growth)\n",
      "- C1268086 (Body structure)\n",
      "- C0345976 (Epithelial neoplasm of skin)\n",
      "- C0037284 (Skin lesion)\n",
      "- C0334094 (Proliferation (morphologic abnormality))\n",
      "- C0007114 (Malignant neoplasm of skin)\n",
      "- C1882062 (Neoplastic disease)\n",
      "- C0577573 (Mass of body region)\n",
      "- C1260954 (Morphologically altered structure)\n",
      "- C1291044 (Integumentary system finding)\n",
      "- C0281981 (Mass of skin)\n",
      "- C0027651 (Neoplasms)\n",
      "- C0037274 (Disease of skin, NOS)\n",
      "- C0455205 (Skin finding)\n",
      "- C1562176 (Proliferative mass)\n",
      "- C4074927 (Lesion of skin and/or skin-associated mucous membrane)\n",
      "- C0424722 (General finding of soft tissue)\n",
      "- C0007097 (Carcinoma)\n",
      "- C2367165 (Malignant neuroendocrine neoplasm)\n",
      "- C1302872 (Neoplasm of integumentary system)\n",
      "- C1368683 (Epithelioma)\n",
      "- C0037286 (Neoplasm of skin)\n",
      "- C1290011 (Disorder of integument)\n",
      "- C0332447 (Morphologically abnormal structure (morphologic abnormality))\n",
      "- C4551686 (Malignant neoplasm of soft tissue)\n",
      "- C1302761 (Neoplasm and/or hamartoma)\n",
      "- C0423767 (Skin or mucosa lesion)\n",
      "- C0577559 (Mass of body structure)\n",
      "- C0345977 (Malignant epithelial neoplasm of skin)\n",
      "- C0263978 (Disorder of soft tissue)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C1532269 (Skin AND/OR mucosa finding)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0221198 (Lesion)\n",
      "- C0178298 (Disorder of skin and subcutaneous tissue)\n",
      "- C0003650 (Apudoma)\n",
      "- C0006826 (Neoplasms - malignant)\n",
      "- C0457193 (Soft tissue mass)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0012288\",\\n  \"refined_term\": \"Non-melanoma skin carcinoma\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 36, 'prompt_tokens': 1079, 'total_tokens': 1115, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCe8eWOM4Vcu0TwFhDDTcL8PQxA5S', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--73ce5888-e46d-4f21-9f41-672a1a32cdcc-0' usage_metadata={'input_tokens': 1079, 'output_tokens': 36, 'total_tokens': 1115, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Non-melanoma skin carcinoma\n",
      "🧠 LLM refined_code: HP:0012288\n",
      "✅ Processed row 41\n",
      "✅ Extracted terms: ['Central nervous system cancer']\n",
      "🌐 [Central nervous system cancer] API Status: 404\n",
      "❌ Failed for term: Central nervous system cancer\n",
      "🧪 Final UMLS mappings: [{'original': 'Central nervous system cancer', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the central nervous system']\n",
      "🌐 [Neoplasm of the central nervous system] API Status: 200\n",
      "✅ Results for Neoplasm of the central nervous system: [{'code': 'HP:0100835', 'term': 'Benign neoplasm of the central nervous system', 'description': 'A neoplasm that arises from the central nervous system and is characterized by the absence of atypical or malignant cytological and architectural features, and absence of invasive features or metastatic potential.'}, {'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0100006', 'term': 'Neoplasm of the central nervous system', 'description': 'Benign and malignant neoplastic processes that arise from or secondarily involve the brain, spinal cord, or meninges.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the central nervous system', 'candidates': [{'code': 'HP:0100835', 'term': 'Benign neoplasm of the central nervous system', 'description': 'A neoplasm that arises from the central nervous system and is characterized by the absence of atypical or malignant cytological and architectural features, and absence of invasive features or metastatic potential.'}, {'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0100006', 'term': 'Neoplasm of the central nervous system', 'description': 'Benign and malignant neoplastic processes that arise from or secondarily involve the brain, spinal cord, or meninges.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Neoplasm of the central nervous system': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100006\",\n",
      "    \"matched_term\": \"Neoplasm of the central nervous system\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100835\",\n",
      "    \"matched_term\": \"Benign neoplasm of the central nervous system\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100836\",\n",
      "    \"matched_term\": \"Malignant neoplasm of the central nervous system\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Brain or spine cancer', 'field_type': 'radio', 'extracted_terms': ['Neoplasm of the central nervous system'], 'umls_mappings': [{'original': 'Neoplasm of the central nervous system', 'candidates': [{'code': 'HP:0100835', 'term': 'Benign neoplasm of the central nervous system', 'description': 'A neoplasm that arises from the central nervous system and is characterized by the absence of atypical or malignant cytological and architectural features, and absence of invasive features or metastatic potential.'}, {'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0100006', 'term': 'Neoplasm of the central nervous system', 'description': 'Benign and malignant neoplastic processes that arise from or secondarily involve the brain, spinal cord, or meninges.'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Neoplasm of the central nervous system', 'Central nervous system cancer'], 'retries': 0, 'ranked_mappings': [{'original': 'Neoplasm of the central nervous system', 'ranked_candidates': [{'code': 'HP:0100006', 'term': 'Neoplasm of the central nervous system', 'description': 'Benign and malignant neoplastic processes that arise from or secondarily involve the brain, spinal cord, or meninges.', 'confidence': 1.0}, {'code': 'HP:0100835', 'term': 'Benign neoplasm of the central nervous system', 'description': 'A neoplasm that arises from the central nervous system and is characterized by the absence of atypical or malignant cytological and architectural features, and absence of invasive features or metastatic potential.', 'confidence': 0.7}, {'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Neoplasm of the central nervous system': {\n",
      "  \"best_match_code\": \"HP:0100006\",\n",
      "  \"best_match_term\": \"Neoplasm of the central nervous system\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 42\n",
      "✅ Extracted terms: ['Hematologic malignancy']\n",
      "🌐 [Hematologic malignancy] API Status: 404\n",
      "❌ Failed for term: Hematologic malignancy\n",
      "🧪 Final UMLS mappings: [{'original': 'Hematologic malignancy', 'candidates': []}]\n",
      "✅ Revised terms: ['Neoplasm of the hematopoietic system']\n",
      "🌐 [Neoplasm of the hematopoietic system] API Status: 404\n",
      "❌ Failed for term: Neoplasm of the hematopoietic system\n",
      "🧪 Final UMLS mappings: [{'original': 'Neoplasm of the hematopoietic system', 'candidates': []}]\n",
      "✅ Revised terms: ['Malignant neoplasm']\n",
      "🌐 [Malignant neoplasm] API Status: 200\n",
      "✅ Results for Malignant neoplasm: [{'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Malignant neoplasm', 'candidates': [{'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Malignant neoplasm': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100836\",\n",
      "    \"matched_term\": \"Malignant neoplasm of the central nervous system\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Blood cancer (including leukemia and lymphoma)', 'field_type': 'radio', 'extracted_terms': ['Malignant neoplasm'], 'umls_mappings': [{'original': 'Malignant neoplasm', 'candidates': [{'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 2, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Malignant neoplasm', 'Hematologic malignancy', 'Neoplasm of the hematopoietic system'], 'retries': 0, 'ranked_mappings': [{'original': 'Malignant neoplasm', 'ranked_candidates': [{'code': 'HP:0100836', 'term': 'Malignant neoplasm of the central nervous system', 'description': 'A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Malignant neoplasm': {}\n",
      "⚠️ Validation failed or empty — using top-ranked fallback.\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Blood cancer (including leukemia and lymphoma)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Malignant neoplasm\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malignant neoplasm\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0100836\",\n",
      "          \"term\": \"Malignant neoplasm of the central nervous system\",\n",
      "          \"description\": \"A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retry_count\": 2,\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"history_rewritten_terms\": [\n",
      "    \"Malignant neoplasm\",\n",
      "    \"Hematologic malignancy\",\n",
      "    \"Neoplasm of the hematopoietic system\"\n",
      "  ],\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malignant neoplasm\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0100836\",\n",
      "          \"term\": \"Malignant neoplasm of the central nervous system\",\n",
      "          \"description\": \"A tumor that originates in the pineal gland, has moderate cellularity and tends to form rosette patterns. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.5\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malignant neoplasm\",\n",
      "      \"best_match_code\": \"HP:0100836\",\n",
      "      \"best_match_term\": \"Malignant neoplasm of the central nervous system\",\n",
      "      \"confidence\": 0.5\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0348374\n",
      "🧩 ancestor_cuis ['C0012634', 'C1302761', 'C0460024', 'C0027766', 'C0577559', 'C0422878', 'C1882062', 'C0576488', 'C0497549', 'C0085136', 'C2720507', 'C1285159', 'C0037088', 'C0006826', 'C0027765', 'C0007682']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C1302761', 'name': 'Neoplasm and/or hamartoma'}, {'cui': 'C0460024', 'name': 'Space-occupying lesion of nervous system'}, {'cui': 'C0027766', 'name': 'Neoplasm of nervous system'}, {'cui': 'C0577559', 'name': 'Mass of body structure'}, {'cui': 'C0422878', 'name': 'Central nervous system finding'}, {'cui': 'C1882062', 'name': 'Neoplastic disease'}, {'cui': 'C0576488', 'name': 'Neurological lesion'}, {'cui': 'C0497549', 'name': 'Malignant neoplasm of nervous system'}, {'cui': 'C0085136', 'name': 'Neoplasm of central nervous system'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0006826', 'name': 'Neoplasms - malignant'}, {'cui': 'C0027765', 'name': 'Nervous system disorders NOS'}, {'cui': 'C0007682', 'name': 'CNS disorder'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Blood cancer (including leukemia and lymphoma)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Malignant neoplasm\"\n",
      "  \"best_match_code\": \"HP:0100836\",\n",
      "  \"best_match_term\": \"Malignant neoplasm of the central nervous system\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C1302761 (Neoplasm and/or hamartoma)\n",
      "- C0460024 (Space-occupying lesion of nervous system)\n",
      "- C0027766 (Neoplasm of nervous system)\n",
      "- C0577559 (Mass of body structure)\n",
      "- C0422878 (Central nervous system finding)\n",
      "- C1882062 (Neoplastic disease)\n",
      "- C0576488 (Neurological lesion)\n",
      "- C0497549 (Malignant neoplasm of nervous system)\n",
      "- C0085136 (Neoplasm of central nervous system)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0006826 (Neoplasms - malignant)\n",
      "- C0027765 (Nervous system disorders NOS)\n",
      "- C0007682 (CNS disorder)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0012126\",\\n  \"refined_term\": \"Hematologic neoplasm\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 36, 'prompt_tokens': 714, 'total_tokens': 750, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCe9x8z1JvEeLXGkZoufPO4Ak2Kph', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--728d51cf-e710-432d-ae61-451c7d0310b0-0' usage_metadata={'input_tokens': 714, 'output_tokens': 36, 'total_tokens': 750, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Hematologic neoplasm\n",
      "🧠 LLM refined_code: HP:0012126\n",
      "✅ Processed row 43\n",
      "✅ Extracted terms: ['Abnormality of the chin']\n",
      "🌐 [Abnormality of the chin] API Status: 200\n",
      "✅ Results for Abnormality of the chin: [{'code': 'HP:0000306', 'term': 'Abnormality of the chin', 'description': 'An abnormality of the chin, i.e., of the inferior portion of the face lying inferior to the lower lip and including the central prominence of the lower jaw. [https://orcid.org/0000-0002-0736-9199, PMID:19125436]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the chin', 'candidates': [{'code': 'HP:0000306', 'term': 'Abnormality of the chin', 'description': 'An abnormality of the chin, i.e., of the inferior portion of the face lying inferior to the lower lip and including the central prominence of the lower jaw. [https://orcid.org/0000-0002-0736-9199, PMID:19125436]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the chin': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000306\",\n",
      "    \"matched_term\": \"Abnormality of the chin\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Chin differences', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the chin'], 'umls_mappings': [{'original': 'Abnormality of the chin', 'candidates': [{'code': 'HP:0000306', 'term': 'Abnormality of the chin', 'description': 'An abnormality of the chin, i.e., of the inferior portion of the face lying inferior to the lower lip and including the central prominence of the lower jaw. [https://orcid.org/0000-0002-0736-9199, PMID:19125436]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the chin', 'ranked_candidates': [{'code': 'HP:0000306', 'term': 'Abnormality of the chin', 'description': 'An abnormality of the chin, i.e., of the inferior portion of the face lying inferior to the lower lip and including the central prominence of the lower jaw. [https://orcid.org/0000-0002-0736-9199, PMID:19125436]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the chin': {\n",
      "  \"best_match_code\": \"HP:0000306\",\n",
      "  \"best_match_term\": \"Abnormality of the chin\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 44\n",
      "✅ Extracted terms: ['Orofacial cleft']\n",
      "🌐 [Orofacial cleft] API Status: 200\n",
      "✅ Results for Orofacial cleft: [{'code': 'HP:0000202', 'term': 'Orofacial cleft', 'description': 'The presence of a cleft (gap, opening, or groove) in the oral cavity, including cleft of the upper lip and/or cleft of the palate. Cleft of the upper lip is visible as a groove or fissure in the lip, most frequently due to a congenital failure of the maxillary and median nasal processes to fuse. Cleft palate is characterized by a grooved depression or fissure in the roof of the mouth, most often resulting from a congenital failure of the palate to fuse properly. Clefts of the lip and palate can occur individually or together. It is preferable to code each defect separately. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-4142-7153, https://www.cdc.gov/ncbddd/birthdefects/surveillancemanual/chapters/chapter-4/chapter4-6.html, PMID:21331089]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Orofacial cleft', 'candidates': [{'code': 'HP:0000202', 'term': 'Orofacial cleft', 'description': 'The presence of a cleft (gap, opening, or groove) in the oral cavity, including cleft of the upper lip and/or cleft of the palate. Cleft of the upper lip is visible as a groove or fissure in the lip, most frequently due to a congenital failure of the maxillary and median nasal processes to fuse. Cleft palate is characterized by a grooved depression or fissure in the roof of the mouth, most often resulting from a congenital failure of the palate to fuse properly. Clefts of the lip and palate can occur individually or together. It is preferable to code each defect separately. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-4142-7153, https://www.cdc.gov/ncbddd/birthdefects/surveillancemanual/chapters/chapter-4/chapter4-6.html, PMID:21331089]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Orofacial cleft': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000202\",\n",
      "    \"matched_term\": \"Orofacial cleft\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Cleft lip and/or cleft palate', 'field_type': 'radio', 'extracted_terms': ['Orofacial cleft'], 'umls_mappings': [{'original': 'Orofacial cleft', 'candidates': [{'code': 'HP:0000202', 'term': 'Orofacial cleft', 'description': 'The presence of a cleft (gap, opening, or groove) in the oral cavity, including cleft of the upper lip and/or cleft of the palate. Cleft of the upper lip is visible as a groove or fissure in the lip, most frequently due to a congenital failure of the maxillary and median nasal processes to fuse. Cleft palate is characterized by a grooved depression or fissure in the roof of the mouth, most often resulting from a congenital failure of the palate to fuse properly. Clefts of the lip and palate can occur individually or together. It is preferable to code each defect separately. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-4142-7153, https://www.cdc.gov/ncbddd/birthdefects/surveillancemanual/chapters/chapter-4/chapter4-6.html, PMID:21331089]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Orofacial cleft', 'ranked_candidates': [{'code': 'HP:0000202', 'term': 'Orofacial cleft', 'description': 'The presence of a cleft (gap, opening, or groove) in the oral cavity, including cleft of the upper lip and/or cleft of the palate. Cleft of the upper lip is visible as a groove or fissure in the lip, most frequently due to a congenital failure of the maxillary and median nasal processes to fuse. Cleft palate is characterized by a grooved depression or fissure in the roof of the mouth, most often resulting from a congenital failure of the palate to fuse properly. Clefts of the lip and palate can occur individually or together. It is preferable to code each defect separately. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-4142-7153, https://www.cdc.gov/ncbddd/birthdefects/surveillancemanual/chapters/chapter-4/chapter4-6.html, PMID:21331089]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Orofacial cleft': {\n",
      "  \"best_match_code\": \"HP:0000202\",\n",
      "  \"best_match_term\": \"Orofacial cleft\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 45\n",
      "✅ Extracted terms: ['Abnormal facial shape']\n",
      "🌐 [Abnormal facial shape] API Status: 200\n",
      "✅ Results for Abnormal facial shape: [{'code': 'HP:0001999', 'term': 'Abnormal facial shape', 'description': 'An abnormal morphology (form) of the face or its components. [https://orcid.org/0000-0002-9602-2321]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal facial shape', 'candidates': [{'code': 'HP:0001999', 'term': 'Abnormal facial shape', 'description': 'An abnormal morphology (form) of the face or its components. [https://orcid.org/0000-0002-9602-2321]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal facial shape': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001999\",\n",
      "    \"matched_term\": \"Abnormal facial shape\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'General face shape differences', 'field_type': 'radio', 'extracted_terms': ['Abnormal facial shape'], 'umls_mappings': [{'original': 'Abnormal facial shape', 'candidates': [{'code': 'HP:0001999', 'term': 'Abnormal facial shape', 'description': 'An abnormal morphology (form) of the face or its components. [https://orcid.org/0000-0002-9602-2321]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal facial shape', 'ranked_candidates': [{'code': 'HP:0001999', 'term': 'Abnormal facial shape', 'description': 'An abnormal morphology (form) of the face or its components. [https://orcid.org/0000-0002-9602-2321]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal facial shape': {\n",
      "  \"best_match_code\": \"HP:0001999\",\n",
      "  \"best_match_term\": \"Abnormal facial shape\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 46\n",
      "✅ Extracted terms: ['Abnormality of the hair']\n",
      "🌐 [Abnormality of the hair] API Status: 200\n",
      "✅ Results for Abnormality of the hair: [{'code': 'HP:0001595', 'term': 'Abnormality of the hair', 'description': 'An abnormality of the hair. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009553', 'term': 'Abnormality of the hairline', 'description': 'The hairline refers to the outline of hair of the head. An abnormality of the hairline can refer to an unusually low or high border between areas of the scalp with and without hair or to abnormal projections of scalp hair. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the hair', 'candidates': [{'code': 'HP:0001595', 'term': 'Abnormality of the hair', 'description': 'An abnormality of the hair. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009553', 'term': 'Abnormality of the hairline', 'description': 'The hairline refers to the outline of hair of the head. An abnormality of the hairline can refer to an unusually low or high border between areas of the scalp with and without hair or to abnormal projections of scalp hair. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the hair': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001595\",\n",
      "    \"matched_term\": \"Abnormality of the hair\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009553\",\n",
      "    \"matched_term\": \"Abnormality of the hairline\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hair differences (sparse, unusual texture)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the hair'], 'umls_mappings': [{'original': 'Abnormality of the hair', 'candidates': [{'code': 'HP:0001595', 'term': 'Abnormality of the hair', 'description': 'An abnormality of the hair. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0009553', 'term': 'Abnormality of the hairline', 'description': 'The hairline refers to the outline of hair of the head. An abnormality of the hairline can refer to an unusually low or high border between areas of the scalp with and without hair or to abnormal projections of scalp hair. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the hair', 'ranked_candidates': [{'code': 'HP:0001595', 'term': 'Abnormality of the hair', 'description': 'An abnormality of the hair. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0009553', 'term': 'Abnormality of the hairline', 'description': 'The hairline refers to the outline of hair of the head. An abnormality of the hairline can refer to an unusually low or high border between areas of the scalp with and without hair or to abnormal projections of scalp hair. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the hair': {\n",
      "  \"best_match_code\": \"HP:0001595\",\n",
      "  \"best_match_term\": \"Abnormality of the hair\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 47\n",
      "✅ Extracted terms: ['Abnormality of the oral cavity']\n",
      "🌐 [Abnormality of the oral cavity] API Status: 200\n",
      "✅ Results for Abnormality of the oral cavity: [{'code': 'HP:0000163', 'term': 'Abnormality of the oral cavity', 'description': 'Abnormality of the oral cavity, i.e., the opening or hollow part of the mouth. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the oral cavity', 'candidates': [{'code': 'HP:0000163', 'term': 'Abnormality of the oral cavity', 'description': 'Abnormality of the oral cavity, i.e., the opening or hollow part of the mouth. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the oral cavity': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000163\",\n",
      "    \"matched_term\": \"Abnormality of the oral cavity\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Inside of the mouth (teeth/gums/tongue) issues', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the oral cavity'], 'umls_mappings': [{'original': 'Abnormality of the oral cavity', 'candidates': [{'code': 'HP:0000163', 'term': 'Abnormality of the oral cavity', 'description': 'Abnormality of the oral cavity, i.e., the opening or hollow part of the mouth. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the oral cavity', 'ranked_candidates': [{'code': 'HP:0000163', 'term': 'Abnormality of the oral cavity', 'description': 'Abnormality of the oral cavity, i.e., the opening or hollow part of the mouth. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the oral cavity': {\n",
      "  \"best_match_code\": \"HP:0000163\",\n",
      "  \"best_match_term\": \"Abnormality of the oral cavity\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 48\n",
      "✅ Extracted terms: ['Abnormality of the mouth']\n",
      "🌐 [Abnormality of the mouth] API Status: 200\n",
      "✅ Results for Abnormality of the mouth: [{'code': 'HP:0000153', 'term': 'Abnormality of the mouth', 'description': 'Congenital absence of or defects in structures of the mouth.'}, {'code': 'HP:0410012', 'term': 'Abnormality of the mouth floor', 'description': 'Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the mouth', 'candidates': [{'code': 'HP:0000153', 'term': 'Abnormality of the mouth', 'description': 'Congenital absence of or defects in structures of the mouth.'}, {'code': 'HP:0410012', 'term': 'Abnormality of the mouth floor', 'description': 'Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the mouth': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000153\",\n",
      "    \"matched_term\": \"Abnormality of the mouth\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0410012\",\n",
      "    \"matched_term\": \"Abnormality of the mouth floor\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Lips or outside of the mouth issues', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the mouth'], 'umls_mappings': [{'original': 'Abnormality of the mouth', 'candidates': [{'code': 'HP:0000153', 'term': 'Abnormality of the mouth', 'description': 'Congenital absence of or defects in structures of the mouth.'}, {'code': 'HP:0410012', 'term': 'Abnormality of the mouth floor', 'description': 'Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the mouth', 'ranked_candidates': [{'code': 'HP:0000153', 'term': 'Abnormality of the mouth', 'description': 'Congenital absence of or defects in structures of the mouth.', 'confidence': 1.0}, {'code': 'HP:0410012', 'term': 'Abnormality of the mouth floor', 'description': 'Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the mouth': {\n",
      "  \"best_match_code\": \"HP:0000153\",\n",
      "  \"best_match_term\": \"Abnormality of the mouth\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Lips or outside of the mouth issues\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the mouth\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the mouth\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000153\",\n",
      "          \"term\": \"Abnormality of the mouth\",\n",
      "          \"description\": \"Congenital absence of or defects in structures of the mouth.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0410012\",\n",
      "          \"term\": \"Abnormality of the mouth floor\",\n",
      "          \"description\": \"Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the mouth\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000153\",\n",
      "          \"term\": \"Abnormality of the mouth\",\n",
      "          \"description\": \"Congenital absence of or defects in structures of the mouth.\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0410012\",\n",
      "          \"term\": \"Abnormality of the mouth floor\",\n",
      "          \"description\": \"Any abnormality of the mouth floor. [https://orcid.org/0000-0001-5208-3432]\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the mouth\",\n",
      "      \"best_match_code\": \"HP:0000153\",\n",
      "      \"best_match_term\": \"Abnormality of the mouth\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0026633\n",
      "🧩 ancestor_cuis ['C0012634', 'C2004465', 'C0266015', 'C0000768', 'C1320354', 'C1285159', 'C0266804', 'C1333803', 'C0008073', 'C2700612', 'C0575142', 'C1290856', 'C0242354', 'C0012242', 'C1827135', 'C0159000', 'C0026636', 'C0012241', 'C2720507', 'C0520555', 'C0037088', 'C1533165']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C2004465', 'name': 'Congenital malformation of upper alimentary tract'}, {'cui': 'C0266015', 'name': 'Congenital anomaly of digestive system, NOS'}, {'cui': 'C0000768', 'name': 'Congenital abnormality'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0266804', 'name': 'Disorder of upper digestive tract'}, {'cui': 'C1333803', 'name': 'Digestive system observation'}, {'cui': 'C0008073', 'name': 'Developmental disorder'}, {'cui': 'C2700612', 'name': 'Disorder of digestive tract'}, {'cui': 'C0575142', 'name': 'Finding of head region'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C0242354', 'name': 'Congenital disorder'}, {'cui': 'C0012242', 'name': 'Disorder of digestive system'}, {'cui': 'C1827135', 'name': 'Finding of mouth region'}, {'cui': 'C0159000', 'name': 'Disorder of digestive system specific to fetus OR newborn'}, {'cui': 'C0026636', 'name': 'Disease of mouth'}, {'cui': 'C0012241', 'name': 'Congenital anomaly of gastrointestinal tract'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0520555', 'name': 'Congenital anomaly of head'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C1533165', 'name': 'Disorder of fetus or newborn'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Lips or outside of the mouth issues\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Abnormality of the mouth\"\n",
      "  \"best_match_code\": \"HP:0000153\",\n",
      "  \"best_match_term\": \"Abnormality of the mouth\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C2004465 (Congenital malformation of upper alimentary tract)\n",
      "- C0266015 (Congenital anomaly of digestive system, NOS)\n",
      "- C0000768 (Congenital abnormality)\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0266804 (Disorder of upper digestive tract)\n",
      "- C1333803 (Digestive system observation)\n",
      "- C0008073 (Developmental disorder)\n",
      "- C2700612 (Disorder of digestive tract)\n",
      "- C0575142 (Finding of head region)\n",
      "- C1290856 (Disorder of head)\n",
      "- C0242354 (Congenital disorder)\n",
      "- C0012242 (Disorder of digestive system)\n",
      "- C1827135 (Finding of mouth region)\n",
      "- C0159000 (Disorder of digestive system specific to fetus OR newborn)\n",
      "- C0026636 (Disease of mouth)\n",
      "- C0012241 (Congenital anomaly of gastrointestinal tract)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0520555 (Congenital anomaly of head)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C1533165 (Disorder of fetus or newborn)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0000153\",\\n  \"refined_term\": \"Abnormality of the mouth\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 36, 'prompt_tokens': 779, 'total_tokens': 815, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeBADLk3oRnLbIXDs3BFUCnXLnjd', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--ff65ea66-3392-4358-b834-46cd7953f1fa-0' usage_metadata={'input_tokens': 779, 'output_tokens': 36, 'total_tokens': 815, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Abnormality of the mouth\n",
      "🧠 LLM refined_code: HP:0000153\n",
      "✅ Processed row 49\n",
      "✅ Extracted terms: ['Abnormality of the neck']\n",
      "🌐 [Abnormality of the neck] API Status: 200\n",
      "✅ Results for Abnormality of the neck: [{'code': 'HP:0000464', 'term': 'Abnormality of the neck', 'description': 'An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the neck', 'candidates': [{'code': 'HP:0000464', 'term': 'Abnormality of the neck', 'description': 'An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the neck': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000464\",\n",
      "    \"matched_term\": \"Abnormality of the neck\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Neck differences (short, broad, webbed, branchial anomalies)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the neck'], 'umls_mappings': [{'original': 'Abnormality of the neck', 'candidates': [{'code': 'HP:0000464', 'term': 'Abnormality of the neck', 'description': 'An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the neck', 'ranked_candidates': [{'code': 'HP:0000464', 'term': 'Abnormality of the neck', 'description': 'An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the neck': {\n",
      "  \"best_match_code\": \"HP:0000464\",\n",
      "  \"best_match_term\": \"Abnormality of the neck\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Neck differences (short, broad, webbed, branchial anomalies)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the neck\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the neck\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000464\",\n",
      "          \"term\": \"Abnormality of the neck\",\n",
      "          \"description\": \"An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the neck\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000464\",\n",
      "          \"term\": \"Abnormality of the neck\",\n",
      "          \"description\": \"An abnormality of the neck. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the neck\",\n",
      "      \"best_match_code\": \"HP:0000464\",\n",
      "      \"best_match_term\": \"Abnormality of the neck\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0266623\n",
      "🧩 ancestor_cuis ['C0575155', 'C0012634', 'C0558385', 'C0000768', 'C2720507', 'C0037088', 'C1533165', 'C0242354', 'C0008073']\n",
      "🧩 candidate_details [{'cui': 'C0575155', 'name': 'Finding of neck region'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0558385', 'name': 'Disorder of neck'}, {'cui': 'C0000768', 'name': 'Congenital abnormality'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C1533165', 'name': 'Disorder of fetus or newborn'}, {'cui': 'C0242354', 'name': 'Congenital disorder'}, {'cui': 'C0008073', 'name': 'Developmental disorder'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Neck differences (short, broad, webbed, branchial anomalies)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Abnormality of the neck\"\n",
      "  \"best_match_code\": \"HP:0000464\",\n",
      "  \"best_match_term\": \"Abnormality of the neck\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0575155 (Finding of neck region)\n",
      "- C0012634 (Disease)\n",
      "- C0558385 (Disorder of neck)\n",
      "- C0000768 (Congenital abnormality)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C1533165 (Disorder of fetus or newborn)\n",
      "- C0242354 (Congenital disorder)\n",
      "- C0008073 (Developmental disorder)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 617, 'total_tokens': 618, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeBUPMjF8q2WHhiS4psNv6j2vFXG', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--ac07c77b-63f5-45aa-bcad-3ad22fd7ce1c-0' usage_metadata={'input_tokens': 617, 'output_tokens': 1, 'total_tokens': 618, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 50\n",
      "✅ Extracted terms: ['Abnormality of the nose']\n",
      "🌐 [Abnormality of the nose] API Status: 200\n",
      "✅ Results for Abnormality of the nose: [{'code': 'HP:0000366', 'term': 'Abnormality of the nose', 'description': 'An abnormality of the nose. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the nose', 'candidates': [{'code': 'HP:0000366', 'term': 'Abnormality of the nose', 'description': 'An abnormality of the nose. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the nose': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000366\",\n",
      "    \"matched_term\": \"Abnormality of the nose\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Nose differences', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the nose'], 'umls_mappings': [{'original': 'Abnormality of the nose', 'candidates': [{'code': 'HP:0000366', 'term': 'Abnormality of the nose', 'description': 'An abnormality of the nose. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the nose', 'ranked_candidates': [{'code': 'HP:0000366', 'term': 'Abnormality of the nose', 'description': 'An abnormality of the nose. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the nose': {\n",
      "  \"best_match_code\": \"HP:0000366\",\n",
      "  \"best_match_term\": \"Abnormality of the nose\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 51\n",
      "✅ Extracted terms: ['Abnormal skull morphology']\n",
      "🌐 [Abnormal skull morphology] API Status: 200\n",
      "✅ Results for Abnormal skull morphology: [{'code': 'HP:0000929', 'term': 'Abnormal skull morphology', 'description': 'An abnormality of the skull, the bony framework of the head which is comprised of the neurocranium (with eight cranial bones) and the viscerocranium (facial skeleton) that comprises fourteen facial bones with the mandible as its largest bone. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal skull morphology', 'candidates': [{'code': 'HP:0000929', 'term': 'Abnormal skull morphology', 'description': 'An abnormality of the skull, the bony framework of the head which is comprised of the neurocranium (with eight cranial bones) and the viscerocranium (facial skeleton) that comprises fourteen facial bones with the mandible as its largest bone. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal skull morphology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000929\",\n",
      "    \"matched_term\": \"Abnormal skull morphology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Skull differences (macro/microcephaly, craniosynostosis)', 'field_type': 'radio', 'extracted_terms': ['Abnormal skull morphology'], 'umls_mappings': [{'original': 'Abnormal skull morphology', 'candidates': [{'code': 'HP:0000929', 'term': 'Abnormal skull morphology', 'description': 'An abnormality of the skull, the bony framework of the head which is comprised of the neurocranium (with eight cranial bones) and the viscerocranium (facial skeleton) that comprises fourteen facial bones with the mandible as its largest bone. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal skull morphology', 'ranked_candidates': [{'code': 'HP:0000929', 'term': 'Abnormal skull morphology', 'description': 'An abnormality of the skull, the bony framework of the head which is comprised of the neurocranium (with eight cranial bones) and the viscerocranium (facial skeleton) that comprises fourteen facial bones with the mandible as its largest bone. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal skull morphology': {\n",
      "  \"best_match_code\": \"HP:0000929\",\n",
      "  \"best_match_term\": \"Abnormal skull morphology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 52\n",
      "✅ Extracted terms: ['Dysphagia']\n",
      "🌐 [Dysphagia] API Status: 200\n",
      "✅ Results for Dysphagia: [{'code': 'HP:0002015', 'term': 'Dysphagia', 'description': 'Difficulty in SWALLOWING which may result from neuromuscular disorder or mechanical obstruction. Dysphagia is classified into two distinct types: oropharyngeal dysphagia due to malfunction of the PHARYNX and UPPER ESOPHAGEAL SPHINCTER; and esophageal dysphagia due to malfunction of the ESOPHAGUS.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Dysphagia', 'candidates': [{'code': 'HP:0002015', 'term': 'Dysphagia', 'description': 'Difficulty in SWALLOWING which may result from neuromuscular disorder or mechanical obstruction. Dysphagia is classified into two distinct types: oropharyngeal dysphagia due to malfunction of the PHARYNX and UPPER ESOPHAGEAL SPHINCTER; and esophageal dysphagia due to malfunction of the ESOPHAGUS.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Dysphagia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002015\",\n",
      "    \"matched_term\": \"Dysphagia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Throat/swallowing difficulties', 'field_type': 'radio', 'extracted_terms': ['Dysphagia'], 'umls_mappings': [{'original': 'Dysphagia', 'candidates': [{'code': 'HP:0002015', 'term': 'Dysphagia', 'description': 'Difficulty in SWALLOWING which may result from neuromuscular disorder or mechanical obstruction. Dysphagia is classified into two distinct types: oropharyngeal dysphagia due to malfunction of the PHARYNX and UPPER ESOPHAGEAL SPHINCTER; and esophageal dysphagia due to malfunction of the ESOPHAGUS.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Dysphagia', 'ranked_candidates': [{'code': 'HP:0002015', 'term': 'Dysphagia', 'description': 'Difficulty in SWALLOWING which may result from neuromuscular disorder or mechanical obstruction. Dysphagia is classified into two distinct types: oropharyngeal dysphagia due to malfunction of the PHARYNX and UPPER ESOPHAGEAL SPHINCTER; and esophageal dysphagia due to malfunction of the ESOPHAGUS.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Dysphagia': {\n",
      "  \"best_match_code\": \"HP:0002015\",\n",
      "  \"best_match_term\": \"Dysphagia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 53\n",
      "✅ Extracted terms: ['Abnormality of eye movement']\n",
      "🌐 [Abnormality of eye movement] API Status: 200\n",
      "✅ Results for Abnormality of eye movement: [{'code': 'HP:0000496', 'term': 'Abnormality of eye movement', 'description': 'An abnormality in voluntary or involuntary eye movements or their control. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of eye movement', 'candidates': [{'code': 'HP:0000496', 'term': 'Abnormality of eye movement', 'description': 'An abnormality in voluntary or involuntary eye movements or their control. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of eye movement': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000496\",\n",
      "    \"matched_term\": \"Abnormality of eye movement\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Eye movement issues (strabismus, nystagmus)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of eye movement'], 'umls_mappings': [{'original': 'Abnormality of eye movement', 'candidates': [{'code': 'HP:0000496', 'term': 'Abnormality of eye movement', 'description': 'An abnormality in voluntary or involuntary eye movements or their control. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of eye movement', 'ranked_candidates': [{'code': 'HP:0000496', 'term': 'Abnormality of eye movement', 'description': 'An abnormality in voluntary or involuntary eye movements or their control. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of eye movement': {\n",
      "  \"best_match_code\": \"HP:0000496\",\n",
      "  \"best_match_term\": \"Abnormality of eye movement\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 54\n",
      "✅ Extracted terms: ['Abnormality of eye size']\n",
      "🌐 [Abnormality of eye size] API Status: 404\n",
      "❌ Failed for term: Abnormality of eye size\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of eye size', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of globe size']\n",
      "🌐 [Abnormality of globe size] API Status: 200\n",
      "✅ Results for Abnormality of globe size: [{'code': 'HP:0100887', 'term': 'Abnormality of globe size', 'description': 'An abnormality in the size of the ocular globe (eyeball). [https://orcid.org/0009-0006-4530-3154]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of globe size', 'candidates': [{'code': 'HP:0100887', 'term': 'Abnormality of globe size', 'description': 'An abnormality in the size of the ocular globe (eyeball). [https://orcid.org/0009-0006-4530-3154]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of globe size': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100887\",\n",
      "    \"matched_term\": \"Abnormality of globe size\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Difference in eye size (microphthalmia/anophthalmia)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of globe size'], 'umls_mappings': [{'original': 'Abnormality of globe size', 'candidates': [{'code': 'HP:0100887', 'term': 'Abnormality of globe size', 'description': 'An abnormality in the size of the ocular globe (eyeball). [https://orcid.org/0009-0006-4530-3154]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of eye size', 'Abnormality of globe size'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of globe size', 'ranked_candidates': [{'code': 'HP:0100887', 'term': 'Abnormality of globe size', 'description': 'An abnormality in the size of the ocular globe (eyeball). [https://orcid.org/0009-0006-4530-3154]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of globe size': {\n",
      "  \"best_match_code\": \"HP:0100887\",\n",
      "  \"best_match_term\": \"Abnormality of globe size\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 55\n",
      "✅ Extracted terms: ['Abnormal iris morphology']\n",
      "🌐 [Abnormal iris morphology] API Status: 404\n",
      "❌ Failed for term: Abnormal iris morphology\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal iris morphology', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the iris']\n",
      "🌐 [Abnormality of the iris] API Status: 200\n",
      "✅ Results for Abnormality of the iris: [{'code': 'HP:0000525', 'term': 'Abnormality of the iris', 'description': 'An abnormality of the iris, which is the pigmented muscular tissue between the cornea and the lens, that is perforated by an opening called the pupil. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the iris', 'candidates': [{'code': 'HP:0000525', 'term': 'Abnormality of the iris', 'description': 'An abnormality of the iris, which is the pigmented muscular tissue between the cornea and the lens, that is perforated by an opening called the pupil. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the iris': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000525\",\n",
      "    \"matched_term\": \"Abnormality of the iris\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Unusual iris (spots, heterochromia)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the iris'], 'umls_mappings': [{'original': 'Abnormality of the iris', 'candidates': [{'code': 'HP:0000525', 'term': 'Abnormality of the iris', 'description': 'An abnormality of the iris, which is the pigmented muscular tissue between the cornea and the lens, that is perforated by an opening called the pupil. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the iris', 'Abnormal iris morphology'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the iris', 'ranked_candidates': [{'code': 'HP:0000525', 'term': 'Abnormality of the iris', 'description': 'An abnormality of the iris, which is the pigmented muscular tissue between the cornea and the lens, that is perforated by an opening called the pupil. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the iris': {\n",
      "  \"best_match_code\": \"HP:0000525\",\n",
      "  \"best_match_term\": \"Abnormality of the iris\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 56\n",
      "✅ Extracted terms: ['Abnormality of the lens']\n",
      "🌐 [Abnormality of the lens] API Status: 200\n",
      "✅ Results for Abnormality of the lens: [{'code': 'HP:0000517', 'term': 'Abnormality of the lens', 'description': 'An abnormality of the lens. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the lens', 'candidates': [{'code': 'HP:0000517', 'term': 'Abnormality of the lens', 'description': 'An abnormality of the lens. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the lens': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000517\",\n",
      "    \"matched_term\": \"Abnormality of the lens\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Lens issue (cataract, ectopia lentis)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the lens'], 'umls_mappings': [{'original': 'Abnormality of the lens', 'candidates': [{'code': 'HP:0000517', 'term': 'Abnormality of the lens', 'description': 'An abnormality of the lens. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the lens', 'ranked_candidates': [{'code': 'HP:0000517', 'term': 'Abnormality of the lens', 'description': 'An abnormality of the lens. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the lens': {\n",
      "  \"best_match_code\": \"HP:0000517\",\n",
      "  \"best_match_term\": \"Abnormality of the lens\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 57\n",
      "✅ Extracted terms: ['Abnormality of vision']\n",
      "🌐 [Abnormality of vision] API Status: 200\n",
      "✅ Results for Abnormality of vision: [{'code': 'HP:0000504', 'term': 'Abnormality of vision', 'description': 'Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of vision', 'candidates': [{'code': 'HP:0000504', 'term': 'Abnormality of vision', 'description': 'Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of vision': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000504\",\n",
      "    \"matched_term\": \"Abnormality of vision\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Major vision issues (blindness, color/night vision, photophobia)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of vision'], 'umls_mappings': [{'original': 'Abnormality of vision', 'candidates': [{'code': 'HP:0000504', 'term': 'Abnormality of vision', 'description': 'Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of vision', 'ranked_candidates': [{'code': 'HP:0000504', 'term': 'Abnormality of vision', 'description': 'Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of vision': {\n",
      "  \"best_match_code\": \"HP:0000504\",\n",
      "  \"best_match_term\": \"Abnormality of vision\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Major vision issues (blindness, color/night vision, photophobia)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of vision\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of vision\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000504\",\n",
      "          \"term\": \"Abnormality of vision\",\n",
      "          \"description\": \"Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of vision\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000504\",\n",
      "          \"term\": \"Abnormality of vision\",\n",
      "          \"description\": \"Abnormality of eyesight (visual perception). [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of vision\",\n",
      "      \"best_match_code\": \"HP:0000504\",\n",
      "      \"best_match_term\": \"Abnormality of vision\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4025846\n",
      "✅ Processed row 58\n",
      "✅ Extracted terms: ['Hyperopia']\n",
      "🌐 [Hyperopia] API Status: 200\n",
      "✅ Results for Hyperopia: [{'code': 'HP:0008499', 'term': 'High hyperopia', 'description': 'A severe form of hypermetropia with over +5.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter, https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0000540', 'term': 'Hyperopia', 'description': 'A refractive error in which rays of light entering the eye parallel to the optic axis are brought to a focus behind the retina, as a result of the eyeball being too short from front to back. It is also called farsightedness because the near point is more distant than it is in emmetropia with an equal amplitude of accommodation. (Dorland, 27th ed)'}, {'code': 'HP:0500042', 'term': 'Latent hyperopia', 'description': 'A term to describe when farsightedness is masked when the accommodative muscles are used to increase the focusing power of the eye. []'}, {'code': 'HP:0031728', 'term': 'Mild hyperopia', 'description': 'A form of hypermetropia with not more than +2.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hyperopia', 'candidates': [{'code': 'HP:0008499', 'term': 'High hyperopia', 'description': 'A severe form of hypermetropia with over +5.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter, https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0000540', 'term': 'Hyperopia', 'description': 'A refractive error in which rays of light entering the eye parallel to the optic axis are brought to a focus behind the retina, as a result of the eyeball being too short from front to back. It is also called farsightedness because the near point is more distant than it is in emmetropia with an equal amplitude of accommodation. (Dorland, 27th ed)'}, {'code': 'HP:0500042', 'term': 'Latent hyperopia', 'description': 'A term to describe when farsightedness is masked when the accommodative muscles are used to increase the focusing power of the eye. []'}, {'code': 'HP:0031728', 'term': 'Mild hyperopia', 'description': 'A form of hypermetropia with not more than +2.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hyperopia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000540\",\n",
      "    \"matched_term\": \"Hyperopia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008499\",\n",
      "    \"matched_term\": \"High hyperopia\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031728\",\n",
      "    \"matched_term\": \"Mild hyperopia\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0500042\",\n",
      "    \"matched_term\": \"Latent hyperopia\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Farsightedness (hyperopia)', 'field_type': 'radio', 'extracted_terms': ['Hyperopia'], 'umls_mappings': [{'original': 'Hyperopia', 'candidates': [{'code': 'HP:0008499', 'term': 'High hyperopia', 'description': 'A severe form of hypermetropia with over +5.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter, https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0000540', 'term': 'Hyperopia', 'description': 'A refractive error in which rays of light entering the eye parallel to the optic axis are brought to a focus behind the retina, as a result of the eyeball being too short from front to back. It is also called farsightedness because the near point is more distant than it is in emmetropia with an equal amplitude of accommodation. (Dorland, 27th ed)'}, {'code': 'HP:0500042', 'term': 'Latent hyperopia', 'description': 'A term to describe when farsightedness is masked when the accommodative muscles are used to increase the focusing power of the eye. []'}, {'code': 'HP:0031728', 'term': 'Mild hyperopia', 'description': 'A form of hypermetropia with not more than +2.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hyperopia', 'ranked_candidates': [{'code': 'HP:0000540', 'term': 'Hyperopia', 'description': 'A refractive error in which rays of light entering the eye parallel to the optic axis are brought to a focus behind the retina, as a result of the eyeball being too short from front to back. It is also called farsightedness because the near point is more distant than it is in emmetropia with an equal amplitude of accommodation. (Dorland, 27th ed)', 'confidence': 1.0}, {'code': 'HP:0008499', 'term': 'High hyperopia', 'description': 'A severe form of hypermetropia with over +5.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter, https://orcid.org/0000-0003-0986-4123]', 'confidence': 0.75}, {'code': 'HP:0500042', 'term': 'Latent hyperopia', 'description': 'A term to describe when farsightedness is masked when the accommodative muscles are used to increase the focusing power of the eye. []', 'confidence': 0.75}, {'code': 'HP:0031728', 'term': 'Mild hyperopia', 'description': 'A form of hypermetropia with not more than +2.00 diopters. [https://orcid.org/0000-0003-0986-4123]', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hyperopia': {\n",
      "  \"best_match_code\": \"HP:0000540\",\n",
      "  \"best_match_term\": \"Hyperopia\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 59\n",
      "✅ Extracted terms: ['Myopia']\n",
      "🌐 [Myopia] API Status: 200\n",
      "✅ Results for Myopia: [{'code': 'HP:0031730', 'term': 'Axial myopia', 'description': 'A form of myopia related to an axial length above the norm and too long for the refractive power of the whole optical system of the eye. [https://orcid.org/0000-0003-0986-4123, PMID:24113300]'}, {'code': 'HP:0011003', 'term': 'High myopia', 'description': 'A severe form of myopia with greater than -6.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter]'}, {'code': 'HP:0500066', 'term': 'Latent myopia', 'description': 'The difference between total and manifest myopia. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0025573', 'term': 'Mild myopia', 'description': 'A mild form of myopia with up to -3.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0031624', 'term': 'Moderate myopia', 'description': 'A moderate form of myopia with refractive error of between -3.00 and -6.00 diopters. []'}, {'code': 'HP:0000545', 'term': 'Myopia', 'description': 'A refractive error in which rays of light entering the EYE parallel to the optic axis are brought to a focus in front of the RETINA when accommodation (ACCOMMODATION, OCULAR) is relaxed. This results from an overly curved CORNEA or from the eyeball being too long from front to back. It is also called nearsightedness.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Myopia', 'candidates': [{'code': 'HP:0031730', 'term': 'Axial myopia', 'description': 'A form of myopia related to an axial length above the norm and too long for the refractive power of the whole optical system of the eye. [https://orcid.org/0000-0003-0986-4123, PMID:24113300]'}, {'code': 'HP:0011003', 'term': 'High myopia', 'description': 'A severe form of myopia with greater than -6.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter]'}, {'code': 'HP:0500066', 'term': 'Latent myopia', 'description': 'The difference between total and manifest myopia. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0025573', 'term': 'Mild myopia', 'description': 'A mild form of myopia with up to -3.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0031624', 'term': 'Moderate myopia', 'description': 'A moderate form of myopia with refractive error of between -3.00 and -6.00 diopters. []'}, {'code': 'HP:0000545', 'term': 'Myopia', 'description': 'A refractive error in which rays of light entering the EYE parallel to the optic axis are brought to a focus in front of the RETINA when accommodation (ACCOMMODATION, OCULAR) is relaxed. This results from an overly curved CORNEA or from the eyeball being too long from front to back. It is also called nearsightedness.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Myopia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000545\",\n",
      "    \"matched_term\": \"Myopia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031730\",\n",
      "    \"matched_term\": \"Axial myopia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011003\",\n",
      "    \"matched_term\": \"High myopia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0500066\",\n",
      "    \"matched_term\": \"Latent myopia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025573\",\n",
      "    \"matched_term\": \"Mild myopia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031624\",\n",
      "    \"matched_term\": \"Moderate myopia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Nearsightedness (myopia)', 'field_type': 'radio', 'extracted_terms': ['Myopia'], 'umls_mappings': [{'original': 'Myopia', 'candidates': [{'code': 'HP:0031730', 'term': 'Axial myopia', 'description': 'A form of myopia related to an axial length above the norm and too long for the refractive power of the whole optical system of the eye. [https://orcid.org/0000-0003-0986-4123, PMID:24113300]'}, {'code': 'HP:0011003', 'term': 'High myopia', 'description': 'A severe form of myopia with greater than -6.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter]'}, {'code': 'HP:0500066', 'term': 'Latent myopia', 'description': 'The difference between total and manifest myopia. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0025573', 'term': 'Mild myopia', 'description': 'A mild form of myopia with up to -3.00 diopters. [https://orcid.org/0000-0003-0986-4123]'}, {'code': 'HP:0031624', 'term': 'Moderate myopia', 'description': 'A moderate form of myopia with refractive error of between -3.00 and -6.00 diopters. []'}, {'code': 'HP:0000545', 'term': 'Myopia', 'description': 'A refractive error in which rays of light entering the EYE parallel to the optic axis are brought to a focus in front of the RETINA when accommodation (ACCOMMODATION, OCULAR) is relaxed. This results from an overly curved CORNEA or from the eyeball being too long from front to back. It is also called nearsightedness.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Myopia', 'ranked_candidates': [{'code': 'HP:0000545', 'term': 'Myopia', 'description': 'A refractive error in which rays of light entering the EYE parallel to the optic axis are brought to a focus in front of the RETINA when accommodation (ACCOMMODATION, OCULAR) is relaxed. This results from an overly curved CORNEA or from the eyeball being too long from front to back. It is also called nearsightedness.', 'confidence': 1.0}, {'code': 'HP:0031730', 'term': 'Axial myopia', 'description': 'A form of myopia related to an axial length above the norm and too long for the refractive power of the whole optical system of the eye. [https://orcid.org/0000-0003-0986-4123, PMID:24113300]', 'confidence': 0.7}, {'code': 'HP:0011003', 'term': 'High myopia', 'description': 'A severe form of myopia with greater than -6.00 diopters. [HPO_CONTRIBUTOR:DDD_ncarter]', 'confidence': 0.7}, {'code': 'HP:0500066', 'term': 'Latent myopia', 'description': 'The difference between total and manifest myopia. [https://orcid.org/0000-0003-0986-4123]', 'confidence': 0.7}, {'code': 'HP:0025573', 'term': 'Mild myopia', 'description': 'A mild form of myopia with up to -3.00 diopters. [https://orcid.org/0000-0003-0986-4123]', 'confidence': 0.7}, {'code': 'HP:0031624', 'term': 'Moderate myopia', 'description': 'A moderate form of myopia with refractive error of between -3.00 and -6.00 diopters. []', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Myopia': {\n",
      "  \"best_match_code\": \"HP:0000545\",\n",
      "  \"best_match_term\": \"Myopia\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 60\n",
      "✅ Extracted terms: ['Abnormality of the optic nerve']\n",
      "🌐 [Abnormality of the optic nerve] API Status: 200\n",
      "✅ Results for Abnormality of the optic nerve: [{'code': 'HP:0000587', 'term': 'Abnormality of the optic nerve', 'description': 'Abnormality of the optic nerve. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the optic nerve', 'candidates': [{'code': 'HP:0000587', 'term': 'Abnormality of the optic nerve', 'description': 'Abnormality of the optic nerve. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the optic nerve': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000587\",\n",
      "    \"matched_term\": \"Abnormality of the optic nerve\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Optic nerve issues', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the optic nerve'], 'umls_mappings': [{'original': 'Abnormality of the optic nerve', 'candidates': [{'code': 'HP:0000587', 'term': 'Abnormality of the optic nerve', 'description': 'Abnormality of the optic nerve. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the optic nerve', 'ranked_candidates': [{'code': 'HP:0000587', 'term': 'Abnormality of the optic nerve', 'description': 'Abnormality of the optic nerve. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the optic nerve': {\n",
      "  \"best_match_code\": \"HP:0000587\",\n",
      "  \"best_match_term\": \"Abnormality of the optic nerve\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 61\n",
      "✅ Extracted terms: ['Abnormality of the retina']\n",
      "🌐 [Abnormality of the retina] API Status: 200\n",
      "✅ Results for Abnormality of the retina: [{'code': 'HP:0000479', 'term': 'Abnormality of the retina', 'description': 'A structural abnormality of the retina. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007703', 'term': 'Abnormality of the retinal pigment epithelium', 'description': None}, {'code': 'HP:0008046', 'term': 'Abnormality of the retinal vasculature', 'description': 'A structural abnormality of retinal vasculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008051', 'term': 'obsolete Abnormality of the retinal pigment epithelium', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the retina', 'candidates': [{'code': 'HP:0000479', 'term': 'Abnormality of the retina', 'description': 'A structural abnormality of the retina. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007703', 'term': 'Abnormality of the retinal pigment epithelium', 'description': None}, {'code': 'HP:0008046', 'term': 'Abnormality of the retinal vasculature', 'description': 'A structural abnormality of retinal vasculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008051', 'term': 'obsolete Abnormality of the retinal pigment epithelium', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the retina': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000479\",\n",
      "    \"matched_term\": \"Abnormality of the retina\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007703\",\n",
      "    \"matched_term\": \"Abnormality of the retinal pigment epithelium\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008046\",\n",
      "    \"matched_term\": \"Abnormality of the retinal vasculature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008051\",\n",
      "    \"matched_term\": \"obsolete Abnormality of the retinal pigment epithelium\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Retina issues (incl. macula)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the retina'], 'umls_mappings': [{'original': 'Abnormality of the retina', 'candidates': [{'code': 'HP:0000479', 'term': 'Abnormality of the retina', 'description': 'A structural abnormality of the retina. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007703', 'term': 'Abnormality of the retinal pigment epithelium', 'description': None}, {'code': 'HP:0008046', 'term': 'Abnormality of the retinal vasculature', 'description': 'A structural abnormality of retinal vasculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008051', 'term': 'obsolete Abnormality of the retinal pigment epithelium', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the retina', 'ranked_candidates': [{'code': 'HP:0000479', 'term': 'Abnormality of the retina', 'description': 'A structural abnormality of the retina. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0007703', 'term': 'Abnormality of the retinal pigment epithelium', 'description': None, 'confidence': 0.7}, {'code': 'HP:0008046', 'term': 'Abnormality of the retinal vasculature', 'description': 'A structural abnormality of retinal vasculature. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0008051', 'term': 'obsolete Abnormality of the retinal pigment epithelium', 'description': None, 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the retina': {\n",
      "  \"best_match_code\": \"HP:0000479\",\n",
      "  \"best_match_term\": \"Abnormality of the retina\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 62\n",
      "✅ Extracted terms: ['Ptosis']\n",
      "🌐 [Ptosis] API Status: 200\n",
      "✅ Results for Ptosis: [{'code': 'HP:4000056', 'term': 'Abnormal apoptosis', 'description': 'Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]'}, {'code': 'HP:0030886', 'term': 'Abnormal lymphocyte apoptosis', 'description': 'A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]'}, {'code': 'HP:0001488', 'term': 'Bilateral ptosis', 'description': None}, {'code': 'HP:0000508', 'term': 'Blepharoptosis', 'description': 'Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Ptosis', 'candidates': [{'code': 'HP:4000056', 'term': 'Abnormal apoptosis', 'description': 'Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]'}, {'code': 'HP:0030886', 'term': 'Abnormal lymphocyte apoptosis', 'description': 'A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]'}, {'code': 'HP:0001488', 'term': 'Bilateral ptosis', 'description': None}, {'code': 'HP:0000508', 'term': 'Blepharoptosis', 'description': 'Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Ptosis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001488\",\n",
      "    \"matched_term\": \"Bilateral ptosis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000508\",\n",
      "    \"matched_term\": \"Blepharoptosis\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:4000056\",\n",
      "    \"matched_term\": \"Abnormal apoptosis\",\n",
      "    \"confidence\": \"0%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0030886\",\n",
      "    \"matched_term\": \"Abnormal lymphocyte apoptosis\",\n",
      "    \"confidence\": \"0%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Ptosis (drooping upper eyelid)', 'field_type': 'radio', 'extracted_terms': ['Ptosis'], 'umls_mappings': [{'original': 'Ptosis', 'candidates': [{'code': 'HP:4000056', 'term': 'Abnormal apoptosis', 'description': 'Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]'}, {'code': 'HP:0030886', 'term': 'Abnormal lymphocyte apoptosis', 'description': 'A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]'}, {'code': 'HP:0001488', 'term': 'Bilateral ptosis', 'description': None}, {'code': 'HP:0000508', 'term': 'Blepharoptosis', 'description': 'Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Ptosis', 'ranked_candidates': [{'code': 'HP:0001488', 'term': 'Bilateral ptosis', 'description': None, 'confidence': 1.0}, {'code': 'HP:0000508', 'term': 'Blepharoptosis', 'description': 'Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.', 'confidence': 0.9}, {'code': 'HP:4000056', 'term': 'Abnormal apoptosis', 'description': 'Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]', 'confidence': 0.0}, {'code': 'HP:0030886', 'term': 'Abnormal lymphocyte apoptosis', 'description': 'A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]', 'confidence': 0.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Ptosis': {\n",
      "  \"best_match_code\": \"HP:0001488\",\n",
      "  \"best_match_term\": \"Bilateral ptosis\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Ptosis (drooping upper eyelid)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Ptosis\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Ptosis\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:4000056\",\n",
      "          \"term\": \"Abnormal apoptosis\",\n",
      "          \"description\": \"Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0030886\",\n",
      "          \"term\": \"Abnormal lymphocyte apoptosis\",\n",
      "          \"description\": \"A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001488\",\n",
      "          \"term\": \"Bilateral ptosis\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000508\",\n",
      "          \"term\": \"Blepharoptosis\",\n",
      "          \"description\": \"Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Ptosis\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001488\",\n",
      "          \"term\": \"Bilateral ptosis\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000508\",\n",
      "          \"term\": \"Blepharoptosis\",\n",
      "          \"description\": \"Drooping of the upper lid due to deficient development or paralysis of the levator palpebrae muscle.\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:4000056\",\n",
      "          \"term\": \"Abnormal apoptosis\",\n",
      "          \"description\": \"Any abnormality of programmed cell death (apoptosis), which is defined as the orchestrated collapse of a cell characterized by membrane blebbing, cell shrinkage, condensation of chromatin, and fragmentation of DNA followed by rapid engulfment of the corpse by neighboring cells. Apoptosis is distinguished from death by necrosis by the absence of an associated inflammatory response. [PMID:11420279]\",\n",
      "          \"confidence\": 0.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0030886\",\n",
      "          \"term\": \"Abnormal lymphocyte apoptosis\",\n",
      "          \"description\": \"A anomaly in the rate of programmed cell death (apoptosis) in lymphocytes. [https://orcid.org/0000-0002-0736-9199, PMID:17562483]\",\n",
      "          \"confidence\": 0.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Ptosis\",\n",
      "      \"best_match_code\": \"HP:0001488\",\n",
      "      \"best_match_term\": \"Bilateral ptosis\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1865916\n",
      "✅ Processed row 63\n",
      "✅ Extracted terms: ['Coloboma']\n",
      "🌐 [Coloboma] API Status: 200\n",
      "✅ Results for Coloboma: [{'code': 'HP:0000567', 'term': 'Chorioretinal coloboma', 'description': 'Absence of a region of the retina, retinal pigment epithelium, and choroid. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0020006', 'term': 'Ciliary body coloboma', 'description': 'A coloboma of the ciliary body. []'}, {'code': 'HP:0000589', 'term': 'Coloboma', 'description': 'Congenital anomaly in which some of the structures of the eye are absent due to incomplete fusion of the fetal intraocular fissure during gestation.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Coloboma', 'candidates': [{'code': 'HP:0000567', 'term': 'Chorioretinal coloboma', 'description': 'Absence of a region of the retina, retinal pigment epithelium, and choroid. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0020006', 'term': 'Ciliary body coloboma', 'description': 'A coloboma of the ciliary body. []'}, {'code': 'HP:0000589', 'term': 'Coloboma', 'description': 'Congenital anomaly in which some of the structures of the eye are absent due to incomplete fusion of the fetal intraocular fissure during gestation.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Coloboma': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000589\",\n",
      "    \"matched_term\": \"Coloboma\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000567\",\n",
      "    \"matched_term\": \"Chorioretinal coloboma\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0020006\",\n",
      "    \"matched_term\": \"Ciliary body coloboma\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Coloboma (notched pupil)', 'field_type': 'radio', 'extracted_terms': ['Coloboma'], 'umls_mappings': [{'original': 'Coloboma', 'candidates': [{'code': 'HP:0000567', 'term': 'Chorioretinal coloboma', 'description': 'Absence of a region of the retina, retinal pigment epithelium, and choroid. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0020006', 'term': 'Ciliary body coloboma', 'description': 'A coloboma of the ciliary body. []'}, {'code': 'HP:0000589', 'term': 'Coloboma', 'description': 'Congenital anomaly in which some of the structures of the eye are absent due to incomplete fusion of the fetal intraocular fissure during gestation.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Coloboma', 'ranked_candidates': [{'code': 'HP:0000589', 'term': 'Coloboma', 'description': 'Congenital anomaly in which some of the structures of the eye are absent due to incomplete fusion of the fetal intraocular fissure during gestation.', 'confidence': 1.0}, {'code': 'HP:0000567', 'term': 'Chorioretinal coloboma', 'description': 'Absence of a region of the retina, retinal pigment epithelium, and choroid. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0020006', 'term': 'Ciliary body coloboma', 'description': 'A coloboma of the ciliary body. []', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Coloboma': {\n",
      "  \"best_match_code\": \"HP:0000589\",\n",
      "  \"best_match_term\": \"Coloboma\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 64\n",
      "✅ Extracted terms: ['Abnormality of the pinna']\n",
      "🌐 [Abnormality of the pinna] API Status: 404\n",
      "❌ Failed for term: Abnormality of the pinna\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the pinna', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the external ear']\n",
      "🌐 [Abnormality of the external ear] API Status: 200\n",
      "✅ Results for Abnormality of the external ear: [{'code': 'HP:0000356', 'term': 'Abnormality of the external ear', 'description': 'An abnormality of the external ear. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the external ear', 'candidates': [{'code': 'HP:0000356', 'term': 'Abnormality of the external ear', 'description': 'An abnormality of the external ear. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the external ear': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000356\",\n",
      "    \"matched_term\": \"Abnormality of the external ear\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Ear shape difference (over/under-developed, cupped, large)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the external ear'], 'umls_mappings': [{'original': 'Abnormality of the external ear', 'candidates': [{'code': 'HP:0000356', 'term': 'Abnormality of the external ear', 'description': 'An abnormality of the external ear. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the pinna', 'Abnormality of the external ear'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the external ear', 'ranked_candidates': [{'code': 'HP:0000356', 'term': 'Abnormality of the external ear', 'description': 'An abnormality of the external ear. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the external ear': {\n",
      "  \"best_match_code\": \"HP:0000356\",\n",
      "  \"best_match_term\": \"Abnormality of the external ear\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 65\n",
      "✅ Extracted terms: ['Conductive hearing impairment']\n",
      "🌐 [Conductive hearing impairment] API Status: 200\n",
      "✅ Results for Conductive hearing impairment: [{'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}, {'code': 'HP:0008591', 'term': 'Congenital conductive hearing impairment', 'description': 'A type of conductive deafness with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Conductive hearing impairment', 'candidates': [{'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}, {'code': 'HP:0008591', 'term': 'Congenital conductive hearing impairment', 'description': 'A type of conductive deafness with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Conductive hearing impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000405\",\n",
      "    \"matched_term\": \"Conductive hearing impairment\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008513\",\n",
      "    \"matched_term\": \"Bilateral conductive hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008591\",\n",
      "    \"matched_term\": \"Congenital conductive hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Conductive hearing loss', 'field_type': 'radio', 'extracted_terms': ['Conductive hearing impairment'], 'umls_mappings': [{'original': 'Conductive hearing impairment', 'candidates': [{'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}, {'code': 'HP:0008591', 'term': 'Congenital conductive hearing impairment', 'description': 'A type of conductive deafness with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 1, 'retries': 0, 'ranked_mappings': [{'original': 'Conductive hearing impairment', 'ranked_candidates': [{'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.', 'confidence': 1.0}, {'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0008591', 'term': 'Congenital conductive hearing impairment', 'description': 'A type of conductive deafness with congenital onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Conductive hearing impairment': {\n",
      "  \"best_match_code\": \"HP:0000405\",\n",
      "  \"best_match_term\": \"Conductive hearing impairment\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 66\n",
      "✅ Extracted terms: ['Sensorineural hearing impairment']\n",
      "🌐 [Sensorineural hearing impairment] API Status: 200\n",
      "✅ Results for Sensorineural hearing impairment: [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0008527', 'term': 'Congenital sensorineural hearing impairment', 'description': 'A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001757', 'term': 'High frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008610', 'term': 'Infantile sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008573', 'term': 'Low-frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008504', 'term': 'Moderate sensorineural hearing impairment', 'description': 'The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Sensorineural hearing impairment', 'candidates': [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0008527', 'term': 'Congenital sensorineural hearing impairment', 'description': 'A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001757', 'term': 'High frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008610', 'term': 'Infantile sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008573', 'term': 'Low-frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008504', 'term': 'Moderate sensorineural hearing impairment', 'description': 'The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Sensorineural hearing impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008619\",\n",
      "    \"matched_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008504\",\n",
      "    \"matched_term\": \"Moderate sensorineural hearing impairment\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001757\",\n",
      "    \"matched_term\": \"High frequency sensorineural hearing impairment\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008573\",\n",
      "    \"matched_term\": \"Low-frequency sensorineural hearing impairment\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008615\",\n",
      "    \"matched_term\": \"Adult onset sensorineural hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011474\",\n",
      "    \"matched_term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008527\",\n",
      "    \"matched_term\": \"Congenital sensorineural hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008610\",\n",
      "    \"matched_term\": \"Infantile sensorineural hearing impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Sensorineural hearing loss (SNHL)', 'field_type': 'radio', 'extracted_terms': ['Sensorineural hearing impairment'], 'umls_mappings': [{'original': 'Sensorineural hearing impairment', 'candidates': [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0008527', 'term': 'Congenital sensorineural hearing impairment', 'description': 'A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001757', 'term': 'High frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008610', 'term': 'Infantile sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008573', 'term': 'Low-frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008504', 'term': 'Moderate sensorineural hearing impairment', 'description': 'The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Sensorineural hearing impairment', 'ranked_candidates': [{'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0008504', 'term': 'Moderate sensorineural hearing impairment', 'description': 'The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.9}, {'code': 'HP:0001757', 'term': 'High frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0008573', 'term': 'Low-frequency sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]', 'confidence': 0.7}, {'code': 'HP:0008527', 'term': 'Congenital sensorineural hearing impairment', 'description': 'A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0008610', 'term': 'Infantile sensorineural hearing impairment', 'description': 'A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Sensorineural hearing impairment': {\n",
      "  \"best_match_code\": \"HP:0008619\",\n",
      "  \"best_match_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Sensorineural hearing loss (SNHL)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Sensorineural hearing impairment\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Sensorineural hearing impairment\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008615\",\n",
      "          \"term\": \"Adult onset sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008619\",\n",
      "          \"term\": \"Bilateral sensorineural hearing impairment\",\n",
      "          \"description\": \"A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011474\",\n",
      "          \"term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "          \"description\": \"Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008527\",\n",
      "          \"term\": \"Congenital sensorineural hearing impairment\",\n",
      "          \"description\": \"A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001757\",\n",
      "          \"term\": \"High frequency sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008610\",\n",
      "          \"term\": \"Infantile sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008573\",\n",
      "          \"term\": \"Low-frequency sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008504\",\n",
      "          \"term\": \"Moderate sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Sensorineural hearing impairment\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008619\",\n",
      "          \"term\": \"Bilateral sensorineural hearing impairment\",\n",
      "          \"description\": \"A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008504\",\n",
      "          \"term\": \"Moderate sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of a moderate form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001757\",\n",
      "          \"term\": \"High frequency sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment that affects primarily the higher frequencies. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008573\",\n",
      "          \"term\": \"Low-frequency sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment that affects primarily the lower frequencies. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008615\",\n",
      "          \"term\": \"Adult onset sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011474\",\n",
      "          \"term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "          \"description\": \"Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008527\",\n",
      "          \"term\": \"Congenital sensorineural hearing impairment\",\n",
      "          \"description\": \"A type of hearing impairment caused by an abnormal functionality of the cochlear nerve with congenital onset. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008610\",\n",
      "          \"term\": \"Infantile sensorineural hearing impairment\",\n",
      "          \"description\": \"A form of sensorineural hearing impairment with infantile onset. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Sensorineural hearing impairment\",\n",
      "      \"best_match_code\": \"HP:0008619\",\n",
      "      \"best_match_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0452138\n",
      "🧩 ancestor_cuis ['C0012634', 'C0018784', 'C1320354', 'C1285159', 'C0574123', 'C0455931', 'C1455844', 'C0574125', 'C4750514', 'C0575142', 'C0423477', 'C0013447', 'C5848261', 'C1290856', 'C4750513', 'C4750518', 'C1384666', 'C0395797', 'C2720507', 'C0037088', 'C5817615', 'C5848260']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0018784', 'name': 'Sensorineural hearing loss (disorder)'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0574123', 'name': 'Ear, nose and throat finding'}, {'cui': 'C0455931', 'name': 'Ear and auditory finding'}, {'cui': 'C1455844', 'name': 'Hearing finding'}, {'cui': 'C0574125', 'name': 'Functional finding'}, {'cui': 'C4750514', 'name': 'Disorder of right ear'}, {'cui': 'C0575142', 'name': 'Finding of head region'}, {'cui': 'C0423477', 'name': 'Ear finding'}, {'cui': 'C0013447', 'name': 'Ear diseases'}, {'cui': 'C5848261', 'name': 'Disorder of hearing'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C4750513', 'name': 'Disorder of left ear'}, {'cui': 'C4750518', 'name': 'Bilateral disorder of ears'}, {'cui': 'C1384666', 'name': 'Hearing impairment'}, {'cui': 'C0395797', 'name': 'Ear, nose and throat disorder'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C5817615', 'name': 'Disorder of sensory organ'}, {'cui': 'C5848260', 'name': 'Disorder of auditory system'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Sensorineural hearing loss (SNHL)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Sensorineural hearing impairment\"\n",
      "  \"best_match_code\": \"HP:0008619\",\n",
      "  \"best_match_term\": \"Bilateral sensorineural hearing impairment\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0018784 (Sensorineural hearing loss (disorder))\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0574123 (Ear, nose and throat finding)\n",
      "- C0455931 (Ear and auditory finding)\n",
      "- C1455844 (Hearing finding)\n",
      "- C0574125 (Functional finding)\n",
      "- C4750514 (Disorder of right ear)\n",
      "- C0575142 (Finding of head region)\n",
      "- C0423477 (Ear finding)\n",
      "- C0013447 (Ear diseases)\n",
      "- C5848261 (Disorder of hearing)\n",
      "- C1290856 (Disorder of head)\n",
      "- C4750513 (Disorder of left ear)\n",
      "- C4750518 (Bilateral disorder of ears)\n",
      "- C1384666 (Hearing impairment)\n",
      "- C0395797 (Ear, nose and throat disorder)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C5817615 (Disorder of sensory organ)\n",
      "- C5848260 (Disorder of auditory system)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0000407\",\\n  \"refined_term\": \"Sensorineural hearing impairment\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 35, 'prompt_tokens': 756, 'total_tokens': 791, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeEtolpBeWJIt6vXgSudpp0g3W1k', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--e0128fb1-3383-49e0-8851-f35ef93e994b-0' usage_metadata={'input_tokens': 756, 'output_tokens': 35, 'total_tokens': 791, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Sensorineural hearing impairment\n",
      "🧠 LLM refined_code: HP:0000407\n",
      "✅ Processed row 67\n",
      "✅ Extracted terms: ['Mixed hearing impairment']\n",
      "🌐 [Mixed hearing impairment] API Status: 200\n",
      "✅ Results for Mixed hearing impairment: [{'code': 'HP:0000410', 'term': 'Mixed hearing impairment', 'description': 'Hearing loss characterized by a combination of conductive and sensorineural hearing loss. It is caused by problems in both the inner ear and middle or outer ear.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Mixed hearing impairment', 'candidates': [{'code': 'HP:0000410', 'term': 'Mixed hearing impairment', 'description': 'Hearing loss characterized by a combination of conductive and sensorineural hearing loss. It is caused by problems in both the inner ear and middle or outer ear.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Mixed hearing impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000410\",\n",
      "    \"matched_term\": \"Mixed hearing impairment\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Mixed hearing loss', 'field_type': 'radio', 'extracted_terms': ['Mixed hearing impairment'], 'umls_mappings': [{'original': 'Mixed hearing impairment', 'candidates': [{'code': 'HP:0000410', 'term': 'Mixed hearing impairment', 'description': 'Hearing loss characterized by a combination of conductive and sensorineural hearing loss. It is caused by problems in both the inner ear and middle or outer ear.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Mixed hearing impairment', 'ranked_candidates': [{'code': 'HP:0000410', 'term': 'Mixed hearing impairment', 'description': 'Hearing loss characterized by a combination of conductive and sensorineural hearing loss. It is caused by problems in both the inner ear and middle or outer ear.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Mixed hearing impairment': {\"best_match_code\": \"HP:0000410\", \"best_match_term\": \"Mixed hearing impairment\", \"confidence\": \"90%\"}\n",
      "✅ Processed row 68\n",
      "✅ Extracted terms: ['Hearing impairment']\n",
      "🌐 [Hearing impairment] API Status: 200\n",
      "✅ Results for Hearing impairment: [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hearing impairment', 'candidates': [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hearing impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008619\",\n",
      "    \"matched_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "    \"confidence\": \"85%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008513\",\n",
      "    \"matched_term\": \"Bilateral conductive hearing impairment\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000405\",\n",
      "    \"matched_term\": \"Conductive hearing impairment\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008615\",\n",
      "    \"matched_term\": \"Adult onset sensorineural hearing impairment\",\n",
      "    \"confidence\": \"65%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011474\",\n",
      "    \"matched_term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "    \"confidence\": \"65%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hearing loss, unsure which type', 'field_type': 'radio', 'extracted_terms': ['Hearing impairment'], 'umls_mappings': [{'original': 'Hearing impairment', 'candidates': [{'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]'}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hearing impairment', 'ranked_candidates': [{'code': 'HP:0008619', 'term': 'Bilateral sensorineural hearing impairment', 'description': 'A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.85}, {'code': 'HP:0008513', 'term': 'Bilateral conductive hearing impairment', 'description': 'A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0000405', 'term': 'Conductive hearing impairment', 'description': 'Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.', 'confidence': 0.75}, {'code': 'HP:0008615', 'term': 'Adult onset sensorineural hearing impairment', 'description': 'The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.65}, {'code': 'HP:0011474', 'term': 'Childhood onset sensorineural hearing impairment', 'description': 'Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]', 'confidence': 0.65}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hearing impairment': {\n",
      "  \"best_match_code\": \"HP:0008619\",\n",
      "  \"best_match_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "  \"confidence\": \"50%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Hearing loss, unsure which type\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Hearing impairment\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hearing impairment\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008615\",\n",
      "          \"term\": \"Adult onset sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008513\",\n",
      "          \"term\": \"Bilateral conductive hearing impairment\",\n",
      "          \"description\": \"A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008619\",\n",
      "          \"term\": \"Bilateral sensorineural hearing impairment\",\n",
      "          \"description\": \"A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011474\",\n",
      "          \"term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "          \"description\": \"Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000405\",\n",
      "          \"term\": \"Conductive hearing impairment\",\n",
      "          \"description\": \"Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hearing impairment\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0008619\",\n",
      "          \"term\": \"Bilateral sensorineural hearing impairment\",\n",
      "          \"description\": \"A bilateral form of sensorineural hearing impairment. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.85\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008513\",\n",
      "          \"term\": \"Bilateral conductive hearing impairment\",\n",
      "          \"description\": \"A bilateral type of conductive hearing impairment. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000405\",\n",
      "          \"term\": \"Conductive hearing impairment\",\n",
      "          \"description\": \"Hearing loss due to interference with the mechanical reception or amplification of sound to the COCHLEA. The interference is in the outer or middle ear involving the EAR CANAL; TYMPANIC MEMBRANE; or EAR OSSICLES.\",\n",
      "          \"confidence\": 0.75\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0008615\",\n",
      "          \"term\": \"Adult onset sensorineural hearing impairment\",\n",
      "          \"description\": \"The presence of sensorineural deafness with late onset. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.65\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011474\",\n",
      "          \"term\": \"Childhood onset sensorineural hearing impairment\",\n",
      "          \"description\": \"Sensorineural hearing impairment with childhood onset. [HPO_CONTRIBUTOR:DDD_dfitzpatrick]\",\n",
      "          \"confidence\": 0.65\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Hearing impairment\",\n",
      "      \"best_match_code\": \"HP:0008619\",\n",
      "      \"best_match_term\": \"Bilateral sensorineural hearing impairment\",\n",
      "      \"confidence\": 0.5\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0452138\n",
      "🧩 ancestor_cuis ['C0012634', 'C0018784', 'C1320354', 'C1285159', 'C0574123', 'C0455931', 'C1455844', 'C0574125', 'C4750514', 'C0575142', 'C0423477', 'C0013447', 'C5848261', 'C1290856', 'C4750513', 'C4750518', 'C1384666', 'C0395797', 'C2720507', 'C0037088', 'C5817615', 'C5848260']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0018784', 'name': 'Sensorineural hearing loss (disorder)'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0574123', 'name': 'Ear, nose and throat finding'}, {'cui': 'C0455931', 'name': 'Ear and auditory finding'}, {'cui': 'C1455844', 'name': 'Hearing finding'}, {'cui': 'C0574125', 'name': 'Functional finding'}, {'cui': 'C4750514', 'name': 'Disorder of right ear'}, {'cui': 'C0575142', 'name': 'Finding of head region'}, {'cui': 'C0423477', 'name': 'Ear finding'}, {'cui': 'C0013447', 'name': 'Ear diseases'}, {'cui': 'C5848261', 'name': 'Disorder of hearing'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C4750513', 'name': 'Disorder of left ear'}, {'cui': 'C4750518', 'name': 'Bilateral disorder of ears'}, {'cui': 'C1384666', 'name': 'Hearing impairment'}, {'cui': 'C0395797', 'name': 'Ear, nose and throat disorder'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C5817615', 'name': 'Disorder of sensory organ'}, {'cui': 'C5848260', 'name': 'Disorder of auditory system'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Hearing loss, unsure which type\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Hearing impairment\"\n",
      "  \"best_match_code\": \"HP:0008619\",\n",
      "  \"best_match_term\": \"Bilateral sensorineural hearing impairment\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0018784 (Sensorineural hearing loss (disorder))\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0574123 (Ear, nose and throat finding)\n",
      "- C0455931 (Ear and auditory finding)\n",
      "- C1455844 (Hearing finding)\n",
      "- C0574125 (Functional finding)\n",
      "- C4750514 (Disorder of right ear)\n",
      "- C0575142 (Finding of head region)\n",
      "- C0423477 (Ear finding)\n",
      "- C0013447 (Ear diseases)\n",
      "- C5848261 (Disorder of hearing)\n",
      "- C1290856 (Disorder of head)\n",
      "- C4750513 (Disorder of left ear)\n",
      "- C4750518 (Bilateral disorder of ears)\n",
      "- C1384666 (Hearing impairment)\n",
      "- C0395797 (Ear, nose and throat disorder)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C5817615 (Disorder of sensory organ)\n",
      "- C5848260 (Disorder of auditory system)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0000365\",\\n  \"refined_term\": \"Hearing impairment\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 33, 'prompt_tokens': 752, 'total_tokens': 785, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeFFCNj3c3rX004um544Oip2vQTX', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--d2491aed-deb5-4495-8c97-dfcf6761e97c-0' usage_metadata={'input_tokens': 752, 'output_tokens': 33, 'total_tokens': 785, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Hearing impairment\n",
      "🧠 LLM refined_code: HP:0000365\n",
      "✅ Processed row 69\n",
      "✅ Extracted terms: ['Tinnitus']\n",
      "🌐 [Tinnitus] API Status: 200\n",
      "✅ Results for Tinnitus: [{'code': 'HP:0034424', 'term': 'Clicking tinnitus', 'description': 'A type of tinnitus that presents as clicks, resembling the noise made by the snapping together of 2 fingers. [PMID:34147152]'}, {'code': 'HP:0000361', 'term': 'obsolete Pulsatile tinnitus (tympanic paraganglioma)', 'description': None}, {'code': 'HP:0008629', 'term': 'Pulsatile tinnitus', 'description': 'Pulsatile tinnitus is generally classified a kind of objective tinnitus, meaning that it is not only audible to the patient but also to the examiner on auscultation of the auditory canal and/or of surrounding structures with use of an auscultation tube or stethoscope. Usually, pulsatile tinnitus is heard as a lower pitched thumping or booming, a rougher blowing sound which is coincidental with respiration, or as a clicking, higher pitched rhythmic sensation. [PMID:23885280]'}, {'code': 'HP:0000360', 'term': 'Tinnitus', 'description': 'A nonspecific symptom of hearing disorder characterized by the sensation of buzzing, ringing, clicking, pulsations, and other noises in the ear. Objective tinnitus refers to noises generated from within the ear or adjacent structures that can be heard by other individuals. The term subjective tinnitus is used when the sound is audible only to the affected individual. Tinnitus may occur as a manifestation of COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; INTRACRANIAL HYPERTENSION; CRANIOCEREBRAL TRAUMA; and other conditions.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Tinnitus', 'candidates': [{'code': 'HP:0034424', 'term': 'Clicking tinnitus', 'description': 'A type of tinnitus that presents as clicks, resembling the noise made by the snapping together of 2 fingers. [PMID:34147152]'}, {'code': 'HP:0000361', 'term': 'obsolete Pulsatile tinnitus (tympanic paraganglioma)', 'description': None}, {'code': 'HP:0008629', 'term': 'Pulsatile tinnitus', 'description': 'Pulsatile tinnitus is generally classified a kind of objective tinnitus, meaning that it is not only audible to the patient but also to the examiner on auscultation of the auditory canal and/or of surrounding structures with use of an auscultation tube or stethoscope. Usually, pulsatile tinnitus is heard as a lower pitched thumping or booming, a rougher blowing sound which is coincidental with respiration, or as a clicking, higher pitched rhythmic sensation. [PMID:23885280]'}, {'code': 'HP:0000360', 'term': 'Tinnitus', 'description': 'A nonspecific symptom of hearing disorder characterized by the sensation of buzzing, ringing, clicking, pulsations, and other noises in the ear. Objective tinnitus refers to noises generated from within the ear or adjacent structures that can be heard by other individuals. The term subjective tinnitus is used when the sound is audible only to the affected individual. Tinnitus may occur as a manifestation of COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; INTRACRANIAL HYPERTENSION; CRANIOCEREBRAL TRAUMA; and other conditions.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Tinnitus': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000360\",\n",
      "    \"matched_term\": \"Tinnitus\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0034424\",\n",
      "    \"matched_term\": \"Clicking tinnitus\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008629\",\n",
      "    \"matched_term\": \"Pulsatile tinnitus\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000361\",\n",
      "    \"matched_term\": \"obsolete Pulsatile tinnitus (tympanic paraganglioma)\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Ringing in the ears (tinnitus)', 'field_type': 'radio', 'extracted_terms': ['Tinnitus'], 'umls_mappings': [{'original': 'Tinnitus', 'candidates': [{'code': 'HP:0034424', 'term': 'Clicking tinnitus', 'description': 'A type of tinnitus that presents as clicks, resembling the noise made by the snapping together of 2 fingers. [PMID:34147152]'}, {'code': 'HP:0000361', 'term': 'obsolete Pulsatile tinnitus (tympanic paraganglioma)', 'description': None}, {'code': 'HP:0008629', 'term': 'Pulsatile tinnitus', 'description': 'Pulsatile tinnitus is generally classified a kind of objective tinnitus, meaning that it is not only audible to the patient but also to the examiner on auscultation of the auditory canal and/or of surrounding structures with use of an auscultation tube or stethoscope. Usually, pulsatile tinnitus is heard as a lower pitched thumping or booming, a rougher blowing sound which is coincidental with respiration, or as a clicking, higher pitched rhythmic sensation. [PMID:23885280]'}, {'code': 'HP:0000360', 'term': 'Tinnitus', 'description': 'A nonspecific symptom of hearing disorder characterized by the sensation of buzzing, ringing, clicking, pulsations, and other noises in the ear. Objective tinnitus refers to noises generated from within the ear or adjacent structures that can be heard by other individuals. The term subjective tinnitus is used when the sound is audible only to the affected individual. Tinnitus may occur as a manifestation of COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; INTRACRANIAL HYPERTENSION; CRANIOCEREBRAL TRAUMA; and other conditions.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Tinnitus', 'ranked_candidates': [{'code': 'HP:0000360', 'term': 'Tinnitus', 'description': 'A nonspecific symptom of hearing disorder characterized by the sensation of buzzing, ringing, clicking, pulsations, and other noises in the ear. Objective tinnitus refers to noises generated from within the ear or adjacent structures that can be heard by other individuals. The term subjective tinnitus is used when the sound is audible only to the affected individual. Tinnitus may occur as a manifestation of COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; INTRACRANIAL HYPERTENSION; CRANIOCEREBRAL TRAUMA; and other conditions.', 'confidence': 1.0}, {'code': 'HP:0034424', 'term': 'Clicking tinnitus', 'description': 'A type of tinnitus that presents as clicks, resembling the noise made by the snapping together of 2 fingers. [PMID:34147152]', 'confidence': 0.7}, {'code': 'HP:0008629', 'term': 'Pulsatile tinnitus', 'description': 'Pulsatile tinnitus is generally classified a kind of objective tinnitus, meaning that it is not only audible to the patient but also to the examiner on auscultation of the auditory canal and/or of surrounding structures with use of an auscultation tube or stethoscope. Usually, pulsatile tinnitus is heard as a lower pitched thumping or booming, a rougher blowing sound which is coincidental with respiration, or as a clicking, higher pitched rhythmic sensation. [PMID:23885280]', 'confidence': 0.7}, {'code': 'HP:0000361', 'term': 'obsolete Pulsatile tinnitus (tympanic paraganglioma)', 'description': None, 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Tinnitus': {\n",
      "  \"best_match_code\": \"HP:0000360\",\n",
      "  \"best_match_term\": \"Tinnitus\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 70\n",
      "✅ Extracted terms: ['Hyperacusis']\n",
      "🌐 [Hyperacusis] API Status: 200\n",
      "✅ Results for Hyperacusis: [{'code': 'HP:0010780', 'term': 'Hyperacusis', 'description': 'An abnormally disproportionate increase in the sensation of loudness in response to auditory stimuli of normal volume. COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; FACIAL NERVE DISEASES; STAPES SURGERY; and other disorders may be associated with this condition.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hyperacusis', 'candidates': [{'code': 'HP:0010780', 'term': 'Hyperacusis', 'description': 'An abnormally disproportionate increase in the sensation of loudness in response to auditory stimuli of normal volume. COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; FACIAL NERVE DISEASES; STAPES SURGERY; and other disorders may be associated with this condition.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hyperacusis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010780\",\n",
      "    \"matched_term\": \"Hyperacusis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hyperacusis (sound hypersensitivity)', 'field_type': 'radio', 'extracted_terms': ['Hyperacusis'], 'umls_mappings': [{'original': 'Hyperacusis', 'candidates': [{'code': 'HP:0010780', 'term': 'Hyperacusis', 'description': 'An abnormally disproportionate increase in the sensation of loudness in response to auditory stimuli of normal volume. COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; FACIAL NERVE DISEASES; STAPES SURGERY; and other disorders may be associated with this condition.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hyperacusis', 'ranked_candidates': [{'code': 'HP:0010780', 'term': 'Hyperacusis', 'description': 'An abnormally disproportionate increase in the sensation of loudness in response to auditory stimuli of normal volume. COCHLEAR DISEASES; VESTIBULOCOCHLEAR NERVE DISEASES; FACIAL NERVE DISEASES; STAPES SURGERY; and other disorders may be associated with this condition.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hyperacusis': {\n",
      "  \"best_match_code\": \"HP:0010780\",\n",
      "  \"best_match_term\": \"Hyperacusis\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 71\n",
      "✅ Extracted terms: ['Dizziness']\n",
      "🌐 [Dizziness] API Status: 200\n",
      "✅ Results for Dizziness: [{'code': 'HP:0002321', 'term': 'Dizziness', 'description': 'An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Dizziness', 'candidates': [{'code': 'HP:0002321', 'term': 'Dizziness', 'description': 'An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Dizziness': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002321\",\n",
      "    \"matched_term\": \"Dizziness\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Dizziness (vertigo)', 'field_type': 'radio', 'extracted_terms': ['Dizziness'], 'umls_mappings': [{'original': 'Dizziness', 'candidates': [{'code': 'HP:0002321', 'term': 'Dizziness', 'description': 'An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Dizziness', 'ranked_candidates': [{'code': 'HP:0002321', 'term': 'Dizziness', 'description': 'An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Dizziness': {\n",
      "  \"best_match_code\": \"HP:0002321\",\n",
      "  \"best_match_term\": \"Dizziness\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Dizziness (vertigo)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Dizziness\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Dizziness\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002321\",\n",
      "          \"term\": \"Dizziness\",\n",
      "          \"description\": \"An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Dizziness\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002321\",\n",
      "          \"term\": \"Dizziness\",\n",
      "          \"description\": \"An imprecise term which may refer to a sense of spatial disorientation, motion of the environment, or lightheadedness.\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Dizziness\",\n",
      "      \"best_match_code\": \"HP:0002321\",\n",
      "      \"best_match_term\": \"Dizziness\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0012833\n",
      "🧩 ancestor_cuis ['C2720507', 'C0037088', 'C0422837']\n",
      "🧩 candidate_details [{'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0422837', 'name': 'Neurological observations'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Dizziness (vertigo)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Dizziness\"\n",
      "  \"best_match_code\": \"HP:0002321\",\n",
      "  \"best_match_term\": \"Dizziness\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0422837 (Neurological observations)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 533, 'total_tokens': 534, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeFjMYOISKZUSi19wKvvZYZ4WZXI', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--fba4548a-0ad0-47ea-85bf-03c5bd4cafbf-0' usage_metadata={'input_tokens': 533, 'output_tokens': 1, 'total_tokens': 534, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 72\n",
      "✅ Extracted terms: ['Abnormal central nervous system morphology']\n",
      "🌐 [Abnormal central nervous system morphology] API Status: 404\n",
      "❌ Failed for term: Abnormal central nervous system morphology\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal central nervous system morphology', 'candidates': []}]\n",
      "✅ Revised terms: ['Neuroimaging abnormality']\n",
      "🌐 [Neuroimaging abnormality] API Status: 404\n",
      "❌ Failed for term: Neuroimaging abnormality\n",
      "🧪 Final UMLS mappings: [{'original': 'Neuroimaging abnormality', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the central nervous system']\n",
      "🌐 [Abnormality of the central nervous system] API Status: 200\n",
      "✅ Results for Abnormality of the central nervous system: [{'code': 'HP:0002011', 'term': 'Abnormality of the central nervous system', 'description': 'A structural abnormality of the central nervous system. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the central nervous system', 'candidates': [{'code': 'HP:0002011', 'term': 'Abnormality of the central nervous system', 'description': 'A structural abnormality of the central nervous system. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the central nervous system': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002011\",\n",
      "    \"matched_term\": \"Abnormality of the central nervous system\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Brain and/or spinal cord issue (MRI structural issues)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the central nervous system'], 'umls_mappings': [{'original': 'Abnormality of the central nervous system', 'candidates': [{'code': 'HP:0002011', 'term': 'Abnormality of the central nervous system', 'description': 'A structural abnormality of the central nervous system. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 2, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Neuroimaging abnormality', 'Abnormal central nervous system morphology', 'Abnormality of the central nervous system'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the central nervous system', 'ranked_candidates': [{'code': 'HP:0002011', 'term': 'Abnormality of the central nervous system', 'description': 'A structural abnormality of the central nervous system. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the central nervous system': {\n",
      "  \"best_match_code\": \"HP:0002011\",\n",
      "  \"best_match_term\": \"Abnormality of the central nervous system\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 73\n",
      "✅ Extracted terms: ['Cerebral palsy']\n",
      "🌐 [Cerebral palsy] API Status: 200\n",
      "✅ Results for Cerebral palsy: [{'code': 'HP:0011445', 'term': 'Athetoid cerebral palsy', 'description': 'A subtype of cerebral palsy characterized by involuntary, purposeless writhing movements which affect the hands, feet, arms, and legs; the face and tongue may be affected as well, leading to involuntary grimacing, drooling, dysarthria and difficulty eating.'}, {'code': 'HP:0100021', 'term': 'Cerebral palsy', 'description': 'A heterogeneous group of nonprogressive motor disorders caused by chronic brain injuries that originate in the prenatal period, perinatal period, or first few years of life. The four major subtypes are spastic, athetoid, ataxic, and mixed cerebral palsy, with spastic forms being the most common. The motor disorder may range from difficulties with fine motor control to severe spasticity (see MUSCLE SPASTICITY) in all limbs. Spastic diplegia (Little disease) is the most common subtype, and is characterized by spasticity that is more prominent in the legs than in the arms. Pathologically, this condition may be associated with LEUKOMALACIA, PERIVENTRICULAR. (From Dev Med Child Neurol 1998 Aug;40(8):520-7)'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Cerebral palsy', 'candidates': [{'code': 'HP:0011445', 'term': 'Athetoid cerebral palsy', 'description': 'A subtype of cerebral palsy characterized by involuntary, purposeless writhing movements which affect the hands, feet, arms, and legs; the face and tongue may be affected as well, leading to involuntary grimacing, drooling, dysarthria and difficulty eating.'}, {'code': 'HP:0100021', 'term': 'Cerebral palsy', 'description': 'A heterogeneous group of nonprogressive motor disorders caused by chronic brain injuries that originate in the prenatal period, perinatal period, or first few years of life. The four major subtypes are spastic, athetoid, ataxic, and mixed cerebral palsy, with spastic forms being the most common. The motor disorder may range from difficulties with fine motor control to severe spasticity (see MUSCLE SPASTICITY) in all limbs. Spastic diplegia (Little disease) is the most common subtype, and is characterized by spasticity that is more prominent in the legs than in the arms. Pathologically, this condition may be associated with LEUKOMALACIA, PERIVENTRICULAR. (From Dev Med Child Neurol 1998 Aug;40(8):520-7)'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Cerebral palsy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100021\",\n",
      "    \"matched_term\": \"Cerebral palsy\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011445\",\n",
      "    \"matched_term\": \"Athetoid cerebral palsy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Cerebral palsy (CP)', 'field_type': 'radio', 'extracted_terms': ['Cerebral palsy'], 'umls_mappings': [{'original': 'Cerebral palsy', 'candidates': [{'code': 'HP:0011445', 'term': 'Athetoid cerebral palsy', 'description': 'A subtype of cerebral palsy characterized by involuntary, purposeless writhing movements which affect the hands, feet, arms, and legs; the face and tongue may be affected as well, leading to involuntary grimacing, drooling, dysarthria and difficulty eating.'}, {'code': 'HP:0100021', 'term': 'Cerebral palsy', 'description': 'A heterogeneous group of nonprogressive motor disorders caused by chronic brain injuries that originate in the prenatal period, perinatal period, or first few years of life. The four major subtypes are spastic, athetoid, ataxic, and mixed cerebral palsy, with spastic forms being the most common. The motor disorder may range from difficulties with fine motor control to severe spasticity (see MUSCLE SPASTICITY) in all limbs. Spastic diplegia (Little disease) is the most common subtype, and is characterized by spasticity that is more prominent in the legs than in the arms. Pathologically, this condition may be associated with LEUKOMALACIA, PERIVENTRICULAR. (From Dev Med Child Neurol 1998 Aug;40(8):520-7)'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Cerebral palsy', 'ranked_candidates': [{'code': 'HP:0100021', 'term': 'Cerebral palsy', 'description': 'A heterogeneous group of nonprogressive motor disorders caused by chronic brain injuries that originate in the prenatal period, perinatal period, or first few years of life. The four major subtypes are spastic, athetoid, ataxic, and mixed cerebral palsy, with spastic forms being the most common. The motor disorder may range from difficulties with fine motor control to severe spasticity (see MUSCLE SPASTICITY) in all limbs. Spastic diplegia (Little disease) is the most common subtype, and is characterized by spasticity that is more prominent in the legs than in the arms. Pathologically, this condition may be associated with LEUKOMALACIA, PERIVENTRICULAR. (From Dev Med Child Neurol 1998 Aug;40(8):520-7)', 'confidence': 1.0}, {'code': 'HP:0011445', 'term': 'Athetoid cerebral palsy', 'description': 'A subtype of cerebral palsy characterized by involuntary, purposeless writhing movements which affect the hands, feet, arms, and legs; the face and tongue may be affected as well, leading to involuntary grimacing, drooling, dysarthria and difficulty eating.', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Cerebral palsy': {\n",
      "  \"best_match_code\": \"HP:0100021\",\n",
      "  \"best_match_term\": \"Cerebral palsy\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 74\n",
      "✅ Extracted terms: ['Cognitive impairment']\n",
      "🌐 [Cognitive impairment] API Status: 200\n",
      "✅ Results for Cognitive impairment: [{'code': 'HP:0100543', 'term': 'Cognitive impairment', 'description': 'Interference or disruption of cognitive processes. This term encompasses a large number of problems and issues associated with intellectual functioning and information processing. 2005'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Cognitive impairment', 'candidates': [{'code': 'HP:0100543', 'term': 'Cognitive impairment', 'description': 'Interference or disruption of cognitive processes. This term encompasses a large number of problems and issues associated with intellectual functioning and information processing. 2005'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Cognitive impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100543\",\n",
      "    \"matched_term\": \"Cognitive impairment\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Cognitive impairment', 'field_type': 'radio', 'extracted_terms': ['Cognitive impairment'], 'umls_mappings': [{'original': 'Cognitive impairment', 'candidates': [{'code': 'HP:0100543', 'term': 'Cognitive impairment', 'description': 'Interference or disruption of cognitive processes. This term encompasses a large number of problems and issues associated with intellectual functioning and information processing. 2005'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Cognitive impairment', 'ranked_candidates': [{'code': 'HP:0100543', 'term': 'Cognitive impairment', 'description': 'Interference or disruption of cognitive processes. This term encompasses a large number of problems and issues associated with intellectual functioning and information processing. 2005', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Cognitive impairment': {\n",
      "  \"best_match_code\": \"HP:0100543\",\n",
      "  \"best_match_term\": \"Cognitive impairment\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 75\n",
      "✅ Extracted terms: ['Impaired coordination']\n",
      "🌐 [Impaired coordination] API Status: 404\n",
      "❌ Failed for term: Impaired coordination\n",
      "🧪 Final UMLS mappings: [{'original': 'Impaired coordination', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of coordination']\n",
      "🌐 [Abnormality of coordination] API Status: 200\n",
      "✅ Results for Abnormality of coordination: [{'code': 'HP:0011443', 'term': 'Abnormality of coordination', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of coordination', 'candidates': [{'code': 'HP:0011443', 'term': 'Abnormality of coordination', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of coordination': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011443\",\n",
      "    \"matched_term\": \"Abnormality of coordination\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Coordination issues (clumsiness, movement)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of coordination'], 'umls_mappings': [{'original': 'Abnormality of coordination', 'candidates': [{'code': 'HP:0011443', 'term': 'Abnormality of coordination', 'description': None}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of coordination', 'Impaired coordination'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of coordination', 'ranked_candidates': [{'code': 'HP:0011443', 'term': 'Abnormality of coordination', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of coordination': {\n",
      "  \"best_match_code\": \"HP:0011443\",\n",
      "  \"best_match_term\": \"Abnormality of coordination\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 76\n",
      "✅ Extracted terms: ['Abnormal EEG']\n",
      "🌐 [Abnormal EEG] API Status: 200\n",
      "✅ Results for Abnormal EEG: [{'code': 'HP:0002353', 'term': 'Abnormal EEG', 'description': \"Abnormality observed by electroencephalogram (EEG), which is used to record of the brain's spontaneous electrical activity from multiple electrodes placed on the scalp. [https://orcid.org/0000-0002-0736-9199]\"}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal EEG', 'candidates': [{'code': 'HP:0002353', 'term': 'Abnormal EEG', 'description': \"Abnormality observed by electroencephalogram (EEG), which is used to record of the brain's spontaneous electrical activity from multiple electrodes placed on the scalp. [https://orcid.org/0000-0002-0736-9199]\"}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal EEG': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002353\",\n",
      "    \"matched_term\": \"Abnormal EEG\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'EEG abnormality', 'field_type': 'radio', 'extracted_terms': ['Abnormal EEG'], 'umls_mappings': [{'original': 'Abnormal EEG', 'candidates': [{'code': 'HP:0002353', 'term': 'Abnormal EEG', 'description': \"Abnormality observed by electroencephalogram (EEG), which is used to record of the brain's spontaneous electrical activity from multiple electrodes placed on the scalp. [https://orcid.org/0000-0002-0736-9199]\"}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal EEG', 'ranked_candidates': [{'code': 'HP:0002353', 'term': 'Abnormal EEG', 'description': \"Abnormality observed by electroencephalogram (EEG), which is used to record of the brain's spontaneous electrical activity from multiple electrodes placed on the scalp. [https://orcid.org/0000-0002-0736-9199]\", 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal EEG': {\n",
      "  \"best_match_code\": \"HP:0002353\",\n",
      "  \"best_match_term\": \"Abnormal EEG\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 77\n",
      "✅ Extracted terms: ['Encephalopathy']\n",
      "🌐 [Encephalopathy] API Status: 200\n",
      "✅ Results for Encephalopathy: [{'code': 'HP:0006846', 'term': 'Acute encephalopathy', 'description': 'A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.'}, {'code': 'HP:0006965', 'term': 'Acute necrotizing encephalopathy', 'description': None}, {'code': 'HP:0007111', 'term': 'Chronic hepatic encephalopathy', 'description': None}, {'code': 'HP:0007239', 'term': 'Congenital encephalopathy', 'description': None}, {'code': 'HP:0200134', 'term': 'Convulsive encephalopathy', 'description': 'A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]'}, {'code': 'HP:0006994', 'term': 'Diffuse leukoencephalopathy', 'description': None}, {'code': 'HP:0006943', 'term': 'Diffuse spongiform leukoencephalopathy', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Encephalopathy', 'candidates': [{'code': 'HP:0006846', 'term': 'Acute encephalopathy', 'description': 'A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.'}, {'code': 'HP:0006965', 'term': 'Acute necrotizing encephalopathy', 'description': None}, {'code': 'HP:0007111', 'term': 'Chronic hepatic encephalopathy', 'description': None}, {'code': 'HP:0007239', 'term': 'Congenital encephalopathy', 'description': None}, {'code': 'HP:0200134', 'term': 'Convulsive encephalopathy', 'description': 'A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]'}, {'code': 'HP:0006994', 'term': 'Diffuse leukoencephalopathy', 'description': None}, {'code': 'HP:0006943', 'term': 'Diffuse spongiform leukoencephalopathy', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Encephalopathy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006846\",\n",
      "    \"matched_term\": \"Acute encephalopathy\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006965\",\n",
      "    \"matched_term\": \"Acute necrotizing encephalopathy\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007111\",\n",
      "    \"matched_term\": \"Chronic hepatic encephalopathy\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007239\",\n",
      "    \"matched_term\": \"Congenital encephalopathy\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0200134\",\n",
      "    \"matched_term\": \"Convulsive encephalopathy\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006994\",\n",
      "    \"matched_term\": \"Diffuse leukoencephalopathy\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006943\",\n",
      "    \"matched_term\": \"Diffuse spongiform leukoencephalopathy\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Encephalopathy', 'field_type': 'radio', 'extracted_terms': ['Encephalopathy'], 'umls_mappings': [{'original': 'Encephalopathy', 'candidates': [{'code': 'HP:0006846', 'term': 'Acute encephalopathy', 'description': 'A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.'}, {'code': 'HP:0006965', 'term': 'Acute necrotizing encephalopathy', 'description': None}, {'code': 'HP:0007111', 'term': 'Chronic hepatic encephalopathy', 'description': None}, {'code': 'HP:0007239', 'term': 'Congenital encephalopathy', 'description': None}, {'code': 'HP:0200134', 'term': 'Convulsive encephalopathy', 'description': 'A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]'}, {'code': 'HP:0006994', 'term': 'Diffuse leukoencephalopathy', 'description': None}, {'code': 'HP:0006943', 'term': 'Diffuse spongiform leukoencephalopathy', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Encephalopathy', 'ranked_candidates': [{'code': 'HP:0006846', 'term': 'Acute encephalopathy', 'description': 'A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.', 'confidence': 0.9}, {'code': 'HP:0006965', 'term': 'Acute necrotizing encephalopathy', 'description': None, 'confidence': 0.8}, {'code': 'HP:0007111', 'term': 'Chronic hepatic encephalopathy', 'description': None, 'confidence': 0.8}, {'code': 'HP:0007239', 'term': 'Congenital encephalopathy', 'description': None, 'confidence': 0.8}, {'code': 'HP:0200134', 'term': 'Convulsive encephalopathy', 'description': 'A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]', 'confidence': 0.8}, {'code': 'HP:0006994', 'term': 'Diffuse leukoencephalopathy', 'description': None, 'confidence': 0.7}, {'code': 'HP:0006943', 'term': 'Diffuse spongiform leukoencephalopathy', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Encephalopathy': {\n",
      "  \"best_match_code\": \"HP:0006846\",\n",
      "  \"best_match_term\": \"Acute encephalopathy\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Encephalopathy\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Encephalopathy\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Encephalopathy\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0006846\",\n",
      "          \"term\": \"Acute encephalopathy\",\n",
      "          \"description\": \"A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006965\",\n",
      "          \"term\": \"Acute necrotizing encephalopathy\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007111\",\n",
      "          \"term\": \"Chronic hepatic encephalopathy\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007239\",\n",
      "          \"term\": \"Congenital encephalopathy\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0200134\",\n",
      "          \"term\": \"Convulsive encephalopathy\",\n",
      "          \"description\": \"A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006994\",\n",
      "          \"term\": \"Diffuse leukoencephalopathy\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006943\",\n",
      "          \"term\": \"Diffuse spongiform leukoencephalopathy\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Encephalopathy\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0006846\",\n",
      "          \"term\": \"Acute encephalopathy\",\n",
      "          \"description\": \"A life-threatening disorder characterized by delirium, seizures, and neuromuscular changes.\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006965\",\n",
      "          \"term\": \"Acute necrotizing encephalopathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007111\",\n",
      "          \"term\": \"Chronic hepatic encephalopathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007239\",\n",
      "          \"term\": \"Congenital encephalopathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0200134\",\n",
      "          \"term\": \"Convulsive encephalopathy\",\n",
      "          \"description\": \"A condition in which epileptiform abnormalities are believed to contribute to the progressive disturbance in cerebral function. Epileptic encephalaopathy is characterized by (1) electrographic EEG paroxysmal activity that is often aggressive, (2) seizures that are usually multiform and intractable, (3) cognitive, behavioral and neurological deficits that may be relentless, and (4) sometimes early death. [PMID:21590624, PMID:23213494]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006994\",\n",
      "          \"term\": \"Diffuse leukoencephalopathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0006943\",\n",
      "          \"term\": \"Diffuse spongiform leukoencephalopathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Encephalopathy\",\n",
      "      \"best_match_code\": \"HP:0006846\",\n",
      "      \"best_match_term\": \"Acute encephalopathy\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1306587\n",
      "✅ Processed row 78\n",
      "✅ Extracted terms: ['Hypertonia']\n",
      "🌐 [Hypertonia] API Status: 200\n",
      "✅ Results for Hypertonia: [{'code': 'HP:0002509', 'term': 'Appendicular hypertonia', 'description': None}, {'code': 'HP:0001276', 'term': 'Hypertonia', 'description': 'Abnormal increase in skeletal or smooth muscle tone. Skeletal muscle hypertonicity may be associated with PYRAMIDAL TRACT lesions or BASAL GANGLIA DISEASES.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypertonia', 'candidates': [{'code': 'HP:0002509', 'term': 'Appendicular hypertonia', 'description': None}, {'code': 'HP:0001276', 'term': 'Hypertonia', 'description': 'Abnormal increase in skeletal or smooth muscle tone. Skeletal muscle hypertonicity may be associated with PYRAMIDAL TRACT lesions or BASAL GANGLIA DISEASES.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypertonia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001276\",\n",
      "    \"matched_term\": \"Hypertonia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002509\",\n",
      "    \"matched_term\": \"Appendicular hypertonia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hypertonia (increased muscle tone)', 'field_type': 'radio', 'extracted_terms': ['Hypertonia'], 'umls_mappings': [{'original': 'Hypertonia', 'candidates': [{'code': 'HP:0002509', 'term': 'Appendicular hypertonia', 'description': None}, {'code': 'HP:0001276', 'term': 'Hypertonia', 'description': 'Abnormal increase in skeletal or smooth muscle tone. Skeletal muscle hypertonicity may be associated with PYRAMIDAL TRACT lesions or BASAL GANGLIA DISEASES.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypertonia', 'ranked_candidates': [{'code': 'HP:0001276', 'term': 'Hypertonia', 'description': 'Abnormal increase in skeletal or smooth muscle tone. Skeletal muscle hypertonicity may be associated with PYRAMIDAL TRACT lesions or BASAL GANGLIA DISEASES.', 'confidence': 1.0}, {'code': 'HP:0002509', 'term': 'Appendicular hypertonia', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypertonia': {\n",
      "  \"best_match_code\": \"HP:0001276\",\n",
      "  \"best_match_term\": \"Hypertonia\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 79\n",
      "✅ Extracted terms: ['Hypotonia']\n",
      "🌐 [Hypotonia] API Status: 200\n",
      "✅ Results for Hypotonia: [{'code': 'HP:0012389', 'term': 'Appendicular hypotonia', 'description': 'Muscular hypotonia of one or more limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008936', 'term': 'Axial hypotonia', 'description': 'Muscular hypotonia (abnormally low muscle tone) affecting the musculature of the trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001252', 'term': 'Central hypotonia', 'description': None}, {'code': 'HP:0001319', 'term': 'Congenital hypotonia', 'description': 'A syndrome of generalized poor muscle tone and muscle weakness presenting in a newborn infant.'}, {'code': 'HP:0006852', 'term': 'Episodic generalised hypotonia', 'description': 'The occurrence of repeated episodes of generalized muscular hypotonia. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000297', 'term': 'Facial hypotonia', 'description': 'Reduced muscle tone of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001290', 'term': 'Generalised hypotonia', 'description': 'Generalized muscular hypotonia (abnormally low muscle tone). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003397', 'term': 'Generalised hypotonia due to defect at the neuromuscular junction', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypotonia', 'candidates': [{'code': 'HP:0012389', 'term': 'Appendicular hypotonia', 'description': 'Muscular hypotonia of one or more limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008936', 'term': 'Axial hypotonia', 'description': 'Muscular hypotonia (abnormally low muscle tone) affecting the musculature of the trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001252', 'term': 'Central hypotonia', 'description': None}, {'code': 'HP:0001319', 'term': 'Congenital hypotonia', 'description': 'A syndrome of generalized poor muscle tone and muscle weakness presenting in a newborn infant.'}, {'code': 'HP:0006852', 'term': 'Episodic generalised hypotonia', 'description': 'The occurrence of repeated episodes of generalized muscular hypotonia. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000297', 'term': 'Facial hypotonia', 'description': 'Reduced muscle tone of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001290', 'term': 'Generalised hypotonia', 'description': 'Generalized muscular hypotonia (abnormally low muscle tone). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003397', 'term': 'Generalised hypotonia due to defect at the neuromuscular junction', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypotonia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001290\",\n",
      "    \"matched_term\": \"Generalised hypotonia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006852\",\n",
      "    \"matched_term\": \"Episodic generalised hypotonia\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003397\",\n",
      "    \"matched_term\": \"Generalised hypotonia due to defect at the neuromuscular junction\",\n",
      "    \"confidence\": \"85%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001252\",\n",
      "    \"matched_term\": \"Central hypotonia\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012389\",\n",
      "    \"matched_term\": \"Appendicular hypotonia\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008936\",\n",
      "    \"matched_term\": \"Axial hypotonia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001319\",\n",
      "    \"matched_term\": \"Congenital hypotonia\",\n",
      "    \"confidence\": \"65%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000297\",\n",
      "    \"matched_term\": \"Facial hypotonia\",\n",
      "    \"confidence\": \"60%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': \"Hypotonia (low muscle tone, 'floppy')\", 'field_type': 'radio', 'extracted_terms': ['Hypotonia'], 'umls_mappings': [{'original': 'Hypotonia', 'candidates': [{'code': 'HP:0012389', 'term': 'Appendicular hypotonia', 'description': 'Muscular hypotonia of one or more limbs. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0008936', 'term': 'Axial hypotonia', 'description': 'Muscular hypotonia (abnormally low muscle tone) affecting the musculature of the trunk. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001252', 'term': 'Central hypotonia', 'description': None}, {'code': 'HP:0001319', 'term': 'Congenital hypotonia', 'description': 'A syndrome of generalized poor muscle tone and muscle weakness presenting in a newborn infant.'}, {'code': 'HP:0006852', 'term': 'Episodic generalised hypotonia', 'description': 'The occurrence of repeated episodes of generalized muscular hypotonia. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000297', 'term': 'Facial hypotonia', 'description': 'Reduced muscle tone of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001290', 'term': 'Generalised hypotonia', 'description': 'Generalized muscular hypotonia (abnormally low muscle tone). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003397', 'term': 'Generalised hypotonia due to defect at the neuromuscular junction', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypotonia', 'ranked_candidates': [{'code': 'HP:0001290', 'term': 'Generalised hypotonia', 'description': 'Generalized muscular hypotonia (abnormally low muscle tone). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0006852', 'term': 'Episodic generalised hypotonia', 'description': 'The occurrence of repeated episodes of generalized muscular hypotonia. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.9}, {'code': 'HP:0003397', 'term': 'Generalised hypotonia due to defect at the neuromuscular junction', 'description': None, 'confidence': 0.85}, {'code': 'HP:0001252', 'term': 'Central hypotonia', 'description': None, 'confidence': 0.8}, {'code': 'HP:0012389', 'term': 'Appendicular hypotonia', 'description': 'Muscular hypotonia of one or more limbs. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}, {'code': 'HP:0008936', 'term': 'Axial hypotonia', 'description': 'Muscular hypotonia (abnormally low muscle tone) affecting the musculature of the trunk. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0001319', 'term': 'Congenital hypotonia', 'description': 'A syndrome of generalized poor muscle tone and muscle weakness presenting in a newborn infant.', 'confidence': 0.65}, {'code': 'HP:0000297', 'term': 'Facial hypotonia', 'description': 'Reduced muscle tone of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.6}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypotonia': {\n",
      "  \"best_match_code\": \"HP:0001290\",\n",
      "  \"best_match_term\": \"Generalised hypotonia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 80\n",
      "✅ Extracted terms: ['Memory impairment']\n",
      "🌐 [Memory impairment] API Status: 200\n",
      "✅ Results for Memory impairment: [{'code': 'HP:0033689', 'term': 'Anterograde memory impairment', 'description': 'Ztráta schopnosti vytvářet nové vzpomínky po určitém spouštěcím stimulu. Tento stav může být organického (úrazy hlavy, záchvaty, nedostatečné okysličení mozku a další podmínky, které nepříznivě ovlivňují nervové struktury řídící paměť) nebo psychogenního původu (při některých neurotických obtížích).'}, {'code': 'HP:0032686', 'term': 'Focal aware cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]'}, {'code': 'HP:0032687', 'term': 'Focal cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Memory impairment', 'candidates': [{'code': 'HP:0033689', 'term': 'Anterograde memory impairment', 'description': 'Ztráta schopnosti vytvářet nové vzpomínky po určitém spouštěcím stimulu. Tento stav může být organického (úrazy hlavy, záchvaty, nedostatečné okysličení mozku a další podmínky, které nepříznivě ovlivňují nervové struktury řídící paměť) nebo psychogenního původu (při některých neurotických obtížích).'}, {'code': 'HP:0032686', 'term': 'Focal aware cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]'}, {'code': 'HP:0032687', 'term': 'Focal cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Memory impairment': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0033689\",\n",
      "    \"matched_term\": \"Anterograde memory impairment\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0032687\",\n",
      "    \"matched_term\": \"Focal cognitive seizure with memory impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0032686\",\n",
      "    \"matched_term\": \"Focal aware cognitive seizure with memory impairment\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Memory impairment', 'field_type': 'radio', 'extracted_terms': ['Memory impairment'], 'umls_mappings': [{'original': 'Memory impairment', 'candidates': [{'code': 'HP:0033689', 'term': 'Anterograde memory impairment', 'description': 'Ztráta schopnosti vytvářet nové vzpomínky po určitém spouštěcím stimulu. Tento stav může být organického (úrazy hlavy, záchvaty, nedostatečné okysličení mozku a další podmínky, které nepříznivě ovlivňují nervové struktury řídící paměť) nebo psychogenního původu (při některých neurotických obtížích).'}, {'code': 'HP:0032686', 'term': 'Focal aware cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]'}, {'code': 'HP:0032687', 'term': 'Focal cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Memory impairment', 'ranked_candidates': [{'code': 'HP:0033689', 'term': 'Anterograde memory impairment', 'description': 'Ztráta schopnosti vytvářet nové vzpomínky po určitém spouštěcím stimulu. Tento stav může být organického (úrazy hlavy, záchvaty, nedostatečné okysličení mozku a další podmínky, které nepříznivě ovlivňují nervové struktury řídící paměť) nebo psychogenního původu (při některých neurotických obtížích).', 'confidence': 0.9}, {'code': 'HP:0032686', 'term': 'Focal aware cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]', 'confidence': 0.7}, {'code': 'HP:0032687', 'term': 'Focal cognitive seizure with memory impairment', 'description': 'A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Memory impairment': {\n",
      "  \"best_match_code\": \"HP:0033689\",\n",
      "  \"best_match_term\": \"Anterograde memory impairment\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Memory impairment\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Memory impairment\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Memory impairment\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0033689\",\n",
      "          \"term\": \"Anterograde memory impairment\",\n",
      "          \"description\": \"Ztr\\u00e1ta schopnosti vytv\\u00e1\\u0159et nov\\u00e9 vzpom\\u00ednky po ur\\u010dit\\u00e9m spou\\u0161t\\u011bc\\u00edm stimulu. Tento stav m\\u016f\\u017ee b\\u00fdt organick\\u00e9ho (\\u00farazy hlavy, z\\u00e1chvaty, nedostate\\u010dn\\u00e9 okysli\\u010den\\u00ed mozku a dal\\u0161\\u00ed podm\\u00ednky, kter\\u00e9 nep\\u0159\\u00edzniv\\u011b ovliv\\u0148uj\\u00ed nervov\\u00e9 struktury \\u0159\\u00edd\\u00edc\\u00ed pam\\u011b\\u0165) nebo psychogenn\\u00edho p\\u016fvodu (p\\u0159i n\\u011bkter\\u00fdch neurotick\\u00fdch obt\\u00ed\\u017e\\u00edch).\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0032686\",\n",
      "          \"term\": \"Focal aware cognitive seizure with memory impairment\",\n",
      "          \"description\": \"A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0032687\",\n",
      "          \"term\": \"Focal cognitive seizure with memory impairment\",\n",
      "          \"description\": \"A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Memory impairment\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0033689\",\n",
      "          \"term\": \"Anterograde memory impairment\",\n",
      "          \"description\": \"Ztr\\u00e1ta schopnosti vytv\\u00e1\\u0159et nov\\u00e9 vzpom\\u00ednky po ur\\u010dit\\u00e9m spou\\u0161t\\u011bc\\u00edm stimulu. Tento stav m\\u016f\\u017ee b\\u00fdt organick\\u00e9ho (\\u00farazy hlavy, z\\u00e1chvaty, nedostate\\u010dn\\u00e9 okysli\\u010den\\u00ed mozku a dal\\u0161\\u00ed podm\\u00ednky, kter\\u00e9 nep\\u0159\\u00edzniv\\u011b ovliv\\u0148uj\\u00ed nervov\\u00e9 struktury \\u0159\\u00edd\\u00edc\\u00ed pam\\u011b\\u0165) nebo psychogenn\\u00edho p\\u016fvodu (p\\u0159i n\\u011bkter\\u00fdch neurotick\\u00fdch obt\\u00ed\\u017e\\u00edch).\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0032686\",\n",
      "          \"term\": \"Focal aware cognitive seizure with memory impairment\",\n",
      "          \"description\": \"A focal cognitive seizure with memory impairment characterized by retained awareness throughout the seizure. [PMID:28276060]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0032687\",\n",
      "          \"term\": \"Focal cognitive seizure with memory impairment\",\n",
      "          \"description\": \"A focal cognitive seizure characterized by transient memory impairment as the initial semiological manifestation whilst other cognitive functions and awareness are preserved at seizure onset. The memory impairment may be an inability to recall events occurring prior to the seizure (retrograde amnesia), or failure to encode new memories for events occurring during the seizure (anterograde amnesia). [PMID:17444534]\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Memory impairment\",\n",
      "      \"best_match_code\": \"HP:0033689\",\n",
      "      \"best_match_term\": \"Anterograde memory impairment\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0233795\n",
      "🧩 ancestor_cuis ['C0002622', 'C0233794', 'C0574125', 'C0564672', 'C0338656', 'C2720507', 'C0700327', 'C0037088']\n",
      "🧩 candidate_details [{'cui': 'C0002622', 'name': 'Amnesia'}, {'cui': 'C0233794', 'name': 'Memory impairment'}, {'cui': 'C0574125', 'name': 'Functional finding'}, {'cui': 'C0564672', 'name': 'Cognitive function observations'}, {'cui': 'C0338656', 'name': 'Impaired cognition'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0700327', 'name': 'Memory observations'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Memory impairment\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Memory impairment\"\n",
      "  \"best_match_code\": \"HP:0033689\",\n",
      "  \"best_match_term\": \"Anterograde memory impairment\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0002622 (Amnesia)\n",
      "- C0233794 (Memory impairment)\n",
      "- C0574125 (Functional finding)\n",
      "- C0564672 (Cognitive function observations)\n",
      "- C0338656 (Impaired cognition)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0700327 (Memory observations)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0002354\",\\n  \"refined_term\": \"Memory impairment\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 32, 'prompt_tokens': 581, 'total_tokens': 613, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeHuMn3f1mVqPzTuCNCXdASg5fHh', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--58c8e8a6-5326-46f6-b31a-93f3261dffe5-0' usage_metadata={'input_tokens': 581, 'output_tokens': 32, 'total_tokens': 613, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Memory impairment\n",
      "🧠 LLM refined_code: HP:0002354\n",
      "✅ Processed row 81\n",
      "✅ Extracted terms: ['Abnormality of movement']\n",
      "🌐 [Abnormality of movement] API Status: 200\n",
      "✅ Results for Abnormality of movement: [{'code': 'HP:0100022', 'term': 'Abnormality of movement', 'description': 'Syndromes which feature DYSKINESIAS as a cardinal manifestation of the disease process. Included in this category are degenerative, hereditary, post-infectious, medication-induced, post-inflammatory, and post-traumatic conditions.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of movement', 'candidates': [{'code': 'HP:0100022', 'term': 'Abnormality of movement', 'description': 'Syndromes which feature DYSKINESIAS as a cardinal manifestation of the disease process. Included in this category are degenerative, hereditary, post-infectious, medication-induced, post-inflammatory, and post-traumatic conditions.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of movement': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100022\",\n",
      "    \"matched_term\": \"Abnormality of movement\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': \"Unusual movements (NOT Parkinson's disease)\", 'field_type': 'radio', 'extracted_terms': ['Abnormality of movement'], 'umls_mappings': [{'original': 'Abnormality of movement', 'candidates': [{'code': 'HP:0100022', 'term': 'Abnormality of movement', 'description': 'Syndromes which feature DYSKINESIAS as a cardinal manifestation of the disease process. Included in this category are degenerative, hereditary, post-infectious, medication-induced, post-inflammatory, and post-traumatic conditions.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of movement', 'ranked_candidates': [{'code': 'HP:0100022', 'term': 'Abnormality of movement', 'description': 'Syndromes which feature DYSKINESIAS as a cardinal manifestation of the disease process. Included in this category are degenerative, hereditary, post-infectious, medication-induced, post-inflammatory, and post-traumatic conditions.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of movement': {\n",
      "  \"best_match_code\": \"HP:0100022\",\n",
      "  \"best_match_term\": \"Abnormality of movement\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 82\n",
      "✅ Extracted terms: ['Parkinsonism']\n",
      "🌐 [Parkinsonism] API Status: 200\n",
      "✅ Results for Parkinsonism: [{'code': 'HP:0001300', 'term': 'Parkinsonism', 'description': 'Skupina poruch motorické kontroly projevující se bradykinezí, svalovou rigiditou, třesem a posturální nestabilitou. Parkinsonovy poruchy jsou obecně rozděleny na primární parkinsonismus (viz Parkinsonova nemoc), sekundární parkinsonismus (viz Parkinsonova nemoc sekundární) a dědičné formy. Parkinsonské poruchy jsou spojeny s dysfunkcí dopaminergních nebo souvisejících motorických neuronových cest v bazálních gangliích.'}, {'code': 'HP:0002548', 'term': 'Parkinsonism with favorable response to dopaminergic medication', 'description': 'Parkinsonism is a clinical syndrome that is a feature of a number of different diseases, including Parkinson disease itself, other neurodegenerative diseases such as progressive supranuclear palsy, and as a side-effect of some neuroleptic medications. Some but not all individuals with Parkinsonism show responsiveness to dopaminergic medication defined as a substantial reduction of amelioration of the component signs of Parkinsonism (including mainly tremor, bradykinesia, rigidity, and postural instability) upon administration of dopaminergic medication. []'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Parkinsonism', 'candidates': [{'code': 'HP:0001300', 'term': 'Parkinsonism', 'description': 'Skupina poruch motorické kontroly projevující se bradykinezí, svalovou rigiditou, třesem a posturální nestabilitou. Parkinsonovy poruchy jsou obecně rozděleny na primární parkinsonismus (viz Parkinsonova nemoc), sekundární parkinsonismus (viz Parkinsonova nemoc sekundární) a dědičné formy. Parkinsonské poruchy jsou spojeny s dysfunkcí dopaminergních nebo souvisejících motorických neuronových cest v bazálních gangliích.'}, {'code': 'HP:0002548', 'term': 'Parkinsonism with favorable response to dopaminergic medication', 'description': 'Parkinsonism is a clinical syndrome that is a feature of a number of different diseases, including Parkinson disease itself, other neurodegenerative diseases such as progressive supranuclear palsy, and as a side-effect of some neuroleptic medications. Some but not all individuals with Parkinsonism show responsiveness to dopaminergic medication defined as a substantial reduction of amelioration of the component signs of Parkinsonism (including mainly tremor, bradykinesia, rigidity, and postural instability) upon administration of dopaminergic medication. []'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Parkinsonism': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001300\",\n",
      "    \"matched_term\": \"Parkinsonism\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002548\",\n",
      "    \"matched_term\": \"Parkinsonism with favorable response to dopaminergic medication\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Parkinsonism', 'field_type': 'radio', 'extracted_terms': ['Parkinsonism'], 'umls_mappings': [{'original': 'Parkinsonism', 'candidates': [{'code': 'HP:0001300', 'term': 'Parkinsonism', 'description': 'Skupina poruch motorické kontroly projevující se bradykinezí, svalovou rigiditou, třesem a posturální nestabilitou. Parkinsonovy poruchy jsou obecně rozděleny na primární parkinsonismus (viz Parkinsonova nemoc), sekundární parkinsonismus (viz Parkinsonova nemoc sekundární) a dědičné formy. Parkinsonské poruchy jsou spojeny s dysfunkcí dopaminergních nebo souvisejících motorických neuronových cest v bazálních gangliích.'}, {'code': 'HP:0002548', 'term': 'Parkinsonism with favorable response to dopaminergic medication', 'description': 'Parkinsonism is a clinical syndrome that is a feature of a number of different diseases, including Parkinson disease itself, other neurodegenerative diseases such as progressive supranuclear palsy, and as a side-effect of some neuroleptic medications. Some but not all individuals with Parkinsonism show responsiveness to dopaminergic medication defined as a substantial reduction of amelioration of the component signs of Parkinsonism (including mainly tremor, bradykinesia, rigidity, and postural instability) upon administration of dopaminergic medication. []'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Parkinsonism', 'ranked_candidates': [{'code': 'HP:0001300', 'term': 'Parkinsonism', 'description': 'Skupina poruch motorické kontroly projevující se bradykinezí, svalovou rigiditou, třesem a posturální nestabilitou. Parkinsonovy poruchy jsou obecně rozděleny na primární parkinsonismus (viz Parkinsonova nemoc), sekundární parkinsonismus (viz Parkinsonova nemoc sekundární) a dědičné formy. Parkinsonské poruchy jsou spojeny s dysfunkcí dopaminergních nebo souvisejících motorických neuronových cest v bazálních gangliích.', 'confidence': 1.0}, {'code': 'HP:0002548', 'term': 'Parkinsonism with favorable response to dopaminergic medication', 'description': 'Parkinsonism is a clinical syndrome that is a feature of a number of different diseases, including Parkinson disease itself, other neurodegenerative diseases such as progressive supranuclear palsy, and as a side-effect of some neuroleptic medications. Some but not all individuals with Parkinsonism show responsiveness to dopaminergic medication defined as a substantial reduction of amelioration of the component signs of Parkinsonism (including mainly tremor, bradykinesia, rigidity, and postural instability) upon administration of dopaminergic medication. []', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Parkinsonism': {\n",
      "  \"best_match_code\": \"HP:0001300\",\n",
      "  \"best_match_term\": \"Parkinsonism\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 83\n",
      "✅ Extracted terms: ['Epilepsy']\n",
      "🌐 [Epilepsy] API Status: 200\n",
      "✅ Results for Epilepsy: [{'code': 'HP:0001250', 'term': 'Epilepsy', 'description': 'A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Epilepsy', 'candidates': [{'code': 'HP:0001250', 'term': 'Epilepsy', 'description': 'A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Epilepsy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001250\",\n",
      "    \"matched_term\": \"Epilepsy\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Seizures', 'field_type': 'radio', 'extracted_terms': ['Epilepsy'], 'umls_mappings': [{'original': 'Epilepsy', 'candidates': [{'code': 'HP:0001250', 'term': 'Epilepsy', 'description': 'A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Epilepsy', 'ranked_candidates': [{'code': 'HP:0001250', 'term': 'Epilepsy', 'description': 'A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Epilepsy': {\n",
      "  \"best_match_code\": \"HP:0001250\",\n",
      "  \"best_match_term\": \"Epilepsy\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Seizures\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Epilepsy\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Epilepsy\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001250\",\n",
      "          \"term\": \"Epilepsy\",\n",
      "          \"description\": \"A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Epilepsy\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001250\",\n",
      "          \"term\": \"Epilepsy\",\n",
      "          \"description\": \"A disorder characterized by recurrent episodes of paroxysmal brain dysfunction due to a sudden, disorderly, and excessive neuronal discharge. Epilepsy classification systems are generally based upon: (1) clinical features of the seizure episodes (e.g., motor seizure), (2) etiology (e.g., post-traumatic), (3) anatomic site of seizure origin (e.g., frontal lobe seizure), (4) tendency to spread to other structures in the brain, and (5) temporal patterns (e.g., nocturnal epilepsy). (From Adams et al., Principles of Neurology, 6th ed, p313)\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Epilepsy\",\n",
      "      \"best_match_code\": \"HP:0001250\",\n",
      "      \"best_match_term\": \"Epilepsy\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0014544\n",
      "🧩 ancestor_cuis ['C0576471', 'C0012634', 'C0036572', 'C0422878', 'C1290856', 'C0006111', 'C0014544', 'C1320354', 'C1285159', 'C2720507', 'C0037088', 'C0422837', 'C0027765', 'C0730595', 'C0007682']\n",
      "🧩 candidate_details [{'cui': 'C0576471', 'name': 'Finding of brain'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0036572', 'name': 'Seizure'}, {'cui': 'C0422878', 'name': 'Central nervous system finding'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C0006111', 'name': 'Disease of brain, NOS'}, {'cui': 'C0014544', 'name': 'Epilepsy'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0422837', 'name': 'Neurological observations'}, {'cui': 'C0027765', 'name': 'Nervous system disorders NOS'}, {'cui': 'C0730595', 'name': 'Seizure related finding'}, {'cui': 'C0007682', 'name': 'CNS disorder'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Seizures\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Epilepsy\"\n",
      "  \"best_match_code\": \"HP:0001250\",\n",
      "  \"best_match_term\": \"Epilepsy\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0576471 (Finding of brain)\n",
      "- C0012634 (Disease)\n",
      "- C0036572 (Seizure)\n",
      "- C0422878 (Central nervous system finding)\n",
      "- C1290856 (Disorder of head)\n",
      "- C0006111 (Disease of brain, NOS)\n",
      "- C0014544 (Epilepsy)\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0422837 (Neurological observations)\n",
      "- C0027765 (Nervous system disorders NOS)\n",
      "- C0730595 (Seizure related finding)\n",
      "- C0007682 (CNS disorder)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0001250\",\\n  \"refined_term\": \"Seizure\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 33, 'prompt_tokens': 666, 'total_tokens': 699, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeIPpYf5avDGMsbi34eeRpn8spdT', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--87d9be67-fe6c-4b52-aef7-42cf225f8aa9-0' usage_metadata={'input_tokens': 666, 'output_tokens': 33, 'total_tokens': 699, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Seizure\n",
      "🧠 LLM refined_code: HP:0001250\n",
      "✅ Processed row 84\n",
      "✅ Extracted terms: ['Autism spectrum disorder']\n",
      "🌐 [Autism spectrum disorder] API Status: 200\n",
      "✅ Results for Autism spectrum disorder: [{'code': 'HP:0000729', 'term': 'Autism spectrum disorder', 'description': 'A spectrum of developmental disorders that includes autism, Asperger syndrome, and Rett syndrome. Signs and symptoms include poor communication skills, defective social interactions, and repetitive behaviors.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Autism spectrum disorder', 'candidates': [{'code': 'HP:0000729', 'term': 'Autism spectrum disorder', 'description': 'A spectrum of developmental disorders that includes autism, Asperger syndrome, and Rett syndrome. Signs and symptoms include poor communication skills, defective social interactions, and repetitive behaviors.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Autism spectrum disorder': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000729\",\n",
      "    \"matched_term\": \"Autism spectrum disorder\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Autism spectrum disorder (ASD)', 'field_type': 'radio', 'extracted_terms': ['Autism spectrum disorder'], 'umls_mappings': [{'original': 'Autism spectrum disorder', 'candidates': [{'code': 'HP:0000729', 'term': 'Autism spectrum disorder', 'description': 'A spectrum of developmental disorders that includes autism, Asperger syndrome, and Rett syndrome. Signs and symptoms include poor communication skills, defective social interactions, and repetitive behaviors.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Autism spectrum disorder', 'ranked_candidates': [{'code': 'HP:0000729', 'term': 'Autism spectrum disorder', 'description': 'A spectrum of developmental disorders that includes autism, Asperger syndrome, and Rett syndrome. Signs and symptoms include poor communication skills, defective social interactions, and repetitive behaviors.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Autism spectrum disorder': {\n",
      "  \"best_match_code\": \"HP:0000729\",\n",
      "  \"best_match_term\": \"Autism spectrum disorder\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 85\n",
      "✅ Extracted terms: ['Bipolar disorder']\n",
      "🌐 [Bipolar disorder] API Status: 200\n",
      "✅ Results for Bipolar disorder: [{'code': 'HP:0007302', 'term': 'Bipolar disorder', 'description': 'A major affective disorder marked by severe mood swings (manic or major depressive episodes) and a tendency to remission and recurrence.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Bipolar disorder', 'candidates': [{'code': 'HP:0007302', 'term': 'Bipolar disorder', 'description': 'A major affective disorder marked by severe mood swings (manic or major depressive episodes) and a tendency to remission and recurrence.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Bipolar disorder': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007302\",\n",
      "    \"matched_term\": \"Bipolar disorder\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Bipolar disorder (manic depression)', 'field_type': 'radio', 'extracted_terms': ['Bipolar disorder'], 'umls_mappings': [{'original': 'Bipolar disorder', 'candidates': [{'code': 'HP:0007302', 'term': 'Bipolar disorder', 'description': 'A major affective disorder marked by severe mood swings (manic or major depressive episodes) and a tendency to remission and recurrence.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Bipolar disorder', 'ranked_candidates': [{'code': 'HP:0007302', 'term': 'Bipolar disorder', 'description': 'A major affective disorder marked by severe mood swings (manic or major depressive episodes) and a tendency to remission and recurrence.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Bipolar disorder': {\n",
      "  \"best_match_code\": \"HP:0007302\",\n",
      "  \"best_match_term\": \"Bipolar disorder\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 86\n",
      "✅ Extracted terms: ['Schizophrenia']\n",
      "🌐 [Schizophrenia] API Status: 200\n",
      "✅ Results for Schizophrenia: [{'code': 'HP:0100753', 'term': 'Schizophrenia', 'description': 'A severe emotional disorder of psychotic depth characteristically marked by a retreat from reality with delusion formation, HALLUCINATIONS, emotional disharmony, and regressive behavior.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Schizophrenia', 'candidates': [{'code': 'HP:0100753', 'term': 'Schizophrenia', 'description': 'A severe emotional disorder of psychotic depth characteristically marked by a retreat from reality with delusion formation, HALLUCINATIONS, emotional disharmony, and regressive behavior.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Schizophrenia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100753\",\n",
      "    \"matched_term\": \"Schizophrenia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Schizophrenia', 'field_type': 'radio', 'extracted_terms': ['Schizophrenia'], 'umls_mappings': [{'original': 'Schizophrenia', 'candidates': [{'code': 'HP:0100753', 'term': 'Schizophrenia', 'description': 'A severe emotional disorder of psychotic depth characteristically marked by a retreat from reality with delusion formation, HALLUCINATIONS, emotional disharmony, and regressive behavior.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Schizophrenia', 'ranked_candidates': [{'code': 'HP:0100753', 'term': 'Schizophrenia', 'description': 'A severe emotional disorder of psychotic depth characteristically marked by a retreat from reality with delusion formation, HALLUCINATIONS, emotional disharmony, and regressive behavior.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Schizophrenia': {\n",
      "  \"best_match_code\": \"HP:0100753\",\n",
      "  \"best_match_term\": \"Schizophrenia\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 87\n",
      "✅ Extracted terms: ['Abnormal behavior']\n",
      "🌐 [Abnormal behavior] API Status: 404\n",
      "❌ Failed for term: Abnormal behavior\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal behavior', 'candidates': []}]\n",
      "✅ Revised terms: ['Stereotypy']\n",
      "🌐 [Stereotypy] API Status: 200\n",
      "✅ Results for Stereotypy: [{'code': 'HP:0000733', 'term': 'Motor stereotypy', 'description': 'Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Stereotypy', 'candidates': [{'code': 'HP:0000733', 'term': 'Motor stereotypy', 'description': 'Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Stereotypy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000733\",\n",
      "    \"matched_term\": \"Motor stereotypy\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Repetitive or self-injurious behavior', 'field_type': 'radio', 'extracted_terms': ['Stereotypy'], 'umls_mappings': [{'original': 'Stereotypy', 'candidates': [{'code': 'HP:0000733', 'term': 'Motor stereotypy', 'description': 'Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Stereotypy', 'Abnormal behavior'], 'retries': 0, 'ranked_mappings': [{'original': 'Stereotypy', 'ranked_candidates': [{'code': 'HP:0000733', 'term': 'Motor stereotypy', 'description': 'Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Stereotypy': {\n",
      "  \"best_match_code\": \"HP:0000733\",\n",
      "  \"best_match_term\": \"Motor stereotypy\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Repetitive or self-injurious behavior\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Stereotypy\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stereotypy\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000733\",\n",
      "          \"term\": \"Motor stereotypy\",\n",
      "          \"description\": \"Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retry_count\": 1,\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"history_rewritten_terms\": [\n",
      "    \"Stereotypy\",\n",
      "    \"Abnormal behavior\"\n",
      "  ],\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stereotypy\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000733\",\n",
      "          \"term\": \"Motor stereotypy\",\n",
      "          \"description\": \"Relatively invariant mode of behavior elicited or determined by a particular situation; may be verbal, postural, or expressive.\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stereotypy\",\n",
      "      \"best_match_code\": \"HP:0000733\",\n",
      "      \"best_match_term\": \"Motor stereotypy\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0038271\n",
      "🧩 ancestor_cuis ['C0474393', 'C1272788', 'C0004927', 'C2720507', 'C0037088']\n",
      "🧩 candidate_details [{'cui': 'C0474393', 'name': 'Motor function behavior'}, {'cui': 'C1272788', 'name': 'Mental state, behavior and/or psychosocial function finding'}, {'cui': 'C0004927', 'name': 'Behavior, NOS'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Repetitive or self-injurious behavior\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Stereotypy\"\n",
      "  \"best_match_code\": \"HP:0000733\",\n",
      "  \"best_match_term\": \"Motor stereotypy\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0474393 (Motor function behavior)\n",
      "- C1272788 (Mental state, behavior and/or psychosocial function finding)\n",
      "- C0004927 (Behavior, NOS)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0100716\",\\n  \"refined_term\": \"Self-injurious behavior\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 35, 'prompt_tokens': 571, 'total_tokens': 606, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeJMk5AnAJtVOFoqE4a88I8sBJXH', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--cb292312-b5fb-4d63-b3a9-808c27f94fce-0' usage_metadata={'input_tokens': 571, 'output_tokens': 35, 'total_tokens': 606, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Self-injurious behavior\n",
      "🧠 LLM refined_code: HP:0100716\n",
      "✅ Processed row 88\n",
      "✅ Extracted terms: ['Aggressive behavior']\n",
      "🌐 [Aggressive behavior] API Status: 200\n",
      "✅ Results for Aggressive behavior: [{'code': 'HP:0000718', 'term': 'Aggressive behavior', 'description': 'Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Aggressive behavior', 'candidates': [{'code': 'HP:0000718', 'term': 'Aggressive behavior', 'description': 'Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Aggressive behavior': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000718\",\n",
      "    \"matched_term\": \"Aggressive behavior\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Aggressive/violent behavior', 'field_type': 'radio', 'extracted_terms': ['Aggressive behavior'], 'umls_mappings': [{'original': 'Aggressive behavior', 'candidates': [{'code': 'HP:0000718', 'term': 'Aggressive behavior', 'description': 'Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Aggressive behavior', 'ranked_candidates': [{'code': 'HP:0000718', 'term': 'Aggressive behavior', 'description': 'Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Aggressive behavior': {\n",
      "  \"best_match_code\": \"HP:0000718\",\n",
      "  \"best_match_term\": \"Aggressive behavior\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Aggressive/violent behavior\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Aggressive behavior\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Aggressive behavior\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000718\",\n",
      "          \"term\": \"Aggressive behavior\",\n",
      "          \"description\": \"Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Aggressive behavior\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000718\",\n",
      "          \"term\": \"Aggressive behavior\",\n",
      "          \"description\": \"Behavior which may be manifested by destructive and attacking action which is verbal or physical, by covert attitudes of hostility or by obstructionism.\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Aggressive behavior\",\n",
      "      \"best_match_code\": \"HP:0000718\",\n",
      "      \"best_match_term\": \"Aggressive behavior\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0001807\n",
      "🧩 ancestor_cuis ['C0562566', 'C1272788', 'C0004927', 'C2720507', 'C0562434', 'C0037088']\n",
      "🧩 candidate_details [{'cui': 'C0562566', 'name': 'Finding relating to aggressive behavior'}, {'cui': 'C1272788', 'name': 'Mental state, behavior and/or psychosocial function finding'}, {'cui': 'C0004927', 'name': 'Behavior, NOS'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0562434', 'name': 'Finding relating to complex and social behaviors'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Aggressive/violent behavior\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Aggressive behavior\"\n",
      "  \"best_match_code\": \"HP:0000718\",\n",
      "  \"best_match_term\": \"Aggressive behavior\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0562566 (Finding relating to aggressive behavior)\n",
      "- C1272788 (Mental state, behavior and/or psychosocial function finding)\n",
      "- C0004927 (Behavior, NOS)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0562434 (Finding relating to complex and social behaviors)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 582, 'total_tokens': 583, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeJab4LxNjFZ3PaYjM6wEu6Tde4a', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--c6b54ce2-0ce6-4cfa-8577-aea4a5068bef-0' usage_metadata={'input_tokens': 582, 'output_tokens': 1, 'total_tokens': 583, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 89\n",
      "✅ Extracted terms: ['Anxiety']\n",
      "🌐 [Anxiety] API Status: 200\n",
      "✅ Results for Anxiety: [{'code': 'HP:0100852', 'term': 'Abnormal fear/anxiety-related behavior', 'description': 'An abnormal fear-induced behavior includes observable actions. This behavior is characterized by abnormal responses to fear or abnormal fear levels. Examples of such behavior include avoiding fear-inducing situations. []'}, {'code': 'HP:5200233', 'term': 'Anticipatory anxiety', 'description': 'A state characterized by future-oriented worry, accompanied by negative affect and autonomic arousal. [PMID:36221311]'}, {'code': 'HP:0000739', 'term': 'Anxiety', 'description': 'Feelings or emotions of dread, apprehension, and impending disaster but not disabling as with ANXIETY DISORDERS.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Anxiety', 'candidates': [{'code': 'HP:0100852', 'term': 'Abnormal fear/anxiety-related behavior', 'description': 'An abnormal fear-induced behavior includes observable actions. This behavior is characterized by abnormal responses to fear or abnormal fear levels. Examples of such behavior include avoiding fear-inducing situations. []'}, {'code': 'HP:5200233', 'term': 'Anticipatory anxiety', 'description': 'A state characterized by future-oriented worry, accompanied by negative affect and autonomic arousal. [PMID:36221311]'}, {'code': 'HP:0000739', 'term': 'Anxiety', 'description': 'Feelings or emotions of dread, apprehension, and impending disaster but not disabling as with ANXIETY DISORDERS.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Anxiety': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000739\",\n",
      "    \"matched_term\": \"Anxiety\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0100852\",\n",
      "    \"matched_term\": \"Abnormal fear/anxiety-related behavior\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:5200233\",\n",
      "    \"matched_term\": \"Anticipatory anxiety\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Anxiety', 'field_type': 'radio', 'extracted_terms': ['Anxiety'], 'umls_mappings': [{'original': 'Anxiety', 'candidates': [{'code': 'HP:0100852', 'term': 'Abnormal fear/anxiety-related behavior', 'description': 'An abnormal fear-induced behavior includes observable actions. This behavior is characterized by abnormal responses to fear or abnormal fear levels. Examples of such behavior include avoiding fear-inducing situations. []'}, {'code': 'HP:5200233', 'term': 'Anticipatory anxiety', 'description': 'A state characterized by future-oriented worry, accompanied by negative affect and autonomic arousal. [PMID:36221311]'}, {'code': 'HP:0000739', 'term': 'Anxiety', 'description': 'Feelings or emotions of dread, apprehension, and impending disaster but not disabling as with ANXIETY DISORDERS.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Anxiety', 'ranked_candidates': [{'code': 'HP:0000739', 'term': 'Anxiety', 'description': 'Feelings or emotions of dread, apprehension, and impending disaster but not disabling as with ANXIETY DISORDERS.', 'confidence': 1.0}, {'code': 'HP:0100852', 'term': 'Abnormal fear/anxiety-related behavior', 'description': 'An abnormal fear-induced behavior includes observable actions. This behavior is characterized by abnormal responses to fear or abnormal fear levels. Examples of such behavior include avoiding fear-inducing situations. []', 'confidence': 0.7}, {'code': 'HP:5200233', 'term': 'Anticipatory anxiety', 'description': 'A state characterized by future-oriented worry, accompanied by negative affect and autonomic arousal. [PMID:36221311]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Anxiety': {\n",
      "  \"best_match_code\": \"HP:0000739\",\n",
      "  \"best_match_term\": \"Anxiety\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 90\n",
      "✅ Extracted terms: ['Depression']\n",
      "🌐 [Depression] API Status: 200\n",
      "✅ Results for Depression: [{'code': 'HP:0000288', 'term': 'Abnormality of the infranasal depression', 'description': 'An abnormality of the philtrum. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007302', 'term': 'Bipolar depression', 'description': 'severe disorder characterized by one or more manic episodes; although diagnosis does not require a major depressive episode, virtually all cases eventually develop one.'}, {'code': 'HP:0031706', 'term': 'Compensatory chin depression', 'description': 'A tendency to hold the chin depressed (lowered) to compensate for a limitation of eye movement. []'}, {'code': 'HP:0000716', 'term': 'Depression', 'description': 'An affective disorder manifested by either a dysphoric mood or loss of interest or pleasure in usual activities. The mood disturbance is prominent and relatively persistent.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Depression', 'candidates': [{'code': 'HP:0000288', 'term': 'Abnormality of the infranasal depression', 'description': 'An abnormality of the philtrum. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007302', 'term': 'Bipolar depression', 'description': 'severe disorder characterized by one or more manic episodes; although diagnosis does not require a major depressive episode, virtually all cases eventually develop one.'}, {'code': 'HP:0031706', 'term': 'Compensatory chin depression', 'description': 'A tendency to hold the chin depressed (lowered) to compensate for a limitation of eye movement. []'}, {'code': 'HP:0000716', 'term': 'Depression', 'description': 'An affective disorder manifested by either a dysphoric mood or loss of interest or pleasure in usual activities. The mood disturbance is prominent and relatively persistent.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Depression': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000716\",\n",
      "    \"matched_term\": \"Depression\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007302\",\n",
      "    \"matched_term\": \"Bipolar depression\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000288\",\n",
      "    \"matched_term\": \"Abnormality of the infranasal depression\",\n",
      "    \"confidence\": \"30%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031706\",\n",
      "    \"matched_term\": \"Compensatory chin depression\",\n",
      "    \"confidence\": \"20%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Depression', 'field_type': 'radio', 'extracted_terms': ['Depression'], 'umls_mappings': [{'original': 'Depression', 'candidates': [{'code': 'HP:0000288', 'term': 'Abnormality of the infranasal depression', 'description': 'An abnormality of the philtrum. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007302', 'term': 'Bipolar depression', 'description': 'severe disorder characterized by one or more manic episodes; although diagnosis does not require a major depressive episode, virtually all cases eventually develop one.'}, {'code': 'HP:0031706', 'term': 'Compensatory chin depression', 'description': 'A tendency to hold the chin depressed (lowered) to compensate for a limitation of eye movement. []'}, {'code': 'HP:0000716', 'term': 'Depression', 'description': 'An affective disorder manifested by either a dysphoric mood or loss of interest or pleasure in usual activities. The mood disturbance is prominent and relatively persistent.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Depression', 'ranked_candidates': [{'code': 'HP:0000716', 'term': 'Depression', 'description': 'An affective disorder manifested by either a dysphoric mood or loss of interest or pleasure in usual activities. The mood disturbance is prominent and relatively persistent.', 'confidence': 1.0}, {'code': 'HP:0007302', 'term': 'Bipolar depression', 'description': 'severe disorder characterized by one or more manic episodes; although diagnosis does not require a major depressive episode, virtually all cases eventually develop one.', 'confidence': 0.7}, {'code': 'HP:0000288', 'term': 'Abnormality of the infranasal depression', 'description': 'An abnormality of the philtrum. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.3}, {'code': 'HP:0031706', 'term': 'Compensatory chin depression', 'description': 'A tendency to hold the chin depressed (lowered) to compensate for a limitation of eye movement. []', 'confidence': 0.2}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Depression': {\n",
      "  \"best_match_code\": \"HP:0000716\",\n",
      "  \"best_match_term\": \"Depression\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 91\n",
      "✅ Extracted terms: ['Delusions']\n",
      "🌐 [Delusions] API Status: 200\n",
      "✅ Results for Delusions: [{'code': 'HP:0000746', 'term': 'Delusions', 'description': \"A false belief regarding the self or persons or objects outside the self that persists despite the facts, and is not considered tenable by one's associates.\"}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Delusions', 'candidates': [{'code': 'HP:0000746', 'term': 'Delusions', 'description': \"A false belief regarding the self or persons or objects outside the self that persists despite the facts, and is not considered tenable by one's associates.\"}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Delusions': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000746\",\n",
      "    \"matched_term\": \"Delusions\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Delusions', 'field_type': 'radio', 'extracted_terms': ['Delusions'], 'umls_mappings': [{'original': 'Delusions', 'candidates': [{'code': 'HP:0000746', 'term': 'Delusions', 'description': \"A false belief regarding the self or persons or objects outside the self that persists despite the facts, and is not considered tenable by one's associates.\"}]}], 'mappability_retry_count': 3, 'retries': 0, 'ranked_mappings': [{'original': 'Delusions', 'ranked_candidates': [{'code': 'HP:0000746', 'term': 'Delusions', 'description': \"A false belief regarding the self or persons or objects outside the self that persists despite the facts, and is not considered tenable by one's associates.\", 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Delusions': {\n",
      "  \"best_match_code\": \"HP:0000746\",\n",
      "  \"best_match_term\": \"Delusions\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 92\n",
      "✅ Extracted terms: ['Hallucinations']\n",
      "🌐 [Hallucinations] API Status: 200\n",
      "✅ Results for Hallucinations: [{'code': 'HP:0000738', 'term': 'Hallucinations', 'description': 'Subjectively experienced sensations in the absence of an appropriate stimulus, but which are regarded by the individual as real. They may be of organic origin or associated with MENTAL DISORDERS.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hallucinations', 'candidates': [{'code': 'HP:0000738', 'term': 'Hallucinations', 'description': 'Subjectively experienced sensations in the absence of an appropriate stimulus, but which are regarded by the individual as real. They may be of organic origin or associated with MENTAL DISORDERS.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hallucinations': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000738\",\n",
      "    \"matched_term\": \"Hallucinations\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hallucinations', 'field_type': 'radio', 'extracted_terms': ['Hallucinations'], 'umls_mappings': [{'original': 'Hallucinations', 'candidates': [{'code': 'HP:0000738', 'term': 'Hallucinations', 'description': 'Subjectively experienced sensations in the absence of an appropriate stimulus, but which are regarded by the individual as real. They may be of organic origin or associated with MENTAL DISORDERS.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hallucinations', 'ranked_candidates': [{'code': 'HP:0000738', 'term': 'Hallucinations', 'description': 'Subjectively experienced sensations in the absence of an appropriate stimulus, but which are regarded by the individual as real. They may be of organic origin or associated with MENTAL DISORDERS.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hallucinations': {\n",
      "  \"best_match_code\": \"HP:0000738\",\n",
      "  \"best_match_term\": \"Hallucinations\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 93\n",
      "✅ Extracted terms: ['Obsessive-compulsive disorder']\n",
      "🌐 [Obsessive-compulsive disorder] API Status: 200\n",
      "✅ Results for Obsessive-compulsive disorder: [{'code': 'HP:0000722', 'term': 'Obsessive-compulsive disorder', 'description': 'The behavior of performing an act persistently and repetitively without it leading to reward or pleasure. The act is usually a small, circumscribed behavior, almost ritualistic, yet not pathologically disturbing. Examples of compulsive behavior include twirling of hair, checking something constantly, not wanting pennies in change, straightening tilted pictures, etc.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Obsessive-compulsive disorder', 'candidates': [{'code': 'HP:0000722', 'term': 'Obsessive-compulsive disorder', 'description': 'The behavior of performing an act persistently and repetitively without it leading to reward or pleasure. The act is usually a small, circumscribed behavior, almost ritualistic, yet not pathologically disturbing. Examples of compulsive behavior include twirling of hair, checking something constantly, not wanting pennies in change, straightening tilted pictures, etc.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Obsessive-compulsive disorder': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000722\",\n",
      "    \"matched_term\": \"Obsessive-compulsive disorder\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Obsessive compulsive disorder (OCD)', 'field_type': 'radio', 'extracted_terms': ['Obsessive-compulsive disorder'], 'umls_mappings': [{'original': 'Obsessive-compulsive disorder', 'candidates': [{'code': 'HP:0000722', 'term': 'Obsessive-compulsive disorder', 'description': 'The behavior of performing an act persistently and repetitively without it leading to reward or pleasure. The act is usually a small, circumscribed behavior, almost ritualistic, yet not pathologically disturbing. Examples of compulsive behavior include twirling of hair, checking something constantly, not wanting pennies in change, straightening tilted pictures, etc.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Obsessive-compulsive disorder', 'ranked_candidates': [{'code': 'HP:0000722', 'term': 'Obsessive-compulsive disorder', 'description': 'The behavior of performing an act persistently and repetitively without it leading to reward or pleasure. The act is usually a small, circumscribed behavior, almost ritualistic, yet not pathologically disturbing. Examples of compulsive behavior include twirling of hair, checking something constantly, not wanting pennies in change, straightening tilted pictures, etc.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Obsessive-compulsive disorder': {\n",
      "  \"best_match_code\": \"HP:0000722\",\n",
      "  \"best_match_term\": \"Obsessive-compulsive disorder\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 94\n",
      "✅ Extracted terms: ['Psychosis']\n",
      "🌐 [Psychosis] API Status: 200\n",
      "✅ Results for Psychosis: [{'code': 'HP:0006932', 'term': 'Brief reactive psychosis', 'description': 'A disorder characterized by delusions, hallucinations, disorganized speech, and/or grossly disorganized behavior that resolve within a month.'}, {'code': 'HP:0000709', 'term': 'Psychosis', 'description': 'WHAT: Psychosis.\\tPsychosis: a loss of contact with reality, a thought disorder, or a change of personality or behavior often associated with delusions, illusions, or hallucinations.\\tWHY:\\tPsychosis may occur in systemic lupus erythematosus, mixed connective tissue disease, or with the administration of steroids, cimetadine (Tagemet), or reserpine.\\tHOW:\\tA psychosis probably exists if a patient demonstrates one or more of the following major criteria: MAJOR CRITERIA LOSS OF CONTACT WITH REALITY -- evidenced by the misinterpretation of the environment as hostile when friendly or vice versa, generally causing bizarre responses to normal and usual environmental stimuli. THOUGHT DISTURBANCE -- evidenced by incoherence, marked illogical content, marked loose associations, or patient\\'s admission of mental confusion and abnormal rate of mental activity. PERSONALITY/BEHAVIOR CHANGES -- characterized by rapid onset and reversals of previous behavior patterns, often observed by reliable family member or friend. The diagnosis is further strengthened by the presence of one or more of the following minor criteria: MINOR CRITERIA DELUSIONS -- firmly held beliefs that cannot be dissuaded by logical discussion; generally of a threatening, powerful, or grandiose nature. ILLUSIONS -- misperceptions of environmental stimuli, e.g. perceiving a person instead of an actual tree shadow. HALLUCINATIONS -- perceptions without environmental stimuli, e.g. hearing voices/noises or seeing a face/vision.\\tREFS:\\t1) \"Differential Diagnosis of Psychotic Features\". In Diagnostic and Statistical Manual of Mental Disorders, 3rd ed. (DSM III). Washington, D.C.: American Psychiatric Association, 1980. 2) Rothfield, N: \"Clinical Features of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 69). Philadelphia: W.B. Saunders Co., 1981. 3) Bennet, RM and Spargo, BH: Neuropsychiatric problems in mixed connective tissue disease. Am J Med 65(6), December 1978, pp. 955-62. DN19307-1. 4) Steinberg, AD: \"Management of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 70). Philadelphia: W.B. Saunders Co., 1981.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Psychosis', 'candidates': [{'code': 'HP:0006932', 'term': 'Brief reactive psychosis', 'description': 'A disorder characterized by delusions, hallucinations, disorganized speech, and/or grossly disorganized behavior that resolve within a month.'}, {'code': 'HP:0000709', 'term': 'Psychosis', 'description': 'WHAT: Psychosis.\\tPsychosis: a loss of contact with reality, a thought disorder, or a change of personality or behavior often associated with delusions, illusions, or hallucinations.\\tWHY:\\tPsychosis may occur in systemic lupus erythematosus, mixed connective tissue disease, or with the administration of steroids, cimetadine (Tagemet), or reserpine.\\tHOW:\\tA psychosis probably exists if a patient demonstrates one or more of the following major criteria: MAJOR CRITERIA LOSS OF CONTACT WITH REALITY -- evidenced by the misinterpretation of the environment as hostile when friendly or vice versa, generally causing bizarre responses to normal and usual environmental stimuli. THOUGHT DISTURBANCE -- evidenced by incoherence, marked illogical content, marked loose associations, or patient\\'s admission of mental confusion and abnormal rate of mental activity. PERSONALITY/BEHAVIOR CHANGES -- characterized by rapid onset and reversals of previous behavior patterns, often observed by reliable family member or friend. The diagnosis is further strengthened by the presence of one or more of the following minor criteria: MINOR CRITERIA DELUSIONS -- firmly held beliefs that cannot be dissuaded by logical discussion; generally of a threatening, powerful, or grandiose nature. ILLUSIONS -- misperceptions of environmental stimuli, e.g. perceiving a person instead of an actual tree shadow. HALLUCINATIONS -- perceptions without environmental stimuli, e.g. hearing voices/noises or seeing a face/vision.\\tREFS:\\t1) \"Differential Diagnosis of Psychotic Features\". In Diagnostic and Statistical Manual of Mental Disorders, 3rd ed. (DSM III). Washington, D.C.: American Psychiatric Association, 1980. 2) Rothfield, N: \"Clinical Features of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 69). Philadelphia: W.B. Saunders Co., 1981. 3) Bennet, RM and Spargo, BH: Neuropsychiatric problems in mixed connective tissue disease. Am J Med 65(6), December 1978, pp. 955-62. DN19307-1. 4) Steinberg, AD: \"Management of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 70). Philadelphia: W.B. Saunders Co., 1981.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Psychosis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000709\",\n",
      "    \"matched_term\": \"Psychosis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006932\",\n",
      "    \"matched_term\": \"Brief reactive psychosis\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Psychosis', 'field_type': 'radio', 'extracted_terms': ['Psychosis'], 'umls_mappings': [{'original': 'Psychosis', 'candidates': [{'code': 'HP:0006932', 'term': 'Brief reactive psychosis', 'description': 'A disorder characterized by delusions, hallucinations, disorganized speech, and/or grossly disorganized behavior that resolve within a month.'}, {'code': 'HP:0000709', 'term': 'Psychosis', 'description': 'WHAT: Psychosis.\\tPsychosis: a loss of contact with reality, a thought disorder, or a change of personality or behavior often associated with delusions, illusions, or hallucinations.\\tWHY:\\tPsychosis may occur in systemic lupus erythematosus, mixed connective tissue disease, or with the administration of steroids, cimetadine (Tagemet), or reserpine.\\tHOW:\\tA psychosis probably exists if a patient demonstrates one or more of the following major criteria: MAJOR CRITERIA LOSS OF CONTACT WITH REALITY -- evidenced by the misinterpretation of the environment as hostile when friendly or vice versa, generally causing bizarre responses to normal and usual environmental stimuli. THOUGHT DISTURBANCE -- evidenced by incoherence, marked illogical content, marked loose associations, or patient\\'s admission of mental confusion and abnormal rate of mental activity. PERSONALITY/BEHAVIOR CHANGES -- characterized by rapid onset and reversals of previous behavior patterns, often observed by reliable family member or friend. The diagnosis is further strengthened by the presence of one or more of the following minor criteria: MINOR CRITERIA DELUSIONS -- firmly held beliefs that cannot be dissuaded by logical discussion; generally of a threatening, powerful, or grandiose nature. ILLUSIONS -- misperceptions of environmental stimuli, e.g. perceiving a person instead of an actual tree shadow. HALLUCINATIONS -- perceptions without environmental stimuli, e.g. hearing voices/noises or seeing a face/vision.\\tREFS:\\t1) \"Differential Diagnosis of Psychotic Features\". In Diagnostic and Statistical Manual of Mental Disorders, 3rd ed. (DSM III). Washington, D.C.: American Psychiatric Association, 1980. 2) Rothfield, N: \"Clinical Features of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 69). Philadelphia: W.B. Saunders Co., 1981. 3) Bennet, RM and Spargo, BH: Neuropsychiatric problems in mixed connective tissue disease. Am J Med 65(6), December 1978, pp. 955-62. DN19307-1. 4) Steinberg, AD: \"Management of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 70). Philadelphia: W.B. Saunders Co., 1981.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Psychosis', 'ranked_candidates': [{'code': 'HP:0000709', 'term': 'Psychosis', 'description': 'WHAT: Psychosis.\\tPsychosis: a loss of contact with reality, a thought disorder, or a change of personality or behavior often associated with delusions, illusions, or hallucinations.\\tWHY:\\tPsychosis may occur in systemic lupus erythematosus, mixed connective tissue disease, or with the administration of steroids, cimetadine (Tagemet), or reserpine.\\tHOW:\\tA psychosis probably exists if a patient demonstrates one or more of the following major criteria: MAJOR CRITERIA LOSS OF CONTACT WITH REALITY -- evidenced by the misinterpretation of the environment as hostile when friendly or vice versa, generally causing bizarre responses to normal and usual environmental stimuli. THOUGHT DISTURBANCE -- evidenced by incoherence, marked illogical content, marked loose associations, or patient\\'s admission of mental confusion and abnormal rate of mental activity. PERSONALITY/BEHAVIOR CHANGES -- characterized by rapid onset and reversals of previous behavior patterns, often observed by reliable family member or friend. The diagnosis is further strengthened by the presence of one or more of the following minor criteria: MINOR CRITERIA DELUSIONS -- firmly held beliefs that cannot be dissuaded by logical discussion; generally of a threatening, powerful, or grandiose nature. ILLUSIONS -- misperceptions of environmental stimuli, e.g. perceiving a person instead of an actual tree shadow. HALLUCINATIONS -- perceptions without environmental stimuli, e.g. hearing voices/noises or seeing a face/vision.\\tREFS:\\t1) \"Differential Diagnosis of Psychotic Features\". In Diagnostic and Statistical Manual of Mental Disorders, 3rd ed. (DSM III). Washington, D.C.: American Psychiatric Association, 1980. 2) Rothfield, N: \"Clinical Features of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 69). Philadelphia: W.B. Saunders Co., 1981. 3) Bennet, RM and Spargo, BH: Neuropsychiatric problems in mixed connective tissue disease. Am J Med 65(6), December 1978, pp. 955-62. DN19307-1. 4) Steinberg, AD: \"Management of Systemic Lupus Erythematosus\". In Textbook of Rheumatology (Ch. 70). Philadelphia: W.B. Saunders Co., 1981.', 'confidence': 1.0}, {'code': 'HP:0006932', 'term': 'Brief reactive psychosis', 'description': 'A disorder characterized by delusions, hallucinations, disorganized speech, and/or grossly disorganized behavior that resolve within a month.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Psychosis': {\n",
      "  \"best_match_code\": \"HP:0000709\",\n",
      "  \"best_match_term\": \"Psychosis\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 95\n",
      "✅ Extracted terms: ['Short attention span']\n",
      "🌐 [Short attention span] API Status: 200\n",
      "✅ Results for Short attention span: [{'code': 'HP:0000736', 'term': 'Short attention span', 'description': 'Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Short attention span', 'candidates': [{'code': 'HP:0000736', 'term': 'Short attention span', 'description': 'Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Short attention span': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000736\",\n",
      "    \"matched_term\": \"Short attention span\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Short attention span (incl. ADD/ADHD)', 'field_type': 'radio', 'extracted_terms': ['Short attention span'], 'umls_mappings': [{'original': 'Short attention span', 'candidates': [{'code': 'HP:0000736', 'term': 'Short attention span', 'description': 'Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Short attention span', 'ranked_candidates': [{'code': 'HP:0000736', 'term': 'Short attention span', 'description': 'Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Short attention span': {\n",
      "  \"best_match_code\": \"HP:0000736\",\n",
      "  \"best_match_term\": \"Short attention span\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Short attention span (incl. ADD/ADHD)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Short attention span\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short attention span\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000736\",\n",
      "          \"term\": \"Short attention span\",\n",
      "          \"description\": \"Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short attention span\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000736\",\n",
      "          \"term\": \"Short attention span\",\n",
      "          \"description\": \"Reduced attention span characterized by distractibility and impulsivity. [PMID:26386541]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Short attention span\",\n",
      "      \"best_match_code\": \"HP:0000736\",\n",
      "      \"best_match_term\": \"Short attention span\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0262630\n",
      "🧩 ancestor_cuis ['C0574125', 'C0564672', 'C2720507', 'C4304688', 'C0037088', 'C1287344']\n",
      "🧩 candidate_details [{'cui': 'C0574125', 'name': 'Functional finding'}, {'cui': 'C0564672', 'name': 'Cognitive function observations'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C4304688', 'name': 'Decline in functional status'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C1287344', 'name': 'Finding related to ability to concentrate'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Short attention span (incl. ADD/ADHD)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Short attention span\"\n",
      "  \"best_match_code\": \"HP:0000736\",\n",
      "  \"best_match_term\": \"Short attention span\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0574125 (Functional finding)\n",
      "- C0564672 (Cognitive function observations)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C4304688 (Decline in functional status)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C1287344 (Finding related to ability to concentrate)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 575, 'total_tokens': 576, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeKgYGmPdKy1KgvONpKrERhI2oaN', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--4b989698-863c-4a47-b43e-1c18a53a384b-0' usage_metadata={'input_tokens': 575, 'output_tokens': 1, 'total_tokens': 576, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 96\n",
      "✅ Extracted terms: ['Atrophic scar']\n",
      "🌐 [Atrophic scar] API Status: 200\n",
      "✅ Results for Atrophic scar: [{'code': 'HP:0001075', 'term': 'Atrophic scars', 'description': 'Scars that form a depression compared to the level of the surrounding skin because of damage to the collagen, fat or other tissues below the skin. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0031158', 'term': 'Widened atrophic scar', 'description': 'An atrophic scar (fibrous connective tissue resulting from incomplete healing of a wound) that has stretched (gotten wider), a manifestation of tissue fragility. [PMID:22353005]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Atrophic scar', 'candidates': [{'code': 'HP:0001075', 'term': 'Atrophic scars', 'description': 'Scars that form a depression compared to the level of the surrounding skin because of damage to the collagen, fat or other tissues below the skin. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0031158', 'term': 'Widened atrophic scar', 'description': 'An atrophic scar (fibrous connective tissue resulting from incomplete healing of a wound) that has stretched (gotten wider), a manifestation of tissue fragility. [PMID:22353005]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Atrophic scar': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001075\",\n",
      "    \"matched_term\": \"Atrophic scars\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031158\",\n",
      "    \"matched_term\": \"Widened atrophic scar\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Atrophic scars', 'field_type': 'radio', 'extracted_terms': ['Atrophic scar'], 'umls_mappings': [{'original': 'Atrophic scar', 'candidates': [{'code': 'HP:0001075', 'term': 'Atrophic scars', 'description': 'Scars that form a depression compared to the level of the surrounding skin because of damage to the collagen, fat or other tissues below the skin. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0031158', 'term': 'Widened atrophic scar', 'description': 'An atrophic scar (fibrous connective tissue resulting from incomplete healing of a wound) that has stretched (gotten wider), a manifestation of tissue fragility. [PMID:22353005]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Atrophic scar', 'ranked_candidates': [{'code': 'HP:0001075', 'term': 'Atrophic scars', 'description': 'Scars that form a depression compared to the level of the surrounding skin because of damage to the collagen, fat or other tissues below the skin. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0031158', 'term': 'Widened atrophic scar', 'description': 'An atrophic scar (fibrous connective tissue resulting from incomplete healing of a wound) that has stretched (gotten wider), a manifestation of tissue fragility. [PMID:22353005]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Atrophic scar': {\n",
      "  \"best_match_code\": \"HP:0001075\",\n",
      "  \"best_match_term\": \"Atrophic scars\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 97\n",
      "✅ Extracted terms: ['Café-au-lait spots']\n",
      "🌐 [Café-au-lait spots] API Status: 200\n",
      "✅ Results for Café-au-lait spots: [{'code': 'HP:0000957', 'term': 'Cafe-au-lait spots', 'description': \"Light brown pigmented macules associated with NEUROFIBROMATOSIS and Albright's syndrome (see FIBROUS DYSPLASIA, POLYOSTOTIC).\"}, {'code': 'HP:0007429', 'term': 'Few cafe-au-lait spots', 'description': 'The presence of two to five cafe-au-lait macules. [https://orcid.org/0000-0003-1773-4011]'}, {'code': 'HP:0007565', 'term': 'Multiple cafe-au-lait spots', 'description': 'The presence of six or more cafe-au-lait spots. [https://orcid.org/0000-0003-1773-4011]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Café-au-lait spots', 'candidates': [{'code': 'HP:0000957', 'term': 'Cafe-au-lait spots', 'description': \"Light brown pigmented macules associated with NEUROFIBROMATOSIS and Albright's syndrome (see FIBROUS DYSPLASIA, POLYOSTOTIC).\"}, {'code': 'HP:0007429', 'term': 'Few cafe-au-lait spots', 'description': 'The presence of two to five cafe-au-lait macules. [https://orcid.org/0000-0003-1773-4011]'}, {'code': 'HP:0007565', 'term': 'Multiple cafe-au-lait spots', 'description': 'The presence of six or more cafe-au-lait spots. [https://orcid.org/0000-0003-1773-4011]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Café-au-lait spots': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000957\",\n",
      "    \"matched_term\": \"Cafe-au-lait spots\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007429\",\n",
      "    \"matched_term\": \"Few cafe-au-lait spots\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007565\",\n",
      "    \"matched_term\": \"Multiple cafe-au-lait spots\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Café-au-lait spots', 'field_type': 'radio', 'extracted_terms': ['Café-au-lait spots'], 'umls_mappings': [{'original': 'Café-au-lait spots', 'candidates': [{'code': 'HP:0000957', 'term': 'Cafe-au-lait spots', 'description': \"Light brown pigmented macules associated with NEUROFIBROMATOSIS and Albright's syndrome (see FIBROUS DYSPLASIA, POLYOSTOTIC).\"}, {'code': 'HP:0007429', 'term': 'Few cafe-au-lait spots', 'description': 'The presence of two to five cafe-au-lait macules. [https://orcid.org/0000-0003-1773-4011]'}, {'code': 'HP:0007565', 'term': 'Multiple cafe-au-lait spots', 'description': 'The presence of six or more cafe-au-lait spots. [https://orcid.org/0000-0003-1773-4011]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Café-au-lait spots', 'ranked_candidates': [{'code': 'HP:0000957', 'term': 'Cafe-au-lait spots', 'description': \"Light brown pigmented macules associated with NEUROFIBROMATOSIS and Albright's syndrome (see FIBROUS DYSPLASIA, POLYOSTOTIC).\", 'confidence': 1.0}, {'code': 'HP:0007429', 'term': 'Few cafe-au-lait spots', 'description': 'The presence of two to five cafe-au-lait macules. [https://orcid.org/0000-0003-1773-4011]', 'confidence': 0.7}, {'code': 'HP:0007565', 'term': 'Multiple cafe-au-lait spots', 'description': 'The presence of six or more cafe-au-lait spots. [https://orcid.org/0000-0003-1773-4011]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Café-au-lait spots': {\n",
      "  \"best_match_code\": \"HP:0000957\",\n",
      "  \"best_match_term\": \"Cafe-au-lait spots\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 98\n",
      "✅ Extracted terms: ['Hyperpigmentation of the skin']\n",
      "🌐 [Hyperpigmentation of the skin] API Status: 200\n",
      "✅ Results for Hyperpigmentation of the skin: [{'code': 'HP:0000953', 'term': 'Hyperpigmentation of the skin', 'description': 'Excessive pigmentation of the skin, usually as a result of increased epidermal or dermal melanin pigmentation, hypermelanosis. Hyperpigmentation can be localized or generalized. The condition may arise from exposure to light, chemicals or other substances, or from a primary metabolic imbalance.'}, {'code': 'HP:0009123', 'term': 'Mixed hypo- and hyperpigmentation of the skin', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hyperpigmentation of the skin', 'candidates': [{'code': 'HP:0000953', 'term': 'Hyperpigmentation of the skin', 'description': 'Excessive pigmentation of the skin, usually as a result of increased epidermal or dermal melanin pigmentation, hypermelanosis. Hyperpigmentation can be localized or generalized. The condition may arise from exposure to light, chemicals or other substances, or from a primary metabolic imbalance.'}, {'code': 'HP:0009123', 'term': 'Mixed hypo- and hyperpigmentation of the skin', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hyperpigmentation of the skin': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000953\",\n",
      "    \"matched_term\": \"Hyperpigmentation of the skin\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009123\",\n",
      "    \"matched_term\": \"Mixed hypo- and hyperpigmentation of the skin\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hyperpigmentation', 'field_type': 'radio', 'extracted_terms': ['Hyperpigmentation of the skin'], 'umls_mappings': [{'original': 'Hyperpigmentation of the skin', 'candidates': [{'code': 'HP:0000953', 'term': 'Hyperpigmentation of the skin', 'description': 'Excessive pigmentation of the skin, usually as a result of increased epidermal or dermal melanin pigmentation, hypermelanosis. Hyperpigmentation can be localized or generalized. The condition may arise from exposure to light, chemicals or other substances, or from a primary metabolic imbalance.'}, {'code': 'HP:0009123', 'term': 'Mixed hypo- and hyperpigmentation of the skin', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hyperpigmentation of the skin', 'ranked_candidates': [{'code': 'HP:0000953', 'term': 'Hyperpigmentation of the skin', 'description': 'Excessive pigmentation of the skin, usually as a result of increased epidermal or dermal melanin pigmentation, hypermelanosis. Hyperpigmentation can be localized or generalized. The condition may arise from exposure to light, chemicals or other substances, or from a primary metabolic imbalance.', 'confidence': 1.0}, {'code': 'HP:0009123', 'term': 'Mixed hypo- and hyperpigmentation of the skin', 'description': None, 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hyperpigmentation of the skin': {\n",
      "  \"best_match_code\": \"HP:0000953\",\n",
      "  \"best_match_term\": \"Hyperpigmentation of the skin\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 99\n",
      "✅ Extracted terms: ['Hypopigmentation of the skin']\n",
      "🌐 [Hypopigmentation of the skin] API Status: 200\n",
      "✅ Results for Hypopigmentation of the skin: [{'code': 'HP:0001010', 'term': 'Hypopigmentation of the skin', 'description': 'A condition caused by a deficiency or a loss of melanin pigmentation in the epidermis, also known as hypomelanosis. Hypopigmentation can be localized or generalized, and may result from genetic defects, trauma, inflammation, or infections.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypopigmentation of the skin', 'candidates': [{'code': 'HP:0001010', 'term': 'Hypopigmentation of the skin', 'description': 'A condition caused by a deficiency or a loss of melanin pigmentation in the epidermis, also known as hypomelanosis. Hypopigmentation can be localized or generalized, and may result from genetic defects, trauma, inflammation, or infections.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypopigmentation of the skin': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001010\",\n",
      "    \"matched_term\": \"Hypopigmentation of the skin\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hypopigmentation', 'field_type': 'radio', 'extracted_terms': ['Hypopigmentation of the skin'], 'umls_mappings': [{'original': 'Hypopigmentation of the skin', 'candidates': [{'code': 'HP:0001010', 'term': 'Hypopigmentation of the skin', 'description': 'A condition caused by a deficiency or a loss of melanin pigmentation in the epidermis, also known as hypomelanosis. Hypopigmentation can be localized or generalized, and may result from genetic defects, trauma, inflammation, or infections.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypopigmentation of the skin', 'ranked_candidates': [{'code': 'HP:0001010', 'term': 'Hypopigmentation of the skin', 'description': 'A condition caused by a deficiency or a loss of melanin pigmentation in the epidermis, also known as hypomelanosis. Hypopigmentation can be localized or generalized, and may result from genetic defects, trauma, inflammation, or infections.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypopigmentation of the skin': {\n",
      "  \"best_match_code\": \"HP:0001010\",\n",
      "  \"best_match_term\": \"Hypopigmentation of the skin\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 100\n",
      "✅ Extracted terms: ['Hypohidrosis']\n",
      "🌐 [Hypohidrosis] API Status: 200\n",
      "✅ Results for Hypohidrosis: [{'code': 'HP:0000966', 'term': 'Hypohidrosis', 'description': 'Abnormally diminished or absent perspiration. Both generalized and segmented (reduced or absent sweating in circumscribed locations) forms of the disease are usually associated with other underlying conditions.'}, {'code': 'HP:0007550', 'term': 'Hypohidrosis or hyperhidrosis', 'description': None}, {'code': 'HP:0034012', 'term': 'Palmoplantar hypohidrosis', 'description': 'Decreased sweating on the palms and soles. [PMID:24664640]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypohidrosis', 'candidates': [{'code': 'HP:0000966', 'term': 'Hypohidrosis', 'description': 'Abnormally diminished or absent perspiration. Both generalized and segmented (reduced or absent sweating in circumscribed locations) forms of the disease are usually associated with other underlying conditions.'}, {'code': 'HP:0007550', 'term': 'Hypohidrosis or hyperhidrosis', 'description': None}, {'code': 'HP:0034012', 'term': 'Palmoplantar hypohidrosis', 'description': 'Decreased sweating on the palms and soles. [PMID:24664640]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypohidrosis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000966\",\n",
      "    \"matched_term\": \"Hypohidrosis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007550\",\n",
      "    \"matched_term\": \"Hypohidrosis or hyperhidrosis\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0034012\",\n",
      "    \"matched_term\": \"Palmoplantar hypohidrosis\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Decreased sweating (hypohidrosis)', 'field_type': 'radio', 'extracted_terms': ['Hypohidrosis'], 'umls_mappings': [{'original': 'Hypohidrosis', 'candidates': [{'code': 'HP:0000966', 'term': 'Hypohidrosis', 'description': 'Abnormally diminished or absent perspiration. Both generalized and segmented (reduced or absent sweating in circumscribed locations) forms of the disease are usually associated with other underlying conditions.'}, {'code': 'HP:0007550', 'term': 'Hypohidrosis or hyperhidrosis', 'description': None}, {'code': 'HP:0034012', 'term': 'Palmoplantar hypohidrosis', 'description': 'Decreased sweating on the palms and soles. [PMID:24664640]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypohidrosis', 'ranked_candidates': [{'code': 'HP:0000966', 'term': 'Hypohidrosis', 'description': 'Abnormally diminished or absent perspiration. Both generalized and segmented (reduced or absent sweating in circumscribed locations) forms of the disease are usually associated with other underlying conditions.', 'confidence': 1.0}, {'code': 'HP:0007550', 'term': 'Hypohidrosis or hyperhidrosis', 'description': None, 'confidence': 0.5}, {'code': 'HP:0034012', 'term': 'Palmoplantar hypohidrosis', 'description': 'Decreased sweating on the palms and soles. [PMID:24664640]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypohidrosis': {\"best_match_code\": \"HP:0000966\", \"best_match_term\": \"Hypohidrosis\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 101\n",
      "✅ Extracted terms: ['Hyperhidrosis']\n",
      "🌐 [Hyperhidrosis] API Status: 200\n",
      "✅ Results for Hyperhidrosis: [{'code': 'HP:0001069', 'term': 'Episodic hyperhidrosis', 'description': 'Intermittent episodes of abnormally increased perspiration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000975', 'term': 'Hyperhidrosis', 'description': 'Excessive sweating. In the localized type, the most frequent sites are the palms, soles, axillae, inguinal folds, and the perineal area. Its chief cause is thought to be emotional. Generalized hyperhidrosis may be induced by a hot, humid environment, by fever, or by vigorous exercise.'}, {'code': 'HP:0007410', 'term': 'Hyperhidrosis of palms and soles', 'description': 'An abnormally increased perspiration on palms and soles. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hyperhidrosis', 'candidates': [{'code': 'HP:0001069', 'term': 'Episodic hyperhidrosis', 'description': 'Intermittent episodes of abnormally increased perspiration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000975', 'term': 'Hyperhidrosis', 'description': 'Excessive sweating. In the localized type, the most frequent sites are the palms, soles, axillae, inguinal folds, and the perineal area. Its chief cause is thought to be emotional. Generalized hyperhidrosis may be induced by a hot, humid environment, by fever, or by vigorous exercise.'}, {'code': 'HP:0007410', 'term': 'Hyperhidrosis of palms and soles', 'description': 'An abnormally increased perspiration on palms and soles. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hyperhidrosis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000975\",\n",
      "    \"matched_term\": \"Hyperhidrosis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001069\",\n",
      "    \"matched_term\": \"Episodic hyperhidrosis\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007410\",\n",
      "    \"matched_term\": \"Hyperhidrosis of palms and soles\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Increased sweating (hyperhidrosis)', 'field_type': 'radio', 'extracted_terms': ['Hyperhidrosis'], 'umls_mappings': [{'original': 'Hyperhidrosis', 'candidates': [{'code': 'HP:0001069', 'term': 'Episodic hyperhidrosis', 'description': 'Intermittent episodes of abnormally increased perspiration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000975', 'term': 'Hyperhidrosis', 'description': 'Excessive sweating. In the localized type, the most frequent sites are the palms, soles, axillae, inguinal folds, and the perineal area. Its chief cause is thought to be emotional. Generalized hyperhidrosis may be induced by a hot, humid environment, by fever, or by vigorous exercise.'}, {'code': 'HP:0007410', 'term': 'Hyperhidrosis of palms and soles', 'description': 'An abnormally increased perspiration on palms and soles. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hyperhidrosis', 'ranked_candidates': [{'code': 'HP:0000975', 'term': 'Hyperhidrosis', 'description': 'Excessive sweating. In the localized type, the most frequent sites are the palms, soles, axillae, inguinal folds, and the perineal area. Its chief cause is thought to be emotional. Generalized hyperhidrosis may be induced by a hot, humid environment, by fever, or by vigorous exercise.', 'confidence': 1.0}, {'code': 'HP:0001069', 'term': 'Episodic hyperhidrosis', 'description': 'Intermittent episodes of abnormally increased perspiration. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0007410', 'term': 'Hyperhidrosis of palms and soles', 'description': 'An abnormally increased perspiration on palms and soles. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hyperhidrosis': {\n",
      "  \"best_match_code\": \"HP:0000975\",\n",
      "  \"best_match_term\": \"Hyperhidrosis\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 102\n",
      "✅ Extracted terms: ['Skin fragility']\n",
      "🌐 [Skin fragility] API Status: 200\n",
      "✅ Results for Skin fragility: [{'code': 'HP:0001030', 'term': 'Skin fragility', 'description': 'Skin that splits easily with minimal injury. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007585', 'term': 'Skin fragility with non-scarring blistering', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Skin fragility', 'candidates': [{'code': 'HP:0001030', 'term': 'Skin fragility', 'description': 'Skin that splits easily with minimal injury. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007585', 'term': 'Skin fragility with non-scarring blistering', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Skin fragility': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001030\",\n",
      "    \"matched_term\": \"Skin fragility\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007585\",\n",
      "    \"matched_term\": \"Skin fragility with non-scarring blistering\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Skin fragility', 'field_type': 'radio', 'extracted_terms': ['Skin fragility'], 'umls_mappings': [{'original': 'Skin fragility', 'candidates': [{'code': 'HP:0001030', 'term': 'Skin fragility', 'description': 'Skin that splits easily with minimal injury. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007585', 'term': 'Skin fragility with non-scarring blistering', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Skin fragility', 'ranked_candidates': [{'code': 'HP:0001030', 'term': 'Skin fragility', 'description': 'Skin that splits easily with minimal injury. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0007585', 'term': 'Skin fragility with non-scarring blistering', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Skin fragility': {\n",
      "  \"best_match_code\": \"HP:0001030\",\n",
      "  \"best_match_term\": \"Skin fragility\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 103\n",
      "✅ Extracted terms: ['Photosensitivity']\n",
      "🌐 [Photosensitivity] API Status: 200\n",
      "✅ Results for Photosensitivity: [{'code': 'HP:0000992', 'term': 'Cutaneous photosensitivity', 'description': 'increased sensitivity of the skin to light and other sources of UV'}, {'code': 'HP:0007396', 'term': 'Early cutaneous photosensitivity', 'description': 'Photosensitivity of the skin occurring early in life. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007537', 'term': 'Severe photosensitivity', 'description': 'A severe degree of photosensitivity of the skin. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Photosensitivity', 'candidates': [{'code': 'HP:0000992', 'term': 'Cutaneous photosensitivity', 'description': 'increased sensitivity of the skin to light and other sources of UV'}, {'code': 'HP:0007396', 'term': 'Early cutaneous photosensitivity', 'description': 'Photosensitivity of the skin occurring early in life. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007537', 'term': 'Severe photosensitivity', 'description': 'A severe degree of photosensitivity of the skin. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Photosensitivity': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000992\",\n",
      "    \"matched_term\": \"Cutaneous photosensitivity\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007537\",\n",
      "    \"matched_term\": \"Severe photosensitivity\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007396\",\n",
      "    \"matched_term\": \"Early cutaneous photosensitivity\",\n",
      "    \"confidence\": \"80%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Skin sensitivity to sunlight', 'field_type': 'radio', 'extracted_terms': ['Photosensitivity'], 'umls_mappings': [{'original': 'Photosensitivity', 'candidates': [{'code': 'HP:0000992', 'term': 'Cutaneous photosensitivity', 'description': 'increased sensitivity of the skin to light and other sources of UV'}, {'code': 'HP:0007396', 'term': 'Early cutaneous photosensitivity', 'description': 'Photosensitivity of the skin occurring early in life. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007537', 'term': 'Severe photosensitivity', 'description': 'A severe degree of photosensitivity of the skin. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Photosensitivity', 'ranked_candidates': [{'code': 'HP:0000992', 'term': 'Cutaneous photosensitivity', 'description': 'increased sensitivity of the skin to light and other sources of UV', 'confidence': 1.0}, {'code': 'HP:0007537', 'term': 'Severe photosensitivity', 'description': 'A severe degree of photosensitivity of the skin. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.9}, {'code': 'HP:0007396', 'term': 'Early cutaneous photosensitivity', 'description': 'Photosensitivity of the skin occurring early in life. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Photosensitivity': {\n",
      "  \"best_match_code\": \"HP:0000992\",\n",
      "  \"best_match_term\": \"Cutaneous photosensitivity\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 104\n",
      "✅ Extracted terms: ['Thick skin']\n",
      "🌐 [Thick skin] API Status: 200\n",
      "✅ Results for Thick skin: [{'code': 'HP:0001072', 'term': 'Thick skin', 'description': 'Laminar thickening of skin. [https://orcid.org/0009-0006-4530-3154]'}, {'code': 'HP:0008399', 'term': 'Thick skin around nails', 'description': 'A thickening of the stratum corneum, the outer layer of the skin, in the region surrounding the nails. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007403', 'term': 'Thick skin of soles', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Thick skin', 'candidates': [{'code': 'HP:0001072', 'term': 'Thick skin', 'description': 'Laminar thickening of skin. [https://orcid.org/0009-0006-4530-3154]'}, {'code': 'HP:0008399', 'term': 'Thick skin around nails', 'description': 'A thickening of the stratum corneum, the outer layer of the skin, in the region surrounding the nails. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007403', 'term': 'Thick skin of soles', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Thick skin': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001072\",\n",
      "    \"matched_term\": \"Thick skin\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008399\",\n",
      "    \"matched_term\": \"Thick skin around nails\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007403\",\n",
      "    \"matched_term\": \"Thick skin of soles\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Thick skin (keratoderma/hyperkeratosis)', 'field_type': 'radio', 'extracted_terms': ['Thick skin'], 'umls_mappings': [{'original': 'Thick skin', 'candidates': [{'code': 'HP:0001072', 'term': 'Thick skin', 'description': 'Laminar thickening of skin. [https://orcid.org/0009-0006-4530-3154]'}, {'code': 'HP:0008399', 'term': 'Thick skin around nails', 'description': 'A thickening of the stratum corneum, the outer layer of the skin, in the region surrounding the nails. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007403', 'term': 'Thick skin of soles', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Thick skin', 'ranked_candidates': [{'code': 'HP:0001072', 'term': 'Thick skin', 'description': 'Laminar thickening of skin. [https://orcid.org/0009-0006-4530-3154]', 'confidence': 1.0}, {'code': 'HP:0008399', 'term': 'Thick skin around nails', 'description': 'A thickening of the stratum corneum, the outer layer of the skin, in the region surrounding the nails. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}, {'code': 'HP:0007403', 'term': 'Thick skin of soles', 'description': None, 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Thick skin': {\n",
      "  \"best_match_code\": \"HP:0001072\",\n",
      "  \"best_match_term\": \"Thick skin\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 105\n",
      "✅ Extracted terms: ['Skin hyperextensibility']\n",
      "🌐 [Skin hyperextensibility] API Status: 200\n",
      "✅ Results for Skin hyperextensibility: [{'code': 'HP:0000974', 'term': 'Skin hyperextensibility', 'description': 'A condition in which the skin can be stretched beyond normal, and then returns to its initial position. [https://orcid.org/0009-0006-4530-3154]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Skin hyperextensibility', 'candidates': [{'code': 'HP:0000974', 'term': 'Skin hyperextensibility', 'description': 'A condition in which the skin can be stretched beyond normal, and then returns to its initial position. [https://orcid.org/0009-0006-4530-3154]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Skin hyperextensibility': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000974\",\n",
      "    \"matched_term\": \"Skin hyperextensibility\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hyperelastic skin', 'field_type': 'radio', 'extracted_terms': ['Skin hyperextensibility'], 'umls_mappings': [{'original': 'Skin hyperextensibility', 'candidates': [{'code': 'HP:0000974', 'term': 'Skin hyperextensibility', 'description': 'A condition in which the skin can be stretched beyond normal, and then returns to its initial position. [https://orcid.org/0009-0006-4530-3154]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Skin hyperextensibility', 'ranked_candidates': [{'code': 'HP:0000974', 'term': 'Skin hyperextensibility', 'description': 'A condition in which the skin can be stretched beyond normal, and then returns to its initial position. [https://orcid.org/0009-0006-4530-3154]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Skin hyperextensibility': {\"best_match_code\": \"HP:0000974\", \"best_match_term\": \"Skin hyperextensibility\", \"confidence\": \"90%\"}\n",
      "✅ Processed row 106\n",
      "✅ Extracted terms: ['Cutis laxa']\n",
      "🌐 [Cutis laxa] API Status: 200\n",
      "✅ Results for Cutis laxa: [{'code': 'HP:0000973', 'term': 'Cutis laxa', 'description': 'A group of connective tissue diseases in which skin hangs in loose pendulous folds. It is believed to be associated with decreased elastic tissue formation as well as an abnormality in elastin formation. Cutis laxa is usually a genetic disease, but acquired cases have been reported. (From Dorland, 27th ed)'}, {'code': 'HP:0007517', 'term': 'Palmoplantar cutis laxa', 'description': 'Loose, wrinkled skin of hands and feet. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Cutis laxa', 'candidates': [{'code': 'HP:0000973', 'term': 'Cutis laxa', 'description': 'A group of connective tissue diseases in which skin hangs in loose pendulous folds. It is believed to be associated with decreased elastic tissue formation as well as an abnormality in elastin formation. Cutis laxa is usually a genetic disease, but acquired cases have been reported. (From Dorland, 27th ed)'}, {'code': 'HP:0007517', 'term': 'Palmoplantar cutis laxa', 'description': 'Loose, wrinkled skin of hands and feet. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Cutis laxa': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000973\",\n",
      "    \"matched_term\": \"Cutis laxa\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007517\",\n",
      "    \"matched_term\": \"Palmoplantar cutis laxa\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': \"Hypoelastic or 'saggy' skin (cutis laxa)\", 'field_type': 'radio', 'extracted_terms': ['Cutis laxa'], 'umls_mappings': [{'original': 'Cutis laxa', 'candidates': [{'code': 'HP:0000973', 'term': 'Cutis laxa', 'description': 'A group of connective tissue diseases in which skin hangs in loose pendulous folds. It is believed to be associated with decreased elastic tissue formation as well as an abnormality in elastin formation. Cutis laxa is usually a genetic disease, but acquired cases have been reported. (From Dorland, 27th ed)'}, {'code': 'HP:0007517', 'term': 'Palmoplantar cutis laxa', 'description': 'Loose, wrinkled skin of hands and feet. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Cutis laxa', 'ranked_candidates': [{'code': 'HP:0000973', 'term': 'Cutis laxa', 'description': 'A group of connective tissue diseases in which skin hangs in loose pendulous folds. It is believed to be associated with decreased elastic tissue formation as well as an abnormality in elastin formation. Cutis laxa is usually a genetic disease, but acquired cases have been reported. (From Dorland, 27th ed)', 'confidence': 1.0}, {'code': 'HP:0007517', 'term': 'Palmoplantar cutis laxa', 'description': 'Loose, wrinkled skin of hands and feet. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Cutis laxa': {\n",
      "  \"best_match_code\": \"HP:0000973\",\n",
      "  \"best_match_term\": \"Cutis laxa\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 107\n",
      "✅ Extracted terms: ['Abnormality of limb bone morphology']\n",
      "🌐 [Abnormality of limb bone morphology] API Status: 200\n",
      "✅ Results for Abnormality of limb bone morphology: [{'code': 'HP:0002813', 'term': 'Abnormality of limb bone morphology', 'description': 'Any abnormality of bones of the arms or legs. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of limb bone morphology', 'candidates': [{'code': 'HP:0002813', 'term': 'Abnormality of limb bone morphology', 'description': 'Any abnormality of bones of the arms or legs. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of limb bone morphology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002813\",\n",
      "    \"matched_term\": \"Abnormality of limb bone morphology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Arm and/or leg bone differences since birth', 'field_type': 'radio', 'extracted_terms': ['Abnormality of limb bone morphology'], 'umls_mappings': [{'original': 'Abnormality of limb bone morphology', 'candidates': [{'code': 'HP:0002813', 'term': 'Abnormality of limb bone morphology', 'description': 'Any abnormality of bones of the arms or legs. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of limb bone morphology', 'ranked_candidates': [{'code': 'HP:0002813', 'term': 'Abnormality of limb bone morphology', 'description': 'Any abnormality of bones of the arms or legs. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of limb bone morphology': {\n",
      "  \"best_match_code\": \"HP:0002813\",\n",
      "  \"best_match_term\": \"Abnormality of limb bone morphology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 108\n",
      "✅ Extracted terms: ['Abnormal curvature of the vertebral column']\n",
      "🌐 [Abnormal curvature of the vertebral column] API Status: 200\n",
      "✅ Results for Abnormal curvature of the vertebral column: [{'code': 'HP:0010674', 'term': 'Abnormal curvature of the vertebral column', 'description': 'The presence of an abnormal curvature of the vertebral column. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal curvature of the vertebral column', 'candidates': [{'code': 'HP:0010674', 'term': 'Abnormal curvature of the vertebral column', 'description': 'The presence of an abnormal curvature of the vertebral column. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal curvature of the vertebral column': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010674\",\n",
      "    \"matched_term\": \"Abnormal curvature of the vertebral column\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Curvature of the spine (scoliosis/kyphosis)', 'field_type': 'radio', 'extracted_terms': ['Abnormal curvature of the vertebral column'], 'umls_mappings': [{'original': 'Abnormal curvature of the vertebral column', 'candidates': [{'code': 'HP:0010674', 'term': 'Abnormal curvature of the vertebral column', 'description': 'The presence of an abnormal curvature of the vertebral column. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal curvature of the vertebral column', 'ranked_candidates': [{'code': 'HP:0010674', 'term': 'Abnormal curvature of the vertebral column', 'description': 'The presence of an abnormal curvature of the vertebral column. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal curvature of the vertebral column': {\n",
      "  \"best_match_code\": \"HP:0010674\",\n",
      "  \"best_match_term\": \"Abnormal curvature of the vertebral column\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 109\n",
      "✅ Extracted terms: ['Joint hypermobility']\n",
      "🌐 [Joint hypermobility] API Status: 200\n",
      "✅ Results for Joint hypermobility: [{'code': 'HP:0003318', 'term': 'Cervical spine joint hypermobility', 'description': None}, {'code': 'HP:0020152', 'term': 'Distal joint hypermobility', 'description': 'Lack of stability of a distal joint (e.g., finger). []'}, {'code': 'HP:0006094', 'term': 'Finger joint hypermobility', 'description': None}, {'code': 'HP:0002761', 'term': 'Generalized joint hypermobility', 'description': 'Joint hypermobility (ability of a joint to move beyond its normal range of motion) affecting many or all joints of the body. In individuals with Joint hypermobility at multiple sites (usually five or more), the term generalized joint hypermobility is preferred. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045087', 'term': 'Hip joint hypermobility', 'description': None}, {'code': 'HP:0001382', 'term': 'Joint hypermobility', 'description': 'The capability that a joint (or a group of joints) has to move, passively and/or actively, beyond normal limits along physiological axes. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045086', 'term': 'Knee joint hypermobility', 'description': 'The ability of the knee to move past its normal range of motion, (knee hyperextension is greater than 10 degrees). [https://orcid.org/0000-0002-6387-4317, PMID:28599980]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Joint hypermobility', 'candidates': [{'code': 'HP:0003318', 'term': 'Cervical spine joint hypermobility', 'description': None}, {'code': 'HP:0020152', 'term': 'Distal joint hypermobility', 'description': 'Lack of stability of a distal joint (e.g., finger). []'}, {'code': 'HP:0006094', 'term': 'Finger joint hypermobility', 'description': None}, {'code': 'HP:0002761', 'term': 'Generalized joint hypermobility', 'description': 'Joint hypermobility (ability of a joint to move beyond its normal range of motion) affecting many or all joints of the body. In individuals with Joint hypermobility at multiple sites (usually five or more), the term generalized joint hypermobility is preferred. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045087', 'term': 'Hip joint hypermobility', 'description': None}, {'code': 'HP:0001382', 'term': 'Joint hypermobility', 'description': 'The capability that a joint (or a group of joints) has to move, passively and/or actively, beyond normal limits along physiological axes. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045086', 'term': 'Knee joint hypermobility', 'description': 'The ability of the knee to move past its normal range of motion, (knee hyperextension is greater than 10 degrees). [https://orcid.org/0000-0002-6387-4317, PMID:28599980]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Joint hypermobility': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001382\",\n",
      "    \"matched_term\": \"Joint hypermobility\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002761\",\n",
      "    \"matched_term\": \"Generalized joint hypermobility\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0020152\",\n",
      "    \"matched_term\": \"Distal joint hypermobility\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003318\",\n",
      "    \"matched_term\": \"Cervical spine joint hypermobility\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006094\",\n",
      "    \"matched_term\": \"Finger joint hypermobility\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0045087\",\n",
      "    \"matched_term\": \"Hip joint hypermobility\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0045086\",\n",
      "    \"matched_term\": \"Knee joint hypermobility\",\n",
      "    \"confidence\": \"60%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Flexible joints (hypermobile)', 'field_type': 'radio', 'extracted_terms': ['Joint hypermobility'], 'umls_mappings': [{'original': 'Joint hypermobility', 'candidates': [{'code': 'HP:0003318', 'term': 'Cervical spine joint hypermobility', 'description': None}, {'code': 'HP:0020152', 'term': 'Distal joint hypermobility', 'description': 'Lack of stability of a distal joint (e.g., finger). []'}, {'code': 'HP:0006094', 'term': 'Finger joint hypermobility', 'description': None}, {'code': 'HP:0002761', 'term': 'Generalized joint hypermobility', 'description': 'Joint hypermobility (ability of a joint to move beyond its normal range of motion) affecting many or all joints of the body. In individuals with Joint hypermobility at multiple sites (usually five or more), the term generalized joint hypermobility is preferred. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045087', 'term': 'Hip joint hypermobility', 'description': None}, {'code': 'HP:0001382', 'term': 'Joint hypermobility', 'description': 'The capability that a joint (or a group of joints) has to move, passively and/or actively, beyond normal limits along physiological axes. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]'}, {'code': 'HP:0045086', 'term': 'Knee joint hypermobility', 'description': 'The ability of the knee to move past its normal range of motion, (knee hyperextension is greater than 10 degrees). [https://orcid.org/0000-0002-6387-4317, PMID:28599980]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Joint hypermobility', 'ranked_candidates': [{'code': 'HP:0001382', 'term': 'Joint hypermobility', 'description': 'The capability that a joint (or a group of joints) has to move, passively and/or actively, beyond normal limits along physiological axes. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]', 'confidence': 1.0}, {'code': 'HP:0002761', 'term': 'Generalized joint hypermobility', 'description': 'Joint hypermobility (ability of a joint to move beyond its normal range of motion) affecting many or all joints of the body. In individuals with Joint hypermobility at multiple sites (usually five or more), the term generalized joint hypermobility is preferred. [https://orcid.org/0000-0002-0736-9199, PMID:28145606]', 'confidence': 0.9}, {'code': 'HP:0020152', 'term': 'Distal joint hypermobility', 'description': 'Lack of stability of a distal joint (e.g., finger). []', 'confidence': 0.7}, {'code': 'HP:0003318', 'term': 'Cervical spine joint hypermobility', 'description': None, 'confidence': 0.6}, {'code': 'HP:0006094', 'term': 'Finger joint hypermobility', 'description': None, 'confidence': 0.6}, {'code': 'HP:0045087', 'term': 'Hip joint hypermobility', 'description': None, 'confidence': 0.6}, {'code': 'HP:0045086', 'term': 'Knee joint hypermobility', 'description': 'The ability of the knee to move past its normal range of motion, (knee hyperextension is greater than 10 degrees). [https://orcid.org/0000-0002-6387-4317, PMID:28599980]', 'confidence': 0.6}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Joint hypermobility': {\n",
      "  \"best_match_code\": \"HP:0001382\",\n",
      "  \"best_match_term\": \"Joint hypermobility\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 110\n",
      "✅ Extracted terms: ['Bone fragility']\n",
      "🌐 [Bone fragility] API Status: 200\n",
      "✅ Results for Bone fragility: [{'code': 'HP:0002659', 'term': 'Bone fragility', 'description': 'An abnormally increased tendency to fractures of bones caused by an abnormal reduction in bone strength that is generally associated with an increased risk of fracture. [https://orcid.org/0009-0006-4530-3154]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Bone fragility', 'candidates': [{'code': 'HP:0002659', 'term': 'Bone fragility', 'description': 'An abnormally increased tendency to fractures of bones caused by an abnormal reduction in bone strength that is generally associated with an increased risk of fracture. [https://orcid.org/0009-0006-4530-3154]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Bone fragility': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002659\",\n",
      "    \"matched_term\": \"Bone fragility\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Frequent broken bones (brittle bones)', 'field_type': 'radio', 'extracted_terms': ['Bone fragility'], 'umls_mappings': [{'original': 'Bone fragility', 'candidates': [{'code': 'HP:0002659', 'term': 'Bone fragility', 'description': 'An abnormally increased tendency to fractures of bones caused by an abnormal reduction in bone strength that is generally associated with an increased risk of fracture. [https://orcid.org/0009-0006-4530-3154]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Bone fragility', 'ranked_candidates': [{'code': 'HP:0002659', 'term': 'Bone fragility', 'description': 'An abnormally increased tendency to fractures of bones caused by an abnormal reduction in bone strength that is generally associated with an increased risk of fracture. [https://orcid.org/0009-0006-4530-3154]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Bone fragility': {\n",
      "  \"best_match_code\": \"HP:0002659\",\n",
      "  \"best_match_term\": \"Bone fragility\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 111\n",
      "✅ Extracted terms: ['Abnormal digit morphology']\n",
      "🌐 [Abnormal digit morphology] API Status: 200\n",
      "✅ Results for Abnormal digit morphology: [{'code': 'HP:0011297', 'term': 'Abnormal digit morphology', 'description': 'A morphological abnormality of a digit, i.e., of a finger or toe. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal digit morphology', 'candidates': [{'code': 'HP:0011297', 'term': 'Abnormal digit morphology', 'description': 'A morphological abnormality of a digit, i.e., of a finger or toe. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal digit morphology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011297\",\n",
      "    \"matched_term\": \"Abnormal digit morphology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Finger and/or toe differences (extra/missing/fused)', 'field_type': 'radio', 'extracted_terms': ['Abnormal digit morphology'], 'umls_mappings': [{'original': 'Abnormal digit morphology', 'candidates': [{'code': 'HP:0011297', 'term': 'Abnormal digit morphology', 'description': 'A morphological abnormality of a digit, i.e., of a finger or toe. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal digit morphology', 'ranked_candidates': [{'code': 'HP:0011297', 'term': 'Abnormal digit morphology', 'description': 'A morphological abnormality of a digit, i.e., of a finger or toe. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal digit morphology': {\n",
      "  \"best_match_code\": \"HP:0011297\",\n",
      "  \"best_match_term\": \"Abnormal digit morphology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 112\n",
      "✅ Extracted terms: ['Abnormality of the hand']\n",
      "🌐 [Abnormality of the hand] API Status: 200\n",
      "✅ Results for Abnormality of the hand: [{'code': 'HP:0001155', 'term': 'Abnormality of the hand', 'description': 'Alterations or deviations from normal shape or size which result in a disfigurement of the hand.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the hand', 'candidates': [{'code': 'HP:0001155', 'term': 'Abnormality of the hand', 'description': 'Alterations or deviations from normal shape or size which result in a disfigurement of the hand.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the hand': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001155\",\n",
      "    \"matched_term\": \"Abnormality of the hand\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hand differences (split hand, extra/missing bones)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the hand'], 'umls_mappings': [{'original': 'Abnormality of the hand', 'candidates': [{'code': 'HP:0001155', 'term': 'Abnormality of the hand', 'description': 'Alterations or deviations from normal shape or size which result in a disfigurement of the hand.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the hand', 'ranked_candidates': [{'code': 'HP:0001155', 'term': 'Abnormality of the hand', 'description': 'Alterations or deviations from normal shape or size which result in a disfigurement of the hand.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the hand': {\n",
      "  \"best_match_code\": \"HP:0001155\",\n",
      "  \"best_match_term\": \"Abnormality of the hand\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 113\n",
      "✅ Extracted terms: ['Abnormality of the foot']\n",
      "🌐 [Abnormality of the foot] API Status: 200\n",
      "✅ Results for Abnormality of the foot: [{'code': 'HP:0001760', 'term': 'Abnormality of the foot', 'description': 'An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001436', 'term': 'Abnormality of the foot musculature', 'description': 'An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the foot', 'candidates': [{'code': 'HP:0001760', 'term': 'Abnormality of the foot', 'description': 'An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001436', 'term': 'Abnormality of the foot musculature', 'description': 'An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the foot': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001760\",\n",
      "    \"matched_term\": \"Abnormality of the foot\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001436\",\n",
      "    \"matched_term\": \"Abnormality of the foot musculature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Foot differences (split foot, extra/missing bones)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the foot'], 'umls_mappings': [{'original': 'Abnormality of the foot', 'candidates': [{'code': 'HP:0001760', 'term': 'Abnormality of the foot', 'description': 'An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001436', 'term': 'Abnormality of the foot musculature', 'description': 'An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the foot', 'ranked_candidates': [{'code': 'HP:0001760', 'term': 'Abnormality of the foot', 'description': 'An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0001436', 'term': 'Abnormality of the foot musculature', 'description': 'An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the foot': {\n",
      "  \"best_match_code\": \"HP:0001760\",\n",
      "  \"best_match_term\": \"Abnormality of the foot\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Foot differences (split foot, extra/missing bones)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the foot\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the foot\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001760\",\n",
      "          \"term\": \"Abnormality of the foot\",\n",
      "          \"description\": \"An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001436\",\n",
      "          \"term\": \"Abnormality of the foot musculature\",\n",
      "          \"description\": \"An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the foot\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001760\",\n",
      "          \"term\": \"Abnormality of the foot\",\n",
      "          \"description\": \"An abnormality of the skeleton of foot. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001436\",\n",
      "          \"term\": \"Abnormality of the foot musculature\",\n",
      "          \"description\": \"An anomaly of the musculature of foot. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the foot\",\n",
      "      \"best_match_code\": \"HP:0001760\",\n",
      "      \"best_match_term\": \"Abnormality of the foot\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C5399834\n",
      "✅ Processed row 114\n",
      "✅ Extracted terms: ['Hip dysplasia']\n",
      "🌐 [Hip dysplasia] API Status: 200\n",
      "✅ Results for Hip dysplasia: [{'code': 'HP:0001385', 'term': 'Congenital hip dysplasia', 'description': 'Medfødt hofteleddsforskyvning inkluderer vanligvis subluksasjon av lårbeinshodet, dysplasi av hofteleddsskålen og fullstendig dislokasjon (utglidning) av lårbeinshodet fra hofteleddsskålen. Denne tilstanden forekommer hos ca. 1 av 1000 levende fødte og er mer vanlig hos jenter enn hos gutter.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hip dysplasia', 'candidates': [{'code': 'HP:0001385', 'term': 'Congenital hip dysplasia', 'description': 'Medfødt hofteleddsforskyvning inkluderer vanligvis subluksasjon av lårbeinshodet, dysplasi av hofteleddsskålen og fullstendig dislokasjon (utglidning) av lårbeinshodet fra hofteleddsskålen. Denne tilstanden forekommer hos ca. 1 av 1000 levende fødte og er mer vanlig hos jenter enn hos gutter.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hip dysplasia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001385\",\n",
      "    \"matched_term\": \"Congenital hip dysplasia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Hip dysplasia', 'field_type': 'radio', 'extracted_terms': ['Hip dysplasia'], 'umls_mappings': [{'original': 'Hip dysplasia', 'candidates': [{'code': 'HP:0001385', 'term': 'Congenital hip dysplasia', 'description': 'Medfødt hofteleddsforskyvning inkluderer vanligvis subluksasjon av lårbeinshodet, dysplasi av hofteleddsskålen og fullstendig dislokasjon (utglidning) av lårbeinshodet fra hofteleddsskålen. Denne tilstanden forekommer hos ca. 1 av 1000 levende fødte og er mer vanlig hos jenter enn hos gutter.'}]}], 'mappability_retry_count': 4, 'retries': 0, 'ranked_mappings': [{'original': 'Hip dysplasia', 'ranked_candidates': [{'code': 'HP:0001385', 'term': 'Congenital hip dysplasia', 'description': 'Medfødt hofteleddsforskyvning inkluderer vanligvis subluksasjon av lårbeinshodet, dysplasi av hofteleddsskålen og fullstendig dislokasjon (utglidning) av lårbeinshodet fra hofteleddsskålen. Denne tilstanden forekommer hos ca. 1 av 1000 levende fødte og er mer vanlig hos jenter enn hos gutter.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hip dysplasia': {\n",
      "  \"best_match_code\": \"HP:0001385\",\n",
      "  \"best_match_term\": \"Congenital hip dysplasia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 115\n",
      "✅ Extracted terms: ['Pectus carinatum']\n",
      "🌐 [Pectus carinatum] API Status: 200\n",
      "✅ Results for Pectus carinatum: [{'code': 'HP:0000768', 'term': 'Pectus carinatum', 'description': 'A developmental anomaly characterized by abnormal anterior protrusion of the STERNUM and adjacent COSTAL CARTILAGE.'}, {'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000917', 'term': 'Pectus carinatum superiorly', 'description': 'Pectus carinatum affecting primarily the superior part of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Pectus carinatum', 'candidates': [{'code': 'HP:0000768', 'term': 'Pectus carinatum', 'description': 'A developmental anomaly characterized by abnormal anterior protrusion of the STERNUM and adjacent COSTAL CARTILAGE.'}, {'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000917', 'term': 'Pectus carinatum superiorly', 'description': 'Pectus carinatum affecting primarily the superior part of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Pectus carinatum': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000768\",\n",
      "    \"matched_term\": \"Pectus carinatum\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000766\",\n",
      "    \"matched_term\": \"Pectus carinatum or pectus excavatum\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000917\",\n",
      "    \"matched_term\": \"Pectus carinatum superiorly\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': \"Pectus carinatum ('pigeon chest')\", 'field_type': 'radio', 'extracted_terms': ['Pectus carinatum'], 'umls_mappings': [{'original': 'Pectus carinatum', 'candidates': [{'code': 'HP:0000768', 'term': 'Pectus carinatum', 'description': 'A developmental anomaly characterized by abnormal anterior protrusion of the STERNUM and adjacent COSTAL CARTILAGE.'}, {'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000917', 'term': 'Pectus carinatum superiorly', 'description': 'Pectus carinatum affecting primarily the superior part of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Pectus carinatum', 'ranked_candidates': [{'code': 'HP:0000768', 'term': 'Pectus carinatum', 'description': 'A developmental anomaly characterized by abnormal anterior protrusion of the STERNUM and adjacent COSTAL CARTILAGE.', 'confidence': 1.0}, {'code': 'HP:0000917', 'term': 'Pectus carinatum superiorly', 'description': 'Pectus carinatum affecting primarily the superior part of the sternum. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}, {'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None, 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Pectus carinatum': {\n",
      "  \"best_match_code\": \"HP:0000768\",\n",
      "  \"best_match_term\": \"Pectus carinatum\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 116\n",
      "✅ Extracted terms: ['Pectus excavatum']\n",
      "🌐 [Pectus excavatum] API Status: 200\n",
      "✅ Results for Pectus excavatum: [{'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000767', 'term': 'Pectus excavatum', 'description': 'A defect of the chest wall characterized by a depression of the sternum, giving the chest (pectus\") a caved-in (\"excavatum\") appearance.\" [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000915', 'term': 'Pectus excavatum inferiorly', 'description': 'Pectus excavatum (defect of the chest wall characterized by depression of the sternum) affecting primarily the inferior region of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Pectus excavatum', 'candidates': [{'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000767', 'term': 'Pectus excavatum', 'description': 'A defect of the chest wall characterized by a depression of the sternum, giving the chest (pectus\") a caved-in (\"excavatum\") appearance.\" [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000915', 'term': 'Pectus excavatum inferiorly', 'description': 'Pectus excavatum (defect of the chest wall characterized by depression of the sternum) affecting primarily the inferior region of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Pectus excavatum': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000767\",\n",
      "    \"matched_term\": \"Pectus excavatum\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000766\",\n",
      "    \"matched_term\": \"Pectus carinatum or pectus excavatum\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000915\",\n",
      "    \"matched_term\": \"Pectus excavatum inferiorly\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': \"Pectus excavatum ('funnel chest')\", 'field_type': 'radio', 'extracted_terms': ['Pectus excavatum'], 'umls_mappings': [{'original': 'Pectus excavatum', 'candidates': [{'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None}, {'code': 'HP:0000767', 'term': 'Pectus excavatum', 'description': 'A defect of the chest wall characterized by a depression of the sternum, giving the chest (pectus\") a caved-in (\"excavatum\") appearance.\" [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000915', 'term': 'Pectus excavatum inferiorly', 'description': 'Pectus excavatum (defect of the chest wall characterized by depression of the sternum) affecting primarily the inferior region of the sternum. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Pectus excavatum', 'ranked_candidates': [{'code': 'HP:0000767', 'term': 'Pectus excavatum', 'description': 'A defect of the chest wall characterized by a depression of the sternum, giving the chest (pectus\") a caved-in (\"excavatum\") appearance.\" [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0000766', 'term': 'Pectus carinatum or pectus excavatum', 'description': None, 'confidence': 0.5}, {'code': 'HP:0000915', 'term': 'Pectus excavatum inferiorly', 'description': 'Pectus excavatum (defect of the chest wall characterized by depression of the sternum) affecting primarily the inferior region of the sternum. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Pectus excavatum': {\n",
      "  \"best_match_code\": \"HP:0000767\",\n",
      "  \"best_match_term\": \"Pectus excavatum\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 117\n",
      "✅ Extracted terms: ['Skeletal dysplasia']\n",
      "🌐 [Skeletal dysplasia] API Status: 200\n",
      "✅ Results for Skeletal dysplasia: [{'code': 'HP:0005716', 'term': 'Lethal skeletal dysplasia', 'description': None}, {'code': 'HP:0002652', 'term': 'Skeletal dysplasia', 'description': 'A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Skeletal dysplasia', 'candidates': [{'code': 'HP:0005716', 'term': 'Lethal skeletal dysplasia', 'description': None}, {'code': 'HP:0002652', 'term': 'Skeletal dysplasia', 'description': 'A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Skeletal dysplasia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002652\",\n",
      "    \"matched_term\": \"Skeletal dysplasia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005716\",\n",
      "    \"matched_term\": \"Lethal skeletal dysplasia\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Skeletal dysplasia (incl. some forms of dwarfism)', 'field_type': 'radio', 'extracted_terms': ['Skeletal dysplasia'], 'umls_mappings': [{'original': 'Skeletal dysplasia', 'candidates': [{'code': 'HP:0005716', 'term': 'Lethal skeletal dysplasia', 'description': None}, {'code': 'HP:0002652', 'term': 'Skeletal dysplasia', 'description': 'A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Skeletal dysplasia', 'ranked_candidates': [{'code': 'HP:0002652', 'term': 'Skeletal dysplasia', 'description': 'A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0005716', 'term': 'Lethal skeletal dysplasia', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Skeletal dysplasia': {\n",
      "  \"best_match_code\": \"HP:0002652\",\n",
      "  \"best_match_term\": \"Skeletal dysplasia\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Skeletal dysplasia (incl. some forms of dwarfism)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Skeletal dysplasia\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Skeletal dysplasia\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005716\",\n",
      "          \"term\": \"Lethal skeletal dysplasia\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0002652\",\n",
      "          \"term\": \"Skeletal dysplasia\",\n",
      "          \"description\": \"A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Skeletal dysplasia\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002652\",\n",
      "          \"term\": \"Skeletal dysplasia\",\n",
      "          \"description\": \"A general term describing features characterized by abnormal development of bones and connective tissues. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005716\",\n",
      "          \"term\": \"Lethal skeletal dysplasia\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Skeletal dysplasia\",\n",
      "      \"best_match_code\": \"HP:0002652\",\n",
      "      \"best_match_term\": \"Skeletal dysplasia\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4280567\n",
      "✅ Processed row 118\n",
      "✅ Extracted terms: ['Facial muscle issue']\n",
      "🌐 [Facial muscle issue] API Status: 200\n",
      "✅ Results for Facial muscle issue: [{'code': 'HP:0000301', 'term': 'Facial muscle issue', 'description': 'An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Facial muscle issue', 'candidates': [{'code': 'HP:0000301', 'term': 'Facial muscle issue', 'description': 'An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Facial muscle issue': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000301\",\n",
      "    \"matched_term\": \"Facial muscle issue\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Facial muscle issue (palsy, chewing, eye movement)', 'field_type': 'radio', 'extracted_terms': ['Facial muscle issue'], 'umls_mappings': [{'original': 'Facial muscle issue', 'candidates': [{'code': 'HP:0000301', 'term': 'Facial muscle issue', 'description': 'An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Facial muscle issue', 'ranked_candidates': [{'code': 'HP:0000301', 'term': 'Facial muscle issue', 'description': 'An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Facial muscle issue': {\n",
      "  \"best_match_code\": \"HP:0000301\",\n",
      "  \"best_match_term\": \"Facial muscle issue\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Facial muscle issue (palsy, chewing, eye movement)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Facial muscle issue\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Facial muscle issue\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000301\",\n",
      "          \"term\": \"Facial muscle issue\",\n",
      "          \"description\": \"An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Facial muscle issue\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000301\",\n",
      "          \"term\": \"Facial muscle issue\",\n",
      "          \"description\": \"An anomaly of a muscle that is innervated by the facial nerve (the seventh cranial nerve). [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Facial muscle issue\",\n",
      "      \"best_match_code\": \"HP:0000301\",\n",
      "      \"best_match_term\": \"Facial muscle issue\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4025865\n",
      "✅ Processed row 119\n",
      "✅ Extracted terms: ['Abnormality of muscle physiology']\n",
      "🌐 [Abnormality of muscle physiology] API Status: 200\n",
      "✅ Results for Abnormality of muscle physiology: [{'code': 'HP:0011804', 'term': 'Abnormality of muscle physiology', 'description': 'A functional abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of muscle physiology', 'candidates': [{'code': 'HP:0011804', 'term': 'Abnormality of muscle physiology', 'description': 'A functional abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of muscle physiology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011804\",\n",
      "    \"matched_term\": \"Abnormality of muscle physiology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Issue with muscle function', 'field_type': 'radio', 'extracted_terms': ['Abnormality of muscle physiology'], 'umls_mappings': [{'original': 'Abnormality of muscle physiology', 'candidates': [{'code': 'HP:0011804', 'term': 'Abnormality of muscle physiology', 'description': 'A functional abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of muscle physiology', 'ranked_candidates': [{'code': 'HP:0011804', 'term': 'Abnormality of muscle physiology', 'description': 'A functional abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of muscle physiology': {\n",
      "  \"best_match_code\": \"HP:0011804\",\n",
      "  \"best_match_term\": \"Abnormality of muscle physiology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 120\n",
      "✅ Extracted terms: ['Abnormal muscle morphology']\n",
      "🌐 [Abnormal muscle morphology] API Status: 200\n",
      "✅ Results for Abnormal muscle morphology: [{'code': 'HP:0011805', 'term': 'Abnormal muscle morphology', 'description': 'A structural abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal muscle morphology', 'candidates': [{'code': 'HP:0011805', 'term': 'Abnormal muscle morphology', 'description': 'A structural abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal muscle morphology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011805\",\n",
      "    \"matched_term\": \"Abnormal muscle morphology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Issue with internal muscle structure (biopsy)', 'field_type': 'radio', 'extracted_terms': ['Abnormal muscle morphology'], 'umls_mappings': [{'original': 'Abnormal muscle morphology', 'candidates': [{'code': 'HP:0011805', 'term': 'Abnormal muscle morphology', 'description': 'A structural abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal muscle morphology', 'ranked_candidates': [{'code': 'HP:0011805', 'term': 'Abnormal muscle morphology', 'description': 'A structural abnormality of a skeletal muscle. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal muscle morphology': {\n",
      "  \"best_match_code\": \"HP:0011805\",\n",
      "  \"best_match_term\": \"Abnormal muscle morphology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 121\n",
      "✅ Extracted terms: ['Motor neuropathy']\n",
      "🌐 [Motor neuropathy] API Status: 200\n",
      "✅ Results for Motor neuropathy: [{'code': 'HP:0007220', 'term': 'Demyelinating motor neuropathy', 'description': 'Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007002', 'term': 'Distal motor neuropathy', 'description': None}, {'code': 'HP:0012246', 'term': 'Oculomotor neuropathy', 'description': 'Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Motor neuropathy', 'candidates': [{'code': 'HP:0007220', 'term': 'Demyelinating motor neuropathy', 'description': 'Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007002', 'term': 'Distal motor neuropathy', 'description': None}, {'code': 'HP:0012246', 'term': 'Oculomotor neuropathy', 'description': 'Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Motor neuropathy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007220\",\n",
      "    \"matched_term\": \"Demyelinating motor neuropathy\",\n",
      "    \"confidence\": \"85%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0007002\",\n",
      "    \"matched_term\": \"Distal motor neuropathy\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012246\",\n",
      "    \"matched_term\": \"Oculomotor neuropathy\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Issue with nerves connected to muscles (EMG/NCS)', 'field_type': 'radio', 'extracted_terms': ['Motor neuropathy'], 'umls_mappings': [{'original': 'Motor neuropathy', 'candidates': [{'code': 'HP:0007220', 'term': 'Demyelinating motor neuropathy', 'description': 'Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0007002', 'term': 'Distal motor neuropathy', 'description': None}, {'code': 'HP:0012246', 'term': 'Oculomotor neuropathy', 'description': 'Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Motor neuropathy', 'ranked_candidates': [{'code': 'HP:0007220', 'term': 'Demyelinating motor neuropathy', 'description': 'Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.85}, {'code': 'HP:0007002', 'term': 'Distal motor neuropathy', 'description': None, 'confidence': 0.8}, {'code': 'HP:0012246', 'term': 'Oculomotor neuropathy', 'description': 'Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Motor neuropathy': {\n",
      "  \"best_match_code\": \"HP:0007220\",\n",
      "  \"best_match_term\": \"Demyelinating motor neuropathy\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Issue with nerves connected to muscles (EMG/NCS)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Motor neuropathy\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Motor neuropathy\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0007220\",\n",
      "          \"term\": \"Demyelinating motor neuropathy\",\n",
      "          \"description\": \"Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007002\",\n",
      "          \"term\": \"Distal motor neuropathy\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012246\",\n",
      "          \"term\": \"Oculomotor neuropathy\",\n",
      "          \"description\": \"Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Motor neuropathy\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0007220\",\n",
      "          \"term\": \"Demyelinating motor neuropathy\",\n",
      "          \"description\": \"Demyelination of peripheral motor nerves. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.85\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0007002\",\n",
      "          \"term\": \"Distal motor neuropathy\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012246\",\n",
      "          \"term\": \"Oculomotor neuropathy\",\n",
      "          \"description\": \"Diseases of the oculomotor nerve or nucleus that result in weakness or paralysis of the superior rectus, inferior rectus, medial rectus, inferior oblique, or levator palpebrae muscles, or impaired parasympathetic innervation to the pupil. With a complete oculomotor palsy, the eyelid will be paralyzed, the eye will be in an abducted and inferior position, and the pupil will be markedly dilated. Commonly associated conditions include neoplasms, CRANIOCEREBRAL TRAUMA, ischemia (especially in association with DIABETES MELLITUS), and aneurysmal compression. (From Adams et al., Principles of Neurology, 6th ed, p270)\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Motor neuropathy\",\n",
      "      \"best_match_code\": \"HP:0007220\",\n",
      "      \"best_match_term\": \"Demyelinating motor neuropathy\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1969462\n",
      "✅ Processed row 122\n",
      "✅ Extracted terms: ['Abnormality of the musculature of the limbs']\n",
      "🌐 [Abnormality of the musculature of the limbs] API Status: 200\n",
      "✅ Results for Abnormality of the musculature of the limbs: [{'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the musculature of the limbs', 'candidates': [{'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the musculature of the limbs': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009127\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the limbs\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Muscle issues in the arms and/or legs (weakness/underdevelopment)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the musculature of the limbs'], 'umls_mappings': [{'original': 'Abnormality of the musculature of the limbs', 'candidates': [{'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the musculature of the limbs', 'ranked_candidates': [{'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the musculature of the limbs': {\n",
      "  \"best_match_code\": \"HP:0009127\",\n",
      "  \"best_match_term\": \"Abnormality of the musculature of the limbs\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 123\n",
      "✅ Extracted terms: ['Abnormality of the musculature']\n",
      "🌐 [Abnormality of the musculature] API Status: 200\n",
      "✅ Results for Abnormality of the musculature: [{'code': 'HP:0003011', 'term': 'Abnormality of the musculature', 'description': 'Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001421', 'term': 'Abnormality of the musculature of the hand', 'description': None}, {'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}, {'code': 'HP:0001437', 'term': 'Abnormality of the musculature of the lower limbs', 'description': None}, {'code': 'HP:0011006', 'term': 'Abnormality of the musculature of the neck', 'description': 'An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001469', 'term': 'Abnormality of the musculature of the pelvis', 'description': None}, {'code': 'HP:0001441', 'term': 'Abnormality of the musculature of the thigh', 'description': None}, {'code': 'HP:0009131', 'term': 'Abnormality of the musculature of the thorax', 'description': 'A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001457', 'term': 'Abnormality of the musculature of the upper arm', 'description': None}, {'code': 'HP:0001446', 'term': 'Abnormality of the musculature of the upper limbs', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the musculature', 'candidates': [{'code': 'HP:0003011', 'term': 'Abnormality of the musculature', 'description': 'Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001421', 'term': 'Abnormality of the musculature of the hand', 'description': None}, {'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}, {'code': 'HP:0001437', 'term': 'Abnormality of the musculature of the lower limbs', 'description': None}, {'code': 'HP:0011006', 'term': 'Abnormality of the musculature of the neck', 'description': 'An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001469', 'term': 'Abnormality of the musculature of the pelvis', 'description': None}, {'code': 'HP:0001441', 'term': 'Abnormality of the musculature of the thigh', 'description': None}, {'code': 'HP:0009131', 'term': 'Abnormality of the musculature of the thorax', 'description': 'A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001457', 'term': 'Abnormality of the musculature of the upper arm', 'description': None}, {'code': 'HP:0001446', 'term': 'Abnormality of the musculature of the upper limbs', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the musculature': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003011\",\n",
      "    \"matched_term\": \"Abnormality of the musculature\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001421\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the hand\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009127\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the limbs\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001437\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the lower limbs\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011006\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the neck\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001469\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the pelvis\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001441\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the thigh\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009131\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the thorax\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001457\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the upper arm\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001446\",\n",
      "    \"matched_term\": \"Abnormality of the musculature of the upper limbs\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Muscle issues in the chest, back, and/or shoulders', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the musculature'], 'umls_mappings': [{'original': 'Abnormality of the musculature', 'candidates': [{'code': 'HP:0003011', 'term': 'Abnormality of the musculature', 'description': 'Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001421', 'term': 'Abnormality of the musculature of the hand', 'description': None}, {'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None}, {'code': 'HP:0001437', 'term': 'Abnormality of the musculature of the lower limbs', 'description': None}, {'code': 'HP:0011006', 'term': 'Abnormality of the musculature of the neck', 'description': 'An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001469', 'term': 'Abnormality of the musculature of the pelvis', 'description': None}, {'code': 'HP:0001441', 'term': 'Abnormality of the musculature of the thigh', 'description': None}, {'code': 'HP:0009131', 'term': 'Abnormality of the musculature of the thorax', 'description': 'A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001457', 'term': 'Abnormality of the musculature of the upper arm', 'description': None}, {'code': 'HP:0001446', 'term': 'Abnormality of the musculature of the upper limbs', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the musculature', 'ranked_candidates': [{'code': 'HP:0003011', 'term': 'Abnormality of the musculature', 'description': 'Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0001421', 'term': 'Abnormality of the musculature of the hand', 'description': None, 'confidence': 0.7}, {'code': 'HP:0009127', 'term': 'Abnormality of the musculature of the limbs', 'description': None, 'confidence': 0.7}, {'code': 'HP:0001437', 'term': 'Abnormality of the musculature of the lower limbs', 'description': None, 'confidence': 0.7}, {'code': 'HP:0011006', 'term': 'Abnormality of the musculature of the neck', 'description': 'An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0001469', 'term': 'Abnormality of the musculature of the pelvis', 'description': None, 'confidence': 0.7}, {'code': 'HP:0001441', 'term': 'Abnormality of the musculature of the thigh', 'description': None, 'confidence': 0.7}, {'code': 'HP:0009131', 'term': 'Abnormality of the musculature of the thorax', 'description': 'A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0001457', 'term': 'Abnormality of the musculature of the upper arm', 'description': None, 'confidence': 0.7}, {'code': 'HP:0001446', 'term': 'Abnormality of the musculature of the upper limbs', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the musculature': {\n",
      "  \"best_match_code\": \"HP:0003011\",\n",
      "  \"best_match_term\": \"Abnormality of the musculature\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Muscle issues in the chest, back, and/or shoulders\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the musculature\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the musculature\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0003011\",\n",
      "          \"term\": \"Abnormality of the musculature\",\n",
      "          \"description\": \"Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001421\",\n",
      "          \"term\": \"Abnormality of the musculature of the hand\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009127\",\n",
      "          \"term\": \"Abnormality of the musculature of the limbs\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001437\",\n",
      "          \"term\": \"Abnormality of the musculature of the lower limbs\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011006\",\n",
      "          \"term\": \"Abnormality of the musculature of the neck\",\n",
      "          \"description\": \"An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001469\",\n",
      "          \"term\": \"Abnormality of the musculature of the pelvis\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001441\",\n",
      "          \"term\": \"Abnormality of the musculature of the thigh\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009131\",\n",
      "          \"term\": \"Abnormality of the musculature of the thorax\",\n",
      "          \"description\": \"A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001457\",\n",
      "          \"term\": \"Abnormality of the musculature of the upper arm\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001446\",\n",
      "          \"term\": \"Abnormality of the musculature of the upper limbs\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the musculature\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0003011\",\n",
      "          \"term\": \"Abnormality of the musculature\",\n",
      "          \"description\": \"Abnormality originating in one or more muscles, i.e., of the set of muscles of body. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001421\",\n",
      "          \"term\": \"Abnormality of the musculature of the hand\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009127\",\n",
      "          \"term\": \"Abnormality of the musculature of the limbs\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001437\",\n",
      "          \"term\": \"Abnormality of the musculature of the lower limbs\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011006\",\n",
      "          \"term\": \"Abnormality of the musculature of the neck\",\n",
      "          \"description\": \"An abnormality of the neck musculature. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001469\",\n",
      "          \"term\": \"Abnormality of the musculature of the pelvis\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001441\",\n",
      "          \"term\": \"Abnormality of the musculature of the thigh\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009131\",\n",
      "          \"term\": \"Abnormality of the musculature of the thorax\",\n",
      "          \"description\": \"A disease or lesion affecting the muscles of the thorax. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001457\",\n",
      "          \"term\": \"Abnormality of the musculature of the upper arm\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001446\",\n",
      "          \"term\": \"Abnormality of the musculature of the upper limbs\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the musculature\",\n",
      "      \"best_match_code\": \"HP:0003011\",\n",
      "      \"best_match_term\": \"Abnormality of the musculature\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4021745\n",
      "✅ Processed row 124\n",
      "✅ Extracted terms: ['Abnormality of the neck musculature']\n",
      "🌐 [Abnormality of the neck musculature] API Status: 404\n",
      "❌ Failed for term: Abnormality of the neck musculature\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the neck musculature', 'candidates': []}]\n",
      "✅ Revised terms: ['Torticollis']\n",
      "🌐 [Torticollis] API Status: 200\n",
      "✅ Results for Torticollis: [{'code': 'HP:0005988', 'term': 'Congenital muscular torticollis', 'description': 'A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000473', 'term': 'Spasmodic torticollis', 'description': 'A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Torticollis', 'candidates': [{'code': 'HP:0005988', 'term': 'Congenital muscular torticollis', 'description': 'A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000473', 'term': 'Spasmodic torticollis', 'description': 'A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Torticollis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005988\",\n",
      "    \"matched_term\": \"Congenital muscular torticollis\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000473\",\n",
      "    \"matched_term\": \"Spasmodic torticollis\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Neck muscle issue (torticollis or neck weakness)', 'field_type': 'radio', 'extracted_terms': ['Torticollis'], 'umls_mappings': [{'original': 'Torticollis', 'candidates': [{'code': 'HP:0005988', 'term': 'Congenital muscular torticollis', 'description': 'A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000473', 'term': 'Spasmodic torticollis', 'description': 'A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the neck musculature', 'Torticollis'], 'retries': 0, 'ranked_mappings': [{'original': 'Torticollis', 'ranked_candidates': [{'code': 'HP:0005988', 'term': 'Congenital muscular torticollis', 'description': 'A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}, {'code': 'HP:0000473', 'term': 'Spasmodic torticollis', 'description': 'A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Torticollis': {\n",
      "  \"best_match_code\": \"HP:0005988\",\n",
      "  \"best_match_term\": \"Congenital muscular torticollis\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Neck muscle issue (torticollis or neck weakness)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Torticollis\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Torticollis\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005988\",\n",
      "          \"term\": \"Congenital muscular torticollis\",\n",
      "          \"description\": \"A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000473\",\n",
      "          \"term\": \"Spasmodic torticollis\",\n",
      "          \"description\": \"A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retry_count\": 1,\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"history_rewritten_terms\": [\n",
      "    \"Abnormality of the neck musculature\",\n",
      "    \"Torticollis\"\n",
      "  ],\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Torticollis\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005988\",\n",
      "          \"term\": \"Congenital muscular torticollis\",\n",
      "          \"description\": \"A congenital form of torticollis resulting from shortening of the sternocleidomastoid muscle and leading to a limited range of motion in both rotation and lateral bending. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.5\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0000473\",\n",
      "          \"term\": \"Spasmodic torticollis\",\n",
      "          \"description\": \"A rare movement disorder of unknown etiology, characterized by painful, involuntary turns of the head to the right, left, upwards, or downwards.\",\n",
      "          \"confidence\": 0.5\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Torticollis\",\n",
      "      \"best_match_code\": \"HP:0005988\",\n",
      "      \"best_match_term\": \"Congenital muscular torticollis\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0079352\n",
      "🧩 ancestor_cuis ['C0012634', 'C0000768', 'C1285159', 'C0008073', 'C0151491', 'C0558385', 'C0265517', 'C1533847', 'C0345380', 'C0427194', 'C0424722', 'C0026857', 'C1290143', 'C0426779', 'C0242354', 'C0575155', 'C0266623', 'C0263978', 'C0265521', 'C2720507', 'C0037088', 'C1533165', 'C0026848']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0000768', 'name': 'Congenital abnormality'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0008073', 'name': 'Developmental disorder'}, {'cui': 'C0151491', 'name': 'Congenital musculoskeletal anomalies NOS'}, {'cui': 'C0558385', 'name': 'Disorder of neck'}, {'cui': 'C0265517', 'name': 'Congenital anomaly of skeletal muscle'}, {'cui': 'C1533847', 'name': 'Disorder of skeletal muscle'}, {'cui': 'C0345380', 'name': 'Congenital anomaly of sternocleidomastoid muscle'}, {'cui': 'C0427194', 'name': 'Muscle finding'}, {'cui': 'C0424722', 'name': 'General finding of soft tissue'}, {'cui': 'C0026857', 'name': 'Musculoskeletal disease'}, {'cui': 'C1290143', 'name': 'Musculoskeletal disorder of the neck'}, {'cui': 'C0426779', 'name': 'Musculoskeletal system finding'}, {'cui': 'C0242354', 'name': 'Congenital disorder'}, {'cui': 'C0575155', 'name': 'Finding of neck region'}, {'cui': 'C0266623', 'name': 'Congenital anomaly of neck'}, {'cui': 'C0263978', 'name': 'Disorder of soft tissue'}, {'cui': 'C0265521', 'name': 'Congenital anomaly of muscle AND/OR tendon'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C1533165', 'name': 'Disorder of fetus or newborn'}, {'cui': 'C0026848', 'name': 'Myopathy'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Neck muscle issue (torticollis or neck weakness)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Torticollis\"\n",
      "  \"best_match_code\": \"HP:0005988\",\n",
      "  \"best_match_term\": \"Congenital muscular torticollis\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0000768 (Congenital abnormality)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0008073 (Developmental disorder)\n",
      "- C0151491 (Congenital musculoskeletal anomalies NOS)\n",
      "- C0558385 (Disorder of neck)\n",
      "- C0265517 (Congenital anomaly of skeletal muscle)\n",
      "- C1533847 (Disorder of skeletal muscle)\n",
      "- C0345380 (Congenital anomaly of sternocleidomastoid muscle)\n",
      "- C0427194 (Muscle finding)\n",
      "- C0424722 (General finding of soft tissue)\n",
      "- C0026857 (Musculoskeletal disease)\n",
      "- C1290143 (Musculoskeletal disorder of the neck)\n",
      "- C0426779 (Musculoskeletal system finding)\n",
      "- C0242354 (Congenital disorder)\n",
      "- C0575155 (Finding of neck region)\n",
      "- C0266623 (Congenital anomaly of neck)\n",
      "- C0263978 (Disorder of soft tissue)\n",
      "- C0265521 (Congenital anomaly of muscle AND/OR tendon)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C1533165 (Disorder of fetus or newborn)\n",
      "- C0026848 (Myopathy)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0000464\",\\n  \"refined_term\": \"Torticollis\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 34, 'prompt_tokens': 798, 'total_tokens': 832, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCePf4HK7XqbxlHflqQpyku9FuWzb', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--f986df2f-3720-4960-8662-971127321902-0' usage_metadata={'input_tokens': 798, 'output_tokens': 34, 'total_tokens': 832, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Torticollis\n",
      "🧠 LLM refined_code: HP:0000464\n",
      "✅ Processed row 125\n",
      "✅ Extracted terms: ['Aneurysm']\n",
      "🌐 [Aneurysm] API Status: 200\n",
      "✅ Results for Aneurysm: [{'code': 'HP:0005112', 'term': 'Abdominal aortic aneurysm', 'description': 'An abnormal balloon- or sac-like dilatation in the wall of the ABDOMINAL AORTA which gives rise to the visceral, the parietal, and the terminal (iliac) branches below the aortic hiatus at the diaphragm.'}, {'code': 'HP:0002617', 'term': 'Aneurysm', 'description': 'Pathological outpouching or sac-like dilatation in the wall of any blood vessel (ARTERIES or VEINS) or the heart (HEART ANEURYSM). It indicates a thin and weakened area in the wall which may later rupture. Aneurysms are classified by location, etiology, or other characteristics.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Aneurysm', 'candidates': [{'code': 'HP:0005112', 'term': 'Abdominal aortic aneurysm', 'description': 'An abnormal balloon- or sac-like dilatation in the wall of the ABDOMINAL AORTA which gives rise to the visceral, the parietal, and the terminal (iliac) branches below the aortic hiatus at the diaphragm.'}, {'code': 'HP:0002617', 'term': 'Aneurysm', 'description': 'Pathological outpouching or sac-like dilatation in the wall of any blood vessel (ARTERIES or VEINS) or the heart (HEART ANEURYSM). It indicates a thin and weakened area in the wall which may later rupture. Aneurysms are classified by location, etiology, or other characteristics.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Aneurysm': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002617\",\n",
      "    \"matched_term\": \"Aneurysm\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005112\",\n",
      "    \"matched_term\": \"Abdominal aortic aneurysm\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Aneurysm', 'field_type': 'radio', 'extracted_terms': ['Aneurysm'], 'umls_mappings': [{'original': 'Aneurysm', 'candidates': [{'code': 'HP:0005112', 'term': 'Abdominal aortic aneurysm', 'description': 'An abnormal balloon- or sac-like dilatation in the wall of the ABDOMINAL AORTA which gives rise to the visceral, the parietal, and the terminal (iliac) branches below the aortic hiatus at the diaphragm.'}, {'code': 'HP:0002617', 'term': 'Aneurysm', 'description': 'Pathological outpouching or sac-like dilatation in the wall of any blood vessel (ARTERIES or VEINS) or the heart (HEART ANEURYSM). It indicates a thin and weakened area in the wall which may later rupture. Aneurysms are classified by location, etiology, or other characteristics.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Aneurysm', 'ranked_candidates': [{'code': 'HP:0002617', 'term': 'Aneurysm', 'description': 'Pathological outpouching or sac-like dilatation in the wall of any blood vessel (ARTERIES or VEINS) or the heart (HEART ANEURYSM). It indicates a thin and weakened area in the wall which may later rupture. Aneurysms are classified by location, etiology, or other characteristics.', 'confidence': 1.0}, {'code': 'HP:0005112', 'term': 'Abdominal aortic aneurysm', 'description': 'An abnormal balloon- or sac-like dilatation in the wall of the ABDOMINAL AORTA which gives rise to the visceral, the parietal, and the terminal (iliac) branches below the aortic hiatus at the diaphragm.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Aneurysm': {\n",
      "  \"best_match_code\": \"HP:0002617\",\n",
      "  \"best_match_term\": \"Aneurysm\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 126\n",
      "✅ Extracted terms: ['Arrhythmia']\n",
      "🌐 [Arrhythmia] API Status: 200\n",
      "✅ Results for Arrhythmia: [{'code': 'HP:0011675', 'term': 'Arrhythmia', 'description': 'any variation from the normal rhythm or rate of the heart beat.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Arrhythmia', 'candidates': [{'code': 'HP:0011675', 'term': 'Arrhythmia', 'description': 'any variation from the normal rhythm or rate of the heart beat.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Arrhythmia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011675\",\n",
      "    \"matched_term\": \"Arrhythmia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Arrhythmia (irregular/fast/slow heart rhythm)', 'field_type': 'radio', 'extracted_terms': ['Arrhythmia'], 'umls_mappings': [{'original': 'Arrhythmia', 'candidates': [{'code': 'HP:0011675', 'term': 'Arrhythmia', 'description': 'any variation from the normal rhythm or rate of the heart beat.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Arrhythmia', 'ranked_candidates': [{'code': 'HP:0011675', 'term': 'Arrhythmia', 'description': 'any variation from the normal rhythm or rate of the heart beat.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Arrhythmia': {\n",
      "  \"best_match_code\": \"HP:0011675\",\n",
      "  \"best_match_term\": \"Arrhythmia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 127\n",
      "✅ Extracted terms: ['Abnormal electrocardiogram']\n",
      "🌐 [Abnormal electrocardiogram] API Status: 200\n",
      "✅ Results for Abnormal electrocardiogram: [{'code': 'HP:0003115', 'term': 'Abnormal electrocardiogram', 'description': 'Abnormal rhythm of the heart. []'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal electrocardiogram', 'candidates': [{'code': 'HP:0003115', 'term': 'Abnormal electrocardiogram', 'description': 'Abnormal rhythm of the heart. []'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal electrocardiogram': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003115\",\n",
      "    \"matched_term\": \"Abnormal electrocardiogram\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Abnormal EKG (ECG)', 'field_type': 'radio', 'extracted_terms': ['Abnormal electrocardiogram'], 'umls_mappings': [{'original': 'Abnormal electrocardiogram', 'candidates': [{'code': 'HP:0003115', 'term': 'Abnormal electrocardiogram', 'description': 'Abnormal rhythm of the heart. []'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal electrocardiogram', 'ranked_candidates': [{'code': 'HP:0003115', 'term': 'Abnormal electrocardiogram', 'description': 'Abnormal rhythm of the heart. []', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal electrocardiogram': {\"best_match_code\": \"HP:0003115\", \"best_match_term\": \"Abnormal electrocardiogram\", \"confidence\": \"100%\"}\n",
      "✅ Processed row 128\n",
      "✅ Extracted terms: ['Arterial dissection']\n",
      "🌐 [Arterial dissection] API Status: 200\n",
      "✅ Results for Arterial dissection: [{'code': 'HP:0005294', 'term': 'Arterial dissection', 'description': 'A tear within the wall of the artery.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Arterial dissection', 'candidates': [{'code': 'HP:0005294', 'term': 'Arterial dissection', 'description': 'A tear within the wall of the artery.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Arterial dissection': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005294\",\n",
      "    \"matched_term\": \"Arterial dissection\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Arterial dissection', 'field_type': 'radio', 'extracted_terms': ['Arterial dissection'], 'umls_mappings': [{'original': 'Arterial dissection', 'candidates': [{'code': 'HP:0005294', 'term': 'Arterial dissection', 'description': 'A tear within the wall of the artery.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Arterial dissection', 'ranked_candidates': [{'code': 'HP:0005294', 'term': 'Arterial dissection', 'description': 'A tear within the wall of the artery.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Arterial dissection': {\n",
      "  \"best_match_code\": \"HP:0005294\",\n",
      "  \"best_match_term\": \"Arterial dissection\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 129\n",
      "✅ Extracted terms: ['Cardiomyopathy']\n",
      "🌐 [Cardiomyopathy] API Status: 200\n",
      "✅ Results for Cardiomyopathy: [{'code': 'HP:0030843', 'term': 'Amyloid cardiomyopathy', 'description': 'Extracellular deposition in cardiac tissue of a proteinaceous material that, when stained with Congo red, demonstrates apple-green birefringence under polarized light and that has a distinct color when stained with sulfated Alcian blue. Viewed with electron microscopy, the amyloid deposits are seen to be composed of a beta-sheet fibrillar material. These nonbranching fibrils have a diameter of 7.5 to 10 nm and are the result of protein misfolding. [https://orcid.org/0000-0002-0736-9199, PMID:16186440]'}, {'code': 'HP:0031992', 'term': 'Apical hypertrophic cardiomyopathy', 'description': 'Apical hypertrophic cardiomyopathy (AHCM) is diastolic dysfunction due to abnormal stiffness of the left ventricle during diastole, with resultant impaired ventricular filling. In AHCM thickened apical segments produce a crowded, spade-shaped, small apical cavity. [https://orcid.org/0000-0001-5835-5515, PMID:23109785, PMID:8685759]'}, {'code': 'HP:0200127', 'term': 'Atrial cardiomyopathy', 'description': 'Any complex of structural, architectural, contractile or electrophysiological changes affecting the atria with the potential to produce clinically relevant manifestations. [PMID:27402624]'}, {'code': 'HP:0012818', 'term': 'Biventricular noncompaction cardiomyopathy', 'description': 'Noncompaction cardiomyopathy that affects both ventricles. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001638', 'term': 'Cardiomyopathy', 'description': 'condition in which there is a deviation from or interruption of the normal structure or function of the myocardium, the middle and thickest layer of the heart wall, composed of heart muscle.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Cardiomyopathy', 'candidates': [{'code': 'HP:0030843', 'term': 'Amyloid cardiomyopathy', 'description': 'Extracellular deposition in cardiac tissue of a proteinaceous material that, when stained with Congo red, demonstrates apple-green birefringence under polarized light and that has a distinct color when stained with sulfated Alcian blue. Viewed with electron microscopy, the amyloid deposits are seen to be composed of a beta-sheet fibrillar material. These nonbranching fibrils have a diameter of 7.5 to 10 nm and are the result of protein misfolding. [https://orcid.org/0000-0002-0736-9199, PMID:16186440]'}, {'code': 'HP:0031992', 'term': 'Apical hypertrophic cardiomyopathy', 'description': 'Apical hypertrophic cardiomyopathy (AHCM) is diastolic dysfunction due to abnormal stiffness of the left ventricle during diastole, with resultant impaired ventricular filling. In AHCM thickened apical segments produce a crowded, spade-shaped, small apical cavity. [https://orcid.org/0000-0001-5835-5515, PMID:23109785, PMID:8685759]'}, {'code': 'HP:0200127', 'term': 'Atrial cardiomyopathy', 'description': 'Any complex of structural, architectural, contractile or electrophysiological changes affecting the atria with the potential to produce clinically relevant manifestations. [PMID:27402624]'}, {'code': 'HP:0012818', 'term': 'Biventricular noncompaction cardiomyopathy', 'description': 'Noncompaction cardiomyopathy that affects both ventricles. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001638', 'term': 'Cardiomyopathy', 'description': 'condition in which there is a deviation from or interruption of the normal structure or function of the myocardium, the middle and thickest layer of the heart wall, composed of heart muscle.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Cardiomyopathy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001638\",\n",
      "    \"matched_term\": \"Cardiomyopathy\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0030843\",\n",
      "    \"matched_term\": \"Amyloid cardiomyopathy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0031992\",\n",
      "    \"matched_term\": \"Apical hypertrophic cardiomyopathy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0200127\",\n",
      "    \"matched_term\": \"Atrial cardiomyopathy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012818\",\n",
      "    \"matched_term\": \"Biventricular noncompaction cardiomyopathy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Cardiomyopathy', 'field_type': 'radio', 'extracted_terms': ['Cardiomyopathy'], 'umls_mappings': [{'original': 'Cardiomyopathy', 'candidates': [{'code': 'HP:0030843', 'term': 'Amyloid cardiomyopathy', 'description': 'Extracellular deposition in cardiac tissue of a proteinaceous material that, when stained with Congo red, demonstrates apple-green birefringence under polarized light and that has a distinct color when stained with sulfated Alcian blue. Viewed with electron microscopy, the amyloid deposits are seen to be composed of a beta-sheet fibrillar material. These nonbranching fibrils have a diameter of 7.5 to 10 nm and are the result of protein misfolding. [https://orcid.org/0000-0002-0736-9199, PMID:16186440]'}, {'code': 'HP:0031992', 'term': 'Apical hypertrophic cardiomyopathy', 'description': 'Apical hypertrophic cardiomyopathy (AHCM) is diastolic dysfunction due to abnormal stiffness of the left ventricle during diastole, with resultant impaired ventricular filling. In AHCM thickened apical segments produce a crowded, spade-shaped, small apical cavity. [https://orcid.org/0000-0001-5835-5515, PMID:23109785, PMID:8685759]'}, {'code': 'HP:0200127', 'term': 'Atrial cardiomyopathy', 'description': 'Any complex of structural, architectural, contractile or electrophysiological changes affecting the atria with the potential to produce clinically relevant manifestations. [PMID:27402624]'}, {'code': 'HP:0012818', 'term': 'Biventricular noncompaction cardiomyopathy', 'description': 'Noncompaction cardiomyopathy that affects both ventricles. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0001638', 'term': 'Cardiomyopathy', 'description': 'condition in which there is a deviation from or interruption of the normal structure or function of the myocardium, the middle and thickest layer of the heart wall, composed of heart muscle.'}]}], 'mappability_retry_count': 2, 'retries': 0, 'ranked_mappings': [{'original': 'Cardiomyopathy', 'ranked_candidates': [{'code': 'HP:0001638', 'term': 'Cardiomyopathy', 'description': 'condition in which there is a deviation from or interruption of the normal structure or function of the myocardium, the middle and thickest layer of the heart wall, composed of heart muscle.', 'confidence': 1.0}, {'code': 'HP:0030843', 'term': 'Amyloid cardiomyopathy', 'description': 'Extracellular deposition in cardiac tissue of a proteinaceous material that, when stained with Congo red, demonstrates apple-green birefringence under polarized light and that has a distinct color when stained with sulfated Alcian blue. Viewed with electron microscopy, the amyloid deposits are seen to be composed of a beta-sheet fibrillar material. These nonbranching fibrils have a diameter of 7.5 to 10 nm and are the result of protein misfolding. [https://orcid.org/0000-0002-0736-9199, PMID:16186440]', 'confidence': 0.75}, {'code': 'HP:0031992', 'term': 'Apical hypertrophic cardiomyopathy', 'description': 'Apical hypertrophic cardiomyopathy (AHCM) is diastolic dysfunction due to abnormal stiffness of the left ventricle during diastole, with resultant impaired ventricular filling. In AHCM thickened apical segments produce a crowded, spade-shaped, small apical cavity. [https://orcid.org/0000-0001-5835-5515, PMID:23109785, PMID:8685759]', 'confidence': 0.75}, {'code': 'HP:0200127', 'term': 'Atrial cardiomyopathy', 'description': 'Any complex of structural, architectural, contractile or electrophysiological changes affecting the atria with the potential to produce clinically relevant manifestations. [PMID:27402624]', 'confidence': 0.75}, {'code': 'HP:0012818', 'term': 'Biventricular noncompaction cardiomyopathy', 'description': 'Noncompaction cardiomyopathy that affects both ventricles. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Cardiomyopathy': {\n",
      "  \"best_match_code\": \"HP:0001638\",\n",
      "  \"best_match_term\": \"Cardiomyopathy\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 130\n",
      "✅ Extracted terms: ['Syncope']\n",
      "🌐 [Syncope] API Status: 200\n",
      "✅ Results for Syncope: [{'code': 'HP:0012669', 'term': 'Carotid sinus syncope', 'description': 'An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012668', 'term': 'Neurocardiogenic syncope', 'description': 'Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Syncope', 'candidates': [{'code': 'HP:0012669', 'term': 'Carotid sinus syncope', 'description': 'An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012668', 'term': 'Neurocardiogenic syncope', 'description': 'Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Syncope': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012669\",\n",
      "    \"matched_term\": \"Carotid sinus syncope\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012668\",\n",
      "    \"matched_term\": \"Neurocardiogenic syncope\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Fainting (syncope)', 'field_type': 'radio', 'extracted_terms': ['Syncope'], 'umls_mappings': [{'original': 'Syncope', 'candidates': [{'code': 'HP:0012669', 'term': 'Carotid sinus syncope', 'description': 'An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012668', 'term': 'Neurocardiogenic syncope', 'description': 'Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Syncope', 'ranked_candidates': [{'code': 'HP:0012669', 'term': 'Carotid sinus syncope', 'description': 'An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.5}, {'code': 'HP:0012668', 'term': 'Neurocardiogenic syncope', 'description': 'Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Syncope': {\n",
      "  \"best_match_code\": \"HP:0012669\",\n",
      "  \"best_match_term\": \"Carotid sinus syncope\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Fainting (syncope)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Syncope\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Syncope\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012669\",\n",
      "          \"term\": \"Carotid sinus syncope\",\n",
      "          \"description\": \"An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012668\",\n",
      "          \"term\": \"Neurocardiogenic syncope\",\n",
      "          \"description\": \"Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Syncope\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012669\",\n",
      "          \"term\": \"Carotid sinus syncope\",\n",
      "          \"description\": \"An exaggerated response to carotid sinus baroreceptor stimulation resulting in syncope from transient diminished cerebral perfusion. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.5\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012668\",\n",
      "          \"term\": \"Neurocardiogenic syncope\",\n",
      "          \"description\": \"Loss of consciousness due to a reduction in blood pressure that is associated with an increase in vagal tone and peripheral vasodilation.\",\n",
      "          \"confidence\": 0.5\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Syncope\",\n",
      "      \"best_match_code\": \"HP:0012669\",\n",
      "      \"best_match_term\": \"Carotid sinus syncope\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0221046\n",
      "🧩 ancestor_cuis ['C0012634', 'C0007820', 'C0007222', 'C1285159', 'C3532905', 'C0558385', 'C1276018', 'C0425654', 'C0007273', 'C0425674', 'C0741983', 'C0042373', 'C1290861', 'C0852949', 'C0424722', 'C0027765', 'C0425560', 'C0577829', 'C0575155', 'C0263978', 'C2720507', 'C1145628', 'C0037088']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0007820', 'name': 'Cerebrovascular disease'}, {'cui': 'C0007222', 'name': 'Cardiovascular disease'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C3532905', 'name': 'Disease of non-coronary systemic artery'}, {'cui': 'C0558385', 'name': 'Disorder of neck'}, {'cui': 'C1276018', 'name': 'Carotid artery finding'}, {'cui': 'C0425654', 'name': 'Blood vessel finding'}, {'cui': 'C0007273', 'name': 'Carotid artery disease'}, {'cui': 'C0425674', 'name': 'Finding of artery'}, {'cui': 'C0741983', 'name': 'Carotid sinus hypersensitivity'}, {'cui': 'C0042373', 'name': 'Vascular disease, NOS'}, {'cui': 'C1290861', 'name': 'Disorder of artery of neck'}, {'cui': 'C0852949', 'name': 'Disease of artery, NOS'}, {'cui': 'C0424722', 'name': 'General finding of soft tissue'}, {'cui': 'C0027765', 'name': 'Nervous system disorders NOS'}, {'cui': 'C0425560', 'name': 'Cardiovascular finding'}, {'cui': 'C0577829', 'name': 'Systemic arterial finding'}, {'cui': 'C0575155', 'name': 'Finding of neck region'}, {'cui': 'C0263978', 'name': 'Disorder of soft tissue'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C1145628', 'name': 'Disorder of autonomic nervous system, NOS'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Fainting (syncope)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Syncope\"\n",
      "  \"best_match_code\": \"HP:0012669\",\n",
      "  \"best_match_term\": \"Carotid sinus syncope\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0007820 (Cerebrovascular disease)\n",
      "- C0007222 (Cardiovascular disease)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C3532905 (Disease of non-coronary systemic artery)\n",
      "- C0558385 (Disorder of neck)\n",
      "- C1276018 (Carotid artery finding)\n",
      "- C0425654 (Blood vessel finding)\n",
      "- C0007273 (Carotid artery disease)\n",
      "- C0425674 (Finding of artery)\n",
      "- C0741983 (Carotid sinus hypersensitivity)\n",
      "- C0042373 (Vascular disease, NOS)\n",
      "- C1290861 (Disorder of artery of neck)\n",
      "- C0852949 (Disease of artery, NOS)\n",
      "- C0424722 (General finding of soft tissue)\n",
      "- C0027765 (Nervous system disorders NOS)\n",
      "- C0425560 (Cardiovascular finding)\n",
      "- C0577829 (Systemic arterial finding)\n",
      "- C0575155 (Finding of neck region)\n",
      "- C0263978 (Disorder of soft tissue)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C1145628 (Disorder of autonomic nervous system, NOS)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0001254\",\\n  \"refined_term\": \"Syncope\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 32, 'prompt_tokens': 782, 'total_tokens': 814, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeQZthe4jhofyQIn2XPZNIBQJQxc', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--0cf24dd3-85c3-41d7-b930-5197c9413008-0' usage_metadata={'input_tokens': 782, 'output_tokens': 32, 'total_tokens': 814, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Syncope\n",
      "🧠 LLM refined_code: HP:0001254\n",
      "✅ Processed row 131\n",
      "✅ Extracted terms: ['Congenital heart defect']\n",
      "🌐 [Congenital heart defect] API Status: 200\n",
      "✅ Results for Congenital heart defect: [{'code': 'HP:0001627', 'term': 'Congenital heart defect', 'description': 'Developmental abnormalities involving structures of the heart. These defects are present at birth but may be discovered later in life.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Congenital heart defect', 'candidates': [{'code': 'HP:0001627', 'term': 'Congenital heart defect', 'description': 'Developmental abnormalities involving structures of the heart. These defects are present at birth but may be discovered later in life.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Congenital heart defect': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001627\",\n",
      "    \"matched_term\": \"Congenital heart defect\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Heart defect (congenital)', 'field_type': 'radio', 'extracted_terms': ['Congenital heart defect'], 'umls_mappings': [{'original': 'Congenital heart defect', 'candidates': [{'code': 'HP:0001627', 'term': 'Congenital heart defect', 'description': 'Developmental abnormalities involving structures of the heart. These defects are present at birth but may be discovered later in life.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Congenital heart defect', 'ranked_candidates': [{'code': 'HP:0001627', 'term': 'Congenital heart defect', 'description': 'Developmental abnormalities involving structures of the heart. These defects are present at birth but may be discovered later in life.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Congenital heart defect': {\n",
      "  \"best_match_code\": \"HP:0001627\",\n",
      "  \"best_match_term\": \"Congenital heart defect\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 132\n",
      "✅ Extracted terms: ['Hypertension']\n",
      "🌐 [Hypertension] API Status: 200\n",
      "✅ Results for Hypertension: [{'code': 'HP:0000822', 'term': 'Arterial hypertension', 'description': 'Persistently high systemic arterial BLOOD PRESSURE. Based on multiple readings (BLOOD PRESSURE DETERMINATION), hypertension is currently defined as when SYSTOLIC PRESSURE is consistently greater than 140 mm Hg or when DIASTOLIC PRESSURE is consistently 90 mm Hg or more.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypertension', 'candidates': [{'code': 'HP:0000822', 'term': 'Arterial hypertension', 'description': 'Persistently high systemic arterial BLOOD PRESSURE. Based on multiple readings (BLOOD PRESSURE DETERMINATION), hypertension is currently defined as when SYSTOLIC PRESSURE is consistently greater than 140 mm Hg or when DIASTOLIC PRESSURE is consistently 90 mm Hg or more.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypertension': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000822\",\n",
      "    \"matched_term\": \"Arterial hypertension\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'High blood pressure (hypertension)', 'field_type': 'radio', 'extracted_terms': ['Hypertension'], 'umls_mappings': [{'original': 'Hypertension', 'candidates': [{'code': 'HP:0000822', 'term': 'Arterial hypertension', 'description': 'Persistently high systemic arterial BLOOD PRESSURE. Based on multiple readings (BLOOD PRESSURE DETERMINATION), hypertension is currently defined as when SYSTOLIC PRESSURE is consistently greater than 140 mm Hg or when DIASTOLIC PRESSURE is consistently 90 mm Hg or more.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypertension', 'ranked_candidates': [{'code': 'HP:0000822', 'term': 'Arterial hypertension', 'description': 'Persistently high systemic arterial BLOOD PRESSURE. Based on multiple readings (BLOOD PRESSURE DETERMINATION), hypertension is currently defined as when SYSTOLIC PRESSURE is consistently greater than 140 mm Hg or when DIASTOLIC PRESSURE is consistently 90 mm Hg or more.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypertension': {\n",
      "  \"best_match_code\": \"HP:0000822\",\n",
      "  \"best_match_term\": \"Arterial hypertension\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 133\n",
      "✅ Extracted terms: ['Hypercholesterolemia']\n",
      "🌐 [Hypercholesterolemia] API Status: 200\n",
      "✅ Results for Hypercholesterolemia: [{'code': 'HP:0003124', 'term': 'Hypercholesterolemia', 'description': 'A condition with abnormally high levels of CHOLESTEROL in the blood. It is defined as a cholesterol value exceeding the 95th percentile for the population.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Hypercholesterolemia', 'candidates': [{'code': 'HP:0003124', 'term': 'Hypercholesterolemia', 'description': 'A condition with abnormally high levels of CHOLESTEROL in the blood. It is defined as a cholesterol value exceeding the 95th percentile for the population.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Hypercholesterolemia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003124\",\n",
      "    \"matched_term\": \"Hypercholesterolemia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'High cholesterol (hypercholesterolemia)', 'field_type': 'radio', 'extracted_terms': ['Hypercholesterolemia'], 'umls_mappings': [{'original': 'Hypercholesterolemia', 'candidates': [{'code': 'HP:0003124', 'term': 'Hypercholesterolemia', 'description': 'A condition with abnormally high levels of CHOLESTEROL in the blood. It is defined as a cholesterol value exceeding the 95th percentile for the population.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Hypercholesterolemia', 'ranked_candidates': [{'code': 'HP:0003124', 'term': 'Hypercholesterolemia', 'description': 'A condition with abnormally high levels of CHOLESTEROL in the blood. It is defined as a cholesterol value exceeding the 95th percentile for the population.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Hypercholesterolemia': {\n",
      "  \"best_match_code\": \"HP:0003124\",\n",
      "  \"best_match_term\": \"Hypercholesterolemia\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 134\n",
      "✅ Extracted terms: ['Stroke']\n",
      "🌐 [Stroke] API Status: 200\n",
      "✅ Results for Stroke: [{'code': 'HP:0034732', 'term': 'Exertional heat stroke', 'description': 'A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40°C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.'}, {'code': 'HP:0001342', 'term': 'Hemorrhagic stroke', 'description': 'A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Stroke', 'candidates': [{'code': 'HP:0034732', 'term': 'Exertional heat stroke', 'description': 'A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40°C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.'}, {'code': 'HP:0001342', 'term': 'Hemorrhagic stroke', 'description': 'A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Stroke': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001342\",\n",
      "    \"matched_term\": \"Hemorrhagic stroke\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0034732\",\n",
      "    \"matched_term\": \"Exertional heat stroke\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Stroke', 'field_type': 'radio', 'extracted_terms': ['Stroke'], 'umls_mappings': [{'original': 'Stroke', 'candidates': [{'code': 'HP:0034732', 'term': 'Exertional heat stroke', 'description': 'A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40°C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.'}, {'code': 'HP:0001342', 'term': 'Hemorrhagic stroke', 'description': 'A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Stroke', 'ranked_candidates': [{'code': 'HP:0001342', 'term': 'Hemorrhagic stroke', 'description': 'A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke', 'confidence': 1.0}, {'code': 'HP:0034732', 'term': 'Exertional heat stroke', 'description': 'A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40°C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Stroke': {\n",
      "  \"best_match_code\": \"HP:0001342\",\n",
      "  \"best_match_term\": \"Hemorrhagic stroke\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Stroke\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Stroke\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stroke\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0034732\",\n",
      "          \"term\": \"Exertional heat stroke\",\n",
      "          \"description\": \"A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40\\u00b0C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001342\",\n",
      "          \"term\": \"Hemorrhagic stroke\",\n",
      "          \"description\": \"A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stroke\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001342\",\n",
      "          \"term\": \"Hemorrhagic stroke\",\n",
      "          \"description\": \"A stroke is a medical emergency. There are two types - ischemic and hemorrhagic. Hemorrhagic stroke is the less common type. It happens when a blood vessel breaks and bleeds into the brain. Within minutes, brain cells begin to die. Causes include a bleeding aneurysm, an arteriovenous malformation (AVM), or an artery wall that breaks open. Symptoms of stroke are: Sudden numbness or weakness of the face, arm or leg (especially on one side of the body) Sudden confusion, trouble speaking or understanding speech Sudden trouble seeing in one or both eyes Sudden trouble walking, dizziness, loss of balance or coordination Sudden severe headache with no known cause  It is important to treat strokes as quickly as possible. With a hemorrhagic stroke, the first steps are to find the cause of bleeding in the brain and then control it. Surgery may be needed. Post-stroke rehabilitation can help people overcome disabilities caused by stroke damage. National Institute of Neurological Disorders and Stroke\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0034732\",\n",
      "          \"term\": \"Exertional heat stroke\",\n",
      "          \"description\": \"A rare disease with malignant hyperthermia characterized by exercise-induced life-threatening hyperthermia with a body temperature over 40\\u00b0C and signs of encephalopathy ranging from confusion to convulsions or coma. Incidence increases with rising ambient temperature and relative humidity. Manifestations may include rhabdomyolysis (presenting with myalgia, muscle weakness, and myoglobinuria), tachycardia, and in severe cases multiorgan failure.\",\n",
      "          \"confidence\": 0.5\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Stroke\",\n",
      "      \"best_match_code\": \"HP:0001342\",\n",
      "      \"best_match_term\": \"Hemorrhagic stroke\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C2937358\n",
      "🧩 ancestor_cuis ['C0576471', 'C0012634', 'C0151699', 'C0422878', 'C0019080', 'C1290856', 'C0006111', 'C1320354', 'C1285159', 'C2720507', 'C0037088', 'C0027765', 'C0007682']\n",
      "🧩 candidate_details [{'cui': 'C0576471', 'name': 'Finding of brain'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0151699', 'name': 'Intracranial hemorrhage'}, {'cui': 'C0422878', 'name': 'Central nervous system finding'}, {'cui': 'C0019080', 'name': 'Hemorrhage'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C0006111', 'name': 'Disease of brain, NOS'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0027765', 'name': 'Nervous system disorders NOS'}, {'cui': 'C0007682', 'name': 'CNS disorder'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Stroke\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Stroke\"\n",
      "  \"best_match_code\": \"HP:0001342\",\n",
      "  \"best_match_term\": \"Hemorrhagic stroke\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0576471 (Finding of brain)\n",
      "- C0012634 (Disease)\n",
      "- C0151699 (Intracranial hemorrhage)\n",
      "- C0422878 (Central nervous system finding)\n",
      "- C0019080 (Hemorrhage)\n",
      "- C1290856 (Disorder of head)\n",
      "- C0006111 (Disease of brain, NOS)\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0027765 (Nervous system disorders NOS)\n",
      "- C0007682 (CNS disorder)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0001297\",\\n  \"refined_term\": \"Cerebral vascular abnormality\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 36, 'prompt_tokens': 646, 'total_tokens': 682, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeR7rsyZu9bqY6NYNtmBiauPNfhg', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--5c9a8bfd-f97f-456d-a8cd-ed0f04fc826f-0' usage_metadata={'input_tokens': 646, 'output_tokens': 36, 'total_tokens': 682, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Cerebral vascular abnormality\n",
      "🧠 LLM refined_code: HP:0001297\n",
      "✅ Processed row 135\n",
      "✅ Extracted terms: ['Asthma']\n",
      "🌐 [Asthma] API Status: 200\n",
      "✅ Results for Asthma: [{'code': 'HP:0012653', 'term': 'Acute severe asthma', 'description': 'A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.'}, {'code': 'HP:0012042', 'term': 'Aspirin-induced asthma', 'description': 'Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Asthma', 'candidates': [{'code': 'HP:0012653', 'term': 'Acute severe asthma', 'description': 'A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.'}, {'code': 'HP:0012042', 'term': 'Aspirin-induced asthma', 'description': 'Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Asthma': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012653\",\n",
      "    \"matched_term\": \"Acute severe asthma\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012042\",\n",
      "    \"matched_term\": \"Aspirin-induced asthma\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Asthma', 'field_type': 'radio', 'extracted_terms': ['Asthma'], 'umls_mappings': [{'original': 'Asthma', 'candidates': [{'code': 'HP:0012653', 'term': 'Acute severe asthma', 'description': 'A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.'}, {'code': 'HP:0012042', 'term': 'Aspirin-induced asthma', 'description': 'Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Asthma', 'ranked_candidates': [{'code': 'HP:0012653', 'term': 'Acute severe asthma', 'description': 'A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.', 'confidence': 0.9}, {'code': 'HP:0012042', 'term': 'Aspirin-induced asthma', 'description': 'Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Asthma': {\n",
      "  \"best_match_code\": \"HP:0012653\",\n",
      "  \"best_match_term\": \"Acute severe asthma\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Asthma\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Asthma\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Asthma\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012653\",\n",
      "          \"term\": \"Acute severe asthma\",\n",
      "          \"description\": \"A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012042\",\n",
      "          \"term\": \"Aspirin-induced asthma\",\n",
      "          \"description\": \"Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Asthma\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012653\",\n",
      "          \"term\": \"Acute severe asthma\",\n",
      "          \"description\": \"A sudden intense and continuous aggravation of a state of asthma, marked by dyspnea to the point of exhaustion and collapse and not responding to the usual therapeutic efforts.\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012042\",\n",
      "          \"term\": \"Aspirin-induced asthma\",\n",
      "          \"description\": \"Asthmatic adverse reaction (e.g., BRONCHOCONSTRICTION) to conventional NSAIDS including aspirin use.\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Asthma\",\n",
      "      \"best_match_code\": \"HP:0012653\",\n",
      "      \"best_match_term\": \"Acute severe asthma\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0038218\n",
      "🧩 ancestor_cuis ['C0012634', 'C0001314', 'C0349790', 'C0035204', 'C2720507', 'C1285159', 'C0037088', 'C0264219', 'C0425442', 'C0004096']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0001314', 'name': 'Acute disease'}, {'cui': 'C0349790', 'name': 'Exacerbation of asthma'}, {'cui': 'C0035204', 'name': 'Respiratory disorder'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0264219', 'name': 'Acute respiratory disease'}, {'cui': 'C0425442', 'name': 'Respiratory system finding'}, {'cui': 'C0004096', 'name': 'Asthma'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Asthma\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Asthma\"\n",
      "  \"best_match_code\": \"HP:0012653\",\n",
      "  \"best_match_term\": \"Acute severe asthma\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0001314 (Acute disease)\n",
      "- C0349790 (Exacerbation of asthma)\n",
      "- C0035204 (Respiratory disorder)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0264219 (Acute respiratory disease)\n",
      "- C0425442 (Respiratory system finding)\n",
      "- C0004096 (Asthma)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0002099\",\\n  \"refined_term\": \"Asthma\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 33, 'prompt_tokens': 610, 'total_tokens': 643, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeRLadNMdEJ90PreqTTxmmVKxzZb', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--ea35ebb1-adf2-4cbf-af7b-5fb449ba5d03-0' usage_metadata={'input_tokens': 610, 'output_tokens': 33, 'total_tokens': 643, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Asthma\n",
      "🧠 LLM refined_code: HP:0002099\n",
      "✅ Processed row 136\n",
      "✅ Extracted terms: ['Chronic lung disease']\n",
      "🌐 [Chronic lung disease] API Status: 200\n",
      "✅ Results for Chronic lung disease: [{'code': 'HP:0006528', 'term': 'Chronic lung disease', 'description': 'A persistent non-neoplastic disorder of the lungs. Representative examples include: chronic obstructive pulmonary disease, chronic bronchitis, emphysema, pulmonary fibrosis, pneumoconiosis, asbestosis, atelectasis, radiation induced pneumonitis, and radiation fibrosis.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Chronic lung disease', 'candidates': [{'code': 'HP:0006528', 'term': 'Chronic lung disease', 'description': 'A persistent non-neoplastic disorder of the lungs. Representative examples include: chronic obstructive pulmonary disease, chronic bronchitis, emphysema, pulmonary fibrosis, pneumoconiosis, asbestosis, atelectasis, radiation induced pneumonitis, and radiation fibrosis.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Chronic lung disease': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006528\",\n",
      "    \"matched_term\": \"Chronic lung disease\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Chronic lung issues (exclude acute infections)', 'field_type': 'radio', 'extracted_terms': ['Chronic lung disease'], 'umls_mappings': [{'original': 'Chronic lung disease', 'candidates': [{'code': 'HP:0006528', 'term': 'Chronic lung disease', 'description': 'A persistent non-neoplastic disorder of the lungs. Representative examples include: chronic obstructive pulmonary disease, chronic bronchitis, emphysema, pulmonary fibrosis, pneumoconiosis, asbestosis, atelectasis, radiation induced pneumonitis, and radiation fibrosis.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Chronic lung disease', 'ranked_candidates': [{'code': 'HP:0006528', 'term': 'Chronic lung disease', 'description': 'A persistent non-neoplastic disorder of the lungs. Representative examples include: chronic obstructive pulmonary disease, chronic bronchitis, emphysema, pulmonary fibrosis, pneumoconiosis, asbestosis, atelectasis, radiation induced pneumonitis, and radiation fibrosis.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Chronic lung disease': {\n",
      "  \"best_match_code\": \"HP:0006528\",\n",
      "  \"best_match_term\": \"Chronic lung disease\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 137\n",
      "✅ Extracted terms: ['Decreased lung function']\n",
      "🌐 [Decreased lung function] API Status: 200\n",
      "✅ Results for Decreased lung function: [{'code': 'HP:0002747', 'term': 'Decreased lung function due to weak breathing muscles', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Decreased lung function', 'candidates': [{'code': 'HP:0002747', 'term': 'Decreased lung function due to weak breathing muscles', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Decreased lung function': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002747\",\n",
      "    \"matched_term\": \"Decreased lung function due to weak breathing muscles\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Decreased lung function', 'field_type': 'radio', 'extracted_terms': ['Decreased lung function'], 'umls_mappings': [{'original': 'Decreased lung function', 'candidates': [{'code': 'HP:0002747', 'term': 'Decreased lung function due to weak breathing muscles', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Decreased lung function', 'ranked_candidates': [{'code': 'HP:0002747', 'term': 'Decreased lung function due to weak breathing muscles', 'description': None, 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Decreased lung function': {\n",
      "  \"best_match_code\": \"HP:0002747\",\n",
      "  \"best_match_term\": \"Decreased lung function due to weak breathing muscles\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Decreased lung function\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Decreased lung function\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Decreased lung function\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002747\",\n",
      "          \"term\": \"Decreased lung function due to weak breathing muscles\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Decreased lung function\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002747\",\n",
      "          \"term\": \"Decreased lung function due to weak breathing muscles\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Decreased lung function\",\n",
      "      \"best_match_code\": \"HP:0002747\",\n",
      "      \"best_match_term\": \"Decreased lung function due to weak breathing muscles\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C3806467\n",
      "✅ Processed row 138\n",
      "✅ Extracted terms: ['Abnormality of the diaphragm']\n",
      "🌐 [Abnormality of the diaphragm] API Status: 200\n",
      "✅ Results for Abnormality of the diaphragm: [{'code': 'HP:0000775', 'term': 'Abnormality of the diaphragm', 'description': 'Any abnormality of the diaphragm, the sheet of skeletal muscle that separates the thoracic cavity from the abdominal cavity. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the diaphragm', 'candidates': [{'code': 'HP:0000775', 'term': 'Abnormality of the diaphragm', 'description': 'Any abnormality of the diaphragm, the sheet of skeletal muscle that separates the thoracic cavity from the abdominal cavity. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the diaphragm': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000775\",\n",
      "    \"matched_term\": \"Abnormality of the diaphragm\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Diaphragm issues (hernia/weakness)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the diaphragm'], 'umls_mappings': [{'original': 'Abnormality of the diaphragm', 'candidates': [{'code': 'HP:0000775', 'term': 'Abnormality of the diaphragm', 'description': 'Any abnormality of the diaphragm, the sheet of skeletal muscle that separates the thoracic cavity from the abdominal cavity. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the diaphragm', 'ranked_candidates': [{'code': 'HP:0000775', 'term': 'Abnormality of the diaphragm', 'description': 'Any abnormality of the diaphragm, the sheet of skeletal muscle that separates the thoracic cavity from the abdominal cavity. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the diaphragm': {\n",
      "  \"best_match_code\": \"HP:0000775\",\n",
      "  \"best_match_term\": \"Abnormality of the diaphragm\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 139\n",
      "✅ Extracted terms: ['Respiratory insufficiency']\n",
      "🌐 [Respiratory insufficiency] API Status: 200\n",
      "✅ Results for Respiratory insufficiency: [{'code': 'HP:0004889', 'term': 'Intermittent episodes of respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002093', 'term': 'Respiratory insufficiency', 'description': 'Failure to adequately provide oxygen to cells of the body and to remove excess carbon dioxide from them. (Stedman, 25th ed)'}, {'code': 'HP:0200073', 'term': 'Respiratory insufficiency due to defective ciliary clearance', 'description': None}, {'code': 'HP:0002747', 'term': 'Respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002091', 'term': 'Restrictive respiratory insufficiency', 'description': 'A functional defect characterized by reduced total lung capacity (TLC) not associated with abnormalities of expiratory airflow or airway resistance. Spirometrically, a restrictive defect is defined as FEV1 (forced expiratory volume in 1 second) and FVC (forced vital capacity) less than 80 per cent. Restrictive lung disease may be caused by alterations in lung parenchyma or because of a disease of the pleura, chest wall, or neuromuscular apparatus. [https://orcid.org/0000-0003-4546-6667, PMID:28194273]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Respiratory insufficiency', 'candidates': [{'code': 'HP:0004889', 'term': 'Intermittent episodes of respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002093', 'term': 'Respiratory insufficiency', 'description': 'Failure to adequately provide oxygen to cells of the body and to remove excess carbon dioxide from them. (Stedman, 25th ed)'}, {'code': 'HP:0200073', 'term': 'Respiratory insufficiency due to defective ciliary clearance', 'description': None}, {'code': 'HP:0002747', 'term': 'Respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002091', 'term': 'Restrictive respiratory insufficiency', 'description': 'A functional defect characterized by reduced total lung capacity (TLC) not associated with abnormalities of expiratory airflow or airway resistance. Spirometrically, a restrictive defect is defined as FEV1 (forced expiratory volume in 1 second) and FVC (forced vital capacity) less than 80 per cent. Restrictive lung disease may be caused by alterations in lung parenchyma or because of a disease of the pleura, chest wall, or neuromuscular apparatus. [https://orcid.org/0000-0003-4546-6667, PMID:28194273]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Respiratory insufficiency': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002093\",\n",
      "    \"matched_term\": \"Respiratory insufficiency\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004889\",\n",
      "    \"matched_term\": \"Intermittent episodes of respiratory insufficiency due to muscle weakness\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002747\",\n",
      "    \"matched_term\": \"Respiratory insufficiency due to muscle weakness\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0200073\",\n",
      "    \"matched_term\": \"Respiratory insufficiency due to defective ciliary clearance\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002091\",\n",
      "    \"matched_term\": \"Restrictive respiratory insufficiency\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Respiratory insufficiency', 'field_type': 'radio', 'extracted_terms': ['Respiratory insufficiency'], 'umls_mappings': [{'original': 'Respiratory insufficiency', 'candidates': [{'code': 'HP:0004889', 'term': 'Intermittent episodes of respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002093', 'term': 'Respiratory insufficiency', 'description': 'Failure to adequately provide oxygen to cells of the body and to remove excess carbon dioxide from them. (Stedman, 25th ed)'}, {'code': 'HP:0200073', 'term': 'Respiratory insufficiency due to defective ciliary clearance', 'description': None}, {'code': 'HP:0002747', 'term': 'Respiratory insufficiency due to muscle weakness', 'description': None}, {'code': 'HP:0002091', 'term': 'Restrictive respiratory insufficiency', 'description': 'A functional defect characterized by reduced total lung capacity (TLC) not associated with abnormalities of expiratory airflow or airway resistance. Spirometrically, a restrictive defect is defined as FEV1 (forced expiratory volume in 1 second) and FVC (forced vital capacity) less than 80 per cent. Restrictive lung disease may be caused by alterations in lung parenchyma or because of a disease of the pleura, chest wall, or neuromuscular apparatus. [https://orcid.org/0000-0003-4546-6667, PMID:28194273]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Respiratory insufficiency', 'ranked_candidates': [{'code': 'HP:0002093', 'term': 'Respiratory insufficiency', 'description': 'Failure to adequately provide oxygen to cells of the body and to remove excess carbon dioxide from them. (Stedman, 25th ed)', 'confidence': 1.0}, {'code': 'HP:0004889', 'term': 'Intermittent episodes of respiratory insufficiency due to muscle weakness', 'description': None, 'confidence': 0.7}, {'code': 'HP:0200073', 'term': 'Respiratory insufficiency due to defective ciliary clearance', 'description': None, 'confidence': 0.7}, {'code': 'HP:0002747', 'term': 'Respiratory insufficiency due to muscle weakness', 'description': None, 'confidence': 0.7}, {'code': 'HP:0002091', 'term': 'Restrictive respiratory insufficiency', 'description': 'A functional defect characterized by reduced total lung capacity (TLC) not associated with abnormalities of expiratory airflow or airway resistance. Spirometrically, a restrictive defect is defined as FEV1 (forced expiratory volume in 1 second) and FVC (forced vital capacity) less than 80 per cent. Restrictive lung disease may be caused by alterations in lung parenchyma or because of a disease of the pleura, chest wall, or neuromuscular apparatus. [https://orcid.org/0000-0003-4546-6667, PMID:28194273]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Respiratory insufficiency': {\n",
      "  \"best_match_code\": \"HP:0002093\",\n",
      "  \"best_match_term\": \"Respiratory insufficiency\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 140\n",
      "✅ Extracted terms: ['Restrictive lung disease']\n",
      "🌐 [Restrictive lung disease] API Status: 200\n",
      "✅ Results for Restrictive lung disease: [{'code': 'HP:0002091', 'term': 'Restrictive lung disease', 'description': 'Decreased lung volume and inadequate ventilation due to parenchymal lung disorders (e.g., interstitial pulmonary fibrosis) or extrapulmonary disorders (e.g., scoliosis). Patients present with shortness of breath and cough.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Restrictive lung disease', 'candidates': [{'code': 'HP:0002091', 'term': 'Restrictive lung disease', 'description': 'Decreased lung volume and inadequate ventilation due to parenchymal lung disorders (e.g., interstitial pulmonary fibrosis) or extrapulmonary disorders (e.g., scoliosis). Patients present with shortness of breath and cough.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Restrictive lung disease': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002091\",\n",
      "    \"matched_term\": \"Restrictive lung disease\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Restrictive lung disease', 'field_type': 'radio', 'extracted_terms': ['Restrictive lung disease'], 'umls_mappings': [{'original': 'Restrictive lung disease', 'candidates': [{'code': 'HP:0002091', 'term': 'Restrictive lung disease', 'description': 'Decreased lung volume and inadequate ventilation due to parenchymal lung disorders (e.g., interstitial pulmonary fibrosis) or extrapulmonary disorders (e.g., scoliosis). Patients present with shortness of breath and cough.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Restrictive lung disease', 'ranked_candidates': [{'code': 'HP:0002091', 'term': 'Restrictive lung disease', 'description': 'Decreased lung volume and inadequate ventilation due to parenchymal lung disorders (e.g., interstitial pulmonary fibrosis) or extrapulmonary disorders (e.g., scoliosis). Patients present with shortness of breath and cough.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Restrictive lung disease': {\n",
      "  \"best_match_code\": \"HP:0002091\",\n",
      "  \"best_match_term\": \"Restrictive lung disease\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 141\n",
      "✅ Extracted terms: ['Abnormal breathing pattern']\n",
      "🌐 [Abnormal breathing pattern] API Status: 404\n",
      "❌ Failed for term: Abnormal breathing pattern\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal breathing pattern', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of breathing']\n",
      "🌐 [Abnormality of breathing] API Status: 404\n",
      "❌ Failed for term: Abnormality of breathing\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of breathing', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormal respiratory system physiology']\n",
      "🌐 [Abnormal respiratory system physiology] API Status: 200\n",
      "✅ Results for Abnormal respiratory system physiology: [{'code': 'HP:0002795', 'term': 'Abnormal respiratory system physiology', 'description': \"When you're short of breath, it's hard or uncomfortable for you to take in the oxygen your body needs. You may feel as if you're not getting enough air. Sometimes you can have mild breathing problems because of a stuffy nose or intense exercise. But shortness of breath can also be a sign of a serious disease. Many conditions can make you feel short of breath:  Lung conditions such as asthma, emphysema, or pneumonia Problems with your trachea or bronchi, which are part of your airway system Heart disease can make you feel breathless if your heart cannot pump enough blood to supply oxygen to your body Anxiety and panic attacks Allergies  If you often have trouble breathing, it is important to find out the cause.\"}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal respiratory system physiology', 'candidates': [{'code': 'HP:0002795', 'term': 'Abnormal respiratory system physiology', 'description': \"When you're short of breath, it's hard or uncomfortable for you to take in the oxygen your body needs. You may feel as if you're not getting enough air. Sometimes you can have mild breathing problems because of a stuffy nose or intense exercise. But shortness of breath can also be a sign of a serious disease. Many conditions can make you feel short of breath:  Lung conditions such as asthma, emphysema, or pneumonia Problems with your trachea or bronchi, which are part of your airway system Heart disease can make you feel breathless if your heart cannot pump enough blood to supply oxygen to your body Anxiety and panic attacks Allergies  If you often have trouble breathing, it is important to find out the cause.\"}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal respiratory system physiology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002795\",\n",
      "    \"matched_term\": \"Abnormal respiratory system physiology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Unusual breathing patterns (apnea/hyperventilation/tachypnea)', 'field_type': 'radio', 'extracted_terms': ['Abnormal respiratory system physiology'], 'umls_mappings': [{'original': 'Abnormal respiratory system physiology', 'candidates': [{'code': 'HP:0002795', 'term': 'Abnormal respiratory system physiology', 'description': \"When you're short of breath, it's hard or uncomfortable for you to take in the oxygen your body needs. You may feel as if you're not getting enough air. Sometimes you can have mild breathing problems because of a stuffy nose or intense exercise. But shortness of breath can also be a sign of a serious disease. Many conditions can make you feel short of breath:  Lung conditions such as asthma, emphysema, or pneumonia Problems with your trachea or bronchi, which are part of your airway system Heart disease can make you feel breathless if your heart cannot pump enough blood to supply oxygen to your body Anxiety and panic attacks Allergies  If you often have trouble breathing, it is important to find out the cause.\"}]}], 'retry_count': 2, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormal breathing pattern', 'Abnormality of breathing', 'Abnormal respiratory system physiology'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal respiratory system physiology', 'ranked_candidates': [{'code': 'HP:0002795', 'term': 'Abnormal respiratory system physiology', 'description': \"When you're short of breath, it's hard or uncomfortable for you to take in the oxygen your body needs. You may feel as if you're not getting enough air. Sometimes you can have mild breathing problems because of a stuffy nose or intense exercise. But shortness of breath can also be a sign of a serious disease. Many conditions can make you feel short of breath:  Lung conditions such as asthma, emphysema, or pneumonia Problems with your trachea or bronchi, which are part of your airway system Heart disease can make you feel breathless if your heart cannot pump enough blood to supply oxygen to your body Anxiety and panic attacks Allergies  If you often have trouble breathing, it is important to find out the cause.\", 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal respiratory system physiology': {\n",
      "  \"best_match_code\": \"HP:0002795\",\n",
      "  \"best_match_term\": \"Abnormal respiratory system physiology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 142\n",
      "✅ Extracted terms: ['Abnormality of the upper respiratory tract']\n",
      "🌐 [Abnormality of the upper respiratory tract] API Status: 200\n",
      "✅ Results for Abnormality of the upper respiratory tract: [{'code': 'HP:0002087', 'term': 'Abnormality of the upper respiratory tract', 'description': 'An abnormality of the upper respiratory tract. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the upper respiratory tract', 'candidates': [{'code': 'HP:0002087', 'term': 'Abnormality of the upper respiratory tract', 'description': 'An abnormality of the upper respiratory tract. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the upper respiratory tract': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002087\",\n",
      "    \"matched_term\": \"Abnormality of the upper respiratory tract\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Upper respiratory tract issues (larynx/trachea/bronchi)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the upper respiratory tract'], 'umls_mappings': [{'original': 'Abnormality of the upper respiratory tract', 'candidates': [{'code': 'HP:0002087', 'term': 'Abnormality of the upper respiratory tract', 'description': 'An abnormality of the upper respiratory tract. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the upper respiratory tract', 'ranked_candidates': [{'code': 'HP:0002087', 'term': 'Abnormality of the upper respiratory tract', 'description': 'An abnormality of the upper respiratory tract. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the upper respiratory tract': {\n",
      "  \"best_match_code\": \"HP:0002087\",\n",
      "  \"best_match_term\": \"Abnormality of the upper respiratory tract\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 143\n",
      "✅ Extracted terms: ['Feeding difficulties']\n",
      "🌐 [Feeding difficulties] API Status: 200\n",
      "✅ Results for Feeding difficulties: [{'code': 'HP:0011968', 'term': 'Feeding difficulties', 'description': 'Interruption or disruption of the intake of food/nutrition.'}, {'code': 'HP:0008872', 'term': 'Feeding difficulties in infancy', 'description': 'Impaired feeding performance of an infant as manifested by difficulties such as weak and ineffective sucking, brief bursts of sucking, and falling asleep during sucking. There may be difficulties with chewing or maintaining attention. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Feeding difficulties', 'candidates': [{'code': 'HP:0011968', 'term': 'Feeding difficulties', 'description': 'Interruption or disruption of the intake of food/nutrition.'}, {'code': 'HP:0008872', 'term': 'Feeding difficulties in infancy', 'description': 'Impaired feeding performance of an infant as manifested by difficulties such as weak and ineffective sucking, brief bursts of sucking, and falling asleep during sucking. There may be difficulties with chewing or maintaining attention. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Feeding difficulties': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011968\",\n",
      "    \"matched_term\": \"Feeding difficulties\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008872\",\n",
      "    \"matched_term\": \"Feeding difficulties in infancy\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Feeding difficulties', 'field_type': 'radio', 'extracted_terms': ['Feeding difficulties'], 'umls_mappings': [{'original': 'Feeding difficulties', 'candidates': [{'code': 'HP:0011968', 'term': 'Feeding difficulties', 'description': 'Interruption or disruption of the intake of food/nutrition.'}, {'code': 'HP:0008872', 'term': 'Feeding difficulties in infancy', 'description': 'Impaired feeding performance of an infant as manifested by difficulties such as weak and ineffective sucking, brief bursts of sucking, and falling asleep during sucking. There may be difficulties with chewing or maintaining attention. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Feeding difficulties', 'ranked_candidates': [{'code': 'HP:0011968', 'term': 'Feeding difficulties', 'description': 'Interruption or disruption of the intake of food/nutrition.', 'confidence': 1.0}, {'code': 'HP:0008872', 'term': 'Feeding difficulties in infancy', 'description': 'Impaired feeding performance of an infant as manifested by difficulties such as weak and ineffective sucking, brief bursts of sucking, and falling asleep during sucking. There may be difficulties with chewing or maintaining attention. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Feeding difficulties': {\n",
      "  \"best_match_code\": \"HP:0011968\",\n",
      "  \"best_match_term\": \"Feeding difficulties\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 144\n",
      "✅ Extracted terms: ['Abnormality of the esophagus']\n",
      "🌐 [Abnormality of the esophagus] API Status: 200\n",
      "✅ Results for Abnormality of the esophagus: [{'code': 'HP:0025270', 'term': 'Functional abnormality of the esophagus', 'description': 'Any physiological abnormality of the esophagus. []'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the esophagus', 'candidates': [{'code': 'HP:0025270', 'term': 'Functional abnormality of the esophagus', 'description': 'Any physiological abnormality of the esophagus. []'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the esophagus': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025270\",\n",
      "    \"matched_term\": \"Functional abnormality of the esophagus\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Esophagus issues (reflux/inflammation/stricture)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the esophagus'], 'umls_mappings': [{'original': 'Abnormality of the esophagus', 'candidates': [{'code': 'HP:0025270', 'term': 'Functional abnormality of the esophagus', 'description': 'Any physiological abnormality of the esophagus. []'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the esophagus', 'ranked_candidates': [{'code': 'HP:0025270', 'term': 'Functional abnormality of the esophagus', 'description': 'Any physiological abnormality of the esophagus. []', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the esophagus': {\n",
      "  \"best_match_code\": \"HP:0025270\",\n",
      "  \"best_match_term\": \"Functional abnormality of the esophagus\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 145\n",
      "✅ Extracted terms: ['Abnormality of the stomach']\n",
      "🌐 [Abnormality of the stomach] API Status: 200\n",
      "✅ Results for Abnormality of the stomach: [{'code': 'HP:0002577', 'term': 'Abnormality of the stomach', 'description': 'An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the stomach', 'candidates': [{'code': 'HP:0002577', 'term': 'Abnormality of the stomach', 'description': 'An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the stomach': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002577\",\n",
      "    \"matched_term\": \"Abnormality of the stomach\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Stomach issues (hernia/pyloric stenosis/delayed emptying)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the stomach'], 'umls_mappings': [{'original': 'Abnormality of the stomach', 'candidates': [{'code': 'HP:0002577', 'term': 'Abnormality of the stomach', 'description': 'An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the stomach', 'ranked_candidates': [{'code': 'HP:0002577', 'term': 'Abnormality of the stomach', 'description': 'An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the stomach': {\n",
      "  \"best_match_code\": \"HP:0002577\",\n",
      "  \"best_match_term\": \"Abnormality of the stomach\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Stomach issues (hernia/pyloric stenosis/delayed emptying)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of the stomach\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the stomach\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002577\",\n",
      "          \"term\": \"Abnormality of the stomach\",\n",
      "          \"description\": \"An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the stomach\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002577\",\n",
      "          \"term\": \"Abnormality of the stomach\",\n",
      "          \"description\": \"An abnormality of the stomach. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of the stomach\",\n",
      "      \"best_match_code\": \"HP:0002577\",\n",
      "      \"best_match_term\": \"Abnormality of the stomach\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4025699\n",
      "✅ Processed row 146\n",
      "✅ Extracted terms: ['Abnormality of the pancreas']\n",
      "🌐 [Abnormality of the pancreas] API Status: 200\n",
      "✅ Results for Abnormality of the pancreas: [{'code': 'HP:0001732', 'term': 'Abnormality of the pancreas', 'description': 'An abnormality of the pancreas. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the pancreas', 'candidates': [{'code': 'HP:0001732', 'term': 'Abnormality of the pancreas', 'description': 'An abnormality of the pancreas. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the pancreas': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001732\",\n",
      "    \"matched_term\": \"Abnormality of the pancreas\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Pancreas issues (pancreatitis/cysts)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the pancreas'], 'umls_mappings': [{'original': 'Abnormality of the pancreas', 'candidates': [{'code': 'HP:0001732', 'term': 'Abnormality of the pancreas', 'description': 'An abnormality of the pancreas. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the pancreas', 'ranked_candidates': [{'code': 'HP:0001732', 'term': 'Abnormality of the pancreas', 'description': 'An abnormality of the pancreas. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the pancreas': {\n",
      "  \"best_match_code\": \"HP:0001732\",\n",
      "  \"best_match_term\": \"Abnormality of the pancreas\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 147\n",
      "✅ Extracted terms: ['Abnormality of the liver']\n",
      "🌐 [Abnormality of the liver] API Status: 200\n",
      "✅ Results for Abnormality of the liver: [{'code': 'HP:0001392', 'term': 'Abnormality of the liver', 'description': 'An abnormality of the liver. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006707', 'term': 'Abnormality of the liver vasculature', 'description': 'An abnormality of the hepatic vasculature. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the liver', 'candidates': [{'code': 'HP:0001392', 'term': 'Abnormality of the liver', 'description': 'An abnormality of the liver. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006707', 'term': 'Abnormality of the liver vasculature', 'description': 'An abnormality of the hepatic vasculature. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the liver': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001392\",\n",
      "    \"matched_term\": \"Abnormality of the liver\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006707\",\n",
      "    \"matched_term\": \"Abnormality of the liver vasculature\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Liver issues (hepatomegaly/cirrhosis/hepatitis/cysts)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the liver'], 'umls_mappings': [{'original': 'Abnormality of the liver', 'candidates': [{'code': 'HP:0001392', 'term': 'Abnormality of the liver', 'description': 'An abnormality of the liver. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0006707', 'term': 'Abnormality of the liver vasculature', 'description': 'An abnormality of the hepatic vasculature. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the liver', 'ranked_candidates': [{'code': 'HP:0001392', 'term': 'Abnormality of the liver', 'description': 'An abnormality of the liver. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0006707', 'term': 'Abnormality of the liver vasculature', 'description': 'An abnormality of the hepatic vasculature. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the liver': {\n",
      "  \"best_match_code\": \"HP:0001392\",\n",
      "  \"best_match_term\": \"Abnormality of the liver\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 148\n",
      "✅ Extracted terms: ['Intestinal dysmotility']\n",
      "🌐 [Intestinal dysmotility] API Status: 200\n",
      "✅ Results for Intestinal dysmotility: [{'code': 'HP:0002579', 'term': 'Gastrointestinal dysmotility', 'description': 'Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012850', 'term': 'Small intestinal dysmotility', 'description': 'Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Intestinal dysmotility', 'candidates': [{'code': 'HP:0002579', 'term': 'Gastrointestinal dysmotility', 'description': 'Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012850', 'term': 'Small intestinal dysmotility', 'description': 'Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Intestinal dysmotility': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012850\",\n",
      "    \"matched_term\": \"Small intestinal dysmotility\",\n",
      "    \"confidence\": \"90%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002579\",\n",
      "    \"matched_term\": \"Gastrointestinal dysmotility\",\n",
      "    \"confidence\": \"80%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Dysmotility (ileus/intestinal pseudo-obstruction)', 'field_type': 'radio', 'extracted_terms': ['Intestinal dysmotility'], 'umls_mappings': [{'original': 'Intestinal dysmotility', 'candidates': [{'code': 'HP:0002579', 'term': 'Gastrointestinal dysmotility', 'description': 'Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012850', 'term': 'Small intestinal dysmotility', 'description': 'Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Intestinal dysmotility', 'ranked_candidates': [{'code': 'HP:0012850', 'term': 'Small intestinal dysmotility', 'description': 'Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.9}, {'code': 'HP:0002579', 'term': 'Gastrointestinal dysmotility', 'description': 'Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Intestinal dysmotility': {\n",
      "  \"best_match_code\": \"HP:0012850\",\n",
      "  \"best_match_term\": \"Small intestinal dysmotility\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Dysmotility (ileus/intestinal pseudo-obstruction)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Intestinal dysmotility\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Intestinal dysmotility\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002579\",\n",
      "          \"term\": \"Gastrointestinal dysmotility\",\n",
      "          \"description\": \"Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012850\",\n",
      "          \"term\": \"Small intestinal dysmotility\",\n",
      "          \"description\": \"Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Intestinal dysmotility\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012850\",\n",
      "          \"term\": \"Small intestinal dysmotility\",\n",
      "          \"description\": \"Abnormal small intestinal contractions, such as spasms and intestinal paralysis related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.9\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0002579\",\n",
      "          \"term\": \"Gastrointestinal dysmotility\",\n",
      "          \"description\": \"Abnormal intestinal contractions, such as spasms and intestinal paralysis, related to the loss of the ability of the gut to coordinate muscular activity because of endogenous or exogenous causes. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Intestinal dysmotility\",\n",
      "      \"best_match_code\": \"HP:0012850\",\n",
      "      \"best_match_term\": \"Small intestinal dysmotility\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0345200\n",
      "🧩 ancestor_cuis ['C0012634', 'C0345247', 'C0021831', 'C0426684', 'C1285159', 'C0345199', 'C1333803', 'C1261141', 'C0579140', 'C3661974', 'C1320355', 'C0574125', 'C2700612', 'C1290837', 'C0341268', 'C0577028', 'C1290864', 'C4544976', 'C0266806', 'C0242354', 'C0400865', 'C0426683', 'C0012242', 'C0159000', 'C2720507', 'C5231095', 'C5231096', 'C0037088', 'C0017178', 'C1533165', 'C0016807']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0345247', 'name': 'Generalized congenital intestinal dysmotility'}, {'cui': 'C0021831', 'name': 'Intestinal disease'}, {'cui': 'C0426684', 'name': 'Bowel finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0345199', 'name': 'Congenital functional disorders of the small intestine'}, {'cui': 'C1333803', 'name': 'Digestive system observation'}, {'cui': 'C1261141', 'name': 'Gastrointestinal tract finding'}, {'cui': 'C0579140', 'name': 'Finding of trunk structure'}, {'cui': 'C3661974', 'name': 'Finding of abdomen'}, {'cui': 'C1320355', 'name': 'Viscus structure finding'}, {'cui': 'C0574125', 'name': 'Functional finding'}, {'cui': 'C2700612', 'name': 'Disorder of digestive tract'}, {'cui': 'C1290837', 'name': 'Disorder of trunk'}, {'cui': 'C0341268', 'name': 'Disorder of small intestine'}, {'cui': 'C0577028', 'name': 'Finding of small intestine'}, {'cui': 'C1290864', 'name': 'Disorder of abdomen'}, {'cui': 'C4544976', 'name': 'Motility disorder of small intestine'}, {'cui': 'C0266806', 'name': 'Disorder of digestive organ'}, {'cui': 'C0242354', 'name': 'Congenital disorder'}, {'cui': 'C0400865', 'name': 'Motility disorder of intestine'}, {'cui': 'C0426683', 'name': 'Abdominal organ finding'}, {'cui': 'C0012242', 'name': 'Disorder of digestive system'}, {'cui': 'C0159000', 'name': 'Disorder of digestive system specific to fetus OR newborn'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C5231095', 'name': 'Finding of abdominopelvic segment of trunk'}, {'cui': 'C5231096', 'name': 'Disorder of abdominopelvic segment of trunk'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0017178', 'name': 'Gastrointestinal disorder, NOS'}, {'cui': 'C1533165', 'name': 'Disorder of fetus or newborn'}, {'cui': 'C0016807', 'name': 'Functional disorder of intestine'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Dysmotility (ileus/intestinal pseudo-obstruction)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Intestinal dysmotility\"\n",
      "  \"best_match_code\": \"HP:0012850\",\n",
      "  \"best_match_term\": \"Small intestinal dysmotility\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C0345247 (Generalized congenital intestinal dysmotility)\n",
      "- C0021831 (Intestinal disease)\n",
      "- C0426684 (Bowel finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0345199 (Congenital functional disorders of the small intestine)\n",
      "- C1333803 (Digestive system observation)\n",
      "- C1261141 (Gastrointestinal tract finding)\n",
      "- C0579140 (Finding of trunk structure)\n",
      "- C3661974 (Finding of abdomen)\n",
      "- C1320355 (Viscus structure finding)\n",
      "- C0574125 (Functional finding)\n",
      "- C2700612 (Disorder of digestive tract)\n",
      "- C1290837 (Disorder of trunk)\n",
      "- C0341268 (Disorder of small intestine)\n",
      "- C0577028 (Finding of small intestine)\n",
      "- C1290864 (Disorder of abdomen)\n",
      "- C4544976 (Motility disorder of small intestine)\n",
      "- C0266806 (Disorder of digestive organ)\n",
      "- C0242354 (Congenital disorder)\n",
      "- C0400865 (Motility disorder of intestine)\n",
      "- C0426683 (Abdominal organ finding)\n",
      "- C0012242 (Disorder of digestive system)\n",
      "- C0159000 (Disorder of digestive system specific to fetus OR newborn)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C5231095 (Finding of abdominopelvic segment of trunk)\n",
      "- C5231096 (Disorder of abdominopelvic segment of trunk)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0017178 (Gastrointestinal disorder, NOS)\n",
      "- C1533165 (Disorder of fetus or newborn)\n",
      "- C0016807 (Functional disorder of intestine)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{\\n  \"refined_code\": \"HP:0005263\",\\n  \"refined_term\": \"Intestinal pseudo-obstruction\",\\n  \"confidence\": \"100%\"\\n}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 35, 'prompt_tokens': 890, 'total_tokens': 925, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeTlbA1XQmw64JpopRBHgNXnPxRp', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--1802217f-e352-4305-ba76-4d2ed47e1652-0' usage_metadata={'input_tokens': 890, 'output_tokens': 35, 'total_tokens': 925, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "🧠 LLM refined_term: Intestinal pseudo-obstruction\n",
      "🧠 LLM refined_code: HP:0005263\n",
      "✅ Processed row 149\n",
      "✅ Extracted terms: ['Abnormality of the intestine']\n",
      "🌐 [Abnormality of the intestine] API Status: 200\n",
      "✅ Results for Abnormality of the intestine: [{'code': 'HP:0002242', 'term': 'Abnormality of the intestine', 'description': 'An abnormality of the intestine. The closely related term enteropathy is used to refer to any disease of the intestine. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the intestine', 'candidates': [{'code': 'HP:0002242', 'term': 'Abnormality of the intestine', 'description': 'An abnormality of the intestine. The closely related term enteropathy is used to refer to any disease of the intestine. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the intestine': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002242\",\n",
      "    \"matched_term\": \"Abnormality of the intestine\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Intestines issues (malabsorption/malrotation/polyps/IBD)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the intestine'], 'umls_mappings': [{'original': 'Abnormality of the intestine', 'candidates': [{'code': 'HP:0002242', 'term': 'Abnormality of the intestine', 'description': 'An abnormality of the intestine. The closely related term enteropathy is used to refer to any disease of the intestine. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the intestine', 'ranked_candidates': [{'code': 'HP:0002242', 'term': 'Abnormality of the intestine', 'description': 'An abnormality of the intestine. The closely related term enteropathy is used to refer to any disease of the intestine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the intestine': {\n",
      "  \"best_match_code\": \"HP:0002242\",\n",
      "  \"best_match_term\": \"Abnormality of the intestine\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 150\n",
      "✅ Extracted terms: ['Abnormality of defecation']\n",
      "🌐 [Abnormality of defecation] API Status: 404\n",
      "❌ Failed for term: Abnormality of defecation\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of defecation', 'candidates': []}]\n",
      "✅ Revised terms: ['Fecal incontinence']\n",
      "🌐 [Fecal incontinence] API Status: 200\n",
      "✅ Results for Fecal incontinence: [{'code': 'HP:0002607', 'term': 'Fecal incontinence', 'description': 'Failure of voluntary control of the anal sphincters, with involuntary passage of feces and flatus.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Fecal incontinence', 'candidates': [{'code': 'HP:0002607', 'term': 'Fecal incontinence', 'description': 'Failure of voluntary control of the anal sphincters, with involuntary passage of feces and flatus.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Fecal incontinence': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002607\",\n",
      "    \"matched_term\": \"Fecal incontinence\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Soiling/defecation problems', 'field_type': 'radio', 'extracted_terms': ['Fecal incontinence'], 'umls_mappings': [{'original': 'Fecal incontinence', 'candidates': [{'code': 'HP:0002607', 'term': 'Fecal incontinence', 'description': 'Failure of voluntary control of the anal sphincters, with involuntary passage of feces and flatus.'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Fecal incontinence', 'Abnormality of defecation'], 'retries': 0, 'ranked_mappings': [{'original': 'Fecal incontinence', 'ranked_candidates': [{'code': 'HP:0002607', 'term': 'Fecal incontinence', 'description': 'Failure of voluntary control of the anal sphincters, with involuntary passage of feces and flatus.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Fecal incontinence': {\n",
      "  \"best_match_code\": \"HP:0002607\",\n",
      "  \"best_match_term\": \"Fecal incontinence\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 151\n",
      "✅ Extracted terms: ['Anorectal malformation']\n",
      "🌐 [Anorectal malformation] API Status: 404\n",
      "❌ Failed for term: Anorectal malformation\n",
      "🧪 Final UMLS mappings: [{'original': 'Anorectal malformation', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the anus']\n",
      "🌐 [Abnormality of the anus] API Status: 200\n",
      "✅ Results for Abnormality of the anus: [{'code': 'HP:0004378', 'term': 'Abnormality of the anus', 'description': 'Abnormality of the anal canal. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the anus', 'candidates': [{'code': 'HP:0004378', 'term': 'Abnormality of the anus', 'description': 'Abnormality of the anal canal. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the anus': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004378\",\n",
      "    \"matched_term\": \"Abnormality of the anus\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Anus issues (anorectal malformation)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the anus'], 'umls_mappings': [{'original': 'Abnormality of the anus', 'candidates': [{'code': 'HP:0004378', 'term': 'Abnormality of the anus', 'description': 'Abnormality of the anal canal. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Anorectal malformation', 'Abnormality of the anus'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the anus', 'ranked_candidates': [{'code': 'HP:0004378', 'term': 'Abnormality of the anus', 'description': 'Abnormality of the anal canal. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the anus': {\n",
      "  \"best_match_code\": \"HP:0004378\",\n",
      "  \"best_match_term\": \"Abnormality of the anus\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 152\n",
      "✅ Extracted terms: ['Abnormality of the bladder']\n",
      "🌐 [Abnormality of the bladder] API Status: 200\n",
      "✅ Results for Abnormality of the bladder: [{'code': 'HP:0000014', 'term': 'Abnormality of the bladder', 'description': 'An abnormality of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000009', 'term': 'Functional abnormality of the bladder', 'description': 'Dysfunction of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the bladder', 'candidates': [{'code': 'HP:0000014', 'term': 'Abnormality of the bladder', 'description': 'An abnormality of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000009', 'term': 'Functional abnormality of the bladder', 'description': 'Dysfunction of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the bladder': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000014\",\n",
      "    \"matched_term\": \"Abnormality of the bladder\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000009\",\n",
      "    \"matched_term\": \"Functional abnormality of the bladder\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Bladder issues (stones/size/overactive/incontinence)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the bladder'], 'umls_mappings': [{'original': 'Abnormality of the bladder', 'candidates': [{'code': 'HP:0000014', 'term': 'Abnormality of the bladder', 'description': 'An abnormality of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0000009', 'term': 'Functional abnormality of the bladder', 'description': 'Dysfunction of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the bladder', 'ranked_candidates': [{'code': 'HP:0000014', 'term': 'Abnormality of the bladder', 'description': 'An abnormality of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0000009', 'term': 'Functional abnormality of the bladder', 'description': 'Dysfunction of the urinary bladder. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the bladder': {\n",
      "  \"best_match_code\": \"HP:0000014\",\n",
      "  \"best_match_term\": \"Abnormality of the bladder\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 153\n",
      "✅ Extracted terms: ['Disorder of sex development']\n",
      "🌐 [Disorder of sex development] API Status: 404\n",
      "❌ Failed for term: Disorder of sex development\n",
      "🧪 Final UMLS mappings: [{'original': 'Disorder of sex development', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the genital system']\n",
      "🌐 [Abnormality of the genital system] API Status: 200\n",
      "✅ Results for Abnormality of the genital system: [{'code': 'HP:0000078', 'term': 'Abnormality of the genital system', 'description': 'An abnormality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the genital system', 'candidates': [{'code': 'HP:0000078', 'term': 'Abnormality of the genital system', 'description': 'An abnormality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the genital system': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000078\",\n",
      "    \"matched_term\": \"Abnormality of the genital system\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Abnormal internal or external sex organ (DSD)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the genital system'], 'umls_mappings': [{'original': 'Abnormality of the genital system', 'candidates': [{'code': 'HP:0000078', 'term': 'Abnormality of the genital system', 'description': 'An abnormality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Disorder of sex development', 'Abnormality of the genital system'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the genital system', 'ranked_candidates': [{'code': 'HP:0000078', 'term': 'Abnormality of the genital system', 'description': 'An abnormality of the genital system. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the genital system': {\"best_match_code\": \"HP:0000078\", \"best_match_term\": \"Abnormality of the genital system\", \"confidence\": \"90%\"}\n",
      "✅ Processed row 154\n",
      "✅ Extracted terms: ['Abnormality of kidney physiology']\n",
      "🌐 [Abnormality of kidney physiology] API Status: 404\n",
      "❌ Failed for term: Abnormality of kidney physiology\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of kidney physiology', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of renal physiology']\n",
      "🌐 [Abnormality of renal physiology] API Status: 200\n",
      "✅ Results for Abnormality of renal physiology: [{'code': 'HP:0012211', 'term': 'Abnormality of renal physiology', 'description': 'An abnormal functionality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of renal physiology', 'candidates': [{'code': 'HP:0012211', 'term': 'Abnormality of renal physiology', 'description': 'An abnormal functionality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of renal physiology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012211\",\n",
      "    \"matched_term\": \"Abnormality of renal physiology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Kidney function issue (failure/filtration/absorption)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of renal physiology'], 'umls_mappings': [{'original': 'Abnormality of renal physiology', 'candidates': [{'code': 'HP:0012211', 'term': 'Abnormality of renal physiology', 'description': 'An abnormal functionality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 2, 'history_rewritten_terms': ['Abnormality of kidney physiology', 'Abnormality of renal physiology'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of renal physiology', 'ranked_candidates': [{'code': 'HP:0012211', 'term': 'Abnormality of renal physiology', 'description': 'An abnormal functionality of the kidney. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of renal physiology': {\n",
      "  \"best_match_code\": \"HP:0012211\",\n",
      "  \"best_match_term\": \"Abnormality of renal physiology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 155\n",
      "✅ Extracted terms: ['Abnormality of kidney morphology']\n",
      "🌐 [Abnormality of kidney morphology] API Status: 404\n",
      "❌ Failed for term: Abnormality of kidney morphology\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of kidney morphology', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the kidney']\n",
      "🌐 [Abnormality of the kidney] API Status: 200\n",
      "✅ Results for Abnormality of the kidney: [{'code': 'HP:0000077', 'term': 'Abnormality of the kidney', 'description': 'An abnormality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the kidney', 'candidates': [{'code': 'HP:0000077', 'term': 'Abnormality of the kidney', 'description': 'An abnormality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the kidney': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000077\",\n",
      "    \"matched_term\": \"Abnormality of the kidney\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Kidney structure issue (size/missing/ectopia)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the kidney'], 'umls_mappings': [{'original': 'Abnormality of the kidney', 'candidates': [{'code': 'HP:0000077', 'term': 'Abnormality of the kidney', 'description': 'An abnormality of the kidney. [https://orcid.org/0000-0002-0736-9199]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of kidney morphology', 'Abnormality of the kidney'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the kidney', 'ranked_candidates': [{'code': 'HP:0000077', 'term': 'Abnormality of the kidney', 'description': 'An abnormality of the kidney. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the kidney': {\n",
      "  \"best_match_code\": \"HP:0000077\",\n",
      "  \"best_match_term\": \"Abnormality of the kidney\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 156\n",
      "✅ Extracted terms: ['Abnormality of the female genitalia']\n",
      "🌐 [Abnormality of the female genitalia] API Status: 200\n",
      "✅ Results for Abnormality of the female genitalia: [{'code': 'HP:0010460', 'term': 'Abnormality of the female genitalia', 'description': 'Abnormality of the female genital system. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the female genitalia', 'candidates': [{'code': 'HP:0010460', 'term': 'Abnormality of the female genitalia', 'description': 'Abnormality of the female genital system. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the female genitalia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010460\",\n",
      "    \"matched_term\": \"Abnormality of the female genitalia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Female sex organ disorder (labia/vagina/uterus/ovaries)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the female genitalia'], 'umls_mappings': [{'original': 'Abnormality of the female genitalia', 'candidates': [{'code': 'HP:0010460', 'term': 'Abnormality of the female genitalia', 'description': 'Abnormality of the female genital system. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the female genitalia', 'ranked_candidates': [{'code': 'HP:0010460', 'term': 'Abnormality of the female genitalia', 'description': 'Abnormality of the female genital system. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the female genitalia': {\n",
      "  \"best_match_code\": \"HP:0010460\",\n",
      "  \"best_match_term\": \"Abnormality of the female genitalia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 157\n",
      "✅ Extracted terms: ['Abnormality of reproductive system physiology']\n",
      "🌐 [Abnormality of reproductive system physiology] API Status: 200\n",
      "✅ Results for Abnormality of reproductive system physiology: [{'code': 'HP:0000080', 'term': 'Abnormality of reproductive system physiology', 'description': 'An abnormal functionality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of reproductive system physiology', 'candidates': [{'code': 'HP:0000080', 'term': 'Abnormality of reproductive system physiology', 'description': 'An abnormal functionality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of reproductive system physiology': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000080\",\n",
      "    \"matched_term\": \"Abnormality of reproductive system physiology\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Genitalia function (infertility/impotence/ovarian failure)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of reproductive system physiology'], 'umls_mappings': [{'original': 'Abnormality of reproductive system physiology', 'candidates': [{'code': 'HP:0000080', 'term': 'Abnormality of reproductive system physiology', 'description': 'An abnormal functionality of the genital system. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of reproductive system physiology', 'ranked_candidates': [{'code': 'HP:0000080', 'term': 'Abnormality of reproductive system physiology', 'description': 'An abnormal functionality of the genital system. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of reproductive system physiology': {\n",
      "  \"best_match_code\": \"HP:0000080\",\n",
      "  \"best_match_term\": \"Abnormality of reproductive system physiology\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 158\n",
      "✅ Extracted terms: ['Abnormality of the male genitalia']\n",
      "🌐 [Abnormality of the male genitalia] API Status: 200\n",
      "✅ Results for Abnormality of the male genitalia: [{'code': 'HP:0010461', 'term': 'Abnormality of the male genitalia', 'description': 'Abnormality of the male genital system. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the male genitalia', 'candidates': [{'code': 'HP:0010461', 'term': 'Abnormality of the male genitalia', 'description': 'Abnormality of the male genital system. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the male genitalia': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0010461\",\n",
      "    \"matched_term\": \"Abnormality of the male genitalia\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Male sex organ disorder (penis/scrotum/testes/prostate)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the male genitalia'], 'umls_mappings': [{'original': 'Abnormality of the male genitalia', 'candidates': [{'code': 'HP:0010461', 'term': 'Abnormality of the male genitalia', 'description': 'Abnormality of the male genital system. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the male genitalia', 'ranked_candidates': [{'code': 'HP:0010461', 'term': 'Abnormality of the male genitalia', 'description': 'Abnormality of the male genital system. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the male genitalia': {\n",
      "  \"best_match_code\": \"HP:0010461\",\n",
      "  \"best_match_term\": \"Abnormality of the male genitalia\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 159\n",
      "✅ Extracted terms: ['Abnormality of the urethra']\n",
      "🌐 [Abnormality of the urethra] API Status: 200\n",
      "✅ Results for Abnormality of the urethra: [{'code': 'HP:0000795', 'term': 'Abnormality of the urethra', 'description': 'An abnormality of the urethra, i.e., of the tube which connects the urinary bladder to the outside of the body. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the urethra', 'candidates': [{'code': 'HP:0000795', 'term': 'Abnormality of the urethra', 'description': 'An abnormality of the urethra, i.e., of the tube which connects the urinary bladder to the outside of the body. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the urethra': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000795\",\n",
      "    \"matched_term\": \"Abnormality of the urethra\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Urethra issue (formation/blockage/hypospadias)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the urethra'], 'umls_mappings': [{'original': 'Abnormality of the urethra', 'candidates': [{'code': 'HP:0000795', 'term': 'Abnormality of the urethra', 'description': 'An abnormality of the urethra, i.e., of the tube which connects the urinary bladder to the outside of the body. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the urethra', 'ranked_candidates': [{'code': 'HP:0000795', 'term': 'Abnormality of the urethra', 'description': 'An abnormality of the urethra, i.e., of the tube which connects the urinary bladder to the outside of the body. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the urethra': {\"best_match_code\": \"HP:0000795\", \"best_match_term\": \"Abnormality of the urethra\", \"confidence\": \"90%\"}\n",
      "✅ Processed row 160\n",
      "✅ Extracted terms: ['Abnormality of the ureter']\n",
      "🌐 [Abnormality of the ureter] API Status: 200\n",
      "✅ Results for Abnormality of the ureter: [{'code': 'HP:0000069', 'term': 'Abnormality of the ureter', 'description': 'An abnormality of the ureter. The ureter is the duct by which urine passes from the kidney to the bladder. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the ureter', 'candidates': [{'code': 'HP:0000069', 'term': 'Abnormality of the ureter', 'description': 'An abnormality of the ureter. The ureter is the duct by which urine passes from the kidney to the bladder. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the ureter': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000069\",\n",
      "    \"matched_term\": \"Abnormality of the ureter\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Ureter issue (size/formation/blockage/missing)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the ureter'], 'umls_mappings': [{'original': 'Abnormality of the ureter', 'candidates': [{'code': 'HP:0000069', 'term': 'Abnormality of the ureter', 'description': 'An abnormality of the ureter. The ureter is the duct by which urine passes from the kidney to the bladder. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 1, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the ureter', 'ranked_candidates': [{'code': 'HP:0000069', 'term': 'Abnormality of the ureter', 'description': 'An abnormality of the ureter. The ureter is the duct by which urine passes from the kidney to the bladder. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the ureter': {\n",
      "  \"best_match_code\": \"HP:0000069\",\n",
      "  \"best_match_term\": \"Abnormality of the ureter\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 161\n",
      "✅ Extracted terms: ['Abnormality of urine']\n",
      "🌐 [Abnormality of urine] API Status: 200\n",
      "✅ Results for Abnormality of urine: [{'code': 'HP:0012401', 'term': 'Abnormality of urine alpha ketoglutarate concentration', 'description': 'A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011279', 'term': 'Abnormality of urine bicarbonate level', 'description': 'An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011280', 'term': 'Abnormality of urine Ca concentration', 'description': 'An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011281', 'term': 'Abnormality of urine catecholamine level', 'description': 'An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003110', 'term': 'Abnormality of urine homeostasis', 'description': 'An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012029', 'term': 'Abnormality of urine hormone level', 'description': 'An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011016', 'term': 'obsolete Abnormality of urine glucose concentration', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of urine', 'candidates': [{'code': 'HP:0012401', 'term': 'Abnormality of urine alpha ketoglutarate concentration', 'description': 'A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011279', 'term': 'Abnormality of urine bicarbonate level', 'description': 'An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011280', 'term': 'Abnormality of urine Ca concentration', 'description': 'An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011281', 'term': 'Abnormality of urine catecholamine level', 'description': 'An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003110', 'term': 'Abnormality of urine homeostasis', 'description': 'An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012029', 'term': 'Abnormality of urine hormone level', 'description': 'An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011016', 'term': 'obsolete Abnormality of urine glucose concentration', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of urine': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003110\",\n",
      "    \"matched_term\": \"Abnormality of urine homeostasis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012401\",\n",
      "    \"matched_term\": \"Abnormality of urine alpha ketoglutarate concentration\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011279\",\n",
      "    \"matched_term\": \"Abnormality of urine bicarbonate level\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011280\",\n",
      "    \"matched_term\": \"Abnormality of urine Ca concentration\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011281\",\n",
      "    \"matched_term\": \"Abnormality of urine catecholamine level\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012029\",\n",
      "    \"matched_term\": \"Abnormality of urine hormone level\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011016\",\n",
      "    \"matched_term\": \"obsolete Abnormality of urine glucose concentration\",\n",
      "    \"confidence\": \"60%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Urine issues (hematuria/proteinuria/color/odor)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of urine'], 'umls_mappings': [{'original': 'Abnormality of urine', 'candidates': [{'code': 'HP:0012401', 'term': 'Abnormality of urine alpha ketoglutarate concentration', 'description': 'A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011279', 'term': 'Abnormality of urine bicarbonate level', 'description': 'An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011280', 'term': 'Abnormality of urine Ca concentration', 'description': 'An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011281', 'term': 'Abnormality of urine catecholamine level', 'description': 'An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003110', 'term': 'Abnormality of urine homeostasis', 'description': 'An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0012029', 'term': 'Abnormality of urine hormone level', 'description': 'An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0011016', 'term': 'obsolete Abnormality of urine glucose concentration', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of urine', 'ranked_candidates': [{'code': 'HP:0003110', 'term': 'Abnormality of urine homeostasis', 'description': 'An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0012401', 'term': 'Abnormality of urine alpha ketoglutarate concentration', 'description': 'A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0011279', 'term': 'Abnormality of urine bicarbonate level', 'description': 'An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0011280', 'term': 'Abnormality of urine Ca concentration', 'description': 'An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0011281', 'term': 'Abnormality of urine catecholamine level', 'description': 'An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0012029', 'term': 'Abnormality of urine hormone level', 'description': 'An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.8}, {'code': 'HP:0011016', 'term': 'obsolete Abnormality of urine glucose concentration', 'description': None, 'confidence': 0.6}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of urine': {\n",
      "  \"best_match_code\": \"HP:0003110\",\n",
      "  \"best_match_term\": \"Abnormality of urine homeostasis\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Urine issues (hematuria/proteinuria/color/odor)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of urine\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of urine\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0012401\",\n",
      "          \"term\": \"Abnormality of urine alpha ketoglutarate concentration\",\n",
      "          \"description\": \"A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011279\",\n",
      "          \"term\": \"Abnormality of urine bicarbonate level\",\n",
      "          \"description\": \"An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011280\",\n",
      "          \"term\": \"Abnormality of urine Ca concentration\",\n",
      "          \"description\": \"An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011281\",\n",
      "          \"term\": \"Abnormality of urine catecholamine level\",\n",
      "          \"description\": \"An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0003110\",\n",
      "          \"term\": \"Abnormality of urine homeostasis\",\n",
      "          \"description\": \"An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012029\",\n",
      "          \"term\": \"Abnormality of urine hormone level\",\n",
      "          \"description\": \"An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011016\",\n",
      "          \"term\": \"obsolete Abnormality of urine glucose concentration\",\n",
      "          \"description\": null\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of urine\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0003110\",\n",
      "          \"term\": \"Abnormality of urine homeostasis\",\n",
      "          \"description\": \"An abnormality of the composition of urine or the levels of its components. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012401\",\n",
      "          \"term\": \"Abnormality of urine alpha ketoglutarate concentration\",\n",
      "          \"description\": \"A deviation from normal of the concentration of 2-oxoglutaric acid in the urine. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011279\",\n",
      "          \"term\": \"Abnormality of urine bicarbonate level\",\n",
      "          \"description\": \"An abnormal amount of hydrogencarbonate in the urine. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011280\",\n",
      "          \"term\": \"Abnormality of urine Ca concentration\",\n",
      "          \"description\": \"An abnormality of calcium concentration in the urine. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011281\",\n",
      "          \"term\": \"Abnormality of urine catecholamine level\",\n",
      "          \"description\": \"An abnormal amount of urinary catecholamine concentration. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0012029\",\n",
      "          \"term\": \"Abnormality of urine hormone level\",\n",
      "          \"description\": \"An abnormal concentration of a hormone in the urine. [https://orcid.org/0000-0002-0736-9199]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0011016\",\n",
      "          \"term\": \"obsolete Abnormality of urine glucose concentration\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.6\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of urine\",\n",
      "      \"best_match_code\": \"HP:0003110\",\n",
      "      \"best_match_term\": \"Abnormality of urine homeostasis\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4025655\n",
      "✅ Processed row 162\n",
      "✅ Extracted terms: ['Autoimmune disease']\n",
      "🌐 [Autoimmune disease] API Status: 200\n",
      "✅ Results for Autoimmune disease: [{'code': 'HP:0002960', 'term': 'Autoimmune disease', 'description': 'Disorders that are characterized by the production of antibodies that react with host tissues or immune effector cells that are autoreactive to endogenous peptides.'}, {'code': 'HP:0011437', 'term': 'Maternal autoimmune disease', 'description': 'A medical history of a fetus or child born to a mother with an autoimmune disease. [https://orcid.org/0000-0002-6410-0882]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Autoimmune disease', 'candidates': [{'code': 'HP:0002960', 'term': 'Autoimmune disease', 'description': 'Disorders that are characterized by the production of antibodies that react with host tissues or immune effector cells that are autoreactive to endogenous peptides.'}, {'code': 'HP:0011437', 'term': 'Maternal autoimmune disease', 'description': 'A medical history of a fetus or child born to a mother with an autoimmune disease. [https://orcid.org/0000-0002-6410-0882]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Autoimmune disease': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002960\",\n",
      "    \"matched_term\": \"Autoimmune disease\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011437\",\n",
      "    \"matched_term\": \"Maternal autoimmune disease\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Autoimmune disorder (e.g., Hashimoto, lupus, ITP)', 'field_type': 'radio', 'extracted_terms': ['Autoimmune disease'], 'umls_mappings': [{'original': 'Autoimmune disease', 'candidates': [{'code': 'HP:0002960', 'term': 'Autoimmune disease', 'description': 'Disorders that are characterized by the production of antibodies that react with host tissues or immune effector cells that are autoreactive to endogenous peptides.'}, {'code': 'HP:0011437', 'term': 'Maternal autoimmune disease', 'description': 'A medical history of a fetus or child born to a mother with an autoimmune disease. [https://orcid.org/0000-0002-6410-0882]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Autoimmune disease', 'ranked_candidates': [{'code': 'HP:0002960', 'term': 'Autoimmune disease', 'description': 'Disorders that are characterized by the production of antibodies that react with host tissues or immune effector cells that are autoreactive to endogenous peptides.', 'confidence': 1.0}, {'code': 'HP:0011437', 'term': 'Maternal autoimmune disease', 'description': 'A medical history of a fetus or child born to a mother with an autoimmune disease. [https://orcid.org/0000-0002-6410-0882]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Autoimmune disease': {\n",
      "  \"best_match_code\": \"HP:0002960\",\n",
      "  \"best_match_term\": \"Autoimmune disease\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 163\n",
      "✅ Extracted terms: ['Immunodeficiency']\n",
      "🌐 [Immunodeficiency] API Status: 200\n",
      "✅ Results for Immunodeficiency: [{'code': 'HP:6000345', 'term': 'Anti-human immunodeficiency virus antibody positivity', 'description': 'The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []'}, {'code': 'HP:0005374', 'term': 'Cellular immunodeficiency', 'description': 'An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]'}, {'code': 'HP:0005387', 'term': 'Combined immunodeficiency', 'description': 'A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]'}, {'code': 'HP:0005363', 'term': 'Humoral immunodeficiency', 'description': 'A general term referring to a defect in immunity resulting from impaired antibody production. []'}, {'code': 'HP:0002721', 'term': 'Immunodeficiency', 'description': 'Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Immunodeficiency', 'candidates': [{'code': 'HP:6000345', 'term': 'Anti-human immunodeficiency virus antibody positivity', 'description': 'The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []'}, {'code': 'HP:0005374', 'term': 'Cellular immunodeficiency', 'description': 'An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]'}, {'code': 'HP:0005387', 'term': 'Combined immunodeficiency', 'description': 'A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]'}, {'code': 'HP:0005363', 'term': 'Humoral immunodeficiency', 'description': 'A general term referring to a defect in immunity resulting from impaired antibody production. []'}, {'code': 'HP:0002721', 'term': 'Immunodeficiency', 'description': 'Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Immunodeficiency': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002721\",\n",
      "    \"matched_term\": \"Immunodeficiency\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005374\",\n",
      "    \"matched_term\": \"Cellular immunodeficiency\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005387\",\n",
      "    \"matched_term\": \"Combined immunodeficiency\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005363\",\n",
      "    \"matched_term\": \"Humoral immunodeficiency\",\n",
      "    \"confidence\": \"80%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:6000345\",\n",
      "    \"matched_term\": \"Anti-human immunodeficiency virus antibody positivity\",\n",
      "    \"confidence\": \"60%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Immunodeficiency (T-cell/combined/other)', 'field_type': 'radio', 'extracted_terms': ['Immunodeficiency'], 'umls_mappings': [{'original': 'Immunodeficiency', 'candidates': [{'code': 'HP:6000345', 'term': 'Anti-human immunodeficiency virus antibody positivity', 'description': 'The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []'}, {'code': 'HP:0005374', 'term': 'Cellular immunodeficiency', 'description': 'An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]'}, {'code': 'HP:0005387', 'term': 'Combined immunodeficiency', 'description': 'A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]'}, {'code': 'HP:0005363', 'term': 'Humoral immunodeficiency', 'description': 'A general term referring to a defect in immunity resulting from impaired antibody production. []'}, {'code': 'HP:0002721', 'term': 'Immunodeficiency', 'description': 'Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Immunodeficiency', 'ranked_candidates': [{'code': 'HP:0002721', 'term': 'Immunodeficiency', 'description': 'Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.', 'confidence': 1.0}, {'code': 'HP:0005374', 'term': 'Cellular immunodeficiency', 'description': 'An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]', 'confidence': 0.8}, {'code': 'HP:0005387', 'term': 'Combined immunodeficiency', 'description': 'A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]', 'confidence': 0.8}, {'code': 'HP:0005363', 'term': 'Humoral immunodeficiency', 'description': 'A general term referring to a defect in immunity resulting from impaired antibody production. []', 'confidence': 0.8}, {'code': 'HP:6000345', 'term': 'Anti-human immunodeficiency virus antibody positivity', 'description': 'The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []', 'confidence': 0.6}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Immunodeficiency': {\n",
      "  \"best_match_code\": \"HP:0002721\",\n",
      "  \"best_match_term\": \"Immunodeficiency\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Immunodeficiency (T-cell/combined/other)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Immunodeficiency\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Immunodeficiency\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:6000345\",\n",
      "          \"term\": \"Anti-human immunodeficiency virus antibody positivity\",\n",
      "          \"description\": \"The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005374\",\n",
      "          \"term\": \"Cellular immunodeficiency\",\n",
      "          \"description\": \"An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005387\",\n",
      "          \"term\": \"Combined immunodeficiency\",\n",
      "          \"description\": \"A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005363\",\n",
      "          \"term\": \"Humoral immunodeficiency\",\n",
      "          \"description\": \"A general term referring to a defect in immunity resulting from impaired antibody production. []\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0002721\",\n",
      "          \"term\": \"Immunodeficiency\",\n",
      "          \"description\": \"Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Immunodeficiency\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0002721\",\n",
      "          \"term\": \"Immunodeficiency\",\n",
      "          \"description\": \"Syndromes in which there is a deficiency or defect in the mechanisms of immunity, either cellular or humoral.\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005374\",\n",
      "          \"term\": \"Cellular immunodeficiency\",\n",
      "          \"description\": \"An immunodeficiency characterized by defective cell-mediated immunity or humoral immunity. [http://www.dictionary.com/browse/cellular-immunodeficiency]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005387\",\n",
      "          \"term\": \"Combined immunodeficiency\",\n",
      "          \"description\": \"A group of phenotypically heterogeneous genetic disorders characterized by profound deficiencies of T- and B-cell function, which predispose the patients to both infectious and noninfectious complications. [PMID:23321211]\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005363\",\n",
      "          \"term\": \"Humoral immunodeficiency\",\n",
      "          \"description\": \"A general term referring to a defect in immunity resulting from impaired antibody production. []\",\n",
      "          \"confidence\": 0.8\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:6000345\",\n",
      "          \"term\": \"Anti-human immunodeficiency virus antibody positivity\",\n",
      "          \"description\": \"The presence of antibodies in the blood circulation that react against a component of the human immunodeficiency virus (HIV). []\",\n",
      "          \"confidence\": 0.6\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Immunodeficiency\",\n",
      "      \"best_match_code\": \"HP:0002721\",\n",
      "      \"best_match_term\": \"Immunodeficiency\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0021051\n",
      "🧩 ancestor_cuis ['C2720507', 'C1532237', 'C0012634', 'C0037088']\n",
      "🧩 candidate_details [{'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C1532237', 'name': 'Disorder of immune function'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Immunodeficiency (T-cell/combined/other)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Immunodeficiency\"\n",
      "  \"best_match_code\": \"HP:0002721\",\n",
      "  \"best_match_term\": \"Immunodeficiency\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C1532237 (Disorder of immune function)\n",
      "- C0012634 (Disease)\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 554, 'total_tokens': 555, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeXdbetfCVxtgJxpSonNQr1dYo3r', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--836f1435-bc40-4e53-b182-0ac5a16e3416-0' usage_metadata={'input_tokens': 554, 'output_tokens': 1, 'total_tokens': 555, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 164\n",
      "✅ Extracted terms: ['Increased inflammatory response']\n",
      "🌐 [Increased inflammatory response] API Status: 200\n",
      "✅ Results for Increased inflammatory response: [{'code': 'HP:0012649', 'term': 'Increased inflammatory response', 'description': 'A abnormal increase in the inflammatory response to injury or infection. [https://orcid.org/0000-0001-9114-8737]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Increased inflammatory response', 'candidates': [{'code': 'HP:0012649', 'term': 'Increased inflammatory response', 'description': 'A abnormal increase in the inflammatory response to injury or infection. [https://orcid.org/0000-0001-9114-8737]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Increased inflammatory response': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0012649\",\n",
      "    \"matched_term\": \"Increased inflammatory response\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Increased inflammatory response', 'field_type': 'radio', 'extracted_terms': ['Increased inflammatory response'], 'umls_mappings': [{'original': 'Increased inflammatory response', 'candidates': [{'code': 'HP:0012649', 'term': 'Increased inflammatory response', 'description': 'A abnormal increase in the inflammatory response to injury or infection. [https://orcid.org/0000-0001-9114-8737]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Increased inflammatory response', 'ranked_candidates': [{'code': 'HP:0012649', 'term': 'Increased inflammatory response', 'description': 'A abnormal increase in the inflammatory response to injury or infection. [https://orcid.org/0000-0001-9114-8737]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Increased inflammatory response': {\n",
      "  \"best_match_code\": \"HP:0012649\",\n",
      "  \"best_match_term\": \"Increased inflammatory response\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 165\n",
      "✅ Extracted terms: ['Recurrent infections']\n",
      "🌐 [Recurrent infections] API Status: 200\n",
      "✅ Results for Recurrent infections: [{'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0040268', 'term': 'obsolete Recurrent infections of the middle ear', 'description': None}, {'code': 'HP:0002719', 'term': 'Recurrent infections', 'description': 'Increased susceptibility to infections. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-5316-1399]'}, {'code': 'HP:0004891', 'term': 'Recurrent infections due to aspiration', 'description': 'Increased susceptibility to infections due to aspiration, as manifested by recurrent episodes of infections due to aspiration. []'}, {'code': 'HP:0006538', 'term': 'Recurrent infections in bronchi and lungs', 'description': 'An increased susceptibility to bronchopulmonary infections as manifested by a history of recurrent bronchopulmonary infections. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0005437', 'term': 'Recurrent infections in infancy and early childhood', 'description': 'Recurrent infections at an early age with improvement in later childhood. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Recurrent infections', 'candidates': [{'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0040268', 'term': 'obsolete Recurrent infections of the middle ear', 'description': None}, {'code': 'HP:0002719', 'term': 'Recurrent infections', 'description': 'Increased susceptibility to infections. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-5316-1399]'}, {'code': 'HP:0004891', 'term': 'Recurrent infections due to aspiration', 'description': 'Increased susceptibility to infections due to aspiration, as manifested by recurrent episodes of infections due to aspiration. []'}, {'code': 'HP:0006538', 'term': 'Recurrent infections in bronchi and lungs', 'description': 'An increased susceptibility to bronchopulmonary infections as manifested by a history of recurrent bronchopulmonary infections. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0005437', 'term': 'Recurrent infections in infancy and early childhood', 'description': 'Recurrent infections at an early age with improvement in later childhood. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Recurrent infections': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0002719\",\n",
      "    \"matched_term\": \"Recurrent infections\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005437\",\n",
      "    \"matched_term\": \"Recurrent infections in infancy and early childhood\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006538\",\n",
      "    \"matched_term\": \"Recurrent infections in bronchi and lungs\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004891\",\n",
      "    \"matched_term\": \"Recurrent infections due to aspiration\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0008866\",\n",
      "    \"matched_term\": \"Failure to thrive secondary to recurrent infections\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0040268\",\n",
      "    \"matched_term\": \"obsolete Recurrent infections of the middle ear\",\n",
      "    \"confidence\": \"40%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Recurrent infections', 'field_type': 'radio', 'extracted_terms': ['Recurrent infections'], 'umls_mappings': [{'original': 'Recurrent infections', 'candidates': [{'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]'}, {'code': 'HP:0040268', 'term': 'obsolete Recurrent infections of the middle ear', 'description': None}, {'code': 'HP:0002719', 'term': 'Recurrent infections', 'description': 'Increased susceptibility to infections. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-5316-1399]'}, {'code': 'HP:0004891', 'term': 'Recurrent infections due to aspiration', 'description': 'Increased susceptibility to infections due to aspiration, as manifested by recurrent episodes of infections due to aspiration. []'}, {'code': 'HP:0006538', 'term': 'Recurrent infections in bronchi and lungs', 'description': 'An increased susceptibility to bronchopulmonary infections as manifested by a history of recurrent bronchopulmonary infections. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0005437', 'term': 'Recurrent infections in infancy and early childhood', 'description': 'Recurrent infections at an early age with improvement in later childhood. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 5, 'retries': 0, 'ranked_mappings': [{'original': 'Recurrent infections', 'ranked_candidates': [{'code': 'HP:0002719', 'term': 'Recurrent infections', 'description': 'Increased susceptibility to infections. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-5316-1399]', 'confidence': 1.0}, {'code': 'HP:0005437', 'term': 'Recurrent infections in infancy and early childhood', 'description': 'Recurrent infections at an early age with improvement in later childhood. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0004891', 'term': 'Recurrent infections due to aspiration', 'description': 'Increased susceptibility to infections due to aspiration, as manifested by recurrent episodes of infections due to aspiration. []', 'confidence': 0.6}, {'code': 'HP:0006538', 'term': 'Recurrent infections in bronchi and lungs', 'description': 'An increased susceptibility to bronchopulmonary infections as manifested by a history of recurrent bronchopulmonary infections. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.6}, {'code': 'HP:0008866', 'term': 'Failure to thrive secondary to recurrent infections', 'description': 'Insufficient weight gain or inappropriate weight loss for a child, that is attributed to an endogenous recurrent infections. [https://en.wikipedia.org/wiki/Failure_to_thrive]', 'confidence': 0.5}, {'code': 'HP:0040268', 'term': 'obsolete Recurrent infections of the middle ear', 'description': None, 'confidence': 0.4}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Recurrent infections': {\n",
      "  \"best_match_code\": \"HP:0002719\",\n",
      "  \"best_match_term\": \"Recurrent infections\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 166\n",
      "✅ Extracted terms: ['Rheumatoid arthritis']\n",
      "🌐 [Rheumatoid arthritis] API Status: 200\n",
      "✅ Results for Rheumatoid arthritis: [{'code': 'HP:0005681', 'term': 'Juvenile rheumatoid arthritis', 'description': \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\"}, {'code': 'HP:0001370', 'term': 'Rheumatoid arthritis', 'description': 'A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Rheumatoid arthritis', 'candidates': [{'code': 'HP:0005681', 'term': 'Juvenile rheumatoid arthritis', 'description': \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\"}, {'code': 'HP:0001370', 'term': 'Rheumatoid arthritis', 'description': 'A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Rheumatoid arthritis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001370\",\n",
      "    \"matched_term\": \"Rheumatoid arthritis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005681\",\n",
      "    \"matched_term\": \"Juvenile rheumatoid arthritis\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Rheumatoid arthritis (juvenile/adult)', 'field_type': 'radio', 'extracted_terms': ['Rheumatoid arthritis'], 'umls_mappings': [{'original': 'Rheumatoid arthritis', 'candidates': [{'code': 'HP:0005681', 'term': 'Juvenile rheumatoid arthritis', 'description': \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\"}, {'code': 'HP:0001370', 'term': 'Rheumatoid arthritis', 'description': 'A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Rheumatoid arthritis', 'ranked_candidates': [{'code': 'HP:0001370', 'term': 'Rheumatoid arthritis', 'description': 'A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.', 'confidence': 1.0}, {'code': 'HP:0005681', 'term': 'Juvenile rheumatoid arthritis', 'description': \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\", 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Rheumatoid arthritis': {\n",
      "  \"best_match_code\": \"HP:0001370\",\n",
      "  \"best_match_term\": \"Rheumatoid arthritis\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Rheumatoid arthritis (juvenile/adult)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Rheumatoid arthritis\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Rheumatoid arthritis\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0005681\",\n",
      "          \"term\": \"Juvenile rheumatoid arthritis\",\n",
      "          \"description\": \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\"\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0001370\",\n",
      "          \"term\": \"Rheumatoid arthritis\",\n",
      "          \"description\": \"A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Rheumatoid arthritis\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0001370\",\n",
      "          \"term\": \"Rheumatoid arthritis\",\n",
      "          \"description\": \"A chronic systemic disease, primarily of the joints, marked by inflammatory changes in the synovial membranes and articular structures, widespread fibrinoid degeneration of the collagen fibers in mesenchymal tissues, and by atrophy and rarefaction of bony structures. Etiology is unknown, but autoimmune mechanisms have been implicated.\",\n",
      "          \"confidence\": 1.0\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0005681\",\n",
      "          \"term\": \"Juvenile rheumatoid arthritis\",\n",
      "          \"description\": \"rheumatoid arthritis of children occurring in three major subtypes defined by the symptoms present during the first six months following onset: systemic onset (Still's Disease, Juvenile Onset), polyarticular onset, and pauciarticular onset; adult onset cases of Still's disease (Still's Disease, adult onset) are also known; only one subtype of juvenile rheumatoid arthritis (polyarticular onset, rheumatoid factor positive) clinically resembles adult rheumatoid arthritis and is considered its childhood equivalent.\",\n",
      "          \"confidence\": 0.7\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Rheumatoid arthritis\",\n",
      "      \"best_match_code\": \"HP:0001370\",\n",
      "      \"best_match_term\": \"Rheumatoid arthritis\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C0003873\n",
      "🧩 ancestor_cuis ['C0012634', 'C1285159', 'C1532237', 'C1285332', 'C1285333', 'C0427210', 'C0026857', 'C0426779', 'C1285339', 'C0004364', 'C5191746', 'C1290884', 'C1285331', 'C0263661', 'C0574941', 'C2720507', 'C0037088', 'C0022408', 'C0003864']\n",
      "🧩 candidate_details [{'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C1532237', 'name': 'Disorder of immune function'}, {'cui': 'C1285332', 'name': 'Inflammation of specific body structures or tissue'}, {'cui': 'C1285333', 'name': 'Inflammation of specific body systems'}, {'cui': 'C0427210', 'name': 'Joint finding'}, {'cui': 'C0026857', 'name': 'Musculoskeletal disease'}, {'cui': 'C0426779', 'name': 'Musculoskeletal system finding'}, {'cui': 'C1285339', 'name': 'Inflammatory disorder of musculoskeletal system'}, {'cui': 'C0004364', 'name': 'Autoimmune disease'}, {'cui': 'C5191746', 'name': 'Disorder of joint region'}, {'cui': 'C1290884', 'name': 'Inflammatory disorder'}, {'cui': 'C1285331', 'name': 'Inflammation of specific body organs'}, {'cui': 'C0263661', 'name': 'Disorder of skeletal system'}, {'cui': 'C0574941', 'name': 'Inflamed joint'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0022408', 'name': 'Arthropathy'}, {'cui': 'C0003864', 'name': 'Arthritis'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Rheumatoid arthritis (juvenile/adult)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Rheumatoid arthritis\"\n",
      "  \"best_match_code\": \"HP:0001370\",\n",
      "  \"best_match_term\": \"Rheumatoid arthritis\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0012634 (Disease)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C1532237 (Disorder of immune function)\n",
      "- C1285332 (Inflammation of specific body structures or tissue)\n",
      "- C1285333 (Inflammation of specific body systems)\n",
      "- C0427210 (Joint finding)\n",
      "- C0026857 (Musculoskeletal disease)\n",
      "- C0426779 (Musculoskeletal system finding)\n",
      "- C1285339 (Inflammatory disorder of musculoskeletal system)\n",
      "- C0004364 (Autoimmune disease)\n",
      "- C5191746 (Disorder of joint region)\n",
      "- C1290884 (Inflammatory disorder)\n",
      "- C1285331 (Inflammation of specific body organs)\n",
      "- C0263661 (Disorder of skeletal system)\n",
      "- C0574941 (Inflamed joint)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0022408 (Arthropathy)\n",
      "- C0003864 (Arthritis)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 732, 'total_tokens': 733, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeYJDluuIkEFNIRuTQ4FpgEaLjE9', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--68eb0490-75cf-4259-abbd-115124cd1a95-0' usage_metadata={'input_tokens': 732, 'output_tokens': 1, 'total_tokens': 733, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 167\n",
      "✅ Extracted terms: ['Thrombosis']\n",
      "🌐 [Thrombosis] API Status: 200\n",
      "✅ Results for Thrombosis: [{'code': 'HP:0001977', 'term': 'Abnormal thrombosis', 'description': 'Venous or arterial thrombosis (formation of blood clots) of spontaneous nature and which cannot be fully explained by acquired risk (e.g. atherosclerosis). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0004420', 'term': 'Arterial thrombosis', 'description': 'Formation of a blood clot in the lumen of an artery.'}, {'code': 'HP:0005305', 'term': 'Cerebral thrombosis', 'description': 'Formation of a blood clot (thrombus) inside a cerebral vein, causing the obstruction of blood flow. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0033724', 'term': 'Cerebral venous sinus thrombosis', 'description': 'An intracranial thrombosis of the venous sinuses. These typically present with headache, seizures or venous stroke secondary to raised cerebral venous pressure. Cerebral venous sinus thromboses usually affect larger areas of brain parenchyma than those affected by cerebral vein thromboses. [https://orcid.org/0000-0002-1735-8178, PMID:29923367]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Thrombosis', 'candidates': [{'code': 'HP:0001977', 'term': 'Abnormal thrombosis', 'description': 'Venous or arterial thrombosis (formation of blood clots) of spontaneous nature and which cannot be fully explained by acquired risk (e.g. atherosclerosis). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0004420', 'term': 'Arterial thrombosis', 'description': 'Formation of a blood clot in the lumen of an artery.'}, {'code': 'HP:0005305', 'term': 'Cerebral thrombosis', 'description': 'Formation of a blood clot (thrombus) inside a cerebral vein, causing the obstruction of blood flow. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0033724', 'term': 'Cerebral venous sinus thrombosis', 'description': 'An intracranial thrombosis of the venous sinuses. These typically present with headache, seizures or venous stroke secondary to raised cerebral venous pressure. Cerebral venous sinus thromboses usually affect larger areas of brain parenchyma than those affected by cerebral vein thromboses. [https://orcid.org/0000-0002-1735-8178, PMID:29923367]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Thrombosis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001977\",\n",
      "    \"matched_term\": \"Abnormal thrombosis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004420\",\n",
      "    \"matched_term\": \"Arterial thrombosis\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005305\",\n",
      "    \"matched_term\": \"Cerebral thrombosis\",\n",
      "    \"confidence\": \"75%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0033724\",\n",
      "    \"matched_term\": \"Cerebral venous sinus thrombosis\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Blood clot (veins/arteries; thrombosis)', 'field_type': 'radio', 'extracted_terms': ['Thrombosis'], 'umls_mappings': [{'original': 'Thrombosis', 'candidates': [{'code': 'HP:0001977', 'term': 'Abnormal thrombosis', 'description': 'Venous or arterial thrombosis (formation of blood clots) of spontaneous nature and which cannot be fully explained by acquired risk (e.g. atherosclerosis). [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0004420', 'term': 'Arterial thrombosis', 'description': 'Formation of a blood clot in the lumen of an artery.'}, {'code': 'HP:0005305', 'term': 'Cerebral thrombosis', 'description': 'Formation of a blood clot (thrombus) inside a cerebral vein, causing the obstruction of blood flow. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0033724', 'term': 'Cerebral venous sinus thrombosis', 'description': 'An intracranial thrombosis of the venous sinuses. These typically present with headache, seizures or venous stroke secondary to raised cerebral venous pressure. Cerebral venous sinus thromboses usually affect larger areas of brain parenchyma than those affected by cerebral vein thromboses. [https://orcid.org/0000-0002-1735-8178, PMID:29923367]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Thrombosis', 'ranked_candidates': [{'code': 'HP:0001977', 'term': 'Abnormal thrombosis', 'description': 'Venous or arterial thrombosis (formation of blood clots) of spontaneous nature and which cannot be fully explained by acquired risk (e.g. atherosclerosis). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}, {'code': 'HP:0004420', 'term': 'Arterial thrombosis', 'description': 'Formation of a blood clot in the lumen of an artery.', 'confidence': 0.75}, {'code': 'HP:0005305', 'term': 'Cerebral thrombosis', 'description': 'Formation of a blood clot (thrombus) inside a cerebral vein, causing the obstruction of blood flow. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.75}, {'code': 'HP:0033724', 'term': 'Cerebral venous sinus thrombosis', 'description': 'An intracranial thrombosis of the venous sinuses. These typically present with headache, seizures or venous stroke secondary to raised cerebral venous pressure. Cerebral venous sinus thromboses usually affect larger areas of brain parenchyma than those affected by cerebral vein thromboses. [https://orcid.org/0000-0002-1735-8178, PMID:29923367]', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Thrombosis': {\n",
      "  \"best_match_code\": \"HP:0001977\",\n",
      "  \"best_match_term\": \"Abnormal thrombosis\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 168\n",
      "✅ Extracted terms: ['Abnormality of blood coagulation']\n",
      "🌐 [Abnormality of blood coagulation] API Status: 404\n",
      "❌ Failed for term: Abnormality of blood coagulation\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of blood coagulation', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of hemostasis']\n",
      "🌐 [Abnormality of hemostasis] API Status: 404\n",
      "❌ Failed for term: Abnormality of hemostasis\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of hemostasis', 'candidates': []}]\n",
      "✅ Revised terms: ['Coagulopathy']\n",
      "🌐 [Coagulopathy] API Status: 200\n",
      "✅ Results for Coagulopathy: [{'code': 'HP:0005520', 'term': 'Chronic consumption coagulopathy', 'description': 'A chronic form of disseminated intravascular coagulation in which a persistent weak or intermittent activating stimulus is present and destruction and production of coagulation factors and platelets are balanced. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003256', 'term': 'Coagulopathy', 'description': 'Hemorrhagic and thrombotic disorders that occur as a consequence of abnormalities in blood coagulation due to a variety of factors such as COAGULATION PROTEIN DISORDERS; BLOOD PLATELET DISORDERS; BLOOD PROTEIN DISORDERS or nutritional conditions.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Coagulopathy', 'candidates': [{'code': 'HP:0005520', 'term': 'Chronic consumption coagulopathy', 'description': 'A chronic form of disseminated intravascular coagulation in which a persistent weak or intermittent activating stimulus is present and destruction and production of coagulation factors and platelets are balanced. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003256', 'term': 'Coagulopathy', 'description': 'Hemorrhagic and thrombotic disorders that occur as a consequence of abnormalities in blood coagulation due to a variety of factors such as COAGULATION PROTEIN DISORDERS; BLOOD PLATELET DISORDERS; BLOOD PROTEIN DISORDERS or nutritional conditions.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Coagulopathy': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003256\",\n",
      "    \"matched_term\": \"Coagulopathy\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0005520\",\n",
      "    \"matched_term\": \"Chronic consumption coagulopathy\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Blood clotting disorder (too fast/too slow)', 'field_type': 'radio', 'extracted_terms': ['Coagulopathy'], 'umls_mappings': [{'original': 'Coagulopathy', 'candidates': [{'code': 'HP:0005520', 'term': 'Chronic consumption coagulopathy', 'description': 'A chronic form of disseminated intravascular coagulation in which a persistent weak or intermittent activating stimulus is present and destruction and production of coagulation factors and platelets are balanced. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0003256', 'term': 'Coagulopathy', 'description': 'Hemorrhagic and thrombotic disorders that occur as a consequence of abnormalities in blood coagulation due to a variety of factors such as COAGULATION PROTEIN DISORDERS; BLOOD PLATELET DISORDERS; BLOOD PROTEIN DISORDERS or nutritional conditions.'}]}], 'retry_count': 2, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Coagulopathy', 'Abnormality of hemostasis', 'Abnormality of blood coagulation'], 'retries': 0, 'ranked_mappings': [{'original': 'Coagulopathy', 'ranked_candidates': [{'code': 'HP:0003256', 'term': 'Coagulopathy', 'description': 'Hemorrhagic and thrombotic disorders that occur as a consequence of abnormalities in blood coagulation due to a variety of factors such as COAGULATION PROTEIN DISORDERS; BLOOD PLATELET DISORDERS; BLOOD PROTEIN DISORDERS or nutritional conditions.', 'confidence': 1.0}, {'code': 'HP:0005520', 'term': 'Chronic consumption coagulopathy', 'description': 'A chronic form of disseminated intravascular coagulation in which a persistent weak or intermittent activating stimulus is present and destruction and production of coagulation factors and platelets are balanced. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Coagulopathy': {\n",
      "  \"best_match_code\": \"HP:0003256\",\n",
      "  \"best_match_term\": \"Coagulopathy\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 169\n",
      "✅ Extracted terms: ['Spontaneous bleeding']\n",
      "🌐 [Spontaneous bleeding] API Status: 404\n",
      "❌ Failed for term: Spontaneous bleeding\n",
      "🧪 Final UMLS mappings: [{'original': 'Spontaneous bleeding', 'candidates': []}]\n",
      "✅ Revised terms: ['Bleeding diathesis']\n",
      "🌐 [Bleeding diathesis] API Status: 200\n",
      "✅ Results for Bleeding diathesis: [{'code': 'HP:0001892', 'term': 'Bleeding diathesis', 'description': \"Normally, if you get hurt, your body forms a blood clot to stop the bleeding. For blood to clot, your body needs cells called platelets and proteins known as clotting factors. If you have a bleeding disorder, you either do not have enough platelets or clotting factors or they don't work the way they should.  Bleeding disorders can be the result of other diseases, such as severe liver disease or a lack of vitamin K. They can also be inherited. Hemophilia is an inherited bleeding disorder. Bleeding disorders can also be a side effect of medicines such as blood thinners. Various blood tests can check for a bleeding disorder. You will also have a physical exam and history. Treatments depend on the cause. They may include medicines and transfusions of blood, platelets, or clotting factor.\"}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Bleeding diathesis', 'candidates': [{'code': 'HP:0001892', 'term': 'Bleeding diathesis', 'description': \"Normally, if you get hurt, your body forms a blood clot to stop the bleeding. For blood to clot, your body needs cells called platelets and proteins known as clotting factors. If you have a bleeding disorder, you either do not have enough platelets or clotting factors or they don't work the way they should.  Bleeding disorders can be the result of other diseases, such as severe liver disease or a lack of vitamin K. They can also be inherited. Hemophilia is an inherited bleeding disorder. Bleeding disorders can also be a side effect of medicines such as blood thinners. Various blood tests can check for a bleeding disorder. You will also have a physical exam and history. Treatments depend on the cause. They may include medicines and transfusions of blood, platelets, or clotting factor.\"}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Bleeding diathesis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001892\",\n",
      "    \"matched_term\": \"Bleeding diathesis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Easy bleeding (with little/no trauma)', 'field_type': 'radio', 'extracted_terms': ['Bleeding diathesis'], 'umls_mappings': [{'original': 'Bleeding diathesis', 'candidates': [{'code': 'HP:0001892', 'term': 'Bleeding diathesis', 'description': \"Normally, if you get hurt, your body forms a blood clot to stop the bleeding. For blood to clot, your body needs cells called platelets and proteins known as clotting factors. If you have a bleeding disorder, you either do not have enough platelets or clotting factors or they don't work the way they should.  Bleeding disorders can be the result of other diseases, such as severe liver disease or a lack of vitamin K. They can also be inherited. Hemophilia is an inherited bleeding disorder. Bleeding disorders can also be a side effect of medicines such as blood thinners. Various blood tests can check for a bleeding disorder. You will also have a physical exam and history. Treatments depend on the cause. They may include medicines and transfusions of blood, platelets, or clotting factor.\"}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Spontaneous bleeding', 'Bleeding diathesis'], 'retries': 0, 'ranked_mappings': [{'original': 'Bleeding diathesis', 'ranked_candidates': [{'code': 'HP:0001892', 'term': 'Bleeding diathesis', 'description': \"Normally, if you get hurt, your body forms a blood clot to stop the bleeding. For blood to clot, your body needs cells called platelets and proteins known as clotting factors. If you have a bleeding disorder, you either do not have enough platelets or clotting factors or they don't work the way they should.  Bleeding disorders can be the result of other diseases, such as severe liver disease or a lack of vitamin K. They can also be inherited. Hemophilia is an inherited bleeding disorder. Bleeding disorders can also be a side effect of medicines such as blood thinners. Various blood tests can check for a bleeding disorder. You will also have a physical exam and history. Treatments depend on the cause. They may include medicines and transfusions of blood, platelets, or clotting factor.\", 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Bleeding diathesis': {\n",
      "  \"best_match_code\": \"HP:0001892\",\n",
      "  \"best_match_term\": \"Bleeding diathesis\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 170\n",
      "✅ Extracted terms: ['Easy bruising']\n",
      "🌐 [Easy bruising] API Status: 200\n",
      "✅ Results for Easy bruising: [{'code': 'HP:0000978', 'term': 'Easy bruising', 'description': 'Appearance of skin bruises following perceived minimal contact or injury.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Easy bruising', 'candidates': [{'code': 'HP:0000978', 'term': 'Easy bruising', 'description': 'Appearance of skin bruises following perceived minimal contact or injury.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Easy bruising': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000978\",\n",
      "    \"matched_term\": \"Easy bruising\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Easy bruising (with little/no trauma)', 'field_type': 'radio', 'extracted_terms': ['Easy bruising'], 'umls_mappings': [{'original': 'Easy bruising', 'candidates': [{'code': 'HP:0000978', 'term': 'Easy bruising', 'description': 'Appearance of skin bruises following perceived minimal contact or injury.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Easy bruising', 'ranked_candidates': [{'code': 'HP:0000978', 'term': 'Easy bruising', 'description': 'Appearance of skin bruises following perceived minimal contact or injury.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Easy bruising': {\n",
      "  \"best_match_code\": \"HP:0000978\",\n",
      "  \"best_match_term\": \"Easy bruising\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 171\n",
      "✅ Extracted terms: ['Prolonged bleeding']\n",
      "🌐 [Prolonged bleeding] API Status: 200\n",
      "✅ Results for Prolonged bleeding: [{'code': 'HP:0006298', 'term': 'Prolonged bleeding after dental extraction', 'description': 'Prolonged bleeding post dental extraction sufficient to require medical intervention. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-7744-1790]'}, {'code': 'HP:0001934', 'term': 'Prolonged bleeding after minor trauma', 'description': None}, {'code': 'HP:0004846', 'term': 'Prolonged bleeding after surgery', 'description': 'Bleeding that persists longer than the normal time following a surgical procedure. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0030137', 'term': 'Prolonged bleeding following circumcision', 'description': 'Bleeding that persists for a longer than usual time following circumcision. []'}, {'code': 'HP:0011890', 'term': 'Prolonged bleeding following procedure', 'description': 'Prolonged or protracted bleeding following an invasive procedure or intervention. [https://orcid.org/0000-0003-2945-4463]'}, {'code': 'HP:0003010', 'term': 'Prolonged bleeding time', 'description': 'Prolongation of the time taken for a standardized skin cut of fixed depth and length to stop bleeding. [https://orcid.org/0000-0002-5523-511X]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Prolonged bleeding', 'candidates': [{'code': 'HP:0006298', 'term': 'Prolonged bleeding after dental extraction', 'description': 'Prolonged bleeding post dental extraction sufficient to require medical intervention. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-7744-1790]'}, {'code': 'HP:0001934', 'term': 'Prolonged bleeding after minor trauma', 'description': None}, {'code': 'HP:0004846', 'term': 'Prolonged bleeding after surgery', 'description': 'Bleeding that persists longer than the normal time following a surgical procedure. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0030137', 'term': 'Prolonged bleeding following circumcision', 'description': 'Bleeding that persists for a longer than usual time following circumcision. []'}, {'code': 'HP:0011890', 'term': 'Prolonged bleeding following procedure', 'description': 'Prolonged or protracted bleeding following an invasive procedure or intervention. [https://orcid.org/0000-0003-2945-4463]'}, {'code': 'HP:0003010', 'term': 'Prolonged bleeding time', 'description': 'Prolongation of the time taken for a standardized skin cut of fixed depth and length to stop bleeding. [https://orcid.org/0000-0002-5523-511X]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Prolonged bleeding': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0003010\",\n",
      "    \"matched_term\": \"Prolonged bleeding time\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011890\",\n",
      "    \"matched_term\": \"Prolonged bleeding following procedure\",\n",
      "    \"confidence\": \"85%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004846\",\n",
      "    \"matched_term\": \"Prolonged bleeding after surgery\",\n",
      "    \"confidence\": \"70%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001934\",\n",
      "    \"matched_term\": \"Prolonged bleeding after minor trauma\",\n",
      "    \"confidence\": \"65%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006298\",\n",
      "    \"matched_term\": \"Prolonged bleeding after dental extraction\",\n",
      "    \"confidence\": \"60%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0030137\",\n",
      "    \"matched_term\": \"Prolonged bleeding following circumcision\",\n",
      "    \"confidence\": \"55%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Persistent bleeding after trauma', 'field_type': 'radio', 'extracted_terms': ['Prolonged bleeding'], 'umls_mappings': [{'original': 'Prolonged bleeding', 'candidates': [{'code': 'HP:0006298', 'term': 'Prolonged bleeding after dental extraction', 'description': 'Prolonged bleeding post dental extraction sufficient to require medical intervention. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-7744-1790]'}, {'code': 'HP:0001934', 'term': 'Prolonged bleeding after minor trauma', 'description': None}, {'code': 'HP:0004846', 'term': 'Prolonged bleeding after surgery', 'description': 'Bleeding that persists longer than the normal time following a surgical procedure. [https://orcid.org/0000-0002-0736-9199]'}, {'code': 'HP:0030137', 'term': 'Prolonged bleeding following circumcision', 'description': 'Bleeding that persists for a longer than usual time following circumcision. []'}, {'code': 'HP:0011890', 'term': 'Prolonged bleeding following procedure', 'description': 'Prolonged or protracted bleeding following an invasive procedure or intervention. [https://orcid.org/0000-0003-2945-4463]'}, {'code': 'HP:0003010', 'term': 'Prolonged bleeding time', 'description': 'Prolongation of the time taken for a standardized skin cut of fixed depth and length to stop bleeding. [https://orcid.org/0000-0002-5523-511X]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Prolonged bleeding', 'ranked_candidates': [{'code': 'HP:0003010', 'term': 'Prolonged bleeding time', 'description': 'Prolongation of the time taken for a standardized skin cut of fixed depth and length to stop bleeding. [https://orcid.org/0000-0002-5523-511X]', 'confidence': 1.0}, {'code': 'HP:0011890', 'term': 'Prolonged bleeding following procedure', 'description': 'Prolonged or protracted bleeding following an invasive procedure or intervention. [https://orcid.org/0000-0003-2945-4463]', 'confidence': 0.85}, {'code': 'HP:0004846', 'term': 'Prolonged bleeding after surgery', 'description': 'Bleeding that persists longer than the normal time following a surgical procedure. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 0.7}, {'code': 'HP:0001934', 'term': 'Prolonged bleeding after minor trauma', 'description': None, 'confidence': 0.65}, {'code': 'HP:0006298', 'term': 'Prolonged bleeding after dental extraction', 'description': 'Prolonged bleeding post dental extraction sufficient to require medical intervention. [https://orcid.org/0000-0002-0736-9199, https://orcid.org/0000-0002-7744-1790]', 'confidence': 0.6}, {'code': 'HP:0030137', 'term': 'Prolonged bleeding following circumcision', 'description': 'Bleeding that persists for a longer than usual time following circumcision. []', 'confidence': 0.55}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Prolonged bleeding': {\n",
      "  \"best_match_code\": \"HP:0003010\",\n",
      "  \"best_match_term\": \"Prolonged bleeding time\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 172\n",
      "✅ Extracted terms: ['Extramedullary hematopoiesis']\n",
      "🌐 [Extramedullary hematopoiesis] API Status: 200\n",
      "✅ Results for Extramedullary hematopoiesis: [{'code': 'HP:0001978', 'term': 'Extramedullary hematopoiesis', 'description': 'The process of hematopoiesis occurring outside of the bone marrow (in the liver, thymus, and spleen) in the postnatal organisms. [https://orcid.org/0000-0002-0736-9199, PMID:27377325, PMID:28101170]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Extramedullary hematopoiesis', 'candidates': [{'code': 'HP:0001978', 'term': 'Extramedullary hematopoiesis', 'description': 'The process of hematopoiesis occurring outside of the bone marrow (in the liver, thymus, and spleen) in the postnatal organisms. [https://orcid.org/0000-0002-0736-9199, PMID:27377325, PMID:28101170]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Extramedullary hematopoiesis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001978\",\n",
      "    \"matched_term\": \"Extramedullary hematopoiesis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Extramedullary hematopoiesis', 'field_type': 'radio', 'extracted_terms': ['Extramedullary hematopoiesis'], 'umls_mappings': [{'original': 'Extramedullary hematopoiesis', 'candidates': [{'code': 'HP:0001978', 'term': 'Extramedullary hematopoiesis', 'description': 'The process of hematopoiesis occurring outside of the bone marrow (in the liver, thymus, and spleen) in the postnatal organisms. [https://orcid.org/0000-0002-0736-9199, PMID:27377325, PMID:28101170]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Extramedullary hematopoiesis', 'ranked_candidates': [{'code': 'HP:0001978', 'term': 'Extramedullary hematopoiesis', 'description': 'The process of hematopoiesis occurring outside of the bone marrow (in the liver, thymus, and spleen) in the postnatal organisms. [https://orcid.org/0000-0002-0736-9199, PMID:27377325, PMID:28101170]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Extramedullary hematopoiesis': {\n",
      "  \"best_match_code\": \"HP:0001978\",\n",
      "  \"best_match_term\": \"Extramedullary hematopoiesis\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 173\n",
      "✅ Extracted terms: ['Recurrent epistaxis']\n",
      "🌐 [Recurrent epistaxis] API Status: 200\n",
      "✅ Results for Recurrent epistaxis: [{'code': 'HP:0004406', 'term': 'Recurrent epistaxis', 'description': None}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Recurrent epistaxis', 'candidates': [{'code': 'HP:0004406', 'term': 'Recurrent epistaxis', 'description': None}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Recurrent epistaxis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0004406\",\n",
      "    \"matched_term\": \"Recurrent epistaxis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Frequent nosebleeds (epistaxis)', 'field_type': 'radio', 'extracted_terms': ['Recurrent epistaxis'], 'umls_mappings': [{'original': 'Recurrent epistaxis', 'candidates': [{'code': 'HP:0004406', 'term': 'Recurrent epistaxis', 'description': None}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Recurrent epistaxis', 'ranked_candidates': [{'code': 'HP:0004406', 'term': 'Recurrent epistaxis', 'description': None, 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Recurrent epistaxis': {\n",
      "  \"best_match_code\": \"HP:0004406\",\n",
      "  \"best_match_term\": \"Recurrent epistaxis\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 174\n",
      "✅ Extracted terms: ['Abnormal platelet count']\n",
      "🌐 [Abnormal platelet count] API Status: 200\n",
      "✅ Results for Abnormal platelet count: [{'code': 'HP:0011873', 'term': 'Abnormal platelet count', 'description': 'Abnormal number of platelets per volume of blood. In a healthy adult, a normal platelet count is between 150,000 and 450,000 per microliter of blood. [https://orcid.org/0000-0002-4381-2442]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal platelet count', 'candidates': [{'code': 'HP:0011873', 'term': 'Abnormal platelet count', 'description': 'Abnormal number of platelets per volume of blood. In a healthy adult, a normal platelet count is between 150,000 and 450,000 per microliter of blood. [https://orcid.org/0000-0002-4381-2442]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal platelet count': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011873\",\n",
      "    \"matched_term\": \"Abnormal platelet count\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Platelet abnormalities (too many/too few)', 'field_type': 'radio', 'extracted_terms': ['Abnormal platelet count'], 'umls_mappings': [{'original': 'Abnormal platelet count', 'candidates': [{'code': 'HP:0011873', 'term': 'Abnormal platelet count', 'description': 'Abnormal number of platelets per volume of blood. In a healthy adult, a normal platelet count is between 150,000 and 450,000 per microliter of blood. [https://orcid.org/0000-0002-4381-2442]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal platelet count', 'ranked_candidates': [{'code': 'HP:0011873', 'term': 'Abnormal platelet count', 'description': 'Abnormal number of platelets per volume of blood. In a healthy adult, a normal platelet count is between 150,000 and 450,000 per microliter of blood. [https://orcid.org/0000-0002-4381-2442]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal platelet count': {\n",
      "  \"best_match_code\": \"HP:0011873\",\n",
      "  \"best_match_term\": \"Abnormal platelet count\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 175\n",
      "✅ Extracted terms: ['Abnormality of erythrocytes']\n",
      "🌐 [Abnormality of erythrocytes] API Status: 200\n",
      "✅ Results for Abnormality of erythrocytes: [{'code': 'HP:0001877', 'term': 'Abnormality of erythrocytes', 'description': 'Any structural abnormality of erythrocytes (red-blood cells). [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of erythrocytes', 'candidates': [{'code': 'HP:0001877', 'term': 'Abnormality of erythrocytes', 'description': 'Any structural abnormality of erythrocytes (red-blood cells). [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of erythrocytes': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0001877\",\n",
      "    \"matched_term\": \"Abnormality of erythrocytes\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Red blood cell abnormalities (anemia/polycythemia/thalassemia)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of erythrocytes'], 'umls_mappings': [{'original': 'Abnormality of erythrocytes', 'candidates': [{'code': 'HP:0001877', 'term': 'Abnormality of erythrocytes', 'description': 'Any structural abnormality of erythrocytes (red-blood cells). [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of erythrocytes', 'ranked_candidates': [{'code': 'HP:0001877', 'term': 'Abnormality of erythrocytes', 'description': 'Any structural abnormality of erythrocytes (red-blood cells). [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of erythrocytes': {\n",
      "  \"best_match_code\": \"HP:0001877\",\n",
      "  \"best_match_term\": \"Abnormality of erythrocytes\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 176\n",
      "✅ Extracted terms: ['Abnormal leukocyte count']\n",
      "🌐 [Abnormal leukocyte count] API Status: 200\n",
      "✅ Results for Abnormal leukocyte count: [{'code': 'HP:0011893', 'term': 'Abnormal leukocyte count', 'description': 'Number of leukocytes per volume of blood beyond normal limits. [https://orcid.org/0000-0002-0736-9199]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal leukocyte count', 'candidates': [{'code': 'HP:0011893', 'term': 'Abnormal leukocyte count', 'description': 'Number of leukocytes per volume of blood beyond normal limits. [https://orcid.org/0000-0002-0736-9199]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal leukocyte count': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011893\",\n",
      "    \"matched_term\": \"Abnormal leukocyte count\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'White blood cell abnormalities (leukocytosis/leukopenia)', 'field_type': 'radio', 'extracted_terms': ['Abnormal leukocyte count'], 'umls_mappings': [{'original': 'Abnormal leukocyte count', 'candidates': [{'code': 'HP:0011893', 'term': 'Abnormal leukocyte count', 'description': 'Number of leukocytes per volume of blood beyond normal limits. [https://orcid.org/0000-0002-0736-9199]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal leukocyte count', 'ranked_candidates': [{'code': 'HP:0011893', 'term': 'Abnormal leukocyte count', 'description': 'Number of leukocytes per volume of blood beyond normal limits. [https://orcid.org/0000-0002-0736-9199]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal leukocyte count': {\n",
      "  \"best_match_code\": \"HP:0011893\",\n",
      "  \"best_match_term\": \"Abnormal leukocyte count\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 177\n",
      "✅ Extracted terms: ['Periodontal disease']\n",
      "🌐 [Periodontal disease] API Status: 200\n",
      "✅ Results for Periodontal disease: [{'code': 'HP:0011058', 'term': 'Generalised periodontal disease', 'description': 'A generalized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}, {'code': 'HP:0011059', 'term': 'Localised periodontal disease', 'description': 'A localized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Periodontal disease', 'candidates': [{'code': 'HP:0011058', 'term': 'Generalised periodontal disease', 'description': 'A generalized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}, {'code': 'HP:0011059', 'term': 'Localised periodontal disease', 'description': 'A localized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Periodontal disease': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011058\",\n",
      "    \"matched_term\": \"Generalised periodontal disease\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0011059\",\n",
      "    \"matched_term\": \"Localised periodontal disease\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Gum disease (loss of tissue around teeth)', 'field_type': 'radio', 'extracted_terms': ['Periodontal disease'], 'umls_mappings': [{'original': 'Periodontal disease', 'candidates': [{'code': 'HP:0011058', 'term': 'Generalised periodontal disease', 'description': 'A generalized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}, {'code': 'HP:0011059', 'term': 'Localised periodontal disease', 'description': 'A localized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Periodontal disease', 'ranked_candidates': [{'code': 'HP:0011058', 'term': 'Generalised periodontal disease', 'description': 'A generalized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 0.5}, {'code': 'HP:0011059', 'term': 'Localised periodontal disease', 'description': 'A localized form of periodontitis. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Periodontal disease': {\n",
      "  \"best_match_code\": \"HP:0011058\",\n",
      "  \"best_match_term\": \"Generalised periodontal disease\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 178\n",
      "✅ Extracted terms: ['Gingivitis']\n",
      "🌐 [Gingivitis] API Status: 200\n",
      "✅ Results for Gingivitis: [{'code': 'HP:0000230', 'term': 'Gingivitis', 'description': 'Inflammation of gum tissue (GINGIVA) without loss of connective tissue.'}, {'code': 'HP:0000212', 'term': 'Hypertrophic gingivitis', 'description': 'Abnormal enlargement or overgrowth of the gingivae brought about by enlargement of existing cells.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Gingivitis', 'candidates': [{'code': 'HP:0000230', 'term': 'Gingivitis', 'description': 'Inflammation of gum tissue (GINGIVA) without loss of connective tissue.'}, {'code': 'HP:0000212', 'term': 'Hypertrophic gingivitis', 'description': 'Abnormal enlargement or overgrowth of the gingivae brought about by enlargement of existing cells.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Gingivitis': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000230\",\n",
      "    \"matched_term\": \"Gingivitis\",\n",
      "    \"confidence\": \"100%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000212\",\n",
      "    \"matched_term\": \"Hypertrophic gingivitis\",\n",
      "    \"confidence\": \"70%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Gingivitis (inflamed/red/swollen gums)', 'field_type': 'radio', 'extracted_terms': ['Gingivitis'], 'umls_mappings': [{'original': 'Gingivitis', 'candidates': [{'code': 'HP:0000230', 'term': 'Gingivitis', 'description': 'Inflammation of gum tissue (GINGIVA) without loss of connective tissue.'}, {'code': 'HP:0000212', 'term': 'Hypertrophic gingivitis', 'description': 'Abnormal enlargement or overgrowth of the gingivae brought about by enlargement of existing cells.'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Gingivitis', 'ranked_candidates': [{'code': 'HP:0000230', 'term': 'Gingivitis', 'description': 'Inflammation of gum tissue (GINGIVA) without loss of connective tissue.', 'confidence': 1.0}, {'code': 'HP:0000212', 'term': 'Hypertrophic gingivitis', 'description': 'Abnormal enlargement or overgrowth of the gingivae brought about by enlargement of existing cells.', 'confidence': 0.7}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Gingivitis': {\n",
      "  \"best_match_code\": \"HP:0000230\",\n",
      "  \"best_match_term\": \"Gingivitis\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 179\n",
      "✅ Extracted terms: ['Oral herpes']\n",
      "🌐 [Oral herpes] API Status: 200\n",
      "✅ Results for Oral herpes: [{'code': 'HP:0410028', 'term': 'Recurrent oral herpes', 'description': 'Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Oral herpes', 'candidates': [{'code': 'HP:0410028', 'term': 'Recurrent oral herpes', 'description': 'Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Oral herpes': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0410028\",\n",
      "    \"matched_term\": \"Recurrent oral herpes\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Oral herpes (blisters/ulcers on gums/tongue)', 'field_type': 'radio', 'extracted_terms': ['Oral herpes'], 'umls_mappings': [{'original': 'Oral herpes', 'candidates': [{'code': 'HP:0410028', 'term': 'Recurrent oral herpes', 'description': 'Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Oral herpes', 'ranked_candidates': [{'code': 'HP:0410028', 'term': 'Recurrent oral herpes', 'description': 'Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Oral herpes': {\n",
      "  \"best_match_code\": \"HP:0410028\",\n",
      "  \"best_match_term\": \"Recurrent oral herpes\",\n",
      "  \"confidence\": \"85%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Oral herpes (blisters/ulcers on gums/tongue)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Oral herpes\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Oral herpes\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0410028\",\n",
      "          \"term\": \"Recurrent oral herpes\",\n",
      "          \"description\": \"Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Oral herpes\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0410028\",\n",
      "          \"term\": \"Recurrent oral herpes\",\n",
      "          \"description\": \"Recurrent episodes of oral herpes, typically characterized by blisters or ulcers on the gums, lips and/or tongue caused by herpes virus. []\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Oral herpes\",\n",
      "      \"best_match_code\": \"HP:0410028\",\n",
      "      \"best_match_term\": \"Recurrent oral herpes\",\n",
      "      \"confidence\": 0.85\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1274321\n",
      "🧩 ancestor_cuis ['C0459149', 'C0012634', 'C0149778', 'C1285329', 'C0276223', 'C1320354', 'C1285159', 'C0019345', 'C0424482', 'C0577649', 'C0266804', 'C0578002', 'C1333803', 'C1290857', 'C0341013', 'C1837066', 'C0729530', 'C0341012', 'C2700612', 'C0277556', 'C0019372', 'C0729555', 'C1698666', 'C0575142', 'C0019348', 'C0424722', 'C1290856', 'C0276221', 'C0009450', 'C0239998', 'C0023760', 'C0012242', 'C1827135', 'C0042769', 'C0026636', 'C0263978', 'C2720507', 'C0037088', 'C0266998']\n",
      "🧩 candidate_details [{'cui': 'C0459149', 'name': 'Disorder of soft tissue of head'}, {'cui': 'C0012634', 'name': 'Disease'}, {'cui': 'C0149778', 'name': 'Soft tissue infection'}, {'cui': 'C1285329', 'name': 'Infective disorder of head'}, {'cui': 'C0276223', 'name': 'Recurrent herpes simplex'}, {'cui': 'C1320354', 'name': 'Head finding'}, {'cui': 'C1285159', 'name': 'Disorder of body system'}, {'cui': 'C0019345', 'name': 'Herpes labialis'}, {'cui': 'C0424482', 'name': 'Lip finding'}, {'cui': 'C0577649', 'name': 'Infection of face'}, {'cui': 'C0266804', 'name': 'Disorder of upper digestive tract'}, {'cui': 'C0578002', 'name': 'Finding of face'}, {'cui': 'C1333803', 'name': 'Digestive system observation'}, {'cui': 'C1290857', 'name': 'Disorder of face'}, {'cui': 'C0341013', 'name': 'Recurrent oral herpes simplex infection'}, {'cui': 'C1837066', 'name': 'Recurrent viral infection'}, {'cui': 'C0729530', 'name': 'Viral infection of the digestive tract'}, {'cui': 'C0341012', 'name': 'Oral herpes simplex infection'}, {'cui': 'C2700612', 'name': 'Disorder of digestive tract'}, {'cui': 'C0277556', 'name': 'Recurrent disease'}, {'cui': 'C0019372', 'name': 'Herpes infection'}, {'cui': 'C0729555', 'name': 'Infection of digestive system'}, {'cui': 'C1698666', 'name': 'Infection of lip'}, {'cui': 'C0575142', 'name': 'Finding of head region'}, {'cui': 'C0019348', 'name': 'Herpes simplex infection'}, {'cui': 'C0424722', 'name': 'General finding of soft tissue'}, {'cui': 'C1290856', 'name': 'Disorder of head'}, {'cui': 'C0276221', 'name': 'Disease caused by Alphaherpesvirinae'}, {'cui': 'C0009450', 'name': 'Communicable disease, NOS'}, {'cui': 'C0239998', 'name': 'Recurrent infection'}, {'cui': 'C0023760', 'name': 'Disease of lips, NOS'}, {'cui': 'C0012242', 'name': 'Disorder of digestive system'}, {'cui': 'C1827135', 'name': 'Finding of mouth region'}, {'cui': 'C0042769', 'name': 'Disease caused by virus'}, {'cui': 'C0026636', 'name': 'Disease of mouth'}, {'cui': 'C0263978', 'name': 'Disorder of soft tissue'}, {'cui': 'C2720507', 'name': 'SNOMED CT Concept (SNOMED RT+CTV3)'}, {'cui': 'C0037088', 'name': 'Clinical observation: symptoms and signs'}, {'cui': 'C0266998', 'name': 'Disorder of oral soft tissues'}]\n",
      "🧩 prompt TASK: Refine the HPO mapping by considering broader UMLS ancestor concepts.\n",
      "\n",
      "Survey Question:\n",
      "\"Oral herpes (blisters/ulcers on gums/tongue)\"\n",
      "\n",
      "Validated Mapping:\n",
      "{\n",
      "  \"original\": \"Oral herpes\"\n",
      "  \"best_match_code\": \"HP:0410028\",\n",
      "  \"best_match_term\": \"Recurrent oral herpes\"\n",
      "}\n",
      "\n",
      "Ancestor terms for this mapping are:\n",
      "- C0459149 (Disorder of soft tissue of head)\n",
      "- C0012634 (Disease)\n",
      "- C0149778 (Soft tissue infection)\n",
      "- C1285329 (Infective disorder of head)\n",
      "- C0276223 (Recurrent herpes simplex)\n",
      "- C1320354 (Head finding)\n",
      "- C1285159 (Disorder of body system)\n",
      "- C0019345 (Herpes labialis)\n",
      "- C0424482 (Lip finding)\n",
      "- C0577649 (Infection of face)\n",
      "- C0266804 (Disorder of upper digestive tract)\n",
      "- C0578002 (Finding of face)\n",
      "- C1333803 (Digestive system observation)\n",
      "- C1290857 (Disorder of face)\n",
      "- C0341013 (Recurrent oral herpes simplex infection)\n",
      "- C1837066 (Recurrent viral infection)\n",
      "- C0729530 (Viral infection of the digestive tract)\n",
      "- C0341012 (Oral herpes simplex infection)\n",
      "- C2700612 (Disorder of digestive tract)\n",
      "- C0277556 (Recurrent disease)\n",
      "- C0019372 (Herpes infection)\n",
      "- C0729555 (Infection of digestive system)\n",
      "- C1698666 (Infection of lip)\n",
      "- C0575142 (Finding of head region)\n",
      "- C0019348 (Herpes simplex infection)\n",
      "- C0424722 (General finding of soft tissue)\n",
      "- C1290856 (Disorder of head)\n",
      "- C0276221 (Disease caused by Alphaherpesvirinae)\n",
      "- C0009450 (Communicable disease, NOS)\n",
      "- C0239998 (Recurrent infection)\n",
      "- C0023760 (Disease of lips, NOS)\n",
      "- C0012242 (Disorder of digestive system)\n",
      "- C1827135 (Finding of mouth region)\n",
      "- C0042769 (Disease caused by virus)\n",
      "- C0026636 (Disease of mouth)\n",
      "- C0263978 (Disorder of soft tissue)\n",
      "- C2720507 (SNOMED CT Concept (SNOMED RT+CTV3))\n",
      "- C0037088 (Clinical observation: symptoms and signs)\n",
      "- C0266998 (Disorder of oral soft tissues)\n",
      "\n",
      "Instructions:\n",
      "- Review the meaning of the survey question in context.\n",
      "- Examine the validated mapping and each ancestor candidate.\n",
      "- If \"original\" is \"Persistent bleeding\", \"best_match_term\" is \"Persistent bleeding after trauma\", it's good, do not use others, just return: {}.\n",
      "- If any of the ancestor CUIs semantically matches the \"original\" term, choose it, like using \"Thrombosis\" is more appropriate than \"Venous thrombosis\"\n",
      "- If any of the ancestor CUIs represents a **more general and appropriate** medical concept than the validated mapping, select it, like using \"Cardiomyopathies\", \"Ataxia\" “Tonic Seizures” is more appropriate than \"Dilated cardiomyopathy\", \"Cerebellar ataxia\", “Focal tonic seizures”.\n",
      "- Then map the selected CUI to the most appropriate **HPO term**.\n",
      "- If the question contains multiple terms separated by a forward slash (\"/\") or expressions like \"and/or\", extract a broader or unifying medical concept that encompasses all listed terms is good.  Example: “Muscle issues in the chest, back, and/or shoulders” → keep using “Abnormality of the musculature of the thorax” as the \"best_match_term\" is better than \"Muscle weakness\".\n",
      "- If the validated mapping is already the most appropriate option, return an empty result.\n",
      "- If the validated mapping includes qualifiers like \"extreme\", \"severe\", or specific etiology (e.g., genetic cause), and the survey question does **not** include those qualifiers or implications, prefer a broader ancestor term, like using \"Short stature\" may be more appropriate than \"Short stature, extreme\".\n",
      "\n",
      "\n",
      "Return your answer strictly in this JSON format:\n",
      "{\n",
      "  \"refined_code\": \"NEW_HPO_CODE\",\n",
      "  \"refined_term\": \"NEW_HPO_TERM\",\n",
      "  \"confidence\": \"XX%\"\n",
      "}\n",
      "\n",
      "If no refinement is needed, return:\n",
      "{}\n",
      "\n",
      "🧩 response content='{}' additional_kwargs={'refusal': None} response_metadata={'token_usage': {'completion_tokens': 1, 'prompt_tokens': 968, 'total_tokens': 969, 'completion_tokens_details': {'accepted_prediction_tokens': 0, 'audio_tokens': 0, 'reasoning_tokens': 0, 'rejected_prediction_tokens': 0}, 'prompt_tokens_details': {'audio_tokens': 0, 'cached_tokens': 0}}, 'model_name': 'gpt-4-0613', 'system_fingerprint': None, 'id': 'chatcmpl-CCeaxNv2usgqvcCSAnVBoAweAb9u6', 'service_tier': 'default', 'finish_reason': 'stop', 'logprobs': None} id='run--184ba688-8f5a-4efe-9ee2-4cc39e2cfc91-0' usage_metadata={'input_tokens': 968, 'output_tokens': 1, 'total_tokens': 969, 'input_token_details': {'audio': 0, 'cache_read': 0}, 'output_token_details': {'audio': 0, 'reasoning': 0}}\n",
      "✅ Processed row 180\n",
      "✅ Extracted terms: ['Tooth fracture']\n",
      "🌐 [Tooth fracture] API Status: 200\n",
      "✅ Results for Tooth fracture: [{'code': 'HP:0025124', 'term': 'Spontaneous tooth fracture', 'description': 'A tendency of teeth to fracture as manifested by a history of repeated fracture of the dental enamel without adequate trauma. []'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Tooth fracture', 'candidates': [{'code': 'HP:0025124', 'term': 'Spontaneous tooth fracture', 'description': 'A tendency of teeth to fracture as manifested by a history of repeated fracture of the dental enamel without adequate trauma. []'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Tooth fracture': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0025124\",\n",
      "    \"matched_term\": \"Spontaneous tooth fracture\",\n",
      "    \"confidence\": \"75%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Spontaneous tooth fracture', 'field_type': 'radio', 'extracted_terms': ['Tooth fracture'], 'umls_mappings': [{'original': 'Tooth fracture', 'candidates': [{'code': 'HP:0025124', 'term': 'Spontaneous tooth fracture', 'description': 'A tendency of teeth to fracture as manifested by a history of repeated fracture of the dental enamel without adequate trauma. []'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Tooth fracture', 'ranked_candidates': [{'code': 'HP:0025124', 'term': 'Spontaneous tooth fracture', 'description': 'A tendency of teeth to fracture as manifested by a history of repeated fracture of the dental enamel without adequate trauma. []', 'confidence': 0.75}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Tooth fracture': {\n",
      "  \"best_match_code\": \"HP:0025124\",\n",
      "  \"best_match_term\": \"Spontaneous tooth fracture\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 181\n",
      "✅ Extracted terms: ['Abnormal number of teeth']\n",
      "🌐 [Abnormal number of teeth] API Status: 200\n",
      "✅ Results for Abnormal number of teeth: [{'code': 'HP:0006483', 'term': 'Abnormal number of teeth', 'description': 'The presence of an altered number of of teeth. [https://orcid.org/0000-0002-9338-3017]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal number of teeth', 'candidates': [{'code': 'HP:0006483', 'term': 'Abnormal number of teeth', 'description': 'The presence of an altered number of of teeth. [https://orcid.org/0000-0002-9338-3017]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormal number of teeth': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006483\",\n",
      "    \"matched_term\": \"Abnormal number of teeth\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Unusual number of teeth (more/less)', 'field_type': 'radio', 'extracted_terms': ['Abnormal number of teeth'], 'umls_mappings': [{'original': 'Abnormal number of teeth', 'candidates': [{'code': 'HP:0006483', 'term': 'Abnormal number of teeth', 'description': 'The presence of an altered number of of teeth. [https://orcid.org/0000-0002-9338-3017]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormal number of teeth', 'ranked_candidates': [{'code': 'HP:0006483', 'term': 'Abnormal number of teeth', 'description': 'The presence of an altered number of of teeth. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormal number of teeth': {\n",
      "  \"best_match_code\": \"HP:0006483\",\n",
      "  \"best_match_term\": \"Abnormal number of teeth\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 182\n",
      "✅ Extracted terms: ['Abnormal tooth morphology']\n",
      "🌐 [Abnormal tooth morphology] API Status: 404\n",
      "❌ Failed for term: Abnormal tooth morphology\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal tooth morphology', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormal shape of the teeth']\n",
      "🌐 [Abnormal shape of the teeth] API Status: 404\n",
      "❌ Failed for term: Abnormal shape of the teeth\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormal shape of the teeth', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of dentition']\n",
      "🌐 [Abnormality of dentition] API Status: 404\n",
      "❌ Failed for term: Abnormality of dentition\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of dentition', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the teeth']\n",
      "🌐 [Abnormality of the teeth] API Status: 200\n",
      "✅ Results for Abnormality of the teeth: [{'code': 'HP:0000164', 'term': 'Abnormality of the teeth', 'description': 'disorders of the dental system that exist at, and usually before, birth regardless of their causation.'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the teeth', 'candidates': [{'code': 'HP:0000164', 'term': 'Abnormality of the teeth', 'description': 'disorders of the dental system that exist at, and usually before, birth regardless of their causation.'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the teeth': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000164\",\n",
      "    \"matched_term\": \"Abnormality of the teeth\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Malformed teeth', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the teeth'], 'umls_mappings': [{'original': 'Abnormality of the teeth', 'candidates': [{'code': 'HP:0000164', 'term': 'Abnormality of the teeth', 'description': 'disorders of the dental system that exist at, and usually before, birth regardless of their causation.'}]}], 'retry_count': 3, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the teeth', 'Abnormal shape of the teeth', 'Abnormality of dentition', 'Abnormal tooth morphology'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the teeth', 'ranked_candidates': [{'code': 'HP:0000164', 'term': 'Abnormality of the teeth', 'description': 'disorders of the dental system that exist at, and usually before, birth regardless of their causation.', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the teeth': {\n",
      "  \"best_match_code\": \"HP:0000164\",\n",
      "  \"best_match_term\": \"Abnormality of the teeth\",\n",
      "  \"confidence\": \"90%\"\n",
      "}\n",
      "✅ Processed row 183\n",
      "✅ Extracted terms: ['Abnormality of the primary dentition']\n",
      "🌐 [Abnormality of the primary dentition] API Status: 404\n",
      "❌ Failed for term: Abnormality of the primary dentition\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the primary dentition', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the deciduous dentition']\n",
      "🌐 [Abnormality of the deciduous dentition] API Status: 404\n",
      "❌ Failed for term: Abnormality of the deciduous dentition\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the deciduous dentition', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of dentition']\n",
      "🌐 [Abnormality of dentition] API Status: 404\n",
      "❌ Failed for term: Abnormality of dentition\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of dentition', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of dental eruption']\n",
      "🌐 [Abnormality of dental eruption] API Status: 200\n",
      "✅ Results for Abnormality of dental eruption: [{'code': 'HP:0006292', 'term': 'Abnormality of dental eruption', 'description': 'An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of dental eruption', 'candidates': [{'code': 'HP:0006292', 'term': 'Abnormality of dental eruption', 'description': 'An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of dental eruption': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006292\",\n",
      "    \"matched_term\": \"Abnormality of dental eruption\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Abnormality of primary teeth (baby teeth problems)', 'field_type': 'radio', 'extracted_terms': ['Abnormality of dental eruption'], 'umls_mappings': [{'original': 'Abnormality of dental eruption', 'candidates': [{'code': 'HP:0006292', 'term': 'Abnormality of dental eruption', 'description': 'An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]'}]}], 'retry_count': 3, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of dental eruption', 'Abnormality of the deciduous dentition', 'Abnormality of dentition', 'Abnormality of the primary dentition'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of dental eruption', 'ranked_candidates': [{'code': 'HP:0006292', 'term': 'Abnormality of dental eruption', 'description': 'An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of dental eruption': {\n",
      "  \"best_match_code\": \"HP:0006292\",\n",
      "  \"best_match_term\": \"Abnormality of dental eruption\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Abnormality of primary teeth (baby teeth problems)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Abnormality of dental eruption\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of dental eruption\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0006292\",\n",
      "          \"term\": \"Abnormality of dental eruption\",\n",
      "          \"description\": \"An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retry_count\": 3,\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"history_rewritten_terms\": [\n",
      "    \"Abnormality of dental eruption\",\n",
      "    \"Abnormality of the deciduous dentition\",\n",
      "    \"Abnormality of dentition\",\n",
      "    \"Abnormality of the primary dentition\"\n",
      "  ],\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of dental eruption\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0006292\",\n",
      "          \"term\": \"Abnormality of dental eruption\",\n",
      "          \"description\": \"An abnormality of tooth eruption. [https://orcid.org/0000-0002-9338-3017]\",\n",
      "          \"confidence\": 1.0\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Abnormality of dental eruption\",\n",
      "      \"best_match_code\": \"HP:0006292\",\n",
      "      \"best_match_term\": \"Abnormality of dental eruption\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C1859363\n",
      "✅ Processed row 184\n",
      "✅ Extracted terms: ['Abnormality of the dental root']\n",
      "🌐 [Abnormality of the dental root] API Status: 200\n",
      "✅ Results for Abnormality of the dental root: [{'code': 'HP:0006486', 'term': 'Abnormality of the dental root', 'description': 'An abnormality of the dental root. [https://orcid.org/0000-0002-9338-3017]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the dental root', 'candidates': [{'code': 'HP:0006486', 'term': 'Abnormality of the dental root', 'description': 'An abnormality of the dental root. [https://orcid.org/0000-0002-9338-3017]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the dental root': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006486\",\n",
      "    \"matched_term\": \"Abnormality of the dental root\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Abnormality of the dental root', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the dental root'], 'umls_mappings': [{'original': 'Abnormality of the dental root', 'candidates': [{'code': 'HP:0006486', 'term': 'Abnormality of the dental root', 'description': 'An abnormality of the dental root. [https://orcid.org/0000-0002-9338-3017]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the dental root', 'ranked_candidates': [{'code': 'HP:0006486', 'term': 'Abnormality of the dental root', 'description': 'An abnormality of the dental root. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the dental root': {\n",
      "  \"best_match_code\": \"HP:0006486\",\n",
      "  \"best_match_term\": \"Abnormality of the dental root\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 185\n",
      "✅ Extracted terms: ['Abnormality of dental pulp']\n",
      "🌐 [Abnormality of dental pulp] API Status: 404\n",
      "❌ Failed for term: Abnormality of dental pulp\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of dental pulp', 'candidates': []}]\n",
      "✅ Revised terms: ['Abnormality of the dental pulp']\n",
      "🌐 [Abnormality of the dental pulp] API Status: 200\n",
      "✅ Results for Abnormality of the dental pulp: [{'code': 'HP:0006479', 'term': 'Abnormality of the dental pulp', 'description': 'An abnormality of the dental pulp. [https://orcid.org/0000-0002-9338-3017]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Abnormality of the dental pulp', 'candidates': [{'code': 'HP:0006479', 'term': 'Abnormality of the dental pulp', 'description': 'An abnormality of the dental pulp. [https://orcid.org/0000-0002-9338-3017]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Abnormality of the dental pulp': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0006479\",\n",
      "    \"matched_term\": \"Abnormality of the dental pulp\",\n",
      "    \"confidence\": \"100%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Abnormality of dental pulp', 'field_type': 'radio', 'extracted_terms': ['Abnormality of the dental pulp'], 'umls_mappings': [{'original': 'Abnormality of the dental pulp', 'candidates': [{'code': 'HP:0006479', 'term': 'Abnormality of the dental pulp', 'description': 'An abnormality of the dental pulp. [https://orcid.org/0000-0002-9338-3017]'}]}], 'retry_count': 1, 'mappability_retry_count': 0, 'history_rewritten_terms': ['Abnormality of the dental pulp', 'Abnormality of dental pulp'], 'retries': 0, 'ranked_mappings': [{'original': 'Abnormality of the dental pulp', 'ranked_candidates': [{'code': 'HP:0006479', 'term': 'Abnormality of the dental pulp', 'description': 'An abnormality of the dental pulp. [https://orcid.org/0000-0002-9338-3017]', 'confidence': 1.0}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Abnormality of the dental pulp': {\n",
      "  \"best_match_code\": \"HP:0006479\",\n",
      "  \"best_match_term\": \"Abnormality of the dental pulp\",\n",
      "  \"confidence\": \"100%\"\n",
      "}\n",
      "✅ Processed row 186\n",
      "✅ Extracted terms: ['Malocclusion']\n",
      "🌐 [Malocclusion] API Status: 200\n",
      "✅ Results for Malocclusion: [{'code': 'HP:0000689', 'term': 'Angle class 2 malocclusion', 'description': None}, {'code': 'HP:0009102', 'term': 'Anterior open-bite malocclusion', 'description': 'Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]'}]\n",
      "🧪 Final UMLS mappings: [{'original': 'Malocclusion', 'candidates': [{'code': 'HP:0000689', 'term': 'Angle class 2 malocclusion', 'description': None}, {'code': 'HP:0009102', 'term': 'Anterior open-bite malocclusion', 'description': 'Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]'}]}]\n",
      "🧩 Entered rank_mappings_node\n",
      "🧠 Raw LLM output for 'Malocclusion': [\n",
      "  {\n",
      "    \"matched_code\": \"HP:0000689\",\n",
      "    \"matched_term\": \"Angle class 2 malocclusion\",\n",
      "    \"confidence\": \"50%\"\n",
      "  },\n",
      "  {\n",
      "    \"matched_code\": \"HP:0009102\",\n",
      "    \"matched_term\": \"Anterior open-bite malocclusion\",\n",
      "    \"confidence\": \"50%\"\n",
      "  }\n",
      "]\n",
      "✅ Final ranked mappings: {'text': 'Over/under bite (malocclusion)', 'field_type': 'radio', 'extracted_terms': ['Malocclusion'], 'umls_mappings': [{'original': 'Malocclusion', 'candidates': [{'code': 'HP:0000689', 'term': 'Angle class 2 malocclusion', 'description': None}, {'code': 'HP:0009102', 'term': 'Anterior open-bite malocclusion', 'description': 'Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]'}]}], 'mappability_retry_count': 0, 'retries': 0, 'ranked_mappings': [{'original': 'Malocclusion', 'ranked_candidates': [{'code': 'HP:0000689', 'term': 'Angle class 2 malocclusion', 'description': None, 'confidence': 0.5}, {'code': 'HP:0009102', 'term': 'Anterior open-bite malocclusion', 'description': 'Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]', 'confidence': 0.5}]}]}\n",
      "🧩 Entered validate_mapping_node\n",
      "🧠 Raw LLM output for 'Malocclusion': {\n",
      "  \"best_match_code\": \"HP:0000689\",\n",
      "  \"best_match_term\": \"Angle class 2 malocclusion\",\n",
      "  \"confidence\": \"70%\"\n",
      "}\n",
      "🧩 Entered gather_ancestor_candidates_node\n",
      "🔎 State snapshot: {\n",
      "  \"text\": \"Over/under bite (malocclusion)\",\n",
      "  \"field_type\": \"radio\",\n",
      "  \"extracted_terms\": [\n",
      "    \"Malocclusion\"\n",
      "  ],\n",
      "  \"umls_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malocclusion\",\n",
      "      \"candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000689\",\n",
      "          \"term\": \"Angle class 2 malocclusion\",\n",
      "          \"description\": null\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009102\",\n",
      "          \"term\": \"Anterior open-bite malocclusion\",\n",
      "          \"description\": \"Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]\"\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"mappability_retry_count\": 0,\n",
      "  \"ranked_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malocclusion\",\n",
      "      \"ranked_candidates\": [\n",
      "        {\n",
      "          \"code\": \"HP:0000689\",\n",
      "          \"term\": \"Angle class 2 malocclusion\",\n",
      "          \"description\": null,\n",
      "          \"confidence\": 0.5\n",
      "        },\n",
      "        {\n",
      "          \"code\": \"HP:0009102\",\n",
      "          \"term\": \"Anterior open-bite malocclusion\",\n",
      "          \"description\": \"Anterior open bite is a malocclusion characterized by a gap between the anterior teeth (incisors), that is, by a deficiency in the normal vertical overlap between antagonist incisal edges when the posterior teeth are in occlusion. [https://orcid.org/0000-0002-9338-3017, PMID:27615261]\",\n",
      "          \"confidence\": 0.5\n",
      "        }\n",
      "      ]\n",
      "    }\n",
      "  ],\n",
      "  \"retries\": 0,\n",
      "  \"validated_mappings\": [\n",
      "    {\n",
      "      \"original\": \"Malocclusion\",\n",
      "      \"best_match_code\": \"HP:0000689\",\n",
      "      \"best_match_term\": \"Angle class 2 malocclusion\",\n",
      "      \"confidence\": 0.7\n",
      "    }\n",
      "  ]\n",
      "}\n",
      "🧩 CUI C4280614\n",
      "✅ Processed row 187\n"
     ]
    }
   ],
   "source": [
    "\n",
    "# Iterate over each row of the DataFrame to map the survey question text to a UMLS code/term\n",
    "for idx, row in df.iterrows():\n",
    "    # Source text column and a fixed field type for the agent\n",
    "    question_text = row['Question']\n",
    "    field_type = 'radio'  # adjust if your form field varies\n",
    "\n",
    "    # Defaults to write back even if mapping fails\n",
    "    agent_term = \"\"\n",
    "    agent_code = \"\"\n",
    "    confidence = 0.0\n",
    "\n",
    "    try:\n",
    "        # Call your LangGraph-based mapping agent\n",
    "        # Expecting a dict with keys like \"refine_mapping\" and/or \"validated_mappings\"\n",
    "        result = umls_mapping_graph.invoke({\n",
    "            \"text\": question_text,\n",
    "            \"field_type\": field_type,\n",
    "            \"retries\": 0  # keep retries at 0 for deterministic behavior\n",
    "        })\n",
    "\n",
    "        # 1) Prefer refined mappings when present (treated as high confidence)\n",
    "        refine_mapping = result.get(\"refine_mapping\", {})\n",
    "        if refine_mapping and isinstance(refine_mapping, dict):\n",
    "            agent_code = refine_mapping.get(\"refined_code\", \"\")   # <-- fixed typo\n",
    "            agent_term = refine_mapping.get(\"refined_term\", \"\")\n",
    "            confidence = 1.0  # refined result is considered high confidence\n",
    "\n",
    "        else:\n",
    "            # 2) Fallback: use the first validated mapping, if available\n",
    "            validated_mappings = result.get(\"validated_mappings\", [])\n",
    "            if validated_mappings and isinstance(validated_mappings, list):\n",
    "                best_mapping = validated_mappings[0]  # assumes the agent returns best-first\n",
    "                agent_code = best_mapping.get(\"best_match_code\", \"\")\n",
    "                agent_term = best_mapping.get(\"best_match_term\", \"\")\n",
    "                confidence = best_mapping.get(\"confidence\", 0.0)\n",
    "\n",
    "                # Normalize confidence to float if the agent returned it as a string\n",
    "                if isinstance(confidence, str):\n",
    "                    try:\n",
    "                        confidence = float(confidence)\n",
    "                    except ValueError:\n",
    "                        confidence = 0.0  # fallback if conversion fails\n",
    "\n",
    "    except Exception as e:\n",
    "        # Log and continue processing subsequent rows\n",
    "        print(f\"❌ Error on row {idx + 1}: {e}\")\n",
    "\n",
    "    # Write outputs back into the DataFrame\n",
    "    # (Make sure these columns exist or will be created as new ones.)\n",
    "    df.at[idx, 'agent_term'] = agent_term\n",
    "    df.at[idx, 'agent_code'] = agent_code\n",
    "    df.at[idx, 'confidence'] = confidence\n",
    "\n",
    "    print(f\"✅ Processed row {idx + 1}\")\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Checking the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Section</th>\n",
       "      <th>Question</th>\n",
       "      <th>HPO term</th>\n",
       "      <th>HPO code</th>\n",
       "      <th>agent_term</th>\n",
       "      <th>agent_code</th>\n",
       "      <th>confidence</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Mother's Pregnancy</td>\n",
       "      <td>Amniotic fluid issue - Too much fluid (polyhyd...</td>\n",
       "      <td>Abnormality of the amniotic fluid</td>\n",
       "      <td>HP:0001560</td>\n",
       "      <td>Abnormality of the amniotic fluid</td>\n",
       "      <td>HP:0001560</td>\n",
       "      <td>0.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Mother's Pregnancy</td>\n",
       "      <td>Decreased fetal movement</td>\n",
       "      <td>Decreased fetal movement</td>\n",
       "      <td>HP:0001558</td>\n",
       "      <td>Decreased fetal movement</td>\n",
       "      <td>HP:0001558</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Mother's Pregnancy</td>\n",
       "      <td>Delivery complication</td>\n",
       "      <td>Abnormal delivery</td>\n",
       "      <td>HP:0001787</td>\n",
       "      <td>Delivery complication</td>\n",
       "      <td>HP:0001787</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Mother's Pregnancy</td>\n",
       "      <td>Maternal health problem</td>\n",
       "      <td>Prenatal maternal abnormality</td>\n",
       "      <td>HP:0002686</td>\n",
       "      <td></td>\n",
       "      <td></td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Mother's Pregnancy</td>\n",
       "      <td>Placental issue</td>\n",
       "      <td>Abnormality of the placenta</td>\n",
       "      <td>HP:0100767</td>\n",
       "      <td>Abnormality of the placenta</td>\n",
       "      <td>HP:0100767</td>\n",
       "      <td>0.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>182</th>\n",
       "      <td>Oral Health</td>\n",
       "      <td>Malformed teeth</td>\n",
       "      <td>Malformed teeth</td>\n",
       "      <td>HP:0006482</td>\n",
       "      <td>Abnormality of the teeth</td>\n",
       "      <td>HP:0000164</td>\n",
       "      <td>0.9</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>183</th>\n",
       "      <td>Oral Health</td>\n",
       "      <td>Abnormality of primary teeth (baby teeth probl...</td>\n",
       "      <td>Abnormality of primary teeth</td>\n",
       "      <td>HP:0006481</td>\n",
       "      <td>Abnormality of dental eruption</td>\n",
       "      <td>HP:0006292</td>\n",
       "      <td>0.7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>184</th>\n",
       "      <td>Oral Health</td>\n",
       "      <td>Abnormality of the dental root</td>\n",
       "      <td>Abnormality of the dental root</td>\n",
       "      <td>HP:0006486</td>\n",
       "      <td>Abnormality of the dental root</td>\n",
       "      <td>HP:0006486</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>185</th>\n",
       "      <td>Oral Health</td>\n",
       "      <td>Abnormality of dental pulp</td>\n",
       "      <td>Abnormality of dental pulp</td>\n",
       "      <td>HP:0006479</td>\n",
       "      <td>Abnormality of the dental pulp</td>\n",
       "      <td>HP:0006479</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>186</th>\n",
       "      <td>Oral Health</td>\n",
       "      <td>Over/under bite (malocclusion)</td>\n",
       "      <td>Misalignment of teeth</td>\n",
       "      <td>HP:0000692</td>\n",
       "      <td>Angle class 2 malocclusion</td>\n",
       "      <td>HP:0000689</td>\n",
       "      <td>0.7</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>187 rows × 7 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                Section                                           Question  \\\n",
       "0    Mother's Pregnancy  Amniotic fluid issue - Too much fluid (polyhyd...   \n",
       "1    Mother's Pregnancy                           Decreased fetal movement   \n",
       "2    Mother's Pregnancy                              Delivery complication   \n",
       "3    Mother's Pregnancy                            Maternal health problem   \n",
       "4    Mother's Pregnancy                                    Placental issue   \n",
       "..                  ...                                                ...   \n",
       "182         Oral Health                                    Malformed teeth   \n",
       "183         Oral Health  Abnormality of primary teeth (baby teeth probl...   \n",
       "184         Oral Health                     Abnormality of the dental root   \n",
       "185         Oral Health                         Abnormality of dental pulp   \n",
       "186         Oral Health                     Over/under bite (malocclusion)   \n",
       "\n",
       "                              HPO term    HPO code  \\\n",
       "0    Abnormality of the amniotic fluid  HP:0001560   \n",
       "1             Decreased fetal movement  HP:0001558   \n",
       "2                    Abnormal delivery  HP:0001787   \n",
       "3        Prenatal maternal abnormality  HP:0002686   \n",
       "4          Abnormality of the placenta  HP:0100767   \n",
       "..                                 ...         ...   \n",
       "182                    Malformed teeth  HP:0006482   \n",
       "183       Abnormality of primary teeth  HP:0006481   \n",
       "184     Abnormality of the dental root  HP:0006486   \n",
       "185         Abnormality of dental pulp  HP:0006479   \n",
       "186              Misalignment of teeth  HP:0000692   \n",
       "\n",
       "                            agent_term  agent_code  confidence  \n",
       "0    Abnormality of the amniotic fluid  HP:0001560         0.9  \n",
       "1             Decreased fetal movement  HP:0001558         1.0  \n",
       "2                Delivery complication  HP:0001787         1.0  \n",
       "3                                                          0.0  \n",
       "4          Abnormality of the placenta  HP:0100767         0.9  \n",
       "..                                 ...         ...         ...  \n",
       "182           Abnormality of the teeth  HP:0000164         0.9  \n",
       "183     Abnormality of dental eruption  HP:0006292         0.7  \n",
       "184     Abnormality of the dental root  HP:0006486         1.0  \n",
       "185     Abnormality of the dental pulp  HP:0006479         1.0  \n",
       "186         Angle class 2 malocclusion  HP:0000689         0.7  \n",
       "\n",
       "[187 rows x 7 columns]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print(df.head())"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "3. Export results."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Output the result and check it \n",
    "df.to_excel(\"mapped_gc.xlsx\")"
   ]
  }
 ],
 "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
}
