source: trunk/autoquest-core-tasktrees/src/main/java/de/ugoe/cs/autoquest/tasktrees/temporalrelation/TaskInstanceTrie.java @ 1267

Last change on this file since 1267 was 1267, checked in by pharms, 11 years ago
  • removed find bugs warnings
File size: 6.4 KB
Line 
1//   Copyright 2012 Georg-August-Universität Göttingen, Germany
2//
3//   Licensed under the Apache License, Version 2.0 (the "License");
4//   you may not use this file except in compliance with the License.
5//   You may obtain a copy of the License at
6//
7//       http://www.apache.org/licenses/LICENSE-2.0
8//
9//   Unless required by applicable law or agreed to in writing, software
10//   distributed under the License is distributed on an "AS IS" BASIS,
11//   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//   See the License for the specific language governing permissions and
13//   limitations under the License.
14
15package de.ugoe.cs.autoquest.tasktrees.temporalrelation;
16
17import java.util.HashMap;
18import java.util.LinkedList;
19import java.util.List;
20import java.util.Map;
21
22import de.ugoe.cs.autoquest.tasktrees.treeifc.ITaskInstance;
23import de.ugoe.cs.autoquest.tasktrees.treeifc.IUserSession;
24import de.ugoe.cs.autoquest.usageprofiles.SymbolMap;
25import de.ugoe.cs.autoquest.usageprofiles.Trie;
26import de.ugoe.cs.autoquest.usageprofiles.TrieProcessor;
27
28/**
29 * <p>
30 * TODO comment
31 * </p>
32 *
33 * @author Patrick Harms
34 */
35public class TaskInstanceTrie extends Trie<ITaskInstance> {
36
37    /**  */
38    private static final long serialVersionUID = 1L;
39
40    /**
41     * <p>
42     * the task comparator to be used for comparing tasks
43     * </p>
44     */
45    private TaskComparator comparator;
46
47    /**
48     * <p>
49     * TODO: comment
50     * </p>
51     *
52     * @param taskComparator2
53     */
54    public TaskInstanceTrie(TaskComparator taskComparator) {
55        super(taskComparator);
56        this.comparator = taskComparator;
57    }
58
59    /**
60     *
61     */
62    public void trainSessions(List<IUserSession> userSessions, int maxOrder) {
63        if (maxOrder < 1) {
64            return;
65        }
66       
67        SymbolMap<ITaskInstance, List<ITaskInstance>> equalTaskInstancesMap =
68            new SymbolMap<ITaskInstance, List<ITaskInstance>>(comparator);
69       
70        Map<ITaskInstance, List<ITaskInstance>> taskInstancesMap =
71            new HashMap<ITaskInstance, List<ITaskInstance>>();
72       
73        System.out.println("preparing training");
74        for (IUserSession session : userSessions) {
75            for (ITaskInstance taskInstance : session) {
76                List<ITaskInstance> equalTaskInstances =
77                    equalTaskInstancesMap.getValue(taskInstance);
78               
79                if (equalTaskInstances == null) {
80                    equalTaskInstances = new LinkedList<ITaskInstance>();
81                    equalTaskInstancesMap.addSymbol(taskInstance, equalTaskInstances);
82                }
83               
84                equalTaskInstances.add(taskInstance);
85                taskInstancesMap.put(taskInstance, equalTaskInstances);
86            }
87        }
88       
89        System.out.println("performing training");
90        for (IUserSession session : userSessions) {
91            train(session, maxOrder, taskInstancesMap);
92        }     
93       
94        updateKnownSymbols();
95    }
96   
97    /* (non-Javadoc)
98     * @see de.ugoe.cs.autoquest.usageprofiles.Trie#equals(java.lang.Object)
99     */
100    @Override
101    public boolean equals(Object other) {
102        if (this == other) {
103            return true;
104        }
105        else if (other instanceof TaskInstanceTrie) {
106            return super.equals(other);
107        }
108        else {
109            return false;
110        }
111    }
112
113    /**
114     *
115     */
116    private void train(IUserSession                            userSession,
117                       int                                     maxOrder,
118                       Map<ITaskInstance, List<ITaskInstance>> taskInstancesMap)
119    {
120        List<ITaskInstance> executedTasks = userSession.getExecutedTasks();
121       
122        List<ITaskInstance> subsequence = new LinkedList<ITaskInstance>();
123       
124        int numberOfTrainedSubsequences = 0;
125        int sequenceMaxCount = 0;
126       
127        for (ITaskInstance currentTaskInstance : executedTasks) {
128            int occurrenceCount = taskInstancesMap.get(currentTaskInstance).size();
129           
130            if ((numberOfTrainedSubsequences % 10) == 0) {
131                sequenceMaxCount = getCurrentSequenceMaxCount();
132            }
133           
134            if (occurrenceCount < sequenceMaxCount) {
135                // this task instance does not need to be considered, as it occurs not often enough
136                // to be part of a sequence, that occurs most often. Therefore train all remaining
137                // sequences so far and go on, until the next useful sequence is found.
138               
139                while (subsequence.size() > 1) {
140                    add(subsequence);
141                    subsequence.remove(0);
142                }
143               
144                subsequence.clear();
145            }
146            else {
147                subsequence.add(currentTaskInstance);
148
149                if (subsequence.size() == maxOrder) {
150                    add(subsequence);
151                    subsequence.remove(0);
152
153                    numberOfTrainedSubsequences++;
154                }
155            }
156        }
157       
158        // add shorter remaining subsequences, if any
159        while (subsequence.size() > 1) {
160            add(subsequence);
161            subsequence.remove(0);
162        }
163    }
164
165    /**
166     * <p>
167     * TODO: comment
168     * </p>
169     *
170     * @return
171     */
172    private int getCurrentSequenceMaxCount() {
173        MaxSequenceCountFinder processor = new MaxSequenceCountFinder();
174        super.process(processor);
175        return processor.getMaxCount();
176    }
177
178    /**
179     * @author Patrick Harms
180     */
181    private static class MaxSequenceCountFinder implements TrieProcessor<ITaskInstance> {
182       
183        /**
184         *
185         */
186        private int currentCount = 0;
187       
188        /* (non-Javadoc)
189         * @see de.ugoe.cs.autoquest.usageprofiles.TrieProcessor#process(java.util.List, int)
190         */
191        @Override
192        public TrieProcessor.Result process(List<ITaskInstance> foundTask, int count) {
193            if (foundTask.size() == 2) {
194                this.currentCount = Math.max(this.currentCount, count);
195               
196                // do not consider children
197                return TrieProcessor.Result.SKIP_NODE;
198            }
199            else {
200                return TrieProcessor.Result.CONTINUE;
201            }
202        }
203
204        /**
205         *
206         */
207        private int getMaxCount() {
208            return currentCount;
209        }
210
211    }
212   
213}
Note: See TracBrowser for help on using the repository browser.