Skip to content

Commit

Permalink
convert.py : try to determine n_ctx automatically for CodeLlama (#2770)
Browse files Browse the repository at this point in the history
  • Loading branch information
slaren authored and pull[bot] committed Feb 12, 2024
1 parent 97b9cc3 commit 0000000
Showing 1 changed file with 11 additions and 1 deletion.
12 changes: 11 additions & 1 deletion convert.py
Original file line number Diff line number Diff line change
Expand Up @@ -200,13 +200,23 @@ def loadOriginalParamsJson(model: 'LazyModel', config_path: 'Path') -> 'Params':
n_embd = config["dim"]
n_layer = config["n_layers"]
n_mult = config["multiple_of"]
n_ctx = 2048 if config["norm_eps"] == 1e-06 else 4096 # hack to determine LLaMA v1 vs v2
n_ff = -1
n_head = config["n_heads"]
n_head_kv = config["n_kv_heads"] if "n_kv_heads" in config else n_head
f_norm_eps = config["norm_eps"]
f_rope_freq_base = config["rope_theta"] if "rope_theta" in config else None

# hack to determine LLaMA v1 vs v2 vs CodeLlama
if f_rope_freq_base and f_rope_freq_base == 1000000:
# CodeLlama
n_ctx = 16384
elif config["norm_eps"] == 1e-05:
# LLaMA v2
n_ctx = 4096
else:
# LLaMA v1
n_ctx = 2048

if n_vocab == -1:
n_vocab = model["tok_embeddings.weight"].shape[0]

Expand Down

0 comments on commit 0000000

Please sign in to comment.