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

com.salesforce.jgrapht.alg.BiconnectivityInspector Maven / Gradle / Ivy

Go to download

This project contains the apt processor that implements all the checks enumerated in @Verify. It is a self contained, and shaded jar.

There is a newer version: 2.0.7
Show newest version
/*
 * (C) Copyright 2007-2017, by France Telecom and Contributors.
 *
 * JGraphT : a free Java graph-theory library
 *
 * This program and the accompanying materials are dual-licensed under
 * either
 *
 * (a) the terms of the GNU Lesser General Public License version 2.1
 * as published by the Free Software Foundation, or (at your option) any
 * later version.
 *
 * or (per the licensee's choosing)
 *
 * (b) the terms of the Eclipse Public License v1.0 as published by
 * the Eclipse Foundation.
 */
package com.salesforce.jgrapht.alg;

import java.util.*;

import com.salesforce.jgrapht.*;

/**
 * Inspects a graph for the biconnectivity property. See {@link BlockCutpointGraph} for more
 * information. A biconnected graph has only one block (i.e. no cutpoints).
 *
 * @param  the graph vertex type
 * @param  the graph edge type
 *
 * @author Guillaume Boulmier
 * @since July 5, 2007
 */
public class BiconnectivityInspector
{
    private BlockCutpointGraph blockCutpointGraph;

    /**
     * Running time = O(m) where m is the number of edges.
     * 
     * @param graph the input graph
     */
    public BiconnectivityInspector(UndirectedGraph graph)
    {
        super();
        this.blockCutpointGraph = new BlockCutpointGraph<>(graph);
    }

    /**
     * Returns the biconnected vertex-components of the graph.
     * 
     * @return the biconnected vertec-components of the graph
     */
    public Set> getBiconnectedVertexComponents()
    {
        Set> biconnectedVertexComponents = new HashSet<>();
        for (UndirectedGraph subgraph : this.blockCutpointGraph.vertexSet()) {
            if (!subgraph.edgeSet().isEmpty()) {
                biconnectedVertexComponents.add(subgraph.vertexSet());
            }
        }

        return biconnectedVertexComponents;
    }

    /**
     * Returns the biconnected vertex-components containing the vertex. A biconnected
     * vertex-component contains all the vertices in the component. A vertex which is not a cutpoint
     * is contained in exactly one component. A cutpoint is contained is at least 2 components.
     *
     * @param vertex the input vertex
     * @return set of all biconnected vertex-components containing the vertex.
     */
    public Set> getBiconnectedVertexComponents(V vertex)
    {
        Set> vertexComponents = new HashSet<>();
        for (Set vertexComponent : getBiconnectedVertexComponents()) {
            if (vertexComponent.contains(vertex)) {
                vertexComponents.add(vertexComponent);
            }
        }
        return vertexComponents;
    }

    /**
     * Returns the cutpoints of the graph.
     * 
     * @return the cutpoints
     */
    public Set getCutpoints()
    {
        return this.blockCutpointGraph.getCutpoints();
    }

    /**
     * Returns true if the graph is biconnected (no cutpoint), false
     * otherwise.
     * 
     * @return true if the graph is biconnected, false otherwise
     */
    public boolean isBiconnected()
    {
        return this.blockCutpointGraph.vertexSet().size() == 1;
    }
}

// End BiconnectivityInspector.java




© 2015 - 2025 Weber Informatics LLC | Privacy Policy