Diffusers 文档
将文件推送到 Hub
并获取增强的文档体验
开始使用
将文件推送到 Hub
🤗 Diffusers 提供了一个 PushToHubMixin,用于将您的模型、scheduler 或 pipeline 上传到 Hub。这是一种在 Hub 上存储文件的简便方法,也允许您与他人分享您的工作。在底层,PushToHubMixin
- 在 Hub 上创建一个仓库
- 保存您的模型、scheduler 或 pipeline 文件,以便稍后可以重新加载
- 上传包含这些文件的文件夹到 Hub
本指南将向您展示如何使用 PushToHubMixin 将您的文件上传到 Hub。
您首先需要使用您的访问令牌登录您的 Hub 帐户
from huggingface_hub import notebook_login
notebook_login()
模型
要将模型推送到 Hub,请调用 push_to_hub() 并指定要存储在 Hub 上的模型的仓库 ID
from diffusers import ControlNetModel
controlnet = ControlNetModel(
block_out_channels=(32, 64),
layers_per_block=2,
in_channels=4,
down_block_types=("DownBlock2D", "CrossAttnDownBlock2D"),
cross_attention_dim=32,
conditioning_embedding_out_channels=(16, 32),
)
controlnet.push_to_hub("my-controlnet-model")
对于模型,您还可以指定要推送到 Hub 的权重的 variant。例如,要推送 fp16
权重
controlnet.push_to_hub("my-controlnet-model", variant="fp16")
push_to_hub() 函数保存模型的 config.json
文件,并且权重会自动以 safetensors
格式保存。
现在您可以从 Hub 上的仓库重新加载模型
model = ControlNetModel.from_pretrained("your-namespace/my-controlnet-model")
Scheduler
要将 scheduler 推送到 Hub,请调用 push_to_hub() 并指定要存储在 Hub 上的 scheduler 的仓库 ID
from diffusers import DDIMScheduler
scheduler = DDIMScheduler(
beta_start=0.00085,
beta_end=0.012,
beta_schedule="scaled_linear",
clip_sample=False,
set_alpha_to_one=False,
)
scheduler.push_to_hub("my-controlnet-scheduler")
push_to_hub() 函数将 scheduler 的 scheduler_config.json
文件保存到指定的仓库。
现在您可以从 Hub 上的仓库重新加载 scheduler
scheduler = DDIMScheduler.from_pretrained("your-namepsace/my-controlnet-scheduler")
Pipeline
您还可以将整个 pipeline 及其所有组件推送到 Hub。例如,使用您想要的参数初始化 StableDiffusionPipeline 的组件
from diffusers import (
UNet2DConditionModel,
AutoencoderKL,
DDIMScheduler,
StableDiffusionPipeline,
)
from transformers import CLIPTextModel, CLIPTextConfig, CLIPTokenizer
unet = UNet2DConditionModel(
block_out_channels=(32, 64),
layers_per_block=2,
sample_size=32,
in_channels=4,
out_channels=4,
down_block_types=("DownBlock2D", "CrossAttnDownBlock2D"),
up_block_types=("CrossAttnUpBlock2D", "UpBlock2D"),
cross_attention_dim=32,
)
scheduler = DDIMScheduler(
beta_start=0.00085,
beta_end=0.012,
beta_schedule="scaled_linear",
clip_sample=False,
set_alpha_to_one=False,
)
vae = AutoencoderKL(
block_out_channels=[32, 64],
in_channels=3,
out_channels=3,
down_block_types=["DownEncoderBlock2D", "DownEncoderBlock2D"],
up_block_types=["UpDecoderBlock2D", "UpDecoderBlock2D"],
latent_channels=4,
)
text_encoder_config = CLIPTextConfig(
bos_token_id=0,
eos_token_id=2,
hidden_size=32,
intermediate_size=37,
layer_norm_eps=1e-05,
num_attention_heads=4,
num_hidden_layers=5,
pad_token_id=1,
vocab_size=1000,
)
text_encoder = CLIPTextModel(text_encoder_config)
tokenizer = CLIPTokenizer.from_pretrained("hf-internal-testing/tiny-random-clip")
将所有组件传递给 StableDiffusionPipeline 并调用 push_to_hub() 以将 pipeline 推送到 Hub
components = {
"unet": unet,
"scheduler": scheduler,
"vae": vae,
"text_encoder": text_encoder,
"tokenizer": tokenizer,
"safety_checker": None,
"feature_extractor": None,
}
pipeline = StableDiffusionPipeline(**components)
pipeline.push_to_hub("my-pipeline")
push_to_hub() 函数将每个组件保存到仓库的子文件夹中。现在您可以从 Hub 上的仓库重新加载 pipeline
pipeline = StableDiffusionPipeline.from_pretrained("your-namespace/my-pipeline")
隐私
在 push_to_hub() 函数中设置 private=True
以使您的模型、scheduler 或 pipeline 文件保持私有
controlnet.push_to_hub("my-controlnet-model-private", private=True)
私有仓库仅对您可见,其他用户将无法克隆该仓库,并且您的仓库不会出现在搜索结果中。即使用户拥有您的私有仓库的 URL,他们也会收到 404 - 抱歉,我们找不到您要查找的页面
。您必须登录才能从私有仓库加载模型。