深度学习_用LSTM构建单词纠错神器(3)

六、模型预测

由于预测的word修正不知道何时结束, 所以我们需要对输入的值进行不断的修正,直到预测到末尾符为止。
即预测时候输入的input2为仅有一个起始符的全都为0的初始向量,然后每次预测都更新下字母位置的值,直到遇到末尾符。


## 由于预测的word 不知道何时结束, 所以我们需要对输入的值进行不断的修正,直到预测到末尾符为止
## 所以我们对于一个全新的输入,进行预测的时候需要先使得input2 输入为 一个全空的单词矩阵
def predict(m, input1_test):
    input2_orign = np.zeros((1, 36, 39))
    input2_orign[:, 0, g.char2int['\t']] = 1

    input_word = ''
    pred_word = ''

    for idx in range(input2_orign.shape[1] - 1): # max_encode_len
        p_tmp =  m.predict([tf.constant(input1_test), tf.constant(input2_orign)])
        # update input
        input2_w_idx = np.argmax(p_tmp[:, idx, :], axis=1)[0]
        # input2_orign[:, idx+1, :] = p_tmp[:, idx, :]
        input2_orign[:, idx+1, input2_w_idx] = 1
        
        input1_w_idx = np.argmax(input1_test[:, idx, :], axis=1)[0]
        pred_word += g.int2char[input2_w_idx]
        input_word += g.int2char[input1_w_idx]

        if (pred_word[-1] == '\n'):
            break
    print(f'[{idx}] input_word: {input_word[:-1]},  pred_word : {pred_word}' )
    return pred_word



def word2tensor(word):
    """
    当没有提供embedding的方法的时候,
    采用最简单的字母位置及出现则标记为1, 否则标记为0。 便于后面一个一个字母预测的时候抽取字母
    """
    char_set = [chr(i) for i in range(ord('a'), ord('z')+1)] + '0 1 2 3 4 5 6 7 8 9'.split() + ['\t', '\n', '#']
    char2int = dict(zip(char_set, range(len(char_set))))
    # int2char = dict(zip(range(len(char_set)), char_set))
    input1_encode_data = np.zeros((1, 34, len(char_set)), dtype='float64')

    # 将矩阵填充上数据 某个字母出现一次则标记增加1
    for w_idx, chr_tmp in enumerate(list(word)):
        if w_idx == 34:
            break
        input1_encode_data[0, w_idx, char2int[chr_tmp]] = 1

    return input1_encode_data


def word_correct(m, word):
    input1_encode_data = word2tensor(word)
    return predict(m, input1_encode_data)

预测测试

for  i in range(1, 50):
    print('--'*23, f'[i]', '--'*23)
    input1_test = input1_encode_data[i:i+1, :, :]
    predict(m, input1_test)


word_correct('hellp')

"""
---------------------------------------------- [12] ----------------------------------------------
[11] input_word: applicat5on,  pred_word : application

---------------------------------------------- [13] ----------------------------------------------
[11] input_word: requrements,  pred_word : requrements

---------------------------------------------- [14] ----------------------------------------------
[11] input_word: advertisrng,  pred_word : advertisrng

---------------------------------------------- [15] ----------------------------------------------
[12] input_word: construction,  pred_word : construction

---------------------------------------------- [16] ----------------------------------------------
[11] input_word: engineer5ng,  pred_word : engineering
"""
上一篇:intent-fliter报错


下一篇:Fliter--过滤器