def chat(passage):
    st.write("Excited to know more about the place?!")
    st.write("Here's HAL9000 to help you with your queries!")
    st.write("**type _bye_ to end the chat")
    while True:
        inp = st.text_input("You: ", key='1')

        if inp.lower() == "bye":
            st.text_area("Bot:",
                         value="Thank You, Have a nice day!",
                         height=200,
                         max_chars=None,
                         key=None)
            break
        result = predictor.predict(passage=passage, question=inp)
        response = result['best_span_str']
        st.text_area("Bot:",
                     value=response,
                     height=200,
                     max_chars=None,
                     key=None)

        mytext = response
        myobj = gTTS(text=mytext, lang=language, slow=False)
        date_string = datetime.datetime.now().strftime("%d%m%Y%H%M%S")
        filename = "voice" + date_string + ".ogg"
        myobj.save(filename)
        name = "C:\\Users\\Arpitha Shibu\\Documents\\BDA SEM III\\1 MOM\\MOM AI Project\\Final\\" + filename
        audio_file = open(name, 'rb')
        audio_bytes = audio_file.read()
        st.audio(audio_bytes, format='audio/ogg')
        os.remove(name)
def play_file_uploaded(file_upload, file_type):
    if 'audio' in file_type:
        audio_bytes = file_upload.read()
        st.audio(audio_bytes, format="audio/wav")
    elif 'video' in file_type:
        video_bytes = file_upload.read()
        st.video(video_bytes)
예제 #3
0
def pdf_to_audio(pdf, slow):
	with st.spinner("Converting PDF to audio... "):
		audio = convert_pdf_to_audio(pdf, slow)
		audio.save('audiobook.wav')

	st.audio('audiobook.wav', format='audio/wav')
	os.remove('audiobook.wav')
예제 #4
0
def show_media_widgets() -> None:
    DATA = Path('data/external')
    st.write("""
    ### Display images """)

    st.write("#### Reference images")
    with st.echo():
        st.image(
            "https://www.dogalize.com/wp-content/uploads/2018/03/ceiling-cat.jpg",
            caption="Ceiling cat",
            use_column_width=True)

    st.write("#### Embed image")
    with st.echo():
        st.image(
            """""",
            caption="embedded image",
            width=500)

    # audio
    st.write("------")
    st.subheader("Embed audio")
    with st.echo():
        audio_file = open(DATA / 'applause7.mp3', 'rb')
        st.audio(audio_file, format='audio/mp3')
    st.write("_Note: seems to have trouble in Firefox_")

    # video
    st.write("------")
    st.subheader("Embed video")
    with st.echo():
        st.video("https://www.youtube.com/watch?v=B2iAodr0fOo", start_time=2)
예제 #5
0
def about():
    set_png_as_page_bg('oil2.png')
    st.title("About present work")
    st.subheader(
        "Billions of dollars are spent in oil rig operations including the safety on deck, quick analysis, efficiency etc. While multiple systems and heavy machinery are"
        " used for various tasks at hand, there always are avenues that can be explored to bring the efficiency and safety at optimum level."
    )
    st.subheader(
        "Multiple sounds are generated at the rigs during the extraction process and classifying the sounds correctly can help the engineers in reinforcing their"
        " initial estimates and quick decisioing.")
    audio_file = open(
        "/Users/prashantmudgal/Documents/Quantplex Labs/Sound_app/machine_6.wav",
        'rb')
    audio_bytes = audio_file.read()
    st.audio(audio_bytes, format='audio/wav')

    st.subheader(
        "In the present POC, we are classifying the sounds obtained from oil rigs into 10 categories:"
    )
    Final_Sound = [
        'Blowout', 'Gas Emission', 'Rock Bed', 'Heavy Gas', 'Heavy Metal',
        'Oil Drill Rig Exterior', 'Operatre Pump', 'Dieseling', 'Fracturing',
        'Hydraulic'
    ]
    df = pd.DataFrame(Final_Sound, columns=['Sound Class'])
    st.table(df)
