未验证 提交 6a79158f 编写于 作者: 4 46319943 提交者: GitHub

Batch features to make the model more efficient (#1730)

The original model didn't batch features, instead, it iterates the list to predict a single input at once.
Upon stacking the input features, we can make the model more efficient.
Co-authored-by: Nwuzewu <wuzewu@baidu.com>
Co-authored-by: NLinjie Chen <40840292+linjieccc@users.noreply.github.com>
上级 07599eed
......@@ -139,14 +139,29 @@ class ErnieSkepSentimentAnalysis(TransformerModule):
)
results = []
feature_list = []
for text in texts:
# feature.shape: [1, 512, 1]
# batch on the first dimension
feature = self._convert_text_to_feature(text)
inputs = [self.array2tensor(ndarray) for ndarray in feature]
feature_list.append(feature)
feature_batch = [
np.concatenate([feature[0] for feature in feature_list], axis=0),
np.concatenate([feature[1] for feature in feature_list], axis=0),
np.concatenate([feature[2] for feature in feature_list], axis=0),
np.concatenate([feature[3] for feature in feature_list], axis=0),
np.concatenate([feature[4] for feature in feature_list], axis=0),
]
inputs = [self.array2tensor(ndarray) for ndarray in feature_batch]
output = self.predictor.run(inputs)
probilities = np.array(output[0].data.float_data())
probilities_list = np.array(output[0].data.float_data())
probilities_list = probilities_list.reshape((-1, 2))
for i, probilities in enumerate(probilities_list):
label = self.label_map[np.argmax(probilities)]
result = {
'text': text,
'text': texts[i],
'sentiment_label': label,
'positive_probs': probilities[1],
'negative_probs': probilities[0]
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册