Skip to content

Commit

Permalink
[PT] add quiz chapter 5 (huggingface#243)
Browse files Browse the repository at this point in the history
  • Loading branch information
johnnv1 authored Jun 20, 2022
1 parent 16efa44 commit 456c608
Show file tree
Hide file tree
Showing 2 changed files with 226 additions and 0 deletions.
3 changes: 3 additions & 0 deletions chapters/pt/_toctree.yml
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,9 @@
title: Busca semântica com o FAISS
- local: chapter5/7
title: Confira o 🤗 Datasets!
- local: chapter5/8
title: Questionário de fim de capítulo
quiz: 5

- title: 7. Principais tarefas NLP
sections:
Expand Down
223 changes: 223 additions & 0 deletions chapters/pt/chapter5/8.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,223 @@
<!-- DISABLE-FRONTMATTER-SECTIONS -->

# Questionário de fim de capítulo
Este capítulo cobriu muita coisa! Não se preocupe se você não entendeu todos os detalhes; os próximos capítulos o ajudarão a entender como as coisas funcionam.

Antes de prosseguir, vamos testar o que você aprendeu neste capítulo.

### 1. A função `load_dataset()` em 🤗 Datasets permite carregar um dataset de qual dos seguintes locais?

<Question
choices={[
{
text: "Localmente, por exemplo no seu laptop",
explain: "Correto! Você pode passar os caminhos dos arquivos locais para o argumento <code>data_files</code> de <code>load_dataset()</code> para carregar conjuntos de dados localmente.",
correct: true
},
{
text: "Do Hugging Face Hub",
explain: "Correto! Você pode carregar conjuntos de dados no Hub fornecendo o ID do conjunto de dados, por exemplo, <code>load_dataset('emotion')</code>.",
correct: true
},
{
text: "De um servidor remoto",
explain: "Correto! Você pode passar URLs para o argumento <code>data_files</code> de <code>load_dataset()</code> para carregar arquivos remotos.",
correct: true
},
]}
/>
### 2. Suponha que você carregue uma das tarefas GLUE da seguinte forma:

```py
from datasets import load_dataset

dataset = load_dataset("glue", "mrpc", split="train")
```

Qual dos seguintes comandos produzirá uma amostra aleatória de 50 elementos do `conjunto de dados`?

<Question
choices={[
{
text: "<code>dataset.sample(50)</code>",
explain: "Isso está incorreto -- não há método <code>Dataset.sample()</code>."
},
{
text: "<code>dataset.shuffle().select(range(50))</code>",
explain: "Correto! Como você viu neste capítulo, você primeiro embaralha o conjunto de dados e depois seleciona as amostras dele.",
correct: true
},
{
text: "<code>dataset.select(range(50)).shuffle()</code>",
explain: "Isso está incorreto - embora o código seja executado, ele embaralha apenas os primeiros 50 elementos do conjunto de dados."
}
]}
/>

### 3. Suponha que você tenha um conjunto de dados sobre animais domésticos chamado `pets_dataset`, que tem uma coluna `name` que denota o nome de cada animal. Qual das seguintes abordagens permitiria filtrar o conjunto de dados para todos os animais de estimação cujos nomes começam com a letra "L"?

<Question
choices={[
{
text: "<code>pets_dataset.filter(lambda x : x['name'].startswith('L'))</code>",
explain: "Correto! Usar uma função lambda do Python para esses filtros rápidos é uma ótima ideia. Você consegue pensar em outra solução?",
correct: true
},
{
text: "<code>pets_dataset.filter(lambda x['name'].startswith('L'))</code>",
explain: "Isso está incorreto -- uma função lambda assume a forma geral <code>lambda *arguments* : *expression*</code>, então você precisa fornecer argumentos neste caso."
},
{
text: "Criar uma função assim <code>def filter_names(x): return x['name'].startswith('L')</code> e executa-la <code>pets_dataset.filter(filter_names)</code>.",
explain: "Correto! Assim como com <code>Dataset.map()</code>, você pode passar funções explícitas para <code>Dataset.filter()</code>. Isso é útil quando você tem alguma lógica complexa que não é adequado para uma função lambda curta. Qual das outras soluções funcionaria?",
correct: true
}
]}
/>

### 4. O que é mapeamento de memória?

<Question
choices={[
{
text: "Um mapeamento entre CPU e GPU RAM",
explain: "Não é isso - tente novamente!",
},
{
text: "Um mapeamento entre RAM e armazenamento do sistema de arquivos",
explain: "Correto! Os 🤗 Datasets tratam cada conjunto de dados como um arquivo mapeado na memória. Isso permite que a biblioteca acesse e opere em elementos do conjunto de dados sem precisar carregá-lo totalmente na memória.",
correct: true
},
{
text: "Um mapeamento entre dois arquivos no cache 🤗 Datasets",
explain: "Isto não está correto - tente novamente!"
}
]}
/>

### 5. Quais dos seguintes são os principais benefícios do mapeamento de memória?

<Question
choices={[
{
text: "Acessar arquivos mapeados na memória é mais rápido do que ler ou gravar no disco.",
explain: "Correto! Isso permite que 🤗 Datasets sejam extremamente rápidos. Mas esse não é o único benefício.",
correct: true
},
{
text: "As aplicações podem acessar segmentos de dados em um arquivo extremamente grande sem precisar ler o arquivo inteiro na RAM primeiro.",
explain: "Correto! Isso permite que 🤗 Datasets carregue conjuntos de dados de vários gigabytes em seu laptop sem explodir sua CPU. Que outra vantagem o mapeamento de memória oferece?",
correct: true
},
{
text: "Consome menos energia, então sua bateria dura mais.",
explain: "Isto não está correto - tente novamente!"
}
]}
/>

### 6. Por que o código a seguir falha?

```py
from datasets import load_dataset

dataset = load_dataset("allocine", streaming=True, split="train")
dataset[0]
```

<Question
choices={[
{
text: "Ele tenta fazer stream de um conjunto de dados grande demais para caber na RAM.",
explain: "Isso não está correto - conjuntos de dados de streaming são descompactados em tempo real e você pode processar conjuntos de dados de terabytes com muito pouca RAM!",
},
{
text: "Ele tenta acessar um <code>IterableDataset</code>.",
explain: "Correto! Um <code>IterableDataset</code> é um gerador, não um contêiner, então você deve acessar seus elementos usando <code>next(iter(dataset))</code>.",
correct: true
},
{
text: "O conjunto de dados <code>allocine</code> não tem uma divisão <code>train</code>.",
explain: "Isso está incorreto - confira o cartão de conjunto de dados [<code>allocine</code>](https://huggingface.co/datasets/allocine) no Hub para ver quais divisões ele contém."
}
]}
/>

### 7. Quais dos seguintes são os principais benefícios de criar um cartão de conjunto de dados?

<Question
choices={[
{
text: "Ele fornece informações sobre o uso pretendido e as tarefas suportadas do conjunto de dados para que outras pessoas na comunidade possam tomar uma decisão informada sobre o uso.",
explain: "Correto! Conjuntos de dados não documentados podem ser usados para treinar modelos que podem não refletir as intenções dos criadores do conjunto de dados ou podem produzir modelos cujo status legal é obscuro se forem treinados em dados que violam restrições de privacidade ou licenciamento. Este não é o único benefício, no entanto!",
correct : true
},
{
text: "Ajuda a chamar a atenção para os preconceitos que estão presentes em um corpus.",
explain: "Correto! Quase todos os conjuntos de dados têm algum tipo de viés, o que pode produzir consequências negativas em contrapartida. Estar ciente disso ajuda os criadores de modelos a entender como lidar com os vieses. Em que mais os cartões de conjunto de dados ajudam?",
correct : true
},
{
text: "Melhora as chances de que outras pessoas da comunidade usem meu conjunto de dados.",
explain: "Correto! Um cartão de conjunto de dados bem escrito tenderá a aumentar o uso de seu precioso conjunto de dados. Que outros benefícios ele oferece?",
correct: true
},
]}
/>

### 8. O que é pesquisa semântica?

<Question
choices={[
{
text: "Uma maneira de pesquisar correspondências exatas entre as palavras em uma consulta e os documentos em um corpus",
explain: "Isso está incorreto - esse tipo de pesquisa é chamado de *pesquisa léxica* e é o que você normalmente vê nos mecanismos de pesquisa tradicionais."
},
{
text: "Uma maneira de pesquisar documentos correspondentes entendendo o significado contextual de uma consulta",
explain: "Correto! A pesquisa semântica usa vetores incorporados para representar consultas e documentos e usa uma métrica de similaridade para medir a quantidade de sobreposição entre eles. De que outra forma você poderia descrevê-la?",
correct: true
},
{
text: "Uma maneira de melhorar a precisão da pesquisa",
explain: "Correto! Os mecanismos de pesquisa semântica podem capturar a intenção de uma consulta muito melhor do que a correspondência de palavras-chave e normalmente recuperam documentos com maior precisão. Mas essa não é a única resposta certa - o que mais a pesquisa semântica oferece?",
correct: true
}
]}
/>

### 9. Para pesquisa semântica assimétrica, você geralmente tem:

<Question
choices={[
{
text: "Uma consulta curta e um parágrafo mais longo que responde à consulta",
explain: "Correto!",
correct : true
},
{
text: "Consultas e parágrafos com aproximadamente o mesmo tamanho",
explain: "Este é realmente um exemplo de pesquisa semântica simétrica - tente novamente!"
},
{
text: "Uma consulta longa e um parágrafo mais curto que responde à consulta",
explain: "Isso está incorreto - tente novamente!"
}
]}
/>

### 10. Posso usar 🤗 Datasets para carregar dados para uso em outros domínios, como processamento de fala (audios)?

<Question
choices={[
{
text: "Não",
explain: "Isso está incorreto -- 🤗 Datasets atualmente suporta dados tabulares, áudio e de visão computacional. Confira o <a href='https://huggingface.co/datasets/mnist'>conjunto de dados MNIST</a> no Hub para um exemplo de visão computacional."
},
{
text: "Sim",
explain: "Correto! Confira os desenvolvimentos interessantes com fala e visão na biblioteca 🤗 Transformers para ver como 🤗 Datasets é usado nesses domínios.",
correct : true
},
]}
/>

0 comments on commit 456c608

Please sign in to comment.