Concevoir des workflows IA multi-étapes

Introduction à l’IA générative dans Snowflake

James Cha-Earley

Senior Developer Advocate, Snowflake

Workflow de révision Cortex

Objectif : Construire un système automatisé pour les retours d'invités internationaux

$$

  • Traduire chaque avis en anglais
  • Résumer le point principal
  • Le catégoriser pour l'orienter vers la bonne équipe
  • Générer une réponse
  • La traduire dans la langue d'origine

Workflow où un avis est reçu, traduit, résumé et catégorisé, et une réponse est envoyée

Introduction à l’IA générative dans Snowflake

Extraction des avis

-- SQL cell
SELECT DESCRIPTION
FROM HOTELS.REVIEWS
WHERE LANGUAGE = 'es'
LIMIT 1;
# Python cell
df = cell1.to_pandas()
review_text = df["DECRIPTION"].iloc[0]
Introduction à l’IA générative dans Snowflake

Avis en espagnol

print(review_text)
Buen hotel y bien situado pero desafortunadamente no me toco buena suerte con 
el servicio; el aire no servía; pedí la cama extra tres veces; la cafetera estaba
dañada; y me sacaron las maletas fuera porque argumentaron que no hice Check out;
siendo que era un día despues; pero su sistema lo marco antes; una total
descortesía hecharme del cuarto y cancelar mis llaves; regresar de caminar y darse
cuenta que han tomado tus cosas fuera es increíble y mas aun sin ninguna disculpa;
yo no volvería ahí aunque la vrd el hotel es bueno y su jubilación el trato
me decepciono
Introduction à l’IA générative dans Snowflake

Traduction

translated = translate(
    text=review_text,
    from_language="es",
    to_language="en"
)

print(translated)
Good hotel and well located, but unfortunately, I didn't have good luck with the service; the air
conditioning didn't work; I asked for the extra bed three times; the coffee maker was broken; 
and they took my bags out because they argued that I hadn't checked out; even though it was a day
later; but their system marked it as checked out; a total discourtesy to throw me out of the room
and cancel my keys; returning from a walk and realizing they've taken your things out is
incredible and even more so without any apology; I wouldn't go back there even though the hotel
itself is good and their retirement the treatment disappoints me.
Introduction à l’IA générative dans Snowflake

Résumé

summary = summarize(text=translated)

print(summary)
The hotel was well-located, but the service was disappointing. The air conditioning
didn't work, an extra bed was not provided despite multiple requests, and the coffee
maker was broken. The hotel staff took the complainant's bags and canceled their
keys despite a later checkout date, which was discourteous and left the complainant
feeling disappointed.
Introduction à l’IA générative dans Snowflake

Classification

topic = classify_text(
    text=summary,
    labels=["staff", "cleanliness", "pricing", "room", "food"]
)

print(topic)
{
  "label": "staff"
}
Introduction à l’IA générative dans Snowflake

Génération de texte

response = complete(
        prompt=f"Write a brief and professional response to this review: {summary}",
        model='llama3.1-8b',
        options={'temperature':0.3, 'max_tokens':120})

print(response)
Thank you for sharing your feedback. While we're glad you found the location
convenient, we're truly sorry to hear about the service issues you experienced.
We understand how frustrating it must have been to face multiple inconveniences
during your stay. Your comments have been shared with the team to ensure these concerns
are addressed and do not recur.
Introduction à l’IA générative dans Snowflake

Traduction de la réponse

translated_response = translate(
    text=response,
    from_language="en",
    to_language="es"
)

print(translated_response)
Gracias por compartir sus comentarios. Si bien nos alegra saber que encontró conveniente
la ubicación, lamentamos sinceramente los inconvenientes que experimentó con el servicio.
Entendemos lo frustrante que debió haber sido enfrentar múltiples inconvenientes durante
su estadía. Sus comentarios han sido compartidos con el equipo para asegurarnos de que
estas situaciones se aborden y no vuelvan a ocurrir.
Introduction à l’IA générative dans Snowflake

Modèle de coût Cortex

Un workflow Cortex montrant que les jetons d'entrée, de calcul et de sortie ont tous un coût associé

1 Image générée par ChatGPT-4o
Introduction à l’IA générative dans Snowflake

Limiter le coût

$$

  • Réduire les entrées, traiter uniquement le texte pertinent

  • Limiter la taille de sortie

  • Baisser la température

# Limiter le coût de complete
complete(prompt=prompt, 
         model='llama3.1-8b', 
         options={
            'max_tokens':120,

'temperature':0})
Introduction à l’IA générative dans Snowflake

Bonnes pratiques Cortex

  • Enchaîner efficacement les modèles
# Résumer d'abord si plusieurs fonctions en aval sont appelées
summarize()
text_classify()
complete()
translate()
  • Journalisation
  • Mise en cache
  • Pipelines par lots
Introduction à l’IA générative dans Snowflake

Passons à la pratique !

Introduction à l’IA générative dans Snowflake

Preparing Video For Download...