test_checkpoint.py 1.2 KB
Newer Older
1
import torch
2
3
import yaml
from diffusers import StableDiffusionPipeline
natalie_cao's avatar
natalie_cao committed
4
from ldm.modules.diffusionmodules.openaimodel import UNetModel
5

6
7
8
if __name__ == "__main__":
    with torch.no_grad():
        yaml_path = "../../train_colossalai.yaml"
9
        with open(yaml_path, "r", encoding="utf-8") as f:
10
11
            config = f.read()
        base_config = yaml.load(config, Loader=yaml.FullLoader)
12
        unet_config = base_config["model"]["params"]["unet_config"]
natalie_cao's avatar
natalie_cao committed
13
        diffusion_model = UNetModel(**unet_config).to("cuda:0")
14

15
        pipe = StableDiffusionPipeline.from_pretrained("/data/scratch/diffuser/stable-diffusion-v1-4").to("cuda:0")
16
17
18
19
20
21
22
23
24
25
26
27
        dif_model_2 = pipe.unet

        random_input_ = torch.rand((4, 4, 32, 32)).to("cuda:0")
        random_input_2 = torch.clone(random_input_).to("cuda:0")
        time_stamp = torch.randint(20, (4,)).to("cuda:0")
        time_stamp2 = torch.clone(time_stamp).to("cuda:0")
        context_ = torch.rand((4, 77, 768)).to("cuda:0")
        context_2 = torch.clone(context_).to("cuda:0")

        out_1 = diffusion_model(random_input_, time_stamp, context_)
        out_2 = dif_model_2(random_input_2, time_stamp2, context_2)
        print(out_1.shape)
28
        print(out_2["sample"].shape)