// 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_coindex", abbreviation = "_zci") public class ZagrebCoindex implements GraphReportExtension, Parametrizable { public String getName() { return "All Zagreb Coindices"; } @Parameter(name = "Alpha", description = "") public Double alpha = 1.0; public String getDescription() { return "All Zagreb Coindices"; } public Object calculate(GraphModel g) { ArrayList<String> out = new ArrayList<>(); ZagrebIndexFunctions zif = new ZagrebIndexFunctions(g); out.add("First Zagreb Coindex : "+ zif.getFirstZagrebCoindex(alpha)); out.add("Second Zagreb Coindex : "+ zif.getSecondZagrebCoindex(alpha)); out.add("First Zagreb Reformulated Coindex : " + zif.getFirstReZagrebCoindex(alpha)); out.add("Second Zagreb Reformulated Coindex : " + zif.getSecondReZagrebCoindex(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"; } }