## Overview

This repository contains the code and resources for the paper.

## Prepare

### Dataset

For the vision task, one can follow the instructions below to prepare the datasets.
Each dataset can be downloaded via the links provided in the following Table. For preprocessing, we follow the procedure described in [link1](https://github.com/pytorch/vision/issues/7545#issuecomment-1631441616), [link2](https://github.com/mlfoundations/task_vectors/issues/1). 
For some datasets, one should use the scripts in `dataset/preparing`.
Note that for the Stanford Cars dataset, after downloading it from Kaggle, one need to remove redundant directories and separately download the .mat file from the provided link.

| Dataset Name      | Download Method                                              | Processing Script    |
| ----------------- | ------------------------------------------------------------ | -------------------- |
| **DTD**           | [Manual Download](https://www.robots.ox.ac.uk/~vgg/data/dtd/download/dtd-r1.0.1.tar.gz) | `​process_dtd.py`​     |
| **EuroSAT**       | [Manual Download](https://madm.dfki.de/files/sentinel/EuroSAT.zip) | `​process_eurosat.py`​ |
| **SUN397**        | [Manual Download](URL)                                       | `​process_sun.py`​     |
| **Stanford-Cars** | [Manual Download](https://www.kaggle.com/datasets/eduardo4jesus/stanford-cars-dataset) | Not specified        |
| **GTSRB**         | [Manual Download](https://cdn.cs50.net/ai/2023/x/projects/5/gtsrb.zip) | Not specified        |
| **NWPU-RESISC45** | [Manual Download](URL)                                       | Not specified        |
| **MNIST**         | Automatically downloaded by script                           | Not specified        |
| **SVHN**          | Automatically downloaded by script                           | Not specified        |


For language tasks, the datasets can be downloaded automatically by script.

### Model

The models can also be downloaded automatically when running the scripts.

## Run

To reproduce the results in the paper, one can run the following commands.

```bash
python eval_scripts_clean/8vision_pertask_linearsearch_layers.py \
    --config=vitB_r16_linearsearch_universal.py \
    --merge_method=ties \
    --merge_space=low_rank_core \
    --representation=matrix_per_layer \
    --isotropize=0 --low_rank=1 --lora_rank=16 --only_eval=True \
    --scaling_coeffs=0.75 --topK=25 --beta=0.25
```

If one want to re-search the hyperparameters, one can set `--only_eval=False`.