--- license: apache-2.0 language: - zh - en --- # Pathology-LLaVA-(PCaption-0.5M dataset)  We developed a domain-speciffc large language-vision assistant (PA-LLaVA) for pathology image understanding. Specifically, (1) we first construct a human pathology image-text dataset by cleaning the public medical image-text data for domainspecific alignment; (2) Using the proposed image-text data, we first train a pathology language-image pretraining (PLIP) model as the specialized visual encoder for pathology image, and then we developed scale-invariant connector to avoid the information loss caused by image scaling; (3) We adopt two-stage learning to train PA-LLaVA, first stage for domain alignment, and second stage for end to end visual question & answering (VQA) task. ##### Our code is publicly available on Github.[ddw2AIGROUP2CQUPT/PA-LLaVA (github.com)](https://github.com/ddw2AIGROUP2CQUPT/PA-LLaVA) ## Architecture ![image/png](https://cdn-uploads.huggingface.co/production/uploads/663f06e01cd68975883a353e/SkFB0x3JunWE_Wae808Nq.png) ## Human Pathology Image-Text data (PCaption-0.5M) ### Introduction These public datasets contain substantial amounts of data unrelated to human pathology. To obtain the human pathology image-text data, we performed two cleaning processes on the raw data, as illustrated in the follow figture: (1) Removing nonpathological images. (2) Removing nonhuman pathology data. Additionally, we excluded image-text pairs with textual descriptions of fewer than 20 words. Ultimately, we obtained 518,413 image-text pairs (named "PCaption-0.5M" ) for the aligned training dataset. Instruction fine-tuning phase we only cleaned PMC-VQA in the same way and obtained 15,788 question-answer pairs related to human pathology. Lastly, we combined PathVQA and Human pathology data obtained from PMC-VQA, thereby constructing a dataset of 35543 question-answer pairs data. #### Data Cleaning Process ![image/png](https://cdn-uploads.huggingface.co/production/uploads/663f06e01cd68975883a353e/IAeFWhH8brZYDaTJnew2N.png) ## Get the Dataset ### Step 1 Download the public datasets. Here we only provide the download link for the public dataset and expose the image id index of our cleaned dataset on HuggingFace. #### Domain Alignment Stage PubMedVision-Alignment: [FreedomIntelligence/PubMedVision · Datasets at Hugging Face](https://huggingface.co/datasets/FreedomIntelligence/PubMedVision) PMC-OA: [axiong/pmc_oa · Datasets at Hugging Face](https://huggingface.co/datasets/axiong/pmc_oa) Quilt-1M: [Quilt-1M: One Million Image-Text Pairs for Histopathology (zenodo.org)](https://zenodo.org/records/8239942) #### Instruction Tuning Stage PathVQA: https://drive.google.com/drive/folders/1G2C2_FUCyYQKCkSeCRRiTTsLDvOAjFj5 PMC-VQA: [xmcmic/PMC-VQA · Datasets at Hugging Face](https://huggingface.co/datasets/xmcmic/PMC-VQA) #### Categorical dataset for zero-sample testing ICIAR 2018 BACH: https://iciar2018-challenge.grand-challenge.org/Download/ OSCC: https://data.mendeley.com/datasets/ftmp4cvtmb/1 ColonPath : https://medfm2023.grand-challenge.org/datasets ### Step 2 Data processing. First, use the image index of the clean dataset provided by us to extract the human pathological dataset, and then process it into the following format: ``` [ { "image": , "caption": }, ] ``` Finally, run dataformate.py to get the format needed to train the model. ``` python dataformat.py ``` ## Checkpoint Our released weights are distributed training weights that can be directly loaded for training through XTuner. If you need merged weights, they can be merged using XTuner (using the weights from the domain alignment phase as an example): ``` xtuner convert pth_to_hf path/pallava_domain_alignment.py ./domain_alignment_weight.pth ./domain_alignment_weight_ft xtuner convert merge meta-llama/Meta-Llama-3-8B-Instruct ./domain_alignment_weight_ft/llm_adapter ./domain_alignment_weight_ft/llm_merge_lora ``` ## Training We used xtuner as a training tool, so please go to xtuner official to complete the environment configuration [https://github.com/InternLM/xtuner]. Then place the pallava folder under the xtuner_add folder into the xtuner folder. #### Domain Alignment ``` NPROC_PER_NODE=8 NNODES=2 PORT=12345 ADDR= NODE_RANK=0 xtuner train pallava_domain_alignment.py --deepspeed deepspeed_zero2 --seed 1024 ``` #### Instruction Tuning ``` NPROC_PER_NODE=8 NNODES=2 PORT=12345 ADDR= NODE_RANK=0 xtuner train pallava_instruction_tuning.py --deepspeed deepspeed_zero2 --seed 1024 ``` ## Result ![image/png](https://cdn-uploads.huggingface.co/production/uploads/663f06e01cd68975883a353e/ng9KbUevJk5HyYONpOg2S.png) ![image/png](https://cdn-uploads.huggingface.co/production/uploads/663f06e01cd68975883a353e/gbVIcTgfHCe80Rm832w35.png) ## Citation ``` @misc{dai2024pallavalargelanguagevisionassistant, title={PA-LLaVA: A Large Language-Vision Assistant for Human Pathology Image Understanding}, author={Dawei Dai and Yuanhui Zhang and Long Xu and Qianlan Yang and Xiaojing Shen and Shuyin Xia and Guoyin Wang}, year={2024}, eprint={2408.09530}, archivePrefix={arXiv}, primaryClass={cs.AI}, url={https://arxiv.org/abs/2408.09530}, } ``` ## contact mailto: [S230233056@stu.cqupt.edu.cn](mailto:S230233056@stu.cqupt.edu.cn) or [dw_dai@163.com](mailto:dw_dai@163.com)