// 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 rostam */ @CommandAttitude(name = "generate_cn", abbreviation = "_g_cn", description = "generated a Tadpole") public class TadpoleGenerator implements GraphGeneratorExtension, Parametrizable, SimpleGeneratorInterface { @Parameter(name = "n") public static Integer n = 10; @Parameter(name = "k") public static Integer k = 10; Vertex[] v; GraphModel g; public void setWorkingGraph(GraphModel g) { this.g = g; } public String getName() { return "Tadpole Graph"; } public String getDescription() { return "Genrates a Tadpole"; } @Override public Edge[] getEdges() { Edge[] ret = new Edge[n+k]; for (int i = 0; i < n - 1; i++) { ret[i] = new Edge(v[i], v[i + 1]); } ret[n-1]=new Edge(v[n-1],v[0]); ret[n] = new Edge(v[1],v[n]); for(int i=n+1;i<n+k;i++) { ret[i] = new Edge(v[i-1],v[i]); } return ret; } public Vertex[] getVertices() { Vertex[] ret = new Vertex[n+k]; for (int i = 0; i < n+k; i++) ret[i] = new Vertex(); v = ret; return ret; } public GraphModel generateGraph() { return GraphGenerator.getGraph(false, this); } public Point[] getVertexPositions() { Point[] ret = new Point[n+k]; Point[] circ = PositionGenerators.circle(5, 5, 100, 100, n); System.arraycopy(circ, 0, ret, 0, n); for(int i=n;i<n+k;i++) { ret[i] = new Point(ret[n-1].x+(i-n+1)*60+100,ret[n-1].y); } return ret; } public String checkParameters() { if (n < 0) return "n must be positive"; else return null; } /** * generates a Tadpole Graph with given parameters */ public static GraphModel generateTadpole(int n,int k) { TadpoleGenerator.n = n; TadpoleGenerator.k = k; return GraphGenerator.getGraph(false, new TadpoleGenerator()); } @Override public String getCategory() { return "General Graphs"; } }