We introduce MMed-RAG, a powerful multimodal RAG system that boosts the factuality of Medical Vision-Language Models (Med-LVLMs) by up to 43.8%! 🩺 [Paper] [X(Twitter)]
- [10/20/2024] The whole data is released in
data/
! Check it out! - [10/18/2024] The manuscript can be found on arXiv.
MMed-RAG enhances alignment across medical domains like radiology, pathology, and ophthalmology with a domain-aware retrieval mechanism. And it tackles three key challenges in alignment of multimodal RAG:
1️⃣ Direct Copy Homework from Others❌ Think it by Self ✅ MMed-RAG helps Med-LVLMs avoid blindly copying external information by encouraging the model to rely on its own visual reasoning when solving complex problems.
2️⃣ Cannot Solve Problems by Self❌ Learn How to Copy ✅ When Med-LVLMs are unsure, MMed-RAG teaches the model to intelligently use retrieved knowledge, pulling in the right information at the right time, boosting accuracy, and reducing errors.
3️⃣ Copied Homework is Wrong❌ Avoid Interference from Incorrect Homework ✅ MMed-RAG prevents models from being misled by incorrect retrievals, reducing the risk of generating inaccurate medical diagnoses.
- Clone this repository and navigate to MMed-RAG folder
git clone https://github.com/richard-peng-xia/MMed-RAG.git
cd MMed-RAG
- Install Package: Create conda environment
conda create -n MMed-RAG python=3.10 -y
conda activate MMed-RAG
cd MMed-RAG
pip install --upgrade pip # enable PEP 660 support
pip install -r requirements.txt
pip install trl
-
Download the required model checkpoints LLaVA-Med-1.5 from huggingface.
-
For all the medical datasets, you need firstly apply for the right of access and then download the dataset.
We provide a corresponding json or jsonl file for each dataset, including the image path, question, answer, and original report.
-
Training: The data used to train the retriever and fine-tune the Med-LVLM are located in
data/training/retriever/MODALITY
anddata/training/alignment/MODALITY
respectively. Each folder contains data for VQA or report generation tasks. -
Test: All the test data for Med-LVLMs is placed under
data/test/TASK/MODALITY
.
TASK
: report/vqa, MODALITY
: radiology/pathology/ophthalmology.
Use the following script, make sure to specify the data paths and the checkpoint saving location.
bash ./scripts/finetune_clip.sh
Use the script train_dpo_2stages.sh
in ./script
or the following command, make sure to specify the necessary data paths and the checkpoint saving location.
deepspeed --include localhost:0,1,2,3 ./train/dpo/train_dpo_2stages.py \
--model_name_or_path /path/to/llava-med_model_checkpoint \
--deepspeed ./scripts/zero3.json \
--version v1 \
--lora_enable True --lora_r 128 --lora_alpha 256 --mm_projector_lr 2e-5 \
--data_path /path/to/data_json \
--image_folder /path/to/img_folder \
--vision_tower openai/clip-vit-large-patch14-336 \
--mm_projector_type mlp2x_gelu \
--mm_vision_select_layer -2 \
--mm_use_im_start_end False \
--mm_use_im_patch_token False \
--image_aspect_ratio pad \
--group_by_modality_length True \
--bf16 True \
--output_dir /path/to/output_checkpoint_saving_location \
--num_train_epochs 3 \
--per_device_train_batch_size 1\
--per_device_eval_batch_size 1 \
--gradient_accumulation_steps 1 \
--evaluation_strategy "no" \
--save_strategy "steps" \
--save_steps 200 \
--save_total_limit 1 \
--learning_rate 1e-7 \
--weight_decay 0. \
--warmup_ratio 0.03 \
--lr_scheduler_type "cosine" \
--logging_steps 1 \
--report_to wandb \
--tf32 True \
--model_max_length 1024 \
--gradient_checkpointing True \
--dataloader_num_workers 4 \
--lazy_preprocess True \
Use retrieve_clip_report.sh
or retrieve_clip_VQA.sh
to retrieve reports for report generation or VQA task. The script uses Harvard-FairVLMed dataset as an example. Make sure to specify the necessary data paths and the saving location.
-
Release the data (VQA and report generation tasks)
-
Release the training code
@article{xia2024mmedrag,
title={MMed-RAG: Versatile Multimodal RAG System for Medical Vision Language Models},
author={Xia, Peng and Zhu, Kangyu and Li, Haoran and Wang, Tianze and Shi, Weijia and Wang, Sheng and Zhang, Linjun and Zou, James and Yao, Huaxiu},
journal={arXiv preprint arXiv:2410.13085},
year={2024}
}
We use code from LLaVA-Med, RULE, CARES. We thank the authors for releasing their code.