211 lines
12 KiB
TypeScript
211 lines
12 KiB
TypeScript
Schema.intersect([
|
||
Schema.intersect([
|
||
Schema.object({
|
||
model_train_type: Schema.union(["sd-dreambooth", "sdxl-finetune"]).default("sd-dreambooth").description("训练种类"),
|
||
pretrained_model_name_or_path: Schema.string().role("filepicker", { type: "model-file" }).default("./sd-models/model.safetensors").description("底模文件路径"),
|
||
resume: Schema.string().role("filepicker", { type: "folder" }).description("从某个 `save_state` 保存的中断状态继续训练,填写文件路径"),
|
||
vae: Schema.string().role("filepicker", { type: "model-file" }).description("(可选) VAE 模型文件路径,使用外置 VAE 文件覆盖模型内本身的"),
|
||
}).description("训练用模型"),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
model_train_type: Schema.const("sd-dreambooth"),
|
||
v2: Schema.boolean().default(false).description("底模为 sd2.0 以后的版本需要启用"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
model_train_type: Schema.const("sd-dreambooth"),
|
||
v2: Schema.const(true).required(),
|
||
v_parameterization: Schema.boolean().default(false).description("v-parameterization 学习"),
|
||
scale_v_pred_loss_like_noise_pred: Schema.boolean().default(false).description("缩放 v-prediction 损失(与v-parameterization配合使用)"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
]),
|
||
|
||
Schema.object({
|
||
train_data_dir: Schema.string().role("filepicker", { type: "folder" }).default("./train/aki").description("训练数据集路径"),
|
||
reg_data_dir: Schema.string().role("filepicker", { type: "folder" }).description("正则化数据集路径。默认留空,不使用正则化图像"),
|
||
prior_loss_weight: Schema.number().step(0.1).description("正则化 - 先验损失权重"),
|
||
resolution: Schema.string().default("512,512").description("训练图片分辨率,宽x高。支持非正方形,但必须是 64 倍数。"),
|
||
enable_bucket: Schema.boolean().default(true).description("启用 arb 桶以允许非固定宽高比的图片"),
|
||
min_bucket_reso: Schema.number().default(256).description("arb 桶最小分辨率"),
|
||
max_bucket_reso: Schema.number().default(1024).description("arb 桶最大分辨率"),
|
||
bucket_reso_steps: Schema.number().default(64).description("arb 桶分辨率划分单位,SDXL 可以使用 32"),
|
||
}).description("数据集设置"),
|
||
|
||
Schema.object({
|
||
output_name: Schema.string().default("aki").description("模型保存名称"),
|
||
output_dir: Schema.string().role("filepicker", { type: "folder" }).default("./output").description("模型保存文件夹"),
|
||
save_model_as: Schema.union(["safetensors", "pt", "ckpt"]).default("safetensors").description("模型保存格式"),
|
||
save_precision: Schema.union(["fp16", "float", "bf16"]).default("fp16").description("模型保存精度"),
|
||
save_every_n_epochs: Schema.number().default(2).description("每 N epoch(轮)自动保存一次模型"),
|
||
save_state: Schema.boolean().description("保存训练状态 配合 `resume` 参数可以继续从某个状态训练"),
|
||
}).description("保存设置"),
|
||
|
||
Schema.object({
|
||
max_train_epochs: Schema.number().min(1).default(10).description("最大训练 epoch(轮数)"),
|
||
train_batch_size: Schema.number().min(1).default(1).description("批量大小"),
|
||
stop_text_encoder_training: Schema.number().min(-1).description("仅 sd-dreambooth 可用。在第 N 步时,停止训练文本编码器。设置为 -1 不训练文本编码器"),
|
||
gradient_checkpointing: Schema.boolean().default(false).description("梯度检查点"),
|
||
gradient_accumulation_steps: Schema.number().min(1).description("梯度累加步数"),
|
||
}).description("训练相关参数"),
|
||
|
||
|
||
Schema.intersect([
|
||
Schema.object({
|
||
learning_rate: Schema.string().default("1e-6").description("学习率"),
|
||
}).description("学习率与优化器设置"),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
model_train_type: Schema.const("sd-dreambooth"),
|
||
learning_rate_te: Schema.string().default("5e-7").description("文本编码器学习率"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
model_train_type: Schema.const("sdxl-finetune").required(),
|
||
learning_rate_te1: Schema.string().default("5e-7").description("SDXL 文本编码器 1 (ViT-L) 学习率"),
|
||
learning_rate_te2: Schema.string().default("5e-7").description("SDXL 文本编码器 2 (BiG-G) 学习率"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
|
||
Schema.object({
|
||
lr_scheduler: Schema.union([
|
||
"linear",
|
||
"cosine",
|
||
"cosine_with_restarts",
|
||
"polynomial",
|
||
"constant",
|
||
"constant_with_warmup",
|
||
]).default("cosine_with_restarts").description("学习率调度器设置"),
|
||
lr_warmup_steps: Schema.number().default(0).description("学习率预热步数"),
|
||
}),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
lr_scheduler: Schema.const("cosine_with_restarts"),
|
||
lr_scheduler_num_cycles: Schema.number().default(1).description("重启次数"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
|
||
Schema.object({
|
||
optimizer_type: Schema.union([
|
||
"AdamW",
|
||
"AdamW8bit",
|
||
"PagedAdamW8bit",
|
||
"Lion",
|
||
"Lion8bit",
|
||
"PagedLion8bit",
|
||
"SGDNesterov",
|
||
"SGDNesterov8bit",
|
||
"DAdaptation",
|
||
"DAdaptAdam",
|
||
"DAdaptAdaGrad",
|
||
"DAdaptAdanIP",
|
||
"DAdaptLion",
|
||
"DAdaptSGD",
|
||
"AdaFactor",
|
||
"Prodigy"
|
||
]).default("AdamW8bit").description("优化器设置"),
|
||
min_snr_gamma: Schema.number().step(0.1).description("最小信噪比伽马值,如果启用推荐为 5"),
|
||
}),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
optimizer_type: Schema.const("Prodigy").required(),
|
||
prodigy_d0: Schema.string(),
|
||
prodigy_d_coef: Schema.string().default("2.0"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
|
||
Schema.object({
|
||
optimizer_args_custom: Schema.array(String).role("table").description("自定义 optimizer_args,一行一个"),
|
||
})
|
||
]),
|
||
|
||
Schema.intersect([
|
||
Schema.object({
|
||
enable_preview: Schema.boolean().default(false).description("启用训练预览图"),
|
||
}).description("训练预览图设置"),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
enable_preview: Schema.const(true).required(),
|
||
sample_prompts: Schema.string().role("textarea").default("(masterpiece, best quality:1.2), 1girl, solo, --n lowres, bad anatomy, bad hands, text, error, missing fingers, extra digit, fewer digits, cropped, worst quality, low quality, normal quality, jpeg artifacts,signature, watermark, username, blurry, --w 512 --h 768 --l 7 --s 24 --d 1337").description("预览图生成参数。`--n` 后方为反向提示词,<br>`--w`宽,`--h`高<br>`--l`: CFG Scale<br>`--s`: 迭代步数<br>`--d`: 种子"),
|
||
sample_sampler: Schema.union(["ddim", "pndm", "lms", "euler", "euler_a", "heun", "dpm_2", "dpm_2_a", "dpmsolver", "dpmsolver++", "dpmsingle", "k_lms", "k_euler", "k_euler_a", "k_dpm_2", "k_dpm_2_a"]).default("euler_a").description("生成预览图所用采样器"),
|
||
sample_every_n_epochs: Schema.number().default(2).description("每 N 个 epoch 生成一次预览图"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
]),
|
||
|
||
Schema.intersect([
|
||
Schema.object({
|
||
log_with: Schema.union(["tensorboard", "wandb"]).default("tensorboard").description("日志模块"),
|
||
log_prefix: Schema.string().description("日志前缀"),
|
||
log_tracker_name: Schema.string().description("日志追踪器名称"),
|
||
logging_dir: Schema.string().default("./logs").description("日志保存文件夹"),
|
||
}).description("日志设置"),
|
||
|
||
Schema.union([
|
||
Schema.object({
|
||
log_with: Schema.const("wandb").required(),
|
||
wandb_api_key: Schema.string().required().description("wandb 的 api 密钥"),
|
||
}),
|
||
Schema.object({}),
|
||
]),
|
||
]),
|
||
|
||
Schema.object({
|
||
caption_extension: Schema.string().default(".txt").description("Tag 文件扩展名"),
|
||
shuffle_caption: Schema.boolean().default(true).description("训练时随机打乱 tokens"),
|
||
weighted_captions: Schema.boolean().default(false).description("使用带权重的 token,不推荐与 shuffle_caption 一同开启"),
|
||
keep_tokens: Schema.number().min(0).max(255).step(1).default(0).description("在随机打乱 tokens 时,保留前 N 个不变"),
|
||
keep_tokens_separator: Schema.string().description("保留 tokens 时使用的分隔符"),
|
||
max_token_length: Schema.number().default(255).description("最大 token 长度"),
|
||
caption_dropout_rate: Schema.number().min(0).max(1).step(0.1).description("丢弃全部标签的概率,对一个图片概率不使用 caption 或 class token"),
|
||
caption_dropout_every_n_epochs: Schema.number().min(0).max(100).step(1).description("每 N 个 epoch 丢弃全部标签"),
|
||
caption_tag_dropout_rate: Schema.number().min(0).max(1).step(0.1).description("按逗号分隔的标签来随机丢弃 tag 的概率"),
|
||
}).description("caption(Tag)选项"),
|
||
|
||
Schema.object({
|
||
noise_offset: Schema.number().step(0.0001).description("在训练中添加噪声偏移来改良生成非常暗或者非常亮的图像,如果启用推荐为 0.1"),
|
||
multires_noise_iterations: Schema.number().step(1).description("多分辨率(金字塔)噪声迭代次数 推荐 6-10。无法与 noise_offset 一同启用"),
|
||
multires_noise_discount: Schema.number().step(0.1).description("多分辨率(金字塔)衰减率 推荐 0.3-0.8,须同时与上方参数 multires_noise_iterations 一同启用"),
|
||
}).description("噪声设置"),
|
||
|
||
Schema.object({
|
||
seed: Schema.number().default(1337).description("随机种子"),
|
||
clip_skip: Schema.number().role("slider").min(0).max(12).step(1).default(2).description("CLIP 跳过层数 *玄学*"),
|
||
no_token_padding: Schema.boolean().default(false).description("禁用 token 填充(与 Diffusers 的旧 Dreambooth 脚本一致)"),
|
||
}).description("高级设置"),
|
||
|
||
Schema.object({
|
||
mixed_precision: Schema.union(["no", "fp16", "bf16"]).default("fp16").description("训练混合精度"),
|
||
full_fp16: Schema.boolean().description("完全使用 FP16 精度"),
|
||
full_bf16: Schema.boolean().description("完全使用 BF16 精度 仅支持 SDXL"),
|
||
xformers: Schema.boolean().default(true).description("启用 xformers"),
|
||
sdpa: Schema.boolean().description("启用 sdpa"),
|
||
lowram: Schema.boolean().default(false).description("低内存模式 该模式下会将 U-net、文本编码器、VAE 直接加载到显存中"),
|
||
cache_latents: Schema.boolean().default(true).description("缓存图像 latent"),
|
||
cache_latents_to_disk: Schema.boolean().default(true).description("缓存图像 latent 到磁盘"),
|
||
persistent_data_loader_workers: Schema.boolean().default(true).description("保留加载训练集的worker,减少每个 epoch 之间的停顿。"),
|
||
vae_batch_size: Schema.number().min(1).description("vae 编码批量大小"),
|
||
}).description("速度优化选项"),
|
||
|
||
Schema.object({
|
||
ddp_timeout: Schema.number().min(0).description("分布式训练超时时间"),
|
||
ddp_gradient_as_bucket_view: Schema.boolean(),
|
||
}).description("分布式训练"),
|
||
]);
|