-
Notifications
You must be signed in to change notification settings - Fork 9
/
equiv.rb
128 lines (101 loc) · 2.29 KB
/
equiv.rb
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
# Copyright (c) Microsoft Corporation. All rights reserved.
# Licensed under the MIT License.
require 'set'
info = {}
File.open(ARGV.shift, "r") do |fd|
while line = fd.gets
ary = line.split(/,/)
os = ary[8]
# Get the information we're tracking for this OS
os_info = info[os]
if os_info.nil?
os_info = info[os] = {}
os_info[:metrics] = {}
end
{
2 => :effectiveness,
3 => :exploitability
}.each_pair do |idx, metric|
metric_info = os_info[:metrics][metric]
if metric_info.nil?
metric_info = os_info[:metrics][metric] = {}
metric_info[:classes] = {}
metric_info[:groups] =
{
1.0 => 0,
0.5 => 0,
0.1 => 0,
0.01 => 0,
0.001 => 0,
0.0001 => 0,
0.0 => 0
}
end
value = ary[idx].to_f
metric_info[:classes][value] =
(metric_info[:classes][value] || 0) + 1
metric_info[:groups].keys.sort { |x,y|
y <=> x
}.each do |key|
if value >= key
metric_info[:groups][key] += 1
break
end
end
end
end
end
$stdout.puts "os,metric,value,count,norm,percent"
$stderr.puts "os,metric,value,count,norm,percent"
info.each_pair do |os, os_info|
os_info[:metrics].each_pair do |metric, metric_info|
min = nil
max = nil
tot = 0
metric_info[:classes].each_pair do |klass, count|
if min.nil?
min = count
elsif count < min
min = count
end
if max.nil?
max = count
elsif count > max
max = count
end
tot += count
end
metric_info[:classes].each_pair do |klass, count|
if max == min
norm = 0
else
norm = (count.to_f - min)/(max - min)
end
$stdout.puts "#{os},#{metric},#{klass},#{count},#{norm},#{count.to_f / tot}"
end
min = nil
max = nil
tot = 0
metric_info[:groups].each_pair do |klass, count|
if min.nil?
min = count
elsif count < min
min = count
end
if max.nil?
max = count
elsif count > max
max = count
end
tot += count
end
metric_info[:groups].each_pair do |klass, count|
if max == min
norm = 0
else
norm = (count.to_f - min)/(max - min)
end
$stderr.puts "#{os},#{metric},#{klass},#{count},#{norm},#{count.to_f / tot}"
end
end
end