本文整理匯總了Java中com.google.common.collect.ImmutableMultimap.get方法的典型用法代碼示例。如果您正苦於以下問題:Java ImmutableMultimap.get方法的具體用法?Java ImmutableMultimap.get怎麽用?Java ImmutableMultimap.get使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類com.google.common.collect.ImmutableMultimap
的用法示例。
在下文中一共展示了ImmutableMultimap.get方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: blame
import com.google.common.collect.ImmutableMultimap; //導入方法依賴的package包/類
public String blame(XmlDocument xmlDocument)
throws IOException, SAXException, ParserConfigurationException {
ImmutableMultimap<Integer, Record> resultingSourceMapping =
getResultingSourceMapping(xmlDocument);
LineReader lineReader = new LineReader(
new StringReader(xmlDocument.prettyPrint()));
StringBuilder actualMappings = new StringBuilder();
String line;
int count = 1;
while ((line = lineReader.readLine()) != null) {
actualMappings.append(count).append(line).append("\n");
if (resultingSourceMapping.containsKey(count)) {
for (Record record : resultingSourceMapping.get(count)) {
actualMappings.append(count).append("-->")
.append(record.getActionLocation().toString())
.append("\n");
}
}
count++;
}
return actualMappings.toString();
}
示例2: immutableMultiMapCollector
import com.google.common.collect.ImmutableMultimap; //導入方法依賴的package包/類
@Test
public void immutableMultiMapCollector() {
ImmutableMultimap<Integer, Integer> result = Stream.iterate(0, p -> p+1)
.parallel()
.limit(GENERATED_ITEMS)
.collect(Collectors.groupingBy(i -> i % 10));
assertEquals(GENERATED_ITEMS,result.size());
assertEquals(10,result.asMap().size());
for (int i=0;i<10;i++) {
int key=i;
ImmutableCollection<Integer> values = result.get(key);
values.forEach(v -> {
assertEquals(key,v % 10);
});
}
}
示例3: align
import com.google.common.collect.ImmutableMultimap; //導入方法依賴的package包/類
@Override
public EventArgScoringAlignment<EquivClassType> align(final AnswerKey answerKey,
final ArgumentOutput argumentOutput) {
checkArgument(answerKey.docId() == argumentOutput.docId());
final ImmutableMultimap<EquivClassType, Response> equivClassToSystemResponses = Multimaps.index(
argumentOutput.responses(), equivClassFunction);
final ImmutableMultimap<EquivClassType, AssessedResponse> equivClassToAnswerKeyResponses =
Multimaps.index(
answerKey.annotatedResponses(),
Functions.compose(equivClassFunction, AssessedResponseFunctions.response()));
final ImmutableSet<EquivClassType> allEquivClasses =
Sets.union(equivClassToSystemResponses.keySet(),
equivClassToAnswerKeyResponses.keySet()).immutableCopy();
final ImmutableSet.Builder<EquivClassType> truePositives = ImmutableSet.builder();
final ImmutableSet.Builder<EquivClassType> falsePositives = ImmutableSet.builder();
final ImmutableSet.Builder<EquivClassType> falseNegatives = ImmutableSet.builder();
final ImmutableSet.Builder<EquivClassType> unassessed = ImmutableSet.builder();
for (final EquivClassType eqivClass : allEquivClasses) {
// a key equivalence class is correct if anyone found a correct response in that class
final ImmutableCollection<AssessedResponse> answerKeyResponsesForEC =
equivClassToAnswerKeyResponses.get(eqivClass);
final boolean isCorrectEquivClass = !FluentIterable.
from(answerKeyResponsesForEC)
.filter(AssessedResponse.IsCorrectUpToInexactJustifications)
.isEmpty();
final ImmutableCollection<Response> systemResponsesForEC = equivClassToSystemResponses.get(
eqivClass);
if (isCorrectEquivClass) {
// only the top-scoring system response for an equivalence class counts
final Optional<Response> selectedSystemResponse =
argumentOutput.selectFromMultipleSystemResponses(
equivClassToSystemResponses.get(eqivClass));
if (selectedSystemResponse.isPresent()) {
final Optional<AssessedResponse> assessmentOfSelectedResponse =
AssessedResponse.findAnnotationForArgument(
selectedSystemResponse.get(), answerKeyResponsesForEC);
if (assessmentOfSelectedResponse.isPresent()) {
if (assessmentOfSelectedResponse.get().isCorrectUpToInexactJustifications()) {
truePositives.add(eqivClass);
} else {
// it was a correct equivalence class, but we the system response for that
// equivalence class was incorrect (e.g. due to bad justifications).
// This counts as both a false positive and a false negative. Note that there
// could be a correct system response for the equivalence class which has a lower
// confidence, but it won't count.
falseNegatives.add(eqivClass);
falsePositives.add(eqivClass);
}
} else {
// the best system response for this equivalence class is unassessed
unassessed.add(eqivClass);
}
} else {
// it was a correct equivalence class, but we didn't find any responses
falseNegatives.add(eqivClass);
}
} else {
// if the equivalence class is incorrect, the system is wrong if it returned *any* response
if (!systemResponsesForEC.isEmpty()) {
falsePositives.add(eqivClass);
} else {
// do nothing - it was a true negative
}
}
}
return EventArgScoringAlignment
.create(argumentOutput.docId(), argumentOutput, answerKey, truePositives.build(),
falsePositives.build(),
falseNegatives.build(), unassessed.build(), equivClassToAnswerKeyResponses,
equivClassToSystemResponses);
}