當前位置: 首頁>>代碼示例>>Java>>正文


Java TreeMultiset.create方法代碼示例

本文整理匯總了Java中com.google.common.collect.TreeMultiset.create方法的典型用法代碼示例。如果您正苦於以下問題:Java TreeMultiset.create方法的具體用法?Java TreeMultiset.create怎麽用?Java TreeMultiset.create使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在com.google.common.collect.TreeMultiset的用法示例。


在下文中一共展示了TreeMultiset.create方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: testPartitionSpread

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
@Test
public void testPartitionSpread() throws Exception {
    Multiset<Integer> results = TreeMultiset.create();
    Cluster c = Cluster.empty();
    try (Partitioner p = new DefaultPartitioner()) {
        PartitionKeyGenerator pkg = new PartitionKeyGenerator();

        mockPartitions(c);

        for (int i = 0; i < messages; i++) {
            results.add(p.partition("test", null, pkg.next(), null, null, c));
        }

        int expected = messages / partitions;
        double threshold = expected * 0.05;

        for (Multiset.Entry<Integer> e : results.entrySet()) {
            int offBy = Math.abs(e.getCount() - expected);
            assertTrue("Partition " + e.getElement() + " had " + e.getCount() + " elements, expected " + expected + ", threshold is " + threshold,
                    offBy < threshold);
        }
    }
}
 
開發者ID:opentable,項目名稱:otj-logging,代碼行數:24,代碼來源:PartitionSpreadTest.java

示例2: context

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public ScorerContext context( List<String> words ) {
    Multiset<String> counter = TreeMultiset.create();
    counter.addAll( words );

    int word_dim = word_model.dimensions();
    float[] word_vecs = new float[ counter.size() * word_dim ];
    IntArrayList word_counts = new IntArrayList();
    int n_words = 0;

    for( Multiset.Entry<String> entry : counter.entrySet() ) {
        if( word_model.get( entry.getElement(), word_vecs, n_words * word_dim ) ) {
            word_counts.add( entry.getCount() );
            n_words += 1;
        }
    }
    word_counts.trim();

    return create_context( word_vecs, word_counts.elements() );
}
 
開發者ID:yahoo,項目名稱:FEL,代碼行數:20,代碼來源:EntityScorer.java

示例3: visit

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public void visit(NodeTraversal traversal, Node node, Node parent) {
  Collection<Definition> defs =
      passUnderTest.getDefinitionsReferencedAt(node);
  if (defs != null) {
    StringBuffer sb = new StringBuffer();
    sb.append("USE ");
    sb.append(Token.name(node.getType()));
    sb.append(" ");
    sb.append(node.getQualifiedName());
    sb.append(" -> ");
    Multiset<String> defstrs = TreeMultiset.create();
    for (Definition def : defs) {
      Node rValue = def.getRValue();
      if (rValue != null) {
        defstrs.add(Token.name(rValue.getType()));
      } else {
        defstrs.add("<null>");
      }
    }

    sb.append(defstrs.toString());
    found.add(sb.toString());
  }
}
 
開發者ID:andyjko,項目名稱:feedlack,代碼行數:25,代碼來源:SimpleDefinitionFinderTest.java

示例4: AppliedPTransformInputWatermark

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public AppliedPTransformInputWatermark(Collection<? extends Watermark> inputWatermarks) {
  this.inputWatermarks = inputWatermarks;
  // The ordering must order elements by timestamp, and must not compare two distinct elements
  // as equal. This is built on the assumption that any element added as a pending element will
  // be consumed without modifications.
  //
  // The same logic is applied for pending timers
  Ordering<CommittedBundle<?>> pendingBundleComparator =
      new BundleByElementTimestampComparator().compound(Ordering.arbitrary());
  this.pendingElements =
      TreeMultiset.create(pendingBundleComparator);
  this.pendingTimers = TreeMultiset.create();
  this.objectTimers = new HashMap<>();
  this.existingTimers = new HashMap<>();
  currentWatermark = new AtomicReference<>(BoundedWindow.TIMESTAMP_MIN_VALUE);
}
 
開發者ID:apache,項目名稱:beam,代碼行數:17,代碼來源:WatermarkManager.java

