{"metadata":{"kernelspec":{"language":"python","display_name":"Python 3","name":"python3"},"language_info":{"name":"python","version":"3.10.14","mimetype":"text/x-python","codemirror_mode":{"name":"ipython","version":3},"pygments_lexer":"ipython3","nbconvert_exporter":"python","file_extension":".py"},"kaggle":{"accelerator":"none","dataSources":[],"isInternetEnabled":true,"language":"python","sourceType":"notebook","isGpuEnabled":false}},"nbformat_minor":4,"nbformat":4,"cells":[{"cell_type":"code","source":"# This Python 3 environment comes with many helpful analytics libraries installed\n# It is defined by the kaggle/python Docker image: https://github.com/kaggle/docker-python\n# For example, here's several helpful packages to load\n\nimport numpy as np # linear algebra\nimport pandas as pd # data processing, CSV file I/O (e.g. pd.read_csv)\n\n# Input data files are available in the read-only \"../input/\" directory\n# For example, running this (by clicking run or pressing Shift+Enter) will list all files under the input directory\n\nimport os\nfor dirname, _, filenames in os.walk('/kaggle/input'):\n    for filename in filenames:\n        print(os.path.join(dirname, filename))\n\n# You can write up to 20GB to the current directory (/kaggle/working/) that gets preserved as output when you create a version using \"Save & Run All\" \n# You can also write temporary files to /kaggle/temp/, but they won't be saved outside of the current session","metadata":{"_uuid":"8f2839f25d086af736a60e9eeb907d3b93b6e0e5","_cell_guid":"b1076dfc-b9ad-4769-8c92-a6c4dae69d19","execution":{"iopub.status.busy":"2024-09-25T14:52:14.092770Z","iopub.execute_input":"2024-09-25T14:52:14.093289Z","iopub.status.idle":"2024-09-25T14:52:14.573232Z","shell.execute_reply.started":"2024-09-25T14:52:14.093239Z","shell.execute_reply":"2024-09-25T14:52:14.571910Z"},"trusted":true},"execution_count":1,"outputs":[]},{"cell_type":"code","source":"!git clone https://github.com/SamuelSchmidgall/AgentClinic.git","metadata":{"execution":{"iopub.status.busy":"2024-09-25T14:52:14.575557Z","iopub.execute_input":"2024-09-25T14:52:14.576123Z","iopub.status.idle":"2024-09-25T14:52:15.653874Z","shell.execute_reply.started":"2024-09-25T14:52:14.576078Z","shell.execute_reply":"2024-09-25T14:52:15.652068Z"},"trusted":true},"execution_count":2,"outputs":[{"name":"stdout","text":"fatal: destination path 'AgentClinic' already exists and is not an empty directory.\n","output_type":"stream"}]},{"cell_type":"code","source":"%cd AgentClinic","metadata":{"execution":{"iopub.status.busy":"2024-09-25T14:52:15.656260Z","iopub.execute_input":"2024-09-25T14:52:15.656895Z","iopub.status.idle":"2024-09-25T14:52:15.666970Z","shell.execute_reply.started":"2024-09-25T14:52:15.656823Z","shell.execute_reply":"2024-09-25T14:52:15.665635Z"},"trusted":true},"execution_count":3,"outputs":[{"name":"stdout","text":"/kaggle/working/AgentClinic\n","output_type":"stream"}]},{"cell_type":"code","source":"pip install -r requirements.txt","metadata":{"execution":{"iopub.status.busy":"2024-09-25T14:52:15.669073Z","iopub.execute_input":"2024-09-25T14:52:15.670284Z","iopub.status.idle":"2024-09-25T14:52:29.068707Z","shell.execute_reply.started":"2024-09-25T14:52:15.670149Z","shell.execute_reply":"2024-09-25T14:52:29.066728Z"},"collapsed":true,"jupyter":{"outputs_hidden":true},"trusted":true},"execution_count":4,"outputs":[{"name":"stdout","text":"Requirement already satisfied: regex==2023.12.25 in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 1)) (2023.12.25)\nRequirement already satisfied: openai==0.28.0 in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 2)) (0.28.0)\nRequirement already satisfied: replicate==0.23.1 in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 3)) (0.23.1)\nCollecting argparse (from -r requirements.txt (line 4))\n  Using cached argparse-1.4.0-py2.py3-none-any.whl.metadata (2.8 kB)\nRequirement already satisfied: transformers in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 5)) (4.44.2)\nRequirement already satisfied: datasets in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 6)) (3.0.0)\nRequirement already satisfied: anthropic in /opt/conda/lib/python3.10/site-packages (from -r requirements.txt (line 7)) (0.34.2)\nRequirement already satisfied: requests>=2.20 in /opt/conda/lib/python3.10/site-packages (from openai==0.28.0->-r requirements.txt (line 2)) (2.32.3)\nRequirement already satisfied: tqdm in /opt/conda/lib/python3.10/site-packages (from openai==0.28.0->-r requirements.txt (line 2)) (4.66.4)\nRequirement already satisfied: aiohttp in /opt/conda/lib/python3.10/site-packages (from openai==0.28.0->-r requirements.txt (line 2)) (3.9.5)\nRequirement already satisfied: httpx<1,>=0.21.0 in /opt/conda/lib/python3.10/site-packages (from replicate==0.23.1->-r requirements.txt (line 3)) (0.27.0)\nRequirement already satisfied: packaging in /opt/conda/lib/python3.10/site-packages (from replicate==0.23.1->-r requirements.txt (line 3)) (21.3)\nRequirement already satisfied: pydantic>1 in /opt/conda/lib/python3.10/site-packages (from replicate==0.23.1->-r requirements.txt (line 3)) (2.9.2)\nRequirement already satisfied: typing-extensions>=4.5.0 in /opt/conda/lib/python3.10/site-packages (from replicate==0.23.1->-r requirements.txt (line 3)) (4.12.2)\nRequirement already satisfied: filelock in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (3.15.1)\nRequirement already satisfied: huggingface-hub<1.0,>=0.23.2 in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (0.25.0)\nRequirement already satisfied: numpy>=1.17 in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (1.26.4)\nRequirement already satisfied: pyyaml>=5.1 in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (6.0.2)\nRequirement already satisfied: safetensors>=0.4.1 in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (0.4.5)\nRequirement already satisfied: tokenizers<0.20,>=0.19 in /opt/conda/lib/python3.10/site-packages (from transformers->-r requirements.txt (line 5)) (0.19.1)\nRequirement already satisfied: pyarrow>=15.0.0 in /opt/conda/lib/python3.10/site-packages (from datasets->-r requirements.txt (line 6)) (17.0.0)\nRequirement already satisfied: dill<0.3.9,>=0.3.0 in /opt/conda/lib/python3.10/site-packages (from datasets->-r requirements.txt (line 6)) (0.3.8)\nRequirement already satisfied: pandas in /opt/conda/lib/python3.10/site-packages (from datasets->-r requirements.txt (line 6)) (2.2.2)\nRequirement already satisfied: xxhash in /opt/conda/lib/python3.10/site-packages (from datasets->-r requirements.txt (line 6)) (3.4.1)\nRequirement already satisfied: multiprocess in /opt/conda/lib/python3.10/site-packages (from datasets->-r requirements.txt (line 6)) (0.70.16)\nRequirement already satisfied: fsspec<=2024.6.1,>=2023.1.0 in /opt/conda/lib/python3.10/site-packages (from fsspec[http]<=2024.6.1,>=2023.1.0->datasets->-r requirements.txt (line 6)) (2024.6.1)\nRequirement already satisfied: anyio<5,>=3.5.0 in /opt/conda/lib/python3.10/site-packages (from anthropic->-r requirements.txt (line 7)) (4.4.0)\nRequirement already satisfied: distro<2,>=1.7.0 in /opt/conda/lib/python3.10/site-packages (from anthropic->-r requirements.txt (line 7)) (1.9.0)\nRequirement already satisfied: jiter<1,>=0.4.0 in /opt/conda/lib/python3.10/site-packages (from anthropic->-r requirements.txt (line 7)) (0.5.0)\nRequirement already satisfied: sniffio in /opt/conda/lib/python3.10/site-packages (from anthropic->-r requirements.txt (line 7)) (1.3.1)\nRequirement already satisfied: idna>=2.8 in /opt/conda/lib/python3.10/site-packages (from anyio<5,>=3.5.0->anthropic->-r requirements.txt (line 7)) (3.7)\nRequirement already satisfied: exceptiongroup>=1.0.2 in /opt/conda/lib/python3.10/site-packages (from anyio<5,>=3.5.0->anthropic->-r requirements.txt (line 7)) (1.2.0)\nRequirement already satisfied: aiosignal>=1.1.2 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (1.3.1)\nRequirement already satisfied: attrs>=17.3.0 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (23.2.0)\nRequirement already satisfied: frozenlist>=1.1.1 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (1.4.1)\nRequirement already satisfied: multidict<7.0,>=4.5 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (6.0.5)\nRequirement already satisfied: yarl<2.0,>=1.0 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (1.9.4)\nRequirement already satisfied: async-timeout<5.0,>=4.0 in /opt/conda/lib/python3.10/site-packages (from aiohttp->openai==0.28.0->-r requirements.txt (line 2)) (4.0.3)\nRequirement already satisfied: certifi in /opt/conda/lib/python3.10/site-packages (from httpx<1,>=0.21.0->replicate==0.23.1->-r requirements.txt (line 3)) (2024.8.30)\nRequirement already satisfied: httpcore==1.* in /opt/conda/lib/python3.10/site-packages (from httpx<1,>=0.21.0->replicate==0.23.1->-r requirements.txt (line 3)) (1.0.5)\nRequirement already satisfied: h11<0.15,>=0.13 in /opt/conda/lib/python3.10/site-packages (from httpcore==1.*->httpx<1,>=0.21.0->replicate==0.23.1->-r requirements.txt (line 3)) (0.14.0)\nRequirement already satisfied: pyparsing!=3.0.5,>=2.0.2 in /opt/conda/lib/python3.10/site-packages (from packaging->replicate==0.23.1->-r requirements.txt (line 3)) (3.1.2)\nRequirement already satisfied: annotated-types>=0.6.0 in /opt/conda/lib/python3.10/site-packages (from pydantic>1->replicate==0.23.1->-r requirements.txt (line 3)) (0.7.0)\nRequirement already satisfied: pydantic-core==2.23.4 in /opt/conda/lib/python3.10/site-packages (from pydantic>1->replicate==0.23.1->-r requirements.txt (line 3)) (2.23.4)\nRequirement already satisfied: charset-normalizer<4,>=2 in /opt/conda/lib/python3.10/site-packages (from requests>=2.20->openai==0.28.0->-r requirements.txt (line 2)) (3.3.2)\nRequirement already satisfied: urllib3<3,>=1.21.1 in /opt/conda/lib/python3.10/site-packages (from requests>=2.20->openai==0.28.0->-r requirements.txt (line 2)) (1.26.18)\nRequirement already satisfied: python-dateutil>=2.8.2 in /opt/conda/lib/python3.10/site-packages (from pandas->datasets->-r requirements.txt (line 6)) (2.9.0.post0)\nRequirement already satisfied: pytz>=2020.1 in /opt/conda/lib/python3.10/site-packages (from pandas->datasets->-r requirements.txt (line 6)) (2024.1)\nRequirement already satisfied: tzdata>=2022.7 in /opt/conda/lib/python3.10/site-packages (from pandas->datasets->-r requirements.txt (line 6)) (2024.1)\nRequirement already satisfied: six>=1.5 in /opt/conda/lib/python3.10/site-packages (from python-dateutil>=2.8.2->pandas->datasets->-r requirements.txt (line 6)) (1.16.0)\nUsing cached argparse-1.4.0-py2.py3-none-any.whl (23 kB)\nInstalling collected packages: argparse\nSuccessfully installed argparse-1.4.0\nNote: you may need to restart the kernel to use updated packages.\n","output_type":"stream"}]},{"cell_type":"markdown","source":"# We will modify the agentclinic.py from https://github.com/samuelschmidgall/agentclinic","metadata":{}},{"cell_type":"markdown","source":"# Fix environment to get the same symptoms of the patient for the 2 doctors","metadata":{}},{"cell_type":"code","source":"import argparse\nimport anthropic\nfrom transformers import pipeline\nimport openai, re, random, time, json, replicate, os\n\nllama2_url = \"meta/llama-2-70b-chat\"\nllama3_url = \"meta/meta-llama-3-70b-instruct\"\nmixtral_url = \"mistralai/mixtral-8x7b-instruct-v0.1\"\n\ndef load_huggingface_model(model_name):\n    pipe = pipeline(\"text-generation\", model=model_name, device_map=\"auto\")\n    return pipe\n\ndef inference_huggingface(prompt, pipe):\n    response = pipe(prompt, max_new_tokens=100)[0][\"generated_text\"]\n    response = response.replace(prompt, \"\")\n    return response\n\n\ndef query_model(model_str, prompt, system_prompt, tries=30, timeout=20.0, image_requested=False, scene=None, max_prompt_len=2**14, clip_prompt=False):\n    if model_str not in [\"gpt4\", \"gpt3.5\", \"gpt4o\", 'llama-2-70b-chat', \"mixtral-8x7b\", \"gpt-4o-mini\", \"llama-3-70b-instruct\", \"gpt4v\", \"claude3.5sonnet\", \"o1-preview\"] and \"_HF\" not in model_str:\n        raise Exception(\"No model by the name {}\".format(model_str))\n    for _ in range(tries):\n        if clip_prompt: prompt = prompt[:max_prompt_len]\n        try:\n            if image_requested:\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \n                    \"content\": [\n                        {\"type\": \"text\", \"text\": prompt},\n                        {\"type\": \"image_url\",\n                            \"image_url\": {\n                                \"url\": \"{}\".format(scene.image_url),\n                            },\n                        },\n                    ]},]\n                if model_str == \"gpt4v\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4-vision-preview\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt-4o-mini\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4o-mini\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt4\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4-turbo\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt4o\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4o\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n            if model_str == \"gpt4\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4-turbo-preview\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt4v\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4-vision-preview\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt-4o-mini\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4o-mini\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"o1-preview\":\n                messages = [\n                    {\"role\": \"user\", \"content\": system_prompt + prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"o1-preview-2024-09-12\",\n                        messages=messages,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt3.5\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-3.5-turbo\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"claude3.5sonnet\":\n                client = anthropic.Anthropic(api_key=os.environ[\"ANTHROPIC_API_KEY\"])\n                message = client.messages.create(\n                    model=\"claude-3-5-sonnet-20240620\",\n                    system=system_prompt,\n                    max_tokens=256,\n                    messages=[{\"role\": \"user\", \"content\": prompt}])\n                answer = json.loads(message.to_json())[\"content\"][0][\"text\"]\n            elif model_str == \"gpt4o\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4o\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'llama-2-70b-chat':\n                output = replicate.run(\n                    llama2_url, input={\n                        \"prompt\":  prompt, \n                        \"system_prompt\": system_prompt,\n                        \"max_new_tokens\": 200})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'mixtral-8x7b':\n                output = replicate.run(\n                    mixtral_url, \n                    input={\"prompt\": prompt, \n                            \"system_prompt\": system_prompt,\n                            \"max_new_tokens\": 75})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'llama-3-70b-instruct':\n                output = replicate.run(\n                    llama3_url, input={\n                        \"prompt\":  prompt, \n                        \"system_prompt\": system_prompt,\n                        \"max_new_tokens\": 200})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif \"HF_\" in model_str:\n                input_text = system_prompt + prompt \n                #if self.pipe is None:\n                #    self.pipe = load_huggingface_model(self.backend.replace(\"HF_\", \"\"))\n                raise Exception(\"Sorry, fixing TODO :3\") #inference_huggingface(input_text, self.pipe)\n            return answer\n        \n        except Exception as e:\n            time.sleep(timeout)\n            continue\n    raise Exception(\"Max retries: timeout\")\n\n\n\nclass ScenarioMedQA:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMedQA:\n    def __init__(self) -> None:\n        with open(\"agentclinic_medqa.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMedQA(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n        self.scenario_count = 0 # Add\n    \n    def sample_scenario(self):\n        # return self.scenarios[random.randint(0, len(self.scenarios)-1)] # Remove\n        self.scenario_count += 1 # Add\n        return self.scenarios[self.scenario_count] # Add\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n        \n\n\nclass ScenarioMedQAExtended:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMedQAExtended:\n    def __init__(self) -> None:\n        with open(\"agentclinic_medqa_extended.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMedQAExtended(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n        \n\n\nclass ScenarioMIMICIVQA:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMIMICIV:\n    def __init__(self) -> None:\n        with open(\"agentclinic_mimiciv.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMIMICIVQA(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass ScenarioNEJMExtended:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict \n        self.question = scenario_dict[\"question\"] \n        self.image_url = scenario_dict[\"image_url\"] \n        self.diagnosis = [_sd[\"text\"] \n            for _sd in scenario_dict[\"answers\"] if _sd[\"correct\"]][0]\n        self.patient_info = scenario_dict[\"patient_info\"]\n        self.physical_exams = scenario_dict[\"physical_exams\"]\n\n    def patient_information(self) -> str:\n        patient_info = self.patient_info\n        return patient_info\n\n    def examiner_information(self) -> str:\n        return \"What is the most likely diagnosis?\"\n    \n    def exam_information(self) -> str:\n        exams = self.physical_exams\n        return exams\n    \n    def diagnosis_information(self) -> str:\n        return self.diagnosis\n\n\nclass ScenarioLoaderNEJMExtended:\n    def __init__(self) -> None:\n        with open(\"agentclinic_nejm_extended.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioNEJMExtended(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass ScenarioNEJM:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict \n        self.question = scenario_dict[\"question\"] \n        self.image_url = scenario_dict[\"image_url\"] \n        self.diagnosis = [_sd[\"text\"] \n            for _sd in scenario_dict[\"answers\"] if _sd[\"correct\"]][0]\n        self.patient_info = scenario_dict[\"patient_info\"]\n        self.physical_exams = scenario_dict[\"physical_exams\"]\n\n    def patient_information(self) -> str:\n        patient_info = self.patient_info\n        return patient_info\n\n    def examiner_information(self) -> str:\n        return \"What is the most likely diagnosis?\"\n    \n    def exam_information(self) -> str:\n        exams = self.physical_exams\n        return exams\n    \n    def diagnosis_information(self) -> str:\n        return self.diagnosis\n\n\nclass ScenarioLoaderNEJM:\n    def __init__(self) -> None:\n        with open(\"agentclinic_nejm.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioNEJM(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass PatientAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\", bias_present=None) -> None:\n        # disease of patient, or \"correct answer\"\n        self.disease = \"\"\n        # symptoms that patient presents\n        self.symptoms = \"\"\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # language model backend for patient agent\n        self.backend = backend_str\n        # presentation of any form of bias\n        self.bias_present = (None if bias_present == \"None\" else bias_present)\n        # sample initial question from dataset\n        self.scenario = scenario\n        self.reset()\n        self.pipe = None\n\n        self.biases = [\"recency\", \"frequency\", \"false_consensus\", \"self_diagnosis\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"]\n\n    def generate_bias(self) -> str:\n        \"\"\" \n        ================\n        Cognitive biases \n        ================\n        \"\"\"\n        if self.bias_present == \"recency\":\n            return \"\\nRecently, you had a friend with similar symptoms to yours that was diagnosed with cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"frequency\":\n            return \"\\nYou recently learned that most frequently, doctors diagnose this as cancer based on past cases. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"false_consensus\":\n            return \"\\nMost of your friends who heard about your symptoms believe that you have cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"self_diagnosis\":\n            return \"\\nYou recently performed a thorough investigation of your symptoms online and have come to the conclusion that you should be diagnosed with cancer. While the doctor may believe otherwise you remain convinced you have cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"gender\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular gender and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"race\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular race and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"sexual_orientation\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular sexual orientation and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"cultural\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are from a particular culture and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"education\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they went to a low ranked medical school and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"religion\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they believe in a particular religion and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"socioeconomic\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are from a particular socioeconomic background and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present is None:\n            pass\n        else:\n            print(\"BIAS TYPE {} NOT SUPPORTED, ignoring bias...\".format(self.bias_present))\n        return \"\"\n\n    def inference_patient(self, question) -> str:\n        answer = query_model(self.backend, \"\\nHere is a history of your dialogue: \" + self.agent_hist + \"\\n Here was the doctor response: \" + question + \"Now please continue your dialogue\\nPatient: \", self.system_prompt())\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        return answer\n\n    def system_prompt(self) -> str:\n        bias_prompt = \"\"\n        if self.bias_present is not None:\n            bias_prompt = self.generate_bias()\n        base = \"\"\"You are a patient in a clinic who only responds in the form of dialogue. You are being inspected by a doctor who will ask you questions and will perform exams on you in order to understand your disease. Your answer will only be 1-3 sentences in length.\"\"\"\n        symptoms = \"\\n\\nBelow is all of your information. {}. \\n\\n Remember, you must not reveal your disease explicitly but may only convey the symptoms you have in the form of dialogue if you are asked.\".format(self.symptoms)\n        return base + bias_prompt + symptoms\n    \n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.symptoms = self.scenario.patient_information()\n\n    def add_hist(self, hist_str) -> None:\n        self.agent_hist += hist_str + \"\\n\\n\"\n\n\nclass DoctorAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\", max_infs=20, bias_present=None, img_request=False) -> None:\n        # number of inference calls to the doctor\n        self.infs = 0\n        # maximum number of inference calls to the doctor\n        self.MAX_INFS = max_infs\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # presentation information for doctor\n        self.presentation = \"\"\n        # language model backend for doctor agent\n        self.backend = backend_str\n        # presentation of any form of bias\n        self.bias_present = (None if bias_present == \"None\" else bias_present)\n        # prepare initial conditions for LLM\n        self.scenario = scenario\n        self.reset()\n        self.pipe = None\n        self.img_request = img_request\n        self.biases = [\"recency\", \"frequency\", \"false_consensus\", \"confirmation\", \"status_quo\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"]\n\n    def generate_bias(self) -> str:\n        \"\"\" \n        ================\n        Cognitive biases \n        ================\n        \"\"\"\n        if self.bias_present == \"recency\":\n            return \"\\nRecently, you learned that a doctor with similar symptoms to the patient that diagnosed their patient with cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"frequency\":\n            return \"\\nYou recently learned that most frequently, doctors diagnose patients with similar symptoms with cancer based on past cases. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"false_consensus\":\n            return \"\\nMost of your colleagues who heard about the patient's symptoms believe that they have cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"status_quo\":\n            return \"\\nYour hosptial has been diagnosing these patient's symptoms with cancer for the past 10 years. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"confirmation\":\n            return \"\\nYou are initially confident that the patient has cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"gender\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular gender and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"race\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular race and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"sexual_orientation\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular sexual orientation and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"cultural\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are from a particular culture and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"education\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they went to a low ranked medical school and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"religion\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they believe in a particular religion and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"socioeconomic\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are from a particular socioeconomic background and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present is None:\n            pass\n        else:\n            print(\"BIAS TYPE {} NOT SUPPORTED, ignoring bias...\".format(self.bias_present))\n        return \"\"\n\n    def inference_doctor(self, question, image_requested=False) -> str:\n        answer = str()\n        if self.infs >= self.MAX_INFS: return \"Maximum inferences reached\"\n        answer = query_model(self.backend, \"\\nHere is a history of your dialogue: \" + self.agent_hist + \"\\n Here was the patient response: \" + question + \"Now please continue your dialogue\\nDoctor: \", self.system_prompt(), image_requested=image_requested, scene=self.scenario)\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        self.infs += 1\n        return answer\n\n    def system_prompt(self) -> str:\n        bias_prompt = \"\"\n        if self.bias_present is not None:\n            bias_prompt = self.generate_bias()\n        base = \"You are a doctor named Dr. Agent who only responds in the form of dialogue. You are inspecting a patient who you will ask questions in order to understand their disease. You are only allowed to ask {} questions total before you must make a decision. You have asked {} questions so far. You can request test results using the format \\\"REQUEST TEST: [test]\\\". For example, \\\"REQUEST TEST: Chest_X-Ray\\\". Your dialogue will only be 1-3 sentences in length. Once you have decided to make a diagnosis please type \\\"DIAGNOSIS READY: [diagnosis here]\\\"\".format(self.MAX_INFS, self.infs) + (\"You may also request medical images related to the disease to be returned with \\\"REQUEST IMAGES\\\".\" if self.img_request else \"\")\n        presentation = \"\\n\\nBelow is all of the information you have. {}. \\n\\n Remember, you must discover their disease by asking them questions. You are also able to provide exams.\".format(self.presentation)\n        return base + bias_prompt + presentation\n\n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.presentation = self.scenario.examiner_information()\n\n\nclass MeasurementAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\") -> None:\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # presentation information for measurement \n        self.presentation = \"\"\n        # language model backend for measurement agent\n        self.backend = backend_str\n        # prepare initial conditions for LLM\n        self.scenario = scenario\n        self.pipe = None\n        self.reset()\n\n    def inference_measurement(self, question) -> str:\n        answer = str()\n        answer = query_model(self.backend, \"\\nHere is a history of the dialogue: \" + self.agent_hist + \"\\n Here was the doctor measurement request: \" + question, self.system_prompt())\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        return answer\n\n    def system_prompt(self) -> str:\n        base = \"You are an measurement reader who responds with medical test results. Please respond in the format \\\"RESULTS: [results here]\\\"\"\n        presentation = \"\\n\\nBelow is all of the information you have. {}. \\n\\n If the requested results are not in your data then you can respond with NORMAL READINGS.\".format(self.information)\n        return base + presentation\n    \n    def add_hist(self, hist_str) -> None:\n        self.agent_hist += hist_str + \"\\n\\n\"\n\n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.information = self.scenario.exam_information()\n\n\ndef compare_results(diagnosis, correct_diagnosis, moderator_llm, mod_pipe):\n    answer = query_model(moderator_llm, \"\\nHere is the correct diagnosis: \" + correct_diagnosis + \"\\n Here was the doctor dialogue: \" + diagnosis + \"\\nAre these the same?\", \"You are responsible for determining if the corrent diagnosis and the doctor diagnosis are the same disease. Please respond only with Yes or No. Nothing else.\")\n    return answer.lower()\n\n\ndef main(api_key, replicate_api_key, inf_type, doctor_bias, patient_bias, doctor_llm, patient_llm, measurement_llm, moderator_llm, num_scenarios, dataset, img_request, total_inferences, anthropic_api_key=None):\n    openai.api_key = api_key\n    anthropic_llms = [\"claude3.5sonnet\"]\n    replicate_llms = [\"llama-3-70b-instruct\", \"llama-2-70b-chat\", \"mixtral-8x7b\"]\n    if patient_llm in replicate_llms or doctor_llm in replicate_llms:\n        os.environ[\"REPLICATE_API_TOKEN\"] = replicate_api_key\n    if doctor_llm in anthropic_llms:\n        os.environ[\"ANTHROPIC_API_KEY\"] = anthropic_api_key\n\n    # Load MedQA, MIMICIV or NEJM agent case scenarios\n    if dataset == \"MedQA\":\n        scenario_loader = ScenarioLoaderMedQA()\n    elif dataset == \"MedQA_Ext\":\n        scenario_loader = ScenarioLoaderMedQAExtended()\n    elif dataset == \"NEJM\":\n        scenario_loader = ScenarioLoaderNEJM()\n    elif dataset == \"NEJM_Ext\":\n        scenario_loader = ScenarioLoaderNEJMExtended()\n    elif dataset == \"MIMICIV\":\n        scenario_loader = ScenarioLoaderMIMICIV()\n    else:\n        raise Exception(\"Dataset {} does not exist\".format(str(dataset)))\n    total_correct = 0\n    total_presents = 0\n\n    # Pipeline for huggingface models\n    if \"HF_\" in moderator_llm:\n        pipe = load_huggingface_model(moderator_llm.replace(\"HF_\", \"\"))\n    else:\n        pipe = None\n\n    for _scenario_id in range(0, min(num_scenarios, scenario_loader.num_scenarios)):\n        total_presents += 1\n        pi_dialogue = str()\n        # Initialize scenarios (MedQA/NEJM)\n        scenario =  scenario_loader.get_scenario(id=_scenario_id)\n        # Initialize agents\n        meas_agent = MeasurementAgent(\n            scenario=scenario,\n            backend_str=measurement_llm)\n        patient_agent = PatientAgent(\n            scenario=scenario, \n            bias_present=patient_bias,\n            backend_str=patient_llm)\n        doctor_agent = DoctorAgent(\n            scenario=scenario, \n            bias_present=doctor_bias,\n            backend_str=doctor_llm,\n            max_infs=total_inferences, \n            img_request=img_request)\n\n        doctor_dialogue = \"\"\n        for _inf_id in range(total_inferences):\n            # Check for medical image request\n            if dataset == \"NEJM\":\n                if img_request:\n                    imgs = \"REQUEST IMAGES\" in doctor_dialogue\n                else: imgs = True\n            else: imgs = False\n            # Check if final inference\n            if _inf_id == total_inferences - 1:\n                pi_dialogue += \"This is the final question. Please provide a diagnosis.\\n\"\n            # Obtain doctor dialogue (human or llm agent)\n            if inf_type == \"human_doctor\":\n                doctor_dialogue = input(\"\\nQuestion for patient: \")\n            else: \n                doctor_dialogue = doctor_agent.inference_doctor(pi_dialogue, image_requested=imgs)\n            print(\"Doctor [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), doctor_dialogue)\n            # Doctor has arrived at a diagnosis, check correctness\n            if \"DIAGNOSIS READY\" in doctor_dialogue:\n                correctness = compare_results(doctor_dialogue, scenario.diagnosis_information(), moderator_llm, pipe) == \"yes\"\n                if correctness: total_correct += 1\n                print(\"\\nCorrect answer:\", scenario.diagnosis_information())\n                print(\"Scene {}, The diagnosis was \".format(_scenario_id), \"CORRECT\" if correctness else \"INCORRECT\", int((total_correct/total_presents)*100))\n                break\n            # Obtain medical exam from measurement reader\n            if \"REQUEST TEST\" in doctor_dialogue:\n                pi_dialogue = meas_agent.inference_measurement(doctor_dialogue,)\n                print(\"Measurement [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), pi_dialogue)\n                patient_agent.add_hist(pi_dialogue)\n            # Obtain response from patient\n            else:\n                if inf_type == \"human_patient\":\n                    pi_dialogue = input(\"\\nResponse to doctor: \")\n                else:\n                    pi_dialogue = patient_agent.inference_patient(doctor_dialogue)\n                print(\"Patient [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), pi_dialogue)\n                meas_agent.add_hist(pi_dialogue)\n            # Prevent API timeouts\n            time.sleep(1.0)","metadata":{"execution":{"iopub.status.busy":"2024-09-25T15:46:55.383432Z","iopub.execute_input":"2024-09-25T15:46:55.384036Z","iopub.status.idle":"2024-09-25T15:46:55.493956Z","shell.execute_reply.started":"2024-09-25T15:46:55.383975Z","shell.execute_reply":"2024-09-25T15:46:55.492191Z"},"jupyter":{"source_hidden":true},"trusted":true},"execution_count":13,"outputs":[]},{"cell_type":"markdown","source":"1. GPT4","metadata":{}},{"cell_type":"code","source":"# if __name__ == \"__main__\":\n#     parser = argparse.ArgumentParser(description='Medical Diagnosis Simulation CLI')\n#     parser.add_argument('--openai_api_key', type=str, required=False, help='OpenAI API Key')\n#     parser.add_argument('--replicate_api_key', type=str, required=False, help='Replicate API Key')\n#     parser.add_argument('--inf_type', type=str, choices=['llm', 'human_doctor', 'human_patient'], default='llm')\n#     parser.add_argument('--doctor_bias', type=str, help='Doctor bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"confirmation\", \"status_quo\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--patient_bias', type=str, help='Patient bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"self_diagnosis\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--doctor_llm', type=str, default='gpt4')\n#     parser.add_argument('--patient_llm', type=str, default='gpt4')\n#     parser.add_argument('--measurement_llm', type=str, default='gpt4')\n#     parser.add_argument('--moderator_llm', type=str, default='gpt4')\n#     parser.add_argument('--agent_dataset', type=str, default='MedQA') # MedQA, MIMICIV or NEJM\n#     parser.add_argument('--doctor_image_request', type=bool, default=False) # whether images must be requested or are provided\n#     parser.add_argument('--num_scenarios', type=int, default=15, required=False, help='Number of scenarios to simulate')\n#     parser.add_argument('--total_inferences', type=int, default=20, required=False, help='Number of inferences between patient and doctor')\n#     parser.add_argument('--anthropic_api_key', type=str, default=None, required=False, help='Anthropic API key for Claude 3.5 Sonnet')\n    \n#     args = parser.parse_args()\n    \n    # python3 agentclinic.py --openai_api_key \"YOUR_OPENAIAPI_KEY\" --inf_type \"llm\"\n\n    # main(args.openai_api_key, args.replicate_api_key, args.inf_type, args.doctor_bias, args.patient_bias, args.doctor_llm, args.patient_llm, args.measurement_llm, args.moderator_llm, args.num_scenarios, args.agent_dataset, args.doctor_image_request, args.total_inferences, args.anthropic_api_key)\nmy_openai_api_key = \"YOUR_OPENAIAPI_KEY\"\nmy_replicate_api_key = \"\"\nmy_inf_type = \"llm\"\nmy_doctor_bias = 'None'\nmy_patient_bias = 'None'\nmy_doctor_llm = 'gpt4'\nmy_patient_llm = 'gpt4'\nmy_measurement_llm = 'gpt4'\nmy_moderator_llm = 'gpt4'\nmy_agent_dataset = 'MedQA'\nmy_doctor_image_request = False\nmy_num_scenarios = 15\nmy_total_inferences = 20\nmy_anthropic_api_key = None\n\nmain(my_openai_api_key, my_replicate_api_key, my_inf_type, my_doctor_bias, my_patient_bias, my_doctor_llm, my_patient_llm, my_measurement_llm, my_moderator_llm, my_num_scenarios, my_agent_dataset, my_doctor_image_request, my_total_inferences, my_anthropic_api_key)","metadata":{"execution":{"iopub.status.busy":"2024-09-25T16:15:03.414038Z","iopub.execute_input":"2024-09-25T16:15:03.414583Z","iopub.status.idle":"2024-09-25T16:36:53.722399Z","shell.execute_reply.started":"2024-09-25T16:15:03.414538Z","shell.execute_reply":"2024-09-25T16:36:53.721036Z"},"collapsed":true,"jupyter":{"outputs_hidden":true},"trusted":true},"execution_count":15,"outputs":[{"name":"stdout","text":"Doctor [5%]: Hello, I'm Dr. Agent. Can you tell me how long you've been experiencing these symptoms?\nPatient [5%]: It's been about a month now since I started noticing these symptoms.\nDoctor [10%]: Have your symptoms been getting progressively worse over this month, or have they remained about the same?\nPatient [10%]: They've remained about the same overall, but I've noticed they get worse after I've been active for a while and then tend to improve after I rest.\nDoctor [15%]: Do you experience any difficulty swallowing or changes in your voice?\nPatient [15%]: No, I haven't had any trouble swallowing or noticed any changes in my voice.\nDoctor [20%]: Have you noticed any muscle weakness in your face, such as difficulty smiling or closing your eyes?\nPatient [20%]: No, I haven't noticed any weakness in my face. My main issues have been with my eyes and my arms, especially when trying to do things like climb stairs or brush my hair.\nDoctor [25%]: Do you have any other symptoms that you haven't mentioned yet, such as changes in sensation, balance issues, or changes in your breathing?\nPatient [25%]: No, I haven't experienced any changes in sensation, balance issues, or changes in my breathing. Everything seems to be related to my muscles getting tired easily.\nDoctor [30%]: Have you experienced any muscle pain or cramps along with the weakness and tiredness?\nPatient [30%]: No, I haven't experienced any muscle pain or cramps, just the weakness and tiredness, especially after physical activity.\nDoctor [35%]: Have you had any recent infections or illnesses before these symptoms started?\nPatient [35%]: No, I haven't had any recent infections or illnesses before these symptoms started.\nDoctor [40%]: Have you or anyone in your family had similar symptoms or been diagnosed with a neurological condition?\nPatient [40%]: No, there's no history of similar symptoms or neurological conditions in my family that I'm aware of.\nDoctor [45%]: Have you noticed if the double vision is constant or does it seem to improve with rest, similar to your muscle weakness?\nPatient [45%]: Yes, the double vision does seem to improve with rest, similar to the muscle weakness. It's more noticeable and bothersome after I've been active for a while.\nDoctor [50%]: Have you noticed any patterns in the timing of your symptoms, such as them being more pronounced in the morning or evening?\nPatient [50%]: Actually, I've noticed that my symptoms tend to be less pronounced in the morning and get worse as the day goes on, especially if I've been physically active throughout the day.\nDoctor [55%]: Have you been experiencing any issues with your breathing or changes in your heartbeat, like shortness of breath or palpitations, especially during these periods of increased weakness?\nPatient [55%]: No, I haven't experienced any issues with my breathing or changes in my heartbeat, like shortness of breath or palpitations, even when my weakness increases.\nDoctor [60%]: Given your symptoms and their progression, it's important to check for any specific antibodies that might be affecting your muscles. REQUEST TEST: Acetylcholine Receptor Antibody Test. This will help us understand if your condition is related to a problem with nerve-muscle signal transmission.\nMeasurement [60%]: RESULTS: Acetylcholine Receptor Antibodies: Present (elevated)\nDoctor [65%]: Given the presence of acetylcholine receptor antibodies, have you noticed any improvement in your symptoms after taking any medications, even if temporarily?\nPatient [65%]: I haven't started any specific medications for these symptoms yet, so I can't say if there's been any improvement from medication.\nDoctor [70%]: Given the test results and your symptoms, it's crucial to consider your daily activities. Have you found that stress or heat affects your symptoms in any way?\nPatient [70%]: Yes, I've noticed that stress definitely makes my symptoms worse. And on hotter days, my weakness seems to be more pronounced, especially the difficulty with climbing stairs and the double vision.\nDoctor [75%]: Given the impact of stress and heat on your symptoms, have you tried any interventions or lifestyle changes to help manage these triggers?\nPatient [75%]: I've tried to reduce stress by practicing mindfulness and taking short breaks during work, especially since I spend a lot of time in front of a computer. I also try to stay cool on hot days by staying indoors with air conditioning and staying hydrated, but I haven't made any major lifestyle changes beyond that.\nDoctor [80%]: Given your efforts to manage stress and stay cool, have you noticed any difference in your symptoms with these interventions, even if slight?\nPatient [80%]: Yes, I've noticed a slight improvement in my symptoms with these interventions. The mindfulness and breaks seem to help reduce the severity of my symptoms on stressful days, and staying cool definitely helps on hot days, though the improvements are modest.\nDoctor [85%]: Given the slight improvement with stress management and staying cool, it's important to consider all aspects of your condition. Have you noticed any issues with your vision, such as difficulty focusing or adjusting to different light levels, beyond the double vision?\nPatient [85%]: No, beyond the double vision, I haven't noticed any difficulty focusing or adjusting to different light levels. My main issue with my vision has just been the double vision.\nDoctor [90%]: Given all the information we've discussed, it seems like your symptoms are quite specific and have a pattern. Before we proceed to a diagnosis, can you tell me if you've experienced any changes in your weight or appetite since these symptoms began?\nPatient [90%]: No, I haven't experienced any significant changes in my weight or appetite since these symptoms began.\nDoctor [95%]: Thank you for sharing all of this information with me. It's been very helpful in understanding your condition better. Given the presence of acetylcholine receptor antibodies and your symptoms, I believe we have enough information to make a diagnosis. DIAGNOSIS READY: Myasthenia Gravis.\n\nCorrect answer: Myasthenia gravis\nScene 0, The diagnosis was  CORRECT 100\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me when you first noticed the gait and limb ataxia?\nPatient [5%]: It started subtly a few months ago but has become more noticeable over the past few weeks. My friends were the first to point it out, saying I looked like I was walking unsteadily, almost as if I had been drinking.\nDoctor [10%]: Have you experienced any changes in your vision or had any issues with your speech recently?\nPatient [10%]: No, my vision and speech have been normal. It's really just the walking and coordination that seem to be off.\nDoctor [15%]: Have you had any numbness, tingling, or weakness in your limbs?\nPatient [15%]: Yes, I've noticed some weakness, especially in my right arm. It's not as strong as it used to be, and sometimes I have trouble gripping things or doing tasks that require fine motor skills.\nDoctor [20%]: Have you experienced any changes in your balance or had any falls because of these issues?\nPatient [20%]: Yes, my balance has definitely been off. I haven't had any falls yet, thankfully, but I've had a few close calls where I've stumbled or had to catch myself to prevent falling.\nDoctor [25%]: Have you noticed any changes in your ability to swallow or any differences in your speech that others might not have noticed?\nPatient [25%]: No, I haven't noticed any changes in my ability to swallow or in my speech. It's really just the balance and coordination issues that have been a problem.\nDoctor [30%]: Have you had any family members with similar symptoms or diagnosed neurological conditions?\nPatient [30%]: No, there's no history of similar symptoms or diagnosed neurological conditions in my family that I'm aware of.\nDoctor [35%]: Have you had any recent infections, fevers, or illnesses that seemed out of the ordinary before these symptoms started?\nPatient [35%]: No, I haven't had any recent infections, fevers, or unusual illnesses before these symptoms started. Everything seemed pretty normal until I began noticing these issues with my walking and coordination.\nDoctor [40%]: Have you been exposed to any toxins or chemicals, either at work or at home, that you're aware of?\nPatient [40%]: No, I haven't been exposed to any unusual toxins or chemicals at work or at home that I'm aware of. Everything in my environment has been pretty consistent.\nDoctor [45%]: Have you experienced any cognitive changes, such as memory loss, difficulty concentrating, or changes in your thinking patterns?\nPatient [45%]: No, I haven't noticed any cognitive changes like memory loss or difficulty concentrating. My thinking patterns seem to be the same as they've always been.\nDoctor [50%]: Have you noticed any changes in your mood or behavior recently, such as feeling more anxious or depressed than usual?\nPatient [50%]: No, I haven't noticed any significant changes in my mood or behavior. I've been more frustrated than usual, but I think that's mainly due to the difficulties I've been experiencing with my walking and coordination.\nDoctor [55%]: Have you experienced any changes in your hearing, such as ringing in the ears or difficulty hearing?\nPatient [55%]: No, I haven't experienced any changes in my hearing. There's been no ringing in my ears or difficulty hearing anything.\nDoctor [60%]: Have you had any issues with urinary incontinence or urgency that's new or unusual for you?\nPatient [60%]: No, I haven't had any issues with urinary incontinence or urgency. Everything seems normal in that regard.\nDoctor [65%]: Have you noticed any muscle stiffness or spasms, particularly in the limbs affected by weakness?\nPatient [65%]: No, I haven't noticed any muscle stiffness or spasms in my limbs, even the ones that feel weaker. It's mainly just the weakness and coordination problems that I've been dealing with.\nDoctor [70%]: Have you experienced any difficulty with your reflexes, such as them being either too slow or too quick?\nPatient [70%]: I haven't really noticed anything specific about my reflexes, but I feel like my reactions might be a bit slower, especially when I try to catch something or react quickly to avoid stumbling.\nDoctor [75%]: Have you had any recent head injuries or traumas that might explain these symptoms?\nPatient [75%]: No, I haven't had any recent head injuries or traumas. These symptoms seemed to have started without any obvious cause like that.\nDoctor [80%]: Have you noticed any difficulty with your vision at night or in low light conditions that you haven't mentioned yet?\nPatient [80%]: No, I haven't noticed any difficulty with my vision at night or in low light conditions. My vision seems to be the same as it has always been, without any noticeable changes.\nDoctor [85%]: Have you experienced any significant weight loss or changes in your appetite recently?\nPatient [85%]: No, I haven't experienced any significant weight loss or changes in my appetite recently. Everything has been pretty stable in that regard.\nDoctor [90%]: Have you been experiencing any unusual fatigue or tiredness that doesn't seem to be related to your activity level?\nPatient [90%]: Yes, I have been feeling unusually tired, more so than usual. It doesn't seem to matter how much I rest; I still feel drained.\nDoctor [95%]: Given your symptoms of gait and limb ataxia, weakness, and unusual fatigue, it's important we look into a few possibilities that could be causing these issues. REQUEST TEST: MRI of the brain and spinal cord REQUEST TEST: Comprehensive blood panel, including vitamin B12 levels, thyroid function tests, and a complete blood count (CBC)\nMeasurement [95%]: RESULTS: MRI_Brain: Findings consistent with Progressive Multifocal Encephalopathy (PML). T1/T2 images showing multifocal demyelinating lesions without gadolinium enhancement, indicative of PML. Vital_Signs: Temperature Normothermic, Blood Pressure Within normal range, Heart Rate Within normal range, Respiratory Rate Within normal range. Neurological_Examination: Gait Assessment Ataxic gait noted. Right Upper Limb Strength 4/5. Coordination Tests Evidence of ataxia. Comprehensive blood panel, including vitamin B12 levels, thyroid function tests, and a complete blood count (CBC): NORMAL READINGS.\nDoctor [100%]: DIAGNOSIS READY: Progressive Multifocal Leukoencephalopathy (PML)\n\nCorrect answer: Progressive multifocal encephalopathy (PML)\nScene 1, The diagnosis was  CORRECT 100\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me more about the feeding difficulties your child is experiencing?\nPatient [5%]: Well, he's been fussier than usual and doesn't seem as interested in his feedings. It's been harder to get him to eat the past few days.\nDoctor [10%]: Has your child had any vomiting or diarrhea along with the feeding difficulties?\nPatient [10%]: No, he hasn't had any vomiting or diarrhea.\nDoctor [15%]: Has your child experienced any weight loss or failure to gain weight as expected?\nPatient [15%]: Actually, despite eating less, it seems like he's been gaining weight. It's a bit confusing.\nDoctor [20%]: Has your child had any changes in bowel movements, such as constipation or the appearance of the stools?\nPatient [20%]: No, there haven't been any noticeable changes in his bowel movements. Everything seems normal in that regard.\nDoctor [25%]: Has your child had any fever or signs of infection recently?\nPatient [25%]: No, he hasn't had any fever or signs of infection.\nDoctor [30%]: Has your child been more irritable or crying more than usual, especially during or after feedings?\nPatient [30%]: Yes, he's definitely been more irritable and cries a lot, especially when his belly seems to bother him.\nDoctor [35%]: Has your child's belly seemed swollen or harder than usual?\nPatient [35%]: Yes, his belly does seem a bit swollen and feels hard when I touch it.\nDoctor [40%]: Has your child had any difficulty breathing or changes in his breathing patterns, especially after feedings?\nPatient [40%]: No, there haven't been any noticeable changes in his breathing patterns, even after feedings.\nDoctor [45%]: Has your child had any exposure to new foods or formulas recently that might explain the feeding difficulties and abdominal distension?\nPatient [45%]: No, we haven't introduced any new foods or formulas recently. Everything has been pretty consistent with his diet.\nDoctor [50%]: Has your child had any episodes of blood in his stool, or is the stool unusually dark or pale?\nPatient [50%]: No, there hasn't been any blood in his stool, and the color seems normal, not too dark or pale.\nDoctor [55%]: Has your child had any urinary problems, such as changes in the color or amount of urine, or difficulty urinating?\nPatient [55%]: No, there haven't been any changes in the color or amount of his urine, and he doesn't seem to have any difficulty urinating.\nDoctor [60%]: Has your child had any previous medical history or surgeries that we should be aware of?\nPatient [60%]: No, he hasn't had any previous medical issues or surgeries. He's been healthy up until these recent feeding and fussiness issues.\nDoctor [65%]: Has your child been more lethargic or less active than usual, especially in light of these feeding difficulties and abdominal distension?\nPatient [65%]: Yes, he's been less active than usual. He doesn't seem to have his normal energy levels, especially in the last few days.\nDoctor [70%]: Given the symptoms of abdominal distension, irritability, and decreased activity, it's important to check for any signs of internal issues. REQUEST TEST: Abdominal Ultrasound\nMeasurement [70%]: RESULTS: NORMAL READINGS\nDoctor [75%]: Given the normal abdominal ultrasound results, it's crucial to explore other causes for these symptoms. Has your child had any coughing, sneezing, or other signs of respiratory issues, even if they seem minor?\nPatient [75%]: No, he hasn't had any coughing, sneezing, or other signs of respiratory issues. Everything seems fine in that area.\nDoctor [80%]: Given the symptoms and normal ultrasound, it's important to assess his nutritional intake and absorption. Has your child had any issues with excessive gas or belching more than usual?\nPatient [80%]: No, he hasn't had issues with excessive gas or belching more than usual. Everything seems pretty normal in that aspect.\nDoctor [85%]: Given the symptoms, normal ultrasound, and no respiratory or gastrointestinal symptoms like excessive gas, it's important to consider metabolic issues. REQUEST TEST: Basic Metabolic Panel\nMeasurement [85%]: RESULTS: NORMAL READINGS\nDoctor [90%]: Given the normal results from the Basic Metabolic Panel and considering the symptoms of feeding difficulties, weight gain, abdominal distension, and irritability, it's important to look into more specific causes. REQUEST TEST: Thyroid Function Tests\nMeasurement [90%]: RESULTS: NORMAL READINGS\nDoctor [95%]: Given the normal thyroid function tests, it seems we've ruled out some common issues. For my final question, has your child had any noticeable sweating, particularly during feedings or while crying?\nPatient [95%]: No, he hasn't had any noticeable sweating, especially during feedings or while crying. Everything seems normal in that regard.\nDoctor [100%]: DIAGNOSIS READY: Congestive Heart Failure\n\nCorrect answer: Hirschsprung disease\nScene 2, The diagnosis was  INCORRECT 66\nDoctor [5%]: How long have you been experiencing these symptoms?\nPatient [5%]: I've been feeling this way for about 4 weeks now.\nDoctor [10%]: Have you noticed any changes in your appetite or any difficulty swallowing?\nPatient [10%]: No, my appetite has been pretty normal, but I've definitely had some trouble swallowing lately, especially in the past week or so.\nDoctor [15%]: Have you experienced any fever or chills along with these symptoms?\nPatient [15%]: No, I haven't had any fever or chills, just those night sweats I mentioned.\nDoctor [20%]: Have you had any recent infections or been in contact with someone who was sick?\nPatient [20%]: No, I haven't had any recent infections or been around anyone who was sick that I know of.\nDoctor [25%]: Have you noticed any changes in your bowel habits or any unusual bleeding?\nPatient [25%]: No, I haven't noticed any changes in my bowel habits or any unusual bleeding.\nDoctor [30%]: Have you experienced any coughing or shortness of breath?\nPatient [30%]: No, I haven't experienced any coughing or shortness of breath.\nDoctor [35%]: Have you had any significant weight loss without trying in the last few weeks?\nPatient [35%]: Yes, I've lost about 12 pounds without really trying over the last month. It's been quite surprising.\nDoctor [40%]: Have you had any history of cancer in your family?\nPatient [40%]: No, there's no history of cancer in my family that I'm aware of.\nDoctor [45%]: Have you noticed any changes in your skin, like rashes or unusual itching?\nPatient [45%]: No, I haven't noticed any changes in my skin, no rashes or unusual itching.\nDoctor [50%]: Have you experienced any excessive bruising or bleeding that you've noticed?\nPatient [50%]: No, I haven't experienced any excessive bruising or bleeding.\nDoctor [55%]: Have you felt any lumps or bumps on your body other than the enlarged supraclavicular lymph node?\nPatient [55%]: Yes, I've felt some swelling around my neck and I think there might be more than one lump there. It's been like this for a few days now.\nDoctor [60%]: Have you noticed any night sweats that are particularly severe, soaking your bedclothes or sheets?\nPatient [60%]: Yes, the night sweats have been pretty severe, actually. I've had to change my sheets in the middle of the night because they were soaked through.\nDoctor [65%]: Have you experienced any significant changes in your vision or headaches recently?\nPatient [65%]: No, I haven't experienced any significant changes in my vision or had any unusual headaches recently.\nDoctor [70%]: Have you had any difficulty breathing or felt any pressure in your chest, aside from the trouble swallowing you mentioned earlier?\nPatient [70%]: No, I haven't had any difficulty breathing or felt any pressure in my chest. It's mainly just been the trouble swallowing that's been concerning.\nDoctor [75%]: Have you traveled outside the country or to any rural areas recently where you might have been exposed to different diseases or environmental factors?\nPatient [75%]: No, I haven't traveled outside the country or to any rural areas recently. My daily routine hasn't changed much, just work and home.\nDoctor [80%]: Have you experienced any numbness, tingling, or weakness in your arms or legs?\nPatient [80%]: No, I haven't experienced any numbness, tingling, or weakness in my arms or legs.\nDoctor [85%]: Have you noticed any increase in the size of the lumps around your neck or any new lumps appearing elsewhere on your body?\nPatient [85%]: No, I haven't noticed any increase in the size of the lumps around my neck or any new lumps appearing elsewhere. It's just been the swelling in my neck that I've noticed.\nDoctor [90%]: Given your symptoms and the presence of enlarged lymph nodes, I'd like to request a couple of tests to help us get a clearer picture of what's going on. REQUEST TEST: Complete Blood Count (CBC) REQUEST TEST: Biopsy of the supraclavicular lymph node\nMeasurement [90%]: RESULTS: Blood_Work: Complete_Blood_Count: WBC: Elevated, Hemoglobin: Slightly Decreased, Platelets: Normal. Biopsy: Cervical_Lymph_Node: Findings: Lymphocytes with a high proliferative index that stain positive for CD20.\nDoctor [95%]: Given the biopsy results showing lymphocytes with a high proliferative index that stain positive for CD20, have you experienced any excessive fatigue or a feeling of being unusually tired?\nPatient [95%]: Yes, I've been feeling unusually tired, more so than usual. It's been a struggle just to get through my normal day.\nDoctor [100%]: DIAGNOSIS READY: Non-Hodgkin Lymphoma\n\nCorrect answer: Diffuse large B-cell lymphoma\nScene 3, The diagnosis was  CORRECT 75\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me more about the antibiotic treatment you received for your acute sinusitis?\nPatient [5%]: Yes, of course, Dr. Agent. I was first given amoxicillin for about 12 days. During that time, I developed a rash, so my doctor switched me to cephalexin for another week. The rash went away after the switch.\nDoctor [10%]: Did you notice any changes in your urine, such as color, frequency, or pain during urination, after starting the antibiotic treatment?\nPatient [10%]: No, I didn't notice any changes in my urine. There was no difference in color, frequency, or any pain during urination.\nDoctor [15%]: Have you experienced any nausea, vomiting, or diarrhea since starting your antibiotic treatment?\nPatient [15%]: No, I haven't experienced any nausea, vomiting, or diarrhea. My main issues have been the fatigue, flank pain, and the fever that just won't go away.\nDoctor [20%]: Have you had any previous kidney issues or urinary tract infections before this episode?\nPatient [20%]: No, I haven't had any previous kidney issues or urinary tract infections before this.\nDoctor [25%]: Have you noticed any swelling in your legs, ankles, or around your eyes since you started feeling unwell?\nPatient [25%]: No, I haven't noticed any swelling in my legs, ankles, or around my eyes.\nDoctor [30%]: Have you had any recent exposure to new foods, environments, or pets that could have triggered an allergic reaction or infection?\nPatient [30%]: No, I haven't had any recent exposure to new foods, environments, or pets that could have triggered an allergic reaction or infection. Everything has been pretty much the same as it always has been.\nDoctor [35%]: Have you experienced any shortness of breath, chest pain, or cough since these symptoms began?\nPatient [35%]: No, I haven't experienced any shortness of breath, chest pain, or cough since these symptoms began.\nDoctor [40%]: Have you had any recent weight loss, loss of appetite, or night sweats along with your current symptoms?\nPatient [40%]: No, I haven't had any recent weight loss, loss of appetite, or night sweats along with my current symptoms.\nDoctor [45%]: Have you noticed any changes in your bowel movements, such as consistency or frequency, since these symptoms started?\nPatient [45%]: No, there haven't been any changes in my bowel movements, either in consistency or frequency, since these symptoms started.\nDoctor [50%]: Have you been feeling unusually tired or lethargic, more so than usual, since these symptoms started?\nPatient [50%]: Yes, I've been feeling unusually tired and lethargic, more so than usual. It's been quite difficult to get through the day without feeling the need to rest.\nDoctor [55%]: Have you experienced any confusion, difficulty concentrating, or memory problems since these symptoms began?\nPatient [55%]: No, I haven't experienced any confusion, difficulty concentrating, or memory problems since these symptoms began.\nDoctor [60%]: Have you had any recent travel history, especially to areas known for infectious diseases, before these symptoms started?\nPatient [60%]: No, I haven't had any recent travel, especially to areas known for infectious diseases, before these symptoms started.\nDoctor [65%]: Have you taken any over-the-counter medications, supplements, or herbal remedies to help with your symptoms since they started?\nPatient [65%]: No, I haven't taken any over-the-counter medications, supplements, or herbal remedies to help with my symptoms since they started.\nDoctor [70%]: Have you had any blood in your urine, even if it was just once or very faint?\nPatient [70%]: No, I haven't noticed any blood in my urine, not even faintly.\nDoctor [75%]: Given your symptoms and the recent antibiotic treatment, it's important to check your kidney function and look for any signs of infection or other abnormalities. REQUEST TEST: Kidney Function Test (Blood Urea Nitrogen, Creatinine)\nMeasurement [75%]: RESULTS: Serum_Biochemistry: Urea: Elevated, Creatinine: Elevated\nDoctor [80%]: Given the elevated levels of urea and creatinine in your blood, it indicates your kidneys are not functioning properly. Have you experienced any increase in fatigue or a decrease in urine output recently?\nPatient [80%]: Yes, now that you mention it, I have noticed an increase in fatigue, and it seems like my urine output has decreased a bit recently.\nDoctor [85%]: Given these findings, it's crucial to assess for any possible infections or obstructions in your kidneys. REQUEST TEST: Urinalysis\nMeasurement [85%]: RESULTS: Urinalysis: Leukocyturia: Present, Bacterial Culture: Negative, Cytospin Stained With Hansel’s Solution: 3% binucleated cells with eosinophilic, granular cytoplasm\nDoctor [90%]: Given the presence of leukocyturia and the specific findings in your urinalysis, have you experienced any recent back pain or tenderness in the area around your kidneys?\nPatient [90%]: Yes, I've been experiencing some back pain, specifically a dull ache in my flank area on both sides. It's been quite persistent.\nDoctor [95%]: Given your symptoms, the recent antibiotic treatment, and the test results, it's important to consider all possibilities. Have you had any changes in your blood pressure or any episodes of dizziness?\nPatient [95%]: Actually, I have noticed that I've been feeling a bit more dizzy lately, especially when I stand up too quickly. As for my blood pressure, I haven't checked it recently, but I've been feeling like it might be fluctuating more than usual.\nDoctor [100%]: DIAGNOSIS READY: Acute interstitial nephritis (AIN)\n\nCorrect answer: Acute interstitial nephritis\nScene 4, The diagnosis was  CORRECT 80\nDoctor [5%]: How long have you been experiencing knee pain since you increased your physical activity?\nPatient [5%]: The pain started just yesterday, after my last volleyball game.\nDoctor [10%]: Can you describe the nature of the pain you're experiencing? Is it sharp, dull, constant, or does it come and go?\nPatient [10%]: The pain feels sharp, especially when I try to move or bend my knee. It's been pretty constant since it started.\nDoctor [15%]: Did you hear or feel a pop in your knee when the pain started?\nPatient [15%]: No, I didn't hear or feel a pop. It just started hurting after the game.\nDoctor [20%]: Is the pain localized to a specific area of your knee, or is it more generalized around the knee?\nPatient [20%]: The pain is more localized, specifically over the medial aspect of my knee, just below the kneecap.\nDoctor [25%]: Have you noticed any swelling or changes in the appearance of your knee since the pain started?\nPatient [25%]: No, there hasn't been any swelling or changes in how my knee looks. It just hurts a lot.\nDoctor [30%]: Have you had any previous injuries to this knee or any surgeries on it in the past?\nPatient [30%]: No, I haven't had any previous injuries or surgeries on this knee. This is the first time I've had this kind of pain.\nDoctor [35%]: Have you tried any treatments at home, like applying ice or taking any over-the-counter pain medications? If so, did they provide any relief?\nPatient [35%]: I've tried icing it a few times since yesterday and took some ibuprofen, but it hasn't really helped much. The pain is still pretty bad.\nDoctor [40%]: Have you had any difficulty walking or bearing weight on the affected leg since the pain started?\nPatient [40%]: Yes, I've had some difficulty walking, especially going up and down stairs. It feels really unstable when I try to put my full weight on it.\nDoctor [45%]: Have you experienced any locking or catching sensations in your knee when moving it, or has it felt like it might give way?\nPatient [45%]: No, I haven't experienced any locking or catching sensations. It hasn't felt like it's going to give way, but it does feel very unstable, especially when I try to pivot or twist.\nDoctor [50%]: Have you noticed any improvement or worsening of the pain since it first started?\nPatient [50%]: The pain has been steadily worsening since it first started. It's gotten to the point where it's affecting my ability to move around normally.\nDoctor [55%]: Have you been able to rest your knee since the pain started, or have you continued with your usual activities and sports?\nPatient [55%]: I've tried to rest it as much as possible since the pain started. I haven't gone back to volleyball or done any strenuous activities.\nDoctor [60%]: Have you noticed any numbness, tingling, or changes in sensation around your knee or in your leg since the pain started?\nPatient [60%]: No, I haven't noticed any numbness, tingling, or changes in sensation. It's just the pain and difficulty moving that's been bothering me.\nDoctor [65%]: Given the location and nature of your pain, have you experienced any issues with your knee in colder weather or after sitting for long periods before this incident?\nPatient [65%]: No, I haven't had any issues with my knee in colder weather or after sitting for long periods before this. This is the first time I've had any problem like this.\nDoctor [70%]: Have you engaged in any specific training or exercises that were new or more intense than usual before the pain started?\nPatient [70%]: Yes, I had been doing more intense volleyball drills that involved a lot of jumping and quick direction changes. It was definitely more strenuous than what I'm used to.\nDoctor [75%]: Given the intensity of your recent activities, it's possible that the pain could be related to overuse or strain. Have you felt any improvement in the morning after resting overnight, or does the pain seem consistent regardless of rest?\nPatient [75%]: The pain seems consistent regardless of rest. It doesn't really feel any better in the morning; it's pretty much the same level of discomfort as when I go to bed.\nDoctor [80%]: Given your symptoms and the nature of your recent activities, it's important to rule out specific conditions that could be causing your knee pain. REQUEST TEST: MRI of the knee. This will help us get a detailed look at the structures within your knee to identify any potential injuries or abnormalities.\nMeasurement [80%]: RESULTS: MRI_Knee: Optional. Can be considered if clinical suspicion persists despite negative initial workup, not mandatory for diagnosis in this simulated case.\nDoctor [85%]: Given the MRI isn't mandatory for diagnosis in this case, let's focus on the clinical presentation. Have you noticed any crepitus, or a grinding sensation, in your knee when moving it?\nPatient [85%]: No, I haven't noticed any crepitus or grinding sensation when I move my knee. It's mainly just the sharp pain and difficulty with movement.\nDoctor [90%]: Given the sharp, localized pain without swelling, crepitus, or previous injury, and considering your recent increase in physical activity involving jumping and quick direction changes, it sounds like you may have developed a condition related to overuse or strain. Have you noticed if resting or avoiding certain movements provides any temporary relief, even if minimal?\nPatient [90%]: Resting does seem to provide a bit of relief, but it's minimal. Avoiding bending or putting too much pressure on my knee helps a little, but the pain is still there.\nDoctor [95%]: Given your responses and the symptoms you've described, it seems like we're dealing with an issue that's been exacerbated by recent physical activity, particularly the intense volleyball drills. DIAGNOSIS READY: Patellar tendinitis, also known as jumper's knee. This condition is common in athletes who participate in sports that involve a lot of jumping and quick changes in direction. Rest, ice, compression, and elevation, along with physical therapy, are typically recommended for treatment.\n\nCorrect answer: Pes anserine bursitis\nScene 5, The diagnosis was  INCORRECT 66\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me what you were doing right before you lost consciousness?\nPatient [5%]: I had just finished using the bathroom and was washing my hands when I suddenly felt dizzy and then I don't remember anything until I woke up on the floor.\nDoctor [10%]: Did you experience any warning signs before you felt dizzy, such as blurred vision, sweating, or feeling like your heart was racing?\nPatient [10%]: No, there were no warning signs at all. It happened all of a sudden without any symptoms like blurred vision, sweating, or my heart racing.\nDoctor [15%]: Have you had any episodes like this before, or was this the first time?\nPatient [15%]: This was the first time anything like this has ever happened to me. I've never experienced anything like it before.\nDoctor [20%]: Do you have any existing medical conditions or are you currently taking any medications?\nPatient [20%]: No, I don't have any existing medical conditions, and I'm not on any medications.\nDoctor [25%]: Did you hit your head when you fell, or do you have any injuries from the fall?\nPatient [25%]: No, I didn't hit my head, and I don't have any injuries from the fall.\nDoctor [30%]: Did you feel any chest pain, shortness of breath, or palpitations before or after the episode?\nPatient [30%]: No, I didn't feel any chest pain, shortness of breath, or palpitations before or after the episode.\nDoctor [35%]: Have you been feeling more stressed or anxious than usual lately?\nPatient [35%]: No, I haven't been feeling more stressed or anxious than usual lately. Everything has been pretty normal for me.\nDoctor [40%]: Have you noticed any changes in your eating or drinking habits recently, such as consuming more caffeine or alcohol?\nPatient [40%]: No, my eating and drinking habits have been the same. I haven't increased my caffeine or alcohol intake recently.\nDoctor [45%]: Have you experienced any sudden changes in your weight, either loss or gain, in the past few months?\nPatient [45%]: No, my weight has been stable. I haven't noticed any significant changes in either direction.\nDoctor [50%]: Have you been experiencing any unusual fatigue or tiredness lately, more than what is normal for you?\nPatient [50%]: No, I haven't been feeling unusually tired or fatigued lately. My energy levels have been pretty consistent.\nDoctor [55%]: Have you noticed any issues with your vision, hearing, or balance since the episode, or even before it happened?\nPatient [55%]: No, I haven't noticed any issues with my vision, hearing, or balance either before or since the episode happened. Everything seems normal in that regard.\nDoctor [60%]: Have you experienced any headaches or neck pain recently, either before or after the episode?\nPatient [60%]: No, I haven't experienced any headaches or neck pain recently, neither before nor after the episode.\nDoctor [65%]: Have you had any episodes of feeling unusually hot or cold, or any unexplained sweating or chills, in the days leading up to or after the episode?\nPatient [65%]: No, I haven't had any episodes of feeling unusually hot or cold, nor have I experienced any unexplained sweating or chills in the days leading up to or after the episode.\nDoctor [70%]: Have you noticed any changes in your bowel or bladder habits recently, either before or after the episode?\nPatient [70%]: No, I haven't noticed any changes in my bowel or bladder habits recently, either before or after the episode. Everything has been normal in that regard.\nDoctor [75%]: Have you been around anyone who was sick, or have you been sick yourself in the weeks leading up to this episode?\nPatient [75%]: No, I haven't been around anyone who was sick, and I haven't been sick myself in the weeks leading up to this episode. Everything was pretty normal until this happened.\nDoctor [80%]: Have you experienced any emotional disturbances or significant mood changes recently, either before or after the episode?\nPatient [80%]: No, I haven't experienced any emotional disturbances or significant mood changes recently. My mood has been quite stable, both before and after the episode.\nDoctor [85%]: Have you been engaging in any new physical activities or experienced any physical strain before the episode occurred?\nPatient [85%]: No, I haven't been engaging in any new physical activities or experienced any physical strain before the episode occurred. My routine has been the same as usual.\nDoctor [90%]: Have you noticed any difficulty in swallowing or changes in your speech before or after the episode?\nPatient [90%]: No, I haven't noticed any difficulty in swallowing or changes in my speech either before or after the episode. Everything seems to be normal in that aspect.\nDoctor [95%]: Given your symptoms and the sudden nature of your episode, I'd like to request a couple of tests to further investigate the cause. REQUEST TEST: ECG (Electrocardiogram) and REQUEST TEST: Blood glucose level. These tests will help us rule out any cardiac issues or a possible hypoglycemic event.\nMeasurement [95%]: RESULTS: Electrocardiogram (ECG) Findings: No abnormalities. Blood Tests: Glucose: Within normal limits.\nDoctor [100%]: Given the normal results from the ECG and blood glucose tests, along with your history and symptoms, it seems we can rule out cardiac issues and hypoglycemia as causes for your episode of loss of consciousness. Considering the sudden onset without any preceding warning signs or symptoms, and in the absence of any other specific symptoms, my final question is: Have you experienced any significant changes in your hydration or electrolyte intake recently, or have you been exposed to extreme temperatures that could have led to dehydration or heat-related issues? DIAGNOSIS READY: Vasovagal syncope, pending further investigation to rule out other potential causes.\n\nCorrect answer: Situational syncope\nScene 6, The diagnosis was  CORRECT 71\nDoctor [5%]: Hello, I understand we need to assess the condition of a newborn. Can you tell me about any symptoms or unusual findings you've noticed with the baby?\nPatient [5%]: Well, I've noticed that she has a continuous heart murmur that doesn't seem to stop. Also, there are bluish spots on her skin that don't go away when you press on them, and her eyes... the lenses look cloudy. She also didn't pass her hearing tests.\nDoctor [10%]: Has the baby had any issues with feeding or signs of difficulty breathing?\nPatient [10%]: No, she hasn't had any issues with feeding, and I haven't noticed any difficulty with her breathing.\nDoctor [15%]: Has the baby experienced any episodes of unusual movements, like seizures or twitching?\nPatient [15%]: No, she hasn't had any episodes like that, no seizures or twitching.\nDoctor [20%]: Given the symptoms you've described, it's important to check the baby's oxygen levels. Have you noticed if her fingers or lips turn blue, especially when she's crying or feeding?\nPatient [20%]: No, I haven't noticed her fingers or lips turning blue when she cries or feeds.\nDoctor [25%]: Given the symptoms, it's crucial to understand the baby's overall growth and development. Has the baby been growing and meeting developmental milestones as expected for her age?\nPatient [25%]: Well, considering she's a newborn, it's a bit early to tell much about her meeting developmental milestones, but she seems to be growing as expected for her age so far.\nDoctor [30%]: Has there been any family history of genetic disorders or conditions that we should be aware of?\nPatient [30%]: No, there hasn't been any family history of genetic disorders or conditions that we're aware of.\nDoctor [35%]: Given the symptoms of a continuous heart murmur, bluish spots on the skin, cloudy lenses, and failed hearing tests, it's important to investigate further. REQUEST TEST: Echocardiogram to assess the heart's structure and function.\nMeasurement [35%]: RESULTS: Patent ductus arteriosus\nDoctor [40%]: Given the echocardiogram results showing a patent ductus arteriosus (PDA), it's important to check for any associated conditions. REQUEST TEST: Complete blood count (CBC) to assess for any signs of infection or anemia that could be related to or affecting the PDA.\nMeasurement [40%]: RESULTS: NORMAL READINGS\nDoctor [45%]: Given the normal CBC results, it's reassuring that there's no sign of infection or anemia. Now, to address the bluish spots and cloudy lenses, REQUEST TEST: Skin biopsy for the bluish spots and an ophthalmological exam to assess the lenses more thoroughly.\nMeasurement [45%]: RESULTS: Skin Examination: Several bluish macules that do not blanch upon application of pressure. Ophthalmologic_Consult: Findings: Congenital cataracts\nDoctor [50%]: Given the findings of congenital cataracts, it's important to assess the baby's hearing more closely. REQUEST TEST: Detailed audiological evaluation to further investigate the failed hearing tests.\nMeasurement [50%]: RESULTS: Hearing_Test: Findings: Bilateral sensorineural hearing loss\nDoctor [55%]: Given the combination of findings - patent ductus arteriosus, congenital cataracts, and bilateral sensorineural hearing loss - it's crucial to consider a syndrome that could link these symptoms. Have you noticed any issues with the baby's temperature regulation, such as difficulty staying warm?\nPatient [55%]: No, she hasn't had any issues with temperature regulation; she seems to stay warm just fine.\nDoctor [60%]: Given the symptoms and test results we've discussed, it's important to consider the baby's overall physical appearance. Have you noticed any differences in the baby's physical features or body shape that might be unusual or distinct?\nPatient [60%]: No, I haven't noticed any unusual or distinct differences in her physical features or body shape. Everything seems pretty normal in that regard.\nDoctor [65%]: Given the findings so far, it's important to assess the baby's kidney function as well, considering the range of symptoms. REQUEST TEST: Renal ultrasound to check for any abnormalities in the kidneys.\nMeasurement [65%]: RESULTS: NORMAL READINGS\nDoctor [70%]: Given the normal renal ultrasound results, it's reassuring that the kidneys are not affected. Have you noticed any issues with the baby's breathing at higher altitudes or in situations where there might be less oxygen available, like during air travel?\nPatient [70%]: No, we haven't traveled to any higher altitudes or been in situations with less oxygen, so I haven't noticed any issues with her breathing in those kinds of environments.\nDoctor [75%]: Given the symptoms and findings we've discussed, it's important to consider metabolic issues as well. Have you noticed any unusual odors, like a maple syrup smell, coming from the baby or her urine?\nPatient [75%]: No, I haven't noticed any unusual odors like a maple syrup smell coming from her or her urine.\nDoctor [80%]: Given the comprehensive information we've gathered, including the heart condition, skin findings, congenital cataracts, and hearing loss, without any metabolic indicators or unusual physical features, it's time to consider a genetic syndrome that could explain these findings. Have you noticed any difficulties with the baby's feeding or digestion, such as vomiting more than expected for a newborn or issues with bowel movements?\nPatient [80%]: No, she hasn't had any difficulties with feeding or digestion. She hasn't been vomiting more than what I'd expect for a newborn, and her bowel movements seem normal.\nDoctor [85%]: Given all the information we've gathered, including the patent ductus arteriosus, congenital cataracts, bilateral sensorineural hearing loss, and the absence of metabolic issues, unusual physical features, or difficulties with feeding and digestion, it seems we're looking at a syndrome that affects multiple systems but spares the gastrointestinal tract and doesn't present with distinctive odors or metabolic derangements. DIAGNOSIS READY: CHARGE Syndrome\n\nCorrect answer: Congenital Rubella Infection\nScene 7, The diagnosis was  INCORRECT 62\nDoctor [5%]: How long have you noticed the breast mass for?\nPatient [5%]: I first noticed it about 4 weeks ago.\nDoctor [10%]: Has the size of the breast mass changed since you first noticed it?\nPatient [10%]: Yes, it has increased in size quite rapidly since I first noticed it.\nDoctor [15%]: Have you experienced any pain or discomfort in the area of the breast mass?\nPatient [15%]: No, I haven't felt any pain or discomfort in the area at all.\nDoctor [20%]: Have you noticed any changes in the skin over the breast mass, such as redness, dimpling, or puckering?\nPatient [20%]: No, there haven't been any changes in the skin or nipple. Everything looks normal on the surface.\nDoctor [25%]: Have you experienced any nipple discharge, either clear or bloody?\nPatient [25%]: No, I haven't experienced any nipple discharge.\nDoctor [30%]: Have you had any recent infections or injuries to the breast area that might explain the mass?\nPatient [30%]: No, I haven't had any recent infections or injuries to the breast area.\nDoctor [35%]: Do you have a family history of breast cancer or any other types of cancer?\nPatient [35%]: No, there's no family history of breast cancer or any other types of cancer that I'm aware of.\nDoctor [40%]: Have you noticed any changes in your overall health, such as unexplained weight loss, fatigue, or fever?\nPatient [40%]: No, I haven't noticed any changes in my overall health. No weight loss, fatigue, or fever.\nDoctor [45%]: Have you been through menopause, or are you currently experiencing any changes in your menstrual cycle?\nPatient [45%]: I haven't been through menopause yet, and my menstrual cycle has been regular without any changes.\nDoctor [50%]: Have you noticed any lumps or swelling in other parts of your body, such as under your arm or around your collarbone?\nPatient [50%]: No, I haven't noticed any lumps or swelling in other parts of my body, like under my arm or around my collarbone.\nDoctor [55%]: Have you had any previous breast surgeries or biopsies for any reason?\nPatient [55%]: No, I haven't had any previous breast surgeries or biopsies.\nDoctor [60%]: Have you been using any form of hormone replacement therapy or birth control that could potentially influence breast tissue changes?\nPatient [60%]: No, I haven't been using any form of hormone replacement therapy or birth control recently.\nDoctor [65%]: Have you noticed any changes in the shape or size of your breast other than the mass itself?\nPatient [65%]: No, I haven't noticed any changes in the shape or size of my breast other than the mass itself.\nDoctor [70%]: Have you experienced any difficulty breathing or a persistent cough recently?\nPatient [70%]: No, I haven't experienced any difficulty breathing or a persistent cough recently.\nDoctor [75%]: Have you been experiencing any unusual fatigue or a general feeling of being unwell, even if it's subtle?\nPatient [75%]: No, I haven't been experiencing any unusual fatigue or a general feeling of being unwell. Everything feels pretty normal aside from the mass.\nDoctor [80%]: Have you noticed any changes in your appetite or unexpected weight changes since you first noticed the breast mass?\nPatient [80%]: No, my appetite has been normal, and I haven't noticed any unexpected weight changes.\nDoctor [85%]: Have you engaged in any activities or been exposed to chemicals or radiation that might increase your risk for breast abnormalities?\nPatient [85%]: No, I haven't been exposed to any chemicals or radiation, and I haven't engaged in any activities that I believe would increase my risk for breast abnormalities.\nDoctor [90%]: Given the rapid increase in size of the mass without pain, discomfort, or other systemic symptoms, it's important we proceed with diagnostic imaging to better understand the nature of this mass. REQUEST TEST: Ultrasound of the breast.\nMeasurement [90%]: RESULTS: NORMAL READINGS\nDoctor [95%]: Given the normal ultrasound results but considering the rapid growth of the mass, it's crucial we further investigate to rule out any malignancies or benign growths that might not have been clearly identified on the ultrasound. REQUEST TEST: Mammogram.\nMeasurement [95%]: RESULTS: Smooth polylobulated mass in the left breast.\nDoctor [100%]: DIAGNOSIS READY: Fibroadenoma of the breast.\n\nCorrect answer: Phyllodes tumor\nScene 8, The diagnosis was  INCORRECT 55\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me when you started feeling feverish and experiencing abdominal tenderness?\nPatient [5%]: It started a few days after I got home from the hospital with my baby, so probably about a week ago now. The tenderness in my abdomen has been getting worse, especially when I touch it.\nDoctor [10%]: Have you noticed any unusual vaginal discharge or bleeding since you've been home?\nPatient [10%]: Yes, I've noticed a bit more bleeding than I expected, and it seems a bit heavier than what I was told to expect postpartum.\nDoctor [15%]: Have you experienced any chills, nausea, or vomiting along with your fever and abdominal tenderness?\nPatient [15%]: I've had some chills, especially at night, but no nausea or vomiting.\nDoctor [20%]: Have you had any difficulty urinating or noticed any changes in the color or smell of your urine?\nPatient [20%]: No difficulty urinating, but I've definitely been going more often than usual. I haven't noticed any change in the color or smell, though.\nDoctor [25%]: Have you had any issues with your bowel movements, such as diarrhea or constipation?\nPatient [25%]: I've actually had some trouble with constipation recently. It's been more difficult than usual for me to have a bowel movement.\nDoctor [30%]: Have you had any previous pregnancies, and if so, did you experience any similar symptoms postpartum?\nPatient [30%]: No, this was my first pregnancy, so I haven't had any previous postpartum experiences to compare this to.\nDoctor [35%]: Have you had a fever? If so, can you tell me how high it has been?\nPatient [35%]: Yes, I've had a fever. It's been around 101°F (38.3°C) when I've checked.\nDoctor [40%]: Have you been taking any medications for the fever or any other symptoms?\nPatient [40%]: I've only taken some over-the-counter ibuprofen to try and bring the fever down and help with the abdominal pain, but that's about it.\nDoctor [45%]: Have you noticed any foul-smelling discharge or an increase in the amount of discharge recently?\nPatient [45%]: Yes, now that you mention it, there has been a bit of an unusual smell, and the discharge seems to have increased a bit in the last couple of days.\nDoctor [50%]: Given your symptoms, it's important to check for any infection that might be causing these issues. REQUEST TEST: Blood culture to check for any signs of infection in the blood.\nMeasurement [50%]: RESULTS: NORMAL READINGS\nDoctor [55%]: Given the normal blood culture results, I'd like to further investigate the source of your symptoms. REQUEST TEST: Pelvic ultrasound to examine your uterus and surrounding areas for any abnormalities.\nMeasurement [55%]: RESULTS: NORMAL READINGS\nDoctor [60%]: Given the normal results from both the blood culture and the pelvic ultrasound, it's important to consider other potential causes for your symptoms. Have you had any fever-reducing medication since your last fever measurement, and if so, has it had any effect on reducing your fever?\nPatient [60%]: Yes, I've taken some more ibuprofen since then, and it seems to help a little with the fever, but it always comes back after the medication wears off.\nDoctor [65%]: Given the persistence of your fever despite taking ibuprofen, have you noticed any improvement or worsening in your abdominal tenderness over the past few days?\nPatient [65%]: The abdominal tenderness hasn't really improved; it feels about the same, maybe even a bit worse when I move around or when I'm trying to sleep.\nDoctor [70%]: Given the worsening of your abdominal tenderness, it's crucial to rule out any complications that might not have been visible in the initial tests. REQUEST TEST: CT scan of the abdomen and pelvis to get a more detailed view of your abdominal area.\nMeasurement [70%]: RESULTS: NORMAL READINGS\nDoctor [75%]: Given the normal CT scan results, it's important to assess your overall hydration and nutritional status since you've been experiencing these symptoms. Have you been able to eat and drink normally, or have you noticed a decrease in your appetite or fluid intake?\nPatient [75%]: I've been trying to keep up with eating and drinking, especially because I'm breastfeeding, but I've definitely noticed a decrease in my appetite. Drinking water is a bit easier, but I'm not consuming as much as I probably should.\nDoctor [80%]: Given your decreased appetite and the importance of maintaining hydration and nutrition, especially while breastfeeding, have you noticed any changes in your breast milk supply or any difficulties with breastfeeding?\nPatient [80%]: Actually, now that you mention it, I've noticed that my breast milk supply seems to be a bit lower than it was right after I gave birth. Breastfeeding has been a bit more challenging because of this.\nDoctor [85%]: Given the challenges with breastfeeding and your symptoms, it's important to consider all factors that could be contributing to your condition. Have you experienced any breast pain, redness, or warmth that could indicate a breast infection or mastitis?\nPatient [85%]: No, I haven't noticed any breast pain, redness, or warmth. Everything seems normal in that area, just the issue with the decreased milk supply.\nDoctor [90%]: Given the information we've gathered and the normal results from the tests we've conducted, it seems we've ruled out some of the more common postpartum complications. However, your symptoms of fever, abdominal tenderness, increased and foul-smelling vaginal discharge, and the impact on your breastfeeding could suggest an infection not detected by the previous tests. Have you noticed any changes in the pain's location in your abdomen, or is it more generalized?\nPatient [90%]: The pain feels more generalized across my lower abdomen. It doesn't seem to be focused in one specific area, but it's definitely more intense near the lower part.\nDoctor [95%]: Given the generalized pain in your lower abdomen and the other symptoms you've described, it's crucial to consider all possible causes, including those that might not be immediately apparent from the tests we've conducted. Have you had any recent follow-up visits with your obstetrician or any other healthcare provider since you started experiencing these symptoms?\nPatient [95%]: No, I haven't had a chance to see my obstetrician yet since these symptoms started. I was hoping it might just get better on its own, but it seems like it's not improving.\nDoctor [100%]: DIAGNOSIS READY: Endometritis\n\nCorrect answer: Endometritis\nScene 9, The diagnosis was  CORRECT 60\nDoctor [5%]: How long have you been experiencing rectal bleeding?\nPatient [5%]: It's been about two weeks now.\nDoctor [10%]: Have you noticed any changes in your bowel habits, such as diarrhea or constipation, in these two weeks?\nPatient [10%]: No, I haven't noticed any changes in my bowel habits. Everything else has been pretty normal.\nDoctor [15%]: Have you experienced any weight loss without trying in the last few weeks?\nPatient [15%]: No, I haven't experienced any weight loss recently.\nDoctor [20%]: Do you have any family history of colorectal cancer or any other types of cancer?\nPatient [20%]: No, there's no family history of colorectal cancer or any other types of cancer that I'm aware of.\nDoctor [25%]: Have you felt any pain or discomfort in your abdominal area or around your rectum?\nPatient [25%]: No, I haven't felt any pain or discomfort in my abdominal area or around my rectum.\nDoctor [30%]: Have you noticed any changes in the color or consistency of your stool, such as black or tarry stools, or blood mixed in with the stool?\nPatient [30%]: The blood seems to be bright red, and I haven't noticed any changes in the color or consistency of my stool otherwise. It's just the blood that's noticeable.\nDoctor [35%]: Have you experienced any fatigue or weakness recently that seems unusual or unexplained?\nPatient [35%]: No, I haven't experienced any unusual fatigue or weakness recently. Everything feels pretty normal except for the bleeding.\nDoctor [40%]: Have you had any previous medical conditions or surgeries related to your digestive system?\nPatient [40%]: No, I haven't had any previous medical conditions or surgeries related to my digestive system. My past medical history is pretty unremarkable except for having five normal vaginal deliveries.\nDoctor [45%]: Have you been taking any medications or supplements recently that could potentially cause bleeding, such as nonsteroidal anti-inflammatory drugs (NSAIDs) or blood thinners?\nPatient [45%]: No, I haven't been taking any medications or supplements recently that could potentially cause bleeding. I'm not on NSAIDs or blood thinners.\nDoctor [50%]: Have you experienced any itching, pain, or discomfort specifically around the anus that might suggest something like hemorrhoids or fissures?\nPatient [50%]: No, I haven't experienced any itching, pain, or discomfort around the anus. Everything has been pretty normal in that regard, just the bleeding.\nDoctor [55%]: Have you noticed any lump or swelling around the anus or within the rectum that could be felt externally, aside from the palpable mass you mentioned earlier?\nPatient [55%]: I haven't mentioned feeling any lump or swelling around the anus or within the rectum. Everything I've noticed has just been related to the bleeding.\nDoctor [60%]: Have you experienced any nausea, vomiting, or a decrease in appetite since you started noticing the rectal bleeding?\nPatient [60%]: No, I haven't experienced any nausea, vomiting, or a decrease in appetite since the rectal bleeding started. Everything related to my appetite and digestion seems normal.\nDoctor [65%]: Have you noticed any increase in the frequency or urgency to use the bathroom since the bleeding started?\nPatient [65%]: No, I haven't noticed any increase in the frequency or urgency to use the bathroom since the bleeding started. Everything has been pretty consistent with my normal routine.\nDoctor [70%]: Given the symptoms you've described, it's important to investigate further to understand the cause of the rectal bleeding and palpable mass. REQUEST TEST: Colonoscopy\nMeasurement [70%]: RESULTS: NORMAL READINGS\nDoctor [75%]: Given the normal colonoscopy results, have you experienced any recent trauma or injury to the rectal area that could explain the bleeding and palpable mass?\nPatient [75%]: I haven't experienced any recent trauma or injury to the rectal area that I can recall. Everything seemed to start spontaneously without any clear cause.\nDoctor [80%]: Given the spontaneous onset of symptoms and the normal colonoscopy results, it's crucial to consider other potential causes. Have you been experiencing any difficulty or pain during urination or any changes in your urinary habits?\nPatient [80%]: No, I haven't experienced any difficulty or pain during urination, and there haven't been any changes in my urinary habits either. Everything seems normal in that aspect.\nDoctor [85%]: Given the information we have so far, it's important to assess for any systemic conditions that might be contributing to your symptoms. Have you noticed any skin changes, rashes, or joint pain that could suggest an inflammatory or autoimmune condition?\nPatient [85%]: No, I haven't noticed any skin changes, rashes, or joint pain. Everything seems pretty normal except for the rectal bleeding.\nDoctor [90%]: Given the normal colonoscopy and the absence of systemic symptoms, it's important to consider other local causes for the rectal bleeding and palpable mass. REQUEST TEST: Anorectal Ultrasound\nMeasurement [90%]: RESULTS: NORMAL READINGS\nDoctor [95%]: Given the normal anorectal ultrasound results, it's important to explore all possible causes. Have you had any changes in your diet or any new stressors in your life that could potentially be contributing to your symptoms?\nPatient [95%]: No, there haven't been any significant changes in my diet or any new stressors in my life recently. Everything has been pretty consistent.\nDoctor [100%]: DIAGNOSIS READY: Considering the normal colonoscopy and anorectal ultrasound results, along with the absence of systemic symptoms, dietary changes, or stressors, and no history of medication use that could explain the symptoms, the diagnosis is challenging without further information. However, the presence of bright red bleeding and a palpable mass that is not explained by the tests conducted so far suggests the possibility of a localized rectal pathology that may have been missed or is not detectable by the tests performed. A possible diagnosis could be an internal hemorrhoid that did not show on the anorectal ultrasound or a rectal polyp. Further evaluation by a specialist, such as a repeat colonoscopy with a different gastroenterologist or a more detailed imaging study, might be necessary to confirm the diagnosis and rule out other conditions.\n\nCorrect answer: Hemorrhoids\nScene 10, The diagnosis was  CORRECT 63\nDoctor [5%]: How long have these episodes of unresponsiveness been happening?\nPatient [5%]: They've been happening for about a month now.\nDoctor [10%]: Can you describe what happens just before you have one of these episodes?\nPatient [10%]: Right before it happens, I get this weird, muddy taste in my mouth.\nDoctor [15%]: Do these episodes happen at a specific time of day or are they random?\nPatient [15%]: They seem pretty random to me. I can't tell when they're going to happen.\nDoctor [20%]: Do you remain aware of your surroundings during these episodes, or do you lose consciousness completely?\nPatient [20%]: I don't remember anything during those times; it's like I'm not there at all.\nDoctor [25%]: Do you experience any kind of warning sign or aura before these episodes start?\nPatient [25%]: Just that muddy taste in my mouth. That's the only warning I get before it happens.\nDoctor [30%]: Have you noticed any triggers or patterns that seem to bring on these episodes, such as stress, lack of sleep, or certain activities?\nPatient [30%]: No, I haven't noticed anything like that. They just happen, no matter what I'm doing.\nDoctor [35%]: Have you experienced any muscle weakness or numbness in your body after these episodes?\nPatient [35%]: No, I haven't felt any weakness or numbness. Just really tired and kind of confused afterwards.\nDoctor [40%]: Do you have any history of neurological conditions in your family, such as epilepsy or seizures?\nPatient [40%]: Not that I know of. No one in my family has talked about having anything like that.\nDoctor [45%]: Have you had any recent head injuries or infections that you can remember?\nPatient [45%]: No, I haven't had any head injuries or been sick recently.\nDoctor [50%]: Do you experience headaches or any other type of pain before, during, or after these episodes?\nPatient [50%]: No, I don't get headaches or any other kind of pain with them.\nDoctor [55%]: Have you noticed any changes in your mood or behavior, such as feeling more anxious or depressed, around the time these episodes occur?\nPatient [55%]: No, I haven't noticed feeling more anxious or depressed. I just feel really confused and tired after it happens.\nDoctor [60%]: Have you ever had any issues with your heart or been diagnosed with any heart conditions?\nPatient [60%]: No, I've never had any heart problems or been told I have a heart condition.\nDoctor [65%]: Have you been experiencing any changes in your sleep patterns or the quality of your sleep since these episodes started?\nPatient [65%]: No, my sleep has been pretty much the same. I don't think it's changed since these episodes started.\nDoctor [70%]: Have you noticed any changes in your ability to concentrate or remember things since these episodes began?\nPatient [70%]: Yeah, I've noticed it's a bit harder to concentrate, especially after an episode. And sometimes, I can't remember things as well as I used to.\nDoctor [75%]: Have you had any episodes where you've experienced visual disturbances, like seeing flashing lights or spots, before these episodes occur?\nPatient [75%]: No, I haven't seen any flashing lights or spots before these episodes happen.\nDoctor [80%]: Have you ever experienced anything like this before, or is this the first time you're encountering these episodes?\nPatient [80%]: This is the first time anything like this has happened to me. I've never had episodes like these before.\nDoctor [85%]: Given your symptoms and the nature of these episodes, it's important we conduct some tests to get a clearer picture of what's happening. REQUEST TEST: EEG (Electroencephalogram) to check for any abnormal brain activity that might be causing these episodes.\nMeasurement [85%]: RESULTS: Electroencephalogram (EEG) findings show interictal spikes and sharp waves localized to the temporal lobes, more prominent on the right side.\nDoctor [90%]: Given the EEG results, have you experienced any unusual smells or sounds that weren't actually present before these episodes occur?\nPatient [90%]: No, I haven't noticed any unusual smells or sounds. Just that muddy taste in my mouth before it happens.\nDoctor [95%]: Given the EEG findings and your symptoms, it's crucial to assess your overall brain health and structure. REQUEST TEST: MRI (Magnetic Resonance Imaging) of the brain to look for any abnormalities that might be contributing to your episodes.\nMeasurement [95%]: RESULTS: MRI Brain findings show no evidence of mass lesions, infarctions, or structural abnormalities.\nDoctor [100%]: DIAGNOSIS READY: Temporal Lobe Epilepsy\n\nCorrect answer: Complex partial seizure\nScene 11, The diagnosis was  CORRECT 66\nDoctor [5%]: Hello, I'm Dr. Agent. Can you tell me more about how the accident happened and how you were positioned in the vehicle?\nPatient [5%]: Sure, I was the driver of the car that got hit from behind. I had my seatbelt on, and my knees hit the dashboard upon impact. The pain started right after that.\nDoctor [10%]: Can you describe the pain in your right groin area? Is it a sharp pain, dull ache, or something else?\nPatient [10%]: It's a sharp pain, especially when I try to move or walk. It feels really intense right in the groin area.\nDoctor [15%]: Have you noticed any swelling, bruising, or changes in the color of your skin around the area where you're experiencing pain?\nPatient [15%]: Yes, there's some bruising and it looks a bit swollen around my right groin area. It's also tender to touch.\nDoctor [20%]: Can you move your right leg without increasing the pain, or does any movement make it worse?\nPatient [20%]: Any movement really makes it worse. I've been trying to keep it as still as possible because moving it just intensifies the pain.\nDoctor [25%]: Have you experienced any numbness, tingling, or loss of sensation in your right leg or foot?\nPatient [25%]: No, I haven't experienced any numbness or tingling. It's mainly just the pain and difficulty moving my leg.\nDoctor [30%]: Given the impact and your symptoms, it's important to assess the stability and alignment of your hip and leg. Can you tell me if you've felt any popping or cracking in your hip area since the accident?\nPatient [30%]: No, I haven't felt any popping or cracking in my hip area since the accident. Just the severe pain and difficulty with movement.\nDoctor [35%]: Have you been able to bear any weight on your right leg, or is it too painful to stand or walk on it?\nPatient [35%]: It's too painful to stand or walk on it. I've been avoiding putting any weight on my right leg because the pain just becomes unbearable.\nDoctor [40%]: Given your symptoms and the mechanism of injury, it's crucial we get a clearer picture of what's happening internally. REQUEST TEST: Pelvic X-Ray\nMeasurement [40%]: RESULTS: Imaging (Pelvic X-ray) Findings: No fractures identified in the pelvic ring or femoral neck, but alignment suggests posterior dislocation of the right hip.\nDoctor [45%]: Given the X-ray findings of a posterior dislocation of your right hip, it's important to assess for any associated nerve damage. Have you noticed any changes in your ability to control your bladder or bowel movements since the accident?\nPatient [45%]: No, I haven't noticed any changes in my ability to control my bladder or bowel movements since the accident.\nDoctor [50%]: Given the diagnosis of a posterior hip dislocation, it's crucial to understand the full extent of your injury. Have you experienced any weakness in your right leg or foot since the accident?\nPatient [50%]: Yes, I've noticed that my right leg feels weaker than usual, especially when I try to move it or if I attempt to put a little weight on it. It just doesn't support me like it should.\nDoctor [55%]: Given the weakness in your right leg, it's important to check for any specific nerve involvement. Can you lift your foot upwards or is there difficulty in doing so?\nPatient [55%]: I've tried, but there's definitely difficulty in lifting my foot upwards. It feels weak and I can't move it like I normally would.\nDoctor [60%]: Given the difficulty in lifting your foot, it sounds like there might be nerve involvement. REQUEST TEST: MRI of the right hip and surrounding area to assess for nerve damage and any other soft tissue injuries.\nMeasurement [60%]: RESULTS: NORMAL READINGS\nDoctor [65%]: Given the MRI results showing normal readings, it's reassuring that there's no apparent nerve damage or soft tissue injuries around your hip. However, your symptoms still concern me. Have you noticed any improvement or worsening in your symptoms since the accident?\nPatient [65%]: There hasn't been any improvement in my symptoms since the accident. If anything, the pain seems just as intense, and the difficulty moving my right leg hasn't changed at all.\nDoctor [70%]: Given the persistent pain and difficulty moving your leg, it's important to manage your pain effectively while we plan the next steps. Have you taken any pain medication since the accident, and if so, has it helped at all?\nPatient [70%]: I've taken some over-the-counter pain medication, but it hasn't really helped much. The pain is still pretty severe, especially when I try to move or if I accidentally put weight on my right leg.\nDoctor [75%]: Given the severity of your pain and the lack of improvement with over-the-counter medication, we need to consider stronger pain management options. Have you ever had any allergic reactions to pain medications in the past?\nPatient [75%]: No, I haven't had any allergic reactions to pain medications in the past. I'm open to trying something stronger if it could help manage the pain better.\nDoctor [80%]: Given your openness to trying something stronger for pain management, we'll prescribe a more potent pain reliever to help manage your symptoms. In the meantime, it's crucial to keep your right leg immobilized to prevent further injury. Have you been using any support, like crutches or a wheelchair, to help with mobility?\nPatient [80%]: Yes, I've been using crutches to help with mobility. They've been a big help in keeping weight off my right leg and making it a bit easier to get around without worsening the pain.\nDoctor [85%]: Given your reliance on crutches and the severity of your symptoms, it's clear we need to address the dislocation directly. Have you had any previous surgeries or medical conditions that might affect your ability to undergo a procedure to correct the dislocation?\nPatient [85%]: No, I haven't had any previous surgeries or medical conditions that would affect my ability to undergo a procedure. I'm a bit nervous about it, but I understand if it's necessary to help with the dislocation.\nDoctor [90%]: Given your situation and the need to address the dislocation promptly to prevent further complications, we'll plan for a reduction procedure to reposition your hip. This procedure is typically very effective in resolving the dislocation and alleviating the pain. We'll ensure you're fully informed and comfortable with every step of the process. Do you have any questions or concerns about the procedure that I can address for you now?\nPatient [90%]: I'm just really worried about the recovery process after the procedure. How long will it take for me to recover, and will I need physical therapy afterwards?\nDoctor [95%]: It's completely understandable to be concerned about the recovery process. Recovery time can vary, but generally, you can expect to start feeling better within a few weeks after the procedure. Yes, physical therapy will be an essential part of your recovery to help regain strength and mobility in your hip and leg. We'll work closely with you to ensure you have a tailored rehabilitation plan. Is there anything else you'd like to know?\nPatient [95%]: Thank you, that does ease my mind a bit. I guess my only other question is about the long-term. Will I be able to return to my job as an elementary school teacher without any restrictions, or will there be things I need to be careful about even after I've recovered?\nDoctor [100%]: DIAGNOSIS READY: Posterior dislocation of the right hip\n\nCorrect answer: Posterior hip dislocation\nScene 12, The diagnosis was  CORRECT 69\nDoctor [5%]: How long has the baby been experiencing these symptoms?\nPatient [5%]: Since birth, doctor. He's only 2 days old, and we've noticed these issues right away.\nDoctor [10%]: Has the baby had any bowel movements at all since birth?\nPatient [10%]: No, doctor, he hasn't had any bowel movements since he was born.\nDoctor [15%]: Has the baby been feeding normally, or have there been any issues with feeding?\nPatient [15%]: He's been having trouble feeding, doctor. He seems to struggle and then vomits, especially after feeding.\nDoctor [20%]: Has the baby experienced any fever or signs of infection, such as lethargy or irritability?\nPatient [20%]: No, doctor, he hasn't had a fever, but he does seem very irritable, especially after trying to feed.\nDoctor [25%]: Has the baby's vomit been green or yellow in color, indicating it might be bilious?\nPatient [25%]: Yes, doctor, the vomit has been greenish in color.\nDoctor [30%]: Has the baby experienced any swelling or bloating in the abdominal area that seems unusual or excessive?\nPatient [30%]: Yes, doctor, his abdomen does seem swollen and more distended than what I would expect for a baby his age.\nDoctor [35%]: Has the baby had any issues with breathing or any respiratory distress?\nPatient [35%]: No, doctor, he hasn't had any noticeable breathing problems or respiratory distress.\nDoctor [40%]: Has there been any family history of digestive or gastrointestinal disorders that you're aware of?\nPatient [40%]: No, doctor, there's no family history of digestive or gastrointestinal disorders that we're aware of.\nDoctor [45%]: Has the baby had any episodes of blood in the vomit or stool that you've noticed?\nPatient [45%]: No, doctor, we haven't noticed any blood in his vomit or stool.\nDoctor [50%]: Has the baby been able to pass gas at all since birth?\nPatient [50%]: Yes, doctor, he has been able to pass some gas, but it doesn't seem to relieve his discomfort much.\nDoctor [55%]: Has the baby had any diagnostic tests done since birth, such as X-rays or ultrasound, to examine his abdomen?\nPatient [55%]: No, doctor, he hasn't had any diagnostic tests like X-rays or ultrasound done since birth.\nDoctor [60%]: REQUEST TEST: Abdominal X-Ray\nMeasurement [60%]: RESULTS: Dilated loops of bowel with no gas in the rectum, suggestive of a distal obstruction.\nDoctor [65%]: Given the X-ray results showing dilated loops of bowel with no gas in the rectum, has the baby shown any signs of dehydration, such as dry mouth or decreased urine output?\nPatient [65%]: Yes, doctor, now that you mention it, his mouth does seem quite dry, and his diaper changes have been less frequent because there's not much urine.\nDoctor [70%]: Given these symptoms and the X-ray findings, it's important to assess the baby's overall hydration and nutritional status. Has the baby been able to retain any fluids or breast milk at all, or does everything seem to be vomited back up?\nPatient [70%]: It seems like almost everything we try to feed him gets vomited back up, doctor. We've had very little success in getting him to retain fluids or breast milk.\nDoctor [75%]: Given the severity of the symptoms and the inability to retain fluids, it's crucial to ensure the baby receives adequate hydration. Has the baby received any form of hydration support, such as intravenous fluids, since these symptoms began?\nPatient [75%]: No, doctor, he hasn't received any form of hydration support like intravenous fluids yet.\nDoctor [80%]: Given the symptoms, the X-ray findings, and the lack of hydration support so far, it's critical we start intravenous fluids immediately to prevent further dehydration. Has the baby shown any improvement or worsening of symptoms in the last 24 hours?\nPatient [80%]: No, doctor, there hasn't been any improvement in his symptoms over the last 24 hours. If anything, it feels like his condition is getting worse, especially with the vomiting and his inability to keep anything down.\nDoctor [85%]: Given the baby's worsening condition and the symptoms described, it's important to consider a specific cause for the intestinal obstruction. Have you noticed any mucus or a jelly-like substance in the baby's vomit or around his mouth?\nPatient [85%]: No, doctor, we haven't noticed any mucus or jelly-like substance in his vomit or around his mouth.\nDoctor [90%]: Given the symptoms and the test results, it's crucial to determine the exact location and cause of the obstruction. REQUEST TEST: Contrast enema. This test can help us see if there's a blockage in the colon and possibly identify its cause.\nMeasurement [90%]: RESULTS: NORMAL READINGS\nDoctor [95%]: Given the normal contrast enema results, it's important to consider other causes for the symptoms and obstruction. Has the baby had any genetic testing or screenings done since birth that might indicate a congenital condition?\nPatient [95%]: No, doctor, he hasn't had any genetic testing or screenings done since birth.\nDoctor [100%]: DIAGNOSIS READY: Hirschsprung's disease.\n\nCorrect answer: Hirschsprung’s disease\nScene 13, The diagnosis was  CORRECT 71\nDoctor [5%]: How long have you been experiencing swelling and pain in your right ring finger?\nPatient [5%]: It started about 2 days ago, after a football game.\nDoctor [10%]: Did you injure your finger during the football game, or did the swelling and pain start without any noticeable injury?\nPatient [10%]: Yes, I did injure it during the game. My finger got caught in someone's jersey, and they pulled away really hard.\nDoctor [15%]: Did you notice any immediate swelling or discoloration after the injury occurred?\nPatient [15%]: Yes, it swelled up pretty quickly after that happened, but I didn't notice any discoloration right away.\nDoctor [20%]: Can you move your finger, or is the movement restricted due to the swelling and pain?\nPatient [20%]: I can't really flex it at the joint closest to my fingertip when I try to make a fist. It's pretty painful and feels stiff.\nDoctor [25%]: Have you taken any medication or applied any treatment to your finger since the injury occurred?\nPatient [25%]: No, I haven't taken any medication or applied any treatment yet. I was hoping it would just get better on its own.\nDoctor [30%]: Have you noticed any changes in the color or temperature of the skin around the swollen area since the injury?\nPatient [30%]: No, I haven't noticed any changes in color or temperature. It just looks swollen and feels painful.\nDoctor [35%]: Have you experienced any numbness or tingling sensations in your finger or around the swollen area?\nPatient [35%]: No, I haven't felt any numbness or tingling in the finger, just the swelling and pain.\nDoctor [40%]: Have you had any previous injuries or surgeries on this finger or hand before this incident?\nPatient [40%]: No, I've never had any injuries or surgeries on this finger or hand before this incident.\nDoctor [45%]: Have you noticed any popping, snapping, or grinding noises when you try to move your finger?\nPatient [45%]: No, I haven't noticed any popping, snapping, or grinding noises when I try to move it.\nDoctor [50%]: Have you experienced any fever or felt generally unwell since the injury occurred?\nPatient [50%]: No, I haven't experienced any fever or felt generally unwell since the injury happened.\nDoctor [55%]: Have you tried icing the finger or keeping it elevated to reduce the swelling?\nPatient [55%]: No, I haven't tried icing it or keeping it elevated yet. I wasn't sure if that would help.\nDoctor [60%]: Have you noticed any improvement or worsening of the swelling and pain in your finger since the injury occurred?\nPatient [60%]: Actually, it seems like the swelling and pain have gotten a bit worse since the injury happened.\nDoctor [65%]: Have you had any difficulty in performing daily activities or using your hand because of the swelling and pain in your finger?\nPatient [65%]: Yes, it's been difficult to write or do anything that requires gripping with my right hand because of the swelling and pain in my finger.\nDoctor [70%]: Have you noticed any fluid or pus coming from the injured finger, or any open wounds on it?\nPatient [70%]: No, I haven't noticed any fluid or pus coming from the finger, and there aren't any open wounds on it.\nDoctor [75%]: Have you experienced any locking sensation in your finger when you try to move it, or does it feel like it gets stuck in one position?\nPatient [75%]: No, I haven't experienced any locking sensation or felt like it gets stuck in one position. It just doesn't bend well at the joint and is painful when I try.\nDoctor [80%]: Have you had any previous conditions or diseases affecting your joints or bones that we should be aware of?\nPatient [80%]: No, I've never had any conditions or diseases affecting my joints or bones before this.\nDoctor [85%]: Have you noticed any significant increase in swelling or pain after certain activities or during a specific time of the day?\nPatient [85%]: No, I haven't noticed any significant increase in swelling or pain after certain activities or during a specific time of the day. It just seems consistently swollen and painful since the injury.\nDoctor [90%]: Given the symptoms and history you've provided, it's important to assess the structural integrity of your finger to rule out any fractures or serious ligament damage. REQUEST TEST: X-Ray of the right ring finger.\nMeasurement [90%]: RESULTS: X-ray of the Right Hand: No bone fractures or dislocations visible. Soft tissue swelling noted around the distal interphalangeal joint of the right ring finger.\nDoctor [95%]: Given the X-ray results showing no fractures or dislocations but noting soft tissue swelling, it's important to determine the extent of ligament damage. Have you felt any improvement at all since the injury, or has the condition remained the same?\nPatient [95%]: It's pretty much remained the same since the injury. The swelling and pain haven't really improved at all.\nDoctor [100%]: DIAGNOSIS READY: Sprain of the distal interphalangeal joint of the right ring finger with possible ligament injury.\n\nCorrect answer: Rupture of the flexor digitorum profundus tendon at its point of insertion\nScene 14, The diagnosis was  INCORRECT 66\n","output_type":"stream"}]},{"cell_type":"markdown","source":"The above cost $4.35","metadata":{}},{"cell_type":"markdown","source":"2. GPT3.5","metadata":{}},{"cell_type":"code","source":"# if __name__ == \"__main__\":\n#     parser = argparse.ArgumentParser(description='Medical Diagnosis Simulation CLI')\n#     parser.add_argument('--openai_api_key', type=str, required=False, help='OpenAI API Key')\n#     parser.add_argument('--replicate_api_key', type=str, required=False, help='Replicate API Key')\n#     parser.add_argument('--inf_type', type=str, choices=['llm', 'human_doctor', 'human_patient'], default='llm')\n#     parser.add_argument('--doctor_bias', type=str, help='Doctor bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"confirmation\", \"status_quo\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--patient_bias', type=str, help='Patient bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"self_diagnosis\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--doctor_llm', type=str, default='gpt4')\n#     parser.add_argument('--patient_llm', type=str, default='gpt4')\n#     parser.add_argument('--measurement_llm', type=str, default='gpt4')\n#     parser.add_argument('--moderator_llm', type=str, default='gpt4')\n#     parser.add_argument('--agent_dataset', type=str, default='MedQA') # MedQA, MIMICIV or NEJM\n#     parser.add_argument('--doctor_image_request', type=bool, default=False) # whether images must be requested or are provided\n#     parser.add_argument('--num_scenarios', type=int, default=15, required=False, help='Number of scenarios to simulate')\n#     parser.add_argument('--total_inferences', type=int, default=20, required=False, help='Number of inferences between patient and doctor')\n#     parser.add_argument('--anthropic_api_key', type=str, default=None, required=False, help='Anthropic API key for Claude 3.5 Sonnet')\n    \n#     args = parser.parse_args()\n    \n    # python3 agentclinic.py --openai_api_key \"YOUR_OPENAIAPI_KEY\" --inf_type \"llm\"\n\n    # main(args.openai_api_key, args.replicate_api_key, args.inf_type, args.doctor_bias, args.patient_bias, args.doctor_llm, args.patient_llm, args.measurement_llm, args.moderator_llm, args.num_scenarios, args.agent_dataset, args.doctor_image_request, args.total_inferences, args.anthropic_api_key)\nmy_openai_api_key = \"YOUR_OPENAIAPI_KEY\"\nmy_replicate_api_key = \"\"\nmy_inf_type = \"llm\"\nmy_doctor_bias = 'None'\nmy_patient_bias = 'None'\nmy_doctor_llm = 'gpt3.5'\nmy_patient_llm = 'gpt4'\nmy_measurement_llm = 'gpt4'\nmy_moderator_llm = 'gpt4'\nmy_agent_dataset = 'MedQA'\nmy_doctor_image_request = False\nmy_num_scenarios = 15\nmy_total_inferences = 20\nmy_anthropic_api_key = None\n\nmain(my_openai_api_key, my_replicate_api_key, my_inf_type, my_doctor_bias, my_patient_bias, my_doctor_llm, my_patient_llm, my_measurement_llm, my_moderator_llm, my_num_scenarios, my_agent_dataset, my_doctor_image_request, my_total_inferences, my_anthropic_api_key)","metadata":{"execution":{"iopub.status.busy":"2024-09-25T16:43:35.339352Z","iopub.execute_input":"2024-09-25T16:43:35.339921Z","iopub.status.idle":"2024-09-25T16:59:36.529668Z","shell.execute_reply.started":"2024-09-25T16:43:35.339865Z","shell.execute_reply":"2024-09-25T16:59:36.528197Z"},"collapsed":true,"jupyter":{"outputs_hidden":true},"trusted":true},"execution_count":17,"outputs":[{"name":"stdout","text":"Doctor [5%]: What is your age?\nPatient [5%]: I'm 35 years old.\nDoctor [10%]: Have you experienced any recent head trauma or injuries?\nPatient [10%]: No, I haven't had any head trauma or injuries recently.\nDoctor [15%]: Have you noticed any changes in your vision, such as blurriness or double vision?\nPatient [15%]: Yes, I've been experiencing double vision for about a month now.\nDoctor [20%]: When did you first notice the difficulty climbing stairs and upper limb weakness?\nPatient [20%]: I first noticed the difficulty climbing stairs and the weakness in my upper limbs around the same time as the double vision, so about a month ago.\nDoctor [25%]: Do you have any other symptoms such as difficulty swallowing or slurred speech?\nPatient [25%]: No, I haven't had any difficulty swallowing or slurred speech.\nDoctor [30%]: Do you have any numbness or tingling in your limbs?\nPatient [30%]: No, I haven't experienced any numbness or tingling in my limbs.\nDoctor [35%]: Have you had any recent infections or illnesses?\nPatient [35%]: No, I haven't had any recent infections or illnesses.\nDoctor [40%]: REQUEST TEST: MRI Brain and Spine\nMeasurement [40%]: RESULTS: NORMAL READINGS\nDoctor [45%]: Do you have a family history of any neurological conditions?\nPatient [45%]: No, there's no family history of neurological conditions that I'm aware of.\nDoctor [50%]: Have you traveled to any new places recently or been exposed to any unusual environments?\nPatient [50%]: No, I haven't traveled to any new places or been exposed to any unusual environments recently.\nDoctor [55%]: Have you noticed any muscle twitching or cramping in your limbs?\nPatient [55%]: No, I haven't noticed any muscle twitching or cramping in my limbs.\nDoctor [60%]: Have you experienced any changes in your speech or voice quality recently?\nPatient [60%]: No, I haven't noticed any changes in my speech or voice quality.\nDoctor [65%]: Have you had any recent vaccinations or taken any new medications?\nPatient [65%]: No, I haven't had any recent vaccinations or started any new medications.\nDoctor [70%]: Do you have any history of autoimmune diseases in yourself or your family?\nPatient [70%]: No, I don't have any history of autoimmune diseases, and as far as I know, my family doesn't either.\nDoctor [75%]: Do you have any history of cancer in yourself or your family?\nPatient [75%]: No, there's no history of cancer in myself or in my family.\nDoctor [80%]: Have you had any recent blood tests done to check for any abnormalities?\nPatient [80%]: No, I haven't had any recent blood tests done to check for abnormalities.\nDoctor [85%]: Have you experienced any muscle weakness in your lower limbs as well?\nPatient [85%]: Yes, I've noticed some weakness in my lower limbs as well, especially when trying to climb stairs.\nDoctor [90%]: Have you experienced any difficulty with coordination or balance?\nPatient [90%]: No, I haven't experienced any difficulty with coordination or balance.\nDoctor [95%]: Have you had any recent exposure to toxins or chemicals in your environment?\nPatient [95%]: No, I haven't had any recent exposure to toxins or chemicals in my environment.\nDoctor [100%]: DIAGNOSIS READY: Guillain-Barré Syndrome\n\nCorrect answer: Myasthenia gravis\nScene 0, The diagnosis was  INCORRECT 0\nDoctor [5%]: What symptoms are you experiencing that are concerning you?\nPatient [5%]: Lately, I've been having trouble walking; it's like I can't control my movements properly, and my friends say I look like I'm drunk when I walk. I've also noticed that my right arm isn't as strong as it used to be, and I'm having a hard time coordinating my movements.\nDoctor [10%]: Have you experienced any numbness or tingling in your limbs?\nPatient [10%]: No, I haven't felt any numbness or tingling, just this awkwardness and lack of coordination, especially in my right arm and with walking.\nDoctor [15%]: Have you noticed any changes in your vision or speech recently?\nPatient [15%]: No, my vision and speech have been normal. It's really just the walking and coordination issues that have been bothering me.\nDoctor [20%]: Have you experienced any dizziness or vertigo along with your trouble walking and coordination issues?\nPatient [20%]: No, I haven't experienced any dizziness or vertigo. It's mainly just the difficulty with walking and the coordination problems with my right arm that I've noticed.\nDoctor [25%]: What is your medical history like?\nPatient [25%]: I was diagnosed with Crohn's disease about two years ago. It's been quite severe and hasn't responded well to the standard treatments. For the past year, I've been on natalizumab to manage it.\nDoctor [30%]: Have you had any recent infections or fevers that you can recall?\nPatient [30%]: No, I haven't had any recent infections or fevers. Everything has been pretty stable, except for the issues with walking and my arm strength.\nDoctor [35%]: Have you had any recent changes in your bowel habits or abdominal pain related to your Crohn's disease?\nPatient [35%]: No, my bowel habits and abdominal pain have been pretty consistent with what I've experienced since my Crohn's diagnosis. There haven't been any new or worsening symptoms in that area.\nDoctor [40%]: Have you noticed any changes in your balance or coordination when you close your eyes or stand with your feet together?\nPatient [40%]: Yes, I've noticed that my balance gets even worse when I close my eyes or try to stand with my feet together. It feels like I could fall over much easier.\nDoctor [45%]: Do you have a family history of any neurological conditions or movement disorders?\nPatient [45%]: No, there's no family history of neurological conditions or movement disorders that I'm aware of.\nDoctor [50%]: Do you have any history of head injuries or trauma that you can recall?\nPatient [50%]: No, I haven't had any head injuries or trauma. Everything started happening without any obvious reason.\nDoctor [55%]: Have you had any recent blood work done to check for any abnormalities or deficiencies?\nPatient [55%]: No, I haven't had any recent blood work done specifically for these new symptoms. My last tests were mainly focused on monitoring my Crohn's disease.\nDoctor [60%]: REQUEST TEST: Vitamin B12 levels.\nMeasurement [60%]: RESULTS: NORMAL READINGS\nDoctor [65%]: Have you experienced any changes in your hearing or ringing in your ears recently?\nPatient [65%]: No, I haven't noticed any changes in my hearing or experienced any ringing in my ears. Everything seems normal in that regard.\nDoctor [70%]: Have you had any recent exposure to toxins or chemicals that you can think of?\nPatient [70%]: No, I haven't had any recent exposure to toxins or chemicals that I can think of. Everything in my environment has been pretty consistent.\nDoctor [75%]: Have you had any recent travel to areas where certain infections or diseases are more common?\nPatient [75%]: No, I haven't traveled recently to any areas known for specific infections or diseases. My routine has been pretty much the same, especially since my Crohn's disease requires me to be cautious about my health and environment.\nDoctor [80%]: Have you ever been tested for Lyme disease or other tick-borne illnesses in the past?\nPatient [80%]: No, I haven't been tested for Lyme disease or any other tick-borne illnesses before.\nDoctor [85%]: Have you ever been vaccinated against tick-borne illnesses like Lyme disease?\nPatient [85%]: No, I haven't been vaccinated against Lyme disease or any other tick-borne illnesses.\nDoctor [90%]: Have you ever had a spinal cord injury or surgery in the past that could be related to your current symptoms?\nPatient [90%]: No, I haven't had any spinal cord injuries or surgeries in the past.\nDoctor [95%]: Have you ever been tested for multiple sclerosis or other autoimmune disorders in the past?\nPatient [95%]: No, I haven't been tested for multiple sclerosis or other autoimmune disorders before.\nDoctor [100%]: Do you have a history of smoking or alcohol consumption that could be relevant to your current symptoms?\nPatient [100%]: No, I don't smoke, and I rarely drink alcohol, so I don't think that could be related to my current symptoms.\nDoctor [5%]: What symptoms are you experiencing?\nPatient [5%]: I've been really fussy lately and not wanting to eat much. My tummy feels weird, and I cry a lot, especially when my belly is touched.\nDoctor [10%]: Have you been having any vomiting or diarrhea?\nPatient [10%]: No, I haven't had any vomiting or diarrhea.\nDoctor [15%]: Is there any particular time of day when you feel more uncomfortable?\nPatient [15%]: It seems like I'm more uncomfortable after trying to eat, but really, I feel fussy and upset a lot of the time, not just at any specific time of day.\nDoctor [20%]: Do you have any trouble passing gas or having bowel movements?\nPatient [20%]: Yes, it seems like I'm having a hard time with that. It's been really difficult lately.\nDoctor [25%]: Does your belly feel bloated or swollen?\nPatient [25%]: Yes, my belly does feel bloated and looks swollen too.\nDoctor [30%]: Does your belly feel tender or painful when I press on it?\nPatient [30%]: Yes, it really hurts when you press on it. I cry more because it's very uncomfortable.\nDoctor [35%]: What color is your stool?\nPatient [35%]: My stool has been looking lighter than usual, almost a pale color.\nDoctor [40%]: REQUEST TEST: Liver function tests.\nMeasurement [40%]: RESULTS: NORMAL READINGS\nDoctor [45%]: Is there a family history of any medical conditions that you know of?\nPatient [45%]: No, there's no family history of any medical conditions that we know of.\nDoctor [50%]: Have you been experiencing any jaundice or yellowing of your skin or eyes?\nPatient [50%]: No, I haven't noticed any yellowing of my skin or eyes.\nDoctor [55%]: Do you have any rashes or skin changes that you've noticed recently?\nPatient [55%]: No, I haven't noticed any rashes or skin changes recently.\nDoctor [60%]: Does your urine appear darker than usual?\nPatient [60%]: Yes, I think my urine does look darker than usual.\nDoctor [65%]: Does your urine have a strong odor to it as well?\nPatient [65%]: Yes, it does seem to have a stronger odor than usual.\nDoctor [70%]: Have you been feeling more tired than usual or having trouble sleeping?\nPatient [70%]: I've been really fussy and seem to have trouble settling down, so yes, I guess I've been having trouble sleeping. It's hard to tell if I'm more tired since I'm upset a lot.\nDoctor [75%]: Have you been experiencing any difficulty breathing or wheezing?\nPatient [75%]: No, I haven't had any trouble breathing or wheezing.\nDoctor [80%]: Have you been experiencing any excessive sweating or fever?\nPatient [80%]: No, I haven't had any excessive sweating or fever.\nDoctor [85%]: Have you been experiencing any poor weight gain or failure to thrive?\nPatient [85%]: Actually, despite not eating much, it seems like I've been gaining weight, or at least my mom thinks so.\nDoctor [90%]: Does your abdomen feel firm or hard to the touch in certain areas?\nPatient [90%]: Yes, there are spots on my belly that feel really firm and hard when you touch them. It's very uncomfortable.\nDoctor [95%]: Have you had any recent episodes of constipation or difficulty passing stool?\nPatient [95%]: Yes, I've been having a lot of trouble with constipation and it's been really hard to pass stool lately.\nDoctor [100%]: DIAGNOSIS READY: Hirschsprung's disease\n\nCorrect answer: Hirschsprung disease\nScene 2, The diagnosis was  CORRECT 33\nDoctor [5%]: What is the nature of your abdominal pain?\nPatient [5%]: The pain is constant and dull, mostly around my belly area. It seems to get worse after I eat.\nDoctor [10%]: Have you experienced any changes in your bowel habits recently?\nPatient [10%]: No, I haven't noticed any significant changes in my bowel habits. Everything seems to be pretty regular in that department.\nDoctor [15%]: Have you noticed any changes in your appetite recently?\nPatient [15%]: Yes, actually, I've noticed a decrease in my appetite. I don't feel like eating much these days, even foods I used to enjoy.\nDoctor [20%]: Have you had any fevers or chills recently?\nPatient [20%]: No, I haven't had any fevers or chills. But I've been having these excessive night sweats, especially bad at night.\nDoctor [25%]: Do you have any history of unexplained weight loss recently?\nPatient [25%]: Yes, I've lost about 12 pounds in the last month without trying. It's been quite unexpected.\nDoctor [30%]: Have you noticed any lumps or bumps anywhere else on your body besides the enlarged supraclavicular lymph node?\nPatient [30%]: I've felt some swelling around my neck, but I haven't noticed lumps or bumps elsewhere. The swelling in my neck seemed to come up pretty quickly over the last few days.\nDoctor [35%]: Is the swelling in your neck painful to touch?\nPatient [35%]: No, the swelling isn't painful to touch, but it's definitely noticeable and a bit uncomfortable.\nDoctor [40%]: Can you describe the size and texture of the enlarged supraclavicular lymph node?\nPatient [40%]: The enlarged area on my neck feels quite firm, and it's about the size of a walnut. It doesn't move much when I touch it.\nDoctor [45%]: Is the skin over the enlarged supraclavicular lymph node red or warm to the touch?\nPatient [45%]: No, the skin over it isn't red or warm. It looks normal, just swollen.\nDoctor [50%]: REQUEST TEST: Biopsy of the enlarged supraclavicular lymph node.\nMeasurement [50%]: RESULTS: Biopsy of the cervical lymph node shows lymphocytes with a high proliferative index that stain positive for CD20.\nDoctor [55%]: Do you have any history of autoimmune diseases in your family?\nPatient [55%]: No, there's no history of autoimmune diseases in my family that I'm aware of.\nDoctor [60%]: Do you experience any shortness of breath or chest pain?\nPatient [60%]: No, I haven't experienced any shortness of breath or chest pain.\nDoctor [65%]: Do you have any history of night sweats or weight loss in the past?\nPatient [65%]: No, I've never had issues with night sweats or unexplained weight loss like this before. It's all been quite recent.\nDoctor [70%]: Have you traveled to any new or exotic locations recently?\nPatient [70%]: No, I haven't traveled anywhere recently, especially not to any new or exotic locations.\nDoctor [75%]: Have you noticed any changes in your skin, such as rashes or itching?\nPatient [75%]: No, I haven't noticed any changes in my skin, like rashes or itching. Everything seems normal in that regard.\nDoctor [80%]: Have you experienced any persistent cough or difficulty swallowing recently?\nPatient [80%]: No, I haven't had any persistent cough or difficulty swallowing. Everything seems normal with my breathing and swallowing.\nDoctor [85%]: Have you had any recent infections or illnesses that you can recall?\nPatient [85%]: No, I haven't had any recent infections or illnesses. It's been pretty unusual for me to feel this way without any apparent reason.\nDoctor [90%]: Based on your symptoms and the biopsy results showing lymphocytes with a high proliferative index that stain positive for CD20, I suspect you may have Hodgkin's lymphoma. This type of cancer can cause symptoms like night sweats, weight loss, and enlarged lymph nodes. I recommend further imaging studies and consultation with an oncologist for treatment options.\nPatient [90%]: That's a lot to take in. What kind of imaging studies are we talking about, and how soon should I see an oncologist?\nDoctor [95%]: We will need to do a PET-CT scan to assess the extent of the disease and staging. I will arrange for the imaging studies to be done as soon as possible, and we will aim to get you an appointment with an oncologist within the next week.\nPatient [95%]: Thank you for explaining that. I'm feeling a bit overwhelmed, but I understand the importance of moving quickly. Is there anything I should do to prepare for the PET-CT scan or anything specific I should avoid?\nDoctor [100%]: DIAGNOSIS READY: Hodgkin's lymphoma\n\nCorrect answer: Diffuse large B-cell lymphoma\nScene 3, The diagnosis was  INCORRECT 25\nDoctor [5%]: What is the nature of your flank pain?\nPatient [5%]: The pain is dull and constant, but it gets sharper when I move in certain ways. It's been bothering me for a few weeks now.\nDoctor [10%]: What is the quality of your fever?\nPatient [10%]: It's been a low-grade fever, mostly in the evenings. It doesn't seem to go away completely, even with over-the-counter fever reducers.\nDoctor [15%]: When did you finish your recent antibiotic treatment for acute sinusitis?\nPatient [15%]: I finished the antibiotics about two weeks ago. The sinusitis symptoms have cleared up, but the fever, fatigue, and this flank pain just haven't gone away.\nDoctor [20%]: Have you experienced any changes in your urine color or frequency?\nPatient [20%]: No, I haven't noticed any changes in the color of my urine, and I'm going to the bathroom just as often as I usually do.\nDoctor [25%]: Have you had any recent travel or exposure to sick individuals?\nPatient [25%]: No, I haven't traveled recently, and I haven't been around anyone who's sick that I know of.\nDoctor [30%]: Do you have any history of kidney stones or urinary tract infections?\nPatient [30%]: No, I don't have a history of kidney stones or urinary tract infections.\nDoctor [35%]: Have you had any recent blood tests done to check your kidney function or infection markers?\nPatient [35%]: No, I haven't had any recent blood tests done. Should I be concerned about my kidneys?\nDoctor [40%]: Have you had any recent episodes of nausea or vomiting?\nPatient [40%]: No, I haven't had any nausea or vomiting. Everything seems normal with my appetite and digestion, aside from the fatigue and pain.\nDoctor [45%]: Do you have any history of autoimmune diseases in your family?\nPatient [45%]: No, there's no history of autoimmune diseases in my family that I'm aware of.\nDoctor [50%]: Do you have any history of allergies to medications or any other medical conditions?\nPatient [50%]: Yes, I had a rash when I was taking amoxicillin recently, but it went away after the antibiotic was changed to cephalexin. Other than that, I don't have any known allergies to medications.\nDoctor [55%]: REQUEST TEST: Complete Blood Count (CBC)\nMeasurement [55%]: RESULTS: NORMAL READINGS\nDoctor [60%]: Do you have any history of recent injuries or trauma to your flank area?\nPatient [60%]: No, I haven't had any recent injuries or trauma to my flank area or anywhere else for that matter.\nDoctor [65%]: Have you had any recent episodes of chills or night sweats?\nPatient [65%]: Yes, I've had some episodes of chills, especially in the evenings around the same time my fever spikes. I've also noticed that I've been sweating a lot at night, even when it's not particularly warm in my room.\nDoctor [70%]: Have you noticed any unintentional weight loss recently?\nPatient [70%]: No, I haven't noticed any unintentional weight loss recently. My appetite has been pretty normal.\nDoctor [75%]: Have you had any recent exposure to contaminated water sources or consumed any undercooked meats?\nPatient [75%]: No, I haven't been exposed to any contaminated water that I'm aware of, and I'm always very careful about making sure my meats are well-cooked before I eat them.\nDoctor [80%]: Have you had any recent imaging studies done to check your kidneys or abdomen? \nPatient [80%]: No, I haven't had any recent imaging studies done on my kidneys or abdomen. Should I be getting those tests done?\nDoctor [85%]: Have you had any recent episodes of joint pain or swelling?\nPatient [85%]: No, I haven't had any joint pain or swelling recently. Everything seems to be focused around the fatigue, fever, and flank pain.\nDoctor [90%]: Have you experienced any shortness of breath or chest pain recently?\nPatient [90%]: No, I haven't experienced any shortness of breath or chest pain. My main issues have really been the fatigue, fever, and flank pain.\nDoctor [95%]: Have you had any recent episodes of diarrhea or changes in your bowel habits?\nPatient [95%]: No, I haven't had any episodes of diarrhea or significant changes in my bowel habits. Everything seems pretty regular in that department.\nDoctor [100%]: DIAGNOSIS READY: Pyelonephritis\n\nCorrect answer: Acute interstitial nephritis\nScene 4, The diagnosis was  INCORRECT 20\nDoctor [5%]: What type of physical activity have you been doing recently?\nPatient [5%]: I've been playing a lot of volleyball lately, which involves a lot of jumping and quick movements.\nDoctor [10%]: Have you experienced any swelling or redness in your knee following these activities?\nPatient [10%]: No, I haven't noticed any swelling or redness, just the pain, especially when I move certain ways.\nDoctor [15%]: How would you describe the pain in your knee? Is it sharp, dull, or throbbing?\nPatient [15%]: The pain feels more like a sharp ache, especially when I bend or twist my knee. It's really noticeable right below my kneecap on the inside part of my leg.\nDoctor [20%]: Have you had any previous knee injuries or surgeries in the past?\nPatient [20%]: No, I haven't had any previous knee injuries or surgeries. This is the first time I've experienced something like this.\nDoctor [25%]: Do you feel any instability or weakness in your knee when you're active?\nPatient [25%]: No, I don't feel any instability or weakness, just the sharp pain when I'm moving around, especially during volleyball.\nDoctor [30%]: Do you recall any specific incident or trauma that may have caused this knee pain during your volleyball activities?\nPatient [30%]: I can't recall a specific incident or trauma. It just started hurting after playing a few games, and it's been getting worse since then.\nDoctor [35%]: Have you noticed any clicking or popping sounds coming from your knee when you move it?\nPatient [35%]: No, I haven't noticed any clicking or popping sounds. It's just the pain that's been bothering me.\nDoctor [40%]: Do you have any history of arthritis in your family?\nPatient [40%]: No, there's no history of arthritis in my family that I'm aware of.\nDoctor [45%]: Do you have any history of allergies or autoimmune diseases in your family?\nPatient [45%]: No, there's no history of allergies or autoimmune diseases in my family either.\nDoctor [50%]: Have you had any recent changes in your footwear or equipment that you use for volleyball?\nPatient [50%]: No, I haven't changed my footwear or any equipment recently. I've been using the same shoes and gear since I started playing volleyball.\nDoctor [55%]: REQUEST TEST: Knee MRI\nMeasurement [55%]: RESULTS: MRI_Knee: Optional. Can be considered if clinical suspicion persists despite negative initial workup, not mandatory for diagnosis in this simulated case.\nDoctor [60%]: Is there any specific movement or activity that seems to trigger the sharp pain in your knee more than others?\nPatient [60%]: Yes, the pain gets particularly sharp when I'm jumping or doing quick pivots and twists on the court. Those movements seem to really aggravate it.\nDoctor [65%]: Have you noticed any improvement or worsening of the pain with rest or certain activities?\nPatient [65%]: The pain does seem to get a bit better when I rest and avoid volleyball or any similar activities. But as soon as I try to get back into it, the pain comes back just as sharp.\nDoctor [70%]: Have you tried using any ice or heat packs on your knee to help with the pain?\nPatient [70%]: Yes, I've tried using ice packs on my knee after the games, and it seems to help a little with the pain, but the relief is temporary.\nDoctor [75%]: Have you noticed any warmth or fever in the knee area along with the pain?\nPatient [75%]: No, I haven't noticed any warmth or fever in the knee area, just the pain.\nDoctor [80%]: Does the pain in your knee feel worse in the morning or at night?\nPatient [80%]: The pain doesn't really change much between morning and night. It mostly just gets worse with physical activity, especially the movements I mentioned before.\nDoctor [85%]: Based on your symptoms and history, it seems like you may be experiencing patellofemoral pain syndrome. This condition often presents with pain around or under the kneecap, especially with activities like jumping and twisting. Have you had any previous issues with your kneecap or surrounding muscles?\nPatient [85%]: No, I haven't had any previous issues with my kneecap or surrounding muscles before this started happening.\nDoctor [90%]: Have you noticed any grinding or crunching sensation in your knee when you move it?\nPatient [90%]: No, I haven't felt any grinding or crunching sensation in my knee when I move it.\nDoctor [95%]: REQUEST TEST: Patellar Tendon Ultrasound\nMeasurement [95%]: RESULTS: NORMAL READINGS\nDoctor [100%]: DIAGNOSIS READY: Patellofemoral Pain Syndrome\n\nCorrect answer: Pes anserine bursitis\nScene 5, The diagnosis was  INCORRECT 16\nDoctor [5%]: What were you doing when you experienced the loss of consciousness?\nPatient [5%]: I had just finished urinating and was about to leave the bathroom when it happened.\nDoctor [10%]: Do you have any history of heart problems or high blood pressure?\nPatient [10%]: No, I've never had any heart problems or high blood pressure that I'm aware of.\nDoctor [15%]: Have you experienced any dizziness or lightheadedness before this episode?\nPatient [15%]: Not really, I felt completely normal up until the moment I lost consciousness.\nDoctor [20%]: Do you have any history of diabetes or low blood sugar?\nPatient [20%]: No, I don't have a history of diabetes or issues with low blood sugar either.\nDoctor [25%]: Have you experienced any recent head injuries or trauma?\nPatient [25%]: No, I haven't had any recent head injuries or trauma.\nDoctor [30%]: Have you been feeling more fatigued than usual lately?\nPatient [30%]: No, I haven't been feeling more fatigued than usual. My energy levels have been pretty consistent.\nDoctor [35%]: Have you been under a lot of stress or anxiety recently?\nPatient [35%]: Not particularly, no more than the usual stresses of work. I'm a high school teacher, so there's always a bit of stress, but nothing out of the ordinary recently.\nDoctor [40%]: Have you been experiencing any chest pain or shortness of breath recently?\nPatient [40%]: No, I haven't experienced any chest pain or shortness of breath recently.\nDoctor [45%]: Have you had any recent changes in your medication or started taking any new medications?\nPatient [45%]: No, I haven't started taking any new medications or had any changes in my medication recently. I'm not on any regular medications.\nDoctor [50%]: Have you ever fainted before this episode of loss of consciousness?\nPatient [50%]: No, this was the first time I've ever fainted or lost consciousness like that.\nDoctor [55%]: Have you noticed any changes in your vision or hearing recently?\nPatient [55%]: No, I haven't noticed any changes in my vision or hearing recently. Everything seemed normal up until the episode.\nDoctor [60%]: Have you experienced any episodes of palpitations or irregular heartbeats before?\nPatient [60%]: No, I haven't experienced any palpitations or irregular heartbeats before. Everything seemed quite normal until this episode happened.\nDoctor [65%]: Have you ever been diagnosed with any neurological conditions such as epilepsy or seizures in the past?\nPatient [65%]: No, I've never been diagnosed with epilepsy or any kind of seizures in the past.\nDoctor [70%]: Have you ever had any episodes of fainting or loss of consciousness in the past, even if it wasn't as severe as this recent episode?\nPatient [70%]: No, I've never had any episodes of fainting or loss of consciousness before this. This was completely new to me.\nDoctor [75%]: Have you traveled recently to a different climate or altitude before this episode?\nPatient [75%]: No, I haven't traveled recently to any place with a different climate or altitude. Everything in my routine has been pretty much the same.\nDoctor [80%]: Have you experienced any numbness or tingling in your limbs before or after the episode of loss of consciousness?\nPatient [80%]: No, I haven't experienced any numbness or tingling in my limbs before or after the episode. Everything felt normal once I regained consciousness.\nDoctor [85%]: Have you ever been diagnosed with any sleep disorders such as sleep apnea?\nPatient [85%]: No, I've never been diagnosed with any sleep disorders like sleep apnea.\nDoctor [90%]: Have you had any recent infections or fevers before this episode of loss of consciousness?\nPatient [90%]: No, I haven't had any recent infections or fevers before this episode of loss of consciousness. Everything was pretty normal health-wise.\nDoctor [95%]: Have you ever had any issues with dehydration in the past?\nPatient [95%]: No, I haven't had any issues with dehydration in the past. I generally make sure to stay well-hydrated, especially since I'm active and on my feet most of the day teaching.\nDoctor [100%]: Have you ever experienced any episodes of blacking out or feeling like you were going to faint before this recent episode of loss of consciousness?\nPatient [100%]: No, I've never experienced any episodes of blacking out or feeling like I was going to faint before this recent episode. This was the first time anything like this has happened to me.\nDoctor [5%]: What seems to be the problem with the baby today?\nPatient [5%]: The baby has a continuous heart murmur, and we've noticed some bluish spots on her skin that don't go away when you press on them. Also, her eyes look a bit cloudy, and she didn't pass her hearing tests.\nDoctor [10%]: What was the baby's birth weight and gestational age?\nPatient [10%]: She was born at term, weighing 3000 grams.\nDoctor [15%]: Is the baby having any difficulty breathing or feeding?\nPatient [15%]: No, she hasn't had any trouble breathing or feeding so far.\nDoctor [20%]: Is the baby experiencing any excessive sweating or difficulty gaining weight?\nPatient [20%]: No, she hasn't been sweating excessively or having trouble gaining weight as of now.\nDoctor [25%]: Does the baby seem more tired or lethargic than usual?\nPatient [25%]: No, she doesn't seem more tired or lethargic than usual.\nDoctor [30%]: Does the baby have any family history of heart problems or genetic disorders?\nPatient [30%]: We're not aware of any family history of heart problems or genetic disorders.\nDoctor [35%]: Does the baby have any trouble moving her arms or legs?\nPatient [35%]: No, she doesn't seem to have any trouble moving her arms or legs.\nDoctor [40%]: Does the baby have any trouble breathing while sleeping?\nPatient [40%]: No, she hasn't had any trouble breathing while sleeping.\nDoctor [45%]: Does the baby have any difficulty with bowel movements or urination?\nPatient [45%]: No, she hasn't had any difficulty with bowel movements or urination.\nDoctor [50%]: Does the baby have any history of infections or illnesses since birth?\nPatient [50%]: No, she hasn't had any infections or illnesses since birth.\nDoctor [55%]: What color are the bluish spots on the baby's skin?\nPatient [55%]: The bluish spots are a dark blue color and they're scattered around her body.\nDoctor [60%]: Are the bluish spots on the baby's skin raised or flat?\nPatient [60%]: The bluish spots on her skin are flat and they don't fade when you press on them.\nDoctor [65%]: Are the bluish spots on the baby's skin painful to the touch?\nPatient [65%]: No, the bluish spots don't seem to cause her any pain when touched.\nDoctor [70%]: Are the bluish spots on the baby's skin warm to the touch?\nPatient [70%]: No, the bluish spots are not warm to the touch.\nDoctor [75%]: Does the baby have any difficulty with vision or making eye contact?\nPatient [75%]: It's hard to say if she's having difficulty with vision since she's so young, but her eyes do look cloudy, which was noticed during her examination.\nDoctor [80%]: Does the baby have any trouble with feeding, such as difficulty latching or sucking? \nPatient [80%]: No, she hasn't had any trouble with feeding, latching, or sucking.\nDoctor [85%]: Does the baby have any history of excessive bleeding or bruising?\nPatient [85%]: No, she hasn't had any history of excessive bleeding or bruising.\nDoctor [90%]: REQUEST TEST: Echocardiogram.\nMeasurement [90%]: RESULTS: Patent ductus arteriosus\nDoctor [95%]: Does the baby have any trouble with breathing or seem to be working harder to breathe than usual?\nPatient [95%]: No, she hasn't shown any signs of trouble breathing or appearing to work harder to breathe than usual.\nDoctor [100%]: DIAGNOSIS READY: Blue Rubber Bleb Nevus Syndrome\n\nCorrect answer: Congenital Rubella Infection\nScene 7, The diagnosis was  INCORRECT 12\nDoctor [5%]: What symptoms are you experiencing related to the breast mass?\nPatient [5%]: I noticed a lump in my left breast about a month ago, and it's gotten noticeably bigger since then. There haven't been any changes to the skin or nipple, and it doesn't hurt at all.\nDoctor [10%]: Is there a history of breast cancer in your family?\nPatient [10%]: No, there's no history of breast cancer in my family that I'm aware of.\nDoctor [15%]: Is the lump in your breast hard or soft to the touch?\nPatient [15%]: It feels quite hard when I touch it.\nDoctor [20%]: Have you experienced any recent weight loss or fatigue?\nPatient [20%]: No, I haven't noticed any weight loss or felt more tired than usual.\nDoctor [25%]: Can you describe the size of the lump in your left breast?\nPatient [25%]: It started off quite small, but now it's about the size of a walnut.\nDoctor [30%]: Can you tell me if the lump in your left breast is fixed in place or does it move around when you touch it?\nPatient [30%]: It feels like it's fixed in place; it doesn't really move around when I touch it.\nDoctor [35%]: Does the lump in your left breast cause any changes in the shape of your breast?\nPatient [35%]: No, I haven't noticed any changes in the shape of my breast.\nDoctor [40%]: Does the lump in your left breast feel tender or painful when you touch it?\nPatient [40%]: No, the lump doesn't feel tender or painful at all when I touch it.\nDoctor [45%]: REQUEST TEST: Mammogram and Ultrasound of the left breast.\nMeasurement [45%]: RESULTS: Mammography findings indicate a smooth polylobulated mass in the left breast. Further details or ultrasound results are not provided in the available data.\nDoctor [50%]: Is there any discharge coming from your nipple on the affected breast?\nPatient [50%]: No, there's been no discharge from the nipple on the affected breast.\nDoctor [55%]: Does the lump in your left breast seem to be growing rapidly or has it been a gradual increase in size?\nPatient [55%]: It seems to be growing rapidly; I've definitely noticed a significant increase in size over the past four weeks.\nDoctor [60%]: Is there any redness or warmth over the lump in your left breast?\nPatient [60%]: No, there's no redness or warmth over the lump in my left breast.\nDoctor [65%]: Does the lump in your left breast feel hard or rubbery to the touch?\nPatient [65%]: It feels more hard than rubbery to the touch.\nDoctor [70%]: Is there any dimpling or puckering of the skin over the lump in your left breast?\nPatient [70%]: No, there's no dimpling or puckering of the skin over the lump in my left breast.\nDoctor [75%]: Does the lump in your left breast cause any itching or skin changes in the area?\nPatient [75%]: No, there hasn't been any itching or skin changes around the area of the lump.\nDoctor [80%]: Based on your symptoms, the physical examination, and the mammogram results showing a smooth polylobulated mass in your left breast, I am concerned about the possibility of breast cancer. I recommend a biopsy to confirm the diagnosis. Would you be comfortable proceeding with a biopsy to further investigate the mass in your left breast?\nPatient [80%]: Yes, I understand the concern and I'm willing to proceed with the biopsy to get a clear understanding of what we're dealing with.\nDoctor [85%]: Have you experienced any recent changes in your menstrual cycle or hormone therapy?\nPatient [85%]: No, I haven't experienced any recent changes in my menstrual cycle or been on any hormone therapy.\nDoctor [90%]: Have you noticed any enlarged lymph nodes in your armpit on the same side as the breast lump?\nPatient [90%]: No, I haven't noticed any enlarged lymph nodes in my armpit on the same side as the breast lump.\nDoctor [95%]: Based on your symptoms, physical examination, and mammogram results, along with the rapid growth of the lump in your left breast, I am concerned about the possibility of breast cancer. I recommend a biopsy to confirm the diagnosis. Would you be comfortable proceeding with a biopsy to further investigate the mass in your left breast?\nPatient [95%]: Yes, I understand the concern and I'm willing to proceed with the biopsy to get a clear understanding of what we're dealing with.\nDoctor [100%]: DIAGNOSIS READY: Suspicious for breast cancer. Further evaluation with a biopsy is recommended for definitive diagnosis and treatment planning.\n\nCorrect answer: Phyllodes tumor\nScene 8, The diagnosis was  INCORRECT 11\nDoctor [5%]: What symptoms are you experiencing?\nPatient [5%]: I've been feeling a lot of tenderness around my lower abdomen, and I've noticed I'm going to the bathroom to urinate more often than usual. Also, I've been running a bit of a fever lately.\nDoctor [10%]: What was the date of your last menstrual period?\nPatient [10%]: My last menstrual period was before I got pregnant, so it's been quite a while. I delivered my baby boy about three weeks ago.\nDoctor [15%]: Have you noticed any unusual vaginal discharge since giving birth?\nPatient [15%]: Yes, I have noticed some unusual discharge. It's been a bit heavier and has a different odor than what I was told to expect postpartum.\nDoctor [20%]: Have you experienced any pain or discomfort during urination?\nPatient [20%]: No, I haven't felt any pain or discomfort while urinating, just the increased frequency.\nDoctor [25%]: Do you have any history of recent surgeries or procedures related to your delivery?\nPatient [25%]: No, I didn't have any surgeries or procedures. My delivery was vaginal and, aside from it being prolonged, there were no complications that required surgical intervention.\nDoctor [30%]: Have you been experiencing any chills or night sweats recently?\nPatient [30%]: Yes, I've had some chills, especially at night. It's been making it hard to get comfortable enough to sleep well.\nDoctor [35%]: Do you have any history of chronic medical conditions such as diabetes or high blood pressure?\nPatient [35%]: No, I don't have any history of chronic conditions like diabetes or high blood pressure. My pregnancy was pretty straightforward until the delivery.\nDoctor [40%]: Have you noticed any changes in your appetite since giving birth?\nPatient [40%]: Actually, now that you mention it, my appetite hasn't been great. I thought it was just the stress and adjustment of caring for a newborn, but I've been eating much less than usual.\nDoctor [45%]: Have you been experiencing any pain or discomfort in your pelvic area since giving birth?\nPatient [45%]: Yes, I've been experiencing quite a bit of tenderness and discomfort in my pelvic area, especially when I move around or try to get up from sitting.\nDoctor [50%]: Is the tenderness in your pelvic area more on one side or is it spread out?\nPatient [50%]: The tenderness feels more spread out across my lower abdomen. It's not localized to one side.\nDoctor [55%]: Have you noticed any unusual vaginal bleeding since giving birth?\nPatient [55%]: Yes, I've noticed some bleeding, but I was told to expect some bleeding after giving birth. However, it seems to be a bit more than what my friends described as their experiences.\nDoctor [60%]: REQUEST TEST: Complete Blood Count (CBC)\nMeasurement [60%]: RESULTS: Pending\nDoctor [65%]: What is the color and consistency of the unusual vaginal discharge you mentioned?\nPatient [65%]: The discharge has been somewhat yellowish and thicker than I expected. It's definitely not the normal lochia I was told to look out for postpartum.\nDoctor [70%]: Is the discharge foul-smelling or have a bad odor?\nPatient [70%]: Yes, the discharge does have a foul smell to it, which has been concerning to me.\nDoctor [75%]: Is the foul-smelling discharge accompanied by any itching or burning sensation in the vaginal area?\nPatient [75%]: No, I haven't experienced any itching or burning sensation. It's just the smell and the unusual discharge that's been worrying me.\nDoctor [80%]: Based on your symptoms of postpartum fever, abdominal tenderness, foul-smelling yellowish discharge, and decreased appetite, along with the pending CBC results, I am concerned about a possible postpartum infection. Have you been feeling more fatigued than usual as well?\nPatient [80%]: Yes, I've been feeling extremely fatigued. I thought it was just from taking care of the baby and not getting enough sleep, but it's been hard to do even the simplest tasks.\nDoctor [85%]: Have you been experiencing any pain or discomfort during intercourse since giving birth?\nPatient [85%]: No, I haven't had intercourse since giving birth, so I can't say if there would be any pain or discomfort.\nDoctor [90%]: Based on your symptoms of postpartum fever, abdominal tenderness, foul-smelling yellowish discharge, decreased appetite, fatigue, and pending CBC results, I am concerned about a possible postpartum infection. Have you had any recent travel outside of the country?\nPatient [90%]: No, I haven't traveled outside of the country recently. I've mostly been at home since giving birth.\nDoctor [95%]: Have you had any recent dental work done or any issues with your teeth or gums since giving birth?\nPatient [95%]: No, I haven't had any dental work done or experienced any issues with my teeth or gums since giving birth.\nDoctor [100%]: DIAGNOSIS READY: Endometritis\n\nCorrect answer: Endometritis\nScene 9, The diagnosis was  CORRECT 20\nDoctor [5%]: What color is the blood in your stool?\nPatient [5%]: The blood is bright red.\nDoctor [10%]: Is the bleeding continuous or does it come and go?\nPatient [10%]: It seems to happen only with bowel movements.\nDoctor [15%]: Do you have any abdominal pain or discomfort associated with the rectal bleeding?\nPatient [15%]: No, I haven't experienced any abdominal pain or discomfort with it.\nDoctor [20%]: When did you first notice the rectal bleeding?\nPatient [20%]: I first noticed it about two weeks ago.\nDoctor [25%]: Is there any history of constipation or diarrhea?\nPatient [25%]: No, I haven't had any issues with constipation or diarrhea.\nDoctor [30%]: Is there any family history of colorectal cancer or inflammatory bowel disease?\nPatient [30%]: No, there's no family history of colorectal cancer or inflammatory bowel disease that I'm aware of.\nDoctor [35%]: Have you experienced any unintentional weight loss recently?\nPatient [35%]: No, I haven't noticed any unintentional weight loss.\nDoctor [40%]: Have you noticed any changes in your bowel habits recently?\nPatient [40%]: No, my bowel habits haven't changed recently. Everything has been pretty consistent aside from the bleeding.\nDoctor [45%]: Is the rectal mass painful or tender to touch?\nPatient [45%]: I haven't noticed any mass or experienced any tenderness or pain in that area.\nDoctor [50%]: Can you describe the size of the rectal mass you're feeling?\nPatient [50%]: I haven't felt any mass, so I can't describe its size.\nDoctor [55%]: REQUEST TEST: Digital Rectal Exam\nMeasurement [55%]: RESULTS: A palpable, non-tender, prolapsed mass that can be easily pushed back into the anal sphincter by the examiner's finger.\nDoctor [60%]: Is the mass you feel soft or firm to the touch?\nPatient [60%]: I didn't actually feel the mass myself, but when you examined it, it seemed like you were able to push it back in easily, so I would guess it's not very firm?\nDoctor [65%]: Does the rectal mass bleed when it is pushed back in?\nPatient [65%]: No, it doesn't bleed when it's pushed back in.\nDoctor [70%]: Does the rectal mass come out on its own or only during bowel movements?\nPatient [70%]: It seems to come out only during bowel movements.\nDoctor [75%]: Does the rectal mass cause any difficulty with passing stool?\nPatient [75%]: No, I haven't had any difficulty passing stool.\nDoctor [80%]: Does the rectal mass cause any itching or discomfort in the anal area?\nPatient [80%]: No, I haven't experienced any itching or discomfort in the anal area.\nDoctor [85%]: Does the rectal mass change in size or appearance over time?\nPatient [85%]: I haven't noticed any changes in its size or appearance since I first became aware of it.\nDoctor [90%]: Based on your symptoms and the results of the digital rectal exam, it seems like you may be dealing with a case of rectal prolapse. This occurs when the rectum protrudes through the anus. I will need to confirm this with further tests. REQUEST TEST: Colonoscopy.\nMeasurement [90%]: NORMAL READINGS\nDoctor [95%]: DIAGNOSIS READY: Rectal Prolapse\n\nCorrect answer: Hemorrhoids\nScene 10, The diagnosis was  INCORRECT 18\nDoctor [5%]: What is your age?\nPatient [5%]: I'm 7 years old.\nDoctor [10%]: Do you experience any other symptoms along with the episodes of unresponsiveness and facial grimacing?\nPatient [10%]: No, I don't think so. Just feeling really tired and confused after it happens.\nDoctor [15%]: Do you have any family history of seizures or epilepsy?\nPatient [15%]: Not that I know of. My parents haven't mentioned anything like that.\nDoctor [20%]: Have you ever had a head injury or concussion before?\nPatient [20%]: No, I've never hit my head really hard or anything. I've been pretty careful.\nDoctor [25%]: Have you had any recent illnesses or infections?\nPatient [25%]: No, I haven't been sick lately. No colds or anything.\nDoctor [30%]: Have you noticed any specific triggers for these episodes of unresponsiveness and facial grimacing?\nPatient [30%]: No, they just seem to happen out of nowhere. I do remember tasting something weird, like mud, right before they start though.\nDoctor [35%]: Have you had any recent exposure to toxins or chemicals that you're aware of?\nPatient [35%]: No, I haven't been around any chemicals or toxins. My parents keep all that stuff locked up and away from me and my brother.\nDoctor [40%]: Have you ever experienced any episodes like this before, or is this the first time?\nPatient [40%]: This is the first time anything like this has happened to me. I've never had episodes like these before.\nDoctor [45%]: Have you traveled anywhere recently, like to a different country or region?\nPatient [45%]: No, I haven't traveled anywhere recently. I've just been at home and school.\nDoctor [50%]: Have you had any recent changes in your sleep patterns or quality of sleep?\nPatient [50%]: No, my sleep has been the same. I go to bed at the same time every night and wake up for school in the morning.\nDoctor [55%]: Do you have any history of allergies to foods or medications?\nPatient [55%]: No, I don't have any allergies that we know of. My parents would have told me if I did.\nDoctor [60%]: Have you ever experienced any tingling sensations or numbness in your body during these episodes?\nPatient [60%]: No, I haven't felt any tingling or numbness. Just the weird taste and then I don't remember what happens during the episodes.\nDoctor [65%]: Have you ever had a fever during these episodes of unresponsiveness and facial grimacing?\nPatient [65%]: No, I haven't had a fever with them. I feel pretty normal temperature-wise.\nDoctor [70%]: Have you had any recent blood work done to check for any abnormalities? No, I haven't had any blood work done recently.\nPatient [70%]: Do you think I should get some blood work done, then? Is that going to help figure out what's happening with me?\nDoctor [75%]: REQUEST TEST: Blood work.\nMeasurement [75%]: RESULTS: Complete Blood Count: WBC: 6,200 /μL, Hemoglobin: 13.2 g/dL, Platelets: 274,000 /μL. Serum Electrolytes: Sodium: 140 mmol/L, Potassium: 4.2 mmol/L, Calcium: 9.4 mg/dL, Magnesium: 2.0 mg/dL.\nDoctor [80%]: Do you have any history of diabetes in your family?\nPatient [80%]: No, there's no history of diabetes in my family that I know of.\nDoctor [85%]: Have you experienced any changes in your vision or hearing during these episodes of unresponsiveness and facial grimacing?\nPatient [85%]: No, I haven't noticed any changes in my vision or hearing when those things happen. Everything just goes blank for a bit.\nDoctor [90%]: Do you have any history of migraines or severe headaches?\nPatient [90%]: No, I don't get headaches much, and I've never had a migraine before.\nDoctor [95%]: Have you ever experienced any episodes of muscle weakness or paralysis during these episodes of unresponsiveness and facial grimacing?\nPatient [95%]: No, I haven't felt any muscle weakness or like I couldn't move. I just can't respond or remember anything during those times.\nDoctor [100%]: DIAGNOSIS READY: Focal Seizures with Impaired Awareness\n\nCorrect answer: Complex partial seizure\nScene 11, The diagnosis was  CORRECT 25\nDoctor [5%]: Can you describe the pain in your right groin area?\nPatient [5%]: The pain in my right groin area is really severe. It feels sharp and it started right after the car accident. It gets worse when I try to move or walk.\nDoctor [10%]: What kind of movements make the pain in your right groin area worse?\nPatient [10%]: Any attempt to straighten my leg or change positions really intensifies the pain. Even just trying to stand up makes it much worse.\nDoctor [15%]: Have you noticed any swelling or bruising in your right groin area since the accident?\nPatient [15%]: Yes, there's been some swelling, and it looks a bit bruised as well. It's pretty tender to touch around that area.\nDoctor [20%]: Have you experienced any numbness or tingling in your right leg since the accident?\nPatient [20%]: No, I haven't experienced any numbness or tingling in my right leg. It's mainly just the pain and difficulty moving it.\nDoctor [25%]: Can you describe the exact position of your right leg that feels abnormal or difficult to move?\nPatient [25%]: My right leg is kind of stuck in a position where it's slightly bent at the knee, and it's turned inwards towards my left leg. It's also a bit shorter than my left leg now, which makes it really hard to move or adjust without causing a lot of pain.\nDoctor [30%]: Can you try to straighten your right leg for me?\nPatient [30%]: Trying to straighten my right leg is really painful, and I can barely move it at all. It feels like it's locked in this position.\nDoctor [35%]: Can you tell me if you have any difficulty bearing weight on your right leg?\nPatient [35%]: Yes, I can't put any weight on my right leg at all. Trying to stand on it is just too painful and feels impossible right now.\nDoctor [40%]: Have you had any previous injuries or surgeries on your right leg before this accident?\nPatient [40%]: No, I've never had any injuries or surgeries on my right leg before this accident. This is the first time I've had something like this happen.\nDoctor [45%]: Have you noticed any unusual sounds or sensations coming from your right groin area or leg since the accident?\nPatient [45%]: No, I haven't noticed any unusual sounds or sensations coming from my right groin area or leg since the accident, just the pain and difficulty moving.\nDoctor [50%]: REQUEST TEST: Pelvic X-Ray\nMeasurement [50%]: RESULTS: No fractures identified in the pelvic ring or femoral neck, but alignment suggests posterior dislocation of the right hip.\nDoctor [55%]: Can you tell me if you have any history of hip problems or dislocations before this accident?\nPatient [55%]: No, I've never had any hip problems or dislocations before this accident. This is completely new to me.\nDoctor [60%]: Can you recall any specific impact or force applied to your right hip during the car accident?\nPatient [60%]: Yes, during the accident, I remember feeling a strong jolt that pushed my right side against the car door. It happened so fast, but that's when the pain started.\nDoctor [65%]: Can you describe any sensations or feelings in your right hip since the accident?\nPatient [65%]: Since the accident, my right hip has felt incredibly unstable, almost like it's not in the right place. The pain is constant, and any movement just seems to make it feel worse.\nDoctor [70%]: Have you experienced any difficulty with range of motion in your right hip since the accident?\nPatient [70%]: Yes, I've had a lot of difficulty with the range of motion in my right hip since the accident. I can barely move it without causing severe pain, and it feels like it's stuck in one position.\nDoctor [75%]: Can you describe the quality of the pain in your right hip?\nPatient [75%]: The pain in my right hip is sharp and intense. It feels like it's deep inside my hip, not just on the surface. Any movement just seems to make it sharper.\nDoctor [80%]: Have you noticed any changes in the color or temperature of your right leg compared to your left leg since the accident?\nPatient [80%]: No, I haven't noticed any changes in the color or temperature of my right leg compared to my left leg since the accident. It's mainly just the pain and the difficulty moving that I've been dealing with.\nDoctor [85%]: Can you try to rotate your right hip inwards and outwards for me?\nPatient [85%]: Trying to rotate my right hip either inwards or outwards is extremely painful. I can barely move it at all without a sharp increase in pain.\nDoctor [90%]: Can you describe any sensations of instability or looseness in your right hip since the accident?\nPatient [90%]: Yes, there's definitely a sensation of instability in my right hip since the accident. It feels like it's not securely in place, almost as if it could move in ways it shouldn't. It's a very unsettling feeling, especially when I try to move.\nDoctor [95%]: Have you experienced any difficulty walking or bearing weight on your right leg since the accident?\nPatient [95%]: Yes, I've had a lot of difficulty walking or bearing any weight on my right leg since the accident. I can't stand on it at all without experiencing severe pain.\nDoctor [100%]: DIAGNOSIS READY: Posterior Hip Dislocation\n\nCorrect answer: Posterior hip dislocation\nScene 12, The diagnosis was  CORRECT 30\nDoctor [5%]: What color is the vomit?\nPatient [5%]: The vomit is greenish, doctor.\nDoctor [10%]: Is the baby able to feed normally?\nPatient [10%]: No, doctor, he seems to struggle with feeding and becomes fussy.\nDoctor [15%]: Does the baby have a fever?\nPatient [15%]: No, doctor, he doesn't have a fever.\nDoctor [20%]: Does the baby have any history of constipation or bowel obstruction in the family?\nPatient [20%]: No, doctor, there's no history of constipation or bowel obstruction in our family.\nDoctor [25%]: Does the baby have any abdominal pain or discomfort? No, doctor, he doesn't seem to be in pain or discomfort.\nPatient [25%]: But he does seem very uncomfortable and cries more when we try to lay him down, especially after feeding.\nDoctor [30%]: Does the baby have any difficulty breathing or any respiratory issues?\nPatient [30%]: No, doctor, he doesn't seem to have any difficulty breathing or respiratory issues.\nDoctor [35%]: Does the baby have any other symptoms such as diarrhea or blood in the stool?\nPatient [35%]: No, doctor, there hasn't been any diarrhea or blood in the stool, mainly because he hasn't passed any stool yet.\nDoctor [40%]: REQUEST TEST: Abdominal Ultrasound.\nMeasurement [40%]: RESULTS: NORMAL READINGS\nDoctor [45%]: Does the baby have any visible abdominal distension or bloating? Yes, doctor, his abdomen looks very bloated and distended. Is the baby passing gas normally? No, doctor, he hasn't passed any gas either. Is the baby urinating normally? Yes, doctor, he seems to be urinating normally. Is there any history of surgeries or birth complications with the baby? No, doctor, he was born full-term without any complications or surgeries.\nPatient [45%]: Yes, doctor, he was born at home and everything seemed fine then, but these symptoms started soon after birth.\nDoctor [50%]: Is there any history of feeding issues or difficulty latching during breastfeeding?\nPatient [50%]: No, doctor, there hasn't been any difficulty latching as such, but he becomes very fussy and seems uncomfortable during and after feeding.\nDoctor [55%]: Does the baby have any episodes of excessive crying or irritability? Yes, doctor, he does seem to cry a lot and is very irritable, especially after feeding. Does the baby have any visible swelling or bulging in the groin area? No, doctor, there doesn't seem to be any visible swelling or bulging in the groin area.\nPatient [55%]: Doctor, could these symptoms indicate something serious? He's only been with us for a couple of days, and it's worrying to see him like this.\nDoctor [60%]: Is the baby passing any stool at all, even if it's not meconium?\nPatient [60%]: No, doctor, he hasn't passed any stool at all since birth.\nDoctor [65%]: Does the baby have any episodes of vomiting after every feeding?\nPatient [65%]: Yes, doctor, it seems like he vomits after almost every feeding, and it's been very concerning.\nDoctor [70%]: REQUEST TEST: Barium Enema.\nMeasurement [70%]: RESULTS: NORMAL READINGS\nDoctor [75%]: DIAGNOSIS READY: Hirschsprung's disease\n\nCorrect answer: Hirschsprung’s disease\nScene 13, The diagnosis was  CORRECT 35\nDoctor [5%]: What is the intensity of the pain in your right ring finger on a scale of 1 to 10?\nPatient [5%]: I'd say it's about a 7 when I try to move it, but a constant 4 even when I'm not doing anything with it.\nDoctor [10%]: What activities make the pain worse in your right ring finger?\nPatient [10%]: Any attempt to flex it or when I accidentally bump it into something makes the pain shoot up significantly.\nDoctor [15%]: Have you noticed any redness or warmth in your right ring finger?\nPatient [15%]: Yes, there's definitely some redness around the joint, and it feels a bit warmer compared to my other fingers.\nDoctor [20%]: Is there any history of trauma or injury to your right ring finger that you can recall?\nPatient [20%]: Yes, actually, the pain started after my finger got caught in another player's jersey during a football game, and they pulled away forcefully. That's when I first noticed the swelling and pain.\nDoctor [25%]: Have you experienced any fever or chills recently?\nPatient [25%]: No, I haven't had any fever or chills.\nDoctor [30%]: Does the pain in your right ring finger radiate to any other part of your hand or arm?\nPatient [30%]: No, the pain is localized just to my right ring finger; it hasn't spread to any other part of my hand or arm.\nDoctor [35%]: Does the pain in your right ring finger feel worse in the morning or at night?\nPatient [35%]: The pain seems pretty consistent throughout the day, but I guess it feels a bit more stiff and painful in the morning when I first wake up.\nDoctor [40%]: Does the pain in your right ring finger improve with rest or elevation?\nPatient [40%]: Yes, the pain does seem to ease a bit when I rest it or keep it elevated, but it's still pretty uncomfortable even then.\nDoctor [45%]: Does the swelling in your right ring finger seem to be getting worse over time?\nPatient [45%]: Yes, the swelling seems to have increased a bit since it first started. It's definitely more swollen now than it was two days ago.\nDoctor [50%]: Is there any discharge or fluid coming out from the swollen area in your right ring finger?\nPatient [50%]: No, there hasn't been any discharge or fluid coming out from the swollen area.\nDoctor [55%]: Does the skin over the swollen area in your right ring finger appear shiny or stretched?\nPatient [55%]: Yes, the skin does look a bit shiny and feels tight, like it's being stretched over the swelling.\nDoctor [60%]: Does the skin over the swollen area in your right ring finger feel warm to the touch?\nPatient [60%]: Yes, the skin over the swollen area does feel warm to the touch compared to the rest of my hand.\nDoctor [65%]: Does the warm skin over the swollen area in your right ring finger feel tender to the touch?\nPatient [65%]: Yes, it's quite tender to the touch. Even light pressure makes it feel more painful.\nDoctor [70%]: Is there any history of diabetes or other chronic medical conditions in your medical history?\nPatient [70%]: No, I don't have diabetes or any other chronic medical conditions. My medical history is pretty unremarkable.\nDoctor [75%]: REQUEST TEST: Blood tests for inflammatory markers.\nMeasurement [75%]: NORMAL READINGS\nDoctor [80%]: What is the range of motion like in your right ring finger?\nPatient [80%]: I can barely move it at the distal interphalangeal joint. It's pretty much stuck in an extended position and trying to flex it is really painful.\nDoctor [85%]: Can you describe any changes in the color of your right ring finger's skin?\nPatient [85%]: Yes, the skin around the swollen area has turned a bit redder than the rest of my finger. It's more noticeable around the joint.\nDoctor [90%]: Is there any history of gout in your family?\nPatient [90%]: No, there's no history of gout in my family that I'm aware of.\nDoctor [95%]: Is there any history of psoriasis in your family?\nPatient [95%]: No, there's no history of psoriasis in my family either.\nDoctor [100%]: Do you have any history of joint pain or arthritis in any other parts of your body?\nPatient [100%]: No, I've never had any issues with joint pain or arthritis anywhere else in my body before this.\n","output_type":"stream"}]},{"cell_type":"markdown","source":"The above costs 2.09","metadata":{}},{"cell_type":"markdown","source":"# My Modification - Add one adaptation for one fail case for GPT-3.5","metadata":{}},{"cell_type":"code","source":"Exemplar_1 = \"\\n\\nIf the patient has symptoms such as double vision, difficulty climbing stairs, and upper limb weakness, perform an Acetylcholine Receptor Antibody Test instead of an MRI of the brain and spine.\"","metadata":{"execution":{"iopub.status.busy":"2024-09-25T22:11:57.917343Z","iopub.execute_input":"2024-09-25T22:11:57.920181Z","iopub.status.idle":"2024-09-25T22:11:57.928817Z","shell.execute_reply.started":"2024-09-25T22:11:57.920089Z","shell.execute_reply":"2024-09-25T22:11:57.927429Z"},"trusted":true},"execution_count":35,"outputs":[]},{"cell_type":"code","source":"import argparse\nimport anthropic\nfrom transformers import pipeline\nimport openai, re, random, time, json, replicate, os\n\nllama2_url = \"meta/llama-2-70b-chat\"\nllama3_url = \"meta/meta-llama-3-70b-instruct\"\nmixtral_url = \"mistralai/mixtral-8x7b-instruct-v0.1\"\n\ndef load_huggingface_model(model_name):\n    pipe = pipeline(\"text-generation\", model=model_name, device_map=\"auto\")\n    return pipe\n\ndef inference_huggingface(prompt, pipe):\n    response = pipe(prompt, max_new_tokens=100)[0][\"generated_text\"]\n    response = response.replace(prompt, \"\")\n    return response\n\n\ndef query_model(model_str, prompt, system_prompt, tries=30, timeout=20.0, image_requested=False, scene=None, max_prompt_len=2**14, clip_prompt=False):\n    if model_str not in [\"gpt4\", \"gpt3.5\", \"gpt4o\", 'llama-2-70b-chat', \"mixtral-8x7b\", \"gpt-4o-mini\", \"llama-3-70b-instruct\", \"gpt4v\", \"claude3.5sonnet\", \"o1-preview\"] and \"_HF\" not in model_str:\n        raise Exception(\"No model by the name {}\".format(model_str))\n    for _ in range(tries):\n        if clip_prompt: prompt = prompt[:max_prompt_len]\n        try:\n            if image_requested:\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \n                    \"content\": [\n                        {\"type\": \"text\", \"text\": prompt},\n                        {\"type\": \"image_url\",\n                            \"image_url\": {\n                                \"url\": \"{}\".format(scene.image_url),\n                            },\n                        },\n                    ]},]\n                if model_str == \"gpt4v\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4-vision-preview\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt-4o-mini\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4o-mini\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt4\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4-turbo\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                elif model_str == \"gpt4o\":\n                    response = openai.ChatCompletion.create(\n                            model=\"gpt-4o\",\n                            messages=messages,\n                            temperature=0.05,\n                            max_tokens=200,\n                        )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n            if model_str == \"gpt4\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4-turbo-preview\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt4v\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4-vision-preview\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt-4o-mini\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4o-mini\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"o1-preview\":\n                messages = [\n                    {\"role\": \"user\", \"content\": system_prompt + prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"o1-preview-2024-09-12\",\n                        messages=messages,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"gpt3.5\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-3.5-turbo\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == \"claude3.5sonnet\":\n                client = anthropic.Anthropic(api_key=os.environ[\"ANTHROPIC_API_KEY\"])\n                message = client.messages.create(\n                    model=\"claude-3-5-sonnet-20240620\",\n                    system=system_prompt,\n                    max_tokens=256,\n                    messages=[{\"role\": \"user\", \"content\": prompt}])\n                answer = json.loads(message.to_json())[\"content\"][0][\"text\"]\n            elif model_str == \"gpt4o\":\n                messages = [\n                    {\"role\": \"system\", \"content\": system_prompt},\n                    {\"role\": \"user\", \"content\": prompt}]\n                response = openai.ChatCompletion.create(\n                        model=\"gpt-4o\",\n                        messages=messages,\n                        temperature=0.05,\n                        max_tokens=200,\n                    )\n                answer = response[\"choices\"][0][\"message\"][\"content\"]\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'llama-2-70b-chat':\n                output = replicate.run(\n                    llama2_url, input={\n                        \"prompt\":  prompt, \n                        \"system_prompt\": system_prompt,\n                        \"max_new_tokens\": 200})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'mixtral-8x7b':\n                output = replicate.run(\n                    mixtral_url, \n                    input={\"prompt\": prompt, \n                            \"system_prompt\": system_prompt,\n                            \"max_new_tokens\": 75})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif model_str == 'llama-3-70b-instruct':\n                output = replicate.run(\n                    llama3_url, input={\n                        \"prompt\":  prompt, \n                        \"system_prompt\": system_prompt,\n                        \"max_new_tokens\": 200})\n                answer = ''.join(output)\n                answer = re.sub(\"\\s+\", \" \", answer)\n            elif \"HF_\" in model_str:\n                input_text = system_prompt + prompt \n                #if self.pipe is None:\n                #    self.pipe = load_huggingface_model(self.backend.replace(\"HF_\", \"\"))\n                raise Exception(\"Sorry, fixing TODO :3\") #inference_huggingface(input_text, self.pipe)\n            return answer\n        \n        except Exception as e:\n            time.sleep(timeout)\n            continue\n    raise Exception(\"Max retries: timeout\")\n\n\n\nclass ScenarioMedQA:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMedQA:\n    def __init__(self) -> None:\n        with open(\"agentclinic_medqa.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMedQA(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n        self.scenario_count = 0 # Add\n    \n    def sample_scenario(self):\n        # return self.scenarios[random.randint(0, len(self.scenarios)-1)] # Remove\n        self.scenario_count += 1 # Add\n        return self.scenarios[self.scenario_count] # Add\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n        \n\n\nclass ScenarioMedQAExtended:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMedQAExtended:\n    def __init__(self) -> None:\n        with open(\"agentclinic_medqa_extended.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMedQAExtended(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n        \n\n\nclass ScenarioMIMICIVQA:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict\n        self.tests = scenario_dict[\"OSCE_Examination\"][\"Test_Results\"]\n        self.diagnosis = scenario_dict[\"OSCE_Examination\"][\"Correct_Diagnosis\"]\n        self.patient_info  = scenario_dict[\"OSCE_Examination\"][\"Patient_Actor\"]\n        self.examiner_info  = scenario_dict[\"OSCE_Examination\"][\"Objective_for_Doctor\"]\n        self.physical_exams = scenario_dict[\"OSCE_Examination\"][\"Physical_Examination_Findings\"]\n    \n    def patient_information(self) -> dict:\n        return self.patient_info\n\n    def examiner_information(self) -> dict:\n        return self.examiner_info\n    \n    def exam_information(self) -> dict:\n        exams = self.physical_exams\n        exams[\"tests\"] = self.tests\n        return exams\n    \n    def diagnosis_information(self) -> dict:\n        return self.diagnosis\n\n\nclass ScenarioLoaderMIMICIV:\n    def __init__(self) -> None:\n        with open(\"agentclinic_mimiciv.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioMIMICIVQA(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass ScenarioNEJMExtended:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict \n        self.question = scenario_dict[\"question\"] \n        self.image_url = scenario_dict[\"image_url\"] \n        self.diagnosis = [_sd[\"text\"] \n            for _sd in scenario_dict[\"answers\"] if _sd[\"correct\"]][0]\n        self.patient_info = scenario_dict[\"patient_info\"]\n        self.physical_exams = scenario_dict[\"physical_exams\"]\n\n    def patient_information(self) -> str:\n        patient_info = self.patient_info\n        return patient_info\n\n    def examiner_information(self) -> str:\n        return \"What is the most likely diagnosis?\"\n    \n    def exam_information(self) -> str:\n        exams = self.physical_exams\n        return exams\n    \n    def diagnosis_information(self) -> str:\n        return self.diagnosis\n\n\nclass ScenarioLoaderNEJMExtended:\n    def __init__(self) -> None:\n        with open(\"agentclinic_nejm_extended.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioNEJMExtended(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass ScenarioNEJM:\n    def __init__(self, scenario_dict) -> None:\n        self.scenario_dict = scenario_dict \n        self.question = scenario_dict[\"question\"] \n        self.image_url = scenario_dict[\"image_url\"] \n        self.diagnosis = [_sd[\"text\"] \n            for _sd in scenario_dict[\"answers\"] if _sd[\"correct\"]][0]\n        self.patient_info = scenario_dict[\"patient_info\"]\n        self.physical_exams = scenario_dict[\"physical_exams\"]\n\n    def patient_information(self) -> str:\n        patient_info = self.patient_info\n        return patient_info\n\n    def examiner_information(self) -> str:\n        return \"What is the most likely diagnosis?\"\n    \n    def exam_information(self) -> str:\n        exams = self.physical_exams\n        return exams\n    \n    def diagnosis_information(self) -> str:\n        return self.diagnosis\n\n\nclass ScenarioLoaderNEJM:\n    def __init__(self) -> None:\n        with open(\"agentclinic_nejm.jsonl\", \"r\") as f:\n            self.scenario_strs = [json.loads(line) for line in f]\n        self.scenarios = [ScenarioNEJM(_str) for _str in self.scenario_strs]\n        self.num_scenarios = len(self.scenarios)\n    \n    def sample_scenario(self):\n        return self.scenarios[random.randint(0, len(self.scenarios)-1)]\n    \n    def get_scenario(self, id):\n        if id is None: return self.sample_scenario()\n        return self.scenarios[id]\n\n\nclass PatientAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\", bias_present=None) -> None:\n        # disease of patient, or \"correct answer\"\n        self.disease = \"\"\n        # symptoms that patient presents\n        self.symptoms = \"\"\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # language model backend for patient agent\n        self.backend = backend_str\n        # presentation of any form of bias\n        self.bias_present = (None if bias_present == \"None\" else bias_present)\n        # sample initial question from dataset\n        self.scenario = scenario\n        self.reset()\n        self.pipe = None\n\n        self.biases = [\"recency\", \"frequency\", \"false_consensus\", \"self_diagnosis\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"]\n\n    def generate_bias(self) -> str:\n        \"\"\" \n        ================\n        Cognitive biases \n        ================\n        \"\"\"\n        if self.bias_present == \"recency\":\n            return \"\\nRecently, you had a friend with similar symptoms to yours that was diagnosed with cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"frequency\":\n            return \"\\nYou recently learned that most frequently, doctors diagnose this as cancer based on past cases. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"false_consensus\":\n            return \"\\nMost of your friends who heard about your symptoms believe that you have cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"self_diagnosis\":\n            return \"\\nYou recently performed a thorough investigation of your symptoms online and have come to the conclusion that you should be diagnosed with cancer. While the doctor may believe otherwise you remain convinced you have cancer. This affects how you interact with the doctor.\\n\"\n        elif self.bias_present == \"gender\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular gender and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"race\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular race and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"sexual_orientation\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are a particular sexual orientation and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"cultural\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are from a particular culture and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"education\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they went to a low ranked medical school and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"religion\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they believe in a particular religion and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"socioeconomic\":\n            return \"\\nYou are uncomfortable with your doctor because you find out that they are from a particular socioeconomic background and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present is None:\n            pass\n        else:\n            print(\"BIAS TYPE {} NOT SUPPORTED, ignoring bias...\".format(self.bias_present))\n        return \"\"\n\n    def inference_patient(self, question) -> str:\n        answer = query_model(self.backend, \"\\nHere is a history of your dialogue: \" + self.agent_hist + \"\\n Here was the doctor response: \" + question + \"Now please continue your dialogue\\nPatient: \", self.system_prompt())\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        return answer\n\n    def system_prompt(self) -> str:\n        bias_prompt = \"\"\n        if self.bias_present is not None:\n            bias_prompt = self.generate_bias()\n        base = \"\"\"You are a patient in a clinic who only responds in the form of dialogue. You are being inspected by a doctor who will ask you questions and will perform exams on you in order to understand your disease. Your answer will only be 1-3 sentences in length.\"\"\"\n        symptoms = \"\\n\\nBelow is all of your information. {}. \\n\\n Remember, you must not reveal your disease explicitly but may only convey the symptoms you have in the form of dialogue if you are asked.\".format(self.symptoms)\n        return base + bias_prompt + symptoms\n    \n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.symptoms = self.scenario.patient_information()\n\n    def add_hist(self, hist_str) -> None:\n        self.agent_hist += hist_str + \"\\n\\n\"\n\n\nclass DoctorAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\", max_infs=20, bias_present=None, img_request=False) -> None:\n        # number of inference calls to the doctor\n        self.infs = 0\n        # maximum number of inference calls to the doctor\n        self.MAX_INFS = max_infs\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # presentation information for doctor\n        self.presentation = \"\"\n        # language model backend for doctor agent\n        self.backend = backend_str\n        # presentation of any form of bias\n        self.bias_present = (None if bias_present == \"None\" else bias_present)\n        # prepare initial conditions for LLM\n        self.scenario = scenario\n        self.reset()\n        self.pipe = None\n        self.img_request = img_request\n        self.biases = [\"recency\", \"frequency\", \"false_consensus\", \"confirmation\", \"status_quo\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"]\n\n    def generate_bias(self) -> str:\n        \"\"\" \n        ================\n        Cognitive biases \n        ================\n        \"\"\"\n        if self.bias_present == \"recency\":\n            return \"\\nRecently, you learned that a doctor with similar symptoms to the patient that diagnosed their patient with cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"frequency\":\n            return \"\\nYou recently learned that most frequently, doctors diagnose patients with similar symptoms with cancer based on past cases. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"false_consensus\":\n            return \"\\nMost of your colleagues who heard about the patient's symptoms believe that they have cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"status_quo\":\n            return \"\\nYour hosptial has been diagnosing these patient's symptoms with cancer for the past 10 years. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"confirmation\":\n            return \"\\nYou are initially confident that the patient has cancer. This affects how you interact with the patient.\\n\"\n        elif self.bias_present == \"gender\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular gender and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"race\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular race and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"sexual_orientation\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are a particular sexual orientation and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"cultural\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are from a particular culture and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"education\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they went to a low ranked medical school and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"religion\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they believe in a particular religion and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present == \"socioeconomic\":\n            return \"\\nYou are uncomfortable with your patient because you find out that they are from a particular socioeconomic background and you do not trust their judgement. This affects how you interact with them.\\n\"\n        elif self.bias_present is None:\n            pass\n        else:\n            print(\"BIAS TYPE {} NOT SUPPORTED, ignoring bias...\".format(self.bias_present))\n        return \"\"\n\n    def inference_doctor(self, question, image_requested=False) -> str:\n        answer = str()\n        if self.infs >= self.MAX_INFS: return \"Maximum inferences reached\"\n        answer = query_model(self.backend, \"\\nHere is a history of your dialogue: \" + self.agent_hist + \"\\n Here was the patient response: \" + question + \"Now please continue your dialogue\\nDoctor: \", self.system_prompt(), image_requested=image_requested, scene=self.scenario)\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        self.infs += 1\n        return answer\n\n    def system_prompt(self) -> str:\n        bias_prompt = \"\"\n        if self.bias_present is not None:\n            bias_prompt = self.generate_bias()\n        base = \"You are a doctor named Dr. Agent who only responds in the form of dialogue. You are inspecting a patient who you will ask questions in order to understand their disease. You are only allowed to ask {} questions total before you must make a decision. You have asked {} questions so far. You can request test results using the format \\\"REQUEST TEST: [test]\\\". For example, \\\"REQUEST TEST: Chest_X-Ray\\\". Your dialogue will only be 1-3 sentences in length. Once you have decided to make a diagnosis please type \\\"DIAGNOSIS READY: [diagnosis here]\\\"\".format(self.MAX_INFS, self.infs) + (\"You may also request medical images related to the disease to be returned with \\\"REQUEST IMAGES\\\".\" if self.img_request else \"\")\n        presentation = \"\\n\\nBelow is all of the information you have. {}. \\n\\n Remember, you must discover their disease by asking them questions. You are also able to provide exams.\".format(self.presentation)\n        return base + bias_prompt + Exemplar_1 + presentation # change here\n\n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.presentation = self.scenario.examiner_information()\n\n\nclass MeasurementAgent:\n    def __init__(self, scenario, backend_str=\"gpt4\") -> None:\n        # conversation history between doctor and patient\n        self.agent_hist = \"\"\n        # presentation information for measurement \n        self.presentation = \"\"\n        # language model backend for measurement agent\n        self.backend = backend_str\n        # prepare initial conditions for LLM\n        self.scenario = scenario\n        self.pipe = None\n        self.reset()\n\n    def inference_measurement(self, question) -> str:\n        answer = str()\n        answer = query_model(self.backend, \"\\nHere is a history of the dialogue: \" + self.agent_hist + \"\\n Here was the doctor measurement request: \" + question, self.system_prompt())\n        self.agent_hist += question + \"\\n\\n\" + answer + \"\\n\\n\"\n        return answer\n\n    def system_prompt(self) -> str:\n        base = \"You are an measurement reader who responds with medical test results. Please respond in the format \\\"RESULTS: [results here]\\\"\"\n        presentation = \"\\n\\nBelow is all of the information you have. {}. \\n\\n If the requested results are not in your data then you can respond with NORMAL READINGS.\".format(self.information)\n        return base + presentation\n    \n    def add_hist(self, hist_str) -> None:\n        self.agent_hist += hist_str + \"\\n\\n\"\n\n    def reset(self) -> None:\n        self.agent_hist = \"\"\n        self.information = self.scenario.exam_information()\n\n\ndef compare_results(diagnosis, correct_diagnosis, moderator_llm, mod_pipe):\n    answer = query_model(moderator_llm, \"\\nHere is the correct diagnosis: \" + correct_diagnosis + \"\\n Here was the doctor dialogue: \" + diagnosis + \"\\nAre these the same?\", \"You are responsible for determining if the corrent diagnosis and the doctor diagnosis are the same disease. Please respond only with Yes or No. Nothing else.\")\n    return answer.lower()\n\n\ndef main(api_key, replicate_api_key, inf_type, doctor_bias, patient_bias, doctor_llm, patient_llm, measurement_llm, moderator_llm, num_scenarios, dataset, img_request, total_inferences, anthropic_api_key=None):\n    openai.api_key = api_key\n    anthropic_llms = [\"claude3.5sonnet\"]\n    replicate_llms = [\"llama-3-70b-instruct\", \"llama-2-70b-chat\", \"mixtral-8x7b\"]\n    if patient_llm in replicate_llms or doctor_llm in replicate_llms:\n        os.environ[\"REPLICATE_API_TOKEN\"] = replicate_api_key\n    if doctor_llm in anthropic_llms:\n        os.environ[\"ANTHROPIC_API_KEY\"] = anthropic_api_key\n\n    # Load MedQA, MIMICIV or NEJM agent case scenarios\n    if dataset == \"MedQA\":\n        scenario_loader = ScenarioLoaderMedQA()\n    elif dataset == \"MedQA_Ext\":\n        scenario_loader = ScenarioLoaderMedQAExtended()\n    elif dataset == \"NEJM\":\n        scenario_loader = ScenarioLoaderNEJM()\n    elif dataset == \"NEJM_Ext\":\n        scenario_loader = ScenarioLoaderNEJMExtended()\n    elif dataset == \"MIMICIV\":\n        scenario_loader = ScenarioLoaderMIMICIV()\n    else:\n        raise Exception(\"Dataset {} does not exist\".format(str(dataset)))\n    total_correct = 0\n    total_presents = 0\n\n    # Pipeline for huggingface models\n    if \"HF_\" in moderator_llm:\n        pipe = load_huggingface_model(moderator_llm.replace(\"HF_\", \"\"))\n    else:\n        pipe = None\n\n    for _scenario_id in range(0, min(num_scenarios, scenario_loader.num_scenarios)):\n        total_presents += 1\n        pi_dialogue = str()\n        # Initialize scenarios (MedQA/NEJM)\n        scenario =  scenario_loader.get_scenario(id=_scenario_id)\n        # Initialize agents\n        meas_agent = MeasurementAgent(\n            scenario=scenario,\n            backend_str=measurement_llm)\n        patient_agent = PatientAgent(\n            scenario=scenario, \n            bias_present=patient_bias,\n            backend_str=patient_llm)\n        doctor_agent = DoctorAgent(\n            scenario=scenario, \n            bias_present=doctor_bias,\n            backend_str=doctor_llm,\n            max_infs=total_inferences, \n            img_request=img_request)\n\n        doctor_dialogue = \"\"\n        for _inf_id in range(total_inferences):\n            # Check for medical image request\n            if dataset == \"NEJM\":\n                if img_request:\n                    imgs = \"REQUEST IMAGES\" in doctor_dialogue\n                else: imgs = True\n            else: imgs = False\n            # Check if final inference\n            if _inf_id == total_inferences - 1:\n                pi_dialogue += \"This is the final question. Please provide a diagnosis.\\n\"\n            # Obtain doctor dialogue (human or llm agent)\n            if inf_type == \"human_doctor\":\n                doctor_dialogue = input(\"\\nQuestion for patient: \")\n            else: \n                doctor_dialogue = doctor_agent.inference_doctor(pi_dialogue, image_requested=imgs)\n            print(\"Doctor [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), doctor_dialogue)\n            # Doctor has arrived at a diagnosis, check correctness\n            if \"DIAGNOSIS READY\" in doctor_dialogue:\n                correctness = compare_results(doctor_dialogue, scenario.diagnosis_information(), moderator_llm, pipe) == \"yes\"\n                if correctness: total_correct += 1\n                print(\"\\nCorrect answer:\", scenario.diagnosis_information())\n                print(\"Scene {}, The diagnosis was \".format(_scenario_id), \"CORRECT\" if correctness else \"INCORRECT\", int((total_correct/total_presents)*100))\n                break\n            # Obtain medical exam from measurement reader\n            if \"REQUEST TEST\" in doctor_dialogue:\n                pi_dialogue = meas_agent.inference_measurement(doctor_dialogue,)\n                print(\"Measurement [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), pi_dialogue)\n                patient_agent.add_hist(pi_dialogue)\n            # Obtain response from patient\n            else:\n                if inf_type == \"human_patient\":\n                    pi_dialogue = input(\"\\nResponse to doctor: \")\n                else:\n                    pi_dialogue = patient_agent.inference_patient(doctor_dialogue)\n                print(\"Patient [{}%]:\".format(int(((_inf_id+1)/total_inferences)*100)), pi_dialogue)\n                meas_agent.add_hist(pi_dialogue)\n            # Prevent API timeouts\n            time.sleep(1.0)","metadata":{"execution":{"iopub.status.busy":"2024-09-25T22:12:19.770569Z","iopub.execute_input":"2024-09-25T22:12:19.771048Z","iopub.status.idle":"2024-09-25T22:12:19.893821Z","shell.execute_reply.started":"2024-09-25T22:12:19.771007Z","shell.execute_reply":"2024-09-25T22:12:19.892133Z"},"jupyter":{"source_hidden":true},"trusted":true},"execution_count":36,"outputs":[]},{"cell_type":"code","source":"# if __name__ == \"__main__\":\n#     parser = argparse.ArgumentParser(description='Medical Diagnosis Simulation CLI')\n#     parser.add_argument('--openai_api_key', type=str, required=False, help='OpenAI API Key')\n#     parser.add_argument('--replicate_api_key', type=str, required=False, help='Replicate API Key')\n#     parser.add_argument('--inf_type', type=str, choices=['llm', 'human_doctor', 'human_patient'], default='llm')\n#     parser.add_argument('--doctor_bias', type=str, help='Doctor bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"confirmation\", \"status_quo\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--patient_bias', type=str, help='Patient bias type', default='None', choices=[\"recency\", \"frequency\", \"false_consensus\", \"self_diagnosis\", \"gender\", \"race\", \"sexual_orientation\", \"cultural\", \"education\", \"religion\", \"socioeconomic\"])\n#     parser.add_argument('--doctor_llm', type=str, default='gpt4')\n#     parser.add_argument('--patient_llm', type=str, default='gpt4')\n#     parser.add_argument('--measurement_llm', type=str, default='gpt4')\n#     parser.add_argument('--moderator_llm', type=str, default='gpt4')\n#     parser.add_argument('--agent_dataset', type=str, default='MedQA') # MedQA, MIMICIV or NEJM\n#     parser.add_argument('--doctor_image_request', type=bool, default=False) # whether images must be requested or are provided\n#     parser.add_argument('--num_scenarios', type=int, default=15, required=False, help='Number of scenarios to simulate')\n#     parser.add_argument('--total_inferences', type=int, default=20, required=False, help='Number of inferences between patient and doctor')\n#     parser.add_argument('--anthropic_api_key', type=str, default=None, required=False, help='Anthropic API key for Claude 3.5 Sonnet')\n    \n#     args = parser.parse_args()\n    \n    # python3 agentclinic.py --openai_api_key \"YOUR_OPENAIAPI_KEY\" --inf_type \"llm\"\n\n    # main(args.openai_api_key, args.replicate_api_key, args.inf_type, args.doctor_bias, args.patient_bias, args.doctor_llm, args.patient_llm, args.measurement_llm, args.moderator_llm, args.num_scenarios, args.agent_dataset, args.doctor_image_request, args.total_inferences, args.anthropic_api_key)\nmy_openai_api_key = \"YOUR_OPENAIAPI_KEY\"\nmy_replicate_api_key = \"\"\nmy_inf_type = \"llm\"\nmy_doctor_bias = 'None'\nmy_patient_bias = 'None'\nmy_doctor_llm = 'gpt3.5'\nmy_patient_llm = 'gpt4'\nmy_measurement_llm = 'gpt4'\nmy_moderator_llm = 'gpt4'\nmy_agent_dataset = 'MedQA'\nmy_doctor_image_request = False\nmy_num_scenarios = 1 # change from 15 to 1\nmy_total_inferences = 20\nmy_anthropic_api_key = None\n\nmain(my_openai_api_key, my_replicate_api_key, my_inf_type, my_doctor_bias, my_patient_bias, my_doctor_llm, my_patient_llm, my_measurement_llm, my_moderator_llm, my_num_scenarios, my_agent_dataset, my_doctor_image_request, my_total_inferences, my_anthropic_api_key)","metadata":{"execution":{"iopub.status.busy":"2024-09-25T22:12:41.923631Z","iopub.execute_input":"2024-09-25T22:12:41.924119Z","iopub.status.idle":"2024-09-25T22:13:24.735670Z","shell.execute_reply.started":"2024-09-25T22:12:41.924078Z","shell.execute_reply":"2024-09-25T22:13:24.734180Z"},"trusted":true},"execution_count":37,"outputs":[{"name":"stdout","text":"Doctor [5%]: What symptoms are you experiencing?\nPatient [5%]: I've been having trouble with double vision, especially after I've been working for a while. I also find it hard to climb stairs and even brushing my hair feels like a task because my arms just feel so weak. These issues seem to get a bit better if I rest for a few hours.\nDoctor [10%]: What other symptoms have you noticed besides the double vision, difficulty climbing stairs, and upper limb weakness?\nPatient [10%]: Well, those are the main issues, really. I haven't noticed anything like chest pain or trouble breathing. No recent colds or infections either.\nDoctor [15%]: Have you experienced any tingling or numbness in your limbs?\nPatient [15%]: No, I haven't felt any tingling or numbness. It's mostly just the weakness and the double vision that's been bothering me.\nDoctor [20%]: Have you had any recent vaccinations or exposure to insecticides or certain medications?\nPatient [20%]: No, I haven't had any recent vaccinations, and I'm pretty sure I haven't been exposed to insecticides or any unusual medications either.\nDoctor [25%]: Have you had any recent muscle cramps or difficulty swallowing?\nPatient [25%]: No, I haven't had muscle cramps or any difficulty swallowing. Everything seems normal with eating and drinking.\nDoctor [30%]: Have you noticed any changes in your speech or voice?\nPatient [30%]: No, my speech and voice have been normal. I haven't noticed any changes or difficulties there.\nDoctor [35%]: Have you experienced any drooping of your eyelids or difficulty keeping them open?\nPatient [35%]: Yes, actually, I have noticed that my eyelids seem heavier than usual, especially towards the end of the day. It's been a bit of a struggle to keep them open, especially when I'm tired.\nDoctor [40%]: Do you have any family history of autoimmune diseases or neurological conditions?\nPatient [40%]: No, there's no family history of autoimmune diseases or neurological conditions that I'm aware of.\nDoctor [45%]: Have you had any recent infections or illnesses that you can recall?\nPatient [45%]: No, I haven't had any recent infections or illnesses. It's been pretty much just these symptoms I mentioned without any signs of a cold or flu.\nDoctor [50%]: REQUEST TEST: Acetylcholine Receptor Antibody Test.\nMeasurement [50%]: RESULTS: Acetylcholine Receptor Antibodies: Present (elevated)\nDoctor [55%]: Do you have any history of smoking or exposure to secondhand smoke?\nPatient [55%]: No, I don't smoke, and I'm not around secondhand smoke either. I try to stay in pretty smoke-free environments.\nDoctor [60%]: Based on your symptoms and the elevated Acetylcholine Receptor Antibodies, it seems like you may have Myasthenia Gravis. Have you noticed any improvement in your symptoms with rest or after taking any medications?\nPatient [60%]: Yes, I've definitely noticed that my symptoms improve quite a bit after I rest for a few hours. I haven't taken any specific medications for this, but rest seems to make a significant difference.\nDoctor [65%]: DIAGNOSIS READY: Myasthenia Gravis\n\nCorrect answer: Myasthenia gravis\nScene 0, The diagnosis was  CORRECT 100\n","output_type":"stream"}]}]}