Spaces:
Sleeping
Sleeping
File size: 6,256 Bytes
a743eab 8593387 7166f82 de062b2 ef60d1f a7c7d5d 5a3b176 8593387 7166f82 43b6c17 7166f82 ef60d1f 7166f82 ef60d1f 37fb05d 4e4575b 7166f82 8593387 4e4575b 8593387 8822d53 7166f82 8822d53 7166f82 ef60d1f 37fb05d ef60d1f c880135 ef60d1f 8822d53 ef60d1f 8822d53 2169527 8822d53 c880135 0d9be8f 37fb05d c880135 37fb05d c880135 8822d53 c880135 8822d53 c880135 7166f82 ef60d1f 37fb05d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 |
import gradio as gr
import assemblyai as aai
from transformers import pipeline
import pandas as pd
import os
# Replace with your AssemblyAI API key
aai.settings.api_key = "62acec891bb04c339ec059b738bedac6"
# Initialize question answering pipeline
question_answerer = pipeline("question-answering", model='distilbert-base-cased-distilled-squad')
# List of questions
questions = [
"Which grade is the child studying?",
"How old is the child?",
"What is the gender?",
"Can you provide the name and location of the child's school?",
"What are the names of the child's guardians or parents?",
"What is the chief complaint regarding the child's oral health? If there is none, just say the word 'none', else elaborate only on medication history",
"Can you provide any relevant medical history for the child? If there is none, just say the word 'none', else elaborate",
"Does the child take any medications regularly? If there is none, just say the word 'none'. If yes, please specify.",
"When was the child's previous dental visit? If no visits before, just say the word 'first' or mention the visit number and nothing else",
"Does the child have any habits such as thumb sucking, tongue thrusting, nail biting, or lip biting? If yes, just list them and don't provide any further details",
"Does the patient brush their teeth? Just use the words 'once daily', 'twice daily', or 'thrice daily' to answer, nothing else",
"Does the child experience bleeding gums? Just say 'yes' or 'no' for this and nothing else",
"Has the child experienced early childhood caries? Just say 'yes' or 'no' and nothing else",
"Please mention if tooth decay is present with tooth number(s), else just say the word 'none' and nothing else",
"Have any teeth been fractured? If yes, please mention the tooth number(s), else just say 'none' and nothing else",
"Is there any pre-shedding mobility of teeth? If yes, please specify, else just say 'none' and nothing else",
"Does the child have malocclusion? If yes, please provide details, else just say the word 'none' and nothing else",
"Does the child experience pain, swelling, or abscess? If yes, please provide details, else just say 'none' and nothing else",
"Are there any other findings you would like to note?",
"What treatment plan do you recommend? Choose only from Options: (Scaling, Filling, Pulp therapy/RCT, Extraction, Medication, Referral) and nothing else"
]
oral_health_assessment_form = [
"Doctor’s Name",
"Child’s Name",
"Grade",
"Age",
"Gender",
"School name and place",
"Guardian/Parents name",
"Chief complaint",
"Medical history",
"Medication history",
"Previous dental visit",
"Habits",
"Brushing habit",
"Bleeding gums",
"Early Childhood caries",
"Decayed",
"Fractured teeth",
"Preshedding mobility",
"Malocclusion",
"Does the child have pain, swelling or abscess? (Urgent care need)",
"Any other finding",
"Treatment plan",
]
# Function to generate answers for the questions
def generate_answer(question, context):
result = question_answerer(question=question, context=context)
return result['answer']
# Function to handle audio recording and transcription
def transcribe_audio(audio_path):
print(f"Received audio file at: {audio_path}")
# Check if the file exists and is not empty
if not os.path.exists(audio_path):
return "Error: Audio file does not exist."
if os.path.getsize(audio_path) == 0:
return "Error: Audio file is empty."
try:
# Transcribe the audio file using AssemblyAI
transcriber = aai.Transcriber()
print("Starting transcription...")
transcript = transcriber.transcribe(audio_path)
print("Transcription process completed.")
# Handle the transcription result
if transcript.status == aai.TranscriptStatus.error:
print(f"Error during transcription: {transcript.error}")
return transcript.error
else:
context = transcript.text
print(f"Transcription text: {context}")
return context
except Exception as e:
print(f"Exception occurred: {e}")
return str(e)
# Function to fill in the answers for the text boxes
def fill_textboxes(context):
answers = []
for question in questions:
answer = generate_answer(question, context)
answers.append(answer)
return answers
# Main Gradio app function
def main(audio):
context = transcribe_audio(audio)
if "Error" in context:
return [context] * len(oral_health_assessment_form)
answers = fill_textboxes(context)
answers.insert(0, "") # for "Child's Name"
answers.insert(0, "Dr. Charles Xavier") # for "Doctor’s Name"
return answers
def save_answers(*args):
answers_dict = {oral_health_assessment_form[i]: args[i] for i in range(len(oral_health_assessment_form))}
print("Saved answers:", answers_dict)
return f"Saved answers: {answers_dict}"
# Create the Gradio interface
with gr.Blocks() as demo:
gr.Markdown("# Audio Transcription and Question Answering App")
audio_input = gr.Audio(type="filepath", label="Record your audio", elem_id="audio_input")
transcribe_button = gr.Button("Transcribe and Generate Form", elem_id="transcribe_button")
with gr.Row(elem_id="textboxes_row"):
with gr.Column():
textboxes_left = [gr.Textbox(label=oral_health_assessment_form[i], value="", interactive=True) for i in range(0, len(oral_health_assessment_form)//2)]
with gr.Column():
textboxes_right = [gr.Textbox(label=oral_health_assessment_form[i], value="", interactive=True) for i in range(len(oral_health_assessment_form)//2, len(oral_health_assessment_form))]
submit_button = gr.Button("Submit", elem_id="submit_button")
output_html = gr.HTML(label="Submitted Answers")
transcribe_button.click(fn=main, inputs=audio_input, outputs=textboxes_left + textboxes_right)
submit_button.click(fn=save_answers, inputs=textboxes_left + textboxes_right, outputs=output_html)
# Launch the app
demo.launch()
|