File size: 2,783 Bytes
a99a26a
 
 
 
 
 
 
 
 
2cb8c65
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a99a26a
2cb8c65
a99a26a
2cb8c65
a99a26a
2cb8c65
a99a26a
2cb8c65
a99a26a
2cb8c65
a99a26a
2cb8c65
a99a26a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2cb8c65
60093ce
2cb8c65
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
---
base_model:
- meta-llama/Meta-Llama-3.1-405B-Instruct
library_name: transformers
tags:
- mergekit
- merge
---

# 🦙⛰️ BigLlama-3.1-681B-Instruct

![image/png](https://cdn-uploads.huggingface.co/production/uploads/61b8e2ba285851687028d395/DcEFMtuBt8-Pl3chGqxoG.png)

<center>🦙✨ <i><a href="https://huggingface.co/mlabonne/BigLlama-3.1-1T-Instruct">mlabonne/BigLlama-3.1-1T-Instruct</a></i></center>

This is an experimental self-merge using [meta-llama/Meta-Llama-3.1-405B-Instruct](https://huggingface.co/meta-llama/Meta-Llama-3.1-405B-Instruct) and created with [mergekit](https://github.com/cg123/mergekit).

This is the direct successor of [Meta-Llama-3-120B-Instruct](https://huggingface.co/mlabonne/Meta-Llama-3-120B-Instruct), a self-merge of Llama 3 70B that produced a decent 120B model for tasks like creative writing.

I tweaked the range of duplicated layers to hopefully make a sensible model. Use it at your own risk!

## 🔍 Applications

I recommend using this model for creative writing with the Llama 3 chat template.

## ⚡ Quantization

TBD.

## 🏆 Evaluation

TBD.

## 🧩 Configuration

This model was merged using the passthrough merge method. The following YAML configuration was used to produce this model:

```yaml
slices:
- sources:
  - layer_range: [0, 42]
    model: meta-llama/Meta-Llama-3.1-405B-Instruct
- sources:
  - layer_range: [21, 63]
    model: meta-llama/Meta-Llama-3.1-405B-Instruct
- sources:
  - layer_range: [42, 84]
    model: meta-llama/Meta-Llama-3.1-405B-Instruct
- sources:
  - layer_range: [63, 105]
    model: meta-llama/Meta-Llama-3.1-405B-Instruct
- sources:
  - layer_range: [84, 126]
    model: meta-llama/Meta-Llama-3.1-405B-Instruct
merge_method: passthrough
dtype: bfloat16
```

Here is the code I've used to generate the config and calculate the number of layers/parameters after passthrough:

```python
def generate_yaml_config(range_size, total_layers, nb_parameters):
    new_size = total_layers + total_layers - range_size
    new_param = (nb_parameters / total_layers) * new_size
    print(f"New size = {new_size} layers")
    print(f"New parameters = {new_param:.2f}B")
    yaml_str = "slices:\n"

    for i in range(0, round(total_layers - range_size + 1), range_size // 2):
        start = i
        end = min(start + range_size, total_layers)
        yaml_str += f"- sources:\n"
        yaml_str += f"  - layer_range: [{start}, {end}]\n"
        yaml_str += f"    model: meta-llama/Meta-Llama-3.1-405B-Instruct\n"

    yaml_str += "merge_method: passthrough\n"
    yaml_str += "dtype: bfloat16\n"

    print(yaml_str)

    return new_size, new_param

# Example usage
new_size, new_param = generate_yaml_config(42, 126, 410)
new_size, new_param = generate_yaml_config(105, new_size, new_param)
```