All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ibm.wala.util.graph.impl.SparseNumberedGraph Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2002 - 2006 IBM Corporation.
 * All rights reserved. This program and the accompanying materials
 * are made available under the terms of the Eclipse Public License v1.0
 * which accompanies this distribution, and is available at
 * http://www.eclipse.org/legal/epl-v10.html
 *
 * Contributors:
 *     IBM Corporation - initial API and implementation
 */
package com.ibm.wala.util.graph.impl;

import com.ibm.wala.util.graph.AbstractNumberedGraph;
import com.ibm.wala.util.graph.INodeWithNumber;
import com.ibm.wala.util.graph.NumberedEdgeManager;
import com.ibm.wala.util.graph.NumberedNodeManager;
import com.ibm.wala.util.intset.BasicNaturalRelation;

/** A graph of numbered nodes, expected to have a fairly sparse edge structure. */
public class SparseNumberedGraph extends AbstractNumberedGraph {

  private final DelegatingNumberedNodeManager nodeManager;

  private final SparseNumberedEdgeManager edgeManager;

  public SparseNumberedGraph() {
    nodeManager = new DelegatingNumberedNodeManager<>();
    edgeManager = new SparseNumberedEdgeManager<>(nodeManager);
  }

  /**
   * If normalCase == n, the s edge manager will eagerly allocated n words to hold out edges for
   * each node. (performance optimization for time)
   *
   * @param normalCase what is the "normal" number of out edges for a node?
   */
  public SparseNumberedGraph(int normalCase) {
    nodeManager = new DelegatingNumberedNodeManager<>();
    edgeManager =
        new SparseNumberedEdgeManager<>(nodeManager, normalCase, BasicNaturalRelation.TWO_LEVEL);
  }

  public SparseNumberedGraph(
      DelegatingNumberedNodeManager nodeManager, SparseNumberedEdgeManager edgeManager) {
    this.nodeManager = nodeManager;
    this.edgeManager = edgeManager;
  }

  /**
   * @see com.ibm.wala.util.graph.AbstractGraph#getNodeManager()
   */
  @Override
  protected NumberedNodeManager getNodeManager() {
    return nodeManager;
  }

  /**
   * @see com.ibm.wala.util.graph.AbstractGraph#getEdgeManager()
   */
  @Override
  protected NumberedEdgeManager getEdgeManager() {
    return edgeManager;
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy