// 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.generators;
import graphtea.graph.graph.Edge;
import graphtea.graph.graph.GraphModel;
import graphtea.graph.graph.Vertex;
import graphtea.platform.lang.CommandAttitude;
import graphtea.platform.parameter.Parameter;
import graphtea.platform.parameter.Parametrizable;
import graphtea.plugins.graphgenerator.GraphGenerator;
import graphtea.plugins.graphgenerator.core.PositionGenerators;
import graphtea.plugins.graphgenerator.core.SimpleGeneratorInterface;
import graphtea.plugins.graphgenerator.core.extension.GraphGeneratorExtension;
import java.awt.*;
import java.util.Vector;
/**
*
*/
@CommandAttitude(name = "generate_knd", abbreviation = "_g_knd")
public class KenserGraphGenerator implements GraphGeneratorExtension, Parametrizable, SimpleGeneratorInterface {
@Parameter(name = "D")
public static Integer d = 3;
@Parameter(name = "N")
public static Integer n = 4;
GraphModel g;
public void setWorkingGraph(GraphModel g) {
this.g = g;
}
Vertex[] v;
public Vertex[] getVertices() {
Vertex[] ret = new Vertex[n];
for (int i = 0; i < n; i++)
ret[i] = new Vertex();
v = ret;
return ret;
}
public Edge[] getEdges() {
Vector<Edge> ret = new Vector<>();
for (int i = 0; i < n; i++) {
for (int j = i; j < (Math.min(n, i + d)); j++) {
ret.add(new Edge(v[i], v[j]));
}
}
Edge[] ret1 = new Edge[ret.size()];
for (int i = 0; i < ret.size(); i++) {
ret1[i] = ret.get(i);
}
return ret1;
}
public Point[] getVertexPositions() {
return PositionGenerators.circle(5, 5, 100, 100, n);
}
public String getName() {
return "K(n/d)";
}
public String getDescription() {
return "Generate K(n/d)";
}
public String checkParameters() {
if( d<0 || n<0)return "Both N & D must be positive!";
if(d>0 & n>0 & d>n)return " D must be smaller than N!";
else
return null;
}
public GraphModel generateGraph() {
return GraphGenerator.getGraph(false, this);
}
/**
* generates a kenser Graph with given parameters
*/
public static GraphModel generateKenserGraph(int n, int d) {
KenserGraphGenerator.n = n;
KenserGraphGenerator.d = d;
return GraphGenerator.getGraph(false, new KenserGraphGenerator());
}
@Override
public String getCategory() {
return "General Graphs";
}
}