2022-10-02 20:03:39 +08:00
|
|
|
import os
|
|
|
|
import numpy as np
|
|
|
|
import PIL
|
|
|
|
import torch
|
|
|
|
from PIL import Image
|
|
|
|
from torch.utils.data import Dataset
|
|
|
|
from torchvision import transforms
|
|
|
|
|
|
|
|
import random
|
|
|
|
import tqdm
|
2022-10-12 00:03:08 +08:00
|
|
|
from modules import devices, shared
|
2022-10-04 13:52:11 +08:00
|
|
|
import re
|
|
|
|
|
|
|
|
re_tag = re.compile(r"[a-zA-Z][_\w\d()]+")
|
2022-10-02 20:03:39 +08:00
|
|
|
|
|
|
|
|
|
|
|
class PersonalizedBase(Dataset):
|
2022-10-12 00:03:08 +08:00
|
|
|
def __init__(self, data_root, width, height, repeats, flip_p=0.5, placeholder_token="*", model=None, device=None, template_file=None, include_cond=False):
|
2022-10-02 20:03:39 +08:00
|
|
|
|
|
|
|
self.placeholder_token = placeholder_token
|
|
|
|
|
2022-10-10 21:35:35 +08:00
|
|
|
self.width = width
|
|
|
|
self.height = height
|
2022-10-02 20:03:39 +08:00
|
|
|
self.flip = transforms.RandomHorizontalFlip(p=flip_p)
|
|
|
|
|
|
|
|
self.dataset = []
|
|
|
|
|
|
|
|
with open(template_file, "r") as file:
|
|
|
|
lines = [x.strip() for x in file.readlines()]
|
|
|
|
|
|
|
|
self.lines = lines
|
|
|
|
|
|
|
|
assert data_root, 'dataset directory not specified'
|
|
|
|
|
2022-10-12 00:03:08 +08:00
|
|
|
cond_model = shared.sd_model.cond_stage_model
|
|
|
|
|
2022-10-11 16:32:46 +08:00
|
|
|
self.image_paths = [os.path.join(data_root, file_path) for file_path in os.listdir(data_root)]
|
2022-10-02 20:03:39 +08:00
|
|
|
print("Preparing dataset...")
|
|
|
|
for path in tqdm.tqdm(self.image_paths):
|
2022-10-11 16:32:46 +08:00
|
|
|
try:
|
|
|
|
image = Image.open(path).convert('RGB').resize((self.width, self.height), PIL.Image.BICUBIC)
|
|
|
|
except Exception:
|
|
|
|
continue
|
2022-10-02 20:03:39 +08:00
|
|
|
|
|
|
|
filename = os.path.basename(path)
|
2022-10-04 13:52:11 +08:00
|
|
|
filename_tokens = os.path.splitext(filename)[0]
|
|
|
|
filename_tokens = re_tag.findall(filename_tokens)
|
2022-10-02 20:03:39 +08:00
|
|
|
|
|
|
|
npimage = np.array(image).astype(np.uint8)
|
|
|
|
npimage = (npimage / 127.5 - 1.0).astype(np.float32)
|
|
|
|
|
|
|
|
torchdata = torch.from_numpy(npimage).to(device=device, dtype=torch.float32)
|
|
|
|
torchdata = torch.moveaxis(torchdata, 2, 0)
|
|
|
|
|
|
|
|
init_latent = model.get_first_stage_encoding(model.encode_first_stage(torchdata.unsqueeze(dim=0))).squeeze()
|
2022-10-03 03:59:01 +08:00
|
|
|
init_latent = init_latent.to(devices.cpu)
|
2022-10-02 20:03:39 +08:00
|
|
|
|
2022-10-12 00:03:08 +08:00
|
|
|
if include_cond:
|
|
|
|
text = self.create_text(filename_tokens)
|
|
|
|
cond = cond_model([text]).to(devices.cpu)
|
|
|
|
else:
|
|
|
|
cond = None
|
|
|
|
|
|
|
|
self.dataset.append((init_latent, filename_tokens, cond))
|
2022-10-02 20:03:39 +08:00
|
|
|
|
|
|
|
self.length = len(self.dataset) * repeats
|
|
|
|
|
|
|
|
self.initial_indexes = np.arange(self.length) % len(self.dataset)
|
|
|
|
self.indexes = None
|
|
|
|
self.shuffle()
|
|
|
|
|
|
|
|
def shuffle(self):
|
|
|
|
self.indexes = self.initial_indexes[torch.randperm(self.initial_indexes.shape[0])]
|
|
|
|
|
2022-10-12 00:03:08 +08:00
|
|
|
def create_text(self, filename_tokens):
|
|
|
|
text = random.choice(self.lines)
|
|
|
|
text = text.replace("[name]", self.placeholder_token)
|
|
|
|
text = text.replace("[filewords]", ' '.join(filename_tokens))
|
|
|
|
return text
|
|
|
|
|
2022-10-02 20:03:39 +08:00
|
|
|
def __len__(self):
|
|
|
|
return self.length
|
|
|
|
|
|
|
|
def __getitem__(self, i):
|
|
|
|
if i % len(self.dataset) == 0:
|
|
|
|
self.shuffle()
|
|
|
|
|
|
|
|
index = self.indexes[i % len(self.indexes)]
|
2022-10-12 00:03:08 +08:00
|
|
|
x, filename_tokens, cond = self.dataset[index]
|
2022-10-02 20:03:39 +08:00
|
|
|
|
2022-10-12 00:03:08 +08:00
|
|
|
text = self.create_text(filename_tokens)
|
|
|
|
return x, text, cond
|