Spaces:
Running
Running
johnslegers
commited on
Commit
·
9643009
1
Parent(s):
121f6d3
test
Browse files- models/stable-diffusion/Put your custom ckpt files here.txt +1 -0
- modules/app.py +312 -38
- modules/dataset.py +0 -19
- modules/inference.py +0 -11
- modules/runtime.py +682 -0
- ui/scripts/Developer Console.cmd +14 -0
- ui/scripts/Start Stable Diffusion UI.cmd +19 -0
- ui/scripts/developer_console.sh +17 -0
- ui/scripts/on_env_start.bat +62 -0
- ui/scripts/on_env_start.sh +44 -0
- ui/scripts/on_sd_start.bat +335 -0
- ui/scripts/on_sd_start.sh +317 -0
- ui/scripts/post_activate.bat +6 -0
- ui/scripts/post_activate.sh +12 -0
- ui/scripts/start.sh +10 -0
- ui/scripts/win_enable_long_filepaths.ps1 +2 -0
models/stable-diffusion/Put your custom ckpt files here.txt
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
|
modules/app.py
CHANGED
@@ -1,55 +1,329 @@
|
|
1 |
-
import os
|
2 |
-
import requests
|
3 |
import json
|
4 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
5 |
|
6 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
7 |
from fastapi.staticfiles import StaticFiles
|
8 |
-
from
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
9 |
|
10 |
-
|
11 |
-
|
12 |
|
13 |
-
|
14 |
-
|
15 |
-
|
16 |
-
|
17 |
-
with open('/root/.huggingface/token') as f:
|
18 |
-
lines = f.readlines()
|
19 |
-
API_TOKEN = lines[0]
|
20 |
|
21 |
-
|
|
|
|
|
22 |
|
23 |
-
|
|
|
|
|
|
|
24 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
25 |
|
26 |
-
|
27 |
-
|
28 |
-
|
29 |
-
|
|
|
|
|
30 |
|
|
|
|
|
|
|
|
|
|
|
31 |
|
32 |
-
|
33 |
-
|
34 |
-
|
35 |
-
"POST",
|
36 |
-
"https://api-inference.huggingface.co/models/osanseviero/BigGAN-deep-128",
|
37 |
-
headers={"Authorization": f"Bearer {API_TOKEN}"},
|
38 |
-
data=json.dumps(input),
|
39 |
-
)
|
40 |
-
#return json.dumps(output)
|
41 |
-
return StreamingResponse(BytesIO(output.content), media_type="image/png")
|
42 |
|
|
|
43 |
|
44 |
-
@app.get(
|
45 |
-
def
|
46 |
-
|
|
|
47 |
|
48 |
-
|
|
|
|
|
49 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
50 |
|
51 |
-
|
52 |
-
def emotion(start, end):
|
53 |
-
output = query_emotion(int(start), int(end))
|
54 |
|
55 |
-
|
|
|
|
|
|
|
1 |
import json
|
2 |
+
import traceback
|
3 |
+
|
4 |
+
import sys
|
5 |
+
import os
|
6 |
+
|
7 |
+
SD_DIR = os.getcwd()
|
8 |
+
print('started in ', SD_DIR)
|
9 |
|
10 |
+
SD_UI_DIR = './ui'
|
11 |
+
sys.path.append(os.path.dirname(SD_UI_DIR))
|
12 |
+
|
13 |
+
CONFIG_DIR = os.path.abspath(os.path.join(SD_UI_DIR, '..', 'scripts'))
|
14 |
+
MODELS_DIR = os.path.abspath(os.path.join(SD_DIR, '..', 'models'))
|
15 |
+
|
16 |
+
OUTPUT_DIRNAME = "Stable Diffusion UI" # in the user's home folder
|
17 |
+
|
18 |
+
from fastapi import FastAPI, HTTPException
|
19 |
from fastapi.staticfiles import StaticFiles
|
20 |
+
from starlette.responses import FileResponse, StreamingResponse
|
21 |
+
from pydantic import BaseModel
|
22 |
+
import logging
|
23 |
+
|
24 |
+
from sd_internal import Request, Response
|
25 |
+
|
26 |
+
app = FastAPI()
|
27 |
+
|
28 |
+
model_loaded = False
|
29 |
+
model_is_loading = False
|
30 |
+
|
31 |
+
modifiers_cache = None
|
32 |
+
outpath = os.path.join(os.path.expanduser("~"), OUTPUT_DIRNAME)
|
33 |
+
|
34 |
+
# don't show access log entries for URLs that start with the given prefix
|
35 |
+
ACCESS_LOG_SUPPRESS_PATH_PREFIXES = ['/ping', '/modifier-thumbnails']
|
36 |
+
|
37 |
+
app.mount('/media', StaticFiles(directory=os.path.join(SD_UI_DIR, 'media/')), name="media")
|
38 |
+
|
39 |
+
# defaults from https://huggingface.co/blog/stable_diffusion
|
40 |
+
class ImageRequest(BaseModel):
|
41 |
+
session_id: str = "session"
|
42 |
+
prompt: str = ""
|
43 |
+
negative_prompt: str = ""
|
44 |
+
init_image: str = None # base64
|
45 |
+
mask: str = None # base64
|
46 |
+
num_outputs: int = 1
|
47 |
+
num_inference_steps: int = 50
|
48 |
+
guidance_scale: float = 7.5
|
49 |
+
width: int = 512
|
50 |
+
height: int = 512
|
51 |
+
seed: int = 42
|
52 |
+
prompt_strength: float = 0.8
|
53 |
+
sampler: str = None # "ddim", "plms", "heun", "euler", "euler_a", "dpm2", "dpm2_a", "lms"
|
54 |
+
# allow_nsfw: bool = False
|
55 |
+
save_to_disk_path: str = None
|
56 |
+
turbo: bool = True
|
57 |
+
use_cpu: bool = False
|
58 |
+
use_full_precision: bool = False
|
59 |
+
use_face_correction: str = None # or "GFPGANv1.3"
|
60 |
+
use_upscale: str = None # or "RealESRGAN_x4plus" or "RealESRGAN_x4plus_anime_6B"
|
61 |
+
use_stable_diffusion_model: str = "sd-v1-4"
|
62 |
+
show_only_filtered_image: bool = False
|
63 |
+
output_format: str = "jpeg" # or "png"
|
64 |
+
|
65 |
+
stream_progress_updates: bool = False
|
66 |
+
stream_image_progress: bool = False
|
67 |
+
|
68 |
+
class SetAppConfigRequest(BaseModel):
|
69 |
+
update_branch: str = "main"
|
70 |
+
|
71 |
+
@app.get('/')
|
72 |
+
def read_root():
|
73 |
+
headers = {"Cache-Control": "no-cache, no-store, must-revalidate", "Pragma": "no-cache", "Expires": "0"}
|
74 |
+
return FileResponse(os.path.join(SD_UI_DIR, 'index.html'), headers=headers)
|
75 |
+
|
76 |
+
@app.get('/ping')
|
77 |
+
async def ping():
|
78 |
+
global model_loaded, model_is_loading
|
79 |
+
|
80 |
+
try:
|
81 |
+
if model_loaded:
|
82 |
+
return {'OK'}
|
83 |
+
|
84 |
+
if model_is_loading:
|
85 |
+
return {'ERROR'}
|
86 |
+
|
87 |
+
model_is_loading = True
|
88 |
+
|
89 |
+
import runtime
|
90 |
+
|
91 |
+
runtime.load_model_ckpt(ckpt_to_use=get_initial_model_to_load())
|
92 |
+
|
93 |
+
model_loaded = True
|
94 |
+
model_is_loading = False
|
95 |
+
|
96 |
+
return {'OK'}
|
97 |
+
except Exception as e:
|
98 |
+
print(traceback.format_exc())
|
99 |
+
return HTTPException(status_code=500, detail=str(e))
|
100 |
+
|
101 |
+
# needs to support the legacy installations
|
102 |
+
def get_initial_model_to_load():
|
103 |
+
custom_weight_path = os.path.join(SD_DIR, 'custom-model.ckpt')
|
104 |
+
ckpt_to_use = "sd-v1-4" if not os.path.exists(custom_weight_path) else "custom-model"
|
105 |
+
|
106 |
+
ckpt_to_use = os.path.join(SD_DIR, ckpt_to_use)
|
107 |
+
|
108 |
+
config = getConfig()
|
109 |
+
if 'model' in config and 'stable-diffusion' in config['model']:
|
110 |
+
model_name = config['model']['stable-diffusion']
|
111 |
+
model_path = resolve_model_to_use(model_name)
|
112 |
+
|
113 |
+
if os.path.exists(model_path + '.ckpt'):
|
114 |
+
ckpt_to_use = model_path
|
115 |
+
else:
|
116 |
+
print('Could not find the configured custom model at:', model_path + '.ckpt', '. Using the default one:', ckpt_to_use + '.ckpt')
|
117 |
+
|
118 |
+
return ckpt_to_use
|
119 |
+
|
120 |
+
def resolve_model_to_use(model_name):
|
121 |
+
if model_name in ('sd-v1-4', 'custom-model'):
|
122 |
+
model_path = os.path.join(MODELS_DIR, 'stable-diffusion', model_name)
|
123 |
+
|
124 |
+
legacy_model_path = os.path.join(SD_DIR, model_name)
|
125 |
+
if not os.path.exists(model_path + '.ckpt') and os.path.exists(legacy_model_path + '.ckpt'):
|
126 |
+
model_path = legacy_model_path
|
127 |
+
else:
|
128 |
+
model_path = os.path.join(MODELS_DIR, 'stable-diffusion', model_name)
|
129 |
+
|
130 |
+
return model_path
|
131 |
+
|
132 |
+
def save_model_to_config(model_name):
|
133 |
+
config = getConfig()
|
134 |
+
if 'model' not in config:
|
135 |
+
config['model'] = {}
|
136 |
+
|
137 |
+
config['model']['stable-diffusion'] = model_name
|
138 |
+
|
139 |
+
setConfig(config)
|
140 |
+
|
141 |
+
@app.post('/image')
|
142 |
+
def image(req : ImageRequest):
|
143 |
+
import runtime
|
144 |
+
|
145 |
+
r = Request()
|
146 |
+
r.session_id = req.session_id
|
147 |
+
r.prompt = req.prompt
|
148 |
+
r.negative_prompt = req.negative_prompt
|
149 |
+
r.init_image = req.init_image
|
150 |
+
r.mask = req.mask
|
151 |
+
r.num_outputs = req.num_outputs
|
152 |
+
r.num_inference_steps = req.num_inference_steps
|
153 |
+
r.guidance_scale = req.guidance_scale
|
154 |
+
r.width = req.width
|
155 |
+
r.height = req.height
|
156 |
+
r.seed = req.seed
|
157 |
+
r.prompt_strength = req.prompt_strength
|
158 |
+
r.sampler = req.sampler
|
159 |
+
# r.allow_nsfw = req.allow_nsfw
|
160 |
+
r.turbo = req.turbo
|
161 |
+
r.use_cpu = req.use_cpu
|
162 |
+
r.use_full_precision = req.use_full_precision
|
163 |
+
r.save_to_disk_path = req.save_to_disk_path
|
164 |
+
r.use_upscale: str = req.use_upscale
|
165 |
+
r.use_face_correction = req.use_face_correction
|
166 |
+
r.show_only_filtered_image = req.show_only_filtered_image
|
167 |
+
r.output_format = req.output_format
|
168 |
+
|
169 |
+
r.stream_progress_updates = True # the underlying implementation only supports streaming
|
170 |
+
r.stream_image_progress = req.stream_image_progress
|
171 |
+
|
172 |
+
r.use_stable_diffusion_model = resolve_model_to_use(req.use_stable_diffusion_model)
|
173 |
+
|
174 |
+
save_model_to_config(req.use_stable_diffusion_model)
|
175 |
+
|
176 |
+
try:
|
177 |
+
if not req.stream_progress_updates:
|
178 |
+
r.stream_image_progress = False
|
179 |
+
|
180 |
+
res = runtime.mk_img(r)
|
181 |
+
|
182 |
+
if req.stream_progress_updates:
|
183 |
+
return StreamingResponse(res, media_type='application/json')
|
184 |
+
else: # compatibility mode: buffer the streaming responses, and return the last one
|
185 |
+
last_result = None
|
186 |
+
|
187 |
+
for result in res:
|
188 |
+
last_result = result
|
189 |
+
|
190 |
+
return json.loads(last_result)
|
191 |
+
except Exception as e:
|
192 |
+
print(traceback.format_exc())
|
193 |
+
return HTTPException(status_code=500, detail=str(e))
|
194 |
+
|
195 |
+
@app.get('/image/stop')
|
196 |
+
def stop():
|
197 |
+
try:
|
198 |
+
if model_is_loading:
|
199 |
+
return {'ERROR'}
|
200 |
+
|
201 |
+
import runtime
|
202 |
+
runtime.stop_processing = True
|
203 |
+
|
204 |
+
return {'OK'}
|
205 |
+
except Exception as e:
|
206 |
+
print(traceback.format_exc())
|
207 |
+
return HTTPException(status_code=500, detail=str(e))
|
208 |
+
|
209 |
+
@app.get('/image/tmp/{session_id}/{img_id}')
|
210 |
+
def get_image(session_id, img_id):
|
211 |
+
import runtime
|
212 |
+
buf = runtime.temp_images[session_id + '/' + img_id]
|
213 |
+
buf.seek(0)
|
214 |
+
return StreamingResponse(buf, media_type='image/jpeg')
|
215 |
+
|
216 |
+
@app.post('/app_config')
|
217 |
+
async def setAppConfig(req : SetAppConfigRequest):
|
218 |
+
try:
|
219 |
+
config = {
|
220 |
+
'update_branch': req.update_branch
|
221 |
+
}
|
222 |
+
|
223 |
+
config_json_str = json.dumps(config)
|
224 |
+
config_bat_str = f'@set update_branch={req.update_branch}'
|
225 |
+
config_sh_str = f'export update_branch={req.update_branch}'
|
226 |
+
|
227 |
+
config_json_path = os.path.join(CONFIG_DIR, 'config.json')
|
228 |
+
config_bat_path = os.path.join(CONFIG_DIR, 'config.bat')
|
229 |
+
config_sh_path = os.path.join(CONFIG_DIR, 'config.sh')
|
230 |
+
|
231 |
+
with open(config_json_path, 'w') as f:
|
232 |
+
f.write(config_json_str)
|
233 |
+
|
234 |
+
with open(config_bat_path, 'w') as f:
|
235 |
+
f.write(config_bat_str)
|
236 |
+
|
237 |
+
with open(config_sh_path, 'w') as f:
|
238 |
+
f.write(config_sh_str)
|
239 |
+
|
240 |
+
return {'OK'}
|
241 |
+
except Exception as e:
|
242 |
+
print(traceback.format_exc())
|
243 |
+
return HTTPException(status_code=500, detail=str(e))
|
244 |
+
|
245 |
+
@app.get('/app_config')
|
246 |
+
def getAppConfig():
|
247 |
+
try:
|
248 |
+
config_json_path = os.path.join(CONFIG_DIR, 'config.json')
|
249 |
+
|
250 |
+
if not os.path.exists(config_json_path):
|
251 |
+
return HTTPException(status_code=500, detail="No config file")
|
252 |
+
|
253 |
+
with open(config_json_path, 'r') as f:
|
254 |
+
return json.load(f)
|
255 |
+
except Exception as e:
|
256 |
+
print(traceback.format_exc())
|
257 |
+
return HTTPException(status_code=500, detail=str(e))
|
258 |
+
|
259 |
+
def getConfig():
|
260 |
+
try:
|
261 |
+
config_json_path = os.path.join(CONFIG_DIR, 'config.json')
|
262 |
|
263 |
+
if not os.path.exists(config_json_path):
|
264 |
+
return {}
|
265 |
|
266 |
+
with open(config_json_path, 'r') as f:
|
267 |
+
return json.load(f)
|
268 |
+
except Exception as e:
|
269 |
+
return {}
|
|
|
|
|
|
|
270 |
|
271 |
+
def setConfig(config):
|
272 |
+
try:
|
273 |
+
config_json_path = os.path.join(CONFIG_DIR, 'config.json')
|
274 |
|
275 |
+
with open(config_json_path, 'w') as f:
|
276 |
+
return json.dump(config, f)
|
277 |
+
except:
|
278 |
+
print(traceback.format_exc())
|
279 |
|
280 |
+
@app.get('/models')
|
281 |
+
def getModels():
|
282 |
+
models = {
|
283 |
+
'active': {
|
284 |
+
'stable-diffusion': 'sd-v1-4',
|
285 |
+
},
|
286 |
+
'options': {
|
287 |
+
'stable-diffusion': ['sd-v1-4'],
|
288 |
+
},
|
289 |
+
}
|
290 |
|
291 |
+
# custom models
|
292 |
+
sd_models_dir = os.path.join(MODELS_DIR, 'stable-diffusion')
|
293 |
+
for file in os.listdir(sd_models_dir):
|
294 |
+
if file.endswith('.ckpt'):
|
295 |
+
model_name = os.path.splitext(file)[0]
|
296 |
+
models['options']['stable-diffusion'].append(model_name)
|
297 |
|
298 |
+
# legacy
|
299 |
+
custom_weight_path = os.path.join(SD_DIR, 'custom-model.ckpt')
|
300 |
+
if os.path.exists(custom_weight_path):
|
301 |
+
models['active']['stable-diffusion'] = 'custom-model'
|
302 |
+
models['options']['stable-diffusion'].append('custom-model')
|
303 |
|
304 |
+
config = getConfig()
|
305 |
+
if 'model' in config and 'stable-diffusion' in config['model']:
|
306 |
+
models['active']['stable-diffusion'] = config['model']['stable-diffusion']
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
307 |
|
308 |
+
return models
|
309 |
|
310 |
+
@app.get('/modifiers.json')
|
311 |
+
def read_modifiers():
|
312 |
+
headers = {"Cache-Control": "no-cache, no-store, must-revalidate", "Pragma": "no-cache", "Expires": "0"}
|
313 |
+
return FileResponse(os.path.join(SD_UI_DIR, 'modifiers.json'), headers=headers)
|
314 |
|
315 |
+
@app.get('/output_dir')
|
316 |
+
def read_home_dir():
|
317 |
+
return {outpath}
|
318 |
|
319 |
+
# don't log certain requests
|
320 |
+
class LogSuppressFilter(logging.Filter):
|
321 |
+
def filter(self, record: logging.LogRecord) -> bool:
|
322 |
+
path = record.getMessage()
|
323 |
+
for prefix in ACCESS_LOG_SUPPRESS_PATH_PREFIXES:
|
324 |
+
if path.find(prefix) != -1:
|
325 |
+
return False
|
326 |
|
327 |
+
return True
|
|
|
|
|
328 |
|
329 |
+
logging.getLogger('uvicorn.access').addFilter(LogSuppressFilter())
|
modules/dataset.py
DELETED
@@ -1,19 +0,0 @@
|
|
1 |
-
from datasets import load_dataset
|
2 |
-
|
3 |
-
dataset = load_dataset("emotion", split="train")
|
4 |
-
|
5 |
-
emotions = dataset.info.features["label"].names
|
6 |
-
|
7 |
-
def query_emotion(start, end):
|
8 |
-
rows = dataset[start:end]
|
9 |
-
texts, labels = [rows[k] for k in rows.keys()]
|
10 |
-
|
11 |
-
observations = []
|
12 |
-
|
13 |
-
for i, text in enumerate(texts):
|
14 |
-
observations.append({
|
15 |
-
"text": text,
|
16 |
-
"emotion": emotions[labels[i]],
|
17 |
-
})
|
18 |
-
|
19 |
-
return observations
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
modules/inference.py
DELETED
@@ -1,11 +0,0 @@
|
|
1 |
-
from transformers import T5Tokenizer, T5ForConditionalGeneration
|
2 |
-
|
3 |
-
tokenizer = T5Tokenizer.from_pretrained("t5-small")
|
4 |
-
model = T5ForConditionalGeneration.from_pretrained("t5-small")
|
5 |
-
|
6 |
-
|
7 |
-
def infer_t5(input):
|
8 |
-
input_ids = tokenizer(input, return_tensors="pt").input_ids
|
9 |
-
outputs = model.generate(input_ids)
|
10 |
-
|
11 |
-
return tokenizer.decode(outputs[0], skip_special_tokens=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
modules/runtime.py
ADDED
@@ -0,0 +1,682 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import json
|
2 |
+
import os, re
|
3 |
+
import traceback
|
4 |
+
import torch
|
5 |
+
import numpy as np
|
6 |
+
from omegaconf import OmegaConf
|
7 |
+
from PIL import Image, ImageOps
|
8 |
+
from tqdm import tqdm, trange
|
9 |
+
from itertools import islice
|
10 |
+
from einops import rearrange
|
11 |
+
import time
|
12 |
+
from pytorch_lightning import seed_everything
|
13 |
+
from torch import autocast
|
14 |
+
from contextlib import nullcontext
|
15 |
+
from einops import rearrange, repeat
|
16 |
+
from ldmlib.util import instantiate_from_config
|
17 |
+
from optimizedSD.optimUtils import split_weighted_subprompts
|
18 |
+
from transformers import logging
|
19 |
+
|
20 |
+
from gfpgan import GFPGANer
|
21 |
+
from basicsr.archs.rrdbnet_arch import RRDBNet
|
22 |
+
from realesrgan import RealESRGANer
|
23 |
+
|
24 |
+
import uuid
|
25 |
+
|
26 |
+
logging.set_verbosity_error()
|
27 |
+
|
28 |
+
# consts
|
29 |
+
config_yaml = "optimizedSD/v1-inference.yaml"
|
30 |
+
filename_regex = re.compile('[^a-zA-Z0-9]')
|
31 |
+
|
32 |
+
# api stuff
|
33 |
+
from sd_internal import Request, Response, Image as ResponseImage
|
34 |
+
import base64
|
35 |
+
from io import BytesIO
|
36 |
+
#from colorama import Fore
|
37 |
+
|
38 |
+
# local
|
39 |
+
stop_processing = False
|
40 |
+
temp_images = {}
|
41 |
+
|
42 |
+
ckpt_file = None
|
43 |
+
gfpgan_file = None
|
44 |
+
real_esrgan_file = None
|
45 |
+
|
46 |
+
model = None
|
47 |
+
modelCS = None
|
48 |
+
modelFS = None
|
49 |
+
model_gfpgan = None
|
50 |
+
model_real_esrgan = None
|
51 |
+
|
52 |
+
model_is_half = False
|
53 |
+
model_fs_is_half = False
|
54 |
+
device = None
|
55 |
+
unet_bs = 1
|
56 |
+
precision = 'autocast'
|
57 |
+
sampler_plms = None
|
58 |
+
sampler_ddim = None
|
59 |
+
|
60 |
+
has_valid_gpu = False
|
61 |
+
force_full_precision = False
|
62 |
+
try:
|
63 |
+
gpu = torch.cuda.current_device()
|
64 |
+
gpu_name = torch.cuda.get_device_name(gpu)
|
65 |
+
print('GPU detected: ', gpu_name)
|
66 |
+
|
67 |
+
force_full_precision = ('nvidia' in gpu_name.lower() or 'geforce' in gpu_name.lower()) and (' 1660' in gpu_name or ' 1650' in gpu_name) # otherwise these NVIDIA cards create green images
|
68 |
+
if force_full_precision:
|
69 |
+
print('forcing full precision on NVIDIA 16xx cards, to avoid green images. GPU detected: ', gpu_name)
|
70 |
+
|
71 |
+
mem_free, mem_total = torch.cuda.mem_get_info(gpu)
|
72 |
+
mem_total /= float(10**9)
|
73 |
+
if mem_total < 3.0:
|
74 |
+
print("GPUs with less than 3 GB of VRAM are not compatible with Stable Diffusion")
|
75 |
+
raise Exception()
|
76 |
+
|
77 |
+
has_valid_gpu = True
|
78 |
+
except:
|
79 |
+
print('WARNING: No compatible GPU found. Using the CPU, but this will be very slow!')
|
80 |
+
pass
|
81 |
+
|
82 |
+
def load_model_ckpt(ckpt_to_use, device_to_use='cuda', turbo=False, unet_bs_to_use=1, precision_to_use='autocast'):
|
83 |
+
global ckpt_file, model, modelCS, modelFS, model_is_half, device, unet_bs, precision, model_fs_is_half
|
84 |
+
|
85 |
+
device = device_to_use if has_valid_gpu else 'cpu'
|
86 |
+
precision = precision_to_use if not force_full_precision else 'full'
|
87 |
+
unet_bs = unet_bs_to_use
|
88 |
+
|
89 |
+
unload_model()
|
90 |
+
|
91 |
+
if device == 'cpu':
|
92 |
+
precision = 'full'
|
93 |
+
|
94 |
+
sd = load_model_from_config(f"{ckpt_to_use}.ckpt")
|
95 |
+
li, lo = [], []
|
96 |
+
for key, value in sd.items():
|
97 |
+
sp = key.split(".")
|
98 |
+
if (sp[0]) == "model":
|
99 |
+
if "input_blocks" in sp:
|
100 |
+
li.append(key)
|
101 |
+
elif "middle_block" in sp:
|
102 |
+
li.append(key)
|
103 |
+
elif "time_embed" in sp:
|
104 |
+
li.append(key)
|
105 |
+
else:
|
106 |
+
lo.append(key)
|
107 |
+
for key in li:
|
108 |
+
sd["model1." + key[6:]] = sd.pop(key)
|
109 |
+
for key in lo:
|
110 |
+
sd["model2." + key[6:]] = sd.pop(key)
|
111 |
+
|
112 |
+
config = OmegaConf.load(f"{config_yaml}")
|
113 |
+
|
114 |
+
model = instantiate_from_config(config.modelUNet)
|
115 |
+
_, _ = model.load_state_dict(sd, strict=False)
|
116 |
+
model.eval()
|
117 |
+
model.cdevice = device
|
118 |
+
model.unet_bs = unet_bs
|
119 |
+
model.turbo = turbo
|
120 |
+
|
121 |
+
modelCS = instantiate_from_config(config.modelCondStage)
|
122 |
+
_, _ = modelCS.load_state_dict(sd, strict=False)
|
123 |
+
modelCS.eval()
|
124 |
+
modelCS.cond_stage_model.device = device
|
125 |
+
|
126 |
+
modelFS = instantiate_from_config(config.modelFirstStage)
|
127 |
+
_, _ = modelFS.load_state_dict(sd, strict=False)
|
128 |
+
modelFS.eval()
|
129 |
+
del sd
|
130 |
+
|
131 |
+
if device != "cpu" and precision == "autocast":
|
132 |
+
model.half()
|
133 |
+
modelCS.half()
|
134 |
+
modelFS.half()
|
135 |
+
model_is_half = True
|
136 |
+
model_fs_is_half = True
|
137 |
+
else:
|
138 |
+
model_is_half = False
|
139 |
+
model_fs_is_half = False
|
140 |
+
|
141 |
+
ckpt_file = ckpt_to_use
|
142 |
+
|
143 |
+
print('loaded ', ckpt_file, 'to', device, 'precision', precision)
|
144 |
+
|
145 |
+
def unload_model():
|
146 |
+
global model, modelCS, modelFS
|
147 |
+
|
148 |
+
if model is not None:
|
149 |
+
del model
|
150 |
+
del modelCS
|
151 |
+
del modelFS
|
152 |
+
|
153 |
+
model = None
|
154 |
+
modelCS = None
|
155 |
+
modelFS = None
|
156 |
+
|
157 |
+
def load_model_gfpgan(gfpgan_to_use):
|
158 |
+
global gfpgan_file, model_gfpgan
|
159 |
+
|
160 |
+
if gfpgan_to_use is None:
|
161 |
+
return
|
162 |
+
|
163 |
+
gfpgan_file = gfpgan_to_use
|
164 |
+
model_path = gfpgan_to_use + ".pth"
|
165 |
+
|
166 |
+
if device == 'cpu':
|
167 |
+
model_gfpgan = GFPGANer(model_path=model_path, upscale=1, arch='clean', channel_multiplier=2, bg_upsampler=None, device=torch.device('cpu'))
|
168 |
+
else:
|
169 |
+
model_gfpgan = GFPGANer(model_path=model_path, upscale=1, arch='clean', channel_multiplier=2, bg_upsampler=None, device=torch.device('cuda'))
|
170 |
+
|
171 |
+
print('loaded ', gfpgan_to_use, 'to', device, 'precision', precision)
|
172 |
+
|
173 |
+
def load_model_real_esrgan(real_esrgan_to_use):
|
174 |
+
global real_esrgan_file, model_real_esrgan
|
175 |
+
|
176 |
+
if real_esrgan_to_use is None:
|
177 |
+
return
|
178 |
+
|
179 |
+
real_esrgan_file = real_esrgan_to_use
|
180 |
+
model_path = real_esrgan_to_use + ".pth"
|
181 |
+
|
182 |
+
RealESRGAN_models = {
|
183 |
+
'RealESRGAN_x4plus': RRDBNet(num_in_ch=3, num_out_ch=3, num_feat=64, num_block=23, num_grow_ch=32, scale=4),
|
184 |
+
'RealESRGAN_x4plus_anime_6B': RRDBNet(num_in_ch=3, num_out_ch=3, num_feat=64, num_block=6, num_grow_ch=32, scale=4)
|
185 |
+
}
|
186 |
+
|
187 |
+
model_to_use = RealESRGAN_models[real_esrgan_to_use]
|
188 |
+
|
189 |
+
if device == 'cpu':
|
190 |
+
model_real_esrgan = RealESRGANer(scale=2, model_path=model_path, model=model_to_use, pre_pad=0, half=False) # cpu does not support half
|
191 |
+
model_real_esrgan.device = torch.device('cpu')
|
192 |
+
model_real_esrgan.model.to('cpu')
|
193 |
+
else:
|
194 |
+
model_real_esrgan = RealESRGANer(scale=2, model_path=model_path, model=model_to_use, pre_pad=0, half=model_is_half)
|
195 |
+
|
196 |
+
model_real_esrgan.model.name = real_esrgan_to_use
|
197 |
+
|
198 |
+
print('loaded ', real_esrgan_to_use, 'to', device, 'precision', precision)
|
199 |
+
|
200 |
+
def mk_img(req: Request):
|
201 |
+
try:
|
202 |
+
yield from do_mk_img(req)
|
203 |
+
except Exception as e:
|
204 |
+
print(traceback.format_exc())
|
205 |
+
|
206 |
+
gc()
|
207 |
+
|
208 |
+
if device != "cpu":
|
209 |
+
modelFS.to("cpu")
|
210 |
+
modelCS.to("cpu")
|
211 |
+
|
212 |
+
model.model1.to("cpu")
|
213 |
+
model.model2.to("cpu")
|
214 |
+
|
215 |
+
gc()
|
216 |
+
|
217 |
+
yield json.dumps({
|
218 |
+
"status": 'failed',
|
219 |
+
"detail": str(e)
|
220 |
+
})
|
221 |
+
|
222 |
+
def do_mk_img(req: Request):
|
223 |
+
global ckpt_file
|
224 |
+
global model, modelCS, modelFS, device
|
225 |
+
global model_gfpgan, model_real_esrgan
|
226 |
+
global stop_processing
|
227 |
+
|
228 |
+
stop_processing = False
|
229 |
+
|
230 |
+
res = Response()
|
231 |
+
res.request = req
|
232 |
+
res.images = []
|
233 |
+
|
234 |
+
temp_images.clear()
|
235 |
+
|
236 |
+
# custom model support:
|
237 |
+
# the req.use_stable_diffusion_model needs to be a valid path
|
238 |
+
# to the ckpt file (without the extension).
|
239 |
+
|
240 |
+
needs_model_reload = False
|
241 |
+
ckpt_to_use = ckpt_file
|
242 |
+
if ckpt_to_use != req.use_stable_diffusion_model:
|
243 |
+
ckpt_to_use = req.use_stable_diffusion_model
|
244 |
+
needs_model_reload = True
|
245 |
+
|
246 |
+
model.turbo = req.turbo
|
247 |
+
if req.use_cpu:
|
248 |
+
if device != 'cpu':
|
249 |
+
device = 'cpu'
|
250 |
+
|
251 |
+
if model_is_half:
|
252 |
+
load_model_ckpt(ckpt_to_use, device)
|
253 |
+
needs_model_reload = False
|
254 |
+
|
255 |
+
load_model_gfpgan(gfpgan_file)
|
256 |
+
load_model_real_esrgan(real_esrgan_file)
|
257 |
+
else:
|
258 |
+
if has_valid_gpu:
|
259 |
+
prev_device = device
|
260 |
+
device = 'cuda'
|
261 |
+
|
262 |
+
if (precision == 'autocast' and (req.use_full_precision or not model_is_half)) or \
|
263 |
+
(precision == 'full' and not req.use_full_precision and not force_full_precision):
|
264 |
+
|
265 |
+
load_model_ckpt(ckpt_to_use, device, req.turbo, unet_bs, ('full' if req.use_full_precision else 'autocast'))
|
266 |
+
needs_model_reload = False
|
267 |
+
|
268 |
+
if prev_device != device:
|
269 |
+
load_model_gfpgan(gfpgan_file)
|
270 |
+
load_model_real_esrgan(real_esrgan_file)
|
271 |
+
|
272 |
+
if needs_model_reload:
|
273 |
+
load_model_ckpt(ckpt_to_use, device, req.turbo, unet_bs, precision)
|
274 |
+
|
275 |
+
if req.use_face_correction != gfpgan_file:
|
276 |
+
load_model_gfpgan(req.use_face_correction)
|
277 |
+
|
278 |
+
if req.use_upscale != real_esrgan_file:
|
279 |
+
load_model_real_esrgan(req.use_upscale)
|
280 |
+
|
281 |
+
model.cdevice = device
|
282 |
+
modelCS.cond_stage_model.device = device
|
283 |
+
|
284 |
+
opt_prompt = req.prompt
|
285 |
+
opt_seed = req.seed
|
286 |
+
opt_n_samples = req.num_outputs
|
287 |
+
opt_n_iter = 1
|
288 |
+
opt_scale = req.guidance_scale
|
289 |
+
opt_C = 4
|
290 |
+
opt_H = req.height
|
291 |
+
opt_W = req.width
|
292 |
+
opt_f = 8
|
293 |
+
opt_ddim_steps = req.num_inference_steps
|
294 |
+
opt_ddim_eta = 0.0
|
295 |
+
opt_strength = req.prompt_strength
|
296 |
+
opt_save_to_disk_path = req.save_to_disk_path
|
297 |
+
opt_init_img = req.init_image
|
298 |
+
opt_use_face_correction = req.use_face_correction
|
299 |
+
opt_use_upscale = req.use_upscale
|
300 |
+
opt_show_only_filtered = req.show_only_filtered_image
|
301 |
+
opt_format = req.output_format
|
302 |
+
opt_sampler_name = req.sampler
|
303 |
+
|
304 |
+
print(req.to_string(), '\n device', device)
|
305 |
+
|
306 |
+
print('\n\n Using precision:', precision)
|
307 |
+
|
308 |
+
seed_everything(opt_seed)
|
309 |
+
|
310 |
+
batch_size = opt_n_samples
|
311 |
+
prompt = opt_prompt
|
312 |
+
assert prompt is not None
|
313 |
+
data = [batch_size * [prompt]]
|
314 |
+
|
315 |
+
if precision == "autocast" and device != "cpu":
|
316 |
+
precision_scope = autocast
|
317 |
+
else:
|
318 |
+
precision_scope = nullcontext
|
319 |
+
|
320 |
+
mask = None
|
321 |
+
|
322 |
+
if req.init_image is None:
|
323 |
+
handler = _txt2img
|
324 |
+
|
325 |
+
init_latent = None
|
326 |
+
t_enc = None
|
327 |
+
else:
|
328 |
+
handler = _img2img
|
329 |
+
|
330 |
+
init_image = load_img(req.init_image, opt_W, opt_H)
|
331 |
+
init_image = init_image.to(device)
|
332 |
+
|
333 |
+
if device != "cpu" and precision == "autocast":
|
334 |
+
init_image = init_image.half()
|
335 |
+
|
336 |
+
modelFS.to(device)
|
337 |
+
|
338 |
+
init_image = repeat(init_image, '1 ... -> b ...', b=batch_size)
|
339 |
+
init_latent = modelFS.get_first_stage_encoding(modelFS.encode_first_stage(init_image)) # move to latent space
|
340 |
+
|
341 |
+
if req.mask is not None:
|
342 |
+
mask = load_mask(req.mask, opt_W, opt_H, init_latent.shape[2], init_latent.shape[3], True).to(device)
|
343 |
+
mask = mask[0][0].unsqueeze(0).repeat(4, 1, 1).unsqueeze(0)
|
344 |
+
mask = repeat(mask, '1 ... -> b ...', b=batch_size)
|
345 |
+
|
346 |
+
if device != "cpu" and precision == "autocast":
|
347 |
+
mask = mask.half()
|
348 |
+
|
349 |
+
move_fs_to_cpu()
|
350 |
+
|
351 |
+
assert 0. <= opt_strength <= 1., 'can only work with strength in [0.0, 1.0]'
|
352 |
+
t_enc = int(opt_strength * opt_ddim_steps)
|
353 |
+
print(f"target t_enc is {t_enc} steps")
|
354 |
+
|
355 |
+
if opt_save_to_disk_path is not None:
|
356 |
+
session_out_path = os.path.join(opt_save_to_disk_path, req.session_id)
|
357 |
+
os.makedirs(session_out_path, exist_ok=True)
|
358 |
+
else:
|
359 |
+
session_out_path = None
|
360 |
+
|
361 |
+
seeds = ""
|
362 |
+
with torch.no_grad():
|
363 |
+
for n in trange(opt_n_iter, desc="Sampling"):
|
364 |
+
for prompts in tqdm(data, desc="data"):
|
365 |
+
|
366 |
+
with precision_scope("cuda"):
|
367 |
+
modelCS.to(device)
|
368 |
+
uc = None
|
369 |
+
if opt_scale != 1.0:
|
370 |
+
uc = modelCS.get_learned_conditioning(batch_size * [req.negative_prompt])
|
371 |
+
if isinstance(prompts, tuple):
|
372 |
+
prompts = list(prompts)
|
373 |
+
|
374 |
+
subprompts, weights = split_weighted_subprompts(prompts[0])
|
375 |
+
if len(subprompts) > 1:
|
376 |
+
c = torch.zeros_like(uc)
|
377 |
+
totalWeight = sum(weights)
|
378 |
+
# normalize each "sub prompt" and add it
|
379 |
+
for i in range(len(subprompts)):
|
380 |
+
weight = weights[i]
|
381 |
+
# if not skip_normalize:
|
382 |
+
weight = weight / totalWeight
|
383 |
+
c = torch.add(c, modelCS.get_learned_conditioning(subprompts[i]), alpha=weight)
|
384 |
+
else:
|
385 |
+
c = modelCS.get_learned_conditioning(prompts)
|
386 |
+
|
387 |
+
modelFS.to(device)
|
388 |
+
|
389 |
+
partial_x_samples = None
|
390 |
+
def img_callback(x_samples, i):
|
391 |
+
nonlocal partial_x_samples
|
392 |
+
|
393 |
+
partial_x_samples = x_samples
|
394 |
+
|
395 |
+
if req.stream_progress_updates:
|
396 |
+
n_steps = opt_ddim_steps if req.init_image is None else t_enc
|
397 |
+
progress = {"step": i, "total_steps": n_steps}
|
398 |
+
|
399 |
+
if req.stream_image_progress and i % 5 == 0:
|
400 |
+
partial_images = []
|
401 |
+
|
402 |
+
for i in range(batch_size):
|
403 |
+
x_samples_ddim = modelFS.decode_first_stage(x_samples[i].unsqueeze(0))
|
404 |
+
x_sample = torch.clamp((x_samples_ddim + 1.0) / 2.0, min=0.0, max=1.0)
|
405 |
+
x_sample = 255.0 * rearrange(x_sample[0].cpu().numpy(), "c h w -> h w c")
|
406 |
+
x_sample = x_sample.astype(np.uint8)
|
407 |
+
img = Image.fromarray(x_sample)
|
408 |
+
buf = BytesIO()
|
409 |
+
img.save(buf, format='JPEG')
|
410 |
+
buf.seek(0)
|
411 |
+
|
412 |
+
del img, x_sample, x_samples_ddim
|
413 |
+
# don't delete x_samples, it is used in the code that called this callback
|
414 |
+
|
415 |
+
temp_images[str(req.session_id) + '/' + str(i)] = buf
|
416 |
+
partial_images.append({'path': f'/image/tmp/{req.session_id}/{i}'})
|
417 |
+
|
418 |
+
progress['output'] = partial_images
|
419 |
+
|
420 |
+
yield json.dumps(progress)
|
421 |
+
|
422 |
+
if stop_processing:
|
423 |
+
raise UserInitiatedStop("User requested that we stop processing")
|
424 |
+
|
425 |
+
# run the handler
|
426 |
+
try:
|
427 |
+
if handler == _txt2img:
|
428 |
+
x_samples = _txt2img(opt_W, opt_H, opt_n_samples, opt_ddim_steps, opt_scale, None, opt_C, opt_f, opt_ddim_eta, c, uc, opt_seed, img_callback, mask, opt_sampler_name)
|
429 |
+
else:
|
430 |
+
x_samples = _img2img(init_latent, t_enc, batch_size, opt_scale, c, uc, opt_ddim_steps, opt_ddim_eta, opt_seed, img_callback, mask)
|
431 |
+
|
432 |
+
yield from x_samples
|
433 |
+
|
434 |
+
x_samples = partial_x_samples
|
435 |
+
except UserInitiatedStop:
|
436 |
+
if partial_x_samples is None:
|
437 |
+
continue
|
438 |
+
|
439 |
+
x_samples = partial_x_samples
|
440 |
+
|
441 |
+
print("saving images")
|
442 |
+
for i in range(batch_size):
|
443 |
+
|
444 |
+
x_samples_ddim = modelFS.decode_first_stage(x_samples[i].unsqueeze(0))
|
445 |
+
x_sample = torch.clamp((x_samples_ddim + 1.0) / 2.0, min=0.0, max=1.0)
|
446 |
+
x_sample = 255.0 * rearrange(x_sample[0].cpu().numpy(), "c h w -> h w c")
|
447 |
+
x_sample = x_sample.astype(np.uint8)
|
448 |
+
img = Image.fromarray(x_sample)
|
449 |
+
|
450 |
+
has_filters = (opt_use_face_correction is not None and opt_use_face_correction.startswith('GFPGAN')) or \
|
451 |
+
(opt_use_upscale is not None and opt_use_upscale.startswith('RealESRGAN'))
|
452 |
+
|
453 |
+
return_orig_img = not has_filters or not opt_show_only_filtered
|
454 |
+
|
455 |
+
if stop_processing:
|
456 |
+
return_orig_img = True
|
457 |
+
|
458 |
+
if opt_save_to_disk_path is not None:
|
459 |
+
prompt_flattened = filename_regex.sub('_', prompts[0])
|
460 |
+
prompt_flattened = prompt_flattened[:50]
|
461 |
+
|
462 |
+
img_id = str(uuid.uuid4())[-8:]
|
463 |
+
|
464 |
+
file_path = f"{prompt_flattened}_{img_id}"
|
465 |
+
img_out_path = os.path.join(session_out_path, f"{file_path}.{opt_format}")
|
466 |
+
meta_out_path = os.path.join(session_out_path, f"{file_path}.txt")
|
467 |
+
|
468 |
+
if return_orig_img:
|
469 |
+
save_image(img, img_out_path)
|
470 |
+
|
471 |
+
save_metadata(meta_out_path, prompts, opt_seed, opt_W, opt_H, opt_ddim_steps, opt_scale, opt_strength, opt_use_face_correction, opt_use_upscale, opt_sampler_name, req.negative_prompt, ckpt_file)
|
472 |
+
|
473 |
+
if return_orig_img:
|
474 |
+
img_data = img_to_base64_str(img, opt_format)
|
475 |
+
res_image_orig = ResponseImage(data=img_data, seed=opt_seed)
|
476 |
+
res.images.append(res_image_orig)
|
477 |
+
|
478 |
+
if opt_save_to_disk_path is not None:
|
479 |
+
res_image_orig.path_abs = img_out_path
|
480 |
+
|
481 |
+
del img
|
482 |
+
|
483 |
+
if has_filters and not stop_processing:
|
484 |
+
print('Applying filters..')
|
485 |
+
|
486 |
+
gc()
|
487 |
+
filters_applied = []
|
488 |
+
|
489 |
+
if opt_use_face_correction:
|
490 |
+
_, _, output = model_gfpgan.enhance(x_sample[:,:,::-1], has_aligned=False, only_center_face=False, paste_back=True)
|
491 |
+
x_sample = output[:,:,::-1]
|
492 |
+
filters_applied.append(opt_use_face_correction)
|
493 |
+
|
494 |
+
if opt_use_upscale:
|
495 |
+
output, _ = model_real_esrgan.enhance(x_sample[:,:,::-1])
|
496 |
+
x_sample = output[:,:,::-1]
|
497 |
+
filters_applied.append(opt_use_upscale)
|
498 |
+
|
499 |
+
filtered_image = Image.fromarray(x_sample)
|
500 |
+
|
501 |
+
filtered_img_data = img_to_base64_str(filtered_image, opt_format)
|
502 |
+
res_image_filtered = ResponseImage(data=filtered_img_data, seed=opt_seed)
|
503 |
+
res.images.append(res_image_filtered)
|
504 |
+
|
505 |
+
filters_applied = "_".join(filters_applied)
|
506 |
+
|
507 |
+
if opt_save_to_disk_path is not None:
|
508 |
+
filtered_img_out_path = os.path.join(session_out_path, f"{file_path}_{filters_applied}.{opt_format}")
|
509 |
+
save_image(filtered_image, filtered_img_out_path)
|
510 |
+
res_image_filtered.path_abs = filtered_img_out_path
|
511 |
+
|
512 |
+
del filtered_image
|
513 |
+
|
514 |
+
seeds += str(opt_seed) + ","
|
515 |
+
opt_seed += 1
|
516 |
+
|
517 |
+
move_fs_to_cpu()
|
518 |
+
gc()
|
519 |
+
del x_samples, x_samples_ddim, x_sample
|
520 |
+
print("memory_final = ", torch.cuda.memory_allocated() / 1e6)
|
521 |
+
|
522 |
+
print('Task completed')
|
523 |
+
|
524 |
+
yield json.dumps(res.json())
|
525 |
+
|
526 |
+
def save_image(img, img_out_path):
|
527 |
+
try:
|
528 |
+
img.save(img_out_path)
|
529 |
+
except:
|
530 |
+
print('could not save the file', traceback.format_exc())
|
531 |
+
|
532 |
+
def save_metadata(meta_out_path, prompts, opt_seed, opt_W, opt_H, opt_ddim_steps, opt_scale, opt_prompt_strength, opt_correct_face, opt_upscale, sampler_name, negative_prompt, ckpt_file):
|
533 |
+
metadata = f"{prompts[0]}\nWidth: {opt_W}\nHeight: {opt_H}\nSeed: {opt_seed}\nSteps: {opt_ddim_steps}\nGuidance Scale: {opt_scale}\nPrompt Strength: {opt_prompt_strength}\nUse Face Correction: {opt_correct_face}\nUse Upscaling: {opt_upscale}\nSampler: {sampler_name}\nNegative Prompt: {negative_prompt}\nStable Diffusion Model: {ckpt_file + '.ckpt'}"
|
534 |
+
|
535 |
+
try:
|
536 |
+
with open(meta_out_path, 'w') as f:
|
537 |
+
f.write(metadata)
|
538 |
+
except:
|
539 |
+
print('could not save the file', traceback.format_exc())
|
540 |
+
|
541 |
+
def _txt2img(opt_W, opt_H, opt_n_samples, opt_ddim_steps, opt_scale, start_code, opt_C, opt_f, opt_ddim_eta, c, uc, opt_seed, img_callback, mask, sampler_name):
|
542 |
+
shape = [opt_n_samples, opt_C, opt_H // opt_f, opt_W // opt_f]
|
543 |
+
|
544 |
+
if device != "cpu":
|
545 |
+
mem = torch.cuda.memory_allocated() / 1e6
|
546 |
+
modelCS.to("cpu")
|
547 |
+
while torch.cuda.memory_allocated() / 1e6 >= mem:
|
548 |
+
time.sleep(1)
|
549 |
+
|
550 |
+
if sampler_name == 'ddim':
|
551 |
+
model.make_schedule(ddim_num_steps=opt_ddim_steps, ddim_eta=opt_ddim_eta, verbose=False)
|
552 |
+
|
553 |
+
samples_ddim = model.sample(
|
554 |
+
S=opt_ddim_steps,
|
555 |
+
conditioning=c,
|
556 |
+
seed=opt_seed,
|
557 |
+
shape=shape,
|
558 |
+
verbose=False,
|
559 |
+
unconditional_guidance_scale=opt_scale,
|
560 |
+
unconditional_conditioning=uc,
|
561 |
+
eta=opt_ddim_eta,
|
562 |
+
x_T=start_code,
|
563 |
+
img_callback=img_callback,
|
564 |
+
mask=mask,
|
565 |
+
sampler = sampler_name,
|
566 |
+
)
|
567 |
+
|
568 |
+
yield from samples_ddim
|
569 |
+
|
570 |
+
def _img2img(init_latent, t_enc, batch_size, opt_scale, c, uc, opt_ddim_steps, opt_ddim_eta, opt_seed, img_callback, mask):
|
571 |
+
# encode (scaled latent)
|
572 |
+
z_enc = model.stochastic_encode(
|
573 |
+
init_latent,
|
574 |
+
torch.tensor([t_enc] * batch_size).to(device),
|
575 |
+
opt_seed,
|
576 |
+
opt_ddim_eta,
|
577 |
+
opt_ddim_steps,
|
578 |
+
)
|
579 |
+
x_T = None if mask is None else init_latent
|
580 |
+
|
581 |
+
# decode it
|
582 |
+
samples_ddim = model.sample(
|
583 |
+
t_enc,
|
584 |
+
c,
|
585 |
+
z_enc,
|
586 |
+
unconditional_guidance_scale=opt_scale,
|
587 |
+
unconditional_conditioning=uc,
|
588 |
+
img_callback=img_callback,
|
589 |
+
mask=mask,
|
590 |
+
x_T=x_T,
|
591 |
+
sampler = 'ddim'
|
592 |
+
)
|
593 |
+
|
594 |
+
yield from samples_ddim
|
595 |
+
|
596 |
+
def move_fs_to_cpu():
|
597 |
+
if device != "cpu":
|
598 |
+
mem = torch.cuda.memory_allocated() / 1e6
|
599 |
+
modelFS.to("cpu")
|
600 |
+
while torch.cuda.memory_allocated() / 1e6 >= mem:
|
601 |
+
time.sleep(1)
|
602 |
+
|
603 |
+
def gc():
|
604 |
+
if device == 'cpu':
|
605 |
+
return
|
606 |
+
|
607 |
+
torch.cuda.empty_cache()
|
608 |
+
torch.cuda.ipc_collect()
|
609 |
+
|
610 |
+
# internal
|
611 |
+
|
612 |
+
def chunk(it, size):
|
613 |
+
it = iter(it)
|
614 |
+
return iter(lambda: tuple(islice(it, size)), ())
|
615 |
+
|
616 |
+
|
617 |
+
def load_model_from_config(ckpt, verbose=False):
|
618 |
+
print(f"Loading model from {ckpt}")
|
619 |
+
pl_sd = torch.load(ckpt, map_location="cpu")
|
620 |
+
if "global_step" in pl_sd:
|
621 |
+
print(f"Global Step: {pl_sd['global_step']}")
|
622 |
+
sd = pl_sd["state_dict"]
|
623 |
+
return sd
|
624 |
+
|
625 |
+
# utils
|
626 |
+
class UserInitiatedStop(Exception):
|
627 |
+
pass
|
628 |
+
|
629 |
+
def load_img(img_str, w0, h0):
|
630 |
+
image = base64_str_to_img(img_str).convert("RGB")
|
631 |
+
w, h = image.size
|
632 |
+
print(f"loaded input image of size ({w}, {h}) from base64")
|
633 |
+
if h0 is not None and w0 is not None:
|
634 |
+
h, w = h0, w0
|
635 |
+
|
636 |
+
w, h = map(lambda x: x - x % 64, (w, h)) # resize to integer multiple of 64
|
637 |
+
image = image.resize((w, h), resample=Image.Resampling.LANCZOS)
|
638 |
+
image = np.array(image).astype(np.float32) / 255.0
|
639 |
+
image = image[None].transpose(0, 3, 1, 2)
|
640 |
+
image = torch.from_numpy(image)
|
641 |
+
return 2.*image - 1.
|
642 |
+
|
643 |
+
def load_mask(mask_str, h0, w0, newH, newW, invert=False):
|
644 |
+
image = base64_str_to_img(mask_str).convert("RGB")
|
645 |
+
w, h = image.size
|
646 |
+
print(f"loaded input mask of size ({w}, {h})")
|
647 |
+
|
648 |
+
if invert:
|
649 |
+
print("inverted")
|
650 |
+
image = ImageOps.invert(image)
|
651 |
+
# where_0, where_1 = np.where(image == 0), np.where(image == 255)
|
652 |
+
# image[where_0], image[where_1] = 255, 0
|
653 |
+
|
654 |
+
if h0 is not None and w0 is not None:
|
655 |
+
h, w = h0, w0
|
656 |
+
|
657 |
+
w, h = map(lambda x: x - x % 64, (w, h)) # resize to integer multiple of 64
|
658 |
+
|
659 |
+
print(f"New mask size ({w}, {h})")
|
660 |
+
image = image.resize((newW, newH), resample=Image.Resampling.LANCZOS)
|
661 |
+
image = np.array(image)
|
662 |
+
|
663 |
+
image = image.astype(np.float32) / 255.0
|
664 |
+
image = image[None].transpose(0, 3, 1, 2)
|
665 |
+
image = torch.from_numpy(image)
|
666 |
+
return image
|
667 |
+
|
668 |
+
# https://stackoverflow.com/a/61114178
|
669 |
+
def img_to_base64_str(img, output_format="PNG"):
|
670 |
+
buffered = BytesIO()
|
671 |
+
img.save(buffered, format=output_format)
|
672 |
+
buffered.seek(0)
|
673 |
+
img_byte = buffered.getvalue()
|
674 |
+
img_str = "data:image/png;base64," + base64.b64encode(img_byte).decode()
|
675 |
+
return img_str
|
676 |
+
|
677 |
+
def base64_str_to_img(img_str):
|
678 |
+
img_str = img_str[len("data:image/png;base64,"):]
|
679 |
+
data = base64.b64decode(img_str)
|
680 |
+
buffered = BytesIO(data)
|
681 |
+
img = Image.open(buffered)
|
682 |
+
return img
|
ui/scripts/Developer Console.cmd
ADDED
@@ -0,0 +1,14 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@echo off
|
2 |
+
|
3 |
+
echo "Opening Stable Diffusion UI - Developer Console.." & echo.
|
4 |
+
|
5 |
+
@call installer\Scripts\activate.bat
|
6 |
+
|
7 |
+
@call conda-unpack
|
8 |
+
|
9 |
+
@call conda --version
|
10 |
+
@call git --version
|
11 |
+
|
12 |
+
@call conda activate .\stable-diffusion\env
|
13 |
+
|
14 |
+
cmd /k
|
ui/scripts/Start Stable Diffusion UI.cmd
ADDED
@@ -0,0 +1,19 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@echo off
|
2 |
+
|
3 |
+
@REM Delete the post-activate hook from the old installer
|
4 |
+
if exist "installer\etc\conda\activate.d\post_activate.bat" (
|
5 |
+
echo. > installer\etc\conda\activate.d\post_activate.bat
|
6 |
+
)
|
7 |
+
|
8 |
+
@call installer\Scripts\activate.bat
|
9 |
+
|
10 |
+
@call conda-unpack
|
11 |
+
|
12 |
+
@call conda --version
|
13 |
+
@call git --version
|
14 |
+
|
15 |
+
@cd installer
|
16 |
+
|
17 |
+
@call ..\scripts\on_env_start.bat
|
18 |
+
|
19 |
+
@pause
|
ui/scripts/developer_console.sh
ADDED
@@ -0,0 +1,17 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
if [ "$0" == "bash" ]; then
|
4 |
+
echo "Opening Stable Diffusion UI - Developer Console.."
|
5 |
+
echo ""
|
6 |
+
|
7 |
+
source installer/bin/activate
|
8 |
+
|
9 |
+
conda-unpack
|
10 |
+
|
11 |
+
conda --version
|
12 |
+
git --version
|
13 |
+
|
14 |
+
conda activate ./stable-diffusion/env
|
15 |
+
else
|
16 |
+
bash --init-file developer_console.sh
|
17 |
+
fi
|
ui/scripts/on_env_start.bat
ADDED
@@ -0,0 +1,62 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@echo off
|
2 |
+
|
3 |
+
@echo. & echo "Stable Diffusion UI - v2" & echo.
|
4 |
+
|
5 |
+
set PATH=C:\Windows\System32;%PATH%
|
6 |
+
|
7 |
+
@cd ..
|
8 |
+
|
9 |
+
if exist "scripts\config.bat" (
|
10 |
+
@call scripts\config.bat
|
11 |
+
)
|
12 |
+
|
13 |
+
if "%update_branch%"=="" (
|
14 |
+
set update_branch=main
|
15 |
+
)
|
16 |
+
|
17 |
+
@>nul grep -c "conda_sd_ui_deps_installed" scripts\install_status.txt
|
18 |
+
@if "%ERRORLEVEL%" NEQ "0" (
|
19 |
+
for /f "tokens=*" %%a in ('python -c "import os; parts = os.getcwd().split(os.path.sep); print(len(parts))"') do if "%%a" NEQ "2" (
|
20 |
+
echo. & echo "!!!! WARNING !!!!" & echo.
|
21 |
+
echo "Your 'stable-diffusion-ui' folder is at %cd%" & echo.
|
22 |
+
echo "The 'stable-diffusion-ui' folder needs to be at the top of your drive, for e.g. 'C:\stable-diffusion-ui' or 'D:\stable-diffusion-ui' etc."
|
23 |
+
echo "Not placing this folder at the top of a drive can cause errors on some computers."
|
24 |
+
echo. & echo "Recommended: Please close this window and move the 'stable-diffusion-ui' folder to the top of a drive. For e.g. 'C:\stable-diffusion-ui'. Then run the installer again." & echo.
|
25 |
+
echo "Not Recommended: If you're sure that you want to install at the current location, please press any key to continue." & echo.
|
26 |
+
|
27 |
+
pause
|
28 |
+
)
|
29 |
+
)
|
30 |
+
|
31 |
+
@>nul grep -c "sd_ui_git_cloned" scripts\install_status.txt
|
32 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
33 |
+
@echo "Stable Diffusion UI's git repository was already installed. Updating from %update_branch%.."
|
34 |
+
|
35 |
+
@cd sd-ui-files
|
36 |
+
|
37 |
+
@call git reset --hard
|
38 |
+
@call git checkout "%update_branch%"
|
39 |
+
@call git pull
|
40 |
+
|
41 |
+
@cd ..
|
42 |
+
) else (
|
43 |
+
@echo. & echo "Downloading Stable Diffusion UI.." & echo.
|
44 |
+
@echo "Using the %update_branch% channel" & echo.
|
45 |
+
|
46 |
+
@call git clone -b "%update_branch%" https://github.com/cmdr2/stable-diffusion-ui.git sd-ui-files && (
|
47 |
+
@echo sd_ui_git_cloned >> scripts\install_status.txt
|
48 |
+
) || (
|
49 |
+
@echo "Error downloading Stable Diffusion UI. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!"
|
50 |
+
pause
|
51 |
+
@exit /b
|
52 |
+
)
|
53 |
+
)
|
54 |
+
|
55 |
+
@xcopy sd-ui-files\ui ui /s /i /Y
|
56 |
+
@copy sd-ui-files\scripts\on_sd_start.bat scripts\ /Y
|
57 |
+
@copy "sd-ui-files\scripts\Start Stable Diffusion UI.cmd" . /Y
|
58 |
+
@copy "sd-ui-files\scripts\Developer Console.cmd" . /Y
|
59 |
+
|
60 |
+
@call scripts\on_sd_start.bat
|
61 |
+
|
62 |
+
@pause
|
ui/scripts/on_env_start.sh
ADDED
@@ -0,0 +1,44 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
printf "\n\nStable Diffusion UI\n\n"
|
4 |
+
|
5 |
+
if [ -f "scripts/config.sh" ]; then
|
6 |
+
source scripts/config.sh
|
7 |
+
fi
|
8 |
+
|
9 |
+
if [ "$update_branch" == "" ]; then
|
10 |
+
export update_branch="main"
|
11 |
+
fi
|
12 |
+
|
13 |
+
if [ -f "scripts/install_status.txt" ] && [ `grep -c sd_ui_git_cloned scripts/install_status.txt` -gt "0" ]; then
|
14 |
+
echo "Stable Diffusion UI's git repository was already installed. Updating from $update_branch.."
|
15 |
+
|
16 |
+
cd sd-ui-files
|
17 |
+
|
18 |
+
git reset --hard
|
19 |
+
git checkout "$update_branch"
|
20 |
+
git pull
|
21 |
+
|
22 |
+
cd ..
|
23 |
+
else
|
24 |
+
printf "\n\nDownloading Stable Diffusion UI..\n\n"
|
25 |
+
printf "Using the $update_branch channel\n\n"
|
26 |
+
|
27 |
+
if git clone -b "$update_branch" https://github.com/cmdr2/stable-diffusion-ui.git sd-ui-files ; then
|
28 |
+
echo sd_ui_git_cloned >> scripts/install_status.txt
|
29 |
+
else
|
30 |
+
printf "\n\nError downloading Stable Diffusion UI. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
31 |
+
read -p "Press any key to continue"
|
32 |
+
exit
|
33 |
+
fi
|
34 |
+
fi
|
35 |
+
|
36 |
+
rm -rf ui
|
37 |
+
cp -Rf sd-ui-files/ui .
|
38 |
+
cp sd-ui-files/scripts/on_sd_start.sh scripts/
|
39 |
+
cp sd-ui-files/scripts/start.sh .
|
40 |
+
cp sd-ui-files/scripts/developer_console.sh .
|
41 |
+
|
42 |
+
./scripts/on_sd_start.sh
|
43 |
+
|
44 |
+
read -p "Press any key to continue"
|
ui/scripts/on_sd_start.bat
ADDED
@@ -0,0 +1,335 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@echo off
|
2 |
+
|
3 |
+
@copy sd-ui-files\scripts\on_env_start.bat scripts\ /Y
|
4 |
+
|
5 |
+
@REM Caution, this file will make your eyes and brain bleed. It's such an unholy mess.
|
6 |
+
@REM Note to self: Please rewrite this in Python. For the sake of your own sanity.
|
7 |
+
|
8 |
+
@copy "sd-ui-files\scripts\Developer Console.cmd" . /Y
|
9 |
+
if exist "Open Developer Console.cmd" del "Open Developer Console.cmd"
|
10 |
+
|
11 |
+
@call python -c "import os; import shutil; frm = 'sd-ui-files\\ui\\hotfix\\9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'; dst = os.path.join(os.path.expanduser('~'), '.cache', 'huggingface', 'transformers', '9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'); shutil.copyfile(frm, dst) if os.path.exists(dst) else print(''); print('Hotfixed broken JSON file from OpenAI');"
|
12 |
+
|
13 |
+
@>nul grep -c "sd_git_cloned" scripts\install_status.txt
|
14 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
15 |
+
@echo "Stable Diffusion's git repository was already installed. Updating.."
|
16 |
+
|
17 |
+
@cd stable-diffusion
|
18 |
+
|
19 |
+
@call git reset --hard
|
20 |
+
@call git pull
|
21 |
+
@call git checkout f6cfebffa752ee11a7b07497b8529d5971de916c
|
22 |
+
|
23 |
+
@call git apply ..\ui\sd_internal\ddim_callback.patch
|
24 |
+
@call git apply ..\ui\sd_internal\env_yaml.patch
|
25 |
+
|
26 |
+
@cd ..
|
27 |
+
) else (
|
28 |
+
@echo. & echo "Downloading Stable Diffusion.." & echo.
|
29 |
+
|
30 |
+
@call git clone https://github.com/basujindal/stable-diffusion.git && (
|
31 |
+
@echo sd_git_cloned >> scripts\install_status.txt
|
32 |
+
) || (
|
33 |
+
@echo "Error downloading Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!"
|
34 |
+
pause
|
35 |
+
@exit /b
|
36 |
+
)
|
37 |
+
|
38 |
+
@cd stable-diffusion
|
39 |
+
@call git checkout f6cfebffa752ee11a7b07497b8529d5971de916c
|
40 |
+
|
41 |
+
@call git apply ..\ui\sd_internal\ddim_callback.patch
|
42 |
+
@call git apply ..\ui\sd_internal\env_yaml.patch
|
43 |
+
|
44 |
+
@cd ..
|
45 |
+
)
|
46 |
+
|
47 |
+
@cd stable-diffusion
|
48 |
+
|
49 |
+
@>nul grep -c "conda_sd_env_created" ..\scripts\install_status.txt
|
50 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
51 |
+
@echo "Packages necessary for Stable Diffusion were already installed"
|
52 |
+
|
53 |
+
@call conda activate .\env
|
54 |
+
) else (
|
55 |
+
@echo. & echo "Downloading packages necessary for Stable Diffusion.." & echo. & echo "***** This will take some time (depending on the speed of the Internet connection) and may appear to be stuck, but please be patient ***** .." & echo.
|
56 |
+
|
57 |
+
@rmdir /s /q .\env
|
58 |
+
|
59 |
+
@REM prevent conda from using packages from the user's home directory, to avoid conflicts
|
60 |
+
@set PYTHONNOUSERSITE=1
|
61 |
+
|
62 |
+
set TMP=%cd%\tmp
|
63 |
+
set TEMP=%cd%\tmp
|
64 |
+
|
65 |
+
@call conda env create --prefix env -f environment.yaml || (
|
66 |
+
@echo. & echo "Error installing the packages necessary for Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
67 |
+
pause
|
68 |
+
exit /b
|
69 |
+
)
|
70 |
+
|
71 |
+
@call conda activate .\env
|
72 |
+
|
73 |
+
@call conda install -c conda-forge -y --prefix env antlr4-python3-runtime=4.8 || (
|
74 |
+
@echo. & echo "Error installing antlr4-python3-runtime for Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
75 |
+
pause
|
76 |
+
exit /b
|
77 |
+
)
|
78 |
+
|
79 |
+
for /f "tokens=*" %%a in ('python -c "import torch; import ldm; import transformers; import numpy; import antlr4; print(42)"') do if "%%a" NEQ "42" (
|
80 |
+
@echo. & echo "Dependency test failed! Error installing the packages necessary for Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
81 |
+
pause
|
82 |
+
exit /b
|
83 |
+
)
|
84 |
+
|
85 |
+
@echo conda_sd_env_created >> ..\scripts\install_status.txt
|
86 |
+
)
|
87 |
+
|
88 |
+
set PATH=C:\Windows\System32;%PATH%
|
89 |
+
|
90 |
+
@>nul grep -c "conda_sd_gfpgan_deps_installed" ..\scripts\install_status.txt
|
91 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
92 |
+
@echo "Packages necessary for GFPGAN (Face Correction) were already installed"
|
93 |
+
) else (
|
94 |
+
@echo. & echo "Downloading packages necessary for GFPGAN (Face Correction).." & echo.
|
95 |
+
|
96 |
+
@set PYTHONNOUSERSITE=1
|
97 |
+
|
98 |
+
set TMP=%cd%\tmp
|
99 |
+
set TEMP=%cd%\tmp
|
100 |
+
|
101 |
+
@call pip install -e git+https://github.com/TencentARC/GFPGAN#egg=GFPGAN || (
|
102 |
+
@echo. & echo "Error installing the packages necessary for GFPGAN (Face Correction). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
103 |
+
pause
|
104 |
+
exit /b
|
105 |
+
)
|
106 |
+
|
107 |
+
@call pip install basicsr==1.4.2 || (
|
108 |
+
@echo. & echo "Error installing the basicsr package necessary for GFPGAN (Face Correction). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
109 |
+
pause
|
110 |
+
exit /b
|
111 |
+
)
|
112 |
+
|
113 |
+
for /f "tokens=*" %%a in ('python -c "from gfpgan import GFPGANer; print(42)"') do if "%%a" NEQ "42" (
|
114 |
+
@echo. & echo "Dependency test failed! Error installing the packages necessary for GFPGAN (Face Correction). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
115 |
+
pause
|
116 |
+
exit /b
|
117 |
+
)
|
118 |
+
|
119 |
+
@echo conda_sd_gfpgan_deps_installed >> ..\scripts\install_status.txt
|
120 |
+
)
|
121 |
+
|
122 |
+
@>nul grep -c "conda_sd_esrgan_deps_installed" ..\scripts\install_status.txt
|
123 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
124 |
+
@echo "Packages necessary for ESRGAN (Resolution Upscaling) were already installed"
|
125 |
+
) else (
|
126 |
+
@echo. & echo "Downloading packages necessary for ESRGAN (Resolution Upscaling).." & echo.
|
127 |
+
|
128 |
+
@set PYTHONNOUSERSITE=1
|
129 |
+
|
130 |
+
set TMP=%cd%\tmp
|
131 |
+
set TEMP=%cd%\tmp
|
132 |
+
|
133 |
+
@call pip install -e git+https://github.com/xinntao/Real-ESRGAN#egg=realesrgan || (
|
134 |
+
@echo. & echo "Error installing the packages necessary for ESRGAN (Resolution Upscaling). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
135 |
+
pause
|
136 |
+
exit /b
|
137 |
+
)
|
138 |
+
|
139 |
+
for /f "tokens=*" %%a in ('python -c "from basicsr.archs.rrdbnet_arch import RRDBNet; from realesrgan import RealESRGANer; print(42)"') do if "%%a" NEQ "42" (
|
140 |
+
@echo. & echo "Dependency test failed! Error installing the packages necessary for ESRGAN (Resolution Upscaling). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
141 |
+
pause
|
142 |
+
exit /b
|
143 |
+
)
|
144 |
+
|
145 |
+
@echo conda_sd_esrgan_deps_installed >> ..\scripts\install_status.txt
|
146 |
+
)
|
147 |
+
|
148 |
+
@>nul grep -c "conda_sd_ui_deps_installed" ..\scripts\install_status.txt
|
149 |
+
@if "%ERRORLEVEL%" EQU "0" (
|
150 |
+
echo "Packages necessary for Stable Diffusion UI were already installed"
|
151 |
+
) else (
|
152 |
+
@echo. & echo "Downloading packages necessary for Stable Diffusion UI.." & echo.
|
153 |
+
|
154 |
+
@set PYTHONNOUSERSITE=1
|
155 |
+
|
156 |
+
set TMP=%cd%\tmp
|
157 |
+
set TEMP=%cd%\tmp
|
158 |
+
|
159 |
+
@call conda install -c conda-forge -y --prefix env uvicorn fastapi || (
|
160 |
+
echo "Error installing the packages necessary for Stable Diffusion UI. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!"
|
161 |
+
pause
|
162 |
+
exit /b
|
163 |
+
)
|
164 |
+
)
|
165 |
+
|
166 |
+
call WHERE uvicorn > .tmp
|
167 |
+
@>nul grep -c "uvicorn" .tmp
|
168 |
+
@if "%ERRORLEVEL%" NEQ "0" (
|
169 |
+
@echo. & echo "UI packages not found! Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
170 |
+
pause
|
171 |
+
exit /b
|
172 |
+
)
|
173 |
+
|
174 |
+
@>nul grep -c "conda_sd_ui_deps_installed" ..\scripts\install_status.txt
|
175 |
+
@if "%ERRORLEVEL%" NEQ "0" (
|
176 |
+
@echo conda_sd_ui_deps_installed >> ..\scripts\install_status.txt
|
177 |
+
)
|
178 |
+
|
179 |
+
|
180 |
+
|
181 |
+
if not exist "..\models\stable-diffusion" mkdir "..\models\stable-diffusion"
|
182 |
+
echo. > "..\models\stable-diffusion\Put your custom ckpt files here.txt"
|
183 |
+
|
184 |
+
@if exist "sd-v1-4.ckpt" (
|
185 |
+
for %%I in ("sd-v1-4.ckpt") do if "%%~zI" EQU "4265380512" (
|
186 |
+
echo "Data files (weights) necessary for Stable Diffusion were already downloaded. Using the HuggingFace 4 GB Model."
|
187 |
+
) else (
|
188 |
+
for %%J in ("sd-v1-4.ckpt") do if "%%~zJ" EQU "7703807346" (
|
189 |
+
echo "Data files (weights) necessary for Stable Diffusion were already downloaded. Using the HuggingFace 7 GB Model."
|
190 |
+
) else (
|
191 |
+
for %%K in ("sd-v1-4.ckpt") do if "%%~zK" EQU "7703810927" (
|
192 |
+
echo "Data files (weights) necessary for Stable Diffusion were already downloaded. Using the Waifu Model."
|
193 |
+
) else (
|
194 |
+
echo. & echo "The model file present at %cd%\sd-v1-4.ckpt is invalid. It is only %%~zK bytes in size. Re-downloading.." & echo.
|
195 |
+
del "sd-v1-4.ckpt"
|
196 |
+
)
|
197 |
+
)
|
198 |
+
)
|
199 |
+
)
|
200 |
+
|
201 |
+
@if not exist "sd-v1-4.ckpt" (
|
202 |
+
@echo. & echo "Downloading data files (weights) for Stable Diffusion.." & echo.
|
203 |
+
|
204 |
+
@call curl -L -k https://me.cmdr2.org/stable-diffusion-ui/sd-v1-4.ckpt > sd-v1-4.ckpt
|
205 |
+
|
206 |
+
@if exist "sd-v1-4.ckpt" (
|
207 |
+
for %%I in ("sd-v1-4.ckpt") do if "%%~zI" NEQ "4265380512" (
|
208 |
+
echo. & echo "Error: The downloaded model file was invalid! Bytes downloaded: %%~zI" & echo.
|
209 |
+
echo. & echo "Error downloading the data files (weights) for Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
210 |
+
pause
|
211 |
+
exit /b
|
212 |
+
)
|
213 |
+
) else (
|
214 |
+
@echo. & echo "Error downloading the data files (weights) for Stable Diffusion. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
215 |
+
pause
|
216 |
+
exit /b
|
217 |
+
)
|
218 |
+
)
|
219 |
+
|
220 |
+
|
221 |
+
|
222 |
+
@if exist "GFPGANv1.3.pth" (
|
223 |
+
for %%I in ("GFPGANv1.3.pth") do if "%%~zI" EQU "348632874" (
|
224 |
+
echo "Data files (weights) necessary for GFPGAN (Face Correction) were already downloaded"
|
225 |
+
) else (
|
226 |
+
echo. & echo "The GFPGAN model file present at %cd%\GFPGANv1.3.pth is invalid. It is only %%~zI bytes in size. Re-downloading.." & echo.
|
227 |
+
del "GFPGANv1.3.pth"
|
228 |
+
)
|
229 |
+
)
|
230 |
+
|
231 |
+
@if not exist "GFPGANv1.3.pth" (
|
232 |
+
@echo. & echo "Downloading data files (weights) for GFPGAN (Face Correction).." & echo.
|
233 |
+
|
234 |
+
@call curl -L -k https://github.com/TencentARC/GFPGAN/releases/download/v1.3.0/GFPGANv1.3.pth > GFPGANv1.3.pth
|
235 |
+
|
236 |
+
@if exist "GFPGANv1.3.pth" (
|
237 |
+
for %%I in ("GFPGANv1.3.pth") do if "%%~zI" NEQ "348632874" (
|
238 |
+
echo. & echo "Error: The downloaded GFPGAN model file was invalid! Bytes downloaded: %%~zI" & echo.
|
239 |
+
echo. & echo "Error downloading the data files (weights) for GFPGAN (Face Correction). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
240 |
+
pause
|
241 |
+
exit /b
|
242 |
+
)
|
243 |
+
) else (
|
244 |
+
@echo. & echo "Error downloading the data files (weights) for GFPGAN (Face Correction). Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
245 |
+
pause
|
246 |
+
exit /b
|
247 |
+
)
|
248 |
+
)
|
249 |
+
|
250 |
+
|
251 |
+
|
252 |
+
@if exist "RealESRGAN_x4plus.pth" (
|
253 |
+
for %%I in ("RealESRGAN_x4plus.pth") do if "%%~zI" EQU "67040989" (
|
254 |
+
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus were already downloaded"
|
255 |
+
) else (
|
256 |
+
echo. & echo "The GFPGAN model file present at %cd%\RealESRGAN_x4plus.pth is invalid. It is only %%~zI bytes in size. Re-downloading.." & echo.
|
257 |
+
del "RealESRGAN_x4plus.pth"
|
258 |
+
)
|
259 |
+
)
|
260 |
+
|
261 |
+
@if not exist "RealESRGAN_x4plus.pth" (
|
262 |
+
@echo. & echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus.." & echo.
|
263 |
+
|
264 |
+
@call curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.1.0/RealESRGAN_x4plus.pth > RealESRGAN_x4plus.pth
|
265 |
+
|
266 |
+
@if exist "RealESRGAN_x4plus.pth" (
|
267 |
+
for %%I in ("RealESRGAN_x4plus.pth") do if "%%~zI" NEQ "67040989" (
|
268 |
+
echo. & echo "Error: The downloaded ESRGAN x4plus model file was invalid! Bytes downloaded: %%~zI" & echo.
|
269 |
+
echo. & echo "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
270 |
+
pause
|
271 |
+
exit /b
|
272 |
+
)
|
273 |
+
) else (
|
274 |
+
@echo. & echo "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
275 |
+
pause
|
276 |
+
exit /b
|
277 |
+
)
|
278 |
+
)
|
279 |
+
|
280 |
+
|
281 |
+
|
282 |
+
@if exist "RealESRGAN_x4plus_anime_6B.pth" (
|
283 |
+
for %%I in ("RealESRGAN_x4plus_anime_6B.pth") do if "%%~zI" EQU "17938799" (
|
284 |
+
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus_anime were already downloaded"
|
285 |
+
) else (
|
286 |
+
echo. & echo "The GFPGAN model file present at %cd%\RealESRGAN_x4plus_anime_6B.pth is invalid. It is only %%~zI bytes in size. Re-downloading.." & echo.
|
287 |
+
del "RealESRGAN_x4plus_anime_6B.pth"
|
288 |
+
)
|
289 |
+
)
|
290 |
+
|
291 |
+
@if not exist "RealESRGAN_x4plus_anime_6B.pth" (
|
292 |
+
@echo. & echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime.." & echo.
|
293 |
+
|
294 |
+
@call curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.2.2.4/RealESRGAN_x4plus_anime_6B.pth > RealESRGAN_x4plus_anime_6B.pth
|
295 |
+
|
296 |
+
@if exist "RealESRGAN_x4plus_anime_6B.pth" (
|
297 |
+
for %%I in ("RealESRGAN_x4plus_anime_6B.pth") do if "%%~zI" NEQ "17938799" (
|
298 |
+
echo. & echo "Error: The downloaded ESRGAN x4plus_anime model file was invalid! Bytes downloaded: %%~zI" & echo.
|
299 |
+
echo. & echo "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
300 |
+
pause
|
301 |
+
exit /b
|
302 |
+
)
|
303 |
+
) else (
|
304 |
+
@echo. & echo "Error downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime. Sorry about that, please try to:" & echo " 1. Run this installer again." & echo " 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md" & echo " 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB" & echo " 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues" & echo "Thanks!" & echo.
|
305 |
+
pause
|
306 |
+
exit /b
|
307 |
+
)
|
308 |
+
)
|
309 |
+
|
310 |
+
|
311 |
+
|
312 |
+
@>nul grep -c "sd_install_complete" ..\scripts\install_status.txt
|
313 |
+
@if "%ERRORLEVEL%" NEQ "0" (
|
314 |
+
@echo sd_weights_downloaded >> ..\scripts\install_status.txt
|
315 |
+
@echo sd_install_complete >> ..\scripts\install_status.txt
|
316 |
+
)
|
317 |
+
|
318 |
+
@echo. & echo "Stable Diffusion is ready!" & echo.
|
319 |
+
|
320 |
+
@set SD_DIR=%cd%
|
321 |
+
|
322 |
+
@cd env\lib\site-packages
|
323 |
+
@set PYTHONPATH=%SD_DIR%;%cd%
|
324 |
+
@cd ..\..\..
|
325 |
+
@echo PYTHONPATH=%PYTHONPATH%
|
326 |
+
|
327 |
+
@cd ..
|
328 |
+
@set SD_UI_PATH=%cd%\ui
|
329 |
+
@cd stable-diffusion
|
330 |
+
|
331 |
+
@call python --version
|
332 |
+
|
333 |
+
@uvicorn server:app --app-dir "%SD_UI_PATH%" --port 9000 --host 0.0.0.0
|
334 |
+
|
335 |
+
@pause
|
ui/scripts/on_sd_start.sh
ADDED
@@ -0,0 +1,317 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
cp sd-ui-files/scripts/on_env_start.sh scripts/
|
4 |
+
|
5 |
+
source installer/etc/profile.d/conda.sh
|
6 |
+
|
7 |
+
cp sd-ui-files/scripts/developer_console.sh .
|
8 |
+
if [ -e "open_dev_console.sh" ]; then
|
9 |
+
rm "open_dev_console.sh"
|
10 |
+
fi
|
11 |
+
|
12 |
+
python -c "import os; import shutil; frm = 'sd-ui-files/ui/hotfix/9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'; dst = os.path.join(os.path.expanduser('~'), '.cache', 'huggingface', 'transformers', '9c24e6cd9f499d02c4f21a033736dabd365962dc80fe3aeb57a8f85ea45a20a3.26fead7ea4f0f843f6eb4055dfd25693f1a71f3c6871b184042d4b126244e142'); shutil.copyfile(frm, dst) if os.path.exists(dst) else print(''); print('Hotfixed broken JSON file from OpenAI');"
|
13 |
+
|
14 |
+
# Caution, this file will make your eyes and brain bleed. It's such an unholy mess.
|
15 |
+
# Note to self: Please rewrite this in Python. For the sake of your own sanity.
|
16 |
+
|
17 |
+
if [ -e "scripts/install_status.txt" ] && [ `grep -c sd_git_cloned scripts/install_status.txt` -gt "0" ]; then
|
18 |
+
echo "Stable Diffusion's git repository was already installed. Updating.."
|
19 |
+
|
20 |
+
cd stable-diffusion
|
21 |
+
|
22 |
+
git reset --hard
|
23 |
+
git pull
|
24 |
+
git checkout f6cfebffa752ee11a7b07497b8529d5971de916c
|
25 |
+
|
26 |
+
git apply ../ui/sd_internal/ddim_callback.patch
|
27 |
+
git apply ../ui/sd_internal/env_yaml.patch
|
28 |
+
|
29 |
+
cd ..
|
30 |
+
else
|
31 |
+
printf "\n\nDownloading Stable Diffusion..\n\n"
|
32 |
+
|
33 |
+
if git clone https://github.com/basujindal/stable-diffusion.git ; then
|
34 |
+
echo sd_git_cloned >> scripts/install_status.txt
|
35 |
+
else
|
36 |
+
printf "\n\nError downloading Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
37 |
+
read -p "Press any key to continue"
|
38 |
+
exit
|
39 |
+
fi
|
40 |
+
|
41 |
+
cd stable-diffusion
|
42 |
+
git checkout f6cfebffa752ee11a7b07497b8529d5971de916c
|
43 |
+
|
44 |
+
git apply ../ui/sd_internal/ddim_callback.patch
|
45 |
+
git apply ../ui/sd_internal/env_yaml.patch
|
46 |
+
|
47 |
+
cd ..
|
48 |
+
fi
|
49 |
+
|
50 |
+
cd stable-diffusion
|
51 |
+
|
52 |
+
if [ `grep -c conda_sd_env_created ../scripts/install_status.txt` -gt "0" ]; then
|
53 |
+
echo "Packages necessary for Stable Diffusion were already installed"
|
54 |
+
|
55 |
+
conda activate ./env
|
56 |
+
else
|
57 |
+
printf "\n\nDownloading packages necessary for Stable Diffusion..\n"
|
58 |
+
printf "\n\n***** This will take some time (depending on the speed of the Internet connection) and may appear to be stuck, but please be patient ***** ..\n\n"
|
59 |
+
|
60 |
+
# prevent conda from using packages from the user's home directory, to avoid conflicts
|
61 |
+
export PYTHONNOUSERSITE=1
|
62 |
+
|
63 |
+
if conda env create --prefix env --force -f environment.yaml ; then
|
64 |
+
echo "Installed. Testing.."
|
65 |
+
else
|
66 |
+
printf "\n\nError installing the packages necessary for Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
67 |
+
read -p "Press any key to continue"
|
68 |
+
exit
|
69 |
+
fi
|
70 |
+
|
71 |
+
conda activate ./env
|
72 |
+
|
73 |
+
if conda install -c conda-forge --prefix ./env -y antlr4-python3-runtime=4.8 ; then
|
74 |
+
echo "Installed. Testing.."
|
75 |
+
else
|
76 |
+
printf "\n\nError installing antlr4-python3-runtime for Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
77 |
+
read -p "Press any key to continue"
|
78 |
+
exit
|
79 |
+
fi
|
80 |
+
|
81 |
+
out_test=`python -c "import torch; import ldm; import transformers; import numpy; import antlr4; print(42)"`
|
82 |
+
if [ "$out_test" != "42" ]; then
|
83 |
+
printf "\n\nDependency test failed! Error installing the packages necessary for Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
84 |
+
read -p "Press any key to continue"
|
85 |
+
exit
|
86 |
+
fi
|
87 |
+
|
88 |
+
echo conda_sd_env_created >> ../scripts/install_status.txt
|
89 |
+
fi
|
90 |
+
|
91 |
+
if [ `grep -c conda_sd_gfpgan_deps_installed ../scripts/install_status.txt` -gt "0" ]; then
|
92 |
+
echo "Packages necessary for GFPGAN (Face Correction) were already installed"
|
93 |
+
else
|
94 |
+
printf "\n\nDownloading packages necessary for GFPGAN (Face Correction)..\n"
|
95 |
+
|
96 |
+
export PYTHONNOUSERSITE=1
|
97 |
+
|
98 |
+
if pip install -e git+https://github.com/TencentARC/GFPGAN#egg=GFPGAN ; then
|
99 |
+
echo "Installed. Testing.."
|
100 |
+
else
|
101 |
+
printf "\n\nError installing the packages necessary for GFPGAN (Face Correction). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
102 |
+
read -p "Press any key to continue"
|
103 |
+
exit
|
104 |
+
fi
|
105 |
+
|
106 |
+
out_test=`python -c "from gfpgan import GFPGANer; print(42)"`
|
107 |
+
if [ "$out_test" != "42" ]; then
|
108 |
+
printf "\n\nDependency test failed! Error installing the packages necessary for GFPGAN (Face Correction). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
109 |
+
read -p "Press any key to continue"
|
110 |
+
exit
|
111 |
+
fi
|
112 |
+
|
113 |
+
echo conda_sd_gfpgan_deps_installed >> ../scripts/install_status.txt
|
114 |
+
fi
|
115 |
+
|
116 |
+
if [ `grep -c conda_sd_esrgan_deps_installed ../scripts/install_status.txt` -gt "0" ]; then
|
117 |
+
echo "Packages necessary for ESRGAN (Resolution Upscaling) were already installed"
|
118 |
+
else
|
119 |
+
printf "\n\nDownloading packages necessary for ESRGAN (Resolution Upscaling)..\n"
|
120 |
+
|
121 |
+
export PYTHONNOUSERSITE=1
|
122 |
+
|
123 |
+
if pip install -e git+https://github.com/xinntao/Real-ESRGAN#egg=realesrgan ; then
|
124 |
+
echo "Installed. Testing.."
|
125 |
+
else
|
126 |
+
printf "\n\nError installing the packages necessary for ESRGAN (Resolution Upscaling). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
127 |
+
read -p "Press any key to continue"
|
128 |
+
exit
|
129 |
+
fi
|
130 |
+
|
131 |
+
out_test=`python -c "from basicsr.archs.rrdbnet_arch import RRDBNet; from realesrgan import RealESRGANer; print(42)"`
|
132 |
+
if [ "$out_test" != "42" ]; then
|
133 |
+
printf "\n\nDependency test failed! Error installing the packages necessary for ESRGAN (Resolution Upscaling). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
134 |
+
read -p "Press any key to continue"
|
135 |
+
exit
|
136 |
+
fi
|
137 |
+
|
138 |
+
echo conda_sd_esrgan_deps_installed >> ../scripts/install_status.txt
|
139 |
+
fi
|
140 |
+
|
141 |
+
if [ `grep -c conda_sd_ui_deps_installed ../scripts/install_status.txt` -gt "0" ]; then
|
142 |
+
echo "Packages necessary for Stable Diffusion UI were already installed"
|
143 |
+
else
|
144 |
+
printf "\n\nDownloading packages necessary for Stable Diffusion UI..\n\n"
|
145 |
+
|
146 |
+
export PYTHONNOUSERSITE=1
|
147 |
+
|
148 |
+
if conda install -c conda-forge --prefix ./env -y uvicorn fastapi ; then
|
149 |
+
echo "Installed. Testing.."
|
150 |
+
else
|
151 |
+
printf "\n\nError installing the packages necessary for Stable Diffusion UI. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
152 |
+
read -p "Press any key to continue"
|
153 |
+
exit
|
154 |
+
fi
|
155 |
+
|
156 |
+
if ! command -v uvicorn &> /dev/null; then
|
157 |
+
printf "\n\nUI packages not found! Error installing the packages necessary for Stable Diffusion UI. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
158 |
+
read -p "Press any key to continue"
|
159 |
+
exit
|
160 |
+
fi
|
161 |
+
|
162 |
+
echo conda_sd_ui_deps_installed >> ../scripts/install_status.txt
|
163 |
+
fi
|
164 |
+
|
165 |
+
|
166 |
+
|
167 |
+
mkdir -p "../models/stable-diffusion"
|
168 |
+
echo "" > "../models/stable-diffusion/Put your custom ckpt files here.txt"
|
169 |
+
|
170 |
+
if [ -f "sd-v1-4.ckpt" ]; then
|
171 |
+
model_size=`find "sd-v1-4.ckpt" -printf "%s"`
|
172 |
+
|
173 |
+
if [ "$model_size" -eq "4265380512" ] || [ "$model_size" -eq "7703807346" ] || [ "$model_size" -eq "7703810927" ]; then
|
174 |
+
echo "Data files (weights) necessary for Stable Diffusion were already downloaded"
|
175 |
+
else
|
176 |
+
printf "\n\nThe model file present at $PWD/sd-v1-4.ckpt is invalid. It is only $model_size bytes in size. Re-downloading.."
|
177 |
+
rm sd-v1-4.ckpt
|
178 |
+
fi
|
179 |
+
fi
|
180 |
+
|
181 |
+
if [ ! -f "sd-v1-4.ckpt" ]; then
|
182 |
+
echo "Downloading data files (weights) for Stable Diffusion.."
|
183 |
+
|
184 |
+
curl -L -k https://me.cmdr2.org/stable-diffusion-ui/sd-v1-4.ckpt > sd-v1-4.ckpt
|
185 |
+
|
186 |
+
if [ -f "sd-v1-4.ckpt" ]; then
|
187 |
+
model_size=`find "sd-v1-4.ckpt" -printf "%s"`
|
188 |
+
if [ ! "$model_size" == "4265380512" ]; then
|
189 |
+
printf "\n\nError: The downloaded model file was invalid! Bytes downloaded: $model_size\n\n"
|
190 |
+
printf "\n\nError downloading the data files (weights) for Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
191 |
+
read -p "Press any key to continue"
|
192 |
+
exit
|
193 |
+
fi
|
194 |
+
else
|
195 |
+
printf "\n\nError downloading the data files (weights) for Stable Diffusion. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
196 |
+
read -p "Press any key to continue"
|
197 |
+
exit
|
198 |
+
fi
|
199 |
+
fi
|
200 |
+
|
201 |
+
|
202 |
+
if [ -f "GFPGANv1.3.pth" ]; then
|
203 |
+
model_size=`find "GFPGANv1.3.pth" -printf "%s"`
|
204 |
+
|
205 |
+
if [ "$model_size" -eq "348632874" ]; then
|
206 |
+
echo "Data files (weights) necessary for GFPGAN (Face Correction) were already downloaded"
|
207 |
+
else
|
208 |
+
printf "\n\nThe model file present at $PWD/GFPGANv1.3.pth is invalid. It is only $model_size bytes in size. Re-downloading.."
|
209 |
+
rm GFPGANv1.3.pth
|
210 |
+
fi
|
211 |
+
fi
|
212 |
+
|
213 |
+
if [ ! -f "GFPGANv1.3.pth" ]; then
|
214 |
+
echo "Downloading data files (weights) for GFPGAN (Face Correction).."
|
215 |
+
|
216 |
+
curl -L -k https://github.com/TencentARC/GFPGAN/releases/download/v1.3.0/GFPGANv1.3.pth > GFPGANv1.3.pth
|
217 |
+
|
218 |
+
if [ -f "GFPGANv1.3.pth" ]; then
|
219 |
+
model_size=`find "GFPGANv1.3.pth" -printf "%s"`
|
220 |
+
if [ ! "$model_size" -eq "348632874" ]; then
|
221 |
+
printf "\n\nError: The downloaded GFPGAN model file was invalid! Bytes downloaded: $model_size\n\n"
|
222 |
+
printf "\n\nError downloading the data files (weights) for GFPGAN (Face Correction). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
223 |
+
read -p "Press any key to continue"
|
224 |
+
exit
|
225 |
+
fi
|
226 |
+
else
|
227 |
+
printf "\n\nError downloading the data files (weights) for GFPGAN (Face Correction). Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
228 |
+
read -p "Press any key to continue"
|
229 |
+
exit
|
230 |
+
fi
|
231 |
+
fi
|
232 |
+
|
233 |
+
|
234 |
+
if [ -f "RealESRGAN_x4plus.pth" ]; then
|
235 |
+
model_size=`find "RealESRGAN_x4plus.pth" -printf "%s"`
|
236 |
+
|
237 |
+
if [ "$model_size" -eq "67040989" ]; then
|
238 |
+
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus were already downloaded"
|
239 |
+
else
|
240 |
+
printf "\n\nThe model file present at $PWD/RealESRGAN_x4plus.pth is invalid. It is only $model_size bytes in size. Re-downloading.."
|
241 |
+
rm RealESRGAN_x4plus.pth
|
242 |
+
fi
|
243 |
+
fi
|
244 |
+
|
245 |
+
if [ ! -f "RealESRGAN_x4plus.pth" ]; then
|
246 |
+
echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus.."
|
247 |
+
|
248 |
+
curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.1.0/RealESRGAN_x4plus.pth > RealESRGAN_x4plus.pth
|
249 |
+
|
250 |
+
if [ -f "RealESRGAN_x4plus.pth" ]; then
|
251 |
+
model_size=`find "RealESRGAN_x4plus.pth" -printf "%s"`
|
252 |
+
if [ ! "$model_size" -eq "67040989" ]; then
|
253 |
+
printf "\n\nError: The downloaded ESRGAN x4plus model file was invalid! Bytes downloaded: $model_size\n\n"
|
254 |
+
printf "\n\nError downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
255 |
+
read -p "Press any key to continue"
|
256 |
+
exit
|
257 |
+
fi
|
258 |
+
else
|
259 |
+
printf "\n\nError downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
260 |
+
read -p "Press any key to continue"
|
261 |
+
exit
|
262 |
+
fi
|
263 |
+
fi
|
264 |
+
|
265 |
+
|
266 |
+
if [ -f "RealESRGAN_x4plus_anime_6B.pth" ]; then
|
267 |
+
model_size=`find "RealESRGAN_x4plus_anime_6B.pth" -printf "%s"`
|
268 |
+
|
269 |
+
if [ "$model_size" -eq "17938799" ]; then
|
270 |
+
echo "Data files (weights) necessary for ESRGAN (Resolution Upscaling) x4plus_anime were already downloaded"
|
271 |
+
else
|
272 |
+
printf "\n\nThe model file present at $PWD/RealESRGAN_x4plus_anime_6B.pth is invalid. It is only $model_size bytes in size. Re-downloading.."
|
273 |
+
rm RealESRGAN_x4plus_anime_6B.pth
|
274 |
+
fi
|
275 |
+
fi
|
276 |
+
|
277 |
+
if [ ! -f "RealESRGAN_x4plus_anime_6B.pth" ]; then
|
278 |
+
echo "Downloading data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime.."
|
279 |
+
|
280 |
+
curl -L -k https://github.com/xinntao/Real-ESRGAN/releases/download/v0.2.2.4/RealESRGAN_x4plus_anime_6B.pth > RealESRGAN_x4plus_anime_6B.pth
|
281 |
+
|
282 |
+
if [ -f "RealESRGAN_x4plus_anime_6B.pth" ]; then
|
283 |
+
model_size=`find "RealESRGAN_x4plus_anime_6B.pth" -printf "%s"`
|
284 |
+
if [ ! "$model_size" -eq "17938799" ]; then
|
285 |
+
printf "\n\nError: The downloaded ESRGAN x4plus_anime model file was invalid! Bytes downloaded: $model_size\n\n"
|
286 |
+
printf "\n\nError downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
287 |
+
read -p "Press any key to continue"
|
288 |
+
exit
|
289 |
+
fi
|
290 |
+
else
|
291 |
+
printf "\n\nError downloading the data files (weights) for ESRGAN (Resolution Upscaling) x4plus_anime. Sorry about that, please try to:\n 1. Run this installer again.\n 2. If that doesn't fix it, please try the common troubleshooting steps at https://github.com/cmdr2/stable-diffusion-ui/blob/main/Troubleshooting.md\n 3. If those steps don't help, please copy *all* the error messages in this window, and ask the community at https://discord.com/invite/u9yhsFmEkB\n 4. If that doesn't solve the problem, please file an issue at https://github.com/cmdr2/stable-diffusion-ui/issues\nThanks!\n\n"
|
292 |
+
read -p "Press any key to continue"
|
293 |
+
exit
|
294 |
+
fi
|
295 |
+
fi
|
296 |
+
|
297 |
+
|
298 |
+
if [ `grep -c sd_install_complete ../scripts/install_status.txt` -gt "0" ]; then
|
299 |
+
echo sd_weights_downloaded >> ../scripts/install_status.txt
|
300 |
+
echo sd_install_complete >> ../scripts/install_status.txt
|
301 |
+
fi
|
302 |
+
|
303 |
+
printf "\n\nStable Diffusion is ready!\n\n"
|
304 |
+
|
305 |
+
SD_PATH=`pwd`
|
306 |
+
export PYTHONPATH="$SD_PATH;$SD_PATH/env/lib/python3.8/site-packages"
|
307 |
+
echo "PYTHONPATH=$PYTHONPATH"
|
308 |
+
|
309 |
+
cd ..
|
310 |
+
export SD_UI_PATH=`pwd`/ui
|
311 |
+
cd stable-diffusion
|
312 |
+
|
313 |
+
python --version
|
314 |
+
|
315 |
+
uvicorn server:app --app-dir "$SD_UI_PATH" --port 9000 --host 0.0.0.0
|
316 |
+
|
317 |
+
read -p "Press any key to continue"
|
ui/scripts/post_activate.bat
ADDED
@@ -0,0 +1,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
@call conda --version
|
2 |
+
@call git --version
|
3 |
+
|
4 |
+
cd %CONDA_PREFIX%\..\scripts
|
5 |
+
|
6 |
+
on_env_start.bat
|
ui/scripts/post_activate.sh
ADDED
@@ -0,0 +1,12 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
conda-unpack
|
4 |
+
|
5 |
+
source $CONDA_PREFIX/etc/profile.d/conda.sh
|
6 |
+
|
7 |
+
conda --version
|
8 |
+
git --version
|
9 |
+
|
10 |
+
cd $CONDA_PREFIX/../scripts
|
11 |
+
|
12 |
+
./on_env_start.sh
|
ui/scripts/start.sh
ADDED
@@ -0,0 +1,10 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
#!/bin/bash
|
2 |
+
|
3 |
+
source installer/bin/activate
|
4 |
+
|
5 |
+
conda-unpack
|
6 |
+
|
7 |
+
conda --version
|
8 |
+
git --version
|
9 |
+
|
10 |
+
scripts/on_env_start.sh
|
ui/scripts/win_enable_long_filepaths.ps1
ADDED
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
1 |
+
Set-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Control\FileSystem' -Name LongPathsEnabled -Type DWord -Value 1
|
2 |
+
pause
|