## 1. Introduction 
Recent advances in deep learning have led to a surge of open-source models across diverse domains. 
While model merging offers a promising way to combine their strengths, existing approaches often suffer from parameter conflicts that degrade performance on domain-specific tasks. 
We propose MIN-Merging, a router-based framework that selectively merges the most important neurons to reduce such conflicts.
Extensive experiments on Computer Vision(CV) and Natural Language Processing(NLP) benchmarks show that MIN-Merging achieves consistent gains on in-domain tasks while retaining the generalization ability of pretrained models on out-of-domain tasks. 
These results highlight its effectiveness as a practical solution to the parameter conflict problem in model merging.
## 2. Code Architecture
 ├────── README.md              # Introduction and instructions for running the code
 ├────── ora_vit.ipynb          # Fine-tuning task-specific models using LoRA
 ├────── train_router.ipynb     # Training the router to select relevant model components
 ├────── merge_test.ipynb       # Merging task-specific models and evaluating performance
 ├────── util.py                # Utility functions for data processing and preprocessing

## 3. How to Run the Code

To reproduce our results or use the provided implementation, please follow the steps below:

### Step 1: Install Dependencies

First, ensure you have Python installed (we recommend Python 3.8+). Then, install all required packages by running:

<pre><code>```pip install -r requirements.txt ``` </code></pre>

This will install all dependencies listed in the requirements.txt file, including PyTorch, Transformers, and other supporting libraries.

### Step 2: Prepare and Fine-Tune the Model
Next, open and run the following notebook to apply LoRA-based fine-tuning to a ViT model:

<pre><code>```jupyter notebook lora_vit.ipynb ``` </code></pre>

This notebook performs low-rank adaptation of a Vision Transformer using task-specific datasets.

### Step 3: Train the Router

After fine-tuning, train the router module that dynamically selects expert layers based on input relevance:

<pre><code>```jupyter notebook train_router.ipynb ``` </code></pre>

This step involves training a lightweight routing network that guides expert selection during inference.

### Step 4: Merge and Evaluate

Finally, merge the fine-tuned models and evaluate performance using the following notebook:

<pre><code>```jupyter notebook merge_test.ipynb ``` </code></pre>

This step demonstrates how the merged model performs across multiple tasks and showcases the benefits of the proposed model merging strategy.

Feel free to open an issue if you encounter any problems during setup or training. We welcome contributions and feedback!