trace_visualization 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (38) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +17 -0
  3. data/Gemfile +6 -0
  4. data/LICENSE +339 -0
  5. data/LICENSE.txt +22 -0
  6. data/README.md +4 -0
  7. data/Rakefile +1 -0
  8. data/lib/trace_visualization/bwt.rb +32 -0
  9. data/lib/trace_visualization/bwt.rbold +32 -0
  10. data/lib/trace_visualization/data/irepetition.rb +49 -0
  11. data/lib/trace_visualization/data/repetition.rb +101 -0
  12. data/lib/trace_visualization/generators.rb +53 -0
  13. data/lib/trace_visualization/longest_common_prefix.rb +34 -0
  14. data/lib/trace_visualization/mapping.rb +120 -0
  15. data/lib/trace_visualization/reorder.rb +25 -0
  16. data/lib/trace_visualization/repetitions.rb +66 -0
  17. data/lib/trace_visualization/repetitions_concatenation.rb +134 -0
  18. data/lib/trace_visualization/repetitions_context.rb +18 -0
  19. data/lib/trace_visualization/repetitions_incrementation.rb +81 -0
  20. data/lib/trace_visualization/repetitions_psy.rb +83 -0
  21. data/lib/trace_visualization/suffix_array.rb +203 -0
  22. data/lib/trace_visualization/utils.rb +47 -0
  23. data/lib/trace_visualization/version.rb +3 -0
  24. data/lib/trace_visualization/visualization/console_color_print.rb +32 -0
  25. data/lib/trace_visualization.rb +10 -0
  26. data/spec/bwt_spec.rb +47 -0
  27. data/spec/generators_spec.rb +30 -0
  28. data/spec/longest_common_prefix_spec.rb +29 -0
  29. data/spec/mapping_spec.rb +67 -0
  30. data/spec/reorder_spec.rb +42 -0
  31. data/spec/repetitions_concatenation_spec.rb +58 -0
  32. data/spec/repetitions_incrementation_spec.rb +88 -0
  33. data/spec/repetitions_psy_spec.rb +39 -0
  34. data/spec/repetitions_spec.rb +18 -0
  35. data/spec/spec_helper.rb +19 -0
  36. data/spec/suffix_array_spec.rb +68 -0
  37. data/trace_visualization.gemspec +35 -0
  38. metadata +204 -0
