File size: 2,476 Bytes
6c036c1
aab52b9
 
 
b08158b
a9b1392
aab52b9
b08158b
61e43c4
 
 
b08158b
 
 
19693ec
4025a2e
b08158b
5ef6d7c
953176b
9894719
953176b
 
 
 
5ef6d7c
e3d3bd5
b08158b
 
 
 
19693ec
 
b08158b
953176b
f60a1b9
b08158b
953176b
b08158b
953176b
b1f7af6
19693ec
 
aab52b9
 
19693ec
aab52b9
4025a2e
b08158b
 
 
 
aab52b9
 
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
from transformers import AutoModelForCausalLM, AutoTokenizer
import torch

# Cargar el modelo y el tokenizador solo una vez para evitar recargas
model_name = "BSC-LT/salamandra-2b"

if "tokenizer" not in globals():
    tokenizer = AutoTokenizer.from_pretrained(model_name, trust_remote_code=True)
    tokenizer.pad_token = tokenizer.eos_token  # 馃敼 Evita errores de atenci贸n

if "model" not in globals():
    model = AutoModelForCausalLM.from_pretrained(model_name, torch_dtype=torch.float16)
    model.eval()  # 馃敼 Optimiza la inferencia para que sea m谩s r谩pida

# Funci贸n exclusiva para humanizaci贸n de texto con enfoque en marketing
def humanize_text(input_text):
    system_prompt = (
        "Transforma el siguiente texto en un mensaje m谩s natural, accesible y atractivo, "
        "manteniendo su significado original. "
        "Adopta un tono m谩s claro y cercano, ideal para comunicaci贸n en marketing. "
        "Convierte estructuras r铆gidas en frases m谩s din谩micas y fluidas, "
        "pero sin perder profesionalismo ni omitir informaci贸n importante. "
        "El resultado debe sentirse humano y aut茅ntico."
    )

    prompt = f"{system_prompt}\n\nTexto original: {input_text}\n\nTexto humanizado:"
    
    inputs = tokenizer(prompt, return_tensors="pt", padding=True, truncation=True)

    outputs = model.generate(
        inputs.input_ids,
        attention_mask=inputs.attention_mask,
        max_new_tokens=170,  # 馃敼 M谩s margen para reformular bien
        min_length=30,  # 馃敼 Evita respuestas demasiado cortas
        do_sample=True,  # 馃敼 Mantiene variabilidad en la reescritura
        temperature=0.85,  # 馃敼 M谩s creatividad sin perder precisi贸n
        top_p=0.9,  # 馃敼 Mantiene coherencia en la reescritura
        repetition_penalty=1.05,  # 馃敼 Evita repeticiones sin restringir demasiado
        num_return_sequences=1,  # 馃敼 Genera solo una respuesta bien formulada
    )

    return tokenizer.decode(outputs[0], skip_special_tokens=True)

# Interfaz en Gradio
with gr.Blocks() as demo:
    gr.Markdown("# 鉁嶏笍 Humanizaci贸n de Texto con ALIA (Optimizado para Marketing)")
    input_text = gr.Textbox(label="Pega aqu铆 el texto generado por IA para humanizar")
    output_text = gr.Textbox(label="Texto humanizado por ALIA", interactive=False)
    submit_button = gr.Button("Humanizar Texto")
    submit_button.click(humanize_text, inputs=input_text, outputs=output_text)

demo.launch()