Spaces:
Runtime error
Runtime error
Update configs.py
Browse files- configs.py +694 -42
configs.py
CHANGED
|
@@ -1,66 +1,400 @@
|
|
| 1 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 2 |
"clip_g": {
|
| 3 |
-
"models": ["
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 4 |
"config": {
|
| 5 |
"adapter_id": "003", "name": "DualShuntAdapter-G",
|
| 6 |
-
"
|
|
|
|
| 7 |
"model": "google/flan-t5-base",
|
| 8 |
"hidden_size": 768
|
| 9 |
-
},
|
| 10 |
-
"
|
| 11 |
-
|
| 12 |
-
|
| 13 |
-
|
|
|
|
|
|
|
|
|
|
| 14 |
"hidden_size": 1280, # This is the adapter's output size
|
| 15 |
"bottleneck": 640, "heads": 20,
|
| 16 |
-
"
|
| 17 |
-
"proj_layers": 2, "layer_norm": True, "dropout": 0.
|
| 18 |
-
"use_dropout":
|
| 19 |
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 20 |
"version": "v0.3.2"
|
| 21 |
},
|
| 22 |
-
|
|
|
|
|
|
|
|
|
|
| 23 |
"shunts_available": {
|
| 24 |
"shunt_type_name": "DualStreamAdapter-G",
|
| 25 |
"config_file_name": "config.json",
|
| 26 |
"shunt_list": [
|
| 27 |
-
"
|
| 28 |
-
"
|
| 29 |
-
"
|
| 30 |
-
"
|
| 31 |
-
"
|
| 32 |
-
"
|
| 33 |
-
"
|
| 34 |
-
"
|
| 35 |
-
"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 36 |
],
|
| 37 |
-
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 38 |
},
|
| 39 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 40 |
"models": ["vit-l-14", 'flan-t5-base'],
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 41 |
"config": {
|
| 42 |
"adapter_id": "002",
|
| 43 |
"name": "DualShuntAdapter",
|
| 44 |
-
"
|
| 45 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 46 |
"hidden_size": 768, # This is the adapter's output size
|
| 47 |
"bottleneck": 384, "heads": 12,
|
| 48 |
-
"
|
| 49 |
-
"proj_layers": 2, "layer_norm": True, "dropout": 0.
|
| 50 |
-
"use_dropout":
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 51 |
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 52 |
"version": "v0.3.2"
|
| 53 |
},
|
| 54 |
-
"repo": "AbstractPhil/t5-flan-base-vit-l-14-dual-stream-adapter",
|
| 55 |
"shunts_available": {
|
| 56 |
"shunt_type_name": "DualStreamAdapter-L",
|
| 57 |
"config_file_name": "config.json",
|
| 58 |
"shunt_list": [
|
| 59 |
-
"
|
| 60 |
-
"
|
| 61 |
-
"
|
| 62 |
-
"
|
| 63 |
-
"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 64 |
],
|
| 65 |
},
|
| 66 |
}
|
|
@@ -68,38 +402,173 @@ T5_SHUNT_REPOS = {
|
|
| 68 |
|
| 69 |
# ─── Adapter Configs ─────────────────────────────────────────────
|
| 70 |
|
| 71 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 72 |
"mobilebert-base-uncased": {
|
| 73 |
"repo_name": "google/mobilebert-uncased",
|
|
|
|
|
|
|
| 74 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 75 |
"subfolder": "",
|
| 76 |
},
|
| 77 |
"bert-base-uncased": {
|
| 78 |
"repo_name": "bert-base-uncased",
|
|
|
|
|
|
|
| 79 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 80 |
},
|
| 81 |
"bert-large-uncased": {
|
| 82 |
"repo_name": "bert-large-uncased",
|
|
|
|
|
|
|
| 83 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 84 |
},
|
| 85 |
"bert-base-cased": {
|
| 86 |
"repo_name": "bert-base-cased",
|
|
|
|
|
|
|
| 87 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 88 |
-
}
|
| 89 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 90 |
|
| 91 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 92 |
"flan-t5-base": {
|
| 93 |
"repo_name": "google/flan-t5-base",
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 94 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 95 |
},
|
| 96 |
"t5-small": {
|
| 97 |
"repo_name": "google-t5/t5-small",
|
|
|
|
|
|
|
| 98 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 99 |
-
|
| 100 |
},
|
| 101 |
"t5_small_human_attentive_try2_pass3": {
|
| 102 |
-
"repo_name": "AbstractPhil/
|
|
|
|
|
|
|
| 103 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 104 |
# the necessary config is present here for posterity in case it fails to load from HuggingFace.
|
| 105 |
"subfolder": "",
|
|
@@ -110,7 +579,7 @@ T5_CONFIGS = {
|
|
| 110 |
"architectures": [
|
| 111 |
"T5ForConditionalGeneration"
|
| 112 |
],
|
| 113 |
-
"attention_dropout": 0.
|
| 114 |
"classifier_dropout": 0.0,
|
| 115 |
"d_ff": 2048,
|
| 116 |
"d_kv": 64,
|
|
@@ -148,4 +617,187 @@ T5_CONFIGS = {
|
|
| 148 |
"vocab_size": 32128
|
| 149 |
}
|
| 150 |
}
|
| 151 |
-
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 1 |
+
from __future__ import annotations
|
| 2 |
+
from typing import Optional
|
| 3 |
+
import logging
|
| 4 |
+
logger = logging.getLogger(__name__)
|
| 5 |
+
|
| 6 |
+
|
| 7 |
+
|
| 8 |
+
|
| 9 |
+
DEFAULT_REPOS = {
|
| 10 |
+
"clip_g": "laion/CLIP-ViT-bigG-14-laion2B-39B-b160k",
|
| 11 |
+
"vit-bigG-14": "laion/CLIP-ViT-bigG-14-laion2B-39B-b160k",
|
| 12 |
+
"clip_l": "openai/clip-vit-large-patch14",
|
| 13 |
+
"vit-l-14": "openai/clip-vit-large-patch14",
|
| 14 |
+
"clip_l_4h": "openai/clip-vit-large-patch14",
|
| 15 |
+
"clip_l_x52": "AbstractPhil/beatrix-x52",
|
| 16 |
+
"clip_h": "openai/clip-vit-large-patch14-h",
|
| 17 |
+
"clip_vision": "openai/clip-vit-large-patch14-vision",
|
| 18 |
+
"t5_base": "google/flan-t5-base",
|
| 19 |
+
"t5_small": "google-t5/t5-small",
|
| 20 |
+
"t5_unchained": "AbstractPhil/t5-unchained",
|
| 21 |
+
"bert_beatrix": "AbstractPhil/bert-beatrix-2048",
|
| 22 |
+
"nomic_bert": "nomic-ai/nomic-bert-2048",
|
| 23 |
+
"mobilebert": "google/mobilebert-uncased",
|
| 24 |
+
"bert_base_uncased": "bert-base-uncased",
|
| 25 |
+
"bert_large_uncased": "bert-large-uncased",
|
| 26 |
+
"bert_base_cased": "bert-base-cased",
|
| 27 |
+
"bert_base_multilingual": "bert-base-multilingual-uncased",
|
| 28 |
+
"bert_base_multilingual_cased": "bert-base-multilingual-cased",
|
| 29 |
+
}
|
| 30 |
+
|
| 31 |
+
HARMONIC_SHUNT_REPOS = {
|
| 32 |
"clip_g": {
|
| 33 |
+
"models": ['t5_base', "clip_g"],
|
| 34 |
+
"repo": "AbstractPhil/t5-flan-base-vit-bigG-14-dual-stream-adapter",
|
| 35 |
+
"shunts_available": {
|
| 36 |
+
"shunt_type_name": "DualStreamAdapter-G",
|
| 37 |
+
"config_file_name": "config.json",
|
| 38 |
+
"shunt_list": [
|
| 39 |
+
{"name": "flan-t5-base+clip_g:caption", "file": "t5-flan-vit-bigG-14-dual_shunt_caption.safetensors" },
|
| 40 |
+
{"name": "flan-t5-base+clip_g:noise-e1", "file": "t5-flan-vit-bigG-14-dual_shunt_no_caption_e1.safetensors" },
|
| 41 |
+
{"name": "flan-t5-base+clip_g:noise-e3", "file": "t5-flan-vit-bigG-14-dual_shunt_no_caption_e2.safetensors" },
|
| 42 |
+
{"name": "flan-t5-base+clip_g:noise-e3", "file": "t5-flan-vit-bigG-14-dual_shunt_no_caption_e3.safetensors" },
|
| 43 |
+
{"name": "flan-t5-base+clip_g:summarize", "file": "t5-flan-vit-bigG-14-dual_shunt_summarize.safetensors" },
|
| 44 |
+
{"name": "flan-t5-base+clip_g_omega32:noise-10000", "file": "dual_shunt_omega_no_caption_e1_step_10000.safetensors" },
|
| 45 |
+
{"name": "flan-t5-base+clip_g_omega32:noise-1000", "file": "dual_shunt_omega_no_caption_noised_e1_step_1000.safetensors" },
|
| 46 |
+
{"name": "flan-t5-base+clip_g_omega32:noise-4000", "file": "dual_shunt_omega_no_caption_noised_e1_step_4000.safetensors" },
|
| 47 |
+
{"name": "flan-t5-base+clip_g_omega32:noise-10000v2", "file": "dual_shunt_omega_no_caption_noised_e1_step_10000.safetensors" },
|
| 48 |
+
],
|
| 49 |
+
},
|
| 50 |
"config": {
|
| 51 |
"adapter_id": "003", "name": "DualShuntAdapter-G",
|
| 52 |
+
"condition_encoders": [{
|
| 53 |
+
"type": "t5_base",
|
| 54 |
"model": "google/flan-t5-base",
|
| 55 |
"hidden_size": 768
|
| 56 |
+
}],
|
| 57 |
+
"modulation_encoders": [
|
| 58 |
+
{
|
| 59 |
+
"type": "clip_g",
|
| 60 |
+
"model": "laion/CLIP-ViT-bigG-14-laion2B-39B-b160k",
|
| 61 |
+
"hidden_size": 1280
|
| 62 |
+
}
|
| 63 |
+
],
|
| 64 |
"hidden_size": 1280, # This is the adapter's output size
|
| 65 |
"bottleneck": 640, "heads": 20,
|
| 66 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 67 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 68 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 69 |
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 70 |
"version": "v0.3.2"
|
| 71 |
},
|
| 72 |
+
},
|
| 73 |
+
"clip_g_8h": {
|
| 74 |
+
"models": ['bert_beatrix-2048', "clip_g"],
|
| 75 |
+
"repo": "AbstractPhil/bert-beatrix-2048-vit-bigG-14-dual-shunt-adapter",
|
| 76 |
"shunts_available": {
|
| 77 |
"shunt_type_name": "DualStreamAdapter-G",
|
| 78 |
"config_file_name": "config.json",
|
| 79 |
"shunt_list": [
|
| 80 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e1", "file": "dual_shunt_g_laion_no_caption_e1.safetensors"},
|
| 81 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-3000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_3000.safetensors"},
|
| 82 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-5000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_5000.safetensors"},
|
| 83 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-7000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_7000.safetensors"},
|
| 84 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-10000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_10000.safetensors"},
|
| 85 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-14000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_14000.safetensors"},
|
| 86 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-20000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_20000.safetensors"},
|
| 87 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-25000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_25000.safetensors"},
|
| 88 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-30000", "file": "dual_shunt_g_booru_no_caption_noised_e1_step_30000.safetensors"},
|
| 89 |
+
{"name": "beatrix+clip_g-booru_v1_8h:noise-e1", "file": "dual_shunt_g_booru_no_caption_noised_e1_final.safetensors"},
|
| 90 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e2", "file": "dual_shunt_g_laion_no_caption_e2.safetensors"},
|
| 91 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e5", "file": "dual_shunt_g_laion_no_caption_e5.safetensors"},
|
| 92 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e8", "file": "dual_shunt_g_laion_no_caption_e8.safetensors"},
|
| 93 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e10", "file": "dual_shunt_g_laion_no_caption_e10.safetensors"},
|
| 94 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e12", "file": "dual_shunt_g_laion_no_caption_e12.safetensors"},
|
| 95 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e15", "file": "dual_shunt_g_laion_no_caption_e15.safetensors"},
|
| 96 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e16", "file": "dual_shunt_g_laion_no_caption_e16.safetensors"},
|
| 97 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e17", "file": "dual_shunt_g_laion_no_caption_e17.safetensors"},
|
| 98 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e18", "file": "dual_shunt_g_laion_no_caption_e18.safetensors"},
|
| 99 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e19", "file": "dual_shunt_g_laion_no_caption_e19.safetensors"},
|
| 100 |
+
{"name": "beatrix+clip_g-laion_v1_8h:noise-e20", "file": "dual_shunt_g_laion_no_caption_e20.safetensors"},
|
| 101 |
],
|
| 102 |
+
},
|
| 103 |
+
"config": {
|
| 104 |
+
"adapter_id": "006", "name": "DualShuntAdapter-G",
|
| 105 |
+
"condition_encoders": [{
|
| 106 |
+
"type": "t5_base",
|
| 107 |
+
"model": "AbstractPhil/bert-beatrix-2048",
|
| 108 |
+
"hidden_size": 768
|
| 109 |
+
}],
|
| 110 |
+
"modulation_encoders": [
|
| 111 |
+
{
|
| 112 |
+
"type": "clip_g",
|
| 113 |
+
"model": "laion/CLIP-ViT-bigG-14-laion2B-39B-b160k",
|
| 114 |
+
"hidden_size": 1280
|
| 115 |
+
}
|
| 116 |
+
],
|
| 117 |
+
"hidden_size": 1280, # This is the adapter's output size
|
| 118 |
+
"bottleneck": 640, "heads": 8,
|
| 119 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 120 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 121 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 122 |
+
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 123 |
+
"version": "v0.3.2"
|
| 124 |
+
},
|
| 125 |
},
|
| 126 |
+
#
|
| 127 |
+
"clip_l_4h_bert": {
|
| 128 |
+
"models": ["bert-beatrix-2048", "clip_l"],
|
| 129 |
+
"repo": "AbstractPhil/bert-beatrix-2048-vit-l-14-dual-shunt-adapter",
|
| 130 |
+
"shunts_available": {
|
| 131 |
+
"shunt_type_name": "DualStreamAdapter-L",
|
| 132 |
+
"config_file_name": "config.json",
|
| 133 |
+
"shunt_list": [
|
| 134 |
+
{"name": "beatrix+clip_l-4h:noise_5000", "file": "dual_shunt_l_booru_no_caption_noised_e1_step_5000.safetensors"},
|
| 135 |
+
{"name": "beatrix+clip_l-4h:noise_10000", "file": "dual_shunt_l_booru_no_caption_noised_e1_step_10000.safetensors"},
|
| 136 |
+
{"name": "beatrix+clip_l-4h:noise_15000", "file": "dual_shunt_l_booru_no_caption_noised_e1_step_15000.safetensors"},
|
| 137 |
+
{"name": "beatrix+clip_l-4h:noise_20000", "file": "dual_shunt_l_booru_no_caption_noised_e1_step_20000.safetensors"},
|
| 138 |
+
{"name": "beatrix+clip_l-4h:noise_25000", "file": "dual_shunt_l_booru_no_caption_noised_e1_step_25000.safetensors"},
|
| 139 |
+
],
|
| 140 |
+
},
|
| 141 |
+
"config": {
|
| 142 |
+
"adapter_id": "005",
|
| 143 |
+
"name": "DualShuntAdapter",
|
| 144 |
+
"condition_encoders": [{
|
| 145 |
+
"type": "bert_beatrix",
|
| 146 |
+
"model": "AbstractPhil/bert-beatrix-2048",
|
| 147 |
+
"hidden_size": 768
|
| 148 |
+
}],
|
| 149 |
+
"modulation_encoders": [{
|
| 150 |
+
"type": "clip_l",
|
| 151 |
+
"model": "openai/clip-vit-large-patch14",
|
| 152 |
+
"hidden_size": 768
|
| 153 |
+
}],
|
| 154 |
+
"hidden_size": 768, # This is the adapter's output size
|
| 155 |
+
"bottleneck": 384, "heads": 4,
|
| 156 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 157 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 158 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 159 |
+
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 160 |
+
"version": "v0.3.2"
|
| 161 |
+
},
|
| 162 |
+
},
|
| 163 |
+
"clip_l_4h": {
|
| 164 |
"models": ["vit-l-14", 'flan-t5-base'],
|
| 165 |
+
"repo": "AbstractPhil/t5-flan-base-vit-l-14-dual-stream-adapter",
|
| 166 |
+
"shunts_available": {
|
| 167 |
+
"shunt_type_name": "DualStreamAdapter-L",
|
| 168 |
+
"config_file_name": "config.json",
|
| 169 |
+
"shunt_list": [
|
| 170 |
+
{"name": "t5+clip_l_4h:noise_13m", "file": "t5-vit-l-14-dual_shunt_booru_13_000_000.safetensors"},
|
| 171 |
+
{"name": "t5+clip_l_4h:noise_51.2m", "file": "t5-vit-l-14-dual_shunt_booru_51_200_000.safetensors"}
|
| 172 |
+
],
|
| 173 |
+
},
|
| 174 |
+
"config": {
|
| 175 |
+
"adapter_id": "003",
|
| 176 |
+
"name": "DualShuntAdapter",
|
| 177 |
+
"condition_encoders": [{
|
| 178 |
+
"type": "t5_base",
|
| 179 |
+
"model": "google/flan-t5-base",
|
| 180 |
+
"hidden_size": 768
|
| 181 |
+
}],
|
| 182 |
+
"modulation_encoders": [{
|
| 183 |
+
"type": "clip_l",
|
| 184 |
+
"model": "openai/clip-vit-large-patch14",
|
| 185 |
+
"hidden_size": 768
|
| 186 |
+
}],
|
| 187 |
+
"hidden_size": 768, # This is the adapter's output size
|
| 188 |
+
"bottleneck": 384, "heads": 4,
|
| 189 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 190 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 191 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 192 |
+
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 193 |
+
"version": "v0.3.2"
|
| 194 |
+
},
|
| 195 |
+
},
|
| 196 |
+
"clip_l_x52": {
|
| 197 |
+
"models": ['bert-beatrix-2048', 'vit-l-14'],
|
| 198 |
+
"repo": "AbstractPhil/beatrix-x52",
|
| 199 |
+
"shunts_available": {
|
| 200 |
+
"shunt_type_name": "HarmonicBank-x52",
|
| 201 |
+
"config_file_name": "config.json",
|
| 202 |
+
"shunt_list": [
|
| 203 |
+
{"name": "beatrix-x52", "file": "AbstractPhil/beatrix-x52-v0001.safetensors"},
|
| 204 |
+
]
|
| 205 |
+
},
|
| 206 |
+
"config": {
|
| 207 |
+
"adapter_id": "072",
|
| 208 |
+
"name": "DualShuntAdapter",
|
| 209 |
+
"condition_encoders": [
|
| 210 |
+
{
|
| 211 |
+
"model": "AbstractPhil/bert-beatrix-2048"
|
| 212 |
+
},
|
| 213 |
+
],
|
| 214 |
+
"modulation_encoders": [
|
| 215 |
+
{
|
| 216 |
+
"model": "openai/clip-vit-large-patch14",
|
| 217 |
+
"offset_slip": 0.0,
|
| 218 |
+
"slip_frequency": 0.27
|
| 219 |
+
},
|
| 220 |
+
{
|
| 221 |
+
"model": "AbstractPhil/clips/Omega-SIM-ViT-CLIP_L_FP32.safetensors",
|
| 222 |
+
"offset_slip": 1.0,
|
| 223 |
+
"slip_frequency": 0.27
|
| 224 |
+
},
|
| 225 |
+
{
|
| 226 |
+
"model": "AbstractPhil/clips/ComfyUI_noobxl-R9_clip_l.safetensors",
|
| 227 |
+
"offset_slip": 2.0,
|
| 228 |
+
"slip_frequency": 0.27
|
| 229 |
+
},
|
| 230 |
+
{
|
| 231 |
+
"model": "AbstractPhil/clips/SIM-VPRED-Ω-73-clip_l.safetensors",
|
| 232 |
+
"offset_slip": 3.0,
|
| 233 |
+
"slip_frequency": 0.27
|
| 234 |
+
},
|
| 235 |
+
],
|
| 236 |
+
"hidden_size": 768, # This is the adapter's output size
|
| 237 |
+
"resonant_heads": 2000, # number of resonant heads to distribute across the shunts
|
| 238 |
+
"spin": 0.5, # the spin factor that this shunt was trained on
|
| 239 |
+
"conv_frequency": 0.29152, # the differentiation frequency of each rope layered phase
|
| 240 |
+
"conv_layers": 52000, # number of convolutional layers
|
| 241 |
+
"use_bottleneck": False, # bottleneck can be enabled for a much more expensive overhead
|
| 242 |
+
"bottleneck": 32, # This is the bottleneck dim size per shunt if used
|
| 243 |
+
"heads": 2, # number of heads per shunt if bottleneck enabled eg 104,000 heads total which is a shitload
|
| 244 |
+
"max_guidance": 10.0,
|
| 245 |
+
"tau_init": 0.1,
|
| 246 |
+
"proj_layers": 16,
|
| 247 |
+
"layer_norm": True,
|
| 248 |
+
"dropout": 0.0,
|
| 249 |
+
"use_dropout": False,
|
| 250 |
+
"use_proj_stack": True,
|
| 251 |
+
"assert_input_dims": True,
|
| 252 |
+
"routing": {
|
| 253 |
+
"type": "phase_gate",
|
| 254 |
+
"math": "tau",
|
| 255 |
+
"rope_phase_offset": 0.0,
|
| 256 |
+
"omnidirectional": False,
|
| 257 |
+
"loosely_coupled": True,
|
| 258 |
+
},
|
| 259 |
+
"version": "v2.0.0",
|
| 260 |
+
|
| 261 |
+
},
|
| 262 |
+
},
|
| 263 |
+
"clip_l": {
|
| 264 |
+
"models": ['flan-t5-base', "vit-l-14"],
|
| 265 |
+
"repo": "AbstractPhil/t5-flan-base-vit-l-14-dual-stream-adapter",
|
| 266 |
"config": {
|
| 267 |
"adapter_id": "002",
|
| 268 |
"name": "DualShuntAdapter",
|
| 269 |
+
"condition_encoders": [{
|
| 270 |
+
"type": "t5_base",
|
| 271 |
+
"model": "google/flan-t5-base",
|
| 272 |
+
"hidden_size": 768
|
| 273 |
+
}],
|
| 274 |
+
"modulation_encoders": [{
|
| 275 |
+
"type": "clip_l",
|
| 276 |
+
"model": "openai/clip-vit-large-patch14",
|
| 277 |
+
"hidden_size": 768
|
| 278 |
+
}],
|
| 279 |
"hidden_size": 768, # This is the adapter's output size
|
| 280 |
"bottleneck": 384, "heads": 12,
|
| 281 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 282 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 283 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 284 |
+
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 285 |
+
"version": "v0.3.2"
|
| 286 |
+
},
|
| 287 |
+
"shunts_available": {
|
| 288 |
+
"shunt_type_name": "DualStreamAdapter-L",
|
| 289 |
+
"config_file_name": "config.json",
|
| 290 |
+
"shunt_list": [
|
| 291 |
+
{"name": "t5+clip_l_12h:caption-20m", "file": "t5-vit-l-14-dual_shunt_caption.safetensors" },
|
| 292 |
+
{"name": "t5+clip_l_12h:noise-20m", "file": "t5-vit-l-14-dual_shunt_no_caption.safetensors" },
|
| 293 |
+
{"name": "t5+clip_l_12h:summarize-20m", "file": "t5-vit-l-14-dual_shunt_summarize.safetensors" },
|
| 294 |
+
],
|
| 295 |
+
},
|
| 296 |
+
},
|
| 297 |
+
#AbstractPhil/bert-beatrix-2048-noobxl-epsilon-v11-dual-shunt-adapter_clip_g
|
| 298 |
+
"clip_g_noob": {
|
| 299 |
+
"models": ['bert-beatrix-2048', "clip_g"],
|
| 300 |
+
"repo": "AbstractPhil/bert-beatrix-2048-noobxl-epsilon-v11-dual-shunt-adapter_clip_g",
|
| 301 |
+
"config": {
|
| 302 |
+
"adapter_id": "006",
|
| 303 |
+
"name": "DualShuntAdapter",
|
| 304 |
+
"condition_encoders": [{
|
| 305 |
+
"type": "bert_beatrix",
|
| 306 |
+
"model": "AbstractPhil/bert-beatrix-2048",
|
| 307 |
+
"hidden_size": 768
|
| 308 |
+
}],
|
| 309 |
+
"modulation_encoders": [{
|
| 310 |
+
"type": "clip_g",
|
| 311 |
+
"model": "AbstractPhil/clips/NAI-11-epsilon_clip_g.safetensors",
|
| 312 |
+
"hidden_size": 1280
|
| 313 |
+
}],
|
| 314 |
+
"hidden_size": 1280, # This is the adapter's output size
|
| 315 |
+
"bottleneck": 640, "heads": 8,
|
| 316 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 317 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 318 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 319 |
+
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 320 |
+
"version": "v0.3.2"
|
| 321 |
+
},
|
| 322 |
+
"shunts_available": {
|
| 323 |
+
"shunt_type_name": "DualStreamAdapter-G",
|
| 324 |
+
"config_file_name": "config.json",
|
| 325 |
+
"shunt_list": [
|
| 326 |
+
{"name": "beatrix+noob_g_8h:noised-1000", "file": "dual_shunt_g_noob_no_caption_e1_step_1000.safetensors"},
|
| 327 |
+
{"name": "beatrix+noob_g_8h:noised-2000", "file": "dual_shunt_g_noob_no_caption_e1_step_2000.safetensors"},
|
| 328 |
+
{"name": "beatrix+noob_g_8h:noised-3000", "file": "dual_shunt_g_noob_no_caption_e1_step_3000.safetensors"},
|
| 329 |
+
{"name": "beatrix+noob_g_8h:noised-4000", "file": "dual_shunt_g_noob_no_caption_e1_step_4000.safetensors"},
|
| 330 |
+
{"name": "beatrix+noob_g_8h:noised-5000", "file": "dual_shunt_g_noob_no_caption_e1_step_5000.safetensors"},
|
| 331 |
+
{"name": "beatrix+noob_g_8h:noised-6000", "file": "dual_shunt_g_noob_no_caption_e1_step_6000.safetensors"},
|
| 332 |
+
{"name": "beatrix+noob_g_8h:noised-7000", "file": "dual_shunt_g_noob_no_caption_e1_step_7000.safetensors"},
|
| 333 |
+
{"name": "beatrix+noob_g_8h:noised-8000", "file": "dual_shunt_g_noob_no_caption_e1_step_8000.safetensors"},
|
| 334 |
+
]
|
| 335 |
+
},
|
| 336 |
+
},
|
| 337 |
+
|
| 338 |
+
|
| 339 |
+
"clip_l_noob": {
|
| 340 |
+
"models": ['bert-beatrix-2048', "vit-l-14"],
|
| 341 |
+
"repo": "AbstractPhil/bert-beatrix-2048-noobxl-epsilon-v11-dual-shunt-adapter",
|
| 342 |
+
"config": {
|
| 343 |
+
"adapter_id": "002",
|
| 344 |
+
"name": "DualShuntAdapter",
|
| 345 |
+
"condition_encoders": [{
|
| 346 |
+
"type": "bert_beatrix",
|
| 347 |
+
"model": "AbstractPhil/bert-beatrix-2048",
|
| 348 |
+
"hidden_size": 768
|
| 349 |
+
}],
|
| 350 |
+
"modulation_encoders": [{
|
| 351 |
+
"type": "clip_l",
|
| 352 |
+
"model": "AbstractPhil/clips/NAI-11-epsilon_clip_l.safetensors",
|
| 353 |
+
"hidden_size": 768
|
| 354 |
+
}],
|
| 355 |
+
"hidden_size": 768, # This is the adapter's output size
|
| 356 |
+
"bottleneck": 384, "heads": 4,
|
| 357 |
+
"max_guidance": 10.0, "tau_init": 0.1,
|
| 358 |
+
"proj_layers": 2, "layer_norm": True, "dropout": 0.0,
|
| 359 |
+
"use_dropout": False, "use_proj_stack": True, "assert_input_dims": True,
|
| 360 |
"routing": {"type": "cross_attention", "enable_causal_mask": False, "bidirectional": True},
|
| 361 |
"version": "v0.3.2"
|
| 362 |
},
|
|
|
|
| 363 |
"shunts_available": {
|
| 364 |
"shunt_type_name": "DualStreamAdapter-L",
|
| 365 |
"config_file_name": "config.json",
|
| 366 |
"shunt_list": [
|
| 367 |
+
{"name": "beatrix+noob_l_4h:noise-5000", "file": "beatrix_dual_shunt_l_noob_e1_step_5000.safetensors"},
|
| 368 |
+
{"name": "beatrix+noob_l_4h:noise-10000", "file": "beatrix_dual_shunt_l_noob_e1_step_10000.safetensors"},
|
| 369 |
+
{"name": "beatrix+noob_l_4h:noise-15000", "file": "beatrix_dual_shunt_l_noob_e1_step_15000.safetensors"},
|
| 370 |
+
{"name": "beatrix+noob_l_4h:noise-20000", "file": "beatrix_dual_shunt_l_noob_e1_step_20000.safetensors"},
|
| 371 |
+
{"name": "beatrix+noob_l_4h:noise-25000", "file": "beatrix_dual_shunt_l_noob_e1_step_25000.safetensors"},
|
| 372 |
+
{"name": "beatrix+noob_l_4h:noise-30000", "file": "beatrix_dual_shunt_l_noob_e1_step_30000.safetensors"},
|
| 373 |
+
{"name": "beatrix+noob_l_4h:noise-35000", "file": "beatrix_dual_shunt_l_noob_e1_step_35000.safetensors"},
|
| 374 |
+
{"name": "beatrix+noob_l_4h:noise-40000", "file": "beatrix_dual_shunt_l_noob_e1_step_40000.safetensors"},
|
| 375 |
+
{"name": "beatrix+noob_l_4h:noise-45000", "file": "beatrix_dual_shunt_l_noob_e1_step_45000.safetensors"},
|
| 376 |
+
{"name": "beatrix+noob_l_4h:noise-50000", "file": "beatrix_dual_shunt_l_noob_e1_step_50000.safetensors"},
|
| 377 |
+
{"name": "beatrix+noob_l_4h:noise-55000", "file": "beatrix_dual_shunt_l_noob_e1_step_55000.safetensors"},
|
| 378 |
+
{"name": "beatrix+noob_l_4h:noise-60000", "file": "beatrix_dual_shunt_l_noob_e1_step_60000.safetensors"},
|
| 379 |
+
{"name": "beatrix+noob_l_4h:noise-65000", "file": "beatrix_dual_shunt_l_noob_e1_step_65000.safetensors"},
|
| 380 |
+
{"name": "beatrix+noob_l_4h:noise-70000", "file": "beatrix_dual_shunt_l_noob_e1_step_70000.safetensors"},
|
| 381 |
+
{"name": "beatrix+noob_l_4h:noise-75000", "file": "beatrix_dual_shunt_l_noob_e1_step_75000.safetensors"},
|
| 382 |
+
{"name": "beatrix+noob_l_4h:noise-80000", "file": "beatrix_dual_shunt_l_noob_e1_step_80000.safetensors"},
|
| 383 |
+
{"name": "beatrix+noob_l_4h:noise-85000", "file": "beatrix_dual_shunt_l_noob_e1_step_85000.safetensors"},
|
| 384 |
+
{"name": "beatrix+noob_l_4h:noise-90000", "file": "beatrix_dual_shunt_l_noob_e1_step_90000.safetensors"},
|
| 385 |
+
{"name": "beatrix+noob_l_4h:noise-100000", "file": "beatrix_dual_shunt_l_noob_e1_step_100000.safetensors"},
|
| 386 |
+
{"name": "beatrix+noob_l_4h:noise-120000", "file": "beatrix_dual_shunt_l_noob_e1_step_120000.safetensors"},
|
| 387 |
+
{"name": "beatrix+noob_l_4h:noise-140000", "file": "beatrix_dual_shunt_l_noob_e1_step_140000.safetensors"},
|
| 388 |
+
{"name": "beatrix+noob_l_4h:noise-150000", "file": "beatrix_dual_shunt_l_noob_e1_step_150000.safetensors"},
|
| 389 |
+
{"name": "beatrix+noob_l_4h:noise-160000", "file": "beatrix_dual_shunt_l_noob_e1_step_160000.safetensors"},
|
| 390 |
+
{"name": "beatrix+noob_l_4h:noise-180000", "file": "beatrix_dual_shunt_l_noob_e1_step_180000.safetensors"},
|
| 391 |
+
{"name": "beatrix+noob_l_4h:noise-200000", "file": "beatrix_dual_shunt_l_noob_e1_step_200000.safetensors"},
|
| 392 |
+
{"name": "beatrix+noob_l_4h:noise-225000", "file": "beatrix_dual_shunt_l_noob_e1_step_225000.safetensors"},
|
| 393 |
+
{"name": "beatrix+noob_l_4h:noise-250000", "file": "beatrix_dual_shunt_l_noob_e1_step_250000.safetensors"},
|
| 394 |
+
{"name": "beatrix+noob_l_4h:noise-275000", "file": "beatrix_dual_shunt_l_noob_e1_step_275000.safetensors"},
|
| 395 |
+
{"name": "beatrix+noob_l_4h:noise-300000", "file": "beatrix_dual_shunt_l_noob_e1_step_300000.safetensors"},
|
| 396 |
+
{"name": "beatrix+noob_l_4h:noise-310000", "file": "beatrix_dual_shunt_l_noob_e1_step_310000.safetensors"},
|
| 397 |
+
{"name": "beatrix+noob_l_4h:noise-314000", "file": "beatrix_dual_shunt_l_noob_e1_step_314000.safetensors"},
|
| 398 |
],
|
| 399 |
},
|
| 400 |
}
|
|
|
|
| 402 |
|
| 403 |
# ─── Adapter Configs ─────────────────────────────────────────────
|
| 404 |
|
| 405 |
+
ENCODER_CONFIGS = {
|
| 406 |
+
"bert-beatrix-2048": {
|
| 407 |
+
"repo_name": "AbstractPhil/bert-beatrix-2048",
|
| 408 |
+
"name": "bert-beatrix-2048",
|
| 409 |
+
"type": "nomic_bert",
|
| 410 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 411 |
+
"use_remote_code": True,
|
| 412 |
+
"subfolder": "",
|
| 413 |
+
},
|
| 414 |
+
"nomic-bert-2048": {
|
| 415 |
+
"repo_name": "nomic-ai/nomic-bert-2048",
|
| 416 |
+
"name": "nomic-bert-2048",
|
| 417 |
+
"type": "nomic_bert",
|
| 418 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 419 |
+
"use_remote_code": True,
|
| 420 |
+
"subfolder": "",
|
| 421 |
+
},
|
| 422 |
"mobilebert-base-uncased": {
|
| 423 |
"repo_name": "google/mobilebert-uncased",
|
| 424 |
+
"name": "mobilebert-base-uncased",
|
| 425 |
+
"type": "mobilebert",
|
| 426 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 427 |
"subfolder": "",
|
| 428 |
},
|
| 429 |
"bert-base-uncased": {
|
| 430 |
"repo_name": "bert-base-uncased",
|
| 431 |
+
"name": "bert-base-uncased",
|
| 432 |
+
"type": "bert",
|
| 433 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 434 |
},
|
| 435 |
"bert-large-uncased": {
|
| 436 |
"repo_name": "bert-large-uncased",
|
| 437 |
+
"name": "bert-large-uncased",
|
| 438 |
+
"type": "bert",
|
| 439 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 440 |
},
|
| 441 |
"bert-base-cased": {
|
| 442 |
"repo_name": "bert-base-cased",
|
| 443 |
+
"name": "bert-base-cased",
|
| 444 |
+
"type": "bert",
|
| 445 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 446 |
+
},
|
| 447 |
+
"bert-large-cased": {
|
| 448 |
+
"repo_name": "google-bert/bert-large-cased",
|
| 449 |
+
"name": "bert-large-cased",
|
| 450 |
+
"type": "bert",
|
| 451 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 452 |
+
},
|
| 453 |
+
"bert-base-multilingual-cased": {
|
| 454 |
+
"repo_name": "google-bert/bert-base-multilingual-cased",
|
| 455 |
+
"name": "bert-base-multilingual-cased",
|
| 456 |
+
"type": "bert",
|
| 457 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 458 |
+
},
|
| 459 |
+
"t5xxl": {
|
| 460 |
+
"repo_name": "google/t5-xxl-lm-adapt",
|
| 461 |
+
"name": "t5-xxl",
|
| 462 |
+
"type": "t5",
|
| 463 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 464 |
+
"subfolder": "",
|
| 465 |
+
},
|
| 466 |
+
"distill-t5-base-4096": {
|
| 467 |
+
"repo_name": "LifuWang/DistillT5",
|
| 468 |
+
"name": "distill-t5-base-4096",
|
| 469 |
+
"type": "t5_encoder_with_projection",
|
| 470 |
+
"tokenizer": "t5_override", # only required if the tokenizer is missing from the model repo
|
| 471 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 472 |
+
"subfolder": "",
|
| 473 |
+
},
|
| 474 |
+
"distill-t5-small-4096": {
|
| 475 |
+
"repo_name": "LifuWang/DistillT5-Small",
|
| 476 |
+
"name": "distill-t5-small-4096",
|
| 477 |
+
"type": "t5_encoder_with_projection",
|
| 478 |
+
"tokenizer": "t5_override", # only required if the tokenizer is missing from the model repo
|
| 479 |
+
"use_huggingface": True,
|
| 480 |
+
# defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 481 |
+
"subfolder": "",
|
| 482 |
+
},
|
| 483 |
+
"distill-t5-large-4096": {
|
| 484 |
+
"repo_name": "LifuWang/DistillT5-Large",
|
| 485 |
+
"name": "distill-t5-large-4096",
|
| 486 |
+
"type": "t5_encoder_with_projection",
|
| 487 |
+
"tokenizer": "t5_override", # only required if the tokenizer is missing from the model repo
|
| 488 |
+
"use_huggingface": True,
|
| 489 |
+
# defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 490 |
+
"subfolder": "",
|
| 491 |
+
},
|
| 492 |
|
| 493 |
+
"t5xxl-unchained": {
|
| 494 |
+
"repo_name": "AbstractPhil/t5xxl-unchained",
|
| 495 |
+
"name": "t5xxl-unchained-f16",
|
| 496 |
+
"type": "t5",
|
| 497 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 498 |
+
"subfolder": "",
|
| 499 |
+
#"tokenizer": "t5-unchained",
|
| 500 |
+
"file_name": "t5xxl-unchained-f16.safetensors",
|
| 501 |
+
"config": {
|
| 502 |
+
"config_file_name": "config.json",
|
| 503 |
+
"architectures": [
|
| 504 |
+
"T5ForConditionalGeneration"
|
| 505 |
+
],
|
| 506 |
+
"attention_dropout": 0.0,
|
| 507 |
+
"classifier_dropout": 0.0,
|
| 508 |
+
|
| 509 |
+
"d_ff": 10240,
|
| 510 |
+
"d_kv": 64,
|
| 511 |
+
"d_model": 4096,
|
| 512 |
+
"decoder_start_token_id": 0,
|
| 513 |
+
"dropout_rate": 0.0,
|
| 514 |
+
"eos_token_id": 1,
|
| 515 |
+
"dense_act_fn": "gelu_pytorch_tanh",
|
| 516 |
+
"initializer_factor": 1.0,
|
| 517 |
+
"is_encoder_decoder": True,
|
| 518 |
+
"is_gated_act": True,
|
| 519 |
+
"layer_norm_epsilon": 1e-06,
|
| 520 |
+
"model_type": "t5",
|
| 521 |
+
"num_decoder_layers": 24,
|
| 522 |
+
"num_heads": 64,
|
| 523 |
+
"num_layers": 24,
|
| 524 |
+
"output_past": True,
|
| 525 |
+
"pad_token_id": 0,
|
| 526 |
+
"relative_attention_num_buckets": 32,
|
| 527 |
+
"tie_word_embeddings": False,
|
| 528 |
+
"vocab_size": 69328,
|
| 529 |
+
}
|
| 530 |
+
},
|
| 531 |
+
"flan-t5-small": {
|
| 532 |
+
"repo_name": "google/flan-t5-small",
|
| 533 |
+
"name": "flan-t5-small",
|
| 534 |
+
"type": "t5",
|
| 535 |
+
"use_huggingface": True,
|
| 536 |
+
# defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 537 |
+
},
|
| 538 |
"flan-t5-base": {
|
| 539 |
"repo_name": "google/flan-t5-base",
|
| 540 |
+
"name": "flan-t5-base",
|
| 541 |
+
"type": "t5",
|
| 542 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 543 |
+
},
|
| 544 |
+
"flan-t5-large": {
|
| 545 |
+
"repo_name": "google/flan-t5-large",
|
| 546 |
+
"name": "flan-t5-large",
|
| 547 |
+
"type": "t5",
|
| 548 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 549 |
+
},
|
| 550 |
+
"flan-t5-xl": {
|
| 551 |
+
"repo_name": "google/flan-t5-xl",
|
| 552 |
+
"name": "flan-t5-xl",
|
| 553 |
+
"type": "t5",
|
| 554 |
+
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 555 |
+
},
|
| 556 |
+
"flan-t5-xxl": {
|
| 557 |
+
"repo_name": "google/flan-t5-xxl",
|
| 558 |
+
"name": "flan-t5-xxl",
|
| 559 |
+
"type": "t5",
|
| 560 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 561 |
},
|
| 562 |
"t5-small": {
|
| 563 |
"repo_name": "google-t5/t5-small",
|
| 564 |
+
"name": "t5-small",
|
| 565 |
+
"type": "t5",
|
| 566 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
|
|
|
| 567 |
},
|
| 568 |
"t5_small_human_attentive_try2_pass3": {
|
| 569 |
+
"repo_name": "AbstractPhil/T5-Small-Human-Attentive-Try2-Pass3",
|
| 570 |
+
"name": "t5_small_human_attentive_try2_pass3",
|
| 571 |
+
"type": "t5",
|
| 572 |
"use_huggingface": True, # defaults to simple loading from HuggingFace, if False, will use repo_name and subfolder
|
| 573 |
# the necessary config is present here for posterity in case it fails to load from HuggingFace.
|
| 574 |
"subfolder": "",
|
|
|
|
| 579 |
"architectures": [
|
| 580 |
"T5ForConditionalGeneration"
|
| 581 |
],
|
| 582 |
+
"attention_dropout": 0.0,
|
| 583 |
"classifier_dropout": 0.0,
|
| 584 |
"d_ff": 2048,
|
| 585 |
"d_kv": 64,
|
|
|
|
| 617 |
"vocab_size": 32128
|
| 618 |
}
|
| 619 |
}
|
| 620 |
+
}
|
| 621 |
+
|
| 622 |
+
|
| 623 |
+
# load these shunts in groups with types
|
| 624 |
+
GROUPED_SHUNTS = {
|
| 625 |
+
# these are automatically loaded by the simple shunt organizer
|
| 626 |
+
# for sdxl, they should have clip_l and clip_g
|
| 627 |
+
# for flux, they should have clip_l or t5xxl or t5-unchained
|
| 628 |
+
# for hidream, they can have clip_l, t5xxl, t5-unchained, or flan-t5-base, or llama - but llama isn't ready yet
|
| 629 |
+
"beatrix": {
|
| 630 |
+
"booru_sdxl_x2": [
|
| 631 |
+
# clip_l heavy using 4 head shunts
|
| 632 |
+
"beatrix+clip_l-4h:noise_25000",
|
| 633 |
+
"beatrix+clip_g-booru_v1_8h:noise-30000"
|
| 634 |
+
],
|
| 635 |
+
"noob_sdxl_x2": [
|
| 636 |
+
# clip_l heavy using 4 head shunts
|
| 637 |
+
"beatrix+noob_g_8h:noised-8000",
|
| 638 |
+
"beatrix+noob_l_4h:noise-314000",
|
| 639 |
+
],
|
| 640 |
+
"booru_": [
|
| 641 |
+
],
|
| 642 |
+
},
|
| 643 |
+
"flan-t5-base": {
|
| 644 |
+
"booru_sdxl_12h": [
|
| 645 |
+
]
|
| 646 |
+
|
| 647 |
+
}
|
| 648 |
+
|
| 649 |
+
}
|
| 650 |
+
|
| 651 |
+
|
| 652 |
+
|
| 653 |
+
SHUNT_DATAS: list[ShuntData] = []
|
| 654 |
+
"""
|
| 655 |
+
Populates the shunts list with available shunts from all the shunt dictionaries.
|
| 656 |
+
"""
|
| 657 |
+
|
| 658 |
+
ENCODER_DATAS: list[EncoderData] = []
|
| 659 |
+
|
| 660 |
+
|
| 661 |
+
class EncoderData:
|
| 662 |
+
"""
|
| 663 |
+
Represents an encoder configuration with its associated properties.
|
| 664 |
+
"""
|
| 665 |
+
def __init__(self,
|
| 666 |
+
name: str,
|
| 667 |
+
file: str,
|
| 668 |
+
repo: str,
|
| 669 |
+
config: dict,
|
| 670 |
+
type: Optional[str] = "t5",
|
| 671 |
+
tokenizer: Optional[str] = ""):
|
| 672 |
+
self.name = name
|
| 673 |
+
self.file = file
|
| 674 |
+
self.repo = repo
|
| 675 |
+
self.config = config
|
| 676 |
+
self.type = type
|
| 677 |
+
self.tokenizer = tokenizer
|
| 678 |
+
|
| 679 |
+
for encoder_dict in ENCODER_CONFIGS.values():
|
| 680 |
+
if "repo_name" in encoder_dict:
|
| 681 |
+
repo_name = encoder_dict["repo_name"]
|
| 682 |
+
file_name = encoder_dict.get("file_name", "")
|
| 683 |
+
# populate the encoders list with a reference to the encoder dictionary
|
| 684 |
+
ENCODER_DATAS.append(EncoderData(
|
| 685 |
+
name=encoder_dict["name"],
|
| 686 |
+
file=file_name,
|
| 687 |
+
repo=repo_name, # repo_name is the HuggingFace repo name
|
| 688 |
+
tokenizer=encoder_dict.get("tokenizer", ""), # empty means use the default repo tokenizer, none found fails
|
| 689 |
+
config=encoder_dict.get("config", {}),
|
| 690 |
+
type=encoder_dict.get("type", "unknown")
|
| 691 |
+
))
|
| 692 |
+
|
| 693 |
+
class ShuntData:
|
| 694 |
+
"""
|
| 695 |
+
Represents a shunt configuration with its associated properties.
|
| 696 |
+
"""
|
| 697 |
+
|
| 698 |
+
def __init__(self, name: str, file: str, repo: str, config: dict, expected: list[str], modulation_encoders: list[dict], condition_encoders: list[dict], shunt_type_name: str, config_file_name: str):
|
| 699 |
+
self.name = name
|
| 700 |
+
self.file = file
|
| 701 |
+
self.repo = repo
|
| 702 |
+
self.config = config
|
| 703 |
+
self.expected = expected
|
| 704 |
+
self.modulation_encoders = modulation_encoders
|
| 705 |
+
self.condition_encoders = condition_encoders
|
| 706 |
+
self.shunt_type_name = shunt_type_name
|
| 707 |
+
self.config_file_name = config_file_name
|
| 708 |
+
|
| 709 |
+
|
| 710 |
+
for shunt_dict in HARMONIC_SHUNT_REPOS.values():
|
| 711 |
+
if "shunts_available" in shunt_dict:
|
| 712 |
+
shunts = shunt_dict["shunts_available"]["shunt_list"]
|
| 713 |
+
for shunt in shunts:
|
| 714 |
+
name, file_name = shunt.get("name"), shunt.get("file")
|
| 715 |
+
# populate the shunts list with a reference to the shunt dictionary
|
| 716 |
+
SHUNT_DATAS.append(ShuntData(
|
| 717 |
+
name=name,
|
| 718 |
+
file=file_name,
|
| 719 |
+
repo=shunt_dict["repo"],
|
| 720 |
+
config=shunt_dict["config"],
|
| 721 |
+
expected=shunt_dict["models"],
|
| 722 |
+
modulation_encoders=shunt_dict["config"]["modulation_encoders"],
|
| 723 |
+
condition_encoders=shunt_dict["config"]["condition_encoders"],
|
| 724 |
+
shunt_type_name=shunt_dict["shunts_available"]["shunt_type_name"],
|
| 725 |
+
config_file_name=shunt_dict["shunts_available"]["config_file_name"]
|
| 726 |
+
))
|
| 727 |
+
|
| 728 |
+
|
| 729 |
+
|
| 730 |
+
class ShuntUtil:
|
| 731 |
+
|
| 732 |
+
@staticmethod
|
| 733 |
+
def get_encoder_by_model_name(model_name: str) -> Optional[EncoderData]:
|
| 734 |
+
"""
|
| 735 |
+
Returns the encoder configuration dictionary by its model name.
|
| 736 |
+
Args:
|
| 737 |
+
model_name (str): The name of the model to retrieve.
|
| 738 |
+
|
| 739 |
+
Returns:
|
| 740 |
+
Optional[EncoderData]: The encoder configuration dictionary if found, otherwise None.
|
| 741 |
+
"""
|
| 742 |
+
logger.info(f"Searching for encoder with model name: {model_name}")
|
| 743 |
+
logger.info(f"Available encoders: {[encoder.name for encoder in ENCODER_DATAS]}")
|
| 744 |
+
for encoder in ENCODER_DATAS:
|
| 745 |
+
logger.info(f"Checking encoder: {encoder.name} against model name: {model_name}")
|
| 746 |
+
if encoder.name == model_name:
|
| 747 |
+
return encoder
|
| 748 |
+
logger.warning(f"Encoder '{model_name}' not found.")
|
| 749 |
+
return None
|
| 750 |
+
|
| 751 |
+
@staticmethod
|
| 752 |
+
def get_encoder_repos_by_shunt_name(shunt_name: str) -> list[str]:
|
| 753 |
+
"""
|
| 754 |
+
Returns the repository name of the encoder associated with the given shunt name.
|
| 755 |
+
|
| 756 |
+
Args:
|
| 757 |
+
shunt_name (str): The name of the shunt to search for.
|
| 758 |
+
|
| 759 |
+
Returns:
|
| 760 |
+
Optional[str]: The repository name if found, otherwise None.
|
| 761 |
+
"""
|
| 762 |
+
shunt = ShuntUtil.get_shunt_by_name(shunt_name)
|
| 763 |
+
prepared = []
|
| 764 |
+
if shunt:
|
| 765 |
+
for model in shunt["expected"]:
|
| 766 |
+
if model in DEFAULT_REPOS:
|
| 767 |
+
prepared.append(DEFAULT_REPOS[model])
|
| 768 |
+
else:
|
| 769 |
+
|
| 770 |
+
logger.warning(f"Model '{model}' not found in default repositories.")
|
| 771 |
+
return prepared
|
| 772 |
+
else:
|
| 773 |
+
logger.warning(f"Shunt '{shunt_name}' not found.")
|
| 774 |
+
|
| 775 |
+
return None
|
| 776 |
+
|
| 777 |
+
@staticmethod
|
| 778 |
+
def get_shunt_by_name(name: str) -> Optional[ShuntData]:
|
| 779 |
+
"""
|
| 780 |
+
Returns the shunt configuration dictionary by its name.
|
| 781 |
+
|
| 782 |
+
Args:
|
| 783 |
+
name (str): The name of the shunt to retrieve.
|
| 784 |
+
|
| 785 |
+
Returns:
|
| 786 |
+
Optional[dict]: The shunt configuration dictionary if found, otherwise None.
|
| 787 |
+
"""
|
| 788 |
+
for shunt in SHUNT_DATAS:
|
| 789 |
+
if shunt.name == name:
|
| 790 |
+
return shunt
|
| 791 |
+
logger.warning(f"Shunt '{name}' not found.")
|
| 792 |
+
return None
|
| 793 |
+
|
| 794 |
+
@staticmethod
|
| 795 |
+
def get_shunt_names() -> list[str]:
|
| 796 |
+
"""
|
| 797 |
+
Returns a list of all available shunt names.
|
| 798 |
+
|
| 799 |
+
Returns:
|
| 800 |
+
list[str]: List of shunt names.
|
| 801 |
+
"""
|
| 802 |
+
return [shunt.name for shunt in SHUNT_DATAS]
|
| 803 |
+
|