ashishkgpian's picture
Update app.py
f07a774 verified
raw
history blame
7.67 kB
import gradio as gr
from transformers import pipeline
import pandas as pd
import os
# Load the model
classifier = pipeline(
"text-classification",
model="ashishkgpian/biolinkbert_base_icd9_classifier_ehr_symptoms_text_icd9_150_epochs_v2"
)
# Load ICD9 codes data
icd9_data = pd.read_csv('D_ICD_DIAGNOSES.csv')
icd9_data.columns = ['ROW_ID', 'ICD9_CODE', 'SHORT_TITLE', 'LONG_TITLE']
def preprocessing(test_df):
test_df.loc[
test_df['ICD9_CODE'].str.startswith("V"), 'ICD9_CODE'] = test_df.ICD9_CODE.apply(
lambda x: x[:4])
test_df.loc[
test_df['ICD9_CODE'].str.startswith("E"), 'ICD9_CODE'] = test_df.ICD9_CODE.apply(
lambda x: x[:4])
test_df.loc[(~test_df.ICD9_CODE.str.startswith("E")) & (
~test_df.ICD9_CODE.str.startswith("V")), 'ICD9_CODE'] = test_df.ICD9_CODE.apply(
lambda x: x[:3])
return test_df
icd9_data = preprocessing(icd9_data)
def classify_symptoms(text):
try:
results = classifier(text, top_k=5)
formatted_results = []
for result in results:
code = result['label']
code_info = icd9_data[icd9_data['ICD9_CODE'] == code]
formatted_results.append({
"ICD9 Code": code,
"Short Title": code_info['SHORT_TITLE'].iloc[0] if not code_info.empty else "N/A",
"Long Title": code_info['LONG_TITLE'].iloc[0] if not code_info.empty else "N/A",
"Confidence": f"{result['score']:.2%}"
})
return formatted_results
except Exception as e:
return f"Error processing classification: {str(e)}"
custom_css = """
.gradio-container {
width: 100% !important;
max-width: 100% !important;
margin: 0 !important;
padding: 0 !important;
min-height: 100vh !important;
display: flex !important;
flex-direction: column !important;
background-color: #000000 !important;
color: #ffffff !important;
}
.main-container {
text-align: center;
padding: 2rem;
margin: 0;
background: #000000;
width: 100%;
color: #ffffff;
}
.content-wrapper {
max-width: 1400px;
margin: 0 auto;
padding: 0 2rem;
width: 100%;
box-sizing: border-box;
background: #000000;
color: #ffffff;
}
h1 {
color: #b388ff !important;
font-size: 2.5rem !important; /* Reduced from 3rem */
margin-bottom: 0.5rem !important;
font-weight: 700 !important;
}
h3 {
color: #9575cd !important;
font-size: 1.2rem !important; /* Reduced from 1.4rem */
font-weight: 500 !important;
margin-bottom: 2rem !important;
}
.input-container {
background: #121212 !important;
padding: 2rem !important;
border-radius: 12px !important;
box-shadow: 0 4px 6px rgba(255, 255, 255, 0.05) !important;
margin: 2rem 0 !important;
width: 100% !important;
border: 1px solid #333333 !important;
}
.input-container label {
color: #ffffff !important;
font-weight: 600 !important;
font-size: 1rem !important; /* Reduced from 1.1rem */
margin-bottom: 0.5rem !important;
background: transparent !important;
}
textarea {
background: #1e1e1e !important;
color: #ffffff !important;
border: 2px solid #673ab7 !important;
border-radius: 8px !important;
padding: 1rem !important;
font-size: 1.1rem !important; /* Reduced from 1.2rem */
min-height: 150px !important;
width: 100% !important;
}
.submit-btn {
background-color: #673ab7 !important;
color: white !important;
padding: 1rem 3rem !important;
border-radius: 8px !important;
font-size: 1.1rem !important; /* Reduced from 1.2rem */
margin-top: 1.5rem !important;
transition: all 0.3s ease !important;
width: auto !important;
font-weight: 600 !important;
border: none !important;
}
.submit-btn:hover {
background-color: #5e35b1 !important;
}
.output-container {
background: #121212 !important;
padding: 2rem !important;
border-radius: 12px !important;
box-shadow: 0 4px 6px rgba(255, 255, 255, 0.05) !important;
margin: 2rem 0 !important;
width: 100% !important;
border: 1px solid #333333 !important;
color: #ffffff !important;
}
.output-container label {
color: #ffffff !important;
font-weight: 600 !important;
font-size: 1rem !important; /* Reduced from 1.1rem */
margin-bottom: 1rem !important;
background: transparent !important;
}
.examples-container {
background: #121212 !important;
padding: 2rem !important;
border-radius: 12px !important;
margin: 2rem 0 !important;
box-shadow: 0 4px 6px rgba(255, 255, 255, 0.05) !important;
width: 100% !important;
border: 1px solid #333333 !important;
color: #ffffff !important;
}
.examples-container label {
color: #ffffff !important;
font-weight: 600 !important;
font-size: 1rem !important; /* Reduced from 1.1rem */
background: transparent !important;
}
.footer {
text-align: center;
padding: 2rem;
background: #000000;
margin-top: auto;
width: 100%;
border-top: 1px solid #333333;
color: #ffffff;
}
"""
with gr.Blocks(css=custom_css) as demo:
with gr.Row(elem_classes=["main-container"]):
with gr.Column(elem_classes=["content-wrapper"]):
gr.Markdown(
"""
# 🏥 Clinical Symptom ICD9 Classifier
### AI-Powered Medical Diagnosis Code Suggestion Tool
"""
)
with gr.Row(elem_classes=["input-output-row"]):
with gr.Column(elem_classes=["input-container"]):
gr.Markdown("Clinical Symptom Description")
with gr.Column(elem_classes=["inner-input-container"]):
input_text = gr.Textbox(
show_label=False,
placeholder="Enter detailed patient symptoms and clinical observations...",
lines=5
)
submit_btn = gr.Button("Analyze Symptoms", elem_classes=["submit-btn"])
with gr.Column(elem_classes=["output-container"]):
output = gr.JSON(
label="Suggested ICD9 Diagnostic Codes with Descriptions"
)
with gr.Row(elem_classes=["examples-container"]):
examples = gr.Examples(
examples=[
["45-year-old male experiencing severe chest pain, radiating to left arm, with shortness of breath and excessive sweating"],
["Persistent headache for 2 weeks, accompanied by dizziness and occasional blurred vision"],
["Diabetic patient reporting frequent urination, increased thirst, and unexplained weight loss"],
["Elderly patient with chronic knee pain, reduced mobility, and signs of inflammation"]
],
inputs=input_text,
label="Example Clinical Cases"
)
submit_btn.click(fn=classify_symptoms, inputs=input_text, outputs=output)
input_text.submit(fn=classify_symptoms, inputs=input_text, outputs=output)
with gr.Row(elem_classes=["footer"]):
gr.Markdown(
"""
⚕️ <strong>Medical Disclaimer:</strong> This AI tool is designed to assist medical professionals in ICD9 code classification.
Always verify suggestions with clinical judgment and consult appropriate medical resources.
"""
)
if __name__ == "__main__":
demo.launch(share=True)