File size: 1,279 Bytes
8e2980b
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import gradio as gr
from transformers import AutoImageProcessor, AutoModelForImageClassification
from PIL import Image
import torch

# Load model
model_id = "replyquickflorida/tooth-agenesis-model"
processor = AutoImageProcessor.from_pretrained(model_id)
model = AutoModelForImageClassification.from_pretrained(model_id)

# Class labels
id2label = {
    0: "Calculus",
    1: "Caries",
    2: "Gingivitis",
    3: "Mouth Ulcer",
    4: "Tooth Discoloration",
    5: "Hypodontia",
}

def predict(image):
    """Run inference on uploaded image"""
    # Process image
    inputs = processor(images=image, return_tensors="pt")
    
    # Run inference
    with torch.no_grad():
        outputs = model(**inputs)
        probs = torch.softmax(outputs.logits, dim=-1)[0]
    
    # Format results
    results = {}
    for idx, label in id2label.items():
        results[label] = float(probs[idx])
    
    return results

# Create Gradio interface
demo = gr.Interface(
    fn=predict,
    inputs=gr.Image(type="pil", label="Upload Tooth X-ray"),
    outputs=gr.Label(num_top_classes=6, label="Diagnosis"),
    title="Tooth Agenesis Diagnosis",
    description="Upload a dental X-ray image to get diagnosis predictions",
    examples=None
)

if __name__ == "__main__":
    demo.launch()