示例5: testPerf

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
@Test
void testPerf() {
    Map<String, Integer> map = IntStream.range(1, 10).boxed()
            .collect(toMap(it -> "s" + it, identity()));
    WeightFailover<String> failover = WeightFailover.<String> newGenericBuilder() //
            .checker(it -> 1.0) //
            .build(map);
    long s = currentTimeMillis();
    Multiset<String> counter = TreeMultiset.create();
    for (int i = 0; i < 100000; i++) {
        List<String> available = failover.getAvailable(2);
        counter.addAll(available);
    }
    // old 260~270
    System.out.println(counter + ", cost:" + (currentTimeMillis() - s));
    s = currentTimeMillis();
    counter = TreeMultiset.create();
    for (int i = 0; i < 100000; i++) {
        counter.add(failover.getOneAvailable());
    }
    // old 60~70
    System.out.println(counter + ", cost:" + (currentTimeMillis() - s));
}
 
開發者ID:PhantomThief,項目名稱:simple-failover-java,代碼行數:24,代碼來源:WeightFailoverTest.java

示例6: main

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public static void main(String[] args) {
    // Parse text to separate words
    String INPUT_TEXT = "Hello World! Hello All! Hi World!";
    // Create Multiset
    Multiset<String> multiset = TreeMultiset.create(Arrays.asList(INPUT_TEXT.split(" ")));

    // Print count words
    System.out.println(multiset); // print [All!, Hello x 2, Hi, World! x 2]- in natural (alphabet) order
    // Print all unique words
    System.out.println(multiset.elementSet());    // print [All!, Hello, Hi, World!]- in natural (alphabet) order

    // Print count occurrences of words
    System.out.println("Hello = " + multiset.count("Hello"));    // print 2
    System.out.println("World = " + multiset.count("World!"));    // print 2
    System.out.println("All = " + multiset.count("All!"));    // print 1
    System.out.println("Hi = " + multiset.count("Hi"));    // print 1
    System.out.println("Empty = " + multiset.count("Empty"));    // print 0

    // Print count all words
    System.out.println(multiset.size());    //print 6

    // Print count unique words
    System.out.println(multiset.elementSet().size());    //print 4
}
 
開發者ID:Vedenin,項目名稱:java_in_examples,代碼行數:25,代碼來源:GuavaTreeMultisetTest.java

示例7: main

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public static void main(String[] args) {
    // Разберем текст на слова
    String INPUT_TEXT = "Hello World! Hello All! Hi World!";
    // Создаем Multiset
    Multiset<String> multiset = TreeMultiset.create(Arrays.asList(INPUT_TEXT.split(" ")));

    // Выводим кол-вом вхождений слов
    System.out.println(multiset); // напечатает [All!, Hello x 2, Hi, World! x 2]- в алфавитном порядке
    // Выводим все уникальные слова
    System.out.println(multiset.elementSet());    // напечатает [All!, Hello, Hi, World!]- в алфавитном порядке

    // Выводим количество по каждому слову
    System.out.println("Hello = " + multiset.count("Hello"));    // напечатает 2
    System.out.println("World = " + multiset.count("World!"));    // напечатает 2
    System.out.println("All = " + multiset.count("All!"));    // напечатает 1
    System.out.println("Hi = " + multiset.count("Hi"));    // напечатает 1
    System.out.println("Empty = " + multiset.count("Empty"));    // напечатает 0

    // Выводим общее количества всех слов в тексте
    System.out.println(multiset.size());    //напечатает 6

    // Выводим общее количество всех уникальных слов
    System.out.println(multiset.elementSet().size());    //напечатает 4
}
 
開發者ID:Vedenin,項目名稱:java_in_examples,代碼行數:25,代碼來源:GuavaTreeMultisetTest.java

示例8: getAlternativeNames

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
/**
 * @param relevantNgrams
 * @param currentName
 * @return
 */
