|
--- |
|
language: |
|
- ms |
|
- en |
|
- zh |
|
- ta |
|
--- |
|
|
|
# Malaysian Finetune Whisper Small V2 |
|
|
|
Finetune Whisper Small on [Malaysian STT Whisper](https://huggingface.co/datasets/mesolitica/malaysian-stt-whisper) |
|
|
|
WanDB at https://wandb.ai/huseinzol05/malaysian-whisper-small-v2, **still on training** |
|
|
|
## Improvement |
|
|
|
1. Distilled from Whisper Large V3 on Malaysian and Science context. |
|
2. Better translation for Malay, Manglish, Mandarin, Tamil and Science context. |
|
3. Word level timestamp, introduced `<|transcribeprecise|>` token, **a new task!** |
|
|
|
## how to |
|
|
|
Load the model, |
|
|
|
```python |
|
import torch |
|
from transformers.models.whisper import tokenization_whisper |
|
|
|
tokenization_whisper.TASK_IDS = ["translate", "transcribe", "transcribeprecise"] |
|
|
|
from transformers import WhisperForConditionalGeneration, WhisperProcessor |
|
|
|
processor = WhisperProcessor.from_pretrained( |
|
'mesolitica/malaysian-whisper-small-v2' |
|
) |
|
tokenizer = processor.tokenizer |
|
model = WhisperForConditionalGeneration.from_pretrained( |
|
'mesolitica/malaysian-whisper-small-v2', torch_dtype = torch.bfloat16 |
|
).cuda().eval() |
|
``` |
|
|
|
### Transcribe |
|
|
|
```python |
|
from datasets import Audio |
|
import requests |
|
|
|
sr = 16000 |
|
audio = Audio(sampling_rate=sr) |
|
|
|
r = requests.get('https://github.com/mesolitica/malaya-speech/raw/master/speech/assembly.mp3') |
|
y = audio.decode_example(audio.encode_example(r.content))['array'] |
|
|
|
with torch.no_grad(): |
|
p = processor([y], return_tensors='pt') |
|
p['input_features'] = p['input_features'].to(torch.bfloat16) |
|
r = model.generate( |
|
p['input_features'].cuda(), |
|
output_scores=True, |
|
return_dict_in_generate=True, |
|
language='ms', |
|
return_timestamps=True, task = 'transcribe') |
|
|
|
tokenizer.convert_tokens_to_string(tokenizer.convert_ids_to_tokens(r.sequences[0])) |
|
``` |
|
|
|
``` |
|
<|startoftranscript|><|ms|><|transcribe|><|0.02|> Assembly on Aging di Vienna, Australia<|3.78|><|3.78|> yang telah diadakan pada tahun 1982<|6.50|><|6.50|> dan berasaskan unjuran tersebut<|8.82|><|8.82|> maka Jabatan Perangkaan Malaysia<|10.40|><|10.40|> menganggarkan menjelang tahun 2035<|13.72|><|13.72|> sejumlah 15% penduduk kita adalah daripada kalangan warga emas.<|18.72|><|19.28|> Untuk makluman Tuan Yang Pertua dan juga Alia Mbahumat,<|22.12|><|22.26|> pembangunan sistem pendaftaran warga emas<|24.02|><|24.02|> ataupun kita sebutkan event<|25.38|><|25.38|> adalah usaha kerajaan ke arah merealisasikan<|28.40|><|endoftext|> |
|
``` |
|
|
|
### Transcribe word level timestamp |
|
|
|
You must use `transcribeprecise` for the task, or `<|transcribeprecise|>` token, |
|
|
|
```python |
|
from datasets import Audio |
|
import requests |
|
|
|
sr = 16000 |
|
audio = Audio(sampling_rate=sr) |
|
|
|
r = requests.get('https://github.com/mesolitica/malaya-speech/raw/master/speech/assembly.mp3') |
|
y = audio.decode_example(audio.encode_example(r.content))['array'] |
|
|
|
with torch.no_grad(): |
|
p = processor([y], return_tensors='pt') |
|
p['input_features'] = p['input_features'].to(torch.bfloat16) |
|
r = model.generate( |
|
p['input_features'].cuda(), |
|
output_scores=True, |
|
return_dict_in_generate=True, |
|
language='ms', |
|
return_timestamps=True, task = 'transcribeprecise') |
|
|
|
tokenizer.convert_tokens_to_string(tokenizer.convert_ids_to_tokens(r.sequences[0])) |
|
``` |
|
|
|
``` |
|
<|startoftranscript|><|ms|><|transcribeprecise|><|0.02|> Assembly<|1.20|><|1.56|> on<|1.64|><|1.74|> Aging<|2.04|><|2.14|> di<|2.22|><|2.26|> Vienna<|2.50|><|2.72|> Australia<|3.12|><|4.26|> yang<|4.38|><|4.42|> telah<|4.58|><|4.62|> diadakan<|5.08|><|5.16|> pada<|5.30|><|5.36|> tahun<|5.60|><|5.62|> 1982<|6.92|><|7.12|> dan<|7.24|><|7.32|> berasaskan<|7.88|><|7.98|> unjuran<|8.36|><|8.42|> tersebut<|8.80|><|8.88|> maka<|9.06|><|9.12|> Jabatan<|9.48|><|9.56|> Perangkaan<|9.98|><|10.04|> Malaysia<|10.36|><|10.84|> menganggarkan<|11.56|><|11.98|> menjelang<|12.34|><|12.40|> tahun<|12.64|><|12.66|> 2035<|14.08|><|14.50|> sejumlah<|14.96|><|14.98|> 15%<|16.14|><|16.26|> penduduk<|16.62|><|16.68|> kita<|16.90|><|17.02|> adalah<|17.30|><|17.40|> daripada<|17.80|><|17.86|> kalangan<|18.16|><|18.22|> warga<|18.40|><|18.46|> emas.<|18.68|><|19.24|> Untuk<|19.40|><|19.46|> makluman<|19.86|><|20.64|> Tuan<|20.76|><|20.82|> Yang<|20.90|><|20.94|> Pertua<|21.14|><|21.20|> dan<|21.28|><|21.34|> juga<|21.50|><|21.58|> Alia<|21.70|><|21.76|> Mbah<|21.88|><|21.92|> Ahmad,<|22.08|><|22.22|> pembangunan<|22.66|><|22.72|> sistem<|23.00|><|23.06|> pendaftaran<|23.48|><|23.54|> warga<|23.72|><|23.78|> emas<|23.98|><|24.06|> ataupun<|24.36|><|24.42|> kita<|24.56|><|24.62|> sebutkan<|24.94|><|25.08|> event<|25.38|><|25.86|> adalah<|26.10|><|26.18|> usaha<|26.46|><|26.60|> kerajaan<|27.06|><|27.16|> kearah<|27.44|><|27.50|> merealisasikan<|28.36|><|28.86|> objektif<|29.36|><|29.42|> yang<|29.52|><|29.56|> telah<|29.72|><|29.76|> digarakan<|30.00|><|endoftext|> |
|
``` |
|
|
|
**Make sure you already monkey patched `tokenization_whisper.TASK_IDS = ["translate", "transcribe", "transcribeprecise"]` at starting of your script**. |
|
|