@@ -0,0 +1,39 @@
1
+ require 'trace_visualization'
2
+ require 'trace_visualization/repetitions_psy'
3
+ require 'trace_visualization/suffix_array'
4
+ require 'trace_visualization/longest_common_prefix'
5
+ require 'trace_visualization/bwt'
6
+ require 'trace_visualization/mapping'
7
+
8
+ describe TraceVisualization::Repetitions do
9
+ it 'simple test PSY1' do
10
+ TraceVisualization::Repetitions.psy1("aaabbbcccaaacccbbb", 3, false).should eq [
11
+ {:lcp=>3, :i=>0, :j=>1},
12
+ {:lcp=>3, :i=>8, :j=>9},
13
+ {:lcp=>3, :i=>16, :j=>17}
14
+ ]
15
+ end
16
+
17
+ it 'simple test PSY1 with mapping' do
18
+ str = "aaa[123]aaa"
19
+ arr = TraceVisualization::Mapping.parse(str)
20
+
21
+ TraceVisualization::Repetitions.psy1(arr, 3, false).should eq [{:lcp=>3, :i=>2, :j=>3}]
22
+ end
23
+
24
+ it 'test decode PSY1' do
25
+ str = "aaa[123]xyz[654]aaa[123]" # <---> "aaaXxyzYaaaX"
26
+ arr = TraceVisualization::Mapping.parse(str)
27
+
28
+ rs = TraceVisualization::Repetitions.psy1(arr, 3)
29
+
30
+ rs.size.should eq 1
31
+ rs[0].length.should eq 4
32
+ rs[0].left_positions.should eq [0, 8]
33
+
34
+ length = rs[0].length
35
+ position = rs[0].left_positions[0]
36
+
37
+ TraceVisualization::Mapping.restore(arr[position ... position + length]).should eq "aaa[123]"
38
+ end
39
+ end
@@ -0,0 +1,18 @@
1
+ require 'trace_visualization/repetitions'
2
+ require 'trace_visualization/generators'
3
+
4
+ describe TraceVisualization::Repetitions do
5
+ context 'naive implementation' do
6
+ it 'strict repetitions for fibonacci string f6' do
7
+ f6 = TraceVisualization::Generators::Fibonacci.str(6)
8
+
9
+ TraceVisualization::Repetitions.naive(f6, 1).should eq([[1, 3, 4, 6, 8, 9, 11, 12], [2, 5, 7, 10, 13]])
10
+ TraceVisualization::Repetitions.naive(f6, 2).should eq([[1, 4, 6, 9, 12], [2, 5, 7, 10], [3, 8, 11]])
11
+ TraceVisualization::Repetitions.naive(f6, 3).should eq([[1, 4, 6, 9], [2, 7, 10], [3, 8, 11]])
12
+ TraceVisualization::Repetitions.naive(f6, 4).should eq([[1, 6, 9], [2, 7, 10], [3, 8]])
13
+ TraceVisualization::Repetitions.naive(f6, 5).should eq([[1, 6, 9], [2, 7]])
14
+ TraceVisualization::Repetitions.naive(f6, 6).should eq([[1, 6]])
15
+ TraceVisualization::Repetitions.naive(f6, 7).should eq([])
16
+ end
17
+ end
18
+ end
@@ -0,0 +1,19 @@
1
+ # This file was generated by the `rspec --init` command. Conventionally, all
2
+ # specs live under a `spec` directory, which RSpec adds to the `$LOAD_PATH`.
3
+ # Require this file using `require "spec_helper"` to ensure that it is only
4
+ # loaded once.
5
+ #
6
+ # See http://rubydoc.info/gems/rspec-core/RSpec/Core/Configuration
7
+ RSpec.configure do |config|
8
+ config.treat_symbols_as_metadata_keys_with_true_values = true
9
+ config.run_all_when_everything_filtered = true
10
+ config.filter_run :focus
11
+
12
+ # Run specs in random order to surface order dependencies. If you find an
13
+ # order dependency and want to debug it, you can fix the order by providing
14
+ # the seed, which is printed after each run.
15
+ # --seed 1234
16
+ config.order = 'random'
17
+
18
+ config.mock_with :rr
19
+ end
@@ -0,0 +1,68 @@
1
+ require 'trace_visualization/suffix_array'
2
+ require 'trace_visualization/mapping'
3
+
4
+ describe TraceVisualization::SuffixArray do
5
+
6
+ context ".naive" do
7
+ it "should return suffix array" do
8
+ TraceVisualization::SuffixArray.naive("abaabaab").should eq([5, 2, 6, 3, 0, 7, 4, 1])
9
+ TraceVisualization::SuffixArray.naive("abracadabra").should eq([10, 7, 0, 3, 5, 8, 1, 4, 6, 9, 2])
10
+ end
11
+
12
+ it "should correct process mapped string" do
13
+ str = "abc[123]def[456]ghi"
14
+ arr = TraceVisualization::Mapping.parse(str)
15
+
16
+ TraceVisualization::SuffixArray.naive(arr).should eq([0, 1, 2, 4, 5, 6, 8, 9, 10, 3, 7])
17
+ end
18
+ end
19
+
20
+ context ".radix_pass" do
21
+ it "do stable radix sort" do
22
+ str = [3, 3, 2, 1, 5, 5, 4]
23
+ a = [0, 1, 2, 3, 4, 5, 6]
24
+ n = a.length
25
+ b = Array.new(n)
26
+
27
+ TraceVisualization::SuffixArray.radix_pass(a, b, str, n, 10)
28
+
29
+ b.should eq([3, 2, 0, 1, 6, 4, 5])
30
+ end
31
+ end
32
+
33
+ context ".effective_linear" do
34
+ it "should return suffix array for linear time (native function)" do
35
+ s = [3, 3, 2, 1, 5, 5, 4, 0, 0, 0]
36
+ n = s.length - 3 # exclude last 3 zeros
37
+ alphabet_size = 10
38
+ suffix_array = Array.new(n + 3, 0)
39
+
40
+ TraceVisualization::SuffixArray.effective_linear(s, suffix_array, n, alphabet_size)
41
+
42
+ suffix_array.should eq([3, 2, 1, 0, 6, 5, 4, 0, 0, 0])
43
+ end
44
+ end
45
+
46
+ context ".effective" do
47
+ it "should return suffix array for linear time (wrapper function)" do
48
+ TraceVisualization::SuffixArray.effective("abaabaab").should eq(TraceVisualization::SuffixArray.naive("abaabaab"))
49
+ TraceVisualization::SuffixArray.effective("abracadabra").should eq(TraceVisualization::SuffixArray.naive("abracadabra"))
50
+ end
51
+
52
+ it "should correct process mapped string" do
53
+ str = "abc[123]def[456]ghi"
54
+ arr = TraceVisualization::Mapping.parse(str)
55
+
56
+ TraceVisualization::SuffixArray.effective(arr).should eq([0, 1, 2, 4, 5, 6, 8, 9, 10, 3, 7])
57
+ end
58
+
59
+ it "bug with endless loop" do
60
+ str = "127.0.0.1 user login\r\n127.0.0.1 user logout"
61
+ arr = TraceVisualization::Mapping.parse(str)
62
+
63
+ sa = TraceVisualization::SuffixArray.effective(arr)
64
+ end
65
+
66
+ end
67
+
68
+ end
@@ -0,0 +1,35 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'trace_visualization/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "trace_visualization"
8
+ spec.version = TraceVisualization::VERSION
9
+ spec.authors = ["Sergey"]
10
+ spec.email = ["mastedm@gmail.com"]
11
+ spec.description = %q{
12
+ Intelligent visualization of software traces
13
+ }
14
+ spec.summary = %q{
15
+ Software for smart trace visualization
16
+ }
17
+ spec.homepage = ""
18
+ spec.license = "MIT"
19
+
20
+ spec.files = `git ls-files`.split($/)
21
+ spec.executables = spec.files.grep(%r{^bin/}) { |f| File.basename(f) }
22
+ spec.test_files = spec.files.grep(%r{^(test|spec|features)/})
23
+ spec.require_paths = ["lib"]
24
+
25
+ spec.add_development_dependency "bundler", "~> 1.3"
26
+ spec.add_development_dependency "rake"
27
+
28
+ spec.add_development_dependency "redcarpet", "~> 1.17"
29
+ spec.add_development_dependency "yard", "~> 0.7.5"
30
+
31
+ spec.add_development_dependency "rspec-core", "~> 2.0"
32
+ spec.add_development_dependency "rspec-expectations", "~> 2.0"
33
+ spec.add_development_dependency "rspec-mocks"
34
+ spec.add_development_dependency "rr", "~> 1.0"
35
+ end
metadata ADDED
@@ -0,0 +1,204 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: trace_visualization
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Sergey
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2013-08-04 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ~>
18
+ - !ruby/object:Gem::Version
19
+ version: '1.3'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ~>
25
+ - !ruby/object:Gem::Version
26
+ version: '1.3'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - '>='
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - '>='
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: redcarpet
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ~>
46
+ - !ruby/object:Gem::Version
47
+ version: '1.17'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ~>
53
+ - !ruby/object:Gem::Version
54
+ version: '1.17'
55
+ - !ruby/object:Gem::Dependency
56
+ name: yard
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ~>
60
+ - !ruby/object:Gem::Version
61
+ version: 0.7.5
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ~>
67
+ - !ruby/object:Gem::Version
68
+ version: 0.7.5
69
+ - !ruby/object:Gem::Dependency
70
+ name: rspec-core
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ~>
74
+ - !ruby/object:Gem::Version
75
+ version: '2.0'
76
+ type: :development
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ~>
81
+ - !ruby/object:Gem::Version
82
+ version: '2.0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: rspec-expectations
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ~>
88
+ - !ruby/object:Gem::Version
89
+ version: '2.0'
90
+ type: :development
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ~>
95
+ - !ruby/object:Gem::Version
96
+ version: '2.0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: rspec-mocks
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - '>='
102
+ - !ruby/object:Gem::Version
103
+ version: '0'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - '>='
109
+ - !ruby/object:Gem::Version
110
+ version: '0'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rr
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - ~>
116
+ - !ruby/object:Gem::Version
117
+ version: '1.0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - ~>
123
+ - !ruby/object:Gem::Version
124
+ version: '1.0'
125
+ description: "\n Intelligent visualization of software traces \n "
126
+ email:
127
+ - mastedm@gmail.com
128
+ executables: []
129
+ extensions: []
130
+ extra_rdoc_files: []
131
+ files:
132
+ - .gitignore
133
+ - Gemfile
134
+ - LICENSE
135
+ - LICENSE.txt
136
+ - README.md
137
+ - Rakefile
138
+ - lib/trace_visualization.rb
139
+ - lib/trace_visualization/bwt.rb
140
+ - lib/trace_visualization/bwt.rbold
141
+ - lib/trace_visualization/data/irepetition.rb
142
+ - lib/trace_visualization/data/repetition.rb
143
+ - lib/trace_visualization/generators.rb
144
+ - lib/trace_visualization/longest_common_prefix.rb
145
+ - lib/trace_visualization/mapping.rb
146
+ - lib/trace_visualization/reorder.rb
147
+ - lib/trace_visualization/repetitions.rb
148
+ - lib/trace_visualization/repetitions_concatenation.rb
149
+ - lib/trace_visualization/repetitions_context.rb
150
+ - lib/trace_visualization/repetitions_incrementation.rb
151
+ - lib/trace_visualization/repetitions_psy.rb
152
+ - lib/trace_visualization/suffix_array.rb
153
+ - lib/trace_visualization/utils.rb
154
+ - lib/trace_visualization/version.rb
155
+ - lib/trace_visualization/visualization/console_color_print.rb
156
+ - spec/bwt_spec.rb
157
+ - spec/generators_spec.rb
158
+ - spec/longest_common_prefix_spec.rb
159
+ - spec/mapping_spec.rb
160
+ - spec/reorder_spec.rb
161
+ - spec/repetitions_concatenation_spec.rb
162
+ - spec/repetitions_incrementation_spec.rb
163
+ - spec/repetitions_psy_spec.rb
164
+ - spec/repetitions_spec.rb
165
+ - spec/spec_helper.rb
166
+ - spec/suffix_array_spec.rb
167
+ - trace_visualization.gemspec
168
+ homepage: ''
169
+ licenses:
170
+ - MIT
171
+ metadata: {}
172
+ post_install_message:
173
+ rdoc_options: []
174
+ require_paths:
175
+ - lib
176
+ required_ruby_version: !ruby/object:Gem::Requirement
177
+ requirements:
178
+ - - '>='
179
+ - !ruby/object:Gem::Version
180
+ version: '0'
181
+ required_rubygems_version: !ruby/object:Gem::Requirement
182
+ requirements:
183
+ - - '>='
184
+ - !ruby/object:Gem::Version
185
+ version: '0'
186
+ requirements: []
187
+ rubyforge_project:
188
+ rubygems_version: 2.0.6
189
+ signing_key:
190
+ specification_version: 4
191
+ summary: Software for smart trace visualization
192
+ test_files:
193
+ - spec/bwt_spec.rb
194
+ - spec/generators_spec.rb
195
+ - spec/longest_common_prefix_spec.rb
196
+ - spec/mapping_spec.rb
197
+ - spec/reorder_spec.rb
198
+ - spec/repetitions_concatenation_spec.rb
199
+ - spec/repetitions_incrementation_spec.rb
200
+ - spec/repetitions_psy_spec.rb
201
+ - spec/repetitions_spec.rb
202
+ - spec/spec_helper.rb
203
+ - spec/suffix_array_spec.rb
204
+ has_rdoc: