1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
/**
* Copyright (c) 2011, 2015 - Lunifera GmbH (Gross Enzersdorf, Austria), Loetz GmbH&Co.KG (69115 Heidelberg, Germany)
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License 2.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Florian Pirchner - Initial implementation
*
*/
package org.eclipse.osbp.xtext.oxtype.linking;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
public class LinkingMetric {
private static final Logger LOGGER = LoggerFactory
.getLogger(LinkingMetric.class);
Map<String, Data> cache = new HashMap<>();
static final LinkingMetric INSTANCE = new LinkingMetric();
public static LinkingMetric getInstance() {
return INSTANCE;
}
private LinkingMetric() {
}
public void addMetric(String key, long timeCreateScope,
long timeExecuteScope) {
Data data = cache.get(key);
if (data == null) {
data = new Data(key);
cache.put(key, data);
}
data.add(timeCreateScope, timeExecuteScope);
}
public void print() {
List<Map.Entry<String, Data>> values = new ArrayList<>(cache.entrySet());
Collections.sort(values, (o1, o2) -> {
return (int) (o2.getValue().timeSum - o1.getValue().timeSum);
});
for (Map.Entry<String, Data> entry : values) {
System.out.println(entry.getValue().toString());
}
}
public void clear() {
cache.clear();
}
static class Data {
final String key;
int count;
long timeCreateScopeSum = 0;
long timeExecuteScopeSum = 0;
long timeSum;
long avgTime;
public Data(String key) {
this.key = key;
}
public void add(long timeCreateScope, long timeExecuteScope) {
this.count++;
this.timeCreateScopeSum += timeCreateScope;
this.timeExecuteScopeSum += timeExecuteScope;
this.timeSum = timeCreateScopeSum + timeExecuteScopeSum;
this.avgTime = timeSum / count;
}
@Override
public String toString() {
return "Data [key=" + key + ", count=" + count
+ ", timeCreateScopeSum=" + timeCreateScopeSum
+ "ms, timeExecuteScopeSum=" + timeExecuteScopeSum
+ "ms , timeSum=" + timeSum + "ms, avgTime=" + avgTime + "ms]";
}
}
}
|