File size: 1,436 Bytes
4c4b26c
 
 
 
 
 
 
 
 
 
 
 
 
2cea944
4c4b26c
 
 
 
2cea944
d869637
4c4b26c
2cea944
d869637
4c4b26c
96e80a0
4c4b26c
2cea944
4c4b26c
4940ea7
 
 
4c4b26c
4940ea7
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import gradio as gr
import numpy as np
from tensorflow.keras.models import load_model

# Load the trained model
model = load_model('skin_model.h5')

# Define a function to make predictions
def predict(image):
    # Preprocess the image
    image = image / 255.0
    image = np.expand_dims(image, axis=0)
    
    # Make a prediction using the model
    prediction = model.predict(image)
    
    # Get the predicted class label
    if prediction[0][0] < 0.5:
        label = 'Benign'
        confidence = 1 - prediction[0][0]  # Confidence for benign
    else:
        label = 'Malignant'
        confidence = prediction[0][0]  # Confidence for malignant
    
    return {'label': label, 'confidence': float(confidence)}  # Convert confidence to float

examples = [["benign.jpg"], ["malignant.jpg"]]

# Define input and output components
image_input = gr.inputs.Image(shape=(150, 150))
label_output = gr.outputs.Label()

# Define a Gradio interface for user interaction
iface = gr.Interface(
    fn=predict,
    inputs=image_input,
    outputs=label_output,
    examples=examples,
    title="Skin Cancer Classification",
    description="Predicts whether a skin image is cancerous or not.",
    theme="default",  # Choose a theme: "default", "compact", "huggingface"
    layout="vertical",  # Choose a layout: "vertical", "horizontal", "double"
    live=False  # Set to True for live updates without clicking "Submit"
)

iface.launch()