本文整理匯總了Java中org.nd4j.linalg.api.ndarray.INDArray.muli方法的典型用法代碼示例。如果您正苦於以下問題:Java INDArray.muli方法的具體用法?Java INDArray.muli怎麽用?Java INDArray.muli使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類org.nd4j.linalg.api.ndarray.INDArray
的用法示例。
在下文中一共展示了INDArray.muli方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: lexicalSubstituteMult
import org.nd4j.linalg.api.ndarray.INDArray; //導入方法依賴的package包/類
/**
* Lexical Substitute task by Multiple Method
* @param word target word
* @param contexts list of given contexts
* @param average average the context vectors of given contexts
* @param top number of results return
* @return a list of {@link Pair}
*/
public List<Pair<String, Double>> lexicalSubstituteMult (String word, List<String> contexts, boolean average, Integer top) {
top = MoreObjects.firstNonNull(top, 10);
INDArray targetVec = getWordVector(word);
INDArray scores = wordPosSimilarity(targetVec);
for (String context : contexts) {
if (hasContext(context)) {
INDArray multScores = wordPosSimilarity(getContextVector(context));
if (average) multScores = Transforms.pow(multScores, 1.0 / contexts.size());
scores.muli(multScores);
}
}
List<Pair<String, Double>> list = new ArrayList<>(wordVocab.size());
for (int i = 0; i < wordVocab.size(); i++) { list.add(new Pair<>(wordVocab.get(i), scores.getDouble(i))); }
return list.stream().sorted((e1, e2) -> Double.valueOf(e2.getValue()).compareTo(Double.valueOf(e1.getValue()))).limit(top).collect(Collectors.toCollection(LinkedList::new));
}