## 1. Introduction 
With the rapid advancement of deep learning, a wide variety of open-source models for different tasks have emerged. However, a single fine-tuned model often fails to meet users' diverse requirements. To address this limitation, model merging has been proposed as an effective approach to integrate the capabilities of existing models into a unified one. Among existing approaches, router-based methods have become representative baselines due to their strong performance; however, their reliance on a trainable router compromises the appealing advantage of traditional model merging—being completely training-free.
In this paper, we propose a training-free router from a similarity-based perspective. Our method achieves performance on par with router-based approaches while eliminating the need for any additional training. We demonstrate the effectiveness of TR-Merging across multiple tasks in both computer vision (CV) and natural language processing (NLP), and demonstrate its flexibility in adapting to diverse requirements.  
## 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!