source: trunk/EventBenchConsole/src/de/ugoe/cs/eventbench/commands/CMDgenerateRandomSequences.java @ 239

Last change on this file since 239 was 209, checked in by sherbold, 13 years ago
  • greatly improved type checking and consistency of type checking for objects checked out of the GlobalDataContainer?
  • Property svn:mime-type set to text/plain
File size: 2.9 KB
Line 
1package de.ugoe.cs.eventbench.commands;
2
3import java.security.InvalidParameterException;
4import java.util.HashSet;
5import java.util.List;
6import java.util.Set;
7
8import de.ugoe.cs.eventbench.data.GlobalDataContainer;
9import de.ugoe.cs.eventbench.data.Event;
10import de.ugoe.cs.eventbench.models.IStochasticProcess;
11import de.ugoe.cs.util.console.Command;
12import de.ugoe.cs.util.console.Console;
13
14/**
15 * <p>
16 * Command to generate random sessions.
17 * </p>
18 *
19 * @author Steffen Herbold
20 * @version 1.0
21 */
22public class CMDgenerateRandomSequences implements Command {
23
24        /*
25         * (non-Javadoc)
26         *
27         * @see de.ugoe.cs.util.console.Command#run(java.util.List)
28         */
29        @Override
30        public void run(List<Object> parameters) {
31                String modelname;
32                String sequencesName;
33                int numSessions;
34                long maxIter;
35                int minLength = 0;
36                int maxLength = Integer.MAX_VALUE;
37                try {
38                        modelname = (String) parameters.get(0);
39                        sequencesName = (String) parameters.get(1);
40                        numSessions = Integer.parseInt((String) parameters.get(2));
41                        maxIter = numSessions * 10;
42                        if (parameters.size() >= 4) {
43                                maxIter = Long.parseLong((String) parameters.get(3));
44                        }
45                        if (parameters.size() >= 5) {
46                                minLength = Integer.parseInt((String) parameters.get(4));
47                        }
48                        if (parameters.size() >= 6) {
49                                maxLength = Integer.parseInt((String) parameters.get(5));
50                        }
51                } catch (Exception e) {
52                        throw new InvalidParameterException();
53                }
54
55                IStochasticProcess model = null;
56                Object dataObject = GlobalDataContainer.getInstance()
57                                .getData(modelname);
58                if (dataObject == null) {
59                        Console.println("Model " + modelname + " not found in storage.");
60                        return;
61                }
62                if (!(dataObject instanceof IStochasticProcess)) {
63                        Console.println("Object " + modelname + " not of type MarkovModel!");
64                        return;
65                }
66                model = (IStochasticProcess) dataObject;
67                Set<List<? extends Event<?>>> sequences = new HashSet<List<? extends Event<?>>>(
68                                numSessions);
69                long numIterations = 0;
70                while (sequences.size() < numSessions && numIterations < maxIter) {
71                        List<? extends Event<?>> generatedSequence = model.randomSequence();
72                        if (generatedSequence.size() >= minLength
73                                        && generatedSequence.size() <= maxLength) {
74                                sequences.add(generatedSequence);
75                        }
76                        numIterations++;
77                }
78                if (sequences.size() < numSessions) {
79                        Console.println("Only " + sequences.size()
80                                        + " unique sessions generated after " + maxIter
81                                        + " iterations");
82                }
83                if (GlobalDataContainer.getInstance().addData(sequencesName, sequences)) {
84                        Console.traceln("Old data \"" + sequencesName + "\" overwritten");
85                }
86        }
87
88        /*
89         * (non-Javadoc)
90         *
91         * @see de.ugoe.cs.util.console.Command#help()
92         */
93        @Override
94        public void help() {
95                Console.println("Usage: generateRandomSequenecs <modelName> <sequencesName> <numSessions> {<maxIter> <minLength> <maxLength>}");
96        }
97
98}
Note: See TracBrowser for help on using the repository browser.