poolformerv2_s36.sail_in1k

timm
Clasificación de imagen

PoolFormer-v2 (un MetaFormer) modelo de clasificación de imágenes. Entrenado en ImageNet-1k por los autores del artículo. Tipo de modelo: Clasificación de imagen / columna vertebral de características. Estadísticas del modelo: Parámetros (M): 30.8, GMACs: 5.0, Activaciones (M): 15.8, Tamaño de la imagen: 224 x 224.

Como usar

Clasificación de Imágenes

from urllib.request import urlopen
from PIL import Image
import timm

img = Image.open(urlopen(
'https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/beignets-task-guide.png'
))

model = timm.create_model('poolformerv2_s36.sail_in1k', pretrained=True)
model = model.eval()

# obtener transformaciones específicas del modelo (normalización, redimensionamiento)
data_config = timm.data.resolve_model_data_config(model)
transforms = timm.data.create_transform(**data_config, is_training=False)

output = model(transforms(img).unsqueeze(0))  # añade una dimensión de batch de 1

top5_probabilities, top5_class_indices = torch.topk(output.softmax(dim=1) * 100, k=5)

Extracción de Mapas de Características

from urllib.request import urlopen
from PIL import Image
import timm

img = Image.open(urlopen(
'https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/beignets-task-guide.png'
))

model = timm.create_model(
'timm/poolformerv2_s36.sail_in1k',
pretrained=True,
features_only=True,
)
model = model.eval()

# obtener transformaciones específicas del modelo (normalización, redimensionamiento)
data_config = timm.data.resolve_model_data_config(model)
transforms = timm.data.create_transform(**data_config, is_training=False)

output = model(transforms(img).unsqueeze(0))  # añade una dimensión de batch de 1

for o in output:
# imprimir forma de cada mapa de características en el output
print(o.shape)

Embeddings de Imágenes

from urllib.request import urlopen
from PIL import Image
import timm

img = Image.open(urlopen(
'https://huggingface.co/datasets/huggingface/documentation-images/resolve/main/beignets-task-guide.png'
))

model = timm.create_model(
'timm/poolformerv2_s36.sail_in1k',
pretrained=True,
num_classes=0,  # eliminar clasificador nn.Linear
)
model = model.eval()

# obtener transformaciones específicas del modelo (normalización, redimensionamiento)
data_config = timm.data.resolve_model_data_config(model)
transforms = timm.data.create_transform(**data_config, is_training=False)

output = model(transforms(img).unsqueeze(0))  # el output es un tensor de tamaño (batch_size, num_features)

# o equivalentemente (sin necesidad de configurar num_classes=0)

output = model.forward_features(transforms(img).unsqueeze(0))
# el output no está agrupado, un tensor de tamaño (1, 512, 7, 7)

output = model.forward_head(output, pre_logits=True)
# el output es un tensor de tamaño (1, num_features)

Funcionalidades

Clasificación de imágenes
Extracción de mapas de características
Embeddings de imágenes

Casos de uso

Clasificación de imágenes
Extracción de mapas de características complejas de imágenes
Generación de embeddings de imágenes para uso posterior en tareas de aprendizaje automático