source: src/main/java/weka/clusterers/forMetisMQI/util/Util.java @ 14

Last change on this file since 14 was 14, checked in by gnappo, 14 years ago

Ulteriori refactoring. Creato il clusterer metisMqi, con opzioni.

File size: 4.6 KB
Line 
1package weka.clusterers.forMetisMQI.util;
2
3import java.awt.Color;
4import java.awt.Dimension;
5import java.awt.Paint;
6import java.util.HashMap;
7import java.util.Iterator;
8import java.util.Map;
9import java.util.Set;
10
11import javax.swing.JFrame;
12
13import org.apache.commons.collections15.Transformer;
14
15import weka.clusterers.forMetisMQI.Random;
16import weka.clusterers.forMetisMQI.graph.Edge;
17import weka.clusterers.forMetisMQI.graph.Node;
18import weka.clusterers.forMetisMQI.graph.UndirectedGraph;
19import edu.uci.ics.jung.algorithms.layout.FRLayout;
20import edu.uci.ics.jung.algorithms.layout.Layout;
21import edu.uci.ics.jung.graph.Graph;
22import edu.uci.ics.jung.visualization.BasicVisualizationServer;
23import edu.uci.ics.jung.visualization.decorators.ToStringLabeller;
24
25public class Util {
26        public static void viewClusters(Graph<Node, Edge> g, Set<Set<Node>> clusters) {
27                Layout<Node, Edge> layout = new FRLayout<Node, Edge>(g);
28                layout.setSize(new Dimension(800, 600)); // sets the initial size of the space
29                // The BasicVisualizationServer<V,E> is parameterized by the edge types
30                BasicVisualizationServer<Node, Edge> vv = new BasicVisualizationServer<Node, Edge>(
31                                layout);
32
33                class VertexPaintTransformer implements Transformer<Node, Paint> {
34                        Set<Set<Node>> clusters = null;
35                        Map<Set<Node>, Color> clustersColor = null;
36
37                        public Set<Node> getCluster(Node node) {
38                                Iterator<Set<Node>> clusterIterator = clusters.iterator();
39                                while (clusterIterator.hasNext()) {
40                                        Set<Node> cluster = clusterIterator.next();
41                                        if (cluster.contains(node))
42                                                return cluster;
43                                }
44                                return null;
45                        }
46
47                        public VertexPaintTransformer(Set<Set<Node>> clusters) {
48                                this.clusters = clusters;
49                                clustersColor = new HashMap<Set<Node>, Color>(clusters.size());
50                                Iterator<Set<Node>> clusterIterator = clusters.iterator();
51                                while (clusterIterator.hasNext()) {
52                                        Set<Node> cluster = clusterIterator.next();
53                                        clustersColor.put(cluster, new Color(Random.instance()
54                                                        .nextInt(256), Random.instance().nextInt(256),
55                                                        Random.instance().nextInt(256)));
56                                }
57                        }
58
59                        public Paint transform(Node i) {
60                                Set<Node> cluster = getCluster(i);
61                                if (cluster == null)
62                                        return Color.RED;
63                                else
64                                        return clustersColor.get(getCluster(i));
65                        }
66                }
67
68                Transformer<Node, Paint> vertexPaint = new VertexPaintTransformer(
69                                clusters);
70                vv.setPreferredSize(new Dimension(800, 600)); // Sets the viewing area
71                                                                                                                // size
72                vv.getRenderContext().setVertexLabelTransformer(
73                                new ToStringLabeller<Node>());
74                vv.getRenderContext().setEdgeLabelTransformer(
75                                new ToStringLabeller<Edge>());
76                vv.getRenderContext().setVertexFillPaintTransformer(vertexPaint);
77                JFrame frame = new JFrame("Graph View");
78                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
79                frame.getContentPane().add(vv);
80                frame.pack();
81                frame.setVisible(true);
82        }
83       
84        public static void viewGraph(Graph<Node, Edge> g){
85                Layout<Node, Edge> layout = new FRLayout<Node, Edge>(g);
86                layout.setSize(new Dimension(800,600)); // sets the initial size of the space
87                // The BasicVisualizationServer<V,E> is parameterized by the edge types
88                BasicVisualizationServer<Node,Edge> vv =
89                new BasicVisualizationServer<Node,Edge>(layout);
90                vv.setPreferredSize(new Dimension(800,600)); //Sets the viewing area size
91                vv.getRenderContext().setVertexLabelTransformer(new ToStringLabeller<Node>());
92                vv.getRenderContext().setEdgeLabelTransformer(new ToStringLabeller<Edge>());
93
94                JFrame frame = new JFrame("Simple Graph View");
95                frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
96                frame.getContentPane().add(vv);
97                frame.pack();
98                frame.setVisible(true);
99        }
100       
101        /**
102         * Generates a small graph with 100 nodes and two big components.
103         * For testing purpose.
104         * @return the generated graph
105         */
106        public UndirectedGraph generateGraph(){
107                UndirectedGraph g = new UndirectedGraph();
108                for (int i = 0; i < 50; i++) {
109                        g.addVertex(new Node(Integer.toString(i)));
110                }
111                for (int j = 0; j < 120; j++) {
112                        g.addEdge(new Edge(Integer.toString(j), 1, 1), new Node(Integer
113                                        .toString(Random.instance().nextInt(50))), new Node(Integer
114                                        .toString(Random.instance().nextInt(50))));
115                }
116                for (int i = 50; i < 100; i++) {
117                        g.addVertex(new Node(Integer.toString(i)));
118                }
119                for (int j = 120; j < 240; j++) {
120                        g.addEdge(new Edge(Integer.toString(j), 1, 1), new Node(Integer
121                                        .toString(50 + Random.instance().nextInt(50))), new Node(
122                                        Integer.toString(50 + Random.instance().nextInt(50))));
123                }
124                for (int j = 240; j < 250; j++) {
125                        g.addEdge(new Edge(Integer.toString(j), 1, 1), new Node(Integer
126                                        .toString(50 + Random.instance().nextInt(50))), new Node(
127                                        Integer.toString(Random.instance().nextInt(50))));
128                }
129                return g;
130        }
131}
Note: See TracBrowser for help on using the repository browser.