Spaces:
Runtime error
Runtime error
Update app.py
Browse files
app.py
CHANGED
@@ -24,7 +24,7 @@ welcome_message = """
|
|
24 |
|
25 |
🗣️📝Interact with ⚕🗣️😷MultiMed⚕ in any language using image, audio or text!
|
26 |
|
27 |
-
📚🌟💼 that uses [Tonic/mistralmed](https://huggingface.co/Tonic/mistralmed) and [adept/fuyu-8B](https://huggingface.co/adept/fuyu-8b) with [Vectara](https://huggingface.co/vectara) embeddings + retrieval w/ [Facebook/Seamless-m4t](https://huggingface.co/facebook/hf-seamless-m4t-large) for audio translation & accessibility.
|
28 |
do [get in touch](https://discord.gg/GWpVpekp). You can also use 😷MultiMed⚕️ on your own data & in your own way by cloning this space. 🧬🔬🔍 Simply click here: <a style="display:inline-block" href="https://huggingface.co/spaces/TeamTonic/MultiMed?duplicate=true"><img src="https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=14" alt="Duplicate Space"></a></h3>
|
29 |
### Join us :
|
30 |
|
@@ -76,7 +76,7 @@ languages = {
|
|
76 |
components = {}
|
77 |
dotenv.load_dotenv()
|
78 |
seamless_client = Client("facebook/seamless_m4t")
|
79 |
-
|
80 |
HuggingFace_Token = os.getenv("HuggingFace_Token")
|
81 |
hf_token = os.getenv("HuggingFace_Token")
|
82 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
@@ -363,19 +363,34 @@ def query_vectara(text):
|
|
363 |
return f"Error: {response.status_code}"
|
364 |
|
365 |
|
366 |
-
def
|
367 |
-
|
368 |
-
|
369 |
-
|
370 |
-
|
371 |
-
|
372 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
373 |
)
|
374 |
-
|
|
|
375 |
response_text = result if isinstance(result, str) else "Error in processing"
|
376 |
return response_text
|
377 |
-
|
378 |
-
# Main function to handle the Gradio interface logic
|
379 |
|
380 |
def process_and_query(input_language=None, audio_input=None, image_input=None, text_input=None):
|
381 |
try:
|
@@ -433,8 +448,8 @@ def process_and_query(input_language=None, audio_input=None, image_input=None, t
|
|
433 |
for source in sources_info:
|
434 |
markdown_output += f"* {source}\n"
|
435 |
|
436 |
-
# Process the summary with
|
437 |
-
final_response =
|
438 |
|
439 |
# Convert translated text to speech and get both audio file and text
|
440 |
target_language = "English" # Set the target language for the speech
|
@@ -444,7 +459,7 @@ def process_and_query(input_language=None, audio_input=None, image_input=None, t
|
|
444 |
hallucination_label = evaluate_hallucination(final_response, summary)
|
445 |
|
446 |
# Add final response and hallucination label to Markdown output
|
447 |
-
markdown_output += "\n### Processed Summary with
|
448 |
markdown_output += final_response + "\n"
|
449 |
markdown_output += "\n### Hallucination Evaluation\n"
|
450 |
markdown_output += f"* **Label**: {hallucination_label}\n"
|
|
|
24 |
|
25 |
🗣️📝Interact with ⚕🗣️😷MultiMed⚕ in any language using image, audio or text!
|
26 |
|
27 |
+
📚🌟💼 that uses [allenai/tulu-2-dpo-13b](https://huggingface.co/allenai/tulu-2-dpo-13b) & [Tonic/mistralmed](https://huggingface.co/Tonic/mistralmed) and [adept/fuyu-8B](https://huggingface.co/adept/fuyu-8b) with [Vectara](https://huggingface.co/vectara) embeddings + retrieval w/ [Facebook/Seamless-m4t](https://huggingface.co/facebook/hf-seamless-m4t-large) for audio translation & accessibility.
|
28 |
do [get in touch](https://discord.gg/GWpVpekp). You can also use 😷MultiMed⚕️ on your own data & in your own way by cloning this space. 🧬🔬🔍 Simply click here: <a style="display:inline-block" href="https://huggingface.co/spaces/TeamTonic/MultiMed?duplicate=true"><img src="https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=14" alt="Duplicate Space"></a></h3>
|
29 |
### Join us :
|
30 |
|
|
|
76 |
components = {}
|
77 |
dotenv.load_dotenv()
|
78 |
seamless_client = Client("facebook/seamless_m4t")
|
79 |
+
tulu_client = Client("https://tonic1-tulu.hf.space/--replicas/xh5ff/")
|
80 |
HuggingFace_Token = os.getenv("HuggingFace_Token")
|
81 |
hf_token = os.getenv("HuggingFace_Token")
|
82 |
device = "cuda" if torch.cuda.is_available() else "cpu"
|
|
|
363 |
return f"Error: {response.status_code}"
|
364 |
|
365 |
|
366 |
+
def process_summary_with_tulu(summary):
|
367 |
+
# Define the parameters for the Tulu Gradio client API call
|
368 |
+
your_message = summary
|
369 |
+
assistant_message = "You are a medical instructor. Assess and describe the proper options to your students in minute detail. Propose a course of action for them to base their recommendations on based on your description."
|
370 |
+
max_new_tokens = 650
|
371 |
+
temperature = 0.4
|
372 |
+
top_p = 0.9
|
373 |
+
repetition_penalty = 0.9
|
374 |
+
advanced = True
|
375 |
+
|
376 |
+
# Initialize the Tulu client
|
377 |
+
tulu_client = Client("https://tonic1-tulu.hf.space/--replicas/xh5ff/")
|
378 |
+
|
379 |
+
# Make the API call
|
380 |
+
result = tulu_client.predict(
|
381 |
+
your_message,
|
382 |
+
assistant_message,
|
383 |
+
max_new_tokens,
|
384 |
+
temperature,
|
385 |
+
top_p,
|
386 |
+
repetition_penalty,
|
387 |
+
advanced,
|
388 |
+
fn_index=0
|
389 |
)
|
390 |
+
|
391 |
+
# Process the result
|
392 |
response_text = result if isinstance(result, str) else "Error in processing"
|
393 |
return response_text
|
|
|
|
|
394 |
|
395 |
def process_and_query(input_language=None, audio_input=None, image_input=None, text_input=None):
|
396 |
try:
|
|
|
448 |
for source in sources_info:
|
449 |
markdown_output += f"* {source}\n"
|
450 |
|
451 |
+
# Process the summary with Tulu
|
452 |
+
final_response = process_summary_with_tulu(summary)
|
453 |
|
454 |
# Convert translated text to speech and get both audio file and text
|
455 |
target_language = "English" # Set the target language for the speech
|
|
|
459 |
hallucination_label = evaluate_hallucination(final_response, summary)
|
460 |
|
461 |
# Add final response and hallucination label to Markdown output
|
462 |
+
markdown_output += "\n### Processed Summary with Tulu\n"
|
463 |
markdown_output += final_response + "\n"
|
464 |
markdown_output += "\n### Hallucination Evaluation\n"
|
465 |
markdown_output += f"* **Label**: {hallucination_label}\n"
|