Spaces:
Sleeping
Sleeping
import streamlit as st | |
import whisper | |
from sklearn.feature_extraction.text import TfidfVectorizer | |
from sklearn.metrics.pairwise import cosine_similarity | |
import base64 | |
st.set_page_config( | |
page_title="Sing It Forward App", | |
page_icon="🎵") | |
st.markdown( | |
""" | |
<style> | |
body { | |
background: linear-gradient(to bottom, #0E5AAB, #00ffff); | |
padding: 20px; | |
border-radius: 10px; | |
} | |
a { | |
color: #EDA67C !important | |
} | |
</style> | |
""", | |
unsafe_allow_html=True | |
) | |
def load_image(image_file): | |
with open(image_file, "rb") as f: | |
return f.read() | |
image_data = load_image("bcg.jpg") | |
image_base64 = base64.b64encode(image_data).decode() | |
st.markdown( | |
f""" | |
<style> | |
.stApp {{ | |
background-image: url(data:image/jpeg;base64,{image_base64}); | |
background-size: cover; | |
background-position: center; | |
background-repeat: no-repeat; | |
}} | |
</style> | |
""", | |
unsafe_allow_html=True | |
) | |
st.markdown("<h1 style='text-align: center; margin-bottom: 5px;'>Sing It Forward App🎵</h1>", unsafe_allow_html=True) | |
description = """ | |
<h5>Welcome to Sing It Forward App!</h5> | |
<p style="text-align: justify;"> | |
Get ready to test your singing skills and memory! First, listen carefully to the first part of the song, then it’s your turn to shine. | |
Record yourself singing the next 15 seconds on your own, matching the lyrics and rhythm perfectly. Think you’ve got what it takes to keep the music going? | |
Let’s see if you can hit the right notes and showcase your talent! Unleash your inner star and take the challenge! | |
</p> | |
📌For any questions or contact: | |
**Name:** <span style="color: #EDA67C;">Sahand Khorsandi</span> | |
**Email:** <a href="mailto:sahand.kh78@yahoo.com" style="color: #EDA67C;">sahand.kh78@yahoo.com</a>""" | |
st.markdown(description, unsafe_allow_html=True) | |
st.write('------') | |
def cosine_sim(text1, text2): | |
vectorizer = TfidfVectorizer().fit_transform([text1, text2]) | |
vectors = vectorizer.toarray() | |
return cosine_similarity(vectors)[0, 1] | |
model = whisper.load_model("base") | |
st.write("Listen to music since you have to record 15seconds after that") | |
st.audio("titanic.mp3") | |
audio_value = st.experimental_audio_input("Sing Rest of music:🎙️") | |
lyrics = "Far across the distance And spaces between us You have come to show you go on" | |
if audio_value: | |
with open("user_sing.mp3", "wb") as f: | |
f.write(audio_value.getbuffer()) | |
user_lyrics = model.transcribe("user_sing.mp3")["text"] | |
st.write(user_lyrics) | |
similarity_score = cosine_sim(lyrics, user_lyrics) | |
if similarity_score > 0.85: | |
st.success('Awsome! You are doing great', icon="✅") | |
else: | |
st.error('Awful! Try harder next time', icon="🚨") |