# DPLoRA: A Dual-Pruning Framework based on ILP Optimization and Progressive Pruning for Parameter-Efficient LoRA Fine-Tuning

![DPLoRA Overview](images/DPLoRA_figure1_v2.png)

This repository is the official implementation of our ICLR 2026 submission "DPLoRA: A Dual-Pruning Framework based on ILP Optimization and Progressive Pruning for Parameter-Efficient LoRA Fine-Tuning".

## Requirements

This project uses two separate requirement files, one for the GLUE benchmark and one for the Alpaca benchmark.

**For GLUE experiments:**
```setup
pip install -r requirements_glue.txt

```

**For Alpacaa experiments:**
```setup
pip install -r requirements_alpaca.txt
```
You will also need to install the following system dependencies:
```setup
sudo apt update
sudo apt install dos2unix
sudo apt-get install coinor-cbc

```

## Storage Requirements
Note: Full experiments require substantial storage:
- **GLUE Benchmark**: ~35GB
- **Alpaca Benchmark**: ~250GB  

## Project Structure
<pre lang="markdown"><code>
├── 1.GLUE/                             # Scripts and results for the GLUE benchmark
├── 2.Alpaca/                           # Scripts and results for the Alpaca benchmark
├── 3.Ablation_Study/                   # Scripts and results for ablation studies
│   ├── Computation Efficiency/
│   ├── Effect_of_EMA_and_Momentum_Penalty/
│   └── Pruning_Schedulers/
│
├── requirements_glue.txt               # Python package requirements for the GLUE environment
└── requirements_alpaca                 # Python package requirements for the Alpaca environment
```
</code></pre>

## Training and Evaluation

All training and evaluation scripts are located within the `scripts/` sub-directory of each main experiment folder.

### GLUE Benchmark

The scripts follow the naming convention `train_<TASK_NAME>_<METHOD>.sh`.

For example, to train **DPLoRA (p=0.6)** on the **CoLA** task:
```bash
cd 1.GLUE/
bash scripts/train_cola_dplora_0.6.sh
```

### Alpaca Benchmark

For example, to train DPLoRA (p=0.8):
```bash
cd 2.Alpaca/
bash scripts/train_alpaca_dplora_0.8.sh
```

## Pre-trained Models

Due to size constraints, we do not provide pre-trained model weights with this code submission. 
Please use the training scripts to reproduce our results.

## Results

Our model achieves the following performance:
### GLUE Benchmark

We report the overall (matched and mismatched) accuracy for MNLI, Matthew's correlation for CoLA, Pearson correlation for STS-B, and accuracy for other tasks. Higher is better for all metrics. † indicates runs with key hyperparameters matched for a fair comparison.

| Method | # Trainable Params(M) | CoLA | MNLI | MRPC | QNLI | QQP | RTE | SST2 | STS-B | Avg. |
| :----- | :-------------------- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :---- | :--- |
| FT | 125.0 | 60.7 | 87.5 | 88.6 | 92.7 | 91.7 | 75.8 | 93.8 | 90.3 | 85.1 |
| LoRA(r=16) | 2.7 | 60.0 | **87.7** | 88.6 | 92.6 | 91.2 | 77.6 | 94.1 | 89.9 | 85.2 |
| LoRA(r=8) | 1.3 | 58.3 | 87.6 | 88.2 | 92.6 | 90.8 | 76.4 | 94.2 | 89.9 | 84.7 |
| SoRA | 0.9 | 58.4 | **87.7** | 87.3 | 92.9 | 91.6 | 76.8 | 93.8 | 90.3 | 84.8 |
| AdaLoRA | 0.3 | 61.4 | 87.3 | 86.5 | 92.7 | 89.8 | 78.8 | 93.9 | **91.0** | 85.2 |
| Adapter* | 0.9 | **62.6** | 87.3 | 88.4 | **93.0** | 90.6 | 75.9 | **94.7** | 90.3 | 85.4 |
| BitFit* | 0.1 | 62.0 | 84.7 | **92.7** | 91.8 | 84.0 | **81.5** | 93.7 | 90.8 | 85.2 |
| OPLoRA (ours) | 1.2 | **62.6** | 87.4 | 88.8 | 92.8 | 91.0 | 79.7 | **94.7** | 90.8 | **86.0** |
| DPLORA (ours, p=0.6) | 0.5 | 61.9 | 86.5 | 89.6 | 92.3 | 90.4 | 77.3 | 94.1 | 90.6 | 85.3 |
| DPLORA (ours, p=0.7) | 0.4 | 60.5 | 86.4 | 89.9 | 92.1 | 90.0 | 76.2 | 93.5 | 90.4 | 84.9 |
| DPLORA (ours, p=0.8) | 0.2 | 62.1 | 85.7 | 89.5 | 91.9 | 89.5 | 77.5 | 93.5 | 89.8 | 84.9 |

### Alpaca Benchmark
| Method | # Trainable Params(M) | MT-BENCH Score |
| :--- | :---: | :---: |
| LoRA (r=8) | 21.0 | 5.56 |
| OPLoRA (ours) | 20.0 | **5.65** |
| DPLoRA (ours, p=0.8) | 4.0 | 5.54 |
**Notes:**
* **Bold** indicates best performance in each column.
* † indicates our implementation with matched hyperparameters.
* '*' indicates a result adopted directly from the original paper.
* '(ours)' denotes a method proposed in this paper.

These results demonstrate our framework's dual strengths: OPLoRA achieves state-of-the-art performance, while DPLoRA provides a superior performance-efficiency trade-off by drastically reducing parameters while maintaining competitive scores.

## Contributing

This code is provided as a companion to our ICLR 2026 submission. For questions or discussions about the implementation, please contact the authors through the conference submission system.
If our paper is accepted, we plan to release the code under an open-source license with a public repository where contributions will be welcome.

## Citation
If you find our work useful in your research, please consider citing our paper:

```bash
@inproceedings{dplora2026,
  title={DPLoRA: A Dual-Pruning Framework based on ILP Optimization and Progressive Pruning for Parameter-Efficient LoRA Fine-Tuning},
  author={Author, First and Author, Second},
  booktitle={International Conference on Learning Representations (ICLR)},
  year={2026}
}
```

