|
--- |
|
license: cc-by-4.0 |
|
metrics: |
|
- cer |
|
pipeline_tag: automatic-speech-recognition |
|
datasets: |
|
- ivangtorre/second_americas_nlp_2022 |
|
tags: |
|
- audio |
|
- automatic-speech-recognition |
|
- speech |
|
- quechua |
|
- xlsr-fine-tuning |
|
model-index: |
|
- name: Wav2Vec2 XLSR 300M Quechua Model by M Romero and Ivan G Torre |
|
results: |
|
- task: |
|
name: Speech Recognition |
|
type: automatic-speech-recognition |
|
dataset: |
|
name: Americas NLP 2022 Quechua |
|
type: second_americas_nlp_2022 |
|
args: Quechua |
|
metrics: |
|
- name: Test CER |
|
type: cer |
|
value: 49.2 |
|
language: |
|
- qu |
|
--- |
|
|
|
This model was finetuned from a Wav2vec2.0 XLS-R model: 300M with the Quechua train parition of the Americas NLP 2022 dataset. This challenge took place during NeurIPSS 2022. |
|
|
|
|
|
|
|
## Example of usage |
|
|
|
The model can be used directly (without a language model) as follows: |
|
|
|
```python |
|
from transformers import Wav2Vec2Processor, Wav2Vec2ForCTC |
|
import torch |
|
import torchaudio |
|
|
|
# load model and processor |
|
processor = Wav2Vec2Processor.from_pretrained("ivangtorre/wav2vec2-xlsr-300m-quechua") |
|
model = Wav2Vec2ForCTC.from_pretrained("ivangtorre/wav2vec2-xlsr-300m-quechua") |
|
|
|
# Pat to wav file |
|
pathfile = "/path/to/wavfile" |
|
|
|
# Load and normalize the file |
|
wav, curr_sample_rate = sf.read(pathfile, dtype="float32") |
|
feats = torch.from_numpy(wav).float() |
|
with torch.no_grad(): |
|
feats = F.layer_norm(feats, feats.shape) |
|
feats = torch.unsqueeze(feats, 0) |
|
logits = model(feats).logits |
|
|
|
# take argmax and decode |
|
predicted_ids = torch.argmax(logits, dim=-1) |
|
transcription = processor.batch_decode(predicted_ids) |
|
print("HF prediction: ", transcription) |
|
``` |
|
|
|
|
|
This code snipnet shows how to Evaluate the wav2vec2-xlsr-300m-quechua in [Second Americas NLP 2022 Quechua dev set](https://huggingface.co/datasets/ivangtorre/second_americas_nlp_2022) |
|
|
|
```python |
|
from datasets import load_dataset |
|
from transformers import Wav2Vec2ForCTC, Wav2Vec2Processor |
|
import torch |
|
from jiwer import cer |
|
import torch.nn.functional as F |
|
from datasets import load_dataset |
|
import soundfile as sf |
|
|
|
americasnlp = load_dataset("ivangtorre/second_americas_nlp_2022", "quechua", split="dev") |
|
quechua = americasnlp.filter(lambda language: language['subset']=='quechua') |
|
|
|
model = Wav2Vec2ForCTC.from_pretrained("ivangtorre/wav2vec2-xlsr-300m-quechua") |
|
processor = Wav2Vec2Processor.from_pretrained("ivangtorre/wav2vec2-xlsr-300m-quechua") |
|
|
|
def map_to_pred(batch): |
|
wav = batch["audio"][0]["array"] |
|
feats = torch.from_numpy(wav).float() |
|
feats = F.layer_norm(feats, feats.shape) # Normalization performed during finetuning |
|
feats = torch.unsqueeze(feats, 0) |
|
logits = model(feats).logits |
|
predicted_ids = torch.argmax(logits, dim=-1) |
|
batch["transcription"] = processor.batch_decode(predicted_ids) |
|
return batch |
|
|
|
result = quechua.map(map_to_pred, batched=True, batch_size=1) |
|
|
|
print("CER:", cer(result["source_processed"], result["transcription"])) |
|
``` |
|
|
|
## Citation |
|
|
|
```bibtex |
|
@article{romero2024automatic, |
|
title={Automatic Speech Recognition Advancements for Indigenous Languages of the Americas}, |
|
author={Romero, Monica and G{\'o}mez-Canaval, Sandra and Torre, Ivan G}, |
|
journal={Applied Sciences}, |
|
volume={14}, |
|
number={15}, |
|
pages={6497}, |
|
year={2024}, |
|
publisher={MDPI} |
|
} |
|
``` |