Foundation models are becoming invaluable tools in medicine. Despite their promise, the strategic deployment of Large Language Models (LLMs) for effective utility in complex medical tasks remains an open question. We introduce a novel framework, Medical Decision-making Agents (MDAgents) which aims to address this gap by automatically assigning a collaboration structure for a team of LLMs. The assigned solo or group collaboration structure is tailored to the medical task at hand, a simple emulation of how real-world medical decision-making processes adapt to tasks of different complexities. We evaluate our framework and baseline methods with state-of-the-art LLMs across a suite of medical benchmarks containing real-world medical knowledge and challenging clinical diagnosis. MDAgents achieved the best performance in seven out of ten benchmarks on the tasks that require an understanding of medical knowledge and multi-modal reasoning, showing a significant improvement of up to 11.8% compared to previous multi-agent setting (p < 0.05). Ablation studies reveal that our MDAgents effectively determines medical complexity to optimize for efficiency and accuracy across diverse medical tasks. We also explore the dynamics of group consensus, offering insights into how collaborative agents could behave in complex clinical team dynamics.
Create a new virtual environment, e.g. with conda
~$ conda create -n mdagents python>=3.9
Install the required packages:
~$ pip install -r requirements.txt
Activate the environment:
~$ conda activate mdagents
- MedQA: https://github.com/jind11/MedQA
- MedMCQA: https://github.com/medmcqa/medmcqa
- PubMedQA: https://github.com/pubmedqa/pubmedqa
- DDXPlus: https://github.com/mila-iqia/ddxplus
- SymCat: https://github.com/teliov/SymCat-to-synthea
- JAMA & Medbullets: https://github.com/xiaoman-zhang/PMC-VQA
- PMC-VQA: https://github.com/xiaoman-zhang/PMC-VQA
- Path-VQA: https://github.com/UCSD-AI4H/PathVQA
- MIMIC-CXR: https://github.com/baeseongsu/mimic-cxr-vqa
- MedVidQA: https://github.com/deepaknlp/MedVidQACL
Caution
main.py will be updated soon to the latest version.
~$ python3 main.py --model {gpt-3.5, gpt-4, gpt-4v, gpt-4o, gemini-pro, gemini-pro-vision} --dataset {medqa, pubmedqa, ddxplus, jama, symcat, medbullets, jama, pmc-vqa, path-vqa, mimic-cxr, medvidqa}
- update the main table with gpt-4o
- update main.py with the latest version
- add baseline methods
- add eval.py
- add more benchmarks (medmcqa, mmlu, mmmu, inspect, etc)