|
import gradio as gr |
|
from transformers import pipeline |
|
import cv2 |
|
import numpy as np |
|
import requests |
|
import g4f |
|
import time |
|
import os |
|
import base64 |
|
|
|
theme = gr.themes.Base( |
|
primary_hue="cyan", |
|
secondary_hue="blue", |
|
neutral_hue="slate", |
|
) |
|
|
|
API_KEY = os.getenv("API_KEY") |
|
|
|
|
|
BREAST_CANCER_API_URL = "https://api-inference.huggingface.co/models/MUmairAB/Breast_Cancer_Detector" |
|
|
|
headers = {"Authorization": "Bearer "+API_KEY+"", 'Content-Type': 'application/json'} |
|
alzheimer_classifier = pipeline("image-classification", model="AhmadHakami/alzheimer-image-classification-google-vit-base-patch16") |
|
|
|
brain_tumor_classifier = pipeline("image-classification", model="Devarshi/Brain_Tumor_Classification") |
|
|
|
|
|
def classify_alzheimer(image): |
|
with open(image, 'rb') as img: |
|
encoded_string = base64.b64encode(img.read()) |
|
image_base = encoded_string.decode('utf-8') |
|
|
|
result = alzheimer_classifier(image_base) |
|
prediction = result[0] |
|
score = prediction['score'] |
|
label = prediction['label'] |
|
return {"score": score, "label": label} |
|
|
|
|
|
|
|
def classify_breast_cancer(image): |
|
image_data = np.array(image, dtype=np.uint8) |
|
_, buffer = cv2.imencode('.jpg', image_data) |
|
binary_data = buffer.tobytes() |
|
|
|
response = requests.post(BREAST_CANCER_API_URL, headers=headers, data=binary_data) |
|
result = {} |
|
print(response.json()) |
|
for ele in response.json(): |
|
label, score = ele.values() |
|
result[label] = score |
|
|
|
return result |
|
|
|
|
|
|
|
def classify_brain_tumor(image): |
|
with open(image, 'rb') as img: |
|
encoded_string = base64.b64encode(img.read()) |
|
image_base = encoded_string.decode('utf-8') |
|
|
|
result = brain_tumor_classifier(image_base) |
|
prediction = result[0] |
|
score = prediction['score'] |
|
label = prediction['label'] |
|
return {"score": score, "label": label} |
|
|
|
|
|
|
|
with gr.Blocks(theme=theme) as Alzheimer: |
|
with gr.Row(): |
|
with gr.Column(): |
|
gr.Markdown("# Alzheimer Detection and Classification") |
|
gr.Markdown("> Classify the alzheimer into Mild Demented, Very Mild Demented, Moderate Demented and Non Demented.") |
|
image = gr.Image() |
|
output = gr.Label(label='Alzheimer Classification', container=True, scale=2) |
|
with gr.Row(): |
|
gr.ClearButton([image, output]) |
|
button = gr.Button(value="Submit", variant="primary") |
|
gr.Examples(inputs=image, fn=classify_alzheimer, examples=[os.path.join(os.path.dirname(__file__), "diseases/Alzheimer/mild_12.jpg"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Alzheimer/moderate_21.jpg"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Alzheimer/verymild_1013.jpg")]) |
|
|
|
button.click(classify_alzheimer, [image], [output]) |
|
|
|
def respond(message, history): |
|
bot_message = g4f.ChatCompletion.create( |
|
model="gpt-3.5-turbo", |
|
provider=g4f.Provider.Vercel, |
|
messages=[{"role": "user", |
|
"content": "Your role is Alzheimer Disease Expert. Now I will provide you with the user query. First check if the user query is related to Alzheimer or not. If it is not related to Alzheimer then simply avoid the query by saying this is not my expertise, whereas if related to Alzheimer reply it as usual. Here's the user Query:" + message}], |
|
) |
|
time.sleep(1) |
|
return str(bot_message) |
|
|
|
|
|
with gr.Column(): |
|
gr.Markdown("# Health Bot for Alzheimer") |
|
gr.Markdown("> **Note:** The information may not be accurate. Please consult a Doctor before considering any actions.") |
|
gr.ChatInterface(respond, autofocus=False, examples=["Explain Alzhiemer diasease.", "What are the types of Alzhiemer diasease?", "Alzhiemer Prevention methods."]).queue() |
|
|
|
|
|
with gr.Blocks(theme=theme) as BreastCancer: |
|
with gr.Row(): |
|
with gr.Column(): |
|
gr.Markdown("# Breast Cancer Detection and Classification") |
|
gr.Markdown("> Classify the breast cancer.") |
|
image = gr.Image() |
|
output = gr.Label(label='Breast Cancer Classification', container=True, scale=2) |
|
with gr.Row(): |
|
button = gr.Button(value="Submit", variant="primary") |
|
gr.ClearButton([image, output]) |
|
gr.Examples(inputs=image, fn=classify_breast_cancer, |
|
examples=[os.path.join(os.path.dirname(__file__), "diseases/Breast_Cancer/class0.png"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Breast_Cancer/class0_1.png"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Breast_Cancer/class1.png"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Breast_Cancer/class1_1.png")]) |
|
|
|
button.click(classify_breast_cancer, [image], [output]) |
|
|
|
def respond(message, history): |
|
bot_message = g4f.ChatCompletion.create( |
|
model="gpt-3.5-turbo", |
|
provider=g4f.Provider.Vercel, |
|
messages=[{"role": "user", |
|
"content": "Your role is Breast_Cancer Disease Expert. Now I will provide you with the user query. First check if the user query is related to Breast_Cancer or not. If it is not related to Breast_Cancer then simply avoid the query by saying this is not my expertise, whereas if related to Breast_Cancer reply it as usual. Here's the user Query:" + message}], |
|
) |
|
time.sleep(1) |
|
yield str(bot_message) |
|
|
|
with gr.Column(): |
|
gr.Markdown("# Health Bot for Breast Cancer") |
|
gr.Markdown("> **Note:** The information may not be accurate. Please consult a Doctor before considering any actions.") |
|
gr.ChatInterface(respond, autofocus=False, examples=["Explain Breast Cancer.", "What are the types of Breast Cancer?", "Breast Cancer Prevention methods."]).queue() |
|
|
|
|
|
with gr.Blocks(theme=theme) as BrainTumor: |
|
with gr.Row(): |
|
with gr.Column(): |
|
gr.Markdown("# Brain Tumor Detection and Classification") |
|
gr.Markdown("> Classify the Brain Tumor.") |
|
image = gr.Image() |
|
output = gr.Label(label='Brain_Tumor Classification', container=True, scale=2) |
|
with gr.Row(): |
|
button = gr.Button(value="Submit", variant="primary") |
|
gr.ClearButton([image, output]) |
|
gr.Examples(inputs=image, fn=classify_brain_tumor, |
|
examples=[os.path.join(os.path.dirname(__file__), "diseases/Brain_Tumor/glioma.jpg"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Brain_Tumor/meningioma.jpg"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Brain_Tumor/no_tumor.jpg"), |
|
os.path.join(os.path.dirname(__file__), "diseases/Brain_Tumor/pituitary.jpg")]) |
|
|
|
button.click(classify_brain_tumor, [image], [output]) |
|
|
|
def respond(message, history): |
|
bot_message = g4f.ChatCompletion.create( |
|
model="gpt-3.5-turbo", |
|
provider=g4f.Provider.Vercel, |
|
messages=[{"role": "user", |
|
"content": "Your role is Brain Tumor Disease Expert. Now I will provide you with the user query. First check if the user query is related to Brain Tumor or not. If it is not related to Brain Tumor then simply avoid the query by saying this is not my expertise, whereas if related to Brain Tumor reply it as usual. Here's the user Query:" + message}], |
|
) |
|
time.sleep(1) |
|
return str(bot_message) |
|
|
|
with gr.Column(): |
|
gr.Markdown("# Health Bot for Brain Tumor") |
|
gr.Markdown("> **Note:** The information may not be accurate. Please consult a Doctor before considering any actions.") |
|
gr.ChatInterface(respond, autofocus=False, examples=["Explain Brain Tumor.", "What are the types of Brain Tumor?", "Brain Tumor Prevention methods."]).queue() |
|
|
|
|
|
Main = gr.TabbedInterface([Alzheimer, BreastCancer, BrainTumor], ["Alzheimer", "Breast Cancer", "Brain Tumor"], |
|
theme=theme, |
|
css=".gradio-container { background: rgba(255, 255, 255, 0.2) !important; box-shadow: 0 8px 32px 0 rgba( 31, 38, 135, 0.37 ) !important; backdrop-filter: blur( 10px ) !important; -webkit-backdrop-filter: blur( 10px ) !important; border-radius: 10px !important; border: 1px solid rgba( 0, 0, 0, 0.5 ) !important;}") |
|
|
|
Main.launch() |