Excalibur-7b / README.md
InferenceIllusionist's picture
Update README.md
2d9610a verified
metadata
base_model:
  - ibm/merlinite-7b
  - InferenceIllusionist/Magic-Dolphin-7b
  - SanjiWatsuki/Kunoichi-DPO-v2-7B
  - mlabonne/Monarch-7B
  - bardsai/jaskier-7b-dpo-v6.1
library_name: transformers
tags:
  - mergekit
  - merge
license: apache-2.0

Excalibur-7b

Update: A fine-tuned version of this model is now publicly available, along with benchmark results. If you're looking for a more conversational, assistant-style exchange you won't want to miss it!

Image generated with Envoid's Model9 SDXL model

GGUFs can be found here

Alternative GGUFs from bartowski can be found here.

EXl2 can also be found here again courtesy of bartowski!

Performance Comparison

Name Avg. ARC HellaSwag MMLU TruthfulQA Winogrande GSM8K
Excalibur-7b 73.6 69.71 87.56 65.66 67.24 82.79 68.61
Magic-Dolphin-7b 67.48 65.78 85.61 64.64 58.01 79.64 51.18
merlinite-7b 64 63.65 84.52 64.91 50.15 79.72 41.09
* Open LLM Leaderboard Dataset

Methodology

Magic-Dolphin-7b was an unexpected surprise. Profoundly satisfied with it as a first attempt. For this follow-up I wanted to target the MMLU benchmark specifically. The challenge this time was placing more weight on Merlinite-7b as an unknown quantity that hasn't been in the spotlight despite its novel LAB tuning method.

Excalibur-7b builds on past success and is the culmination of several learnings:

  • Measuring KL-divergences for new quantization types brought a deeper understanding of benchmarking and assessing model performance
  • This signifcantly sped up the testing process by using MMLU as a base, narrowing down over 10 candidate linear merges to 1: merliniteX-blockB1
  • Reaching the limitations of linear merging necessitated a pivot to reviewing the viability of SLERP, DARE-TIES, and Passthrough methods
  • Thus a competing candidate merge pool was tested between different merge algorithms. Once more the list was narrowed from 10 candidates to 1: merliniteX-blockF2
  • merliniteX-blockF2 (SLERP of Magic-Dolphin-7B and jaskier-7b-dpo in unorthadox proportions) was originally planned for release earlier this week
  • Instead -blockB1 and -blockF2 were merged and the results were placed head to head in a final round of tests. Ultimately a more conventional execution of SLERP showed the best results for the final step.

Sample Question

Bonus Question - Vision Capabilities

Requires additional mistral-7b-mmproj-v1.5-Q4_1.gguf file for vision functionality

Select up the gguf file of your choice in Kobold as usual, then make sure to choose the mmproj file above in the LLaVA mmproj field of the model submenu:

This is a merge of pre-trained language models created using mergekit.

Merge Details

Merge Method

This model was merged using the SLERP merge method.

Models Merged

The following models were included in the merge:

Configuration

The following YAML configurations were used to produce this model:

merliniteX-blockB1

models:
  - model: models/merlinite-7b
    parameters:
      weight: 1.0
  - model: models/Kunoichi-DPO-v2-7B
    parameters:
      weight: 0.2
  - model: models/jaskier-7b-dpo-v6.1
    parameters:
      weight: 0.6
  - model: models/Monarch-7b
    parameters:
      weight: 0.4
merge_method: linear
dtype: float16

merliniteX-blockF2

slices:
  - sources:
      - model: models/Magic-Dolphin-7b
        layer_range: [0, 32]
      - model: models/jaskier-7b-dpo-v6.1
        layer_range: [0, 32]
merge_method: slerp
base_model: models/Magic-Dolphin-7b
parameters:
  t:
    - filter: self_attn
      value: [0, 0.5, 0.3, 0.7, 0.5, 1]
    - filter: mlp
      value: [1, 0.5, 0.7, 0.3, 0.5, 0]
    - value: 0.5 # fallback for rest of tensors
dtype: float16

merliniteX-blockH1 (Excalibur-7b)

slices:
  - sources:
      - model: models/merliniteX-blockF2
        layer_range: [0, 32]
      - model: models/merliniteX-blockB1
        layer_range: [0, 32]
merge_method: slerp
base_model: models/merliniteX-blockF2
parameters:
  t:
    - filter: self_attn
      value: [1, 0.7, 0.3, 0.5, 0]
    - filter: mlp
      value: [0, 0.3, 0.7, 0.5, 1]
    - value: 0.5 # fallback for rest of tensors
dtype: float16