# Visual Instruction Tuning task
This code is adapted from [LibMoE](https://github.com/Fsoft-AIC/LibMoE) repository. We use this code to train the model on the Visual Instruction Tuning task.

### 📥 Installation

1. **Clone this repository:**

    ```bash
    git clone https://github.com/Fsoft-AIC/LibMoE.git
    cd LibMoE
    ```

2. **Install dependencies:**

    *We used Python 3.9 `venv` for all experiments, and it should be compatible with Python 3.9 or 3.10 under Anaconda if you prefer to use it.*

    - Using `venv`:

        ```bash
        python -m venv /path/to/new/virtual/moe
        source /path/to/new/virtual/moe/bin/activate
        ```

    - Using `Anaconda`:

        ```bash
        conda create -n moe python=3.9 -y
        conda activate moe
        ```

    Then, install the required packages:

    ```bash
    pip install --upgrade pip
    pip install -e .
    pip install -r ./requirements.txt
    ```

3. **Install additional packages:**

    Choose the FlashAttention version based on your Torch version from the [FlashAttention Releases](https://github.com/Dao-AILab/flash-attention/releases/).

    Example:

    ```bash
    pip install https://github.com/Dao-AILab/flash-attention/releases/download/v2.6.3/flash_attn-2.6.3+cu118torch2.1cxx11abiFALSE-cp311-cp311-linux_x86_64.whl
    ```

### 📊 Dataset Preparation
For a detailed, step-by-step guide on setting up the dataset, please refer to the [dataset guide](https://github.com/Fsoft-AIC/LibMoE/blob/main/docs/dataset_guide.md).

### 🏋️‍♂️ Training
```bash
bash scripts/train/phi35mini/siglip/sft_graph_full.sh 1 0.9 0/9 normalized 0
```

### 📈 Evaluation
```bash
bash scripts/eval/run_eval.sh
```
