sun2dar's picture
Update app.py
2ff9636
raw
history blame
1.86 kB
import cohere
import gradio as gr
import requests
from PIL import Image
import io
def generate_text(prompt,maxi,cohere_api_key):
co = cohere.Client(cohere_api_key)
response = co.generate(prompt=prompt,
temperature=0,
max_tokens=maxi)
return response[0]
def generate_image(prompt,gradio_api_key):
r = requests.post('https://clipdrop-api.co/text-to-image/v1',
files={
'prompt': (None, prompt, 'text/plain')
},
headers={'x-api-key': gradio_api_key}
)
if r.ok:
images = Image.open(io.BytesIO(r.content))
return images
else:
raise ValueError("Failed to generate image")
def text_and_image_generator(prompt,maxi,cohere_api_key,gradio_api_key):
if cohere_api_key=="kits" and gradio_api_key=="kits":
cohere_api_key = "3kUv9DkIN6vtDUhUXFnYyk3cqy53VWuDfC6g3mp4"
gradio_api_key = "e35a803cffac3d96f1c364a1bb8ddf00fd702be129881b1acb36f963c0ba86489cad39a6cb6f15f7cbfe919a3c4eb46e"
text = generate_text(f"Generate a story with {prompt}. Conclude the generated story properly.",maxi,cohere_api_key)
image = generate_image(text,gradio_api_key)
title = generate_text(f"title for the story {prompt} within 5 words",5,cohere_api_key)
return title,text,image
app = gr.Interface(
title="Story and Image Generator",
fn=text_and_image_generator,
inputs = [gr.inputs.Textbox(label="Enter your prompt to generate a story"),
gr.inputs.Slider(1,1000,label="Story length"),gr.inputs.Textbox(type="password",label="Cohere API key"),gr.inputs.Textbox(type="password",label="ClipDrop API key")],
outputs= [gr.outputs.Textbox(label="Story title"),gr.outputs.Textbox(label="Story"),gr.outputs.Image(type="pil",label="Image based on the Generated story")],theme="dark"
)
app.launch()