def present_audio(audio_samples, label, fig, plotting_slot, row):
    "Show audio player and plot"
    # show audio player
    st.header(label)
    temp_file_name = "temp.wav"
    sf.write(temp_file_name, audio_samples.T, FS)
    st.audio(temp_file_name)
    remove(temp_file_name)
    # plot audio in subplot
    if fig is None:
        if label == "original":
            n_rows = 3
            titles = ["original", "input", "enhanced"]
            height = 600
        else:
            n_rows = 2
            titles = ["input", "enhanced"]
            height = 400
        fig = make_subplots(
            rows=n_rows,
            cols=1,
            subplot_titles=titles,
            shared_xaxes=True,
        )
        fig.update_layout(showlegend=False, height=height)
        fig.update_yaxes(fixedrange=True, range=[-1.0, 1.0], title="level")
        fig.update_xaxes(title="time [s]")
    time = np.arange(len(audio_samples)) / FS
    fig.append_trace(
        go.Scatter(x=time, y=audio_samples, line=dict(width=1)),
        row=row,
        col=1,
    )
    plotting_slot.plotly_chart(fig, use_container_width=True)
    return fig
예제 #7
0
def play(raw_text, idioma_key):
    tts = gTTS(text=raw_text, lang=idioma_key)
    tts.save("audio.mp3")
    audio_file = open("audio.mp3", "rb")
    audio_bytes = audio_file.read()
    #st.write("To download -> see options on the right side")
    st.audio(audio_bytes, format="audio/mp3")
예제 #8
0
def run(alarmH, alarmM):
    while (True):
        if (alarmH == datetime.datetime.now().hour
                and alarmM == datetime.datetime.now().minute):
            st.write("Time to wake up")
            audio_file = open("song.mp3", "rb")
            st.audio(audio_file, format='audio/mp3')
            break
예제 #9
0
def main():
    st.sidebar.subheader(
        'Saiba tudo sobre o seu artista favorito no Spotify! \nConfira popularidade, número de seguidores e músicas mais tocadas.\n'
    )

    name_input = st.sidebar.text_input('Digite o nome do artista:')

    st.sidebar.markdown('[GitHub](https://github.com/mariromildo)')

    if name_input:
        result = sp.search(q='artist:' + name_input, type='artist')
        result_id = result['artists']['items'][0]['id']
        query = 'spotify:artist:' + result_id
        artist = sp.artist(query)

        # Artist infos
        name = artist['name']
        genres = artist['genres'][0]
        popularity = artist['popularity']
        followers = artist['followers']['total']
        image = artist['images'][0]['url']

        st.header(name)
        st.write('**Gênero musical:**', genres)
        st.write('**Popularidade:**', popularity)
        st.write('**Seguidores no Spotify:**', followers)
        st.image(image, width=200)
        st.write('__________________________________________________________')

        # Top 3 track infos
        top_tracks = sp.artist_top_tracks(query)['tracks']
        st.header('Top tracks')

        for track in range(3):
            music_name = top_tracks[track]['name']
            album = top_tracks[track]['album']['name']
            album_image = top_tracks[track]['album']['images'][track]['url']
            preview = top_tracks[track]['preview_url']
            feat = top_tracks[track]['artists']
            feat_name = []
            for i in range(len(feat)):
                feat_name.append(feat[i]['name'])

            if len(feat_name) > 0:
                feat_name.remove(name)

            st.write('**Música:**', music_name)
            if len(
                    feat_name
            ) > 0:  # Returning featured artists only when the value isn't the searched artist name
                st.write('**Participação:**',
                         ', '.join(str(p) for p in feat_name))

            st.write('**Album:**', album)
            st.image(album_image, width=200)  # track audio preview
            st.audio(preview)
            st.write(
                '__________________________________________________________')
예제 #10
0
def alarm(alarmH,alarmM,ap):
    if ap == 'pm':
        alarmH=alarmM+12
    while(True):
        if(alarmH==datetime.datetime.now().hour and alarm==datetime.datetime.now().minute):
            st.write("Time to wake up")
            audio_file=open("song.mp3","rb")
            st.audio(audio_file,format='audio/mp3')
            break
