immunoscore_results_aggregator 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +4 -0
- data/Gemfile +14 -0
- data/Gemfile.lock +47 -0
- data/README.md +54 -0
- data/Rakefile +2 -0
- data/bin/immunoscore_cli.rb +76 -0
- data/config.rb +14 -0
- data/data_struct.rb +280 -0
- data/docs/aggregator.html +200 -0
- data/docs/analyzer.html +1121 -0
- data/docs/data_struct.html +504 -0
- data/docs/database_connection.html +93 -0
- data/docs/docco.css +506 -0
- data/docs/exporter.html +216 -0
- data/docs/immunoscore_results_loader.html +485 -0
- data/docs/public/fonts/aller-bold.eot +0 -0
- data/docs/public/fonts/aller-bold.ttf +0 -0
- data/docs/public/fonts/aller-bold.woff +0 -0
- data/docs/public/fonts/aller-light.eot +0 -0
- data/docs/public/fonts/aller-light.ttf +0 -0
- data/docs/public/fonts/aller-light.woff +0 -0
- data/docs/public/fonts/novecento-bold.eot +0 -0
- data/docs/public/fonts/novecento-bold.ttf +0 -0
- data/docs/public/fonts/novecento-bold.woff +0 -0
- data/docs/public/stylesheets/normalize.css +375 -0
- data/docs/semicolon_cleaner.html +231 -0
- data/immunoscore_results_aggregator.gemspec +32 -0
- data/immunoscore_results_aggregator.rb +9 -0
- data/lib/analyzer.rb +664 -0
- data/lib/data_struct.rb +280 -0
- data/lib/database_connection.rb +4 -0
- data/lib/exporter.rb +76 -0
- data/lib/immunoscore_results_aggregator/version.rb +3 -0
- data/lib/immunoscore_results_loader.rb +218 -0
- data/lib/mongo_aggregator.rb +106 -0
- data/lib/semicolon_cleaner.rb +68 -0
- data/license.txt +21 -0
- metadata +243 -0
data/docs/exporter.html
ADDED
@@ -0,0 +1,216 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
|
3
|
+
<html>
|
4
|
+
<head>
|
5
|
+
<title>exporter.rb</title>
|
6
|
+
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
|
7
|
+
<meta name="viewport" content="width=device-width, target-densitydpi=160dpi, initial-scale=1.0; maximum-scale=1.0; user-scalable=0;">
|
8
|
+
<link rel="stylesheet" media="all" href="docco.css" />
|
9
|
+
</head>
|
10
|
+
<body>
|
11
|
+
<div id="container">
|
12
|
+
<div id="background"></div>
|
13
|
+
|
14
|
+
<ul id="jump_to">
|
15
|
+
<li>
|
16
|
+
<a class="large" href="javascript:void(0);">Jump To …</a>
|
17
|
+
<a class="small" href="javascript:void(0);">+</a>
|
18
|
+
<div id="jump_wrapper">
|
19
|
+
<div id="jump_page">
|
20
|
+
|
21
|
+
|
22
|
+
<a class="source" href="analyzer.html">
|
23
|
+
analyzer.rb
|
24
|
+
</a>
|
25
|
+
|
26
|
+
|
27
|
+
<a class="source" href="cli.html">
|
28
|
+
cli.rb
|
29
|
+
</a>
|
30
|
+
|
31
|
+
|
32
|
+
<a class="source" href="data_struct.html">
|
33
|
+
data_struct.rb
|
34
|
+
</a>
|
35
|
+
|
36
|
+
|
37
|
+
<a class="source" href="database_connection.html">
|
38
|
+
database_connection.rb
|
39
|
+
</a>
|
40
|
+
|
41
|
+
|
42
|
+
<a class="source" href="exporter.html">
|
43
|
+
exporter.rb
|
44
|
+
</a>
|
45
|
+
|
46
|
+
|
47
|
+
<a class="source" href="immunoscore_results_loader.html">
|
48
|
+
immunoscore_results_loader.rb
|
49
|
+
</a>
|
50
|
+
|
51
|
+
|
52
|
+
<a class="source" href="mongo_aggregator.html">
|
53
|
+
mongo_aggregator.rb
|
54
|
+
</a>
|
55
|
+
|
56
|
+
|
57
|
+
<a class="source" href="semicolon_cleaner.html">
|
58
|
+
semicolon_cleaner.rb
|
59
|
+
</a>
|
60
|
+
|
61
|
+
</div>
|
62
|
+
</li>
|
63
|
+
</ul>
|
64
|
+
|
65
|
+
<ul class="sections">
|
66
|
+
|
67
|
+
<li id="title">
|
68
|
+
<div class="annotation">
|
69
|
+
<h1>exporter.rb</h1>
|
70
|
+
</div>
|
71
|
+
</li>
|
72
|
+
|
73
|
+
|
74
|
+
|
75
|
+
<li id="section-1">
|
76
|
+
<div class="annotation">
|
77
|
+
|
78
|
+
<div class="pilwrap ">
|
79
|
+
<a class="pilcrow" href="#section-1">¶</a>
|
80
|
+
</div>
|
81
|
+
<p>Copyright (c) 2014, Carlo B. Bifulco. All rights reserved.</p>
|
82
|
+
|
83
|
+
</div>
|
84
|
+
|
85
|
+
<div class="content"><div class='highlight'><pre>
|
86
|
+
|
87
|
+
<span class="hljs-keyword">require</span> <span class="hljs-string">"csv"</span>
|
88
|
+
require_relative <span class="hljs-string">"analyzer"</span>
|
89
|
+
require_relative <span class="hljs-string">"data_struct"</span>
|
90
|
+
require_relative <span class="hljs-string">"immunoscore_results_loader"</span></pre></div></div>
|
91
|
+
|
92
|
+
</li>
|
93
|
+
|
94
|
+
|
95
|
+
<li id="section-2">
|
96
|
+
<div class="annotation">
|
97
|
+
|
98
|
+
<div class="pilwrap ">
|
99
|
+
<a class="pilcrow" href="#section-2">¶</a>
|
100
|
+
</div>
|
101
|
+
<h2 id="where-all-export-from-definiens-go">Where all export from Definiens go</h2>
|
102
|
+
|
103
|
+
</div>
|
104
|
+
|
105
|
+
<div class="content"><div class='highlight'><pre><span class="hljs-constant">EXPORT_DIR</span>=<span class="hljs-constant">YAML</span>.load_file(<span class="hljs-string">"config.yaml"</span>)[<span class="hljs-string">"export_dir"</span>] <span class="hljs-keyword">or</span> <span class="hljs-string">"./results_export"</span>
|
106
|
+
|
107
|
+
<span class="hljs-function"><span class="hljs-keyword">def</span> </span>export_clean_all
|
108
|
+
`rm -rf <span class="hljs-comment">#{EXPORT_DIR}/*`</span>
|
109
|
+
<span class="hljs-keyword">end</span>
|
110
|
+
|
111
|
+
<span class="hljs-function"><span class="hljs-keyword">def</span> </span>cd3? file_path
|
112
|
+
<span class="hljs-keyword">not</span> (file_path !~ <span class="hljs-regexp">/_CD3_/</span>)
|
113
|
+
<span class="hljs-keyword">end</span>
|
114
|
+
|
115
|
+
<span class="hljs-function"><span class="hljs-keyword">def</span> </span>cd8? file_path
|
116
|
+
<span class="hljs-keyword">not</span> (file_path !~ <span class="hljs-regexp">/_CD8_/</span>)
|
117
|
+
<span class="hljs-keyword">end</span>
|
118
|
+
|
119
|
+
<span class="hljs-function"><span class="hljs-keyword">def</span> </span>export_file case_dir,file_path
|
120
|
+
<span class="hljs-keyword">if</span> cd8? file_path
|
121
|
+
<span class="hljs-constant">Dir</span>.mkdir(case_dir+<span class="hljs-string">"/CD8"</span>) <span class="hljs-keyword">unless</span> <span class="hljs-constant">Dir</span>.exist?(case_dir+<span class="hljs-string">"/CD8"</span>)
|
122
|
+
fh=<span class="hljs-constant">File</span>.new(case_dir+<span class="hljs-string">"/CD8/"</span>+<span class="hljs-constant">File</span>.basename(file_path),<span class="hljs-string">"w"</span>)
|
123
|
+
<span class="hljs-keyword">else</span>
|
124
|
+
<span class="hljs-constant">Dir</span>.mkdir(case_dir+<span class="hljs-string">"/CD3"</span>) <span class="hljs-keyword">unless</span> <span class="hljs-constant">Dir</span>.exist?(case_dir+<span class="hljs-string">"/CD3"</span>)
|
125
|
+
fh=<span class="hljs-constant">File</span>.new(case_dir+<span class="hljs-string">"/CD3/"</span>+<span class="hljs-constant">File</span>.basename(file_path),<span class="hljs-string">"w"</span>)
|
126
|
+
<span class="hljs-keyword">end</span>
|
127
|
+
|
128
|
+
<span class="hljs-keyword">end</span></pre></div></div>
|
129
|
+
|
130
|
+
</li>
|
131
|
+
|
132
|
+
|
133
|
+
<li id="section-3">
|
134
|
+
<div class="annotation">
|
135
|
+
|
136
|
+
<div class="pilwrap ">
|
137
|
+
<a class="pilcrow" href="#section-3">¶</a>
|
138
|
+
</div>
|
139
|
+
<p>exports novel directory structure with only relevant files</p>
|
140
|
+
|
141
|
+
</div>
|
142
|
+
|
143
|
+
<div class="content"><div class='highlight'><pre><span class="hljs-function"><span class="hljs-keyword">def</span> </span>export_mongo</pre></div></div>
|
144
|
+
|
145
|
+
</li>
|
146
|
+
|
147
|
+
|
148
|
+
<li id="section-4">
|
149
|
+
<div class="annotation">
|
150
|
+
|
151
|
+
<div class="pilwrap ">
|
152
|
+
<a class="pilcrow" href="#section-4">¶</a>
|
153
|
+
</div>
|
154
|
+
<p>defined in immunoscore_results_loader</p>
|
155
|
+
|
156
|
+
</div>
|
157
|
+
|
158
|
+
<div class="content"><div class='highlight'><pre> <span class="hljs-constant">JSON_CLASS_MAPPER</span>.values.each <span class="hljs-keyword">do</span> |mm_class|
|
159
|
+
mm_class.all.each <span class="hljs-keyword">do</span> |mm_object|
|
160
|
+
puts <span class="hljs-string">"<span class="hljs-subst">#{mm_object}</span>: <span class="hljs-subst">#{mm_object[<span class="hljs-symbol">:case_n</span>]}</span>"</span>
|
161
|
+
<span class="hljs-keyword">next</span> <span class="hljs-keyword">unless</span> mm_object[<span class="hljs-symbol">:case_n</span>] != <span class="hljs-keyword">nil</span>
|
162
|
+
case_dir=(<span class="hljs-constant">EXPORT_DIR</span>+<span class="hljs-string">"/"</span>+ mm_object[<span class="hljs-symbol">:case_n</span>])
|
163
|
+
<span class="hljs-constant">Dir</span>.mkdir case_dir <span class="hljs-keyword">unless</span> <span class="hljs-constant">Dir</span>.exist?(case_dir)
|
164
|
+
fh=export_file case_dir, mm_object[<span class="hljs-symbol">:path</span>]
|
165
|
+
fh.write(mm_object[<span class="hljs-symbol">:data_load</span>])
|
166
|
+
fh.close
|
167
|
+
|
168
|
+
<span class="hljs-keyword">end</span>
|
169
|
+
<span class="hljs-keyword">end</span>
|
170
|
+
<span class="hljs-keyword">end</span>
|
171
|
+
|
172
|
+
|
173
|
+
|
174
|
+
<span class="hljs-function"><span class="hljs-keyword">def</span> </span>make_html reporting_order=[
|
175
|
+
<span class="hljs-symbol">:histogram</span>,
|
176
|
+
<span class="hljs-symbol">:original</span>,
|
177
|
+
<span class="hljs-symbol">:density</span>,
|
178
|
+
<span class="hljs-symbol">:ct_tile</span>,
|
179
|
+
<span class="hljs-symbol">:im_tile</span>,
|
180
|
+
<span class="hljs-symbol">:statistic</span>,
|
181
|
+
<span class="hljs-symbol">:classification</span>]
|
182
|
+
all_cases=[]
|
183
|
+
<span class="hljs-constant">ImmunoScoreResults</span>.all.each <span class="hljs-keyword">do</span> |i|
|
184
|
+
case_summary=[]
|
185
|
+
i.cd.sort.each <span class="hljs-keyword">do</span> |slide_cd|
|
186
|
+
reporting_order.each <span class="hljs-keyword">do</span> |feature|
|
187
|
+
slide_cd.public_send(feature).sort!{|a,b| a.path<=>b.path}.each <span class="hljs-keyword">do</span> |report|</pre></div></div>
|
188
|
+
|
189
|
+
</li>
|
190
|
+
|
191
|
+
|
192
|
+
<li id="section-5">
|
193
|
+
<div class="annotation">
|
194
|
+
|
195
|
+
<div class="pilwrap ">
|
196
|
+
<a class="pilcrow" href="#section-5">¶</a>
|
197
|
+
</div>
|
198
|
+
<p>binding.pry</p>
|
199
|
+
|
200
|
+
</div>
|
201
|
+
|
202
|
+
<div class="content"><div class='highlight'><pre> case_summary<< report[<span class="hljs-symbol">:path</span>]
|
203
|
+
<span class="hljs-keyword">end</span>
|
204
|
+
<span class="hljs-keyword">end</span>
|
205
|
+
<span class="hljs-keyword">end</span>
|
206
|
+
all_cases << case_summary
|
207
|
+
<span class="hljs-keyword">end</span>
|
208
|
+
all_cases
|
209
|
+
<span class="hljs-keyword">end</span></pre></div></div>
|
210
|
+
|
211
|
+
</li>
|
212
|
+
|
213
|
+
</ul>
|
214
|
+
</div>
|
215
|
+
</body>
|
216
|
+
</html>
|