// 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.*;
/**
* @author Mohammad Ali Rostami
* @email mamliam@gmail.com
*/
@CommandAttitude(name = "generate_generalized_peterson", abbreviation = "_g_p", description = "generalized peterson")
public class GeneralizedPetersonGenerator implements GraphGeneratorExtension, Parametrizable, SimpleGeneratorInterface {
private GraphModel g;
@Parameter(name = "n")
public static Integer n = 5;
@Parameter(name = "k")
public static Integer k = 2;
private Vertex[] v;
public String getName() {
return "Generalized Peterson";
}
public String getDescription() {
return "Generalized Peterson";
}
public void setWorkingGraph(GraphModel g) {
this.g = g;
}
public Vertex[] getVertices() {
Vertex[] ret = new Vertex[2 * n];
for (int i = 0; i < 2 * n; i++)
ret[i] = new Vertex();
this.v = ret;
return ret;
}
public Edge[] getEdges() {
Edge[] ret = new Edge[3 * n];
int counter = 0;
for (int i = 0; i < n; i++) {
ret[counter] = new Edge(v[(i % n)], v[((i + 1) % n)]);
counter++;
ret[counter] = new Edge(v[(i % n)], v[((i + n) % (2 * n))]);
counter++;
if (i + n + k > 2 * n - 1)
ret[counter] = new Edge(v[((i + n) % (2 * n))], v[((i + n + k) % (2 * n)) + n]);
else
ret[counter] = new Edge(v[((i + n) % (2 * n))], v[((i + n + k) % (2 * n))]);
counter++;
}
return ret;
}
public Point[] getVertexPositions() {
Point[] p = new Point[2 * n];
Point[] p1 = PositionGenerators.circle(300, 200, 200, n);
Point[] p2 = PositionGenerators.circle(600, 200, 200, n);
for (int i = 0; i < n; i++) {
p[i] = p2[i];
p[i + n] = p1[i];
}
return p;
}
public String checkParameters() {
if (k>0 & n>0 & k > n / 2)
return "K should be smaller than n/2 !";
if ( n<0 || k<0)return " Both k & n must be positive!";
else
return null;
}
public GraphModel generateGraph() {
return GraphGenerator.getGraph(false, this);
}
/**
* generates a Generalized Peterson Graph with given parameters
*/
public static GraphModel generateGeneralizedPeterson(int n, int k) {
GeneralizedPetersonGenerator.n = n;
GeneralizedPetersonGenerator.k = k;
return GraphGenerator.getGraph(false, new GeneralizedPetersonGenerator());
}
@Override
public String getCategory() {
return "General Graphs";
}
}