예제 #11
0
def text2speech(input_text):
    synthesizer = torch.hub.load('coqui-ai/TTS:dev', 'tts', source='github')
    wav = synthesizer.tts(input_text)
    audio_obj = IPython.display.Audio(wav, rate=synthesizer.ap.sample_rate)
    with open(WAVE_OUTPUT_FILE, 'wb') as f:
        f.write(audio_obj.data)

    with open(WAVE_OUTPUT_FILE, 'rb') as audio_file:
        st.audio(audio_file, format='audio/wav')
예제 #12
0
def main():
    st.title('Hello World')
    st.header('')
    st.subheader('')
    st.text('')
    st.image('logo.png')
    st.subheader('')
    st.audio('name.wav')
    st.video('name.mov')
def myplaysound(filename):
    # plays audio file filename in streamlit
    # have to click button though
    audio_file = open(filename, "rb")
    audio_bytes = audio_file.read()
    st.audio(audio_bytes, format="audio/ogg")
    # audio_file.close
    # os.remove(filename)
    st.write('Click play button to play')
예제 #14
0
def main():

    st.header('This is a header')
    st.subheader('This is a subheader')
    st.text("It's a text")

    st.image('image.png')
    st.audio('record.wav')
    st.video('video.mov')
예제 #15
0
def present_audio(
    audio_samples, label, fig, plotting_slot, row, signal_presentation, pesq_score
):
    "Show audio player and plot"
    # show audio player
    st.header(label)
    st.write("pesq: " + str(round(pesq_score, 2)))
    temp_file_name = "temp.wav"
    sf.write(temp_file_name, audio_samples.T, FS)
    st.audio(temp_file_name)
    remove(temp_file_name)
    # plot audio in subplot
    if fig is None:
        if label == "original":
            n_rows = 3
            titles = ["original", "input", "enhanced"]
            height = 600
        else:
            n_rows = 2
            titles = ["input", "enhanced"]
            height = 400
        fig = make_subplots(
            rows=n_rows,
            cols=1,
            subplot_titles=titles,
            shared_xaxes=True,
        )
        fig.update_layout(showlegend=False, height=height)
        if signal_presentation == "Time signal":
            fig.update_yaxes(fixedrange=True, range=[-1.0, 1.0], title="level")
        else:
            fig.update_yaxes(fixedrange=True, title="Frequency Hz")
        fig.update_xaxes(title="time [s]")
    time = np.arange(len(audio_samples)) / FS
    if signal_presentation == "Time signal":
        fig.append_trace(
            go.Scatter(x=time, y=audio_samples, line=dict(width=1)),
            row=row,
            col=1,
        )
    else:
        freqs, bins, Pxx = signal.spectrogram(
            audio_samples,
            fs=FS,
            window="hann",
            nfft=512,
        )
        fig.append_trace(
            go.Heatmap(
                x=bins, y=freqs, z=10 * np.log10(Pxx), colorscale="Jet", showscale=False
            ),
            row=row,
            col=1,
        )
    plotting_slot.plotly_chart(fig, use_container_width=True)
    return fig
예제 #16
0
def main():
    st.title('Hello World')
    st.header('This is a header')
    st.subheader('This is a subheader')
    st.text('This is a text')
    st.image('logo.png')
    st.subheader('This is a audio')
    st.audio('record.wav')
    st.subheader('This is a video')
    st.video('sentiment_motion.mov')
예제 #17
0
def np_audio(np_array, stem_name, samplerate=44100):
    soundfile.write('temp.wav', np_array, samplerate, 'PCM_24')
    st.audio('temp.wav', format='audio/wav')
    with open("temp.wav", "rb") as f:
        file_id = _calculate_file_id(f.read(), "audio/wav")
        wav_url = f'{STATIC_MEDIA_ENDPOINT}/{file_id}.wav'
        stem_urls.append({
            'src': wav_url,
            'name': stem_name,
            'customClass': stem_name,
            })
