File size: 2,868 Bytes
3767294
058b417
c162eaf
183273b
79852cb
2f92e03
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
bf9ae69
b5c1947
d17bdaa
 
 
 
 
 
 
 
0745070
b2802d9
bf9ae69
0745070
b2802d9
0745070
 
b5c1947
0745070
45c0de0
0745070
b5c1947
0745070
 
 
 
c73ec2c
b5c1947
02b6ab1
b5c1947
c73ec2c
 
c4b2c28
0745070
45c0de0
0745070
 
016a73d
0745070
 
 
c73ec2c
 
 
0745070
c73ec2c
 
 
10a0cf1
c73ec2c
 
 
 
 
2f92e03
 
0745070
 
 
 
79852cb
 
 
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import streamlit as st
from transformers import pipeline
import time

#Nombre_modelo = 'pysentimiento/robertuito-sentiment-analysis'
#######################creacion de funciones######################
def cargar_modelo(model_name):
    return pipeline("zero-shot-classification", model=model_name, device=0)

def graficar(result):
    # Crear un gr谩fico de pastel
    fig, ax = plt.subplots()
    ax.pie(result["scores"], labels=result["labels"], autopct="%1.1f%%", startangle=90)
    ax.axis("equal")  # Hace que el gr谩fico sea un c铆rculo perfecto
    # Mostrar el gr谩fico en Streamlit
    st.pyplot(fig)    

#######################fin creacion de funciones######################




st.title("Ejercicio interfaz transformers pipeline con modelos Zero-shot")

model_options = [
    "facebook/bart-large-mnli",
    "roberta-large-mnli",
    "cross-encoder/nli-roberta-base"
]
# Seleccionar el modelo del pipeline
selected_model = st.selectbox("Selecciona un modelo", model_options)
#funcion eleccion del modelo
@st.cache_resource

#asignacion del modelo a usar
classifier = cargar_modelo(selected_model)

# Entrada de texto para la oraci贸n
nombre = st.text_input("Ingrese un nombre o una oraci贸n  a clasificar:")

etiquetas = st.text_area(
    "Ingresa las categor铆as separadas por comas:",
    placeholder="Ejemplo: masculino,femenino"
)

# Bot贸n para clasificar
if st.button("Clasificar"):
# Show a spinner during a process
    with st.spinner(text="Ejecutando el modelo"):
        time.sleep(3)
        st.success("Revisar el resultado obtenido en la parte inferior")    

    
    if nombre and etiquetas:
        # Procesar las categor铆as ingresadas por el usuario
        labels = [label.strip() for label in etiquetas.split(",")]

        # Obtener las predicciones
        result = classifier(nombre, candidate_labels=labels)

        # Mostrar los resultados
        st.subheader("Resultados de Clasificaci贸n")
        #for label, score in zip(result["labels"], result["scores"]):
        #    st.write(f"**{label}**: {score:.2f}")
        
        for label, score in zip(result["labels"], result["scores"]):
            with st.container():
                st.markdown(
                    f"""
                    <div style="background-color: #283747;padding:10px;margin-bottom:10px;border-radius:5px;border: 1px solid #ddd;">
                        <h4 style="margin:0;">{label}</h4>
                        <p style="margin:0;">Confianza: <b>{score:.2f}</b></p>
                    </div>
                    """,
                    unsafe_allow_html=True,
                )
        graficar(result)
    else:
        st.warning("Por favor, ingresa una oraci贸n y categor铆as v谩lidas.")

        
#Clasificador =  pipeline('sentiment-analysis', model = Nombre_modelo,device='cuda')
#Res=Cla("sundays are good day for relaxing")
#print(Res)