-
Notifications
You must be signed in to change notification settings - Fork 1
/
image_from_text.py
110 lines (99 loc) · 2.97 KB
/
image_from_text.py
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#import argparse
import discord
from discord.ext import commands
import os
from PIL import Image
from min_dalle import MinDalle
import torch
'''
parser = argparse.ArgumentParser()
parser.add_argument('--mega', action='store_true')
parser.add_argument('--no-mega', dest='mega', action='store_false')
parser.set_defaults(mega=False)
parser.add_argument('--fp16', action='store_true')
parser.add_argument('--text', type=str, default='Dali painting of WALL·E')
parser.add_argument('--seed', type=int, default=-1)
parser.add_argument('--grid-size', type=int, default=1)
parser.add_argument('--image-path', type=str, default='generated')
parser.add_argument('--models-root', type=str, default='pretrained')
parser.add_argument('--top_k', type=int, default=256)
def ascii_from_image(image: Image.Image, size: int = 128) -> str:
gray_pixels = image.resize((size, int(0.55 * size))).convert('L').getdata()
chars = list('.,;/IOX')
chars = [chars[i * len(chars) // 256] for i in gray_pixels]
chars = [chars[i * size: (i + 1) * size] for i in range(size // 2)]
return '\n'.join(''.join(row) for row in chars)
'''
class ImageFromText(commands.Cog):
def __init__(self, bot):
self.bot = bot
@commands.command()
async def imagine(self, ctx, prompt):
# take parameters
# if arg missing handle it
await ctx.send("Generating "+prompt+"...")
generate_image(
is_mega=True,
text=prompt,
seed=-1,
grid_size=2,
top_k=256,
image_path='generated',
models_root='pretrained',
fp16=False,
)
with open("generated.png", "rb") as fh:
f = discord.File(fh, filename="output.png")
await ctx.send(file=f)
def save_image(image: Image.Image, path: str):
if os.path.isdir(path):
path = os.path.join(path, 'generated.png')
elif not path.endswith('.png'):
path += '.png'
print("saving image to", path)
image.save(path)
return image
def generate_image(
is_mega: bool,
text: str,
seed: int,
grid_size: int,
top_k: int,
image_path: str,
models_root: str,
fp16: bool,
):
model = MinDalle(
is_mega=is_mega,
models_root=models_root,
is_reusable=False,
is_verbose=True,
device='cuda',
dtype=torch.float16 if fp16 else torch.float32
)
image = model.generate_image(
text,
seed,
grid_size,
top_k=top_k,
is_verbose=True
)
save_image(image, image_path)
#print(ascii_from_image(image, size=128))
'''
if __name__ == '__main__':
args = parser.parse_args()
print(args)
generate_image(
is_mega=args.mega,
text=args.text,
seed=args.seed,
grid_size=args.grid_size,
top_k=args.top_k,
image_path=args.image_path,
models_root=args.models_root,
fp16=args.fp16,
)
'''
def setup(bot):
bot.add_cog(ImageFromText(bot))