Real-time collaboration for Jupyter Notebooks, Linux Terminals, LaTeX, VS Code, R IDE, and more,
all in one place. Commercial Alternative to JupyterHub.
Real-time collaboration for Jupyter Notebooks, Linux Terminals, LaTeX, VS Code, R IDE, and more,
all in one place. Commercial Alternative to JupyterHub.
Path: blob/main/transformers_doc/pt/quicktour.ipynb
Views: 2542
Tour rápido
Comece a trabalhar com 🤗 Transformers! Comece usando pipeline()
para rápida inferência e facilmente carregue um modelo pré-treinado e um tokenizer com AutoClass para resolver tarefas de texto, visão ou áudio.
Todos os exemplos de código apresentados na documentação têm um botão no canto superior direito para escolher se você deseja ocultar ou mostrar o código no Pytorch ou no TensorFlow. Caso contrário, é esperado que funcione para ambos back-ends sem nenhuma alteração.
Pipeline
pipeline()
é a maneira mais fácil de usar um modelo pré-treinado para uma dada tarefa.
A pipeline()
apoia diversas tarefas fora da caixa:
Texto:
Análise sentimental: classifica a polaridade de um texto.
Geração de texto (em Inglês): gera texto a partir de uma entrada.
Reconhecimento de entidade mencionada: legenda cada palavra com uma classe que a representa (pessoa, data, local, etc...)
Respostas: extrai uma resposta dado algum contexto e uma questão
Máscara de preenchimento: preenche o espaço, dado um texto com máscaras de palavras.
Sumarização: gera o resumo de um texto longo ou documento.
Tradução: traduz texto para outra língua.
Extração de características: cria um tensor que representa o texto.
Imagem:
Classificação de imagens: classifica uma imagem.
Segmentação de imagem: classifica cada pixel da imagem.
Detecção de objetos: detecta objetos em uma imagem.
Audio:
Classficação de áudio: legenda um trecho de áudio fornecido.
Reconhecimento de fala automático: transcreve audio em texto.
Para mais detalhes sobre a pipeline()
e tarefas associadas, siga a documentação aqui.
Uso da pipeline
No exemplo a seguir, você usará pipeline()
para análise sentimental.
Instale as seguintes dependências se você ainda não o fez:
Importe pipeline()
e especifique a tarefa que deseja completar:
A pipeline baixa and armazena um modelo pré-treinado padrão e tokenizer para análise sentimental. Agora você pode usar classifier
no texto alvo:
Para mais de uma sentença, passe uma lista para a pipeline()
, a qual retornará uma lista de dicionários:
A pipeline()
também pode iterar sobre um Dataset inteiro. Comece instalando a biblioteca de 🤗 Datasets:
Crie uma pipeline()
com a tarefa que deseja resolver e o modelo que deseja usar.
A seguir, carregue uma base de dados (confira a 🤗 Iniciação em Datasets para mais detalhes) que você gostaria de iterar sobre. Por exemplo, vamos carregar o dataset MInDS-14:
Precisamos garantir que a taxa de amostragem do conjunto de dados corresponda à taxa de amostragem em que o facebook/wav2vec2-base-960h foi treinado.
Os arquivos de áudio são carregados e re-amostrados automaticamente ao chamar a coluna "audio"
. Vamos extrair as arrays de formas de onda originais das primeiras 4 amostras e passá-las como uma lista para o pipeline:
Para um conjunto de dados maior onde as entradas são maiores (como em fala ou visão), será necessário passar um gerador em vez de uma lista que carregue todas as entradas na memória. Consulte a documentação do pipeline para mais informações.
Use outro modelo e tokenizer na pipeline
A pipeline()
pode acomodar qualquer modelo do Model Hub, facilitando sua adaptação para outros casos de uso. Por exemplo, se você quiser um modelo capaz de lidar com texto em francês, use as tags no Model Hub para filtrar um modelo apropriado. O principal resultado filtrado retorna um modelo BERT bilíngue ajustado para análise de sentimentos. Ótimo, vamos usar este modelo!
Use o AutoModelForSequenceClassification
e AutoTokenizer
para carregar o modelo pré-treinado e seu tokenizer associado (mais em AutoClass
abaixo):
Use o TFAutoModelForSequenceClassification
and AutoTokenizer
para carregar o modelo pré-treinado e o tokenizer associado (mais em TFAutoClass
abaixo):
Então você pode especificar o modelo e o tokenizador na pipeline()
e aplicar o classifier
no seu texto alvo:
Se você não conseguir achar um modelo para o seu caso de uso, precisará usar fine-tune em um modelo pré-treinado nos seus dados. Veja nosso tutorial de fine-tuning para descobrir como. Finalmente, depois que você tiver usado esse processo em seu modelo, considere compartilhá-lo conosco (veja o tutorial aqui) na plataforma Model Hub afim de democratizar NLP! 🤗
AutoClass
Por baixo dos panos, as classes AutoModelForSequenceClassification
e AutoTokenizer
trabalham juntas para fortificar o pipeline()
. Um AutoClass é um atalho que automaticamente recupera a arquitetura de um modelo pré-treinado a partir de seu nome ou caminho. Basta selecionar a AutoClass
apropriada para sua tarefa e seu tokenizer associado com AutoTokenizer
.
Vamos voltar ao nosso exemplo e ver como você pode usar a AutoClass
para replicar os resultados do pipeline()
.
AutoTokenizer
Um tokenizer é responsável por pré-processar o texto em um formato que seja compreensível para o modelo. Primeiro, o tokenizer dividirá o texto em palavras chamadas tokens. Existem várias regras que regem o processo de tokenização, incluindo como dividir uma palavra e em que nível (saiba mais sobre tokenização aqui). A coisa mais importante a lembrar, porém, é que você precisa instanciar o tokenizer com o mesmo nome do modelo para garantir que está usando as mesmas regras de tokenização com as quais um modelo foi pré-treinado.
Carregue um tokenizer com AutoTokenizer
:
Em seguida, o tokenizer converte os tokens em números para construir um tensor como entrada para o modelo. Isso é conhecido como o vocabulário do modelo.
Passe o texto para o tokenizer:
O tokenizer retornará um dicionário contendo:
input_ids: representações numéricas de seus tokens.
atttention_mask: indica quais tokens devem ser atendidos.
Assim como o pipeline()
, o tokenizer aceitará uma lista de entradas. Além disso, o tokenizer também pode preencher e truncar o texto para retornar um lote com comprimento uniforme:
Leia o tutorial de pré-processamento para obter mais detalhes sobre tokenização.
AutoModel
🤗 Transformers fornecem uma maneira simples e unificada de carregar instâncias pré-treinadas. Isso significa que você pode carregar um AutoModel
como carregaria um AutoTokenizer
. A única diferença é selecionar o AutoModel
correto para a tarefa. Como você está fazendo classificação de texto ou sequência, carregue AutoModelForSequenceClassification
:
Veja o sumário de tarefas para qual classe de AutoModel
usar para cada tarefa.
Agora você pode passar seu grupo de entradas pré-processadas diretamente para o modelo. Você apenas tem que descompactar o dicionário usando **
:
O modelo gera as ativações finais no atributo logits
. Aplique a função softmax aos logits
para recuperar as probabilidades:
🤗 Transformers fornecem uma maneira simples e unificada de carregar instâncias pré-treinadas. Isso significa que você pode carregar um TFAutoModel
como carregaria um AutoTokenizer
. A única diferença é selecionar o TFAutoModel
correto para a tarefa. Como você está fazendo classificação de texto ou sequência, carregue TFAutoModelForSequenceClassification
:
Veja o sumário de tarefas para qual classe de AutoModel
usar para cada tarefa.
Agora você pode passar seu grupo de entradas pré-processadas diretamente para o modelo através da passagem de chaves de dicionários ao tensor.
O modelo gera as ativações finais no atributo logits
. Aplique a função softmax aos logits
para recuperar as probabilidades:
Todos os modelos de 🤗 Transformers (PyTorch ou TensorFlow) geram tensores antes da função de ativação final (como softmax) pois essa função algumas vezes é fundida com a perda.
Os modelos são um standard torch.nn.Module
ou um [tf.keras.Model
](https: //www.tensorflow.org/api_docs/python/tf/keras/Model) para que você possa usá-los em seu loop de treinamento habitual. No entanto, para facilitar as coisas, 🤗 Transformers fornece uma classe Trainer
para PyTorch que adiciona funcionalidade para treinamento distribuído, precisão mista e muito mais. Para o TensorFlow, você pode usar o método fit
de Keras. Consulte o tutorial de treinamento para obter mais detalhes.
As saídas do modelo 🤗 Transformers são classes de dados especiais para que seus atributos sejam preenchidos automaticamente em um IDE. As saídas do modelo também se comportam como uma tupla ou um dicionário (por exemplo, você pode indexar com um inteiro, uma parte ou uma string), caso em que os atributos None
são ignorados.
Salvar um modelo
Uma vez que seu modelo estiver afinado, você pode salvá-lo com seu Tokenizer usando PreTrainedModel.save_pretrained()
:
Quando você estiver pronto para usá-lo novamente, recarregue com PreTrainedModel.from_pretrained()
:
Uma vez que seu modelo estiver afinado, você pode salvá-lo com seu Tokenizer usando TFPreTrainedModel.save_pretrained()
:
Quando você estiver pronto para usá-lo novamente, recarregue com TFPreTrainedModel.from_pretrained()
Um recurso particularmente interessante dos 🤗 Transformers é a capacidade de salvar um modelo e recarregá-lo como um modelo PyTorch ou TensorFlow. Use from_pt
ou from_tf
para converter o modelo de um framework para outro: