Compare commits
No commits in common. "dfdc370b8e17a14cff73ca416c6b33c4d219433b" and "25cfa08b276e3aa8f4611bf9df19a78c60acfae9" have entirely different histories.
dfdc370b8e
...
25cfa08b27
@ -1,5 +0,0 @@
|
|||||||
# Transformer-based Translator
|
|
||||||
|
|
||||||
Simple Transformer
|
|
||||||
|
|
||||||
! [](image/Screenshot_20230329_023305.png)
|
|
||||||
Binary file not shown.
|
Before Width: | Height: | Size: 67 KiB |
19
predict.py
19
predict.py
@ -22,25 +22,6 @@ SHOW_NUM = 5
|
|||||||
NUM_HEADS = 8
|
NUM_HEADS = 8
|
||||||
DROPOUT_RATE = 0.5
|
DROPOUT_RATE = 0.5
|
||||||
|
|
||||||
def en2tokens(en_sentence, en_vocab, for_model=False, en_seq=50):
|
|
||||||
'''
|
|
||||||
English to tokens
|
|
||||||
|
|
||||||
Args:
|
|
||||||
en_sentence (str)
|
|
||||||
en_vocab (torchtext.Vocab)
|
|
||||||
|
|
||||||
for_model (bool, default=False): if `True`, it will add <SOS>, <END>, <PAD> tokens
|
|
||||||
en_seq (int): for padding <PAD>
|
|
||||||
Outputs:
|
|
||||||
tokens (LongTensor): (b,)
|
|
||||||
'''
|
|
||||||
tokenizer = torchtext.data.utils.get_tokenizer("basic_english")
|
|
||||||
tokens = en_vocab( tokenizer(en_sentence.lower()) )
|
|
||||||
if for_model:
|
|
||||||
tokens = [ en_vocab['<SOS>'] ] + tokens + [ en_vocab['<END>'] ]
|
|
||||||
tokens = tokens + [ en_vocab['<PAD>'] for _ in range(en_seq - len(tokens)) ]
|
|
||||||
return torch.LongTensor(tokens)
|
|
||||||
|
|
||||||
def predict(en_str, model, en_vocab, ch_vocab):
|
def predict(en_str, model, en_vocab, ch_vocab):
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user