// GraphTea Project: http://github.com/graphtheorysoftware/GraphTea
// Copyright (C) 2012 Graph Theory Software Foundation: http://GraphTheorySoftware.com
// Copyright (C) 2008 Mathematical Science Department of Sharif University of Technology
// Distributed under the terms of the GNU General Public License (GPL): http://www.gnu.org/licenses/
package graphtea.extensions.reports.zagreb;
import graphtea.graph.graph.Edge;
import graphtea.graph.graph.GraphModel;
import graphtea.platform.lang.CommandAttitude;
import graphtea.platform.parameter.Parameter;
import graphtea.platform.parameter.Parametrizable;
import graphtea.plugins.reports.extension.GraphReportExtension;
import java.util.ArrayList;
/**
* @author Ali Rostami
*/
@CommandAttitude(name = "zagreb_index_edges", abbreviation = "_zie")
public class ZagrebIndexSelectedEdges implements GraphReportExtension, Parametrizable {
public String getName() {
return "Zagreb Indices of Selected Edges";
}
@Parameter(name = "Alpha", description = "")
public Double alpha = 1.0;
public String getDescription() {
return "Zagreb Indices of Selected Edges";
}
public Object calculate(GraphModel g) {
ArrayList<String> out = new ArrayList<>();
ZagrebIndexFunctions zif = new ZagrebIndexFunctions(g);
out.add("First General Zagreb Index : "+ zif.getFirstZagrebSelectedEdges(alpha));
out.add("Second General Zagreb Index : "+ zif.getSecondZagrebSelectedEdges(alpha));
out.add("First Reformulated Zagreb Index : " + zif.getFirstReZagrebSelectedEdges(alpha));
out.add("Second Reformulated Zagreb Index : " + zif.getSecondReZagrebSelectedEdges(alpha));
return out;
}
private boolean edge_adj(Edge e1,Edge e2) {
if(e1.source.getId()==e2.source.getId() &&
e1.target.getId()==e2.target.getId()) return false;
else if(e1.target.getId()==e2.source.getId() &&
e1.source.getId()==e2.target.getId()) return false;
else if(e1.source.getId() == e2.source.getId()) return true;
else if(e1.source.getId() == e2.target.getId()) return true;
else if(e1.target.getId() == e2.source.getId()) return true;
else if(e1.target.getId() == e2.target.getId()) return true;
return false;
}
public String checkParameters() {
return null;
}
@Override
public String getCategory() {
return "Topological Indices-Zagreb Indices";
}
}