簡介
主要內容包括
如何將文本處理為Tensorflow LSTM的輸入
如何定義LSTM
用訓練好的LSTM進行文本分類
代碼
導入相關庫
#coding=utf-8
importtensorflowastf
fromtensorflow.contribimportlearn
importnumpyasnp
fromtensorflow.python.ops.rnnimportstatic_rnn
fromtensorflow.python.ops.rnn_cell_implimportBasicLSTMCell
數據
# 數據
positive_texts=[
"我 今天 很 高興",
"我 很 開心",
"他 很 高興",
"他 很 開心"
]
negative_texts=[
"我 不 高興",
"我 不 開心",
"他 今天 不 高興",
"他 不 開心"
]
label_name_dict={
0:"正面情感",
1:"負面情感"
}
配置信息
配置信息
embedding_size=50
num_classes=2
將文本和label數值化
# 將文本和label數值化
all_texts=positive_texts+negative_textslabels=[0]*len(positive_texts)+[1]*len(negative_texts)
max_document_length=4
vocab_processor=learn.preprocessing.VocabularyProcessor(max_document_length)
datas=np.array(list(vocab_processor.fit_transform(all_texts)))
vocab_size=len(vocab_processor.vocabulary_)
定義placeholder(容器),存放輸入輸出
# 容器,存放輸入輸出
datas_placeholder=tf.placeholder(tf.int32, [None, max_document_length])
labels_placeholder=tf.placeholder(tf.int32, [None])
詞向量處理
# 詞向量表
embeddings=tf.get_variable("embeddings", [vocab_size, embedding_size],initializer=tf.truncated_normal_initializer)
# 將詞索引號轉換為詞向量[None, max_document_length] => [None, max_document_length, embedding_size]
embedded=tf.nn.embedding_lookup(embeddings, datas_placeholder)
將數據處理為LSTM的輸入格式
# 轉換為LSTM的輸入格式,要求是數組,數組的每個元素代表某個時間戳一個Batch的數據
rnn_input=tf.unstack(embedded, max_document_length,axis=1)
定義LSTM
# 定義LSTM
lstm_cell=BasicLSTMCell(20,forget_bias=1.0)
rnn_outputs, rnn_states=static_rnn(lstm_cell, rnn_input,dtype=tf.float32)
#利用LSTM最后的輸出進行預測
logits=tf.layers.dense(rnn_outputs[-1], num_classes)
predicted_labels=tf.argmax(logits,axis=1)
定義損失和優化器
# 定義損失和優化器
losses=tf.nn.softmax_cross_entropy_with_logits(
labels=tf.one_hot(labels_placeholder, num_classes),
logits=logits
)
mean_loss=tf.reduce_mean(losses)
optimizer=tf.train.AdamOptimizer(learning_rate=1e-2).minimize(mean_loss)
執行
withtf.Session()assess:
# 初始化變量
sess.run(tf.global_variables_initializer())
訓練# 定義要填充的數據
feed_dict={
datas_placeholder: datas,
labels_placeholder: labels
}
print("開始訓練")
forstepinrange(100):
_, mean_loss_val=sess.run([optimizer, mean_loss],feed_dict=feed_dict)
ifstep%10==0:
print("step ={}tmean loss ={}".format(step, mean_loss_val))
預測
print("訓練結束,進行預測")
predicted_labels_val=sess.run(predicted_labels,feed_dict=feed_dict)
fori, textinenumerate(all_texts):
label=predicted_labels_val[i]
label_name=label_name_dict[label]
print("{}=>{}".format(text, label_name))
審核編輯 黃昊宇
-
LSTM
+關注
關注
0文章
59瀏覽量
3773
發布評論請先 登錄
相關推薦
評論