예제 #18
0
    def test_st_audio_options(self):
        """Test st.audio with options."""
        fake_audio_data = "\x11\x22\x33\x44\x55\x66".encode("utf-8")
        st.audio(fake_audio_data, format="audio/mp3", start_time=10)

        el = self.get_delta_from_queue().new_element
        # Manually base64 encoded payload above via
        # base64.b64encode(bytes('\x11\x22\x33\x44\x55\x66'.encode('utf-8')))
        self.assertEqual(el.audio.data, "ESIzRFVm")
        self.assertEqual(el.audio.format, "audio/mp3")
        self.assertEqual(el.audio.start_time, 10)
예제 #19
0
def render_trial_sound(label, trials_per_class):
    # read the files from the label directory
    label_dir = './data/' + label
    wav_files = [f for f in listdir(label_dir) if isfile(join(label_dir, f))]
    # print('Wav files', wav_files)
    # render samples sounds
    random_wav_files = random.sample(wav_files, trials_per_class)
    for wav_file in random_wav_files:
        audio_file = open(label_dir + '/' + wav_file, 'rb')
        audio_bytes = audio_file.read()
        st.audio(audio_bytes)
예제 #20
0
    def test_st_audio_options(self):
        """Test st.audio with options."""
        from streamlit.media_file_manager import _calculate_file_id

        fake_audio_data = "\x11\x22\x33\x44\x55\x66".encode("utf-8")
        st.audio(fake_audio_data, format="audio/mp3", start_time=10)

        el = self.get_delta_from_queue().new_element
        self.assertEqual(el.audio.start_time, 10)
        self.assertTrue(el.audio.url.startswith(STATIC_MEDIA_ENDPOINT))
        self.assertTrue(_calculate_file_id(fake_audio_data, "audio/mp3"), el.audio.url)
예제 #21
0
def audio_section(idx, file_name):
    # print('file name', file_name)
    audio_file = open(file_name, 'rb')
    audio_bytes = audio_file.read()
    st.audio(audio_bytes)
    options = copy.deepcopy(random_labels)
    options.insert(0, DEFAULT_OPTION)
    options.append(UNKNOWN_OPTION)
    radio_answer = st.radio("Audio label", options, key=file_name)
    st.write('You selected label: **{}**'.format(radio_answer))
    global answers
    answers[idx] = [file_name, radio_answer]
예제 #22
0
def main():
    st.title('Hello World')
    st.header('This is header')
    st.subheader('This is subheader')
    st.text('This is text')
    st.subheader('Imagens')
    st.image('0.jpeg')
    st.image('logo.png')
    st.subheader('Audio')
    st.audio('record.mov')
    st.subheader('Video')
    st.video('formaturaNicolas.mp4')
def main():
    title = "Music Genre Classifier"
    st.title(title)
    image = Image.open('./presentation/turntable-2154823_1920.jpg')
    st.image(image, use_column_width=True)

    if st.button('Record'):
        with st.spinner('Recording...'):
            signal = sd.rec(int(6 * RECORD_SR),
                            samplerate=RECORD_SR,
                            channels=1,
                            blocking=True,
                            dtype='float64')
            #sd.wait()
            signal = signal.reshape(signal.shape[0])
            #st.write(signal.shape)
            #st.write(signal)

            new_num_samples = round(
                len(signal) * float(DESIRED_SR) / RECORD_SR)
            signal = sps.resample(signal, new_num_samples)

            # st.write(signal.shape)
            # st.write(type(signal))
            # st.write(signal)

            st.experimental_set_query_params(signal=signal)

        st.success("Recording completed")

    app_state = st.experimental_get_query_params()

    if st.button('Play'):
        try:
            signal = np.array(app_state["signal"], dtype='float')
            # st.write(type(signal))
            # st.write(signal.shape)
            temp_file = io.BytesIO()
            write(temp_file, 22050, signal)
            st.audio(temp_file, format='audio/wav')
        except:
            st.write("Please record sound first")

    if st.button('Classify'):
        with st.spinner("Thinking..."):
            signal = np.array(app_state["signal"], dtype='float')
            # st.write(type(signal))
            # st.write(signal.shape)
            # st.write(signal)
            pred = model.predict(get_harm_perc(signal))
        st.success("Classification completed")
        labels[np.argmax(pred)]
