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


Java ObjectDoubleOpenHashMap類代碼示例

本文整理匯總了Java中com.carrotsearch.hppc.ObjectDoubleOpenHashMap的典型用法代碼示例。如果您正苦於以下問題:Java ObjectDoubleOpenHashMap類的具體用法?Java ObjectDoubleOpenHashMap怎麽用?Java ObjectDoubleOpenHashMap使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: getFitness

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
/**
 * Computes min squared error
 * 
 * @param expression
 *            Expression
 * @param graphVectors
 *            Values for given graphs
 * @return Fitness of expression
 */
public double getFitness(Expression expression, ObjectDoubleOpenHashMap<String>[] graphVectors) {
    double values[] = new double[graphVectors.length];
    for (int i = 0; i < graphVectors.length; i++) {
        values[i] = Math.abs(expression.getValue(graphVectors[i]));
    }

    double max = getMax(values);
    double fitness = 0d;
    for (int i = 0; i < values.length - 1; i++) {
        for (int j = i + 1; j < values.length; j++) {
            fitness = fitness + Math.pow(values[i] - values[j], 2);
        }
    }
    if (fitness == 0) {
        return 1;
    }
    fitness = fitness / (max * max); // norm to 1
    fitness = 2 * fitness / (values.length * (values.length - 1)); // compute
                                                                   // average
    return (1d - fitness);
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:31,代碼來源:MinSquaredError.java

示例2: getValue

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Override
public double getValue(ObjectDoubleOpenHashMap<String> graphMetrics) {
    double leftValue = left.getValue(graphMetrics);
    double rightValue = right.getValue(graphMetrics);
    switch (operation) {
    case DIV:
        return leftValue / rightValue;
    case MINUS:
        return leftValue - rightValue;
    case PLUS:
        return leftValue + rightValue;
    case TIMES:
        return leftValue * rightValue;
    default:
        return Double.NaN;
    }
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:18,代碼來源:Operation.java

示例3: test

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Test
public void test() {
    Model model = ModelFactory.createDefaultModel();
    InputStream is = this.getClass().getClassLoader().getResourceAsStream(GRAPH_FILE);
    model.read(is, null, "N3");
    IOUtils.closeQuietly(is);

    GraphCreator creator = new GraphCreator();
    ColouredGraph graph = creator.processModel(model);

    EdgeColourDistributionMetric metric = new EdgeColourDistributionMetric();
    ObjectDistribution<BitSet> distribution = metric.apply(graph);

    ObjectDoubleOpenHashMap<BitSet> expectedCounts = new ObjectDoubleOpenHashMap<BitSet>();
    ColourPalette palette = graph.getEdgePalette();
    for (int i = 0; i < EXPECTED_PROPERTY_URIS.length; ++i) {
        expectedCounts.put(palette.getColour(EXPECTED_PROPERTY_URIS[i]), EXPECTED_PROPERTY_COUNTS[i]);
    }

    for (int i = 0; i < distribution.sampleSpace.length; ++i) {
        Assert.assertTrue(expectedCounts.containsKey(distribution.sampleSpace[i]));
        Assert.assertEquals(expectedCounts.get(distribution.sampleSpace[i]), distribution.values[i]);
    }
    Assert.assertEquals(expectedCounts.size(), distribution.sampleSpace.length);
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:26,代碼來源:EdgeColourDistributionMetricTest.java

示例4: propagateTopicWeight

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
/** Propagate a topic weight to a node and all its children.
	weight is assumed to be a log.
*/
   public void propagateTopicWeight(ObjectDoubleOpenHashMap<NCRPNode> nodeWeights,
								 NCRPNode node, double weight) {
	if (! nodeWeights.containsKey(node)) {
		// calculating the NCRP prior proceeds from the
		//  root down (ie following child links),
		//  but adding the word-topic weights comes from
		//  the bottom up, following parent links and then 
		//  child links. It's possible that the leaf node may have
		//  been removed just prior to this round, so the current
		//  node may not have an NCRP weight. If so, it's not 
		//  going to be sampled anyway, so ditch it.
		return;
	}

	for (NCRPNode child: node.children) {
		propagateTopicWeight(nodeWeights, child, weight);
	}

	nodeWeights.addTo(node, weight);
   }
 
開發者ID:cmoen,項目名稱:mallet,代碼行數:24,代碼來源:HierarchicalLDA.java

示例5: argmax

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
/** Returns the key in map that has the greatest score */
public static Object argmax (ObjectDoubleOpenHashMap map)
{
  // A local class! Yes, Virginia, this is legal Java.
  class Accumulator implements ObjectDoubleProcedure {
    double bestVal = Double.NEGATIVE_INFINITY;
    Object bestObj = null;
    public void apply (Object a, double b)
    {
      if (b > bestVal) {
        bestVal = b;
        bestObj = a;
      }
    }
  }

  Accumulator procedure = new Accumulator ();
    map.forEach(procedure);
  return procedure.bestObj;
}
 
開發者ID:cmoen,項目名稱:mallet,代碼行數:21,代碼來源:CollectionUtils.java

示例6: printGraphMetrics

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
private String printGraphMetrics(ObjectDoubleOpenHashMap<String>[] graphVectors) {
    StringBuilder builder = new StringBuilder();
    builder.append("Metric");
    for (int i = 0; i < graphVectors.length; ++i) {
        builder.append("\tgraph");
        builder.append(i);
    }
    builder.append('\n');
    String key;
    for (int i = 0; i < graphVectors[0].allocated.length; ++i) {
        if (graphVectors[0].allocated[i]) {
            key = (String) ((Object[]) graphVectors[0].keys)[i];
            builder.append(key);
            builder.append('\t');
            builder.append(Double.toString(graphVectors[0].values[i]));
            for (int j = 1; j < graphVectors.length; ++j) {
                builder.append('\t');
                if (graphVectors[j].containsKey(key)) {
                    builder.append(Double.toString(graphVectors[j].get(key)));
                } else {
                    builder.append('?');
                }
            }
            builder.append('\n');
        }
    }
    return builder.toString();
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:29,代碼來源:CharacteristicExpressionSearcher.java

示例7: getFitness

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Override
public double getFitness(Expression expression, ObjectDoubleOpenHashMap<String>[] graphVectors) {
    double fitness = decorated.getFitness(expression, graphVectors);
    double comparedFitness = fitness / decorated.getFitness(expression, referenceGraphVectors);
    return (2 * fitness * comparedFitness) / (fitness + comparedFitness);
    // return comparedFitness;
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:8,代碼來源:ReferenceGraphBasedFitnessDecorator.java

示例8: getValue

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Override
public double getValue(ObjectDoubleOpenHashMap<String> graphMetrics) {
    if (graphMetrics.containsKey(metric.getName())) {
        return graphMetrics.get(metric.getName());
    } else {
        // this is an error.
        return Double.NaN;
    }
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:10,代碼來源:AtomicVariable.java

示例9: test

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Test
public void test() {
    Model model = ModelFactory.createDefaultModel();
    InputStream is = this.getClass().getClassLoader().getResourceAsStream(GRAPH_FILE);
    model.read(is, null, "N3");
    IOUtils.closeQuietly(is);

    GraphCreator creator = new GraphCreator();
    ColouredGraph graph = creator.processModel(model);

    VertexColourDistributionMetric metric = new VertexColourDistributionMetric();
    ObjectDistribution<BitSet> distribution = metric.apply(graph);

    ObjectDoubleOpenHashMap<BitSet> expectedCounts = new ObjectDoubleOpenHashMap<BitSet>();
    ColourPalette palette = graph.getVertexPalette();
    BitSet colour;
    for (int i = 0; i < EXPECTED_VERTEX_CLASSES.length; ++i) {
        if (EXPECTED_VERTEX_CLASSES[i].contains("|")) {
            colour = palette.getColourMixture(EXPECTED_VERTEX_CLASSES[i].split("\\|"));
        } else {
            colour = palette.getColour(EXPECTED_VERTEX_CLASSES[i]);
        }
        Assert.assertTrue("There is no colour for " + EXPECTED_VERTEX_CLASSES[i], colour.cardinality() > 0);
        expectedCounts.put(colour, EXPECTED_VERTEX_COUNTS[i]);
    }
    expectedCounts.put(new BitSet(), EXPECTED_VERTEXES_WITHOUT_COLOURS);

    for (int i = 0; i < distribution.sampleSpace.length; ++i) {
        Assert.assertTrue(expectedCounts.containsKey(distribution.sampleSpace[i]));
        Assert.assertEquals(expectedCounts.get(distribution.sampleSpace[i]), distribution.values[i]);
    }
    Assert.assertEquals(expectedCounts.size(), distribution.sampleSpace.length);
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:34,代碼來源:VertexColourDistributionMetricTest.java

示例10: calculateMarginals

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
public Marginals calculateMarginals() {
  ObjectDoubleOpenHashMap<String> x = ObjectDoubleOpenHashMap.newInstance();
  ObjectDoubleOpenHashMap<String> y = ObjectDoubleOpenHashMap.newInstance();
  double sum = 0;
  for (Table.Cell<String, String, Double> cell : xyProb.cellSet()) {
    x.putOrAdd(cell.getRowKey(), cell.getValue(), cell.getValue());
    y.putOrAdd(cell.getColumnKey(), cell.getValue(), cell.getValue());
    sum += cell.getValue();
  }
  return new Marginals(x, y, sum);
}
 
開發者ID:steveash,項目名稱:jg2p,代碼行數:12,代碼來源:ProbTable.java

示例11: calculateNCRP

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
public void calculateNCRP(ObjectDoubleOpenHashMap<NCRPNode> nodeWeights, 
					  NCRPNode node, double weight) {
for (NCRPNode child: node.children) {
	calculateNCRP(nodeWeights, child,
				  weight + Math.log((double) child.customers / (node.customers + gamma)));
}

nodeWeights.put(node, weight + Math.log(gamma / (node.customers + gamma)));
  }
 
開發者ID:cmoen,項目名稱:mallet,代碼行數:10,代碼來源:HierarchicalLDA.java

示例12: ReferenceGraphBasedFitnessDecorator

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
public ReferenceGraphBasedFitnessDecorator(FitnessFunction decorated,
        ObjectDoubleOpenHashMap<String>[] referenceGraphVectors) {
    this.decorated = decorated;
    this.referenceGraphVectors = referenceGraphVectors;
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:6,代碼來源:ReferenceGraphBasedFitnessDecorator.java

示例13: getFitness

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
public double getFitness(Expression expression, ObjectDoubleOpenHashMap<String>[] graphVectors) {
    double value = super.getFitness(expression, graphVectors);
    return value - expression.getSize() * FACTOR;
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:5,代碼來源:LengthAwareMinSquaredError.java

示例14: getValue

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@Override
public double getValue(ObjectDoubleOpenHashMap<String> graphMetrics) {
    return constantValue;
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:5,代碼來源:Constant.java

示例15: createReferenceGraphVectors

import com.carrotsearch.hppc.ObjectDoubleOpenHashMap; //導入依賴的package包/類
@SuppressWarnings("unchecked")
private static ObjectDoubleOpenHashMap<String>[] createReferenceGraphVectors(ColouredGraph[] graphs,
        List<SingleValueMetric> metrics) {
    Grph temp;
    int numberOfNodes, partSize;
    List<ObjectDoubleOpenHashMap<String>> vectors = new ArrayList<ObjectDoubleOpenHashMap<String>>(
            5 * graphs.length);
    for (int i = 0; i < graphs.length; ++i) {
        numberOfNodes = graphs[i].getGraph().getNumberOfVertices();
        LOGGER.info("Generating reference graphs with " + numberOfNodes + " nodes.");
        // Star
        StarTopologyGenerator starGenerator = new StarTopologyGenerator();
        temp = new InMemoryGrph();
        temp.addNVertices(numberOfNodes);
        starGenerator.compute(temp);
        vectors.add(MetricUtils.calculateGraphMetrics(new ColouredGraph(temp, null, null), metrics));
        temp = null;

        // Grid
        partSize = (int) Math.sqrt(numberOfNodes);
        MetricUtils.calculateGraphMetrics(new ColouredGraph(ClassicalGraphs.grid(partSize, partSize), null, null),
                metrics);

        // Ring
        vectors.add(MetricUtils.calculateGraphMetrics(
                new ColouredGraph(ClassicalGraphs.cycle(numberOfNodes), null, null), metrics));

        // Clique
        // vectors.add(MetricUtils.calculateGraphMetrics(
        // new ColouredGraph(ClassicalGraphs.completeGraph(numberOfNodes),
        // null, null), metrics));
        vectors.add(MetricUtils.calculateGraphMetrics(
                new ColouredGraph(ClassicalGraphs.completeGraph(partSize), null, null), metrics));

        // Bipartite
        // partSize = numberOfNodes / 2;
        partSize = numberOfNodes / 8;
        vectors.add(MetricUtils.calculateGraphMetrics(
                new ColouredGraph(ClassicalGraphs.completeBipartiteGraph(partSize, partSize), null, null),
                metrics));
    }
    return vectors.toArray(new ObjectDoubleOpenHashMap[vectors.size()]);
}
 
開發者ID:dice-group,項目名稱:Lemming,代碼行數:44,代碼來源:RefinementTest.java


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