File size: 1,393 Bytes
3b6f551
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
50
51
52
53
54
import gradio as gr
import tensorflow as tf
import numpy as np
from PIL import Image

# Carregar o modelo treinado
# O modelo deve estar na mesma pasta que este script
model = tf.keras.models.load_model('meu_modelo.h5')

def predict_image(img):
    # Converter a imagem PIL para um array NumPy
    img = np.array(img)

    # Redimensionar a imagem para o tamanho esperado pelo modelo (224, 224)
    img = tf.image.resize(img, (224, 224))

    # Pré-processamento manual para MobileNetV2:
    # Escalar os valores de pixel para o intervalo [-1, 1]
    img = img / 127.5 - 1

    # Adicionar uma dimensão de batch
    img = np.expand_dims(img, axis=0)

    prediction = model.predict(img)

    # Interpretar o resultado da predição e criar um dicionário para a saída
    if prediction < 0.5:
        result = {"ai": float(1 - prediction[0][0]), "human": float(prediction[0][0])}
    else:
        result = {"human": float(prediction[0][0]), "ai": float(1 - prediction[0][0])}

    return result

# Lista de exemplos
# As imagens de exemplo devem estar na mesma pasta que este script
exemplos = [
    'vangoghai.jpg',
    'vangoghhuman.jpg'
]

# Criar a interface do gradio
image_input = gr.Image()
label_output = gr.Label()

interface = gr.Interface(
    fn=predict_image,
    inputs=image_input,
    outputs=label_output,
    examples=exemplos
)

# Lançar a interface
interface.launch()