afg1 commited on
Commit
c3e2724
1 Parent(s): 8025720

Upload configuration_mixformer_sequential.py

Browse files
configuration_mixformer_sequential.py ADDED
@@ -0,0 +1,53 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Copyright (c) Microsoft Corporation.
2
+ # Licensed under the MIT license.
3
+
4
+ import math
5
+ from typing import Any, Dict, List, Optional, Union
6
+
7
+ from transformers import PretrainedConfig
8
+
9
+
10
+ class MixFormerSequentialConfig(PretrainedConfig):
11
+ """MixFormer (sequential for DeepSpeed) configuration."""
12
+
13
+ model_type = "mixformer-sequential"
14
+
15
+ attribute_map = {
16
+ "max_position_embeddings": "n_positions",
17
+ "hidden_size": "n_embd",
18
+ "num_attention_heads": "n_head",
19
+ "num_hidden_layers": "n_layer",
20
+ }
21
+
22
+ def __init__(
23
+ self,
24
+ vocab_size: Optional[int] = 50304,
25
+ n_positions: Optional[int] = 2048,
26
+ n_embd: Optional[int] = 1024,
27
+ n_layer: Optional[int] = 20,
28
+ n_inner: Optional[int] = None,
29
+ n_head: Optional[int] = 16,
30
+ rotary_dim: Optional[int] = 32,
31
+ activation_function: Optional[str] = "gelu_new",
32
+ embd_pdrop: Optional[float] = 0.0,
33
+ resid_pdrop: Optional[float] = 0.0,
34
+ layer_norm_epsilon: Optional[float] = 1e-5,
35
+ initializer_range: Optional[float] = 0.02,
36
+ tie_word_embeddings: Optional[bool] = False,
37
+ pad_vocab_size_multiple: Optional[int] = 64,
38
+ **kwargs
39
+ ) -> None:
40
+ self.vocab_size = int(math.ceil(vocab_size / pad_vocab_size_multiple) * pad_vocab_size_multiple)
41
+ self.n_positions = n_positions
42
+ self.n_embd = n_embd
43
+ self.n_layer = n_layer
44
+ self.n_inner = n_inner
45
+ self.n_head = n_head
46
+ self.rotary_dim = min(rotary_dim, n_embd // n_head)
47
+ self.activation_function = activation_function
48
+ self.embd_pdrop = embd_pdrop
49
+ self.resid_pdrop = resid_pdrop
50
+ self.layer_norm_epsilon = layer_norm_epsilon
51
+ self.initializer_range = initializer_range
52
+
53
+ super().__init__(tie_word_embeddings=tie_word_embeddings, **kwargs)