Spaces:
Sleeping
Sleeping
File size: 1,067 Bytes
84163d0 596a54e f828c3b 596a54e 84163d0 f828c3b 84163d0 f828c3b 84163d0 f828c3b 84163d0 596a54e f828c3b 596a54e 84163d0 f828c3b 596a54e f828c3b 84163d0 596a54e f828c3b 596a54e 84163d0 |
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 |
from fastapi import FastAPI
from pydantic import BaseModel
from transformers import AutoTokenizer, AutoModelForSequenceClassification
import torch
app = FastAPI(
title="Medical Text Classifier",
description="Classifier using Bio_ClinicalBERT",
version="1.0"
)
MODEL_NAME = "emilyalsentzer/Bio_ClinicalBERT"
tokenizer = AutoTokenizer.from_pretrained(MODEL_NAME)
model = AutoModelForSequenceClassification.from_pretrained(
MODEL_NAME,
num_labels=4 # تقدر تغيّر عدد اللابلز
)
LABELS = ["disease", "treatment", "test", "symptom"]
class Input(BaseModel):
text: str
@app.get("/")
def home():
return {"status": "Bio_ClinicalBERT is running"}
@app.post("/predict")
def predict(data: Input):
inputs = tokenizer(data.text, return_tensors="pt", truncation=True)
outputs = model(**inputs)
probs = torch.softmax(outputs.logits, dim=1)
label_id = torch.argmax(probs).item()
return {
"input": data.text,
"predicted_label": LABELS[label_id],
"confidence": float(probs.max())
}
|