예제 #24
0
def main():

    img = Image.open('data/image_03.jpg')
    st.image(img, use_column_width=True)  # 이미지를 페이지 화면에 맞게 폭을 늘려서 출력함

    # 인터넷에 있는 이미지도 가능
    # st.image('')  여기안에 url 주소 가져오면 됨

    video_file = open('data/secret_of_success.mp4', 'rb').read()  # 비디오 파일 불러오기
    st.video(video_file)  # 비디오파일 불러온것을 실행해라

    audio_file = open('data/song.mp3', 'rb').read()  # 오디오 파일 불러오기
    st.audio(audio_file)  # 오디오 실행
예제 #25
0
    def test_st_audio(self):
        """Test st.audio."""
        # TODO(armando): generate real audio data
        # For now it doesnt matter cause browser is the one that uses it.
        fake_audio_data = "\x11\x22\x33\x44\x55\x66".encode("utf-8")

        st.audio(fake_audio_data)

        el = self.get_delta_from_queue().new_element
        # Manually base64 encoded payload above via
        # base64.b64encode(bytes('\x11\x22\x33\x44\x55\x66'.encode('utf-8')))
        self.assertEqual(el.audio.data, "ESIzRFVm")
        self.assertEqual(el.audio.format, "audio/wav")
예제 #26
0
def cs_display_media():
    st.markdown(
        "<h5 style='text-align: center ; color: black;'>Rendered -- Display Media Section</h5>",
        unsafe_allow_html=True)
    st.markdown('***')

    st.markdown('**Image**')
    st.markdown("- **st.image**('_`path`_')")
    st.image('./brain.png', width=300)
    st.markdown('***')

    st.markdown('**Audio**')
    st.markdown("- **st.audio**(_`data`_)")
    audio_code = '''
     audio_file = open('./Media/Cornfield_Chase.wav', 'rb')
     audio_bytes = audio_file.read()
     st.audio(audio_bytes, format='audio/wav')
    '''
    st.code(audio_code)
    audio_file = open('./Media/Cornfield_Chase.wav', 'rb')
    audio_bytes = audio_file.read()
    st.audio(audio_bytes, format='audio/wav')
    st.markdown(
        "<h6 style='text-align: center ;'>Source ~ Interstellar ✨( Cornfield Chase ) </h6>",
        unsafe_allow_html=True)

    st.markdown('***')
    st.markdown('**Video**')
    st.markdown("- **st.video**(_`data`_)")
    video_code = '''
    video_file = open('./Media/Star-6962.mp4', 'rb')
    video_bytes = video_file.read()
    st.video(video_bytes)

    '''
    st.code(video_code)
    video_file = open('./Media/Star-6962.mp4', 'rb')
    video_bytes = video_file.read()
    st.video(video_bytes)
    st.markdown(
        "<h6 style='text-align: center ;'>Creator - fxxu, Source - Pixbay </h6>",
        unsafe_allow_html=True)
    st.markdown('***')

    info = st.beta_expander('Direct References')
    info.markdown(
        '''[<img src='data:image/png;base64,{}' class='img-fluid' width=32 height=32 style='float:left; vertical-align:middle'>](https://docs.streamlit.io/en/stable/api.html#display-media) <small style='color:black; font-size:16px;'>Link to the Official Documentation of this Section </small>'''
        .format(img_to_bytes("logo.png")),
        unsafe_allow_html=True)

    st.markdown('***')
예제 #27
0
def main():
    col1, mid, col2 = st.beta_columns([10, 1, 10])
    with col1:
        image = Image.open(os.path.join(IMAGE_DIR, 'speak.jpg'))
        st.image(image, width=200)
    with col2:
        image = Image.open(os.path.join(IMAGE_DIR, 'unicorn.jpg'))
        st.image(image, width=200)

    title = "Talk to Transformer"
    st.title(title)

    session_state = SessionState.get(name="", button_sent=False)
    record_button_clicked = st.button('Record')
    if record_button_clicked or session_state.button_sent:  # <-- first time is button interaction, next time use state:
        st.empty()
        session_state.button_sent = True
        if record_button_clicked:
            # you can get some voice samples from here: https://huggingface.co/facebook/wav2vec2-base-960h
            with st.spinner(f'Recording for {DURATION} seconds ....'):
                sound.record()
            st.success("Recording completed")

            if st.button('Play'):
                try:
                    audio_file = open(WAVE_OUTPUT_FILE, 'rb')
                    audio_bytes = audio_file.read()
                    st.audio(audio_bytes, format='audio/wav')
                except:
                    st.write("Please record sound first")

        st.subheader("Here is what you spoke:\n")
        if record_button_clicked:
            session_state.input_text = speech2text(WAVE_OUTPUT_FILE)
            session_state.input_text = session_state.input_text.capitalize()
            for question_str in [
                    'Which ', 'Why ', 'Who ', 'Whose ', 'Whom ', 'What ',
                    'How '
            ]:
                if session_state.input_text.startswith(question_str):
                    session_state.input_text += '?'
                    break
        st.write(session_state.input_text)

        st.subheader("Generating text using Transformer(DistilGPT2) model: \n")
        if record_button_clicked:
            session_state.gen_txt = generate_text(session_state.input_text)
        st.write(session_state.gen_txt)

        with st.spinner('Converting text to speech...'):
            text2speech(session_state.gen_txt)
예제 #28
0
def render_file(wavfile, transcript_path, PathToFixed):

    TranscriptFile = os.path.join(
        transcript_path,
        wavfile.split(DELIM)[-1].replace(".wav", ".txt"))

    with open(TranscriptFile, 'r', encoding='utf-8') as f:
        data = f.read()
    key = wavfile.split(DELIM)[-1]

    st.subheader("Name of File = " + key)
    st.audio(open(wavfile, 'rb').read(), format='audio/wav')
    content = st_ace(value=data,
                     theme=st.sidebar.selectbox("Theme.",
                                                options=THEMES,
                                                key=key),
                     font_size=st.sidebar.slider("Font size.",
                                                 5,
                                                 24,
                                                 24,
                                                 key=key),
                     tab_size=st.sidebar.slider("Tab size.", 1, 8, 4, key=key),
                     show_gutter=st.sidebar.checkbox("Show gutter.",
                                                     value=True,
                                                     key=key),
                     show_print_margin=st.sidebar.checkbox(
                         "Show print margin.", value=True, key=key),
                     wrap=st.sidebar.checkbox("Wrap enabled.",
                                              value=True,
                                              key=key),
                     key=key)
    st.title(content)

    if st.sidebar.button("Reject"):
        print("Reject", key)
        SessionState.get().current_index += 1
        SessionState.sync()
        SavePickleState(SessionState.get().current_index,
                        key.replace(".wav", ".txt"))
        return

    if st.sidebar.button("Go to next file"):

        FixedTranscript = os.path.join(PathToFixed,
                                       key.replace(".wav", ".txt"))
        print(FixedTranscript)
        open(FixedTranscript, "w", encoding="utf-8").write(content)
        SessionState.get().current_index += 1
        SessionState.sync()
        SavePickleState(SessionState.get().current_index)
예제 #29
0
def display_media_audio(path: Path, start_second: int = 0):
    format_ = path.name.split(".")[-1]
    if format_ == "mp3":
        format_ = "audio/mp3"
    elif format_ == "wav":
        format_ = "audio/wav"
    elif format_ == "flac":
        format_ = "audio/x-flac"
    else:
        st.warning("Selected type is not readable format")

    if format_ in {"audio/wav", "audio/mp3", "audio/x-flac"}:
        st.audio(read_audio_bytes(path),
                 start_time=start_second,
                 format=format_)
예제 #30
0
def display_media_audio_from_ndarray(y: np.ndarray, sr: int):
    max_num = 32767.0 / y.max()
    y_hex = (y * max_num).astype(np.int16)
    binary_wave = struct.pack("h" * len(y_hex), *(y_hex.tolist()))

    with tempfile.TemporaryFile() as fp:
        w = wave.Wave_write(fp)  # type: ignore
        params = (1, 2, sr, len(binary_wave), "NONE", "not compressed")
        w.setparams(params)  # type: ignore
        w.writeframes(binary_wave)
        w.close()
        fp.seek(0)
        bytesio = io.BytesIO(fp.read())

    st.audio(bytesio)