-
Notifications
You must be signed in to change notification settings - Fork 12
Expand file tree
/
Copy pathdfloat11_model_loader.py
More file actions
81 lines (66 loc) · 2.47 KB
/
dfloat11_model_loader.py
File metadata and controls
81 lines (66 loc) · 2.47 KB
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
import comfy
import folder_paths
import torch
from dfloat11 import DFloat11Model
class DFloat11ModelLoader:
"""
A custom node to load a DFloat11 diffusion model from the `diffusion_models` directory.
DFloat11 models are >30% smaller than their float16 counterparts, yet produce bit-for-bit identical outputs.
"""
MODEL_TO_PATTERN_DICT = {
"Flux": {
"double_blocks\.\d+": (
"img_mod.lin",
"img_attn.qkv",
"img_attn.proj",
"img_mlp.0",
"img_mlp.2",
"txt_mod.lin",
"txt_attn.qkv",
"txt_attn.proj",
"txt_mlp.0",
"txt_mlp.2",
),
"single_blocks\.\d+": (
"linear1",
"linear2",
"modulation.lin",
),
},
}
@classmethod
def INPUT_TYPES(cls):
return {
"required": {
"dfloat11_model_name": (folder_paths.get_filename_list("diffusion_models"),),
}
}
RETURN_TYPES = ("MODEL",)
FUNCTION = "load_dfloat11_model"
CATEGORY = "DFloat11"
def load_dfloat11_model(self, dfloat11_model_name):
dfloat11_model_path = folder_paths.get_full_path_or_raise("diffusion_models", dfloat11_model_name)
sd = comfy.utils.load_torch_file(dfloat11_model_path)
if not any(k.endswith("encoded_exponent") for k in sd.keys()):
raise ValueError(f"The model '{dfloat11_model_name}' is not a DFloat11 model.")
load_device = comfy.model_management.get_torch_device()
offload_device = comfy.model_management.unet_offload_device()
model_config = comfy.sd.model_detection.model_config_from_unet(sd, "")
model_config.set_inference_dtype(torch.bfloat16, torch.bfloat16)
model = model_config.get_model(sd, "")
model = model.to(offload_device)
DFloat11Model.from_single_file(
dfloat11_model_path,
pattern_dict=DFloat11ModelLoader.MODEL_TO_PATTERN_DICT[type(model_config).__name__],
bfloat16_model=model.diffusion_model,
device=offload_device,
)
return (
comfy.model_patcher.ModelPatcher(model, load_device=load_device, offload_device=offload_device),
)
NODE_CLASS_MAPPINGS = {
"DFloat11ModelLoader": DFloat11ModelLoader,
}
NODE_DISPLAY_NAME_MAPPINGS = {
"DFloat11ModelLoader": "DFloat11 Model Loader",
}