|
import os |
|
import streamlit as st |
|
import requests |
|
from transformers import pipeline |
|
from typing import Dict |
|
from together import Together |
|
|
|
|
|
def img2txt(url: str) -> str: |
|
print("Initializing captioning model...") |
|
captioning_model = pipeline("image-to-text", model="Salesforce/blip-image-captioning-base") |
|
|
|
print("Generating text from the image...") |
|
text = captioning_model(url, max_new_tokens=20)[0]["generated_text"] |
|
|
|
print(text) |
|
return text |
|
|
|
|
|
def txt2story(prompt: str, top_k: int, top_p: float, temperature: float) -> str: |
|
|
|
client = Together(api_key=os.environ.get("TOGETHER_API_KEY")) |
|
|
|
|
|
story_prompt = f"Write a short story of no more than 250 words based on the following prompt: {prompt}" |
|
|
|
|
|
stream = client.chat.completions.create( |
|
model="meta-llama/Meta-Llama-3.1-8B-Instruct-Turbo", |
|
messages=[ |
|
{"role": "system", "content": '''As an experienced short story writer, write a meaningful story influenced by the provided prompt. |
|
Ensure the story does not exceed 250 words.'''}, |
|
{"role": "user", "content": story_prompt} |
|
], |
|
top_k=top_k, |
|
top_p=top_p, |
|
temperature=temperature, |
|
stream=True |
|
) |
|
|
|
|
|
story = '' |
|
for chunk in stream: |
|
story += chunk.choices[0].delta.content |
|
|
|
return story |
|
|
|
|
|
def txt2speech(text: str) -> None: |
|
print("Initializing MeloTTS text-to-speech conversion...") |
|
pipe = pipeline("text-to-speech", model="myshell-ai/MeloTTS-English") |
|
|
|
|
|
audio = pipe(text) |
|
|
|
|
|
with open("audio_story.wav", "wb") as file: |
|
file.write(audio["wav"]) |
|
|
|
|
|
def get_user_preferences() -> Dict[str, str]: |
|
preferences = {} |
|
|
|
preferences['continent'] = st.selectbox("Continent", ["North America", "Europe", "Asia", "Africa", "Australia"]) |
|
preferences['genre'] = st.selectbox("Genre", ["Science Fiction", "Fantasy", "Mystery", "Romance"]) |
|
preferences['setting'] = st.selectbox("Setting", ["Future", "Medieval times", "Modern day", "Alternate reality"]) |
|
preferences['plot'] = st.selectbox("Plot", ["Hero's journey", "Solving a mystery", "Love story", "Survival"]) |
|
preferences['tone'] = st.selectbox("Tone", ["Serious", "Light-hearted", "Humorous", "Dark"]) |
|
preferences['theme'] = st.selectbox("Theme", ["Self-discovery", "Redemption", "Love", "Justice"]) |
|
preferences['conflict'] = st.selectbox("Conflict Type", ["Person vs. Society", "Internal struggle", "Person vs. Nature", "Person vs. Person"]) |
|
preferences['twist'] = st.selectbox("Mystery/Twist", ["Plot twist", "Hidden identity", "Unexpected ally/enemy", "Time paradox"]) |
|
preferences['ending'] = st.selectbox("Ending", ["Happy", "Bittersweet", "Open-ended", "Tragic"]) |
|
|
|
return preferences |
|
|