source: trunk/quest-ui-core/src/main/java/de/ugoe/cs/quest/commands/usage/CMDshowMarkovModel.java @ 766

Last change on this file since 766 was 766, checked in by sherbold, 12 years ago
File size: 3.3 KB
Line 
1package de.ugoe.cs.quest.commands.usage;
2
3import java.awt.Dimension;
4import java.awt.Rectangle;
5import java.awt.Shape;
6import java.util.List;
7
8import javax.swing.JFrame;
9
10import org.apache.commons.collections15.Transformer;
11
12import de.ugoe.cs.quest.CommandHelpers;
13import de.ugoe.cs.quest.usageprofiles.FirstOrderMarkovModel;
14import de.ugoe.cs.quest.usageprofiles.FirstOrderMarkovModel.MarkovEdge;
15import de.ugoe.cs.util.console.Command;
16import de.ugoe.cs.util.console.GlobalDataContainer;
17import edu.uci.ics.jung.algorithms.layout.ISOMLayout;
18import edu.uci.ics.jung.algorithms.layout.Layout;
19import edu.uci.ics.jung.graph.Graph;
20import edu.uci.ics.jung.visualization.BasicVisualizationServer;
21import edu.uci.ics.jung.visualization.decorators.ToStringLabeller;
22import edu.uci.ics.jung.visualization.renderers.Renderer.VertexLabel.Position;
23
24/**
25 * <p>
26 * Command that visualizes first-order Markov models.
27 * </p>
28 *
29 * @author Steffen Herbold
30 * @version 1.0
31 */
32public class CMDshowMarkovModel implements Command {
33
34        /*
35         * (non-Javadoc)
36         *
37         * @see de.ugoe.cs.util.console.Command#help()
38         */
39        @Override
40        public String help() {
41                return "showMarkovModel <modelname> {<showNodeNames>}";
42        }
43
44        /*
45         * (non-Javadoc)
46         *
47         * @see de.ugoe.cs.util.console.Command#run(java.util.List)
48         */
49        @Override
50        public void run(List<Object> parameters) {
51                String modelname;
52                boolean showNodeNames = false;
53                try {
54                        modelname = (String) parameters.get(0);
55                        if (parameters.size() == 2) {
56                                showNodeNames = Boolean
57                                                .parseBoolean((String) parameters.get(1));
58                        }
59                } catch (Exception e) {
60                        throw new IllegalArgumentException();
61                }
62
63                Object dataObject = GlobalDataContainer.getInstance()
64                                .getData(modelname);
65                if (dataObject == null) {
66                        CommandHelpers.objectNotFoundMessage(modelname);
67                        return;
68                }
69                if (!(dataObject instanceof FirstOrderMarkovModel)) {
70                        CommandHelpers.objectNotType(modelname, "FirstOrderMarkovModel");
71                        return;
72                }
73                FirstOrderMarkovModel mm = (FirstOrderMarkovModel) dataObject;
74
75                Graph<String, MarkovEdge> graph = mm.getGraph();
76                Layout<String, MarkovEdge> layout = new ISOMLayout<String, MarkovEdge>(
77                                graph);
78                layout.setSize(new Dimension(1000, 800)); // sets the initial size
79                                                                                                        // of the space
80                // The BasicVisualizationServer<V,E> is parameterized by the edge
81                // types
82                BasicVisualizationServer<String, MarkovEdge> vv = new BasicVisualizationServer<String, MarkovEdge>(
83                                layout);
84                vv.setPreferredSize(new Dimension(1100, 850)); // Sets the viewing
85                                                                                                                // area size
86
87                if (showNodeNames) {
88                        final Rectangle rect = new Rectangle(240, 20);
89
90                        Transformer<String, Shape> vertexShapeTransformer = new Transformer<String, Shape>() {
91                                public Shape transform(String s) {
92                                        return rect;
93                                }
94                        };
95                        vv.getRenderer().getVertexLabelRenderer()
96                                        .setPosition(Position.CNTR);
97                        vv.getRenderContext().setVertexShapeTransformer(
98                                        vertexShapeTransformer);
99                        vv.getRenderContext().setVertexLabelTransformer(
100                                        new ToStringLabeller<String>());
101                }
102
103                vv.getRenderContext().setEdgeLabelTransformer(
104                                new ToStringLabeller<MarkovEdge>());
105
106                JFrame frame = new JFrame("Markov Model");
107                frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
108                frame.getContentPane().add(vv);
109                frame.pack();
110                frame.setVisible(true);
111        }
112}
Note: See TracBrowser for help on using the repository browser.