Newer
Older
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
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"# 3D Nerve Surface Segmentation "
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"**Add Proper References Here**\n",
"\n",
"**NOTICE:** This notebook assumes you are familiar layered surface detection on tubular objects introduced in the *NerveSegmentation2D* notebook. "
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"import os\n",
"import numpy as np\n",
"import matplotlib.pyplot as plt\n",
"from matplotlib.image import imsave \n",
"from skimage.io import imread\n",
"from scipy.ndimage.interpolation import map_coordinates\n",
"\n",
"from qimtools import visualization, inspection, io\n",
"from slgbuilder import GraphObject,MaxflowBuilder"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"The objects (nerves) in the volume have two different sizes which need to be handled differently. With small nerves marked in red an large in blue."
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(200, 200, 10)\n"
]
}
],
"source": [
"in_dir = 'data/'\n",
"Vol_path = os.path.join(in_dir, 'nerves3D.tiff')\n",
"\n",
"# Load the data\n",
"vol = io.Volume( Vol_path )\n",
"\n",
"# Convert the stack of 2D slices to a 3D volume\n",
"vol = vol.concatenate().astype(np.int32)\n",
"vol = np.transpose(vol,(1,2,0))\n",
"\n",
"print(vol.shape)"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [],
"source": [
"%matplotlib notebook"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"scrolled": true
},
"outputs": [
{
"data": {
"application/javascript": [
"/* Put everything inside the global mpl namespace */\n",
"window.mpl = {};\n",
"\n",
"\n",
"mpl.get_websocket_type = function() {\n",
" if (typeof(WebSocket) !== 'undefined') {\n",
" return WebSocket;\n",
" } else if (typeof(MozWebSocket) !== 'undefined') {\n",
" return MozWebSocket;\n",
" } else {\n",
" alert('Your browser does not have WebSocket support. ' +\n",
" 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
" 'Firefox 4 and 5 are also supported but you ' +\n",
" 'have to enable WebSockets in about:config.');\n",
" };\n",
"}\n",
"\n",
"mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
" this.id = figure_id;\n",
"\n",
" this.ws = websocket;\n",
"\n",
" this.supports_binary = (this.ws.binaryType != undefined);\n",
"\n",
" if (!this.supports_binary) {\n",
" var warnings = document.getElementById(\"mpl-warnings\");\n",
" if (warnings) {\n",
" warnings.style.display = 'block';\n",
" warnings.textContent = (\n",
" \"This browser does not support binary websocket messages. \" +\n",
" \"Performance may be slow.\");\n",
" }\n",
" }\n",
"\n",
" this.imageObj = new Image();\n",
"\n",
" this.context = undefined;\n",
" this.message = undefined;\n",
" this.canvas = undefined;\n",
" this.rubberband_canvas = undefined;\n",
" this.rubberband_context = undefined;\n",
" this.format_dropdown = undefined;\n",
"\n",
" this.image_mode = 'full';\n",
"\n",
" this.root = $('<div/>');\n",
" this._root_extra_style(this.root)\n",
" this.root.attr('style', 'display: inline-block');\n",
"\n",
" $(parent_element).append(this.root);\n",
"\n",
" this._init_header(this);\n",
" this._init_canvas(this);\n",
" this._init_toolbar(this);\n",
"\n",
" var fig = this;\n",
"\n",
" this.waiting = false;\n",
"\n",
" this.ws.onopen = function () {\n",
" fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
" fig.send_message(\"send_image_mode\", {});\n",
" if (mpl.ratio != 1) {\n",
" fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
" }\n",
" fig.send_message(\"refresh\", {});\n",
" }\n",
"\n",
" this.imageObj.onload = function() {\n",
" if (fig.image_mode == 'full') {\n",
" // Full images could contain transparency (where diff images\n",
" // almost always do), so we need to clear the canvas so that\n",
" // there is no ghosting.\n",
" fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
" }\n",
" fig.context.drawImage(fig.imageObj, 0, 0);\n",
" };\n",
"\n",
" this.imageObj.onunload = function() {\n",
" fig.ws.close();\n",
" }\n",
"\n",
" this.ws.onmessage = this._make_on_message_function(this);\n",
"\n",
" this.ondownload = ondownload;\n",
"}\n",
"\n",
"mpl.figure.prototype._init_header = function() {\n",
" var titlebar = $(\n",
" '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
" 'ui-helper-clearfix\"/>');\n",
" var titletext = $(\n",
" '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
" 'text-align: center; padding: 3px;\"/>');\n",
" titlebar.append(titletext)\n",
" this.root.append(titlebar);\n",
" this.header = titletext[0];\n",
"}\n",
"\n",
"\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._init_canvas = function() {\n",
" var fig = this;\n",
"\n",
" var canvas_div = $('<div/>');\n",
"\n",
" canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
"\n",
" function canvas_keyboard_event(event) {\n",
" return fig.key_event(event, event['data']);\n",
" }\n",
"\n",
" canvas_div.keydown('key_press', canvas_keyboard_event);\n",
" canvas_div.keyup('key_release', canvas_keyboard_event);\n",
" this.canvas_div = canvas_div\n",
" this._canvas_extra_style(canvas_div)\n",
" this.root.append(canvas_div);\n",
"\n",
" var canvas = $('<canvas/>');\n",
" canvas.addClass('mpl-canvas');\n",
" canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
"\n",
" this.canvas = canvas[0];\n",
" this.context = canvas[0].getContext(\"2d\");\n",
"\n",
" var backingStore = this.context.backingStorePixelRatio ||\n",
"\tthis.context.webkitBackingStorePixelRatio ||\n",
"\tthis.context.mozBackingStorePixelRatio ||\n",
"\tthis.context.msBackingStorePixelRatio ||\n",
"\tthis.context.oBackingStorePixelRatio ||\n",
"\tthis.context.backingStorePixelRatio || 1;\n",
"\n",
" mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
"\n",
" var rubberband = $('<canvas/>');\n",
" rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
"\n",
" var pass_mouse_events = true;\n",
"\n",
" canvas_div.resizable({\n",
" start: function(event, ui) {\n",
" pass_mouse_events = false;\n",
" },\n",
" resize: function(event, ui) {\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" stop: function(event, ui) {\n",
" pass_mouse_events = true;\n",
" fig.request_resize(ui.size.width, ui.size.height);\n",
" },\n",
" });\n",
"\n",
" function mouse_event_fn(event) {\n",
" if (pass_mouse_events)\n",
" return fig.mouse_event(event, event['data']);\n",
" }\n",
"\n",
" rubberband.mousedown('button_press', mouse_event_fn);\n",
" rubberband.mouseup('button_release', mouse_event_fn);\n",
" // Throttle sequential mouse events to 1 every 20ms.\n",
" rubberband.mousemove('motion_notify', mouse_event_fn);\n",
"\n",
" rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
" rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
"\n",
" canvas_div.on(\"wheel\", function (event) {\n",
" event = event.originalEvent;\n",
" event['data'] = 'scroll'\n",
" if (event.deltaY < 0) {\n",
" event.step = 1;\n",
" } else {\n",
" event.step = -1;\n",
" }\n",
" mouse_event_fn(event);\n",
" });\n",
"\n",
" canvas_div.append(canvas);\n",
" canvas_div.append(rubberband);\n",
"\n",
" this.rubberband = rubberband;\n",
" this.rubberband_canvas = rubberband[0];\n",
" this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
" this.rubberband_context.strokeStyle = \"#000000\";\n",
"\n",
" this._resize_canvas = function(width, height) {\n",
" // Keep the size of the canvas, canvas container, and rubber band\n",
" // canvas in synch.\n",
" canvas_div.css('width', width)\n",
" canvas_div.css('height', height)\n",
"\n",
" canvas.attr('width', width * mpl.ratio);\n",
" canvas.attr('height', height * mpl.ratio);\n",
" canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
"\n",
" rubberband.attr('width', width);\n",
" rubberband.attr('height', height);\n",
" }\n",
"\n",
" // Set the figure to an initial 600x600px, this will subsequently be updated\n",
" // upon first draw.\n",
" this._resize_canvas(600, 600);\n",
"\n",
" // Disable right mouse context menu.\n",
" $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
" return false;\n",
" });\n",
"\n",
" function set_focus () {\n",
" canvas.focus();\n",
" canvas_div.focus();\n",
" }\n",
"\n",
" window.setTimeout(set_focus, 100);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items) {\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) {\n",
" // put a spacer in here.\n",
" continue;\n",
" }\n",
" var button = $('<button/>');\n",
" button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
" 'ui-button-icon-only');\n",
" button.attr('role', 'button');\n",
" button.attr('aria-disabled', 'false');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
"\n",
" var icon_img = $('<span/>');\n",
" icon_img.addClass('ui-button-icon-primary ui-icon');\n",
" icon_img.addClass(image);\n",
" icon_img.addClass('ui-corner-all');\n",
"\n",
" var tooltip_span = $('<span/>');\n",
" tooltip_span.addClass('ui-button-text');\n",
" tooltip_span.html(tooltip);\n",
"\n",
" button.append(icon_img);\n",
" button.append(tooltip_span);\n",
"\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" var fmt_picker_span = $('<span/>');\n",
"\n",
" var fmt_picker = $('<select/>');\n",
" fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
" fmt_picker_span.append(fmt_picker);\n",
" nav_element.append(fmt_picker_span);\n",
" this.format_dropdown = fmt_picker[0];\n",
"\n",
" for (var ind in mpl.extensions) {\n",
" var fmt = mpl.extensions[ind];\n",
" var option = $(\n",
" '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
" fmt_picker.append(option);\n",
" }\n",
"\n",
" // Add hover states to the ui-buttons\n",
" $( \".ui-button\" ).hover(\n",
" function() { $(this).addClass(\"ui-state-hover\");},\n",
" function() { $(this).removeClass(\"ui-state-hover\");}\n",
" );\n",
"\n",
" var status_bar = $('<span class=\"mpl-message\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"}\n",
"\n",
"mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
" // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
" // which will in turn request a refresh of the image.\n",
" this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
"}\n",
"\n",
"mpl.figure.prototype.send_message = function(type, properties) {\n",
" properties['type'] = type;\n",
" properties['figure_id'] = this.id;\n",
" this.ws.send(JSON.stringify(properties));\n",
"}\n",
"\n",
"mpl.figure.prototype.send_draw_message = function() {\n",
" if (!this.waiting) {\n",
" this.waiting = true;\n",
" this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
" }\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" var format_dropdown = fig.format_dropdown;\n",
" var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
" fig.ondownload(fig, format);\n",
"}\n",
"\n",
"\n",
"mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
" var size = msg['size'];\n",
" if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
" fig._resize_canvas(size[0], size[1]);\n",
" fig.send_message(\"refresh\", {});\n",
" };\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
" var x0 = msg['x0'] / mpl.ratio;\n",
" var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
" var x1 = msg['x1'] / mpl.ratio;\n",
" var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
" x0 = Math.floor(x0) + 0.5;\n",
" y0 = Math.floor(y0) + 0.5;\n",
" x1 = Math.floor(x1) + 0.5;\n",
" y1 = Math.floor(y1) + 0.5;\n",
" var min_x = Math.min(x0, x1);\n",
" var min_y = Math.min(y0, y1);\n",
" var width = Math.abs(x1 - x0);\n",
" var height = Math.abs(y1 - y0);\n",
"\n",
" fig.rubberband_context.clearRect(\n",
" 0, 0, fig.canvas.width / mpl.ratio, fig.canvas.height / mpl.ratio);\n",
"\n",
" fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
" // Updates the figure title.\n",
" fig.header.textContent = msg['label'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
" var cursor = msg['cursor'];\n",
" switch(cursor)\n",
" {\n",
" case 0:\n",
" cursor = 'pointer';\n",
" break;\n",
" case 1:\n",
" cursor = 'default';\n",
" break;\n",
" case 2:\n",
" cursor = 'crosshair';\n",
" break;\n",
" case 3:\n",
" cursor = 'move';\n",
" break;\n",
" }\n",
" fig.rubberband_canvas.style.cursor = cursor;\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_message = function(fig, msg) {\n",
" fig.message.textContent = msg['message'];\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
" // Request the server to send over a new figure.\n",
" fig.send_draw_message();\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
" fig.image_mode = msg['mode'];\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Called whenever the canvas gets updated.\n",
" this.send_message(\"ack\", {});\n",
"}\n",
"\n",
"// A function to construct a web socket function for onmessage handling.\n",
"// Called in the figure constructor.\n",
"mpl.figure.prototype._make_on_message_function = function(fig) {\n",
" return function socket_on_message(evt) {\n",
" if (evt.data instanceof Blob) {\n",
" /* FIXME: We get \"Resource interpreted as Image but\n",
" * transferred with MIME type text/plain:\" errors on\n",
" * Chrome. But how to set the MIME type? It doesn't seem\n",
" * to be part of the websocket stream */\n",
" evt.data.type = \"image/png\";\n",
"\n",
" /* Free the memory for the previous frames */\n",
" if (fig.imageObj.src) {\n",
" (window.URL || window.webkitURL).revokeObjectURL(\n",
" fig.imageObj.src);\n",
" }\n",
"\n",
" fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
" evt.data);\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
" else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
" fig.imageObj.src = evt.data;\n",
" fig.updated_canvas_event();\n",
" fig.waiting = false;\n",
" return;\n",
" }\n",
"\n",
" var msg = JSON.parse(evt.data);\n",
" var msg_type = msg['type'];\n",
"\n",
" // Call the \"handle_{type}\" callback, which takes\n",
" // the figure and JSON message as its only arguments.\n",
" try {\n",
" var callback = fig[\"handle_\" + msg_type];\n",
" } catch (e) {\n",
" console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
" return;\n",
" }\n",
"\n",
" if (callback) {\n",
" try {\n",
" // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
" callback(fig, msg);\n",
" } catch (e) {\n",
" console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
" }\n",
" }\n",
" };\n",
"}\n",
"\n",
"// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
"mpl.findpos = function(e) {\n",
" //this section is from http://www.quirksmode.org/js/events_properties.html\n",
" var targ;\n",
" if (!e)\n",
" e = window.event;\n",
" if (e.target)\n",
" targ = e.target;\n",
" else if (e.srcElement)\n",
" targ = e.srcElement;\n",
" if (targ.nodeType == 3) // defeat Safari bug\n",
" targ = targ.parentNode;\n",
"\n",
" // jQuery normalizes the pageX and pageY\n",
" // pageX,Y are the mouse positions relative to the document\n",
" // offset() returns the position of the element relative to the document\n",
" var x = e.pageX - $(targ).offset().left;\n",
" var y = e.pageY - $(targ).offset().top;\n",
"\n",
" return {\"x\": x, \"y\": y};\n",
"};\n",
"\n",
"/*\n",
" * return a copy of an object with only non-object keys\n",
" * we need this to avoid circular references\n",
" * http://stackoverflow.com/a/24161582/3208463\n",
" */\n",
"function simpleKeys (original) {\n",
" return Object.keys(original).reduce(function (obj, key) {\n",
" if (typeof original[key] !== 'object')\n",
" obj[key] = original[key]\n",
" return obj;\n",
" }, {});\n",
"}\n",
"\n",
"mpl.figure.prototype.mouse_event = function(event, name) {\n",
" var canvas_pos = mpl.findpos(event)\n",
"\n",
" if (name === 'button_press')\n",
" {\n",
" this.canvas.focus();\n",
" this.canvas_div.focus();\n",
" }\n",
"\n",
" var x = canvas_pos.x * mpl.ratio;\n",
" var y = canvas_pos.y * mpl.ratio;\n",
"\n",
" this.send_message(name, {x: x, y: y, button: event.button,\n",
" step: event.step,\n",
" guiEvent: simpleKeys(event)});\n",
"\n",
" /* This prevents the web browser from automatically changing to\n",
" * the text insertion cursor when the button is pressed. We want\n",
" * to control all of the cursor setting manually through the\n",
" * 'cursor' event from matplotlib */\n",
" event.preventDefault();\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" // Handle any extra behaviour associated with a key event\n",
"}\n",
"\n",
"mpl.figure.prototype.key_event = function(event, name) {\n",
"\n",
" // Prevent repeat events\n",
" if (name == 'key_press')\n",
" {\n",
" if (event.which === this._key)\n",
" return;\n",
" else\n",
" this._key = event.which;\n",
" }\n",
" if (name == 'key_release')\n",
" this._key = null;\n",
"\n",
" var value = '';\n",
" if (event.ctrlKey && event.which != 17)\n",
" value += \"ctrl+\";\n",
" if (event.altKey && event.which != 18)\n",
" value += \"alt+\";\n",
" if (event.shiftKey && event.which != 16)\n",
" value += \"shift+\";\n",
"\n",
" value += 'k';\n",
" value += event.which.toString();\n",
"\n",
" this._key_event_extra(event, name);\n",
"\n",
" this.send_message(name, {key: value,\n",
" guiEvent: simpleKeys(event)});\n",
" return false;\n",
"}\n",
"\n",
"mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
" if (name == 'download') {\n",
" this.handle_save(this, null);\n",
" } else {\n",
" this.send_message(\"toolbar_button\", {name: name});\n",
" }\n",
"};\n",
"\n",
"mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
" this.message.textContent = tooltip;\n",
"};\n",
"mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Pan axes with left mouse, zoom with right\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
"\n",
"mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
"\n",
"mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
" // Create a \"websocket\"-like object which calls the given IPython comm\n",
" // object with the appropriate methods. Currently this is a non binary\n",
" // socket, so there is still some room for performance tuning.\n",
" var ws = {};\n",
"\n",
" ws.close = function() {\n",
" comm.close()\n",
" };\n",
" ws.send = function(m) {\n",
" //console.log('sending', m);\n",
" comm.send(m);\n",
" };\n",
" // Register the callback with on_msg.\n",
" comm.on_msg(function(msg) {\n",
" //console.log('receiving', msg['content']['data'], msg);\n",
" // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
" ws.onmessage(msg['content']['data'])\n",
" });\n",
" return ws;\n",
"}\n",
"\n",
"mpl.mpl_figure_comm = function(comm, msg) {\n",
" // This is the function which gets called when the mpl process\n",
" // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
"\n",
" var id = msg.content.data.id;\n",
" // Get hold of the div created by the display call when the Comm\n",
" // socket was opened in Python.\n",
" var element = $(\"#\" + id);\n",
" var ws_proxy = comm_websocket_adapter(comm)\n",
"\n",
" function ondownload(figure, format) {\n",
" window.open(figure.imageObj.src);\n",
" }\n",
"\n",
" var fig = new mpl.figure(id, ws_proxy,\n",
" ondownload,\n",
" element.get(0));\n",
"\n",
" // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
" // web socket which is closed, not our websocket->open comm proxy.\n",
" ws_proxy.onopen();\n",
"\n",
" fig.parent_element = element.get(0);\n",
" fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
" if (!fig.cell_info) {\n",
" console.error(\"Failed to find cell for figure\", id, fig);\n",
" return;\n",
" }\n",
"\n",
" var output_index = fig.cell_info[2]\n",
" var cell = fig.cell_info[0];\n",
"\n",
"};\n",
"\n",
"mpl.figure.prototype.handle_close = function(fig, msg) {\n",
" var width = fig.canvas.width/mpl.ratio\n",
" fig.root.unbind('remove')\n",
"\n",
" // Update the output cell to use the data from the current canvas.\n",
" fig.push_to_output();\n",
" var dataURL = fig.canvas.toDataURL();\n",
" // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
" // the notebook keyboard shortcuts fail.\n",
" IPython.keyboard_manager.enable()\n",
" $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
" fig.close_ws(fig, msg);\n",
"}\n",
"\n",
"mpl.figure.prototype.close_ws = function(fig, msg){\n",
" fig.send_message('closing', msg);\n",
" // fig.ws.close()\n",
"}\n",
"\n",
"mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
" // Turn the data on the canvas into data in the output cell.\n",
" var width = this.canvas.width/mpl.ratio\n",
" var dataURL = this.canvas.toDataURL();\n",
" this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
"}\n",
"\n",
"mpl.figure.prototype.updated_canvas_event = function() {\n",
" // Tell IPython that the notebook contents must change.\n",
" IPython.notebook.set_dirty(true);\n",
" this.send_message(\"ack\", {});\n",
" var fig = this;\n",
" // Wait a second, then push the new image to the DOM so\n",
" // that it is saved nicely (might be nice to debounce this).\n",
" setTimeout(function () { fig.push_to_output() }, 1000);\n",
"}\n",
"\n",
"mpl.figure.prototype._init_toolbar = function() {\n",
" var fig = this;\n",
"\n",
" var nav_element = $('<div/>');\n",
" nav_element.attr('style', 'width: 100%');\n",
" this.root.append(nav_element);\n",
"\n",
" // Define a callback function for later on.\n",
" function toolbar_event(event) {\n",
" return fig.toolbar_button_onclick(event['data']);\n",
" }\n",
" function toolbar_mouse_event(event) {\n",
" return fig.toolbar_button_onmouseover(event['data']);\n",
" }\n",
"\n",
" for(var toolbar_ind in mpl.toolbar_items){\n",
" var name = mpl.toolbar_items[toolbar_ind][0];\n",
" var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
" var image = mpl.toolbar_items[toolbar_ind][2];\n",
" var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
"\n",
" if (!name) { continue; };\n",
"\n",
" var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
" button.click(method_name, toolbar_event);\n",
" button.mouseover(tooltip, toolbar_mouse_event);\n",
" nav_element.append(button);\n",
" }\n",
"\n",
" // Add the status bar.\n",
" var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
" nav_element.append(status_bar);\n",
" this.message = status_bar[0];\n",
"\n",
" // Add the close button to the window.\n",
" var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
" var button = $('<button class=\"btn btn-mini btn-primary\" href=\"#\" title=\"Stop Interaction\"><i class=\"fa fa-power-off icon-remove icon-large\"></i></button>');\n",
" button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
" button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
" buttongrp.append(button);\n",
" var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
" titlebar.prepend(buttongrp);\n",
"}\n",
"\n",
"mpl.figure.prototype._root_extra_style = function(el){\n",
" var fig = this\n",
" el.on(\"remove\", function(){\n",
"\tfig.close_ws(fig, {});\n",
" });\n",
"}\n",
"\n",
"mpl.figure.prototype._canvas_extra_style = function(el){\n",
" // this is important to make the div 'focusable\n",
" el.attr('tabindex', 0)\n",
" // reach out to IPython and tell the keyboard manager to turn it's self\n",
" // off when our div gets focus\n",
"\n",
" // location in version 3\n",
" if (IPython.notebook.keyboard_manager) {\n",
" IPython.notebook.keyboard_manager.register_events(el);\n",
" }\n",
" else {\n",
" // location in version 2\n",
" IPython.keyboard_manager.register_events(el);\n",
" }\n",
"\n",
"}\n",
"\n",
"mpl.figure.prototype._key_event_extra = function(event, name) {\n",
" var manager = IPython.notebook.keyboard_manager;\n",
" if (!manager)\n",
" manager = IPython.keyboard_manager;\n",
"\n",
" // Check for shift+enter\n",
" if (event.shiftKey && event.which == 13) {\n",
" this.canvas_div.blur();\n",
" // select the cell after this one\n",
" var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
" IPython.notebook.select(index + 1);\n",
" }\n",
"}\n",
"\n",
"mpl.figure.prototype.handle_save = function(fig, msg) {\n",
" fig.ondownload(fig, null);\n",
"}\n",
"\n",
"\n",
"mpl.find_output_cell = function(html_output) {\n",
" // Return the cell and output element which can be found *uniquely* in the notebook.\n",
" // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
" // IPython event is triggered only after the cells have been serialised, which for\n",
" // our purposes (turning an active figure into a static one), is too late.\n",
" var cells = IPython.notebook.get_cells();\n",
" var ncells = cells.length;\n",
" for (var i=0; i<ncells; i++) {\n",
" var cell = cells[i];\n",
" if (cell.cell_type === 'code'){\n",
" for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
" var data = cell.output_area.outputs[j];\n",
" if (data.data) {\n",
" // IPython >= 3 moved mimebundle to data attribute of output\n",
" data = data.data;\n",
" }\n",
" if (data['text/html'] == html_output) {\n",
" return [cell, data, j];\n",
" }\n",
" }\n",
" }\n",
" }\n",
"}\n",
"\n",
"// Register the function which deals with the matplotlib target/channel.\n",
"// The kernel may be null if the page has been refreshed.\n",
"if (IPython.notebook.kernel != null) {\n",
" IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
"}\n"
],
"text/plain": [
"<IPython.core.display.Javascript object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"data": {
"text/html": [
"<img src=\"\" width=\"640\">"
],
"text/plain": [
"<IPython.core.display.HTML object>"
]
},
"metadata": {},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"Instructions:\n",
" Controls\n",
" --------\n",
" 'up-arrow' : Next slice in volume\n",
" 'down-arrow' : Previous slice in volume\n",
" 'right-arrow' : +10 slices\n",
" 'left-arrow' : -10 slices\n",
" 'PgUp' : +50 slices\n",
" 'PgDown' : -50 slices\n",
"\n",
" scroll wheel : previous/next slice\n",
" \n"
]
}
],
"source": [
"visualization.show_vol( vol, axis=2 )"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [],
"source": [
"%matplotlib inline"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"scrolled": true
},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"Number of objects: 25\n"
]
}
],
"source": [
"# Get centers\n",
"path = in_dir+'nerveCenters.png'\n",
"centers = imread(path)[:,:,0]\n",
"\n",
"centers_small = np.transpose(np.where(centers==1))\n",
"centers_large = np.transpose(np.where(centers==2))\n",
"\n",
"# Show volume slice with centers.\n",
"plt.imshow(vol[...,0], cmap='gray')\n",
"plt.scatter(centers_small[..., 1], centers_small[..., 0], color='red', s=6)\n",
"plt.scatter(centers_large[..., 1], centers_large[..., 0], color='blue', s=6)\n",
"plt.show()\n",
"\n",
"print(f'Number of objects: {len(centers_small)+len(centers_large)}')"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [],
"source": [
"def unfold_image(img, center, max_dists=None, r_min=1, r_max=20, angles=30, steps=15):\n",
"\n",
" # Sampling angles and radii.\n",
" angles = np.linspace(0, 2*np.pi, angles, endpoint=False)\n",
" distances = np.linspace(r_min, r_max, steps, endpoint=True)\n",
" \n",
" if max_dists is not None:\n",
" max_dists.append(np.max(distances))\n",
" \n",
" # Get angles.\n",
" angles_cos = np.cos(angles)\n",
" angles_sin = np.sin(angles)\n",
" \n",
" # Calculate points positions.\n",
" x_pos = center[0] + np.outer(angles_cos, distances)\n",
" y_pos = center[1] + np.outer(angles_sin, distances)\n",
" \n",
" # Create list of sampling points.\n",
" sampling_points = np.array([x_pos, y_pos]).transpose()\n",
" sampling_shape = sampling_points.shape\n",
" sampling_points_flat = sampling_points.reshape((-1, 2))\n",
" \n",
" # Sample from image.\n",
" samples = map_coordinates(img, sampling_points_flat.transpose(), mode='nearest')\n",
" samples = samples.reshape(sampling_shape[:2])\n",
" \n",
" return samples, sampling_points\n",
"\n",
"def draw_segmentations(data, helper,layer=0):\n",
" \"\"\"Draw all segmentations for objects in the helper on top of the data.\"\"\"\n",
" \n",
" if data.ndim != 3:\n",
" raise ValueError('Data should be in three dimensions')\n",
" K = (len(helper.objects)//vol.shape[-1])//2\n",
" \n",
" # Create figure.\n",
" plt.figure(figsize=(10, 10))\n",
" plt.imshow(data[...,layer], cmap='gray')\n",
" plt.xlim([0, data[...,layer].shape[1]-1])\n",
" plt.ylim([data[...,layer].shape[0]-1, 0])\n",
"\n",
" # Draw segmentation lines.\n",
" for i, obj in enumerate(helper.objects):\n",
" if (i >= layer*K and i < (layer+1)*K) or (i >= (vol.shape[-1]+layer)*K and i< (vol.shape[-1]+layer+1)*K):\n",