public Multiset<String> getAlternativeNames(
        final Multiset<NGram<String>> relevantNgrams,
        final String currentName) {
    // Get all alternative namings
    final Multiset<String> nameAlternatives = ngramLM
            .getAlternativeNamings(relevantNgrams, WILDCARD_TOKEN);
    nameAlternatives.add(currentName); // Give the current identifier a
                                        // chance...

    // Prune naming alternatives
    final Multiset<String> toKeep = TreeMultiset.create();

    int seen = 0;
    for (final Entry<String> ent : Multisets.copyHighestCountFirst(
            nameAlternatives).entrySet()) {
        if (seen > 1000) {
            break;
        }
        toKeep.add(ent.getElement(), ent.getCount());
        seen++;
    }
    toKeep.add(AbstractNGramLM.UNK_SYMBOL);
    return toKeep;
}
 
開發者ID:mast-group,項目名稱:naturalize,代碼行數:30,代碼來源:AbstractIdentifierRenamings.java

示例9: testSerialization

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public void testSerialization() {
    BeanWithMultisetTypes bean = new BeanWithMultisetTypes();

    List<String> list = Arrays.asList( "foo", "abc", null, "abc" );
    List<String> listWithNonNull = Arrays.asList( "foo", "abc", "bar", "abc" );

    bean.multiset = LinkedHashMultiset.create( list );
    bean.hashMultiset = HashMultiset.create( Arrays.asList( "abc", "abc" ) );
    bean.linkedHashMultiset = LinkedHashMultiset.create( list );
    bean.sortedMultiset = TreeMultiset.create( listWithNonNull );
    bean.treeMultiset = TreeMultiset.create( listWithNonNull );
    bean.immutableMultiset = ImmutableMultiset.copyOf( listWithNonNull );
    bean.enumMultiset = EnumMultiset.create( Arrays.asList( AlphaEnum.B, AlphaEnum.A, AlphaEnum.D, AlphaEnum.A ) );

    String expected = "{" +
            "\"multiset\":[\"foo\",\"abc\",\"abc\",null]," +
            "\"hashMultiset\":[\"abc\",\"abc\"]," +
            "\"linkedHashMultiset\":[\"foo\",\"abc\",\"abc\",null]," +
            "\"sortedMultiset\":[\"abc\",\"abc\",\"bar\",\"foo\"]," +
            "\"treeMultiset\":[\"abc\",\"abc\",\"bar\",\"foo\"]," +
            "\"immutableMultiset\":[\"foo\",\"abc\",\"abc\",\"bar\"]," +
            "\"enumMultiset\":[\"A\",\"A\",\"B\",\"D\"]" +
            "}";

    assertEquals( expected, BeanWithMultisetTypesMapper.INSTANCE.write( bean ) );
}
 
開發者ID:nmorel,項目名稱:gwt-jackson,代碼行數:27,代碼來源:MultisetGwtTest.java

示例10: testSchema

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
@Test
public void testSchema() throws IOException {
    SchemaSampler s = new SchemaSampler(Resources.asCharSource(Resources.getResource("schema014.json"), Charsets.UTF_8).read());

    Multiset<String> prefixCounts = TreeMultiset.create();
    Multiset<String> otherCounts = TreeMultiset.create();
    for (int i = 0; i < 100; i++) {
        JsonNode r = s.sample();
        assertEquals(r.get("v1").asText(), r.get("v2").get("VIN").asText());
        prefixCounts.add(r.get("v1").asText().substring(0, 2));
        otherCounts.add(r.get("v3").asText().substring(0, 2));
        System.out.printf("%s\n", r);
    }
    assertEquals("[1F, 2F, 3F]", prefixCounts.elementSet().toString());
    assertEquals("[2F, 3F]", otherCounts.elementSet().toString());
}
 
開發者ID:tdunning,項目名稱:log-synth,代碼行數:17,代碼來源:VinSamplerTest.java

示例11: selectNext

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
private <T extends Comparable<?>> Multiset<T> selectNext(RandomSelector<T> selector, Random random, int size) {
  Multiset<T> selectedElements = TreeMultiset.create();
  for (int i = 0; i < size; i++) {
    selectedElements.add(selector.next(random));
  }
  return selectedElements;
}
 
開發者ID:ogregoire,項目名稱:fror-common,代碼行數:8,代碼來源:RandomSelectorTest.java

示例12: visit

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public void visit(NodeTraversal traversal, Node node, Node parent) {
  Collection<Definition> defs =
      passUnderTest.getDefinitionsReferencedAt(node);
  if (defs != null) {
    StringBuilder sb = new StringBuilder();
    sb.append("USE ");
    sb.append(Token.name(node.getType()));
    sb.append(" ");
    sb.append(node.getQualifiedName());
    sb.append(" -> ");
    Multiset<String> defstrs = TreeMultiset.create();
    for (Definition def : defs) {
      String defstr;

      Node rValue = def.getRValue();
      if (rValue != null) {
        defstr = Token.name(rValue.getType());
      } else {
        defstr = "<null>";
      }

      if (def.isExtern()) {
        defstr = "EXTERN " + defstr;
      }

      defstrs.add(defstr);
    }

    sb.append(defstrs.toString());
    found.add(sb.toString());
  }
}
 
開發者ID:ehsan,項目名稱:js-symbolic-executor,代碼行數:33,代碼來源:SimpleDefinitionFinderTest.java

示例13: computeGrammarTreeSizeStats

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
@Override
public SortedMultiset<Integer> computeGrammarTreeSizeStats() {
    // Get tree size distribution.
    final SortedMultiset<Integer> treeSizes = TreeMultiset.create();
    for (final Entry<T, ConcurrentHashMultiset<TreeNode<T>>> entry : grammar
            .entrySet()) {
        for (final Multiset.Entry<TreeNode<T>> rule : entry.getValue()
                .entrySet()) {
            treeSizes.add(rule.getElement().getTreeSize(), rule.getCount());
        }
    }
    return treeSizes;
}
 
開發者ID:mast-group,項目名稱:codemining-treelm,代碼行數:14,代碼來源:TSGrammar.java

示例14: printStatisticsFor

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public void printStatisticsFor(final int[] minPatternSizes,
        final int[] minPatternCounts) {
    Arrays.sort(minPatternCounts);
    Arrays.sort(minPatternSizes);

    loadPatternsForFiles();

    Multiset<Integer> prunedByCount = TreeMultiset.create();
    for (final Entry<TreeNode<Integer>> pattern : patterns.entrySet()) {
        prunedByCount.add(patternDictionary.get(pattern.getElement()),
                pattern.getCount());
    }
    System.out
            .println("minCount,minSize,nSeenPatterns,patternRecall,avgPatternSizeSeen,avgCoverage,avgFileRecall,avgSitesMatched,avgPatternSizePerFile");

    for (int i = 0; i < minPatternCounts.length; i++) {
        prunedByCount = getRulesWithMinCount(prunedByCount,
                minPatternCounts[i]);

        Multiset<Integer> prunedByCountBySize = prunedByCount;
        for (int j = 0; j < minPatternSizes.length; j++) {
            prunedByCountBySize = getRulesWithMinSize(prunedByCountBySize,
                    minPatternSizes[j]);
            // Great now our patterns are in prunedByCountBySize
            printPatternStatistics(prunedByCountBySize,
                    minPatternCounts[i], minPatternSizes[j]);
        }
    }
}
 
開發者ID:mast-group,項目名稱:codemining-treelm,代碼行數:30,代碼來源:PatternStatsCalculator.java

示例15: getAlternativeNamings

import com.google.common.collect.TreeMultiset; //導入方法依賴的package包/類
public Multiset<String> getAlternativeNamings(
        final Multiset<NGram<String>> ngrams, final String tokenToSubstitute) {
    final Multiset<String> namings = TreeMultiset.create();
    final LongTrie<String> globalTrie = getTrie();

    for (final Multiset.Entry<NGram<String>> ngramEntry : ngrams.entrySet()) {
        final NGram<String> ngram = ngramEntry.getElement();

        final Set<String> alternatives = checkNotNull(getAlternativesForNGram(
                globalTrie, ngram, tokenToSubstitute));
        namings.addAll(alternatives);
    }

    return namings;
}
 
開發者ID:mast-group,項目名稱:codemining-sequencelm,代碼行數:16,代碼來源:AbstractNGramLM.java


注:本文中的com.google.common.collect.TreeMultiset.create方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。