初始化项目,由ModelHub XC社区提供模型
Model: indonesian-nlp/wav2vec2-indonesian-javanese-sundanese Source: Original Platform
This commit is contained in:
27
.gitattributes
vendored
Normal file
27
.gitattributes
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.arrow filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bin filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bin.* filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ftz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.h5 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.joblib filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lfs.* filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.model filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.msgpack filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.onnx filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ot filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.parquet filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pb filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pth filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
saved_model/**/* filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tar.* filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tflite filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zstandard filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
||||||
182
README.md
Normal file
182
README.md
Normal file
@@ -0,0 +1,182 @@
|
|||||||
|
---
|
||||||
|
language:
|
||||||
|
- id
|
||||||
|
- jv
|
||||||
|
- sun
|
||||||
|
datasets:
|
||||||
|
- mozilla-foundation/common_voice_7_0
|
||||||
|
- openslr
|
||||||
|
- magic_data
|
||||||
|
- titml
|
||||||
|
metrics:
|
||||||
|
- wer
|
||||||
|
tags:
|
||||||
|
- audio
|
||||||
|
- automatic-speech-recognition
|
||||||
|
- hf-asr-leaderboard
|
||||||
|
- id
|
||||||
|
- jv
|
||||||
|
- robust-speech-event
|
||||||
|
- speech
|
||||||
|
- su
|
||||||
|
license: apache-2.0
|
||||||
|
model-index:
|
||||||
|
- name: Wav2Vec2 Indonesian Javanese and Sundanese by Indonesian NLP
|
||||||
|
results:
|
||||||
|
- task:
|
||||||
|
name: Automatic Speech Recognition
|
||||||
|
type: automatic-speech-recognition
|
||||||
|
dataset:
|
||||||
|
name: Common Voice 6.1
|
||||||
|
type: common_voice
|
||||||
|
args: id
|
||||||
|
metrics:
|
||||||
|
- name: Test WER
|
||||||
|
type: wer
|
||||||
|
value: 4.056
|
||||||
|
- name: Test CER
|
||||||
|
type: cer
|
||||||
|
value: 1.472
|
||||||
|
- task:
|
||||||
|
name: Automatic Speech Recognition
|
||||||
|
type: automatic-speech-recognition
|
||||||
|
dataset:
|
||||||
|
name: Common Voice 7
|
||||||
|
type: mozilla-foundation/common_voice_7_0
|
||||||
|
args: id
|
||||||
|
metrics:
|
||||||
|
- name: Test WER
|
||||||
|
type: wer
|
||||||
|
value: 4.492
|
||||||
|
- name: Test CER
|
||||||
|
type: cer
|
||||||
|
value: 1.577
|
||||||
|
- task:
|
||||||
|
name: Automatic Speech Recognition
|
||||||
|
type: automatic-speech-recognition
|
||||||
|
dataset:
|
||||||
|
name: Robust Speech Event - Dev Data
|
||||||
|
type: speech-recognition-community-v2/dev_data
|
||||||
|
args: id
|
||||||
|
metrics:
|
||||||
|
- name: Test WER
|
||||||
|
type: wer
|
||||||
|
value: 48.94
|
||||||
|
- task:
|
||||||
|
name: Automatic Speech Recognition
|
||||||
|
type: automatic-speech-recognition
|
||||||
|
dataset:
|
||||||
|
name: Robust Speech Event - Test Data
|
||||||
|
type: speech-recognition-community-v2/eval_data
|
||||||
|
args: id
|
||||||
|
metrics:
|
||||||
|
- name: Test WER
|
||||||
|
type: wer
|
||||||
|
value: 68.95
|
||||||
|
---
|
||||||
|
|
||||||
|
# Multilingual Speech Recognition for Indonesian Languages
|
||||||
|
|
||||||
|
This is the model built for the project
|
||||||
|
[Multilingual Speech Recognition for Indonesian Languages](https://github.com/indonesian-nlp/multilingual-asr).
|
||||||
|
It is a fine-tuned [facebook/wav2vec2-large-xlsr-53](https://huggingface.co/facebook/wav2vec2-large-xlsr-53)
|
||||||
|
model on the [Indonesian Common Voice dataset](https://huggingface.co/datasets/common_voice),
|
||||||
|
[High-quality TTS data for Javanese - SLR41](https://huggingface.co/datasets/openslr), and
|
||||||
|
[High-quality TTS data for Sundanese - SLR44](https://huggingface.co/datasets/openslr) datasets.
|
||||||
|
|
||||||
|
We also provide a [live demo](https://huggingface.co/spaces/indonesian-nlp/multilingual-asr) to test the model.
|
||||||
|
|
||||||
|
When using this model, make sure that your speech input is sampled at 16kHz.
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
The model can be used directly (without a language model) as follows:
|
||||||
|
```python
|
||||||
|
import torch
|
||||||
|
import torchaudio
|
||||||
|
from datasets import load_dataset
|
||||||
|
from transformers import Wav2Vec2ForCTC, Wav2Vec2Processor
|
||||||
|
|
||||||
|
test_dataset = load_dataset("common_voice", "id", split="test[:2%]")
|
||||||
|
|
||||||
|
processor = Wav2Vec2Processor.from_pretrained("indonesian-nlp/wav2vec2-indonesian-javanese-sundanese")
|
||||||
|
model = Wav2Vec2ForCTC.from_pretrained("indonesian-nlp/wav2vec2-indonesian-javanese-sundanese")
|
||||||
|
|
||||||
|
resampler = torchaudio.transforms.Resample(48_000, 16_000)
|
||||||
|
|
||||||
|
# Preprocessing the datasets.
|
||||||
|
# We need to read the aduio files as arrays
|
||||||
|
def speech_file_to_array_fn(batch):
|
||||||
|
speech_array, sampling_rate = torchaudio.load(batch["path"])
|
||||||
|
batch["speech"] = resampler(speech_array).squeeze().numpy()
|
||||||
|
return batch
|
||||||
|
|
||||||
|
test_dataset = test_dataset.map(speech_file_to_array_fn)
|
||||||
|
inputs = processor(test_dataset[:2]["speech"], sampling_rate=16_000, return_tensors="pt", padding=True)
|
||||||
|
|
||||||
|
with torch.no_grad():
|
||||||
|
logits = model(inputs.input_values, attention_mask=inputs.attention_mask).logits
|
||||||
|
|
||||||
|
predicted_ids = torch.argmax(logits, dim=-1)
|
||||||
|
|
||||||
|
print("Prediction:", processor.batch_decode(predicted_ids))
|
||||||
|
print("Reference:", test_dataset[:2]["sentence"])
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
## Evaluation
|
||||||
|
|
||||||
|
The model can be evaluated as follows on the Indonesian test data of Common Voice.
|
||||||
|
|
||||||
|
```python
|
||||||
|
import torch
|
||||||
|
import torchaudio
|
||||||
|
from datasets import load_dataset, load_metric
|
||||||
|
from transformers import Wav2Vec2ForCTC, Wav2Vec2Processor
|
||||||
|
import re
|
||||||
|
|
||||||
|
test_dataset = load_dataset("common_voice", "id", split="test")
|
||||||
|
wer = load_metric("wer")
|
||||||
|
|
||||||
|
processor = Wav2Vec2Processor.from_pretrained("indonesian-nlp/wav2vec2-indonesian-javanese-sundanese")
|
||||||
|
model = Wav2Vec2ForCTC.from_pretrained("indonesian-nlp/wav2vec2-indonesian-javanese-sundanese")
|
||||||
|
model.to("cuda")
|
||||||
|
|
||||||
|
chars_to_ignore_regex = '[\,\?\.\!\-\;\:\"\“\%\‘\'\”\<5C>]'
|
||||||
|
|
||||||
|
resampler = torchaudio.transforms.Resample(48_000, 16_000)
|
||||||
|
|
||||||
|
# Preprocessing the datasets.
|
||||||
|
# We need to read the audio files as arrays
|
||||||
|
def speech_file_to_array_fn(batch):
|
||||||
|
batch["sentence"] = re.sub(chars_to_ignore_regex, '', batch["sentence"]).lower()
|
||||||
|
speech_array, sampling_rate = torchaudio.load(batch["path"])
|
||||||
|
batch["speech"] = resampler(speech_array).squeeze().numpy()
|
||||||
|
return batch
|
||||||
|
|
||||||
|
test_dataset = test_dataset.map(speech_file_to_array_fn)
|
||||||
|
|
||||||
|
# Preprocessing the datasets.
|
||||||
|
# We need to read the audio files as arrays
|
||||||
|
def evaluate(batch):
|
||||||
|
inputs = processor(batch["speech"], sampling_rate=16_000, return_tensors="pt", padding=True)
|
||||||
|
|
||||||
|
with torch.no_grad():
|
||||||
|
logits = model(inputs.input_values.to("cuda"), attention_mask=inputs.attention_mask.to("cuda")).logits
|
||||||
|
|
||||||
|
pred_ids = torch.argmax(logits, dim=-1)
|
||||||
|
batch["pred_strings"] = processor.batch_decode(pred_ids)
|
||||||
|
return batch
|
||||||
|
|
||||||
|
result = test_dataset.map(evaluate, batched=True, batch_size=8)
|
||||||
|
|
||||||
|
print("WER: {:2f}".format(100 * wer.compute(predictions=result["pred_strings"], references=result["sentence"])))
|
||||||
|
```
|
||||||
|
|
||||||
|
**Test Result**: 11.57 %
|
||||||
|
|
||||||
|
## Training
|
||||||
|
|
||||||
|
The Common Voice `train`, `validation`, and ... datasets were used for training as well as ... and ... # TODO
|
||||||
|
|
||||||
|
The script used for training can be found [here](https://github.com/cahya-wirawan/indonesian-speech-recognition)
|
||||||
|
(will be available soon)
|
||||||
1
added_tokens.json
Normal file
1
added_tokens.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
alphabet.json
Normal file
1
alphabet.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"labels": [" ", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "\u00e9", "\u2047", ""], "is_bpe": false}
|
||||||
2
common_voice_id_test_eval_results.txt
Normal file
2
common_voice_id_test_eval_results.txt
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
WER: 0.04055565914600037
|
||||||
|
CER: 0.014725628860442217
|
||||||
87
config.json
Normal file
87
config.json
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
{
|
||||||
|
"_name_or_path": "facebook/wav2vec2-large-xlsr-53",
|
||||||
|
"activation_dropout": 0.055,
|
||||||
|
"apply_spec_augment": true,
|
||||||
|
"architectures": [
|
||||||
|
"Wav2Vec2ForCTC"
|
||||||
|
],
|
||||||
|
"attention_dropout": 0.094,
|
||||||
|
"bos_token_id": 1,
|
||||||
|
"classifier_proj_size": 256,
|
||||||
|
"codevector_dim": 768,
|
||||||
|
"contrastive_logits_temperature": 0.1,
|
||||||
|
"conv_bias": true,
|
||||||
|
"conv_dim": [
|
||||||
|
512,
|
||||||
|
512,
|
||||||
|
512,
|
||||||
|
512,
|
||||||
|
512,
|
||||||
|
512,
|
||||||
|
512
|
||||||
|
],
|
||||||
|
"conv_kernel": [
|
||||||
|
10,
|
||||||
|
3,
|
||||||
|
3,
|
||||||
|
3,
|
||||||
|
3,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
"conv_stride": [
|
||||||
|
5,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2,
|
||||||
|
2
|
||||||
|
],
|
||||||
|
"ctc_loss_reduction": "mean",
|
||||||
|
"ctc_zero_infinity": true,
|
||||||
|
"diversity_loss_weight": 0.1,
|
||||||
|
"do_stable_layer_norm": true,
|
||||||
|
"eos_token_id": 2,
|
||||||
|
"feat_extract_activation": "gelu",
|
||||||
|
"feat_extract_dropout": 0.0,
|
||||||
|
"feat_extract_norm": "layer",
|
||||||
|
"feat_proj_dropout": 0.04,
|
||||||
|
"feat_quantizer_dropout": 0.0,
|
||||||
|
"final_dropout": 0.0,
|
||||||
|
"gradient_checkpointing": false,
|
||||||
|
"hidden_act": "gelu",
|
||||||
|
"hidden_dropout": 0.047,
|
||||||
|
"hidden_size": 1024,
|
||||||
|
"initializer_range": 0.02,
|
||||||
|
"intermediate_size": 4096,
|
||||||
|
"layer_norm_eps": 1e-05,
|
||||||
|
"layerdrop": 0.041,
|
||||||
|
"mask_channel_length": 10,
|
||||||
|
"mask_channel_min_space": 1,
|
||||||
|
"mask_channel_other": 0.0,
|
||||||
|
"mask_channel_prob": 0.0,
|
||||||
|
"mask_channel_selection": "static",
|
||||||
|
"mask_feature_length": 10,
|
||||||
|
"mask_feature_prob": 0.0,
|
||||||
|
"mask_time_length": 10,
|
||||||
|
"mask_time_min_space": 1,
|
||||||
|
"mask_time_other": 0.0,
|
||||||
|
"mask_time_prob": 0.4,
|
||||||
|
"mask_time_selection": "static",
|
||||||
|
"model_type": "wav2vec2",
|
||||||
|
"num_attention_heads": 16,
|
||||||
|
"num_codevector_groups": 2,
|
||||||
|
"num_codevectors_per_group": 320,
|
||||||
|
"num_conv_pos_embedding_groups": 16,
|
||||||
|
"num_conv_pos_embeddings": 128,
|
||||||
|
"num_feat_extract_layers": 7,
|
||||||
|
"num_hidden_layers": 24,
|
||||||
|
"num_negatives": 100,
|
||||||
|
"pad_token_id": 29,
|
||||||
|
"proj_codevector_dim": 768,
|
||||||
|
"torch_dtype": "float32",
|
||||||
|
"transformers_version": "4.11.2",
|
||||||
|
"use_weighted_layer_sum": false,
|
||||||
|
"vocab_size": 30
|
||||||
|
}
|
||||||
140
eval.py
Executable file
140
eval.py
Executable file
@@ -0,0 +1,140 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
import argparse
|
||||||
|
import re
|
||||||
|
from typing import Dict
|
||||||
|
|
||||||
|
import torch
|
||||||
|
from datasets import Audio, Dataset, load_dataset, load_metric
|
||||||
|
|
||||||
|
from transformers import AutoFeatureExtractor, pipeline
|
||||||
|
|
||||||
|
|
||||||
|
def log_results(result: Dataset, args: Dict[str, str]):
|
||||||
|
"""DO NOT CHANGE. This function computes and logs the result metrics."""
|
||||||
|
|
||||||
|
log_outputs = args.log_outputs
|
||||||
|
dataset_id = "_".join(args.dataset.split("/") + [args.config, args.split])
|
||||||
|
|
||||||
|
# load metric
|
||||||
|
wer = load_metric("wer")
|
||||||
|
cer = load_metric("cer")
|
||||||
|
|
||||||
|
# compute metrics
|
||||||
|
wer_result = wer.compute(references=result["target"], predictions=result["prediction"])
|
||||||
|
cer_result = cer.compute(references=result["target"], predictions=result["prediction"])
|
||||||
|
|
||||||
|
# print & log results
|
||||||
|
result_str = f"WER: {wer_result}\n" f"CER: {cer_result}"
|
||||||
|
print(result_str)
|
||||||
|
|
||||||
|
with open(f"{dataset_id}_eval_results.txt", "w") as f:
|
||||||
|
f.write(result_str)
|
||||||
|
|
||||||
|
# log all results in text file. Possibly interesting for analysis
|
||||||
|
if log_outputs is not None:
|
||||||
|
pred_file = f"log_{dataset_id}_predictions.txt"
|
||||||
|
target_file = f"log_{dataset_id}_targets.txt"
|
||||||
|
|
||||||
|
with open(pred_file, "w") as p, open(target_file, "w") as t:
|
||||||
|
|
||||||
|
# mapping function to write output
|
||||||
|
def write_to_file(batch, i):
|
||||||
|
p.write(f"{i}" + "\n")
|
||||||
|
p.write(batch["prediction"] + "\n")
|
||||||
|
t.write(f"{i}" + "\n")
|
||||||
|
t.write(batch["target"] + "\n")
|
||||||
|
|
||||||
|
result.map(write_to_file, with_indices=True)
|
||||||
|
|
||||||
|
|
||||||
|
def normalize_text(text: str) -> str:
|
||||||
|
"""DO ADAPT FOR YOUR USE CASE. this function normalizes the target text."""
|
||||||
|
|
||||||
|
chars_to_ignore_regex = '[,?.!-;:""%\'"<EFBFBD>\'‘’_,!łńō–—\\\\\\“”\\[\\]]'
|
||||||
|
|
||||||
|
text = re.sub(chars_to_ignore_regex, "", text.lower())
|
||||||
|
text = re.sub(r'[‘’´`]', r"'", text)
|
||||||
|
text = re.sub(r'è', r"é", text)
|
||||||
|
text = re.sub(r"(-|' | '| +)", " ", text)
|
||||||
|
|
||||||
|
# In addition, we can normalize the target text, e.g. removing new lines characters etc...
|
||||||
|
# note that order is important here!
|
||||||
|
token_sequences_to_ignore = ["\n\n", "\n", " ", " "]
|
||||||
|
|
||||||
|
for t in token_sequences_to_ignore:
|
||||||
|
text = " ".join(text.split(t))
|
||||||
|
|
||||||
|
return text
|
||||||
|
|
||||||
|
|
||||||
|
def main(args):
|
||||||
|
# load dataset
|
||||||
|
dataset = load_dataset(args.dataset, args.config, split=args.split, use_auth_token=True)
|
||||||
|
|
||||||
|
# for testing: only process the first two examples as a test
|
||||||
|
# dataset = dataset.select(range(10))
|
||||||
|
|
||||||
|
# load processor
|
||||||
|
feature_extractor = AutoFeatureExtractor.from_pretrained(args.model_id)
|
||||||
|
sampling_rate = feature_extractor.sampling_rate
|
||||||
|
|
||||||
|
# resample audio
|
||||||
|
dataset = dataset.cast_column("audio", Audio(sampling_rate=sampling_rate))
|
||||||
|
|
||||||
|
# load eval pipeline
|
||||||
|
if args.device is None:
|
||||||
|
args.device = 0 if torch.cuda.is_available() else -1
|
||||||
|
asr = pipeline("automatic-speech-recognition", model=args.model_id, device=args.device)
|
||||||
|
|
||||||
|
# map function to decode audio
|
||||||
|
def map_to_pred(batch):
|
||||||
|
prediction = asr(
|
||||||
|
batch["audio"]["array"], chunk_length_s=args.chunk_length_s, stride_length_s=args.stride_length_s
|
||||||
|
)
|
||||||
|
|
||||||
|
batch["prediction"] = prediction["text"]
|
||||||
|
batch["target"] = normalize_text(batch["sentence"])
|
||||||
|
return batch
|
||||||
|
|
||||||
|
# run inference on all examples
|
||||||
|
result = dataset.map(map_to_pred, remove_columns=dataset.column_names)
|
||||||
|
|
||||||
|
# compute and log_results
|
||||||
|
# do not change function below
|
||||||
|
log_results(result, args)
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
parser = argparse.ArgumentParser()
|
||||||
|
|
||||||
|
parser.add_argument(
|
||||||
|
"--model_id", type=str, required=True, help="Model identifier. Should be loadable with 🤗 Transformers"
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--dataset",
|
||||||
|
type=str,
|
||||||
|
required=True,
|
||||||
|
help="Dataset name to evaluate the `model_id`. Should be loadable with 🤗 Datasets",
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--config", type=str, required=True, help="Config of the dataset. *E.g.* `'en'` for Common Voice"
|
||||||
|
)
|
||||||
|
parser.add_argument("--split", type=str, required=True, help="Split of the dataset. *E.g.* `'test'`")
|
||||||
|
parser.add_argument(
|
||||||
|
"--chunk_length_s", type=float, default=None, help="Chunk length in seconds. Defaults to 5 seconds."
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--stride_length_s", type=float, default=None, help="Stride of the audio chunks. Defaults to 1 second."
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--log_outputs", action="store_true", help="If defined, write outputs to log file for analysis."
|
||||||
|
)
|
||||||
|
parser.add_argument(
|
||||||
|
"--device",
|
||||||
|
type=int,
|
||||||
|
default=None,
|
||||||
|
help="The device to run the pipeline on. -1 for CPU (default), 0 for the first GPU and so on.",
|
||||||
|
)
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
main(args)
|
||||||
3
language_model/4gram.bin
Normal file
3
language_model/4gram.bin
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:c2b756cefd29a19b4ee62b258a75bed0261585e9512491490faa05ba57d91ae5
|
||||||
|
size 2233200344
|
||||||
1
language_model/attrs.json
Normal file
1
language_model/attrs.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"alpha": 0.5, "beta": 1.5, "unk_score_offset": -10.0, "score_boundary": true}
|
||||||
500002
language_model/unigrams.txt
Normal file
500002
language_model/unigrams.txt
Normal file
File diff suppressed because it is too large
Load Diff
3688
log_common_voice_id_test_predictions.txt
Normal file
3688
log_common_voice_id_test_predictions.txt
Normal file
File diff suppressed because it is too large
Load Diff
3688
log_common_voice_id_test_targets.txt
Normal file
3688
log_common_voice_id_test_targets.txt
Normal file
File diff suppressed because it is too large
Load Diff
6076
log_mozilla-foundation_common_voice_7_0_id_test_predictions.txt
Normal file
6076
log_mozilla-foundation_common_voice_7_0_id_test_predictions.txt
Normal file
File diff suppressed because it is too large
Load Diff
6076
log_mozilla-foundation_common_voice_7_0_id_test_targets.txt
Normal file
6076
log_mozilla-foundation_common_voice_7_0_id_test_targets.txt
Normal file
File diff suppressed because it is too large
Load Diff
7216
log_mozilla-foundation_common_voice_8_0_id_test_predictions.txt
Normal file
7216
log_mozilla-foundation_common_voice_8_0_id_test_predictions.txt
Normal file
File diff suppressed because it is too large
Load Diff
7216
log_mozilla-foundation_common_voice_8_0_id_test_targets.txt
Normal file
7216
log_mozilla-foundation_common_voice_8_0_id_test_targets.txt
Normal file
File diff suppressed because it is too large
Load Diff
@@ -0,0 +1,2 @@
|
|||||||
|
WER: 0.04492122024807241
|
||||||
|
CER: 0.015773881015293457
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
WER: 0.03829846712947864
|
||||||
|
CER: 0.013491587206330155
|
||||||
10
preprocessor_config.json
Normal file
10
preprocessor_config.json
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
{
|
||||||
|
"do_normalize": true,
|
||||||
|
"feature_extractor_type": "Wav2Vec2FeatureExtractor",
|
||||||
|
"feature_size": 1,
|
||||||
|
"padding_side": "right",
|
||||||
|
"padding_value": 0.0,
|
||||||
|
"processor_class": "Wav2Vec2ProcessorWithLM",
|
||||||
|
"return_attention_mask": true,
|
||||||
|
"sampling_rate": 16000
|
||||||
|
}
|
||||||
3
pytorch_model.bin
Normal file
3
pytorch_model.bin
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:ea90feff05f74ce30926777673cd8fb4ac9a26604c67c107f253c1aab4c14e18
|
||||||
|
size 1262046641
|
||||||
1
special_tokens_map.json
Normal file
1
special_tokens_map.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"bos_token": null, "eos_token": null, "unk_token": "[UNK]", "pad_token": "[PAD]"}
|
||||||
1
tokenizer_config.json
Normal file
1
tokenizer_config.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"unk_token": "[UNK]", "bos_token": null, "eos_token": null, "pad_token": "[PAD]", "do_lower_case": false, "word_delimiter_token": "|", "special_tokens_map_file": "/home/cahya/.cache/huggingface/transformers/2641b6017f5e33cf3ddf20eee64ac79230cb6776eaded034e59321c40d3c6e01.a21d51735cf8667bcd610f057e88548d5d6a381401f6b4501a8bc6c1a9dc8498", "tokenizer_file": null, "name_or_path": "indonesian-nlp/wav2vec2-indonesian-javanese-sundanese", "tokenizer_class": "Wav2Vec2CTCTokenizer", "processor_class": "Wav2Vec2ProcessorWithLM"}
|
||||||
1
vocab.json
Normal file
1
vocab.json
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"a": 1, "b": 2, "c": 3, "d": 4, "e": 5, "f": 6, "g": 7, "h": 8, "i": 9, "j": 10, "k": 11, "l": 12, "m": 13, "n": 14, "o": 15, "p": 16, "q": 17, "r": 18, "s": 19, "t": 20, "u": 21, "v": 22, "w": 23, "x": 24, "y": 25, "z": 26, "é": 27, "|": 0, "[UNK]": 28, "[PAD]": 29}
|
||||||
Reference in New Issue
Block a user