author | Matti Laitinen <matti.t.laitinen@nokia.com> |
Wed, 21 Apr 2010 20:01:08 +0300 | |
changeset 7 | 8e12a575a9b5 |
permissions | -rw-r--r-- |
7
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
1 |
/* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
2 |
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies). |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
3 |
* All rights reserved. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
4 |
* This component and the accompanying materials are made available |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
5 |
* under the terms of "Eclipse Public License v1.0" |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
6 |
* which accompanies this distribution, and is available |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
7 |
* at the URL "http://www.eclipse.org/legal/epl-v10.html". |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
8 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
9 |
* Initial Contributors: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
10 |
* Nokia Corporation - initial contribution. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
11 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
12 |
* Contributors: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
13 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
14 |
* Description: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
15 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
16 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
17 |
package com.nokia.s60tools.swmtanalyser.analysers; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
18 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
19 |
import java.text.DecimalFormat; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
20 |
import java.util.ArrayList; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
21 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
22 |
import com.nokia.s60tools.swmtanalyser.data.DiskOverview; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
23 |
import com.nokia.s60tools.swmtanalyser.data.KernelElements; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
24 |
import com.nokia.s60tools.swmtanalyser.data.ParsedData; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
25 |
import com.nokia.s60tools.swmtanalyser.data.SystemData; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
26 |
import com.nokia.s60tools.swmtanalyser.model.SWMTLogReaderUtils; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
27 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
28 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
29 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
30 |
* Defines Enum constants for all Kernel events to be analysed. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
31 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
32 |
enum KERNEL_EVENTS{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
33 |
NO_OF_THREADS("Number of Threads"), NO_OF_PROCESSES("Number of Processes"), |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
34 |
NO_OF_TIMERS("Number of Timers"), NO_OF_SEMAPHORES("Number of Semaphores"), |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
35 |
NO_OF_SERVERS("Number of Servers"), NO_OF_MSGQUEUES("Number of Msg. Queues"), |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
36 |
NO_OF_SESSIONS("Number of Sessions"), NO_OF_CHUNKS("Number of Chunks"); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
37 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
38 |
private String event_name; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
39 |
private String event_cateogory = "System Data"; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
40 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
41 |
private KERNEL_EVENTS(String eventName) { |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
42 |
this.event_name = eventName; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
43 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
44 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
45 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
46 |
* Returns event string |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
47 |
* @return name of the event |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
48 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
49 |
public String getEventName() |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
50 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
51 |
return event_name; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
52 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
53 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
54 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
55 |
* Returns event category |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
56 |
* @return category of the event |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
57 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
58 |
public String getEventCategory() |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
59 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
60 |
return event_cateogory; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
61 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
62 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
63 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
64 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
65 |
* Analyses RAM and DISK events and Kernal events. It implements interface IAnalyser. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
66 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
67 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
68 |
public class LinearAnalyser implements IAnalyser { |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
69 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
70 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
71 |
* {@link #RAM_AND_DISK_TITLE} and {@link #KERNEL_ELEMS_TITLE} issues |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
72 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
73 |
ArrayList<ResultsParentNodes> allIssues = new ArrayList<ResultsParentNodes>(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
74 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
75 |
protected static DecimalFormat Bytes_Format = new DecimalFormat("#####.##"); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
76 |
protected int [] time_intervals = null; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
77 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
78 |
private static final String RAM_AND_DISK_TITLE = "RAM and Disk Memory"; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
79 |
private static final String KERNEL_ELEMS_TITLE = "Kernel Elements"; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
80 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
81 |
private ParsedData logData = null; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
82 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
83 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
84 |
/* (non-Javadoc) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
85 |
* @see com.nokia.s60tools.swmtanalyser.analysers.IAnalyser#analyse(com.nokia.s60tools.swmtanalyser.data.ParsedData) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
86 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
87 |
public void analyse(ParsedData logData) { |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
88 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
89 |
this.logData = logData; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
90 |
allIssues.clear(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
91 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
92 |
//List to store RAM DISK issues |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
93 |
ArrayList<ResultElements> ram_disk_issues = new ArrayList<ResultElements>(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
94 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
95 |
//Analyse RAM events using the logData and store the results in given list |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
96 |
analyseUsedRam(logData, ram_disk_issues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
97 |
//Analyse DISK events using the logData and store the results in given list |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
98 |
analyseDiskSizes(logData, ram_disk_issues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
99 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
100 |
//Create parent for all RAM and Disks issues. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
101 |
ResultsParentNodes ram_and_disk_node = new ResultsParentNodes(RAM_AND_DISK_TITLE); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
102 |
ram_and_disk_node.setChildren(ram_disk_issues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
103 |
allIssues.add(ram_and_disk_node); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
104 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
105 |
//List to store Kernel issues |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
106 |
ArrayList<ResultElements> kernel_issues = new ArrayList<ResultElements>(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
107 |
//Analyse Kernel events using the logData and store the results in given list |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
108 |
analyseKernelHandles(logData, kernel_issues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
109 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
110 |
//Create parent for all kernel issues found |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
111 |
ResultsParentNodes kernel_analysis_node = new ResultsParentNodes(KERNEL_ELEMS_TITLE); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
112 |
kernel_analysis_node.setChildren(kernel_issues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
113 |
allIssues.add(kernel_analysis_node); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
114 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
115 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
116 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
117 |
/* (non-Javadoc) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
118 |
* @see com.nokia.s60tools.swmtanalyser.analysers.IAnalyser#getResults() |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
119 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
120 |
public Object[] getResults() { |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
121 |
return allIssues.toArray(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
122 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
123 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
124 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
125 |
/* (non-Javadoc) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
126 |
* @see com.nokia.s60tools.swmtanalyser.analysers.IAnalyser#getChildren(java.lang.Object) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
127 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
128 |
public Object[] getChildren(Object parent) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
129 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
130 |
if(parent instanceof ResultsParentNodes && allIssues.contains(parent)) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
131 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
132 |
return ((ResultsParentNodes)(parent)).getChildren(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
133 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
134 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
135 |
return null; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
136 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
137 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
138 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
139 |
* This method linearly analyses the variation of used Ram size. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
140 |
* @param logData signifies data of all seleced cycles. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
141 |
* @param results signifies the list to which all issues will be added to. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
142 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
143 |
private void analyseUsedRam(ParsedData logData, ArrayList<ResultElements> results) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
144 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
145 |
SWMTLogReaderUtils utils = new SWMTLogReaderUtils(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
146 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
147 |
ArrayList<SystemData> systemData = utils.getSystemDataFromAllCycles(logData); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
148 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
149 |
//Store used memory values |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
150 |
long [] usedRamValues = new long[logData.getNumberOfCycles()]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
151 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
152 |
//Calculate used memory using the total and free memroy |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
153 |
for(int i=0; i<logData.getNumberOfCycles(); i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
154 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
155 |
long totalMem = systemData.get(i).getTotalMemory(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
156 |
long freeMem = systemData.get(i).getFreeMemory(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
157 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
158 |
if(totalMem == -1 || freeMem == -1){ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
159 |
usedRamValues[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
160 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
161 |
else{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
162 |
long usedMemory = totalMem - freeMem; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
163 |
usedRamValues[i] = usedMemory; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
164 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
165 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
166 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
167 |
//Get the delta value. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
168 |
long usedMemChange = utils.calculateDeltaForGivenSet(usedRamValues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
169 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
170 |
ResultElements res_elem = new ResultElements("RAM", "RAM used", getFormattedBytes(usedMemChange), usedMemChange, AnalyserConstants.DeltaType.SIZE); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
171 |
res_elem.setEventValues(usedRamValues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
172 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
173 |
calculateGrowinessAndPriority(usedRamValues, res_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
174 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
175 |
//Add if the element priority is CRITICAL or HIGH or NORMAL |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
176 |
if(res_elem.getPriority() != AnalyserConstants.Priority.NEGLIGIBLE) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
177 |
results.add(res_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
178 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
179 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
180 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
181 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
182 |
* This method linearly analyses the variation of used size for all disks. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
183 |
* @param logData signifies data of all seleced cycles. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
184 |
* @param results signifies the list to which all issues will be added to. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
185 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
186 |
private void analyseDiskSizes(ParsedData logData, ArrayList<ResultElements> results) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
187 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
188 |
SWMTLogReaderUtils utils = new SWMTLogReaderUtils(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
189 |
ArrayList<String> diskNames = utils.getAllDiskNames(logData); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
190 |
for(String disk:diskNames) { |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
191 |
ArrayList<DiskOverview> diskData = utils.getUsedMemoryAndSizesForDisk(disk, logData); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
192 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
193 |
//Store used memory values |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
194 |
long [] diskUsedValues = new long[logData.getNumberOfCycles()]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
195 |
for(int i=0; i<logData.getNumberOfCycles(); i++){ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
196 |
diskUsedValues[i] = diskData.get(i).getUsedSize(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
197 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
198 |
long delta = utils.calculateDeltaForGivenSet(diskUsedValues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
199 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
200 |
ResultElements res_elem = new ResultElements(disk, "Disk used", getFormattedBytes(delta), delta, AnalyserConstants.DeltaType.SIZE); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
201 |
res_elem.setEventValues(diskUsedValues); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
202 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
203 |
calculateGrowinessAndPriority(diskUsedValues, res_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
204 |
//Add if the element priority is CRITICAL or HIGH or NORMAL |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
205 |
if(res_elem.getPriority() != AnalyserConstants.Priority.NEGLIGIBLE) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
206 |
results.add(res_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
207 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
208 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
209 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
210 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
211 |
* This method analyses variation of various kernel handles. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
212 |
* @param logData signifies data of all seleced cycles. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
213 |
* @param results signifies the list to which all issues will be added to. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
214 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
215 |
private void analyseKernelHandles(ParsedData logData, ArrayList<ResultElements> results) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
216 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
217 |
SWMTLogReaderUtils utils = new SWMTLogReaderUtils(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
218 |
ArrayList<KernelElements> kernelElems = utils.getKerenelElemsFromAllCycles(logData); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
219 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
220 |
for(KERNEL_EVENTS event: KERNEL_EVENTS.values()){ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
221 |
long [] event_values = new long[kernelElems.size()]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
222 |
for(int i=0; i<kernelElems.size(); i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
223 |
event_values[i] = getKernelEventValue(kernelElems.get(i),event); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
224 |
long delta = utils.calculateDeltaForGivenSet(event_values); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
225 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
226 |
ResultElements result_elem = new ResultElements(event.getEventName(), event.getEventCategory(), Long.toString(delta), delta, AnalyserConstants.DeltaType.COUNT); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
227 |
result_elem.setEventValues(event_values); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
228 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
229 |
calculateGrowinessAndPriority(event_values,result_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
230 |
//Add if the element priority is CRITICAL or HIGH or NORMAL |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
231 |
if(result_elem.getPriority() != AnalyserConstants.Priority.NEGLIGIBLE) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
232 |
results.add(result_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
233 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
234 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
235 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
236 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
237 |
* |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
238 |
* @param kernelData -- structure which holds info about all kernel handles in one cycle. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
239 |
* @param event -- name of the kernel event whose value must be read from the structure. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
240 |
* @return value of the event. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
241 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
242 |
private long getKernelEventValue(KernelElements kernelData, KERNEL_EVENTS event) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
243 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
244 |
long event_value = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
245 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
246 |
switch(event) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
247 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
248 |
case NO_OF_PROCESSES: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
249 |
event_value = kernelData.getNumberOfProcesses(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
250 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
251 |
case NO_OF_THREADS: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
252 |
event_value = kernelData.getNumberOfThreads(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
253 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
254 |
case NO_OF_CHUNKS: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
255 |
event_value = kernelData.getNumberOfChunks(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
256 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
257 |
case NO_OF_SEMAPHORES: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
258 |
event_value = kernelData.getNumberOfSemaphores(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
259 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
260 |
case NO_OF_SERVERS: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
261 |
event_value = kernelData.getNumberOfServers(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
262 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
263 |
case NO_OF_SESSIONS: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
264 |
event_value = kernelData.getNumberOfSessions(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
265 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
266 |
case NO_OF_TIMERS: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
267 |
event_value = kernelData.getNumberOfTimers(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
268 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
269 |
case NO_OF_MSGQUEUES: |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
270 |
event_value = kernelData.getNumberOfMsgQueues(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
271 |
break; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
272 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
273 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
274 |
return event_value; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
275 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
276 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
277 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
278 |
* The method calculates growiness factor based on given event |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
279 |
* values and given time intervals. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
280 |
* @param values values of the event to be analysed |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
281 |
* @param time time intervals |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
282 |
* @return growiness factor. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
283 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
284 |
private double calculateGrowiness(long [] values, int [] time) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
285 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
286 |
if(values.length != time.length) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
287 |
return 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
288 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
289 |
long [] time_differences = new long[time.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
290 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
291 |
for(int i=0; i<time.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
292 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
293 |
if(i == 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
294 |
time_differences[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
295 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
296 |
time_differences[i] = time[i] - time[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
297 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
298 |
long [] normalizedRoCs = calculateNormalizedRoC(values); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
299 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
300 |
double [] normalizedRocWithTime = new double [normalizedRoCs.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
301 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
302 |
for(int i=0; i<normalizedRocWithTime.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
303 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
304 |
if(i == 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
305 |
normalizedRocWithTime[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
306 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
307 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
308 |
//Assuming time difference is greater than zero. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
309 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
310 |
normalizedRocWithTime[i] = (double)(normalizedRoCs[i])/Math.log(time_differences[i]); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
311 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
312 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
313 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
314 |
double [] overallNormalizedRoc = new double [normalizedRocWithTime.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
315 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
316 |
overallNormalizedRoc[0] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
317 |
double totalNormalizedRoc = 0.0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
318 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
319 |
for(int i=1; i < normalizedRocWithTime.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
320 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
321 |
if(normalizedRocWithTime[i] > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
322 |
overallNormalizedRoc[i] = overallNormalizedRoc[i-1] + normalizedRocWithTime[i]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
323 |
else if(normalizedRocWithTime[i] < 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
324 |
overallNormalizedRoc[i] = -Math.log(-normalizedRocWithTime[i])+ overallNormalizedRoc[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
325 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
326 |
overallNormalizedRoc[i] = overallNormalizedRoc[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
327 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
328 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
329 |
totalNormalizedRoc = overallNormalizedRoc[overallNormalizedRoc.length - 1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
330 |
int growth_index = calculateStableGrowth(values); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
331 |
double growiness_factor = Math.exp(growth_index); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
332 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
333 |
double log_of_first = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
334 |
double log_of_last = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
335 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
336 |
if(values[values.length -1] != 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
337 |
log_of_last = Math.log(values[values.length -1]); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
338 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
339 |
if(values[0] != 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
340 |
log_of_first = Math.log(values[0]); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
341 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
342 |
double log_diff = log_of_last - log_of_first; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
343 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
344 |
double tmp = Math.round(Math.exp(totalNormalizedRoc)); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
345 |
double final_growth_factor = tmp * log_diff + growiness_factor; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
346 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
347 |
return final_growth_factor; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
348 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
349 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
350 |
protected long [] calculateNormalizedRoC(long [] values) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
351 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
352 |
long [] deltas = new long[values.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
353 |
long [] valueVsBaseline = new long[values.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
354 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
355 |
deltas[0] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
356 |
valueVsBaseline[0] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
357 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
358 |
for(int i=1; i<values.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
359 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
360 |
deltas[i] = values[i] - values[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
361 |
valueVsBaseline[i] = values[i] - values[0]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
362 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
363 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
364 |
long [] normalizedRoC = new long[values.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
365 |
normalizedRoC[0] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
366 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
367 |
for(int i=1; i < values.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
368 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
369 |
if(deltas[i] > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
370 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
371 |
if(valueVsBaseline[i] > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
372 |
normalizedRoC[i] = (long)Math.log(deltas[i]); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
373 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
374 |
else if(valueVsBaseline[i] < 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
375 |
normalizedRoC[i] = (long)(Math.log(deltas[i] + valueVsBaseline[i])); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
376 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
377 |
normalizedRoC[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
378 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
379 |
else if(deltas[i] < 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
380 |
normalizedRoC[i] = -(long)Math.log(-deltas[i]); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
381 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
382 |
normalizedRoC[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
383 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
384 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
385 |
return normalizedRoC; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
386 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
387 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
388 |
private int calculateStableGrowth(long [] values) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
389 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
390 |
int [] stableGrowiness = new int[values.length]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
391 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
392 |
for(int i=0; i<stableGrowiness.length; i++) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
393 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
394 |
if(i >0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
395 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
396 |
long diff = values[i] - values[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
397 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
398 |
if(diff > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
399 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
400 |
stableGrowiness[i] = stableGrowiness[i-1] + 1; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
401 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
402 |
else if(diff == 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
403 |
stableGrowiness[i] = stableGrowiness[i-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
404 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
405 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
406 |
if(values[i] > values[0]) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
407 |
stableGrowiness[i] = stableGrowiness[i-1] - 1; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
408 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
409 |
stableGrowiness[i] = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
410 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
411 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
412 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
413 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
414 |
return stableGrowiness[stableGrowiness.length-1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
415 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
416 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
417 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
418 |
* The method calculates priority of an issue, based on the values of |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
419 |
* growiness factor, delta factor and number of Cycles. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
420 |
* @param growing_factor |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
421 |
* @param delta_factor |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
422 |
* @param noOfCycles |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
423 |
* @return priority of the issue. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
424 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
425 |
protected AnalyserConstants.Priority calculatePriorityFactor(double growing_factor, double delta_factor, int noOfCycles) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
426 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
427 |
double high_threshold = Math.exp(noOfCycles - 1); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
428 |
int temp = noOfCycles/2; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
429 |
double normal_threshold = Math.exp(temp); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
430 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
431 |
int temp1 = noOfCycles/4; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
432 |
double low_threshold = Math.exp(temp1); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
433 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
434 |
if(growing_factor > high_threshold) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
435 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
436 |
if(delta_factor > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
437 |
return AnalyserConstants.Priority.CRITICAL; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
438 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
439 |
if(growing_factor > normal_threshold) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
440 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
441 |
if(delta_factor > 0.5) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
442 |
return AnalyserConstants.Priority.CRITICAL; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
443 |
else if(delta_factor > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
444 |
return AnalyserConstants.Priority.HIGH; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
445 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
446 |
if(growing_factor > low_threshold) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
447 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
448 |
if(delta_factor > 3) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
449 |
return AnalyserConstants.Priority.CRITICAL; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
450 |
else if(delta_factor > 0.5) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
451 |
return AnalyserConstants.Priority.HIGH; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
452 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
453 |
if(growing_factor > Math.exp(1)) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
454 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
455 |
if(delta_factor > 5) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
456 |
return AnalyserConstants.Priority.CRITICAL; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
457 |
else if(delta_factor > 3) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
458 |
return AnalyserConstants.Priority.HIGH; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
459 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
460 |
if(growing_factor >0 && delta_factor > 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
461 |
return AnalyserConstants.Priority.NORMAL; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
462 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
463 |
return AnalyserConstants.Priority.NEGLIGIBLE; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
464 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
465 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
466 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
467 |
* The method formats the given value to Bytes, Kilo Bytes and Mega Bytes. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
468 |
* @param bytes -- value to be formatted. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
469 |
* @return formatted string in KB or MB |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
470 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
471 |
protected String getFormattedBytes(long bytes) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
472 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
473 |
String formatted_value = ""; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
474 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
475 |
if (bytes < 1024) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
476 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
477 |
formatted_value += Bytes_Format.format(bytes) + " B"; //$NON-NLS-1$ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
478 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
479 |
else if (bytes <= 500 * 1024) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
480 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
481 |
formatted_value += Bytes_Format.format(bytes / 1024) + " KB"; //$NON-NLS-1$ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
482 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
483 |
else |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
484 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
485 |
formatted_value += Bytes_Format.format(((float) bytes / (1024 * 1024))) + " MB"; //$NON-NLS-1$ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
486 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
487 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
488 |
return formatted_value; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
489 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
490 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
491 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
492 |
* The method calculates Growiness and priority based on given set of values. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
493 |
* As no time intervals are provided, the method treats that the event is alive in all cycles (from first to last). |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
494 |
* @param event_values -- values of the event being analysed. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
495 |
* @param result_elem -- structure to which calculated growiness and priority would be set to. |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
496 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
497 |
protected void calculateGrowinessAndPriority(long [] event_values, ResultElements result_elem) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
498 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
499 |
SWMTLogReaderUtils utils = new SWMTLogReaderUtils(); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
500 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
501 |
if(time_intervals == null) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
502 |
time_intervals = utils.getTimeIntervalsFromLogData(logData); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
503 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
504 |
calculateGrowinessAndPriority(event_values, time_intervals, result_elem); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
505 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
506 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
507 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
508 |
/** |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
509 |
* The method calculates Growiness and priority based on given set of values and given time intervals |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
510 |
* @param event_values |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
511 |
* @param log_intervals |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
512 |
* @param result_elem |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
513 |
*/ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
514 |
protected void calculateGrowinessAndPriority(long [] event_values, int [] log_intervals, ResultElements result_elem) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
515 |
{ |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
516 |
double growiness = calculateGrowiness(event_values, log_intervals); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
517 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
518 |
long firstValue = event_values[0]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
519 |
long lastValue = event_values[event_values.length -1]; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
520 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
521 |
double log_of_first = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
522 |
double log_of_last = 0; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
523 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
524 |
if(firstValue != 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
525 |
log_of_first = Math.log(firstValue); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
526 |
if(lastValue != 0) |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
527 |
log_of_last = Math.log(lastValue); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
528 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
529 |
double prioritization_factor = log_of_last - log_of_first; |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
530 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
531 |
AnalyserConstants.Priority priority = calculatePriorityFactor(growiness, prioritization_factor, log_intervals.length); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
532 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
533 |
result_elem.setGrowingFactor(growiness); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
534 |
result_elem.setPriority(priority); |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
535 |
|
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
536 |
} |
8e12a575a9b5
MemSpy Carbide Extension 1.6.0
Matti Laitinen <matti.t.laitinen@nokia.com>
parents:
diff
changeset
|
537 |
} |