Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance. Project price only 1 $
You can buy this project and download/modify it how often you want.
/*
* This file is part of GraphStream .
*
* GraphStream is a library whose purpose is to handle static or dynamic
* graph, create them from scratch, file or any source and display them.
*
* This program is free software distributed under the terms of two licenses, the
* CeCILL-C license that fits European law, and the GNU Lesser General Public
* License. You can use, modify and/ or redistribute the software under the terms
* of the CeCILL-C license as circulated by CEA, CNRS and INRIA at the following
* URL or under the terms of the GNU LGPL as published by
* the Free Software Foundation, either version 3 of the License, or (at your
* option) any later version.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*
* The fact that you are presently reading this means that you have had
* knowledge of the CeCILL-C and LGPL licenses and that you accept their terms.
*/
/**
* @since 2009-02-19
*
* @author Guilhelm Savin
* @author Yoann Pigné
* @author Antoine Dutot
* @author Stefan Balev
* @author Hicham Brahimi
*/
package org.graphstream.graph.implementations;
import org.graphstream.graph.Graph;
import org.graphstream.graph.NodeFactory;
/**
* A graph implementation that supports multiple edges between two nodes.
*/
public class MultiGraph extends AdjacencyListGraph {
/**
* Creates an empty graph.
*
* @param id
* Unique identifier of the graph.
* @param strictChecking
* If true any non-fatal error throws an exception.
* @param autoCreate
* If true (and strict checking is false), nodes are automatically
* created when referenced when creating a edge, even if not yet
* inserted in the graph.
* @param initialNodeCapacity
* Initial capacity of the node storage data structures. Use this if
* you know the approximate maximum number of nodes of the graph. The
* graph can grow beyond this limit, but storage reallocation is
* expensive operation.
* @param initialEdgeCapacity
* Initial capacity of the edge storage data structures. Use this if
* you know the approximate maximum number of edges of the graph. The
* graph can grow beyond this limit, but storage reallocation is
* expensive operation.
*/
public MultiGraph(String id, boolean strictChecking, boolean autoCreate, int initialNodeCapacity,
int initialEdgeCapacity) {
super(id, strictChecking, autoCreate, initialNodeCapacity, initialEdgeCapacity);
// All we need to do is to change the node factory
setNodeFactory(new NodeFactory() {
public MultiNode newInstance(String id, Graph graph) {
return new MultiNode((AbstractGraph) graph, id);
}
});
}
/**
* Creates an empty graph with default edge and node capacity.
*
* @param id
* Unique identifier of the graph.
* @param strictChecking
* If true any non-fatal error throws an exception.
* @param autoCreate
* If true (and strict checking is false), nodes are automatically
* created when referenced when creating a edge, even if not yet
* inserted in the graph.
*/
public MultiGraph(String id, boolean strictChecking, boolean autoCreate) {
this(id, strictChecking, autoCreate, DEFAULT_NODE_CAPACITY, DEFAULT_EDGE_CAPACITY);
}
/**
* Creates an empty graph with strict checking and without auto-creation.
*
* @param id
* Unique identifier of the graph.
*/
public MultiGraph(String id) {
this(id, true, false);
}
}