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

org.javanetworkanalyzer.model.Edge Maven / Gradle / Ivy

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.model;

import org.jgrapht.WeightedGraph;
import org.jgrapht.graph.DefaultWeightedEdge;

/**
 * Weighted edge for use in {@link TraversalGraph}.
 *
 * @author Adam Gouge
 * @param 
 */
public class Edge extends DefaultWeightedEdge
        implements EdgeSPT, EdgeID {

    private double weight = WeightedGraph.DEFAULT_EDGE_WEIGHT;
    private E baseGraphEdge;
    private int id;
    private boolean setID = false;
    private double descriptor;

    /**
     * Sets the weight of this edge.
     * @param newWeight
     * @return 
     */
    public Edge setWeight(double newWeight) {
        weight = newWeight;
        return this;
    }

    @Override
    protected double getWeight() {
        return weight;
    }
    
    public double getDescriptor(){
        return descriptor;
    }

    public void setDescriptor(double descriptor) {
        this.descriptor = descriptor;
    }    
    

    @Override
    public E getBaseGraphEdge() {
        return baseGraphEdge;
    }

    @Override
    public void setBaseGraphEdge(E edgeCent) {
        baseGraphEdge = edgeCent;
    }

    @Override
    public int getID() {
        return id;
    }

    @Override
    public void setID(int id) {
        if (!setID) {
            this.id = id;
            setID = true;
        } else {
            throw new IllegalStateException("Cannot set the edge id more than once.");
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy