# VIG-training
Official repository for "Focusing Where Vision Matters: Selective Training for Large Vision Language Models via Visual Information Gain"

## Environment
This code was tested on `Ubuntu 20.04.6 LTS` and requires:

* Python 3.10
* CUDA capable GPU

Setup conda env:

```shell
conda create -n vig python=3.10 -y
conda activate vig
pip install -U uv
cd LLaVA
uv pip install -e .
 
uv pip install opencv-python
uv pip install -U accelerate
uv pip install transformers==4.47.0
uv pip install numpy==1.26.4
uv pip install huggingface-hub==0.36.0
uv pip install protobuf==3.20.0
uv pip install deepspeed==0.14.4
uv pip install wandb
uv pip install flash_attn

cd ..
# PWD: VIG-training
```

## 1. Dataset Preperation
Please follow the instructions in the official [LLaVA-1.5 repository](https://github.com/haotian-liu/LLaVA) to download and organize the image-text datasets. Ensure that the data is structured correctly in your directory before proceeding.

## 2. Visual Information Gain
To perform VIG-guided selective training, we first compute the VIG score for each training sample to identify visually significant samples and tokens.

### Step 1: Calculate VIG Scores
Run the following script to compute the raw VIG scores for the dataset:

```shell
cd vig
bash bash/get_vig.sh
```

### Step 2: Generate Selection Indices
After computing the scores, generate the indices of the selected samples and the corresponding threshold. The default selection ratio p is set to 70%. You can modify the ratio by passing it as an argument to the script.

```shell
# pwd: VIG-training/vig
bash bash/get_info.sh
```

[Output] This will generate a selected index file (e.g., `sel_idx.npy`) and print the corresponding threshold value.


## 2. Train
### Step 1: Configure Hyperparameters
Before starting the training, update the `scripts/v1_5/finetune.sh` script with the threshold and index file obtained from the previous step.
Open scripts/v1_5/finetune.sh and locate the following arguments:

```shell
...
--threshold `threshold you get` \
--sel_idx `sel_idx.npy`
...
```

### Step 2: Launch Training
Once configured, initiate the instruction tuning process using the command below:
```shell
# pwd: VIG-training/LLaVA
bash script/v1_5/finetune.sh
```

## Overview
### Abstract
Large Vision Language Models (LVLMs) have achieved remarkable progress, yet they often suffer from language bias, producing answers without relying on visual evidence. While prior work attempts to mitigate this through decoding strategies, architectural modifications, or curated instruction data, they typically lack a quantitative measure of how much individual training samples or tokens actually benefit from the image. In this work, we introduce Visual Information Gain (VIG), a perplexity-based metric that measures the reduction in prediction uncertainty provided by visual input. VIG enables fine-grained analysis at both sample and token levels, effectively highlighting visually grounded elements such as colors, spatial relations, and attributes. Leveraging this, we propose a VIG-guided selective training scheme that prioritizes high-VIG samples and tokens. This approach improves visual grounding and mitigates language bias, achieving superior performance with significantly reduced supervision by focusing exclusively on visually informative samples and tokens.

### Contribution
- We introduce Visual Information Gain (VIG), a perplexity-based metric that quantifies the contribution of visual input by measuring the reduction in model uncertainty. VIG provides a model-agnostic and decomposable measure, enabling fine-grained analysis of visual dependency at both the sample and token levels.
- We empirically demonstrate that VIG serves as a reliable indicator of visual grounding. Our analysis shows that VIG aligns with benchmark-level modality dependencies and successfully identifies visually grounded tokens (such as colors, spatial relations, and attributes) while distinguishing them from tokens driven primarily by textual priors.
- We propose a VIG-guided selective training scheme that prioritizes high-VIG samples and tokens. This approach enhances data efficiency by pruning weakly grounded samples and focusing optimization on visually informative tokens. Notably, this strategy improves visual grounding and mitigates language bias, achieving superior performance with highly sparse supervision compared to full-data training.
