-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtutorial_train_lora.py
More file actions
54 lines (43 loc) · 1.97 KB
/
tutorial_train_lora.py
File metadata and controls
54 lines (43 loc) · 1.97 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
from share import *
import pytorch_lightning as pl
from torch.utils.data import DataLoader
from tutorial_dataset import MyDatasetCOCO
from cldm.logger import ImageLogger
from cldm.model import create_model, load_state_dict
from pytorch_lightning.callbacks import ModelCheckpoint
import torch
torch.set_float32_matmul_precision('high')
torch.backends.cuda.matmul.allow_tf32=True
torch.backends.cudnn.allow_tf32=True
# Configs
resume_path = './pretrained/control_sd15_ini.ckpt'
batch_size = 8
logger_freq = 500
learning_rate = 5e-5
sd_locked = True
only_mid_control = False
# First use cpu to load models. Pytorch Lightning will automatically move it to GPUs.
model = create_model('./models/cldm_v15_lora.yaml').cpu()
model.load_state_dict(load_state_dict(resume_path, location='cpu'), strict=False)
model.learning_rate = learning_rate
model.sd_locked = sd_locked
model.only_mid_control = only_mid_control
train_dataset = MyDatasetCOCO(root='data/ms-coco')
val_dataset = MyDatasetCOCO(root='data/ms-coco', train=False)
train_dataloader = DataLoader(train_dataset, num_workers=16, batch_size=batch_size, shuffle=True, pin_memory=True)
val_dataloader = DataLoader(val_dataset, num_workers=16, batch_size=batch_size, shuffle=False, pin_memory=True)
logger = ImageLogger(batch_frequency=logger_freq,split='train_lora')
checkpoint_callback = ModelCheckpoint(
dirpath=f'image_log/checkpoint_lora01/',
save_top_k=-1,
save_last=True,
save_weights_only=False,
every_n_epochs=1,
)
# trainer = pl.Trainer(devices=1, precision='bf16-mixed', callbacks=[logger])
trainer = pl.Trainer(devices=1, precision=32, callbacks=[logger, checkpoint_callback], max_epochs=15)
# trainer = pl.Trainer(strategy='ddp', accelerator='gpu', devices=1, precision=32, callbacks=[logger,checkpoint_callback], accumulate_grad_batches=4)
# # Train!
trainer.fit(model, train_dataloader, val_dataloader)
# model_path = 'image_log/checkpoint_lora01/epoch=5-step=88716.ckpt'
# trainer.validate(model, val_dataloader, model_path)