# Auto LLM Merging

## Overview

This is a framework that supports automatic merging of language models, consisting of various components.

### Key Components

- **Merge Methods**: Supports multiple merging algorithms including Slerp, linear merge, Ties, and task arithmetic
- **Loader**: Manages input/output operations for model loading and saving
- **Utils**: Contains utilities for merging, logging, caching, and other helper functions
- **Tokenizer**: Handles alignment of tokenizers across different models
- **Merge Strategies**: Implements diverse merging approaches:
  - Normal model merging
  - Normal slice merging
  - Depth-wise Integration Strategy (DIS)
  - Layer-wise Fusion Strategy (LFS)
  - Layer-wise Fusion Strategy with Multi-objective optimization (LFS_MO)
  - Layer Pruning Strategy
- **Evaluation**: Powered by [lm-evaluation-harness](https://github.com/EleutherAI/lm-evaluation-harness/tree/15ffb0dafa9c869c7436ba9a3cf3067ac4c9d846) for comprehensive model assessment

## Installation

To run the code, please ensure you have the required dependencies installed:

# Install dependencies using conda
conda env create -f environment.yml

## Usage

The framework uses SMAC optimizer and supports both single-objective and multi-objective optimization approaches.

### Layer Pruning

```bash
python3 merge.py --config ./exp_config/config_prune.yaml

We've placed the tasks used in our experiments in the `custom_tasks` directory. You can also design your own optimization objectives.

### Reproducing Our Results

We've placed the search configurations from our paper in the `search_config` directory. You can evaluate these configurations using the provided configs.
