Attività e valutazioni delle pipeline

Modelli multi-modali con Hugging Face

James Chapman

Curriculum Manager, DataCamp

Pipeline vs. componenti del modello

Approccio attuale

from transformers import BlipProcessor, BlipForConditionalGeneration
checkpoint = "Salesforce/blip-image-captioning-base"
processor = BlipProcessor.from_pretrained(checkpoint)
model = BlipForConditionalGeneration.from_pretrained(checkpoint)

Pipeline

from transformers import pipeline
pipe = pipeline("image-to-text", model=checkpoint)
Modelli multi-modali con Hugging Face

Confronto di esempio

Preprocessore e modello direttamente

inputs = processor(images=image, 
                   return_tensors="pt")
gen = model.generate(**inputs)
processor.decode(gen[0])

Pipeline

pipe(image)
[{'generated_text': 
'a man wearing a black shirt'}]

datapoint5

Modelli multi-modali con Hugging Face

Trovare modelli e task

Trova modelli per una pipeline via API:

from huggingface_hub import HfApi
model = list(api.list_models(task="text-to-image", limit=5))
pipe = pipeline("text-to-image", model[0].id)

Schermata della home del modello su Hugging Face

Modelli multi-modali con Hugging Face

Passare opzioni ai modelli

  • MusicgenForConditionalGeneration sotto il cofano
pipe = pipeline(task="text-to-audio", 
                model="facebook/musicgen-small", framework="pt")
generate_kwargs = {"temperature": 0.8, "max_new_tokens": 20}

outputs = pipe("Classic rock riff", generate_kwargs=generate_kwargs)
  • temperature (0-1): controlla casualità e creatività
  • max_new_tokens: limita il numero di token generati
Modelli multi-modali con Hugging Face

Valutare le prestazioni della pipeline

  • Accuracy: quota totale di classificazioni corrette
  • Precision: quanto spesso le predizioni di classe sono corrette
  • Recall: quante classi reali sono state identificate correttamente
  • F1 Score: combina precision e recall
from evaluate import evaluator

task_evaluator = evaluator("image-classification")
metrics_dict = { "precision": "precision", "recall": "recall", "f1": "f1", }
label_map = pipe.model.config.label2id
Modelli multi-modali con Hugging Face

Valutare le prestazioni della pipeline

eval_results = task_evaluator.compute(
  model_or_pipeline=pipe,

data=dataset,
metric=evaluate.combine(metrics_dict),
label_mapping=label_map)
print(eval_results)
{'precision': 0.999001923076923, 
'recall': 0.999, 
'f1': 0.9989999609405906, ...}
pipe = pipeline(task="image-classification",
model="ideepankarsharma2003/AI_ImageClassi
fication_MidjourneyV6_SDXL"
)
dataset = load_dataset("ideepankarsharma2003/
Midjourney_v6_Classification_small_shuffled")

esempio di immagine AI del dataset: un cane sott'acqua

Modelli multi-modali con Hugging Face

Vamos praticar!

Modelli multi-modali con Hugging Face

Preparing Video For Download...