# Q-Tuning with Mistral-7B

This project demonstrates **Q-Tuning** experiments using **[LLaMA-Factory](https://github.com/hiyouga/LLaMA-Factory)** with the **Mistral-7B** model.
The repository includes scripts for environment setup, model download, and training.

**Note that WISE denotes our Q-Tuning method.** You will see WISE-related code throughout this implementation, which refers to our **Quadrant-based Tuning (Q-Tuning)** method.

---

## 1. Prepare the Model

We use [ModelScope](https://modelscope.cn/models) to download **Mistral-7B-v0.1**:

```bash
mkdir models
pip install modelscope
modelscope download --model AI-ModelScope/Mistral-7B-v0.1 --local_dir ./models/mistral-7b
```

> **Note:** In this demo version, the `wizard` and `mathinstruct` datasets are truncated to the first 1,000 samples.
> You may replace them with the full versions under `q_tuning/LLaMA-Factory/data`.
> If filenames differ, please update `dataset_info.json` accordingly.

---

## 2. Set Up the Environment

Create and activate a Conda environment (Python 3.10 recommended):

```bash
conda create -n q_tuning python=3.10
conda activate q_tuning
```

Install **LLaMA-Factory** with metric support:

```bash
cd LLaMA-Factory
pip install -e .[metrics]
cd ..
```
Unzip the provided transformers.zip to apply some necessary fixes:
```bash
unzip transformers.zip
```
---

## 3. Run the Demo

Execute the provided demo script:

```bash
./demo.sh
```

This will set up environment variables and launch `llamafactory-cli train` with the Q-Tuning configuration.

---

## Notes

* Ensure that the model path (`./models/mistral-7b`) matches the configuration in `demo.sh`.
* You can modify datasets, model checkpoints, and pruning ratios by editing the arguments in `demo.sh`.
* The supplementary package includes a runnable Q-Tuning implementation and training scripts. The full codebase, including evaluation pipelines, will be released upon acceptance of the paper.

---

