felixwf commited on
Commit
a202bc8
·
verified ·
1 Parent(s): d87044c

Create app.py

Browse files
Files changed (1) hide show
  1. app.py +63 -0
app.py ADDED
@@ -0,0 +1,63 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import streamlit as st
2
+ from transformers import pipeline
3
+
4
+ # img2text
5
+ def img2text(url):
6
+ image_to_text_model = pipeline("image-to-text", model="Salesforce/blip-image-captioning-large")
7
+ text = image_to_text_model(url)[0]["generated_text"]
8
+
9
+ print(text)
10
+ return text
11
+
12
+ # txt2Story
13
+ def txt2story(text):
14
+ pipe = pipeline("text-generation", model="pranavpsv/genre-story-generator-v2")
15
+ story_txt = pipe(text)[0]['generated_text']
16
+
17
+ print(story_txt)
18
+ return story_txt
19
+
20
+ # Story2Audio
21
+ def text2audio(story_text):
22
+ pipe = pipeline("text-to-audio", model="Matthijs/mms-tts-eng")
23
+ audio_data = pipe(story_text)
24
+ return audio_data
25
+
26
+
27
+ def main():
28
+ st.set_page_config(page_title="Your Image to Audio Story", page_icon="🦜")
29
+ st.header("Turn Your Image to Audio Story")
30
+ uploaded_file = st.file_uploader("Select an Image...")
31
+
32
+ if uploaded_file is not None:
33
+ print(uploaded_file)
34
+ bytes_data = uploaded_file.getvalue()
35
+ with open(uploaded_file.name, "wb") as file:
36
+ file.write(bytes_data)
37
+ st.image(uploaded_file, caption="Uploaded Image", use_column_width=True)
38
+
39
+
40
+ #Stage 1: Image to Text
41
+ st.text('Processing img2text...')
42
+ scenario = img2text(uploaded_file.name)
43
+ st.write(scenario)
44
+
45
+ #Stage 2: Text to Story
46
+ st.text('Generating a story...')
47
+ story = txt2story(scenario)
48
+ st.write(story)
49
+
50
+ #Stage 3: Story to Audio data
51
+ st.text('Generating audio data...')
52
+ audio_data =text2audio(story)
53
+
54
+ # Play button
55
+ if st.button("Play Audio"):
56
+ st.audio(audio_data['audio'],
57
+ format="audio/wav",
58
+ start_time=0,
59
+ sample_rate = audio_data['sampling_rate'])
60
+
61
+
62
+ if __name__ == "__main__":
63
+ main()