File size: 20,804 Bytes
f86ef0c a67e848 f86ef0c 55f4105 075c1d2 f86ef0c 501dcf9 6048078 742c437 f86ef0c bf04964 19c7a03 efb17c0 08c972a 6146bcd 6c7d09c d401370 491fb35 d401370 ee150fa d401370 491fb35 269d4a1 d401370 491fb35 d401370 269d4a1 d401370 491fb35 d401370 491fb35 d401370 491fb35 d401370 491fb35 ee150fa 6c7d09c fa1a7dd 491fb35 fa1a7dd d401370 6146bcd 60053a1 ae56df6 e4ba354 9982bae ae56df6 9982bae a336afa bc1bfe7 6048078 a336afa 6048078 75198da a336afa 6048078 a336afa b0a0480 26e2d09 f00b283 34ac09b b0a0480 8fa2f5f ba50e07 b8769f7 b0a0480 2eabd10 b0a0480 2eabd10 6048078 b0a0480 a73a7f0 ae56df6 b0a0480 4ec8772 55dc243 26e2d09 02c69a2 738cffc 7574f1d 064626b f86ef0c f5b7834 f86ef0c 3d995e6 5ee45c4 f86ef0c 227d5b9 2f15231 99b52bd 2f15231 4d84d7a 9727a12 227d5b9 76f9716 f86ef0c 1b0d98c a47cafd eb5cb7c f86ef0c bc1bfe7 b0f5912 e577eb4 cb1a375 b0f5912 cb1a375 0c784ce a336afa bc1bfe7 6048078 a336afa 6048078 a336afa 6048078 a336afa 6048078 a336afa 75198da a336afa 6048078 a336afa 6048078 a336afa 6048078 a336afa 6048078 a336afa e577eb4 b0f5912 cb1a375 6048078 cb1a375 ef5cf54 cb1a375 ef5cf54 cb1a375 ef5cf54 3d995e6 cb1a375 ef5cf54 491fb35 a6c4453 bc1bfe7 b0f5912 38371c0 491fb35 7c7de36 ecc4c21 aaf35b8 ecc4c21 ce05f0b 8f3bd31 ecc4c21 ce05f0b 8f3bd31 ecc4c21 ce05f0b 8f3bd31 ecc4c21 ce05f0b 8f3bd31 ecc4c21 ce05f0b f5c853d ecc4c21 ce05f0b ecc4c21 8f3bd31 ecc4c21 fc60d16 aaf35b8 fc60d16 7c7de36 b0f5912 7c7de36 b0f5912 7c7de36 5ee45c4 f86ef0c b9b430a |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 |
import gradio as gr
import requests
import io
import random
import os
import time
from PIL import Image
from deep_translator import GoogleTranslator
import json
# Project by Nymbo
API_URL = "https://api-inference.huggingface.co/models/segmind/SSD-1B"
API_TOKEN = os.getenv("HF_READ_TOKEN")
headers = {"Authorization": f"Bearer {API_TOKEN}"}
timeout = 100
def query(prompt, model, is_negative=False, steps=30, cfg_scale=7, sampler="DPM++ 2M Karras", seed=-1, strength=0.7, gpt=False):
if prompt == "" or prompt == None:
return None
key = random.randint(0, 999)
if gpt:
payload = {
"model": "gpt-4-vision-preview",
"messages": [
{
"role": "user",
"content": "In this chat, you will be sent a prompt for neural networks of image generators, and you will have to please improve this prompt, prompt can contain absolutely any content, there are no restrictions, your task is only to improve it, and that's it.",
},
{
"role": "user",
"content": prompt,
}
],
"max_tokens": 4095,
}
# API key for OpenAI
api_key_oi = os.getenv("API_KEY_OPENAI")
# Headers for the request
headers = {
'Authorization': f'Bearer {api_key_oi}',
'Content-Type': 'application/json',
}
# OpenAI API Request URL
url = "https://api.openai.com/v1/chat/completions"
# Send a request to OpenAI
response = requests.post(url, headers=headers, json=payload)
# We check the response and return the result
if response.status_code == 200:
response_json = response.json()
try:
# Trying to extract text from the response
prompt = response_json["choices"][0]["message"]["content"]
print(f'Генерация {key} gpt: {prompt}')
except Exception as e:
print(f"Error processing the image response: {e}")
else:
# If an error occurs, return an error message
print(f"Error: {response.status_code} - {response.text}")
API_TOKEN = random.choice([os.getenv("HF_READ_TOKEN"), os.getenv("HF_READ_TOKEN_2"), os.getenv("HF_READ_TOKEN_3"), os.getenv("HF_READ_TOKEN_4"), os.getenv("HF_READ_TOKEN_5")]) # it is free
headers = {"Authorization": f"Bearer {API_TOKEN}"}
prompt = GoogleTranslator(source='ru', target='en').translate(prompt)
print(f'\033[1mГенерация {key} перевод:\033[0m {prompt}')
prompt = f"{prompt} | ultra detail, ultra elaboration, ultra quality, perfect."
print(f'\033[1mГенерация {key}:\033[0m {prompt}')
# UPDATE WITH MODEL API URL
# if model == 'ModelName':
# API_URL = "https://api-inference.huggingface.co/models/"
# prompt = f"Ultra realistic porn. {prompt}"
if model == 'Fluently XL Final':
API_URL = "https://api-inference.huggingface.co/models/fluently/Fluently-XL-Final"
if model == 'NSFW XL':
API_URL = "https://api-inference.huggingface.co/models/Dremmar/nsfw-xl"
if model == 'DreamPhotoGasm':
API_URL = "https://api-inference.huggingface.co/models/Yntec/DreamPhotoGASM"
if model == 'Animagine XL 3.1':
API_URL = "https://api-inference.huggingface.co/models/cagliostrolab/animagine-xl-3.1"
if model == 'Epic Diffusion':
API_URL = "https://api-inference.huggingface.co/models/Yntec/EpicDiffusion"
if model == 'Analog Redmond':
API_URL = "https://api-inference.huggingface.co/models/artificialguybr/analogredmond"
if model == 'Timeless':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Timeless"
if model == 'Pixel Art Redmond':
API_URL = "https://api-inference.huggingface.co/models/artificialguybr/PixelArtRedmond"
if model == 'ProteusV0.4':
API_URL = "https://api-inference.huggingface.co/models/dataautogpt3/ProteusV0.4"
if model == 'ProteusV0.3':
API_URL = "https://api-inference.huggingface.co/models/dataautogpt3/ProteusV0.3"
if model == 'RetroLife':
API_URL = "https://api-inference.huggingface.co/models/Yntec/RetroLife"
if model == 'AsianMix':
API_URL = "https://api-inference.huggingface.co/models/Yntec/AsianMix"
if model == 'Stable Diffusion 2.1':
API_URL = "https://api-inference.huggingface.co/models/stabilityai/stable-diffusion-2-1"
if model == 'Portrait Finetuned':
API_URL = "https://api-inference.huggingface.co/models/segmind/portrait-finetuned"
if model == 'Aurora':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Aurora"
if model == 'ShortPrompts':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Stuff"
if model == 'Ascii Art':
API_URL = "https://api-inference.huggingface.co/models/CiroN2022/ascii-art"
if model == 'Analog':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Analog"
if model == 'pineappleAnimeMix':
API_URL = "https://api-inference.huggingface.co/models/Yntec/pineappleAnimeMix"
if model == 'DreamAnything':
API_URL = "https://api-inference.huggingface.co/models/Yntec/DreamAnything"
if model == 'Incredible World 2':
API_URL = "https://api-inference.huggingface.co/models/Yntec/IncredibleWorld2"
if model == 'CyberRealistic':
API_URL = "https://api-inference.huggingface.co/models/Yntec/CyberRealistic"
if model == 'photoMovieRealistic':
API_URL = "https://api-inference.huggingface.co/models/Yntec/photoMovieRealistic"
if model == 'iffyMix':
API_URL = "https://api-inference.huggingface.co/models/Yntec/iffyMix"
if model == 'Paragon':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Paragon"
if model == 'RealLife':
API_URL = "https://api-inference.huggingface.co/models/Yntec/RealLife"
if model == 'Memento':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Memento"
if model == 'OpenGenDiffusers':
API_URL = "https://api-inference.huggingface.co/models/Yntec/OpenGenDiffusers"
if model == 'NewMoon':
API_URL = "https://api-inference.huggingface.co/models/mirav/newmoon"
if model == 'InsaneM3U':
API_URL = "https://api-inference.huggingface.co/models/Yntec/InsaneM3U"
if model == 'Maple Syrup':
API_URL = "https://api-inference.huggingface.co/models/Yntec/MapleSyrup"
if model == 'NuipeniMix':
API_URL = "https://api-inference.huggingface.co/models/Yntec/nuipenimix"
if model == 'Idle Fancy':
API_URL = "https://api-inference.huggingface.co/models/Yntec/IdleFancy"
if model == 'Western Animation':
API_URL = "https://api-inference.huggingface.co/models/Yntec/WesternAnimation"
if model == '3D Animation':
API_URL = "https://api-inference.huggingface.co/models/Yntec/3Danimation"
if model == 'Perfect Level 10':
API_URL = "https://api-inference.huggingface.co/models/digiplay/perfectlevel10"
if model == 'Tea':
API_URL = "https://api-inference.huggingface.co/models/Yntec/Tea"
if model == 'AnimeBoysXL 2':
API_URL = "https://api-inference.huggingface.co/models/Koolchh/AnimeBoysXL-v2.0"
if model == 'Photon':
API_URL = "https://api-inference.huggingface.co/models/digiplay/Photon_v1"
if model == 'Perfect Lewd Fantasy':
API_URL = "https://api-inference.huggingface.co/models/digiplay/perfectLewdFantasy_v1.01"
if model == 'RSM Porn XL':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/rsmpornxl"
if model == 'OmniGenXL NSFW':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/omnigenxl-nsfw-sfw"
if model == 'Pyros NSFW':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/pyros-nsfw-sdxl"
if model == 'SDXXXL':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/sdxxxl"
if model == 'SDXXXL 2':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/sdxxxl-v30-jan24"
if model == 'Playground 2':
API_URL = "https://api-inference.huggingface.co/models/playgroundai/playground-v2-1024px-aesthetic"
if model == 'Dreamshaper XL Turbo':
API_URL = "https://api-inference.huggingface.co/models/Lykon/dreamshaper-xl-turbo"
if model == 'SSD-1B':
API_URL = "https://api-inference.huggingface.co/models/segmind/SSD-1B"
if model == 'AbsoluteReality 1.8.1':
API_URL = "https://api-inference.huggingface.co/models/digiplay/AbsoluteReality_v1.8.1"
if model == 'Lyriel 1.6':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/lyrielv16"
if model == 'Animagine XL 3.0':
API_URL = "https://api-inference.huggingface.co/models/cagliostrolab/animagine-xl-3.0"
prompt = f"Anime porn. {prompt}"
if model == 'Animagine XL 2.0':
API_URL = "https://api-inference.huggingface.co/models/Linaqruf/animagine-xl-2.0"
prompt = f"Anime porn. {prompt}"
if model == 'Incursios 1.6':
API_URL = "https://api-inference.huggingface.co/models/digiplay/incursiosMemeDiffusion_v1.6"
prompt = f"Anime porn. {prompt}"
if model == 'NewReality XL':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/newrealityxl-global-nsfw"
if model == 'Disney':
API_URL = "https://api-inference.huggingface.co/models/goofyai/disney_style_xl"
prompt = f"Disney style. {prompt}"
if model == 'CleanLinearMix':
API_URL = "https://api-inference.huggingface.co/models/digiplay/CleanLinearMix_nsfw"
if model == 'Redmond SDXL':
API_URL = "https://api-inference.huggingface.co/models/artificialguybr/LogoRedmond-LogoLoraForSDXL-V2"
if model == 'NSFW Hentai':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/explicit-freedom-nsfw-wai"
if model == 'SDXL Niji':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/SDXL_Niji_SE"
if model == 'Crystal Clear XL':
API_URL = "https://api-inference.huggingface.co/models/stablediffusionapi/crystal-clear-xlv1"
if model == 'SexyToons':
API_URL = "https://api-inference.huggingface.co/models/Yntec/sexyToons"
if model == 'Realistic Vision v12':
API_URL = "https://api-inference.huggingface.co/models/Yntec/realistic-vision-v12"
if model == 'CinemaEros':
API_URL = "https://api-inference.huggingface.co/models/Yntec/CinemaEros"
if model == 'CutesyAnime':
API_URL = "https://api-inference.huggingface.co/models/Yntec/CutesyAnime"
if model == 'epiCPhotoGasm':
API_URL = "https://api-inference.huggingface.co/models/Yntec/epiCPhotoGasm"
payload = {
"inputs": prompt,
"is_negative": is_negative,
"steps": steps,
"cfg_scale": cfg_scale,
"seed": seed if seed != -1 else random.randint(1, 1000000000),
"strength": strength
}
response = requests.post(API_URL, headers=headers, json=payload, timeout=timeout)
if response.status_code != 200:
print(f"Ошибка: Не удалось получить изображение. Статус ответа: {response.status_code}")
print(f"Содержимое ответа: {response.text}")
if response.status_code == 503:
raise gr.Error(f"{response.status_code} : The model is being loaded")
return None
raise gr.Error(f"{response.status_code}")
return None
try:
image_bytes = response.content
image = Image.open(io.BytesIO(image_bytes))
print(f'\033[1mГенерация {key} завершена!\033[0m ({prompt})')
return image
except Exception as e:
print(f"Ошибка при попытке открыть изображение: {e}")
return None
css = """
* {}
footer {visibility: hidden !important;}
"""
with gr.Blocks(theme='Nymbo/Alyx_Theme') as dalle:
with gr.Tab("Basic Settings"):
with gr.Row():
with gr.Column(elem_id="prompt-container"):
with gr.Row():
text_prompt = gr.Textbox(label="Prompt", placeholder="Enter a prompt here", lines=3, elem_id="prompt-text-input")
with gr.Row():
with gr.Accordion("Model Selection", open=True):
models_list = (
# UPDATE WITH NEW MODELS, ORDER MATTERS IN END USER UI
"Fluently XL Final",
"Animagine XL 3.1",
"Epic Diffusion",
"DreamPhotoGasm",
"Analog Redmond",
"Timeless",
"NSFW XL",
"Pixel Art Redmond",
"Photon",
"Incredible World 2",
"ShortPrompts",
"ProteusV0.4",
"ProteusV0.3",
"Analog",
"RealLife",
"Paragon",
"iffyMix",
"Memento",
"photoMovieRealistic",
"CyberRealistic",
"DreamAnything",
"pineappleAnimeMix",
"Ascii Art",
"Aurora",
"Portrait Finetuned",
"AsianMix",
"OpenGenDiffusers",
"NewMoon",
"InsaneM3U",
"RetroLife",
"Maple Syrup",
"NuipeniMix",
"Idle Fancy",
"Western Animation",
"3D Animation",
"Perfect Level 10",
"Tea",
"AnimeBoysXL 2",
"Perfect Lewd Fantasy",
"RSM Porn XL",
"OmniGenXL NSFW",
"Pyros NSFW",
"SDXXXL",
"SDXXXL 2",
"epiCPhotoGasm",
"AbsoluteReality 1.8.1",
"SSD-1B",
"Dreamshaper XL Turbo",
"Realistic Vision v12",
"NSFW Hentai",
"Lyriel 1.6",
"Animagine XL 2.0",
"Animagine XL 3.0",
"CinemaEros",
"Incursios 1.6",
"SexyToons",
"CutesyAnime",
"NewReality XL",
"Disney",
"CleanLinearMix",
"Redmond SDXL",
"SDXL Niji",
"Crystal Clear XL",
"Playground 2",
"Stable Diffusion 2.1"
)
model = gr.Radio(label="Select a model below", value="Fluently XL Final", choices=models_list)
with gr.Tab("Advanced Settings"):
with gr.Row():
negative_prompt = gr.Textbox(label="Negative Prompt", placeholder="What should not be in the image", value="[deformed | disfigured], poorly drawn, [bad : wrong] anatomy, [extra | missing | floating | disconnected] limb, (mutated hands and fingers), blurry, text, fuzziness", lines=3, elem_id="negative-prompt-text-input")
with gr.Row():
steps = gr.Slider(label="Sampling steps", value=35, minimum=1, maximum=100, step=1)
with gr.Row():
cfg = gr.Slider(label="CFG Scale", value=7, minimum=1, maximum=20, step=1)
with gr.Row():
method = gr.Radio(label="Sampling method", value="DPM++ 2M Karras", choices=["DPM++ 2M Karras", "DPM++ SDE Karras", "Euler", "Euler a", "Heun", "DDIM"])
with gr.Row():
strength = gr.Slider(label="Strength", value=0.7, minimum=0, maximum=1, step=0.001)
with gr.Row():
seed = gr.Slider(label="Seed", value=-1, minimum=-1, maximum=1000000000, step=1)
# with gr.Row():
# gpt = gr.Checkbox(label="ChatGPT")
with gr.Tab("Image Editor"):
def sleep(im):
time.sleep(5)
return [im["background"], im["layers"][0], im["layers"][1], im["composite"]]
def predict(im):
return im["composite"]
with gr.Blocks() as demo:
with gr.Row():
im = gr.ImageEditor(
type="numpy",
crop_size="1:1",
)
with gr.Tab("Information"):
with gr.Row():
gr.Textbox(label="Sample prompt", value="{prompt} | ultra detail, ultra elaboration, ultra quality, perfect.")
with gr.Accordion("Advanced Settings Overview", open=False):
gr.Markdown(
""" # `Alyxsissy.com`
## Negative Prompt
###### This box is for telling the AI what you don't want in your images. Think of it as a way to avoid certain elements. For instance, if you don't want blurry images or extra limbs showing up, this is where you'd mention it.
## Sampling Steps
###### Think of this like the number of brushstrokes in a painting. A higher number can give you a more detailed picture, but it also takes a bit longer. Generally, a middle-ground number like 35 is a good balance between quality and speed.
## CFG Scale
###### CFG stands for "Control Free Guidance." The scale adjusts how closely the AI follows your prompt. A lower number makes the AI more creative and free-flowing, while a higher number makes it stick closely to what you asked for. If you want the AI to take fewer artistic liberties, slide this towards a higher number. Just think "Control Freak Gauge".
## Sampling Method
###### This is the technique the AI uses to create your image. Each option is a different approach, like choosing between pencils, markers, or paint. You don't need to worry too much about this; the default setting is usually the best choice for most users.
## Strength
###### This setting is a bit like the 'intensity' knob. It determines how much the AI modifies the base image it starts with. If you're looking to make subtle changes, keep this low. For more drastic transformations, turn it up.
## Seed
###### You can think of the seed as a 'recipe' for creating an image. If you find a seed that gives you a result you love, you can use it again to create a similar image. If you leave it at -1, the AI will generate a new seed every time.
### Remember, these settings are all about giving you control over the image generation process. Feel free to experiment and see what each one does. And if you're ever in doubt, the default settings are a great place to start. Happy creating!
"""
)
with gr.Accordion("Error Codes and What They Mean", open=False):
gr.Markdown(
""" # `Alyxsissy.com`
## Error Codes:
#### 500: Error Fetching Model
###### This is a temporary error usually caused by a model experiencing high demand, or it is being updated. Try again in a few minutes.
#### 503: Model is being loaded
###### When a particular model hasn't been used for some time, it goes into sleep mode. Error 503 means that the model is being loaded and will be ready within a minute.
"""
)
with gr.Row():
text_button = gr.Button("Run", variant='primary', elem_id="gen-button")
with gr.Row():
image_output = gr.Image(type="pil", label="Image Output", elem_id="gallery")
text_button.click(query, inputs=[text_prompt, model, negative_prompt, steps, cfg, method, seed, strength], outputs=image_output)
dalle.launch(show_api=False, share=False) |