
org.javanetworkanalyzer.analyzers.AccessibilityAnalyzer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-network-analyzer Show documentation
Show all versions of java-network-analyzer Show documentation
Graph theory and social network analysis algorithms implemented on JGraphT graphs.
The newest version!
/*
* Java Network Analyzer provides a collection of graph theory and social
* network analysis algorithms implemented on mathematical graphs using the
* JGraphT library.
*
* Java Network Analyzer is developed by the GIS group of the DECIDE team of the
* Lab-STICC CNRS laboratory, see .
* It is part of the OrbisGIS tool ecosystem.
*
* The GIS group of the DECIDE team is located at :
*
* Laboratoire Lab-STICC – CNRS UMR 6285
* Equipe DECIDE
* UNIVERSITÉ DE BRETAGNE-SUD
* Institut Universitaire de Technologie de Vannes
* 8, Rue Montaigne - BP 561 56017 Vannes Cedex
*
* Java Network Analyzer is distributed under LGPL 3 license.
*
* Copyright (C) 2012-2014 CNRS (IRSTV CNRS FR 2488)
* Copyright (C) 2015-2018 CNRS (Lab-STICC CNRS UMR 6285)
*
* Java Network Analyzer is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation, either version 3 of the License, or (at your option) any
* later version.
*
* Java Network Analyzer 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
* Java Network Analyzer. If not, see .
*
* For more information, please consult:
* or contact directly:
* info_at_ orbisgis.org
*/
package org.javanetworkanalyzer.analyzers;
import java.util.Set;
import org.javanetworkanalyzer.alg.DijkstraForAccessibility;
import org.javanetworkanalyzer.data.VAccess;
import org.javanetworkanalyzer.model.EdgeSPT;
import org.jgrapht.DirectedGraph;
import org.jgrapht.Graph;
import org.jgrapht.graph.EdgeReversedGraph;
/**
* Calculates, for each vertex, the (distance to the) closest destination among
* several possible destinations.
*
* @author Adam Gouge
* @param edge
*/
public class AccessibilityAnalyzer extends GeneralizedGraphAnalyzer {
/**
* The set of destinations.
*/
private Set destinations;
/**
* Constructor: sets the graph.
*
* @param graph Graph
* @param destinations
*/
public AccessibilityAnalyzer(Graph graph,
Set destinations) {
super(graph);
this.destinations = destinations;
verifyDestinations();
}
/**
* Performs accessibility analysis.
*/
public void compute() {
// If the graph is directed, then reverse it.
Graph g;
if (graph instanceof DirectedGraph) {
g = new EdgeReversedGraph((DirectedGraph) graph);
} else {
g = graph;
}
// Obtain a Dijkstra algorithm on the reversed graph.
DijkstraForAccessibility dijkstra =
new DijkstraForAccessibility(g);
// Now shortest paths from each destination the reversed graph
// correspond to shortest paths to each destination in the original
// graph.
for (VAccess dest : destinations) {
// Update the distance of each destination to itself.
dest.setClosestDestinationId(dest.getID());
dest.setDistanceToClosestDestination(0.0);
// Calculate all shortest paths from this destination and update
// the closest destination accordingly.
dijkstra.calculate(dest);
}
}
/**
* Makes sure that every requested destination is contained in the graph.
*/
private void verifyDestinations() {
for (VAccess dest : destinations) {
if (!graph.containsVertex(dest)) {
throw new IllegalArgumentException(
"Destination " + dest.getID() + " is not contained "
+ "in the graph.");
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy