##// END OF EJS Templates
Added BIAS4&5 inputs bug FFT analysis....
jeandet -
r4:0f6ca3b33310 None
parent child
Show More
This diff has been collapsed as it changes many lines, (4225 lines changed) Show them Hide them
@@ -0,0 +1,4225
1 {
2 "cells": [
3 {
4 "cell_type": "code",
5 "execution_count": 1,
6 "metadata": {
7 "ExecuteTime": {
8 "end_time": "2017-06-01T12:31:37.074717Z",
9 "start_time": "2017-06-01T12:31:36.678473Z"
10 }
11 },
12 "outputs": [],
13 "source": [
14 "%matplotlib notebook\n",
15 "import sys\n",
16 "sys.path.append(\"/opt/LFRCOMPLIANCE/\")\n",
17 "import matplotlib.pyplot as plt\n",
18 "import numpy as np\n",
19 "import pandas as pds\n",
20 "from glob import glob\n",
21 "from IPython.display import display\n",
22 "from lfrcompliance.test_engine.testcontext import *\n",
23 "from lfrcompliance.test_engine.result_loader import *\n",
24 "from lfrcompliance.tcpackets.constants import *\n",
25 "from lfrcompliance.test_engine.tests.analysis import TF\n",
26 "import multiprocessing.dummy\n",
27 "from dateutil import parser"
28 ]
29 },
30 {
31 "cell_type": "code",
32 "execution_count": 2,
33 "metadata": {
34 "ExecuteTime": {
35 "end_time": "2017-06-01T12:31:39.348311Z",
36 "start_time": "2017-06-01T12:31:37.210462Z"
37 },
38 "collapsed": true
39 },
40 "outputs": [],
41 "source": [
42 "res=ResultLoader(tm_files=[\"/home/jeandet/Documents/DATA/LFR_Packets/2017_03_02_14_21_53_packet_log.data\",\n",
43 " \"/home/jeandet/Documents/DATA/LFR_Packets/2017_03_02_14_21_54_packet_record.data\"])\n",
44 "res.decomutePackets()\n",
45 "res.loadSWF()"
46 ]
47 },
48 {
49 "cell_type": "code",
50 "execution_count": 3,
51 "metadata": {
52 "ExecuteTime": {
53 "end_time": "2017-06-01T12:31:39.351880Z",
54 "start_time": "2017-06-01T12:31:39.349319Z"
55 }
56 },
57 "outputs": [
58 {
59 "data": {
60 "text/plain": [
61 "190"
62 ]
63 },
64 "execution_count": 3,
65 "metadata": {},
66 "output_type": "execute_result"
67 }
68 ],
69 "source": [
70 "res.SWFCount()"
71 ]
72 },
73 {
74 "cell_type": "markdown",
75 "metadata": {},
76 "source": [
77 "# Snapshots at F0 for cold and ambient cases"
78 ]
79 },
80 {
81 "cell_type": "code",
82 "execution_count": 13,
83 "metadata": {
84 "ExecuteTime": {
85 "end_time": "2017-06-01T12:36:58.818223Z",
86 "start_time": "2017-06-01T12:36:58.685453Z"
87 }
88 },
89 "outputs": [
90 {
91 "data": {
92 "application/javascript": [
93 "/* Put everything inside the global mpl namespace */\n",
94 "window.mpl = {};\n",
95 "\n",
96 "\n",
97 "mpl.get_websocket_type = function() {\n",
98 " if (typeof(WebSocket) !== 'undefined') {\n",
99 " return WebSocket;\n",
100 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
101 " return MozWebSocket;\n",
102 " } else {\n",
103 " alert('Your browser does not have WebSocket support.' +\n",
104 " 'Please try Chrome, Safari or Firefox β‰₯ 6. ' +\n",
105 " 'Firefox 4 and 5 are also supported but you ' +\n",
106 " 'have to enable WebSockets in about:config.');\n",
107 " };\n",
108 "}\n",
109 "\n",
110 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
111 " this.id = figure_id;\n",
112 "\n",
113 " this.ws = websocket;\n",
114 "\n",
115 " this.supports_binary = (this.ws.binaryType != undefined);\n",
116 "\n",
117 " if (!this.supports_binary) {\n",
118 " var warnings = document.getElementById(\"mpl-warnings\");\n",
119 " if (warnings) {\n",
120 " warnings.style.display = 'block';\n",
121 " warnings.textContent = (\n",
122 " \"This browser does not support binary websocket messages. \" +\n",
123 " \"Performance may be slow.\");\n",
124 " }\n",
125 " }\n",
126 "\n",
127 " this.imageObj = new Image();\n",
128 "\n",
129 " this.context = undefined;\n",
130 " this.message = undefined;\n",
131 " this.canvas = undefined;\n",
132 " this.rubberband_canvas = undefined;\n",
133 " this.rubberband_context = undefined;\n",
134 " this.format_dropdown = undefined;\n",
135 "\n",
136 " this.image_mode = 'full';\n",
137 "\n",
138 " this.root = $('<div/>');\n",
139 " this._root_extra_style(this.root)\n",
140 " this.root.attr('style', 'display: inline-block');\n",
141 "\n",
142 " $(parent_element).append(this.root);\n",
143 "\n",
144 " this._init_header(this);\n",
145 " this._init_canvas(this);\n",
146 " this._init_toolbar(this);\n",
147 "\n",
148 " var fig = this;\n",
149 "\n",
150 " this.waiting = false;\n",
151 "\n",
152 " this.ws.onopen = function () {\n",
153 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
154 " fig.send_message(\"send_image_mode\", {});\n",
155 " if (mpl.ratio != 1) {\n",
156 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
157 " }\n",
158 " fig.send_message(\"refresh\", {});\n",
159 " }\n",
160 "\n",
161 " this.imageObj.onload = function() {\n",
162 " if (fig.image_mode == 'full') {\n",
163 " // Full images could contain transparency (where diff images\n",
164 " // almost always do), so we need to clear the canvas so that\n",
165 " // there is no ghosting.\n",
166 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
167 " }\n",
168 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
169 " };\n",
170 "\n",
171 " this.imageObj.onunload = function() {\n",
172 " this.ws.close();\n",
173 " }\n",
174 "\n",
175 " this.ws.onmessage = this._make_on_message_function(this);\n",
176 "\n",
177 " this.ondownload = ondownload;\n",
178 "}\n",
179 "\n",
180 "mpl.figure.prototype._init_header = function() {\n",
181 " var titlebar = $(\n",
182 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
183 " 'ui-helper-clearfix\"/>');\n",
184 " var titletext = $(\n",
185 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
186 " 'text-align: center; padding: 3px;\"/>');\n",
187 " titlebar.append(titletext)\n",
188 " this.root.append(titlebar);\n",
189 " this.header = titletext[0];\n",
190 "}\n",
191 "\n",
192 "\n",
193 "\n",
194 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
195 "\n",
196 "}\n",
197 "\n",
198 "\n",
199 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
200 "\n",
201 "}\n",
202 "\n",
203 "mpl.figure.prototype._init_canvas = function() {\n",
204 " var fig = this;\n",
205 "\n",
206 " var canvas_div = $('<div/>');\n",
207 "\n",
208 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
209 "\n",
210 " function canvas_keyboard_event(event) {\n",
211 " return fig.key_event(event, event['data']);\n",
212 " }\n",
213 "\n",
214 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
215 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
216 " this.canvas_div = canvas_div\n",
217 " this._canvas_extra_style(canvas_div)\n",
218 " this.root.append(canvas_div);\n",
219 "\n",
220 " var canvas = $('<canvas/>');\n",
221 " canvas.addClass('mpl-canvas');\n",
222 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
223 "\n",
224 " this.canvas = canvas[0];\n",
225 " this.context = canvas[0].getContext(\"2d\");\n",
226 "\n",
227 " var backingStore = this.context.backingStorePixelRatio ||\n",
228 "\tthis.context.webkitBackingStorePixelRatio ||\n",
229 "\tthis.context.mozBackingStorePixelRatio ||\n",
230 "\tthis.context.msBackingStorePixelRatio ||\n",
231 "\tthis.context.oBackingStorePixelRatio ||\n",
232 "\tthis.context.backingStorePixelRatio || 1;\n",
233 "\n",
234 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
235 "\n",
236 " var rubberband = $('<canvas/>');\n",
237 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
238 "\n",
239 " var pass_mouse_events = true;\n",
240 "\n",
241 " canvas_div.resizable({\n",
242 " start: function(event, ui) {\n",
243 " pass_mouse_events = false;\n",
244 " },\n",
245 " resize: function(event, ui) {\n",
246 " fig.request_resize(ui.size.width, ui.size.height);\n",
247 " },\n",
248 " stop: function(event, ui) {\n",
249 " pass_mouse_events = true;\n",
250 " fig.request_resize(ui.size.width, ui.size.height);\n",
251 " },\n",
252 " });\n",
253 "\n",
254 " function mouse_event_fn(event) {\n",
255 " if (pass_mouse_events)\n",
256 " return fig.mouse_event(event, event['data']);\n",
257 " }\n",
258 "\n",
259 " rubberband.mousedown('button_press', mouse_event_fn);\n",
260 " rubberband.mouseup('button_release', mouse_event_fn);\n",
261 " // Throttle sequential mouse events to 1 every 20ms.\n",
262 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
263 "\n",
264 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
265 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
266 "\n",
267 " canvas_div.on(\"wheel\", function (event) {\n",
268 " event = event.originalEvent;\n",
269 " event['data'] = 'scroll'\n",
270 " if (event.deltaY < 0) {\n",
271 " event.step = 1;\n",
272 " } else {\n",
273 " event.step = -1;\n",
274 " }\n",
275 " mouse_event_fn(event);\n",
276 " });\n",
277 "\n",
278 " canvas_div.append(canvas);\n",
279 " canvas_div.append(rubberband);\n",
280 "\n",
281 " this.rubberband = rubberband;\n",
282 " this.rubberband_canvas = rubberband[0];\n",
283 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
284 " this.rubberband_context.strokeStyle = \"#000000\";\n",
285 "\n",
286 " this._resize_canvas = function(width, height) {\n",
287 " // Keep the size of the canvas, canvas container, and rubber band\n",
288 " // canvas in synch.\n",
289 " canvas_div.css('width', width)\n",
290 " canvas_div.css('height', height)\n",
291 "\n",
292 " canvas.attr('width', width * mpl.ratio);\n",
293 " canvas.attr('height', height * mpl.ratio);\n",
294 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
295 "\n",
296 " rubberband.attr('width', width);\n",
297 " rubberband.attr('height', height);\n",
298 " }\n",
299 "\n",
300 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
301 " // upon first draw.\n",
302 " this._resize_canvas(600, 600);\n",
303 "\n",
304 " // Disable right mouse context menu.\n",
305 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
306 " return false;\n",
307 " });\n",
308 "\n",
309 " function set_focus () {\n",
310 " canvas.focus();\n",
311 " canvas_div.focus();\n",
312 " }\n",
313 "\n",
314 " window.setTimeout(set_focus, 100);\n",
315 "}\n",
316 "\n",
317 "mpl.figure.prototype._init_toolbar = function() {\n",
318 " var fig = this;\n",
319 "\n",
320 " var nav_element = $('<div/>')\n",
321 " nav_element.attr('style', 'width: 100%');\n",
322 " this.root.append(nav_element);\n",
323 "\n",
324 " // Define a callback function for later on.\n",
325 " function toolbar_event(event) {\n",
326 " return fig.toolbar_button_onclick(event['data']);\n",
327 " }\n",
328 " function toolbar_mouse_event(event) {\n",
329 " return fig.toolbar_button_onmouseover(event['data']);\n",
330 " }\n",
331 "\n",
332 " for(var toolbar_ind in mpl.toolbar_items) {\n",
333 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
334 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
335 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
336 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
337 "\n",
338 " if (!name) {\n",
339 " // put a spacer in here.\n",
340 " continue;\n",
341 " }\n",
342 " var button = $('<button/>');\n",
343 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
344 " 'ui-button-icon-only');\n",
345 " button.attr('role', 'button');\n",
346 " button.attr('aria-disabled', 'false');\n",
347 " button.click(method_name, toolbar_event);\n",
348 " button.mouseover(tooltip, toolbar_mouse_event);\n",
349 "\n",
350 " var icon_img = $('<span/>');\n",
351 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
352 " icon_img.addClass(image);\n",
353 " icon_img.addClass('ui-corner-all');\n",
354 "\n",
355 " var tooltip_span = $('<span/>');\n",
356 " tooltip_span.addClass('ui-button-text');\n",
357 " tooltip_span.html(tooltip);\n",
358 "\n",
359 " button.append(icon_img);\n",
360 " button.append(tooltip_span);\n",
361 "\n",
362 " nav_element.append(button);\n",
363 " }\n",
364 "\n",
365 " var fmt_picker_span = $('<span/>');\n",
366 "\n",
367 " var fmt_picker = $('<select/>');\n",
368 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
369 " fmt_picker_span.append(fmt_picker);\n",
370 " nav_element.append(fmt_picker_span);\n",
371 " this.format_dropdown = fmt_picker[0];\n",
372 "\n",
373 " for (var ind in mpl.extensions) {\n",
374 " var fmt = mpl.extensions[ind];\n",
375 " var option = $(\n",
376 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
377 " fmt_picker.append(option)\n",
378 " }\n",
379 "\n",
380 " // Add hover states to the ui-buttons\n",
381 " $( \".ui-button\" ).hover(\n",
382 " function() { $(this).addClass(\"ui-state-hover\");},\n",
383 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
384 " );\n",
385 "\n",
386 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
387 " nav_element.append(status_bar);\n",
388 " this.message = status_bar[0];\n",
389 "}\n",
390 "\n",
391 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
392 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
393 " // which will in turn request a refresh of the image.\n",
394 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
395 "}\n",
396 "\n",
397 "mpl.figure.prototype.send_message = function(type, properties) {\n",
398 " properties['type'] = type;\n",
399 " properties['figure_id'] = this.id;\n",
400 " this.ws.send(JSON.stringify(properties));\n",
401 "}\n",
402 "\n",
403 "mpl.figure.prototype.send_draw_message = function() {\n",
404 " if (!this.waiting) {\n",
405 " this.waiting = true;\n",
406 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
407 " }\n",
408 "}\n",
409 "\n",
410 "\n",
411 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
412 " var format_dropdown = fig.format_dropdown;\n",
413 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
414 " fig.ondownload(fig, format);\n",
415 "}\n",
416 "\n",
417 "\n",
418 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
419 " var size = msg['size'];\n",
420 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
421 " fig._resize_canvas(size[0], size[1]);\n",
422 " fig.send_message(\"refresh\", {});\n",
423 " };\n",
424 "}\n",
425 "\n",
426 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
427 " var x0 = msg['x0'] / mpl.ratio;\n",
428 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
429 " var x1 = msg['x1'] / mpl.ratio;\n",
430 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
431 " x0 = Math.floor(x0) + 0.5;\n",
432 " y0 = Math.floor(y0) + 0.5;\n",
433 " x1 = Math.floor(x1) + 0.5;\n",
434 " y1 = Math.floor(y1) + 0.5;\n",
435 " var min_x = Math.min(x0, x1);\n",
436 " var min_y = Math.min(y0, y1);\n",
437 " var width = Math.abs(x1 - x0);\n",
438 " var height = Math.abs(y1 - y0);\n",
439 "\n",
440 " fig.rubberband_context.clearRect(\n",
441 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
442 "\n",
443 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
444 "}\n",
445 "\n",
446 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
447 " // Updates the figure title.\n",
448 " fig.header.textContent = msg['label'];\n",
449 "}\n",
450 "\n",
451 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
452 " var cursor = msg['cursor'];\n",
453 " switch(cursor)\n",
454 " {\n",
455 " case 0:\n",
456 " cursor = 'pointer';\n",
457 " break;\n",
458 " case 1:\n",
459 " cursor = 'default';\n",
460 " break;\n",
461 " case 2:\n",
462 " cursor = 'crosshair';\n",
463 " break;\n",
464 " case 3:\n",
465 " cursor = 'move';\n",
466 " break;\n",
467 " }\n",
468 " fig.rubberband_canvas.style.cursor = cursor;\n",
469 "}\n",
470 "\n",
471 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
472 " fig.message.textContent = msg['message'];\n",
473 "}\n",
474 "\n",
475 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
476 " // Request the server to send over a new figure.\n",
477 " fig.send_draw_message();\n",
478 "}\n",
479 "\n",
480 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
481 " fig.image_mode = msg['mode'];\n",
482 "}\n",
483 "\n",
484 "mpl.figure.prototype.updated_canvas_event = function() {\n",
485 " // Called whenever the canvas gets updated.\n",
486 " this.send_message(\"ack\", {});\n",
487 "}\n",
488 "\n",
489 "// A function to construct a web socket function for onmessage handling.\n",
490 "// Called in the figure constructor.\n",
491 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
492 " return function socket_on_message(evt) {\n",
493 " if (evt.data instanceof Blob) {\n",
494 " /* FIXME: We get \"Resource interpreted as Image but\n",
495 " * transferred with MIME type text/plain:\" errors on\n",
496 " * Chrome. But how to set the MIME type? It doesn't seem\n",
497 " * to be part of the websocket stream */\n",
498 " evt.data.type = \"image/png\";\n",
499 "\n",
500 " /* Free the memory for the previous frames */\n",
501 " if (fig.imageObj.src) {\n",
502 " (window.URL || window.webkitURL).revokeObjectURL(\n",
503 " fig.imageObj.src);\n",
504 " }\n",
505 "\n",
506 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
507 " evt.data);\n",
508 " fig.updated_canvas_event();\n",
509 " fig.waiting = false;\n",
510 " return;\n",
511 " }\n",
512 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
513 " fig.imageObj.src = evt.data;\n",
514 " fig.updated_canvas_event();\n",
515 " fig.waiting = false;\n",
516 " return;\n",
517 " }\n",
518 "\n",
519 " var msg = JSON.parse(evt.data);\n",
520 " var msg_type = msg['type'];\n",
521 "\n",
522 " // Call the \"handle_{type}\" callback, which takes\n",
523 " // the figure and JSON message as its only arguments.\n",
524 " try {\n",
525 " var callback = fig[\"handle_\" + msg_type];\n",
526 " } catch (e) {\n",
527 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
528 " return;\n",
529 " }\n",
530 "\n",
531 " if (callback) {\n",
532 " try {\n",
533 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
534 " callback(fig, msg);\n",
535 " } catch (e) {\n",
536 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
537 " }\n",
538 " }\n",
539 " };\n",
540 "}\n",
541 "\n",
542 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
543 "mpl.findpos = function(e) {\n",
544 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
545 " var targ;\n",
546 " if (!e)\n",
547 " e = window.event;\n",
548 " if (e.target)\n",
549 " targ = e.target;\n",
550 " else if (e.srcElement)\n",
551 " targ = e.srcElement;\n",
552 " if (targ.nodeType == 3) // defeat Safari bug\n",
553 " targ = targ.parentNode;\n",
554 "\n",
555 " // jQuery normalizes the pageX and pageY\n",
556 " // pageX,Y are the mouse positions relative to the document\n",
557 " // offset() returns the position of the element relative to the document\n",
558 " var x = e.pageX - $(targ).offset().left;\n",
559 " var y = e.pageY - $(targ).offset().top;\n",
560 "\n",
561 " return {\"x\": x, \"y\": y};\n",
562 "};\n",
563 "\n",
564 "/*\n",
565 " * return a copy of an object with only non-object keys\n",
566 " * we need this to avoid circular references\n",
567 " * http://stackoverflow.com/a/24161582/3208463\n",
568 " */\n",
569 "function simpleKeys (original) {\n",
570 " return Object.keys(original).reduce(function (obj, key) {\n",
571 " if (typeof original[key] !== 'object')\n",
572 " obj[key] = original[key]\n",
573 " return obj;\n",
574 " }, {});\n",
575 "}\n",
576 "\n",
577 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
578 " var canvas_pos = mpl.findpos(event)\n",
579 "\n",
580 " if (name === 'button_press')\n",
581 " {\n",
582 " this.canvas.focus();\n",
583 " this.canvas_div.focus();\n",
584 " }\n",
585 "\n",
586 " var x = canvas_pos.x * mpl.ratio;\n",
587 " var y = canvas_pos.y * mpl.ratio;\n",
588 "\n",
589 " this.send_message(name, {x: x, y: y, button: event.button,\n",
590 " step: event.step,\n",
591 " guiEvent: simpleKeys(event)});\n",
592 "\n",
593 " /* This prevents the web browser from automatically changing to\n",
594 " * the text insertion cursor when the button is pressed. We want\n",
595 " * to control all of the cursor setting manually through the\n",
596 " * 'cursor' event from matplotlib */\n",
597 " event.preventDefault();\n",
598 " return false;\n",
599 "}\n",
600 "\n",
601 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
602 " // Handle any extra behaviour associated with a key event\n",
603 "}\n",
604 "\n",
605 "mpl.figure.prototype.key_event = function(event, name) {\n",
606 "\n",
607 " // Prevent repeat events\n",
608 " if (name == 'key_press')\n",
609 " {\n",
610 " if (event.which === this._key)\n",
611 " return;\n",
612 " else\n",
613 " this._key = event.which;\n",
614 " }\n",
615 " if (name == 'key_release')\n",
616 " this._key = null;\n",
617 "\n",
618 " var value = '';\n",
619 " if (event.ctrlKey && event.which != 17)\n",
620 " value += \"ctrl+\";\n",
621 " if (event.altKey && event.which != 18)\n",
622 " value += \"alt+\";\n",
623 " if (event.shiftKey && event.which != 16)\n",
624 " value += \"shift+\";\n",
625 "\n",
626 " value += 'k';\n",
627 " value += event.which.toString();\n",
628 "\n",
629 " this._key_event_extra(event, name);\n",
630 "\n",
631 " this.send_message(name, {key: value,\n",
632 " guiEvent: simpleKeys(event)});\n",
633 " return false;\n",
634 "}\n",
635 "\n",
636 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
637 " if (name == 'download') {\n",
638 " this.handle_save(this, null);\n",
639 " } else {\n",
640 " this.send_message(\"toolbar_button\", {name: name});\n",
641 " }\n",
642 "};\n",
643 "\n",
644 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
645 " this.message.textContent = tooltip;\n",
646 "};\n",
647 "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",
648 "\n",
649 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
650 "\n",
651 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
652 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
653 " // object with the appropriate methods. Currently this is a non binary\n",
654 " // socket, so there is still some room for performance tuning.\n",
655 " var ws = {};\n",
656 "\n",
657 " ws.close = function() {\n",
658 " comm.close()\n",
659 " };\n",
660 " ws.send = function(m) {\n",
661 " //console.log('sending', m);\n",
662 " comm.send(m);\n",
663 " };\n",
664 " // Register the callback with on_msg.\n",
665 " comm.on_msg(function(msg) {\n",
666 " //console.log('receiving', msg['content']['data'], msg);\n",
667 " // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
668 " ws.onmessage(msg['content']['data'])\n",
669 " });\n",
670 " return ws;\n",
671 "}\n",
672 "\n",
673 "mpl.mpl_figure_comm = function(comm, msg) {\n",
674 " // This is the function which gets called when the mpl process\n",
675 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
676 "\n",
677 " var id = msg.content.data.id;\n",
678 " // Get hold of the div created by the display call when the Comm\n",
679 " // socket was opened in Python.\n",
680 " var element = $(\"#\" + id);\n",
681 " var ws_proxy = comm_websocket_adapter(comm)\n",
682 "\n",
683 " function ondownload(figure, format) {\n",
684 " window.open(figure.imageObj.src);\n",
685 " }\n",
686 "\n",
687 " var fig = new mpl.figure(id, ws_proxy,\n",
688 " ondownload,\n",
689 " element.get(0));\n",
690 "\n",
691 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
692 " // web socket which is closed, not our websocket->open comm proxy.\n",
693 " ws_proxy.onopen();\n",
694 "\n",
695 " fig.parent_element = element.get(0);\n",
696 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
697 " if (!fig.cell_info) {\n",
698 " console.error(\"Failed to find cell for figure\", id, fig);\n",
699 " return;\n",
700 " }\n",
701 "\n",
702 " var output_index = fig.cell_info[2]\n",
703 " var cell = fig.cell_info[0];\n",
704 "\n",
705 "};\n",
706 "\n",
707 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
708 " var width = fig.canvas.width/mpl.ratio\n",
709 " fig.root.unbind('remove')\n",
710 "\n",
711 " // Update the output cell to use the data from the current canvas.\n",
712 " fig.push_to_output();\n",
713 " var dataURL = fig.canvas.toDataURL();\n",
714 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
715 " // the notebook keyboard shortcuts fail.\n",
716 " IPython.keyboard_manager.enable()\n",
717 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
718 " fig.close_ws(fig, msg);\n",
719 "}\n",
720 "\n",
721 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
722 " fig.send_message('closing', msg);\n",
723 " // fig.ws.close()\n",
724 "}\n",
725 "\n",
726 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
727 " // Turn the data on the canvas into data in the output cell.\n",
728 " var width = this.canvas.width/mpl.ratio\n",
729 " var dataURL = this.canvas.toDataURL();\n",
730 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
731 "}\n",
732 "\n",
733 "mpl.figure.prototype.updated_canvas_event = function() {\n",
734 " // Tell IPython that the notebook contents must change.\n",
735 " IPython.notebook.set_dirty(true);\n",
736 " this.send_message(\"ack\", {});\n",
737 " var fig = this;\n",
738 " // Wait a second, then push the new image to the DOM so\n",
739 " // that it is saved nicely (might be nice to debounce this).\n",
740 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
741 "}\n",
742 "\n",
743 "mpl.figure.prototype._init_toolbar = function() {\n",
744 " var fig = this;\n",
745 "\n",
746 " var nav_element = $('<div/>')\n",
747 " nav_element.attr('style', 'width: 100%');\n",
748 " this.root.append(nav_element);\n",
749 "\n",
750 " // Define a callback function for later on.\n",
751 " function toolbar_event(event) {\n",
752 " return fig.toolbar_button_onclick(event['data']);\n",
753 " }\n",
754 " function toolbar_mouse_event(event) {\n",
755 " return fig.toolbar_button_onmouseover(event['data']);\n",
756 " }\n",
757 "\n",
758 " for(var toolbar_ind in mpl.toolbar_items){\n",
759 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
760 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
761 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
762 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
763 "\n",
764 " if (!name) { continue; };\n",
765 "\n",
766 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
767 " button.click(method_name, toolbar_event);\n",
768 " button.mouseover(tooltip, toolbar_mouse_event);\n",
769 " nav_element.append(button);\n",
770 " }\n",
771 "\n",
772 " // Add the status bar.\n",
773 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
774 " nav_element.append(status_bar);\n",
775 " this.message = status_bar[0];\n",
776 "\n",
777 " // Add the close button to the window.\n",
778 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
779 " 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",
780 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
781 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
782 " buttongrp.append(button);\n",
783 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
784 " titlebar.prepend(buttongrp);\n",
785 "}\n",
786 "\n",
787 "mpl.figure.prototype._root_extra_style = function(el){\n",
788 " var fig = this\n",
789 " el.on(\"remove\", function(){\n",
790 "\tfig.close_ws(fig, {});\n",
791 " });\n",
792 "}\n",
793 "\n",
794 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
795 " // this is important to make the div 'focusable\n",
796 " el.attr('tabindex', 0)\n",
797 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
798 " // off when our div gets focus\n",
799 "\n",
800 " // location in version 3\n",
801 " if (IPython.notebook.keyboard_manager) {\n",
802 " IPython.notebook.keyboard_manager.register_events(el);\n",
803 " }\n",
804 " else {\n",
805 " // location in version 2\n",
806 " IPython.keyboard_manager.register_events(el);\n",
807 " }\n",
808 "\n",
809 "}\n",
810 "\n",
811 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
812 " var manager = IPython.notebook.keyboard_manager;\n",
813 " if (!manager)\n",
814 " manager = IPython.keyboard_manager;\n",
815 "\n",
816 " // Check for shift+enter\n",
817 " if (event.shiftKey && event.which == 13) {\n",
818 " this.canvas_div.blur();\n",
819 " // select the cell after this one\n",
820 " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
821 " IPython.notebook.select(index + 1);\n",
822 " }\n",
823 "}\n",
824 "\n",
825 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
826 " fig.ondownload(fig, null);\n",
827 "}\n",
828 "\n",
829 "\n",
830 "mpl.find_output_cell = function(html_output) {\n",
831 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
832 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
833 " // IPython event is triggered only after the cells have been serialised, which for\n",
834 " // our purposes (turning an active figure into a static one), is too late.\n",
835 " var cells = IPython.notebook.get_cells();\n",
836 " var ncells = cells.length;\n",
837 " for (var i=0; i<ncells; i++) {\n",
838 " var cell = cells[i];\n",
839 " if (cell.cell_type === 'code'){\n",
840 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
841 " var data = cell.output_area.outputs[j];\n",
842 " if (data.data) {\n",
843 " // IPython >= 3 moved mimebundle to data attribute of output\n",
844 " data = data.data;\n",
845 " }\n",
846 " if (data['text/html'] == html_output) {\n",
847 " return [cell, data, j];\n",
848 " }\n",
849 " }\n",
850 " }\n",
851 " }\n",
852 "}\n",
853 "\n",
854 "// Register the function which deals with the matplotlib target/channel.\n",
855 "// The kernel may be null if the page has been refreshed.\n",
856 "if (IPython.notebook.kernel != null) {\n",
857 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
858 "}\n"
859 ],
860 "text/plain": [
861 "<IPython.core.display.Javascript object>"
862 ]
863 },
864 "metadata": {},
865 "output_type": "display_data"
866 },
867 {
868 "data": {
869 "text/html": [
870 "<img src=\"\" width=\"1798.9499446000175\">"
871 ],
872 "text/plain": [
873 "<IPython.core.display.HTML object>"
874 ]
875 },
876 "metadata": {},
877 "output_type": "display_data"
878 },
879 {
880 "data": {
881 "application/javascript": [
882 "/* Put everything inside the global mpl namespace */\n",
883 "window.mpl = {};\n",
884 "\n",
885 "\n",
886 "mpl.get_websocket_type = function() {\n",
887 " if (typeof(WebSocket) !== 'undefined') {\n",
888 " return WebSocket;\n",
889 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
890 " return MozWebSocket;\n",
891 " } else {\n",
892 " alert('Your browser does not have WebSocket support.' +\n",
893 " 'Please try Chrome, Safari or Firefox β‰₯ 6. ' +\n",
894 " 'Firefox 4 and 5 are also supported but you ' +\n",
895 " 'have to enable WebSockets in about:config.');\n",
896 " };\n",
897 "}\n",
898 "\n",
899 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
900 " this.id = figure_id;\n",
901 "\n",
902 " this.ws = websocket;\n",
903 "\n",
904 " this.supports_binary = (this.ws.binaryType != undefined);\n",
905 "\n",
906 " if (!this.supports_binary) {\n",
907 " var warnings = document.getElementById(\"mpl-warnings\");\n",
908 " if (warnings) {\n",
909 " warnings.style.display = 'block';\n",
910 " warnings.textContent = (\n",
911 " \"This browser does not support binary websocket messages. \" +\n",
912 " \"Performance may be slow.\");\n",
913 " }\n",
914 " }\n",
915 "\n",
916 " this.imageObj = new Image();\n",
917 "\n",
918 " this.context = undefined;\n",
919 " this.message = undefined;\n",
920 " this.canvas = undefined;\n",
921 " this.rubberband_canvas = undefined;\n",
922 " this.rubberband_context = undefined;\n",
923 " this.format_dropdown = undefined;\n",
924 "\n",
925 " this.image_mode = 'full';\n",
926 "\n",
927 " this.root = $('<div/>');\n",
928 " this._root_extra_style(this.root)\n",
929 " this.root.attr('style', 'display: inline-block');\n",
930 "\n",
931 " $(parent_element).append(this.root);\n",
932 "\n",
933 " this._init_header(this);\n",
934 " this._init_canvas(this);\n",
935 " this._init_toolbar(this);\n",
936 "\n",
937 " var fig = this;\n",
938 "\n",
939 " this.waiting = false;\n",
940 "\n",
941 " this.ws.onopen = function () {\n",
942 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
943 " fig.send_message(\"send_image_mode\", {});\n",
944 " if (mpl.ratio != 1) {\n",
945 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
946 " }\n",
947 " fig.send_message(\"refresh\", {});\n",
948 " }\n",
949 "\n",
950 " this.imageObj.onload = function() {\n",
951 " if (fig.image_mode == 'full') {\n",
952 " // Full images could contain transparency (where diff images\n",
953 " // almost always do), so we need to clear the canvas so that\n",
954 " // there is no ghosting.\n",
955 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
956 " }\n",
957 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
958 " };\n",
959 "\n",
960 " this.imageObj.onunload = function() {\n",
961 " this.ws.close();\n",
962 " }\n",
963 "\n",
964 " this.ws.onmessage = this._make_on_message_function(this);\n",
965 "\n",
966 " this.ondownload = ondownload;\n",
967 "}\n",
968 "\n",
969 "mpl.figure.prototype._init_header = function() {\n",
970 " var titlebar = $(\n",
971 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
972 " 'ui-helper-clearfix\"/>');\n",
973 " var titletext = $(\n",
974 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
975 " 'text-align: center; padding: 3px;\"/>');\n",
976 " titlebar.append(titletext)\n",
977 " this.root.append(titlebar);\n",
978 " this.header = titletext[0];\n",
979 "}\n",
980 "\n",
981 "\n",
982 "\n",
983 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
984 "\n",
985 "}\n",
986 "\n",
987 "\n",
988 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
989 "\n",
990 "}\n",
991 "\n",
992 "mpl.figure.prototype._init_canvas = function() {\n",
993 " var fig = this;\n",
994 "\n",
995 " var canvas_div = $('<div/>');\n",
996 "\n",
997 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
998 "\n",
999 " function canvas_keyboard_event(event) {\n",
1000 " return fig.key_event(event, event['data']);\n",
1001 " }\n",
1002 "\n",
1003 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
1004 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
1005 " this.canvas_div = canvas_div\n",
1006 " this._canvas_extra_style(canvas_div)\n",
1007 " this.root.append(canvas_div);\n",
1008 "\n",
1009 " var canvas = $('<canvas/>');\n",
1010 " canvas.addClass('mpl-canvas');\n",
1011 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
1012 "\n",
1013 " this.canvas = canvas[0];\n",
1014 " this.context = canvas[0].getContext(\"2d\");\n",
1015 "\n",
1016 " var backingStore = this.context.backingStorePixelRatio ||\n",
1017 "\tthis.context.webkitBackingStorePixelRatio ||\n",
1018 "\tthis.context.mozBackingStorePixelRatio ||\n",
1019 "\tthis.context.msBackingStorePixelRatio ||\n",
1020 "\tthis.context.oBackingStorePixelRatio ||\n",
1021 "\tthis.context.backingStorePixelRatio || 1;\n",
1022 "\n",
1023 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
1024 "\n",
1025 " var rubberband = $('<canvas/>');\n",
1026 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
1027 "\n",
1028 " var pass_mouse_events = true;\n",
1029 "\n",
1030 " canvas_div.resizable({\n",
1031 " start: function(event, ui) {\n",
1032 " pass_mouse_events = false;\n",
1033 " },\n",
1034 " resize: function(event, ui) {\n",
1035 " fig.request_resize(ui.size.width, ui.size.height);\n",
1036 " },\n",
1037 " stop: function(event, ui) {\n",
1038 " pass_mouse_events = true;\n",
1039 " fig.request_resize(ui.size.width, ui.size.height);\n",
1040 " },\n",
1041 " });\n",
1042 "\n",
1043 " function mouse_event_fn(event) {\n",
1044 " if (pass_mouse_events)\n",
1045 " return fig.mouse_event(event, event['data']);\n",
1046 " }\n",
1047 "\n",
1048 " rubberband.mousedown('button_press', mouse_event_fn);\n",
1049 " rubberband.mouseup('button_release', mouse_event_fn);\n",
1050 " // Throttle sequential mouse events to 1 every 20ms.\n",
1051 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
1052 "\n",
1053 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
1054 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
1055 "\n",
1056 " canvas_div.on(\"wheel\", function (event) {\n",
1057 " event = event.originalEvent;\n",
1058 " event['data'] = 'scroll'\n",
1059 " if (event.deltaY < 0) {\n",
1060 " event.step = 1;\n",
1061 " } else {\n",
1062 " event.step = -1;\n",
1063 " }\n",
1064 " mouse_event_fn(event);\n",
1065 " });\n",
1066 "\n",
1067 " canvas_div.append(canvas);\n",
1068 " canvas_div.append(rubberband);\n",
1069 "\n",
1070 " this.rubberband = rubberband;\n",
1071 " this.rubberband_canvas = rubberband[0];\n",
1072 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
1073 " this.rubberband_context.strokeStyle = \"#000000\";\n",
1074 "\n",
1075 " this._resize_canvas = function(width, height) {\n",
1076 " // Keep the size of the canvas, canvas container, and rubber band\n",
1077 " // canvas in synch.\n",
1078 " canvas_div.css('width', width)\n",
1079 " canvas_div.css('height', height)\n",
1080 "\n",
1081 " canvas.attr('width', width * mpl.ratio);\n",
1082 " canvas.attr('height', height * mpl.ratio);\n",
1083 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
1084 "\n",
1085 " rubberband.attr('width', width);\n",
1086 " rubberband.attr('height', height);\n",
1087 " }\n",
1088 "\n",
1089 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
1090 " // upon first draw.\n",
1091 " this._resize_canvas(600, 600);\n",
1092 "\n",
1093 " // Disable right mouse context menu.\n",
1094 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
1095 " return false;\n",
1096 " });\n",
1097 "\n",
1098 " function set_focus () {\n",
1099 " canvas.focus();\n",
1100 " canvas_div.focus();\n",
1101 " }\n",
1102 "\n",
1103 " window.setTimeout(set_focus, 100);\n",
1104 "}\n",
1105 "\n",
1106 "mpl.figure.prototype._init_toolbar = function() {\n",
1107 " var fig = this;\n",
1108 "\n",
1109 " var nav_element = $('<div/>')\n",
1110 " nav_element.attr('style', 'width: 100%');\n",
1111 " this.root.append(nav_element);\n",
1112 "\n",
1113 " // Define a callback function for later on.\n",
1114 " function toolbar_event(event) {\n",
1115 " return fig.toolbar_button_onclick(event['data']);\n",
1116 " }\n",
1117 " function toolbar_mouse_event(event) {\n",
1118 " return fig.toolbar_button_onmouseover(event['data']);\n",
1119 " }\n",
1120 "\n",
1121 " for(var toolbar_ind in mpl.toolbar_items) {\n",
1122 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
1123 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
1124 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
1125 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
1126 "\n",
1127 " if (!name) {\n",
1128 " // put a spacer in here.\n",
1129 " continue;\n",
1130 " }\n",
1131 " var button = $('<button/>');\n",
1132 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
1133 " 'ui-button-icon-only');\n",
1134 " button.attr('role', 'button');\n",
1135 " button.attr('aria-disabled', 'false');\n",
1136 " button.click(method_name, toolbar_event);\n",
1137 " button.mouseover(tooltip, toolbar_mouse_event);\n",
1138 "\n",
1139 " var icon_img = $('<span/>');\n",
1140 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
1141 " icon_img.addClass(image);\n",
1142 " icon_img.addClass('ui-corner-all');\n",
1143 "\n",
1144 " var tooltip_span = $('<span/>');\n",
1145 " tooltip_span.addClass('ui-button-text');\n",
1146 " tooltip_span.html(tooltip);\n",
1147 "\n",
1148 " button.append(icon_img);\n",
1149 " button.append(tooltip_span);\n",
1150 "\n",
1151 " nav_element.append(button);\n",
1152 " }\n",
1153 "\n",
1154 " var fmt_picker_span = $('<span/>');\n",
1155 "\n",
1156 " var fmt_picker = $('<select/>');\n",
1157 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
1158 " fmt_picker_span.append(fmt_picker);\n",
1159 " nav_element.append(fmt_picker_span);\n",
1160 " this.format_dropdown = fmt_picker[0];\n",
1161 "\n",
1162 " for (var ind in mpl.extensions) {\n",
1163 " var fmt = mpl.extensions[ind];\n",
1164 " var option = $(\n",
1165 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
1166 " fmt_picker.append(option)\n",
1167 " }\n",
1168 "\n",
1169 " // Add hover states to the ui-buttons\n",
1170 " $( \".ui-button\" ).hover(\n",
1171 " function() { $(this).addClass(\"ui-state-hover\");},\n",
1172 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
1173 " );\n",
1174 "\n",
1175 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
1176 " nav_element.append(status_bar);\n",
1177 " this.message = status_bar[0];\n",
1178 "}\n",
1179 "\n",
1180 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
1181 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
1182 " // which will in turn request a refresh of the image.\n",
1183 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
1184 "}\n",
1185 "\n",
1186 "mpl.figure.prototype.send_message = function(type, properties) {\n",
1187 " properties['type'] = type;\n",
1188 " properties['figure_id'] = this.id;\n",
1189 " this.ws.send(JSON.stringify(properties));\n",
1190 "}\n",
1191 "\n",
1192 "mpl.figure.prototype.send_draw_message = function() {\n",
1193 " if (!this.waiting) {\n",
1194 " this.waiting = true;\n",
1195 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
1196 " }\n",
1197 "}\n",
1198 "\n",
1199 "\n",
1200 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
1201 " var format_dropdown = fig.format_dropdown;\n",
1202 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
1203 " fig.ondownload(fig, format);\n",
1204 "}\n",
1205 "\n",
1206 "\n",
1207 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
1208 " var size = msg['size'];\n",
1209 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
1210 " fig._resize_canvas(size[0], size[1]);\n",
1211 " fig.send_message(\"refresh\", {});\n",
1212 " };\n",
1213 "}\n",
1214 "\n",
1215 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
1216 " var x0 = msg['x0'] / mpl.ratio;\n",
1217 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
1218 " var x1 = msg['x1'] / mpl.ratio;\n",
1219 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
1220 " x0 = Math.floor(x0) + 0.5;\n",
1221 " y0 = Math.floor(y0) + 0.5;\n",
1222 " x1 = Math.floor(x1) + 0.5;\n",
1223 " y1 = Math.floor(y1) + 0.5;\n",
1224 " var min_x = Math.min(x0, x1);\n",
1225 " var min_y = Math.min(y0, y1);\n",
1226 " var width = Math.abs(x1 - x0);\n",
1227 " var height = Math.abs(y1 - y0);\n",
1228 "\n",
1229 " fig.rubberband_context.clearRect(\n",
1230 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
1231 "\n",
1232 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
1233 "}\n",
1234 "\n",
1235 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
1236 " // Updates the figure title.\n",
1237 " fig.header.textContent = msg['label'];\n",
1238 "}\n",
1239 "\n",
1240 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
1241 " var cursor = msg['cursor'];\n",
1242 " switch(cursor)\n",
1243 " {\n",
1244 " case 0:\n",
1245 " cursor = 'pointer';\n",
1246 " break;\n",
1247 " case 1:\n",
1248 " cursor = 'default';\n",
1249 " break;\n",
1250 " case 2:\n",
1251 " cursor = 'crosshair';\n",
1252 " break;\n",
1253 " case 3:\n",
1254 " cursor = 'move';\n",
1255 " break;\n",
1256 " }\n",
1257 " fig.rubberband_canvas.style.cursor = cursor;\n",
1258 "}\n",
1259 "\n",
1260 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
1261 " fig.message.textContent = msg['message'];\n",
1262 "}\n",
1263 "\n",
1264 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
1265 " // Request the server to send over a new figure.\n",
1266 " fig.send_draw_message();\n",
1267 "}\n",
1268 "\n",
1269 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
1270 " fig.image_mode = msg['mode'];\n",
1271 "}\n",
1272 "\n",
1273 "mpl.figure.prototype.updated_canvas_event = function() {\n",
1274 " // Called whenever the canvas gets updated.\n",
1275 " this.send_message(\"ack\", {});\n",
1276 "}\n",
1277 "\n",
1278 "// A function to construct a web socket function for onmessage handling.\n",
1279 "// Called in the figure constructor.\n",
1280 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
1281 " return function socket_on_message(evt) {\n",
1282 " if (evt.data instanceof Blob) {\n",
1283 " /* FIXME: We get \"Resource interpreted as Image but\n",
1284 " * transferred with MIME type text/plain:\" errors on\n",
1285 " * Chrome. But how to set the MIME type? It doesn't seem\n",
1286 " * to be part of the websocket stream */\n",
1287 " evt.data.type = \"image/png\";\n",
1288 "\n",
1289 " /* Free the memory for the previous frames */\n",
1290 " if (fig.imageObj.src) {\n",
1291 " (window.URL || window.webkitURL).revokeObjectURL(\n",
1292 " fig.imageObj.src);\n",
1293 " }\n",
1294 "\n",
1295 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
1296 " evt.data);\n",
1297 " fig.updated_canvas_event();\n",
1298 " fig.waiting = false;\n",
1299 " return;\n",
1300 " }\n",
1301 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
1302 " fig.imageObj.src = evt.data;\n",
1303 " fig.updated_canvas_event();\n",
1304 " fig.waiting = false;\n",
1305 " return;\n",
1306 " }\n",
1307 "\n",
1308 " var msg = JSON.parse(evt.data);\n",
1309 " var msg_type = msg['type'];\n",
1310 "\n",
1311 " // Call the \"handle_{type}\" callback, which takes\n",
1312 " // the figure and JSON message as its only arguments.\n",
1313 " try {\n",
1314 " var callback = fig[\"handle_\" + msg_type];\n",
1315 " } catch (e) {\n",
1316 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
1317 " return;\n",
1318 " }\n",
1319 "\n",
1320 " if (callback) {\n",
1321 " try {\n",
1322 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
1323 " callback(fig, msg);\n",
1324 " } catch (e) {\n",
1325 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
1326 " }\n",
1327 " }\n",
1328 " };\n",
1329 "}\n",
1330 "\n",
1331 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
1332 "mpl.findpos = function(e) {\n",
1333 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
1334 " var targ;\n",
1335 " if (!e)\n",
1336 " e = window.event;\n",
1337 " if (e.target)\n",
1338 " targ = e.target;\n",
1339 " else if (e.srcElement)\n",
1340 " targ = e.srcElement;\n",
1341 " if (targ.nodeType == 3) // defeat Safari bug\n",
1342 " targ = targ.parentNode;\n",
1343 "\n",
1344 " // jQuery normalizes the pageX and pageY\n",
1345 " // pageX,Y are the mouse positions relative to the document\n",
1346 " // offset() returns the position of the element relative to the document\n",
1347 " var x = e.pageX - $(targ).offset().left;\n",
1348 " var y = e.pageY - $(targ).offset().top;\n",
1349 "\n",
1350 " return {\"x\": x, \"y\": y};\n",
1351 "};\n",
1352 "\n",
1353 "/*\n",
1354 " * return a copy of an object with only non-object keys\n",
1355 " * we need this to avoid circular references\n",
1356 " * http://stackoverflow.com/a/24161582/3208463\n",
1357 " */\n",
1358 "function simpleKeys (original) {\n",
1359 " return Object.keys(original).reduce(function (obj, key) {\n",
1360 " if (typeof original[key] !== 'object')\n",
1361 " obj[key] = original[key]\n",
1362 " return obj;\n",
1363 " }, {});\n",
1364 "}\n",
1365 "\n",
1366 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
1367 " var canvas_pos = mpl.findpos(event)\n",
1368 "\n",
1369 " if (name === 'button_press')\n",
1370 " {\n",
1371 " this.canvas.focus();\n",
1372 " this.canvas_div.focus();\n",
1373 " }\n",
1374 "\n",
1375 " var x = canvas_pos.x * mpl.ratio;\n",
1376 " var y = canvas_pos.y * mpl.ratio;\n",
1377 "\n",
1378 " this.send_message(name, {x: x, y: y, button: event.button,\n",
1379 " step: event.step,\n",
1380 " guiEvent: simpleKeys(event)});\n",
1381 "\n",
1382 " /* This prevents the web browser from automatically changing to\n",
1383 " * the text insertion cursor when the button is pressed. We want\n",
1384 " * to control all of the cursor setting manually through the\n",
1385 " * 'cursor' event from matplotlib */\n",
1386 " event.preventDefault();\n",
1387 " return false;\n",
1388 "}\n",
1389 "\n",
1390 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
1391 " // Handle any extra behaviour associated with a key event\n",
1392 "}\n",
1393 "\n",
1394 "mpl.figure.prototype.key_event = function(event, name) {\n",
1395 "\n",
1396 " // Prevent repeat events\n",
1397 " if (name == 'key_press')\n",
1398 " {\n",
1399 " if (event.which === this._key)\n",
1400 " return;\n",
1401 " else\n",
1402 " this._key = event.which;\n",
1403 " }\n",
1404 " if (name == 'key_release')\n",
1405 " this._key = null;\n",
1406 "\n",
1407 " var value = '';\n",
1408 " if (event.ctrlKey && event.which != 17)\n",
1409 " value += \"ctrl+\";\n",
1410 " if (event.altKey && event.which != 18)\n",
1411 " value += \"alt+\";\n",
1412 " if (event.shiftKey && event.which != 16)\n",
1413 " value += \"shift+\";\n",
1414 "\n",
1415 " value += 'k';\n",
1416 " value += event.which.toString();\n",
1417 "\n",
1418 " this._key_event_extra(event, name);\n",
1419 "\n",
1420 " this.send_message(name, {key: value,\n",
1421 " guiEvent: simpleKeys(event)});\n",
1422 " return false;\n",
1423 "}\n",
1424 "\n",
1425 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
1426 " if (name == 'download') {\n",
1427 " this.handle_save(this, null);\n",
1428 " } else {\n",
1429 " this.send_message(\"toolbar_button\", {name: name});\n",
1430 " }\n",
1431 "};\n",
1432 "\n",
1433 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
1434 " this.message.textContent = tooltip;\n",
1435 "};\n",
1436 "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",
1437 "\n",
1438 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
1439 "\n",
1440 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
1441 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
1442 " // object with the appropriate methods. Currently this is a non binary\n",
1443 " // socket, so there is still some room for performance tuning.\n",
1444 " var ws = {};\n",
1445 "\n",
1446 " ws.close = function() {\n",
1447 " comm.close()\n",
1448 " };\n",
1449 " ws.send = function(m) {\n",
1450 " //console.log('sending', m);\n",
1451 " comm.send(m);\n",
1452 " };\n",
1453 " // Register the callback with on_msg.\n",
1454 " comm.on_msg(function(msg) {\n",
1455 " //console.log('receiving', msg['content']['data'], msg);\n",
1456 " // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
1457 " ws.onmessage(msg['content']['data'])\n",
1458 " });\n",
1459 " return ws;\n",
1460 "}\n",
1461 "\n",
1462 "mpl.mpl_figure_comm = function(comm, msg) {\n",
1463 " // This is the function which gets called when the mpl process\n",
1464 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
1465 "\n",
1466 " var id = msg.content.data.id;\n",
1467 " // Get hold of the div created by the display call when the Comm\n",
1468 " // socket was opened in Python.\n",
1469 " var element = $(\"#\" + id);\n",
1470 " var ws_proxy = comm_websocket_adapter(comm)\n",
1471 "\n",
1472 " function ondownload(figure, format) {\n",
1473 " window.open(figure.imageObj.src);\n",
1474 " }\n",
1475 "\n",
1476 " var fig = new mpl.figure(id, ws_proxy,\n",
1477 " ondownload,\n",
1478 " element.get(0));\n",
1479 "\n",
1480 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
1481 " // web socket which is closed, not our websocket->open comm proxy.\n",
1482 " ws_proxy.onopen();\n",
1483 "\n",
1484 " fig.parent_element = element.get(0);\n",
1485 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
1486 " if (!fig.cell_info) {\n",
1487 " console.error(\"Failed to find cell for figure\", id, fig);\n",
1488 " return;\n",
1489 " }\n",
1490 "\n",
1491 " var output_index = fig.cell_info[2]\n",
1492 " var cell = fig.cell_info[0];\n",
1493 "\n",
1494 "};\n",
1495 "\n",
1496 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
1497 " var width = fig.canvas.width/mpl.ratio\n",
1498 " fig.root.unbind('remove')\n",
1499 "\n",
1500 " // Update the output cell to use the data from the current canvas.\n",
1501 " fig.push_to_output();\n",
1502 " var dataURL = fig.canvas.toDataURL();\n",
1503 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
1504 " // the notebook keyboard shortcuts fail.\n",
1505 " IPython.keyboard_manager.enable()\n",
1506 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
1507 " fig.close_ws(fig, msg);\n",
1508 "}\n",
1509 "\n",
1510 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
1511 " fig.send_message('closing', msg);\n",
1512 " // fig.ws.close()\n",
1513 "}\n",
1514 "\n",
1515 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
1516 " // Turn the data on the canvas into data in the output cell.\n",
1517 " var width = this.canvas.width/mpl.ratio\n",
1518 " var dataURL = this.canvas.toDataURL();\n",
1519 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
1520 "}\n",
1521 "\n",
1522 "mpl.figure.prototype.updated_canvas_event = function() {\n",
1523 " // Tell IPython that the notebook contents must change.\n",
1524 " IPython.notebook.set_dirty(true);\n",
1525 " this.send_message(\"ack\", {});\n",
1526 " var fig = this;\n",
1527 " // Wait a second, then push the new image to the DOM so\n",
1528 " // that it is saved nicely (might be nice to debounce this).\n",
1529 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
1530 "}\n",
1531 "\n",
1532 "mpl.figure.prototype._init_toolbar = function() {\n",
1533 " var fig = this;\n",
1534 "\n",
1535 " var nav_element = $('<div/>')\n",
1536 " nav_element.attr('style', 'width: 100%');\n",
1537 " this.root.append(nav_element);\n",
1538 "\n",
1539 " // Define a callback function for later on.\n",
1540 " function toolbar_event(event) {\n",
1541 " return fig.toolbar_button_onclick(event['data']);\n",
1542 " }\n",
1543 " function toolbar_mouse_event(event) {\n",
1544 " return fig.toolbar_button_onmouseover(event['data']);\n",
1545 " }\n",
1546 "\n",
1547 " for(var toolbar_ind in mpl.toolbar_items){\n",
1548 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
1549 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
1550 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
1551 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
1552 "\n",
1553 " if (!name) { continue; };\n",
1554 "\n",
1555 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
1556 " button.click(method_name, toolbar_event);\n",
1557 " button.mouseover(tooltip, toolbar_mouse_event);\n",
1558 " nav_element.append(button);\n",
1559 " }\n",
1560 "\n",
1561 " // Add the status bar.\n",
1562 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
1563 " nav_element.append(status_bar);\n",
1564 " this.message = status_bar[0];\n",
1565 "\n",
1566 " // Add the close button to the window.\n",
1567 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
1568 " 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",
1569 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
1570 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
1571 " buttongrp.append(button);\n",
1572 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
1573 " titlebar.prepend(buttongrp);\n",
1574 "}\n",
1575 "\n",
1576 "mpl.figure.prototype._root_extra_style = function(el){\n",
1577 " var fig = this\n",
1578 " el.on(\"remove\", function(){\n",
1579 "\tfig.close_ws(fig, {});\n",
1580 " });\n",
1581 "}\n",
1582 "\n",
1583 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
1584 " // this is important to make the div 'focusable\n",
1585 " el.attr('tabindex', 0)\n",
1586 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
1587 " // off when our div gets focus\n",
1588 "\n",
1589 " // location in version 3\n",
1590 " if (IPython.notebook.keyboard_manager) {\n",
1591 " IPython.notebook.keyboard_manager.register_events(el);\n",
1592 " }\n",
1593 " else {\n",
1594 " // location in version 2\n",
1595 " IPython.keyboard_manager.register_events(el);\n",
1596 " }\n",
1597 "\n",
1598 "}\n",
1599 "\n",
1600 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
1601 " var manager = IPython.notebook.keyboard_manager;\n",
1602 " if (!manager)\n",
1603 " manager = IPython.keyboard_manager;\n",
1604 "\n",
1605 " // Check for shift+enter\n",
1606 " if (event.shiftKey && event.which == 13) {\n",
1607 " this.canvas_div.blur();\n",
1608 " // select the cell after this one\n",
1609 " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
1610 " IPython.notebook.select(index + 1);\n",
1611 " }\n",
1612 "}\n",
1613 "\n",
1614 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
1615 " fig.ondownload(fig, null);\n",
1616 "}\n",
1617 "\n",
1618 "\n",
1619 "mpl.find_output_cell = function(html_output) {\n",
1620 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
1621 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
1622 " // IPython event is triggered only after the cells have been serialised, which for\n",
1623 " // our purposes (turning an active figure into a static one), is too late.\n",
1624 " var cells = IPython.notebook.get_cells();\n",
1625 " var ncells = cells.length;\n",
1626 " for (var i=0; i<ncells; i++) {\n",
1627 " var cell = cells[i];\n",
1628 " if (cell.cell_type === 'code'){\n",
1629 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
1630 " var data = cell.output_area.outputs[j];\n",
1631 " if (data.data) {\n",
1632 " // IPython >= 3 moved mimebundle to data attribute of output\n",
1633 " data = data.data;\n",
1634 " }\n",
1635 " if (data['text/html'] == html_output) {\n",
1636 " return [cell, data, j];\n",
1637 " }\n",
1638 " }\n",
1639 " }\n",
1640 " }\n",
1641 "}\n",
1642 "\n",
1643 "// Register the function which deals with the matplotlib target/channel.\n",
1644 "// The kernel may be null if the page has been refreshed.\n",
1645 "if (IPython.notebook.kernel != null) {\n",
1646 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
1647 "}\n"
1648 ],
1649 "text/plain": [
1650 "<IPython.core.display.Javascript object>"
1651 ]
1652 },
1653 "metadata": {},
1654 "output_type": "display_data"
1655 },
1656 {
1657 "data": {
1658 "text/html": [
1659 "<img src=\"\" width=\"1798.9499446000175\">"
1660 ],
1661 "text/plain": [
1662 "<IPython.core.display.HTML object>"
1663 ]
1664 },
1665 "metadata": {},
1666 "output_type": "display_data"
1667 },
1668 {
1669 "data": {
1670 "text/plain": [
1671 "<matplotlib.axes._subplots.AxesSubplot at 0x7f2c468e6b00>"
1672 ]
1673 },
1674 "execution_count": 13,
1675 "metadata": {},
1676 "output_type": "execute_result"
1677 }
1678 ],
1679 "source": [
1680 "plt.figure()\n",
1681 "res.SWF(0,0)[\"E1\"].plot(figsize=(18,8), title=\"Cold\")\n",
1682 "plt.figure()\n",
1683 "res.SWF(0,189)[\"E1\"].plot(figsize=(18,8),title=\"Ambient\")"
1684 ]
1685 },
1686 {
1687 "cell_type": "markdown",
1688 "metadata": {},
1689 "source": [
1690 "# FFT comparaison at F0 "
1691 ]
1692 },
1693 {
1694 "cell_type": "code",
1695 "execution_count": 42,
1696 "metadata": {
1697 "ExecuteTime": {
1698 "end_time": "2017-06-01T12:58:06.078012Z",
1699 "start_time": "2017-06-01T12:58:05.909224Z"
1700 },
1701 "scrolled": false
1702 },
1703 "outputs": [
1704 {
1705 "data": {
1706 "application/javascript": [
1707 "/* Put everything inside the global mpl namespace */\n",
1708 "window.mpl = {};\n",
1709 "\n",
1710 "\n",
1711 "mpl.get_websocket_type = function() {\n",
1712 " if (typeof(WebSocket) !== 'undefined') {\n",
1713 " return WebSocket;\n",
1714 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
1715 " return MozWebSocket;\n",
1716 " } else {\n",
1717 " alert('Your browser does not have WebSocket support.' +\n",
1718 " 'Please try Chrome, Safari or Firefox β‰₯ 6. ' +\n",
1719 " 'Firefox 4 and 5 are also supported but you ' +\n",
1720 " 'have to enable WebSockets in about:config.');\n",
1721 " };\n",
1722 "}\n",
1723 "\n",
1724 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
1725 " this.id = figure_id;\n",
1726 "\n",
1727 " this.ws = websocket;\n",
1728 "\n",
1729 " this.supports_binary = (this.ws.binaryType != undefined);\n",
1730 "\n",
1731 " if (!this.supports_binary) {\n",
1732 " var warnings = document.getElementById(\"mpl-warnings\");\n",
1733 " if (warnings) {\n",
1734 " warnings.style.display = 'block';\n",
1735 " warnings.textContent = (\n",
1736 " \"This browser does not support binary websocket messages. \" +\n",
1737 " \"Performance may be slow.\");\n",
1738 " }\n",
1739 " }\n",
1740 "\n",
1741 " this.imageObj = new Image();\n",
1742 "\n",
1743 " this.context = undefined;\n",
1744 " this.message = undefined;\n",
1745 " this.canvas = undefined;\n",
1746 " this.rubberband_canvas = undefined;\n",
1747 " this.rubberband_context = undefined;\n",
1748 " this.format_dropdown = undefined;\n",
1749 "\n",
1750 " this.image_mode = 'full';\n",
1751 "\n",
1752 " this.root = $('<div/>');\n",
1753 " this._root_extra_style(this.root)\n",
1754 " this.root.attr('style', 'display: inline-block');\n",
1755 "\n",
1756 " $(parent_element).append(this.root);\n",
1757 "\n",
1758 " this._init_header(this);\n",
1759 " this._init_canvas(this);\n",
1760 " this._init_toolbar(this);\n",
1761 "\n",
1762 " var fig = this;\n",
1763 "\n",
1764 " this.waiting = false;\n",
1765 "\n",
1766 " this.ws.onopen = function () {\n",
1767 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
1768 " fig.send_message(\"send_image_mode\", {});\n",
1769 " if (mpl.ratio != 1) {\n",
1770 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
1771 " }\n",
1772 " fig.send_message(\"refresh\", {});\n",
1773 " }\n",
1774 "\n",
1775 " this.imageObj.onload = function() {\n",
1776 " if (fig.image_mode == 'full') {\n",
1777 " // Full images could contain transparency (where diff images\n",
1778 " // almost always do), so we need to clear the canvas so that\n",
1779 " // there is no ghosting.\n",
1780 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
1781 " }\n",
1782 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
1783 " };\n",
1784 "\n",
1785 " this.imageObj.onunload = function() {\n",
1786 " this.ws.close();\n",
1787 " }\n",
1788 "\n",
1789 " this.ws.onmessage = this._make_on_message_function(this);\n",
1790 "\n",
1791 " this.ondownload = ondownload;\n",
1792 "}\n",
1793 "\n",
1794 "mpl.figure.prototype._init_header = function() {\n",
1795 " var titlebar = $(\n",
1796 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
1797 " 'ui-helper-clearfix\"/>');\n",
1798 " var titletext = $(\n",
1799 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
1800 " 'text-align: center; padding: 3px;\"/>');\n",
1801 " titlebar.append(titletext)\n",
1802 " this.root.append(titlebar);\n",
1803 " this.header = titletext[0];\n",
1804 "}\n",
1805 "\n",
1806 "\n",
1807 "\n",
1808 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
1809 "\n",
1810 "}\n",
1811 "\n",
1812 "\n",
1813 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
1814 "\n",
1815 "}\n",
1816 "\n",
1817 "mpl.figure.prototype._init_canvas = function() {\n",
1818 " var fig = this;\n",
1819 "\n",
1820 " var canvas_div = $('<div/>');\n",
1821 "\n",
1822 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
1823 "\n",
1824 " function canvas_keyboard_event(event) {\n",
1825 " return fig.key_event(event, event['data']);\n",
1826 " }\n",
1827 "\n",
1828 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
1829 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
1830 " this.canvas_div = canvas_div\n",
1831 " this._canvas_extra_style(canvas_div)\n",
1832 " this.root.append(canvas_div);\n",
1833 "\n",
1834 " var canvas = $('<canvas/>');\n",
1835 " canvas.addClass('mpl-canvas');\n",
1836 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
1837 "\n",
1838 " this.canvas = canvas[0];\n",
1839 " this.context = canvas[0].getContext(\"2d\");\n",
1840 "\n",
1841 " var backingStore = this.context.backingStorePixelRatio ||\n",
1842 "\tthis.context.webkitBackingStorePixelRatio ||\n",
1843 "\tthis.context.mozBackingStorePixelRatio ||\n",
1844 "\tthis.context.msBackingStorePixelRatio ||\n",
1845 "\tthis.context.oBackingStorePixelRatio ||\n",
1846 "\tthis.context.backingStorePixelRatio || 1;\n",
1847 "\n",
1848 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
1849 "\n",
1850 " var rubberband = $('<canvas/>');\n",
1851 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
1852 "\n",
1853 " var pass_mouse_events = true;\n",
1854 "\n",
1855 " canvas_div.resizable({\n",
1856 " start: function(event, ui) {\n",
1857 " pass_mouse_events = false;\n",
1858 " },\n",
1859 " resize: function(event, ui) {\n",
1860 " fig.request_resize(ui.size.width, ui.size.height);\n",
1861 " },\n",
1862 " stop: function(event, ui) {\n",
1863 " pass_mouse_events = true;\n",
1864 " fig.request_resize(ui.size.width, ui.size.height);\n",
1865 " },\n",
1866 " });\n",
1867 "\n",
1868 " function mouse_event_fn(event) {\n",
1869 " if (pass_mouse_events)\n",
1870 " return fig.mouse_event(event, event['data']);\n",
1871 " }\n",
1872 "\n",
1873 " rubberband.mousedown('button_press', mouse_event_fn);\n",
1874 " rubberband.mouseup('button_release', mouse_event_fn);\n",
1875 " // Throttle sequential mouse events to 1 every 20ms.\n",
1876 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
1877 "\n",
1878 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
1879 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
1880 "\n",
1881 " canvas_div.on(\"wheel\", function (event) {\n",
1882 " event = event.originalEvent;\n",
1883 " event['data'] = 'scroll'\n",
1884 " if (event.deltaY < 0) {\n",
1885 " event.step = 1;\n",
1886 " } else {\n",
1887 " event.step = -1;\n",
1888 " }\n",
1889 " mouse_event_fn(event);\n",
1890 " });\n",
1891 "\n",
1892 " canvas_div.append(canvas);\n",
1893 " canvas_div.append(rubberband);\n",
1894 "\n",
1895 " this.rubberband = rubberband;\n",
1896 " this.rubberband_canvas = rubberband[0];\n",
1897 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
1898 " this.rubberband_context.strokeStyle = \"#000000\";\n",
1899 "\n",
1900 " this._resize_canvas = function(width, height) {\n",
1901 " // Keep the size of the canvas, canvas container, and rubber band\n",
1902 " // canvas in synch.\n",
1903 " canvas_div.css('width', width)\n",
1904 " canvas_div.css('height', height)\n",
1905 "\n",
1906 " canvas.attr('width', width * mpl.ratio);\n",
1907 " canvas.attr('height', height * mpl.ratio);\n",
1908 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
1909 "\n",
1910 " rubberband.attr('width', width);\n",
1911 " rubberband.attr('height', height);\n",
1912 " }\n",
1913 "\n",
1914 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
1915 " // upon first draw.\n",
1916 " this._resize_canvas(600, 600);\n",
1917 "\n",
1918 " // Disable right mouse context menu.\n",
1919 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
1920 " return false;\n",
1921 " });\n",
1922 "\n",
1923 " function set_focus () {\n",
1924 " canvas.focus();\n",
1925 " canvas_div.focus();\n",
1926 " }\n",
1927 "\n",
1928 " window.setTimeout(set_focus, 100);\n",
1929 "}\n",
1930 "\n",
1931 "mpl.figure.prototype._init_toolbar = function() {\n",
1932 " var fig = this;\n",
1933 "\n",
1934 " var nav_element = $('<div/>')\n",
1935 " nav_element.attr('style', 'width: 100%');\n",
1936 " this.root.append(nav_element);\n",
1937 "\n",
1938 " // Define a callback function for later on.\n",
1939 " function toolbar_event(event) {\n",
1940 " return fig.toolbar_button_onclick(event['data']);\n",
1941 " }\n",
1942 " function toolbar_mouse_event(event) {\n",
1943 " return fig.toolbar_button_onmouseover(event['data']);\n",
1944 " }\n",
1945 "\n",
1946 " for(var toolbar_ind in mpl.toolbar_items) {\n",
1947 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
1948 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
1949 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
1950 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
1951 "\n",
1952 " if (!name) {\n",
1953 " // put a spacer in here.\n",
1954 " continue;\n",
1955 " }\n",
1956 " var button = $('<button/>');\n",
1957 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
1958 " 'ui-button-icon-only');\n",
1959 " button.attr('role', 'button');\n",
1960 " button.attr('aria-disabled', 'false');\n",
1961 " button.click(method_name, toolbar_event);\n",
1962 " button.mouseover(tooltip, toolbar_mouse_event);\n",
1963 "\n",
1964 " var icon_img = $('<span/>');\n",
1965 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
1966 " icon_img.addClass(image);\n",
1967 " icon_img.addClass('ui-corner-all');\n",
1968 "\n",
1969 " var tooltip_span = $('<span/>');\n",
1970 " tooltip_span.addClass('ui-button-text');\n",
1971 " tooltip_span.html(tooltip);\n",
1972 "\n",
1973 " button.append(icon_img);\n",
1974 " button.append(tooltip_span);\n",
1975 "\n",
1976 " nav_element.append(button);\n",
1977 " }\n",
1978 "\n",
1979 " var fmt_picker_span = $('<span/>');\n",
1980 "\n",
1981 " var fmt_picker = $('<select/>');\n",
1982 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
1983 " fmt_picker_span.append(fmt_picker);\n",
1984 " nav_element.append(fmt_picker_span);\n",
1985 " this.format_dropdown = fmt_picker[0];\n",
1986 "\n",
1987 " for (var ind in mpl.extensions) {\n",
1988 " var fmt = mpl.extensions[ind];\n",
1989 " var option = $(\n",
1990 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
1991 " fmt_picker.append(option)\n",
1992 " }\n",
1993 "\n",
1994 " // Add hover states to the ui-buttons\n",
1995 " $( \".ui-button\" ).hover(\n",
1996 " function() { $(this).addClass(\"ui-state-hover\");},\n",
1997 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
1998 " );\n",
1999 "\n",
2000 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
2001 " nav_element.append(status_bar);\n",
2002 " this.message = status_bar[0];\n",
2003 "}\n",
2004 "\n",
2005 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
2006 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
2007 " // which will in turn request a refresh of the image.\n",
2008 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
2009 "}\n",
2010 "\n",
2011 "mpl.figure.prototype.send_message = function(type, properties) {\n",
2012 " properties['type'] = type;\n",
2013 " properties['figure_id'] = this.id;\n",
2014 " this.ws.send(JSON.stringify(properties));\n",
2015 "}\n",
2016 "\n",
2017 "mpl.figure.prototype.send_draw_message = function() {\n",
2018 " if (!this.waiting) {\n",
2019 " this.waiting = true;\n",
2020 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
2021 " }\n",
2022 "}\n",
2023 "\n",
2024 "\n",
2025 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
2026 " var format_dropdown = fig.format_dropdown;\n",
2027 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
2028 " fig.ondownload(fig, format);\n",
2029 "}\n",
2030 "\n",
2031 "\n",
2032 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
2033 " var size = msg['size'];\n",
2034 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
2035 " fig._resize_canvas(size[0], size[1]);\n",
2036 " fig.send_message(\"refresh\", {});\n",
2037 " };\n",
2038 "}\n",
2039 "\n",
2040 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
2041 " var x0 = msg['x0'] / mpl.ratio;\n",
2042 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
2043 " var x1 = msg['x1'] / mpl.ratio;\n",
2044 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
2045 " x0 = Math.floor(x0) + 0.5;\n",
2046 " y0 = Math.floor(y0) + 0.5;\n",
2047 " x1 = Math.floor(x1) + 0.5;\n",
2048 " y1 = Math.floor(y1) + 0.5;\n",
2049 " var min_x = Math.min(x0, x1);\n",
2050 " var min_y = Math.min(y0, y1);\n",
2051 " var width = Math.abs(x1 - x0);\n",
2052 " var height = Math.abs(y1 - y0);\n",
2053 "\n",
2054 " fig.rubberband_context.clearRect(\n",
2055 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
2056 "\n",
2057 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
2058 "}\n",
2059 "\n",
2060 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
2061 " // Updates the figure title.\n",
2062 " fig.header.textContent = msg['label'];\n",
2063 "}\n",
2064 "\n",
2065 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
2066 " var cursor = msg['cursor'];\n",
2067 " switch(cursor)\n",
2068 " {\n",
2069 " case 0:\n",
2070 " cursor = 'pointer';\n",
2071 " break;\n",
2072 " case 1:\n",
2073 " cursor = 'default';\n",
2074 " break;\n",
2075 " case 2:\n",
2076 " cursor = 'crosshair';\n",
2077 " break;\n",
2078 " case 3:\n",
2079 " cursor = 'move';\n",
2080 " break;\n",
2081 " }\n",
2082 " fig.rubberband_canvas.style.cursor = cursor;\n",
2083 "}\n",
2084 "\n",
2085 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
2086 " fig.message.textContent = msg['message'];\n",
2087 "}\n",
2088 "\n",
2089 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
2090 " // Request the server to send over a new figure.\n",
2091 " fig.send_draw_message();\n",
2092 "}\n",
2093 "\n",
2094 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
2095 " fig.image_mode = msg['mode'];\n",
2096 "}\n",
2097 "\n",
2098 "mpl.figure.prototype.updated_canvas_event = function() {\n",
2099 " // Called whenever the canvas gets updated.\n",
2100 " this.send_message(\"ack\", {});\n",
2101 "}\n",
2102 "\n",
2103 "// A function to construct a web socket function for onmessage handling.\n",
2104 "// Called in the figure constructor.\n",
2105 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
2106 " return function socket_on_message(evt) {\n",
2107 " if (evt.data instanceof Blob) {\n",
2108 " /* FIXME: We get \"Resource interpreted as Image but\n",
2109 " * transferred with MIME type text/plain:\" errors on\n",
2110 " * Chrome. But how to set the MIME type? It doesn't seem\n",
2111 " * to be part of the websocket stream */\n",
2112 " evt.data.type = \"image/png\";\n",
2113 "\n",
2114 " /* Free the memory for the previous frames */\n",
2115 " if (fig.imageObj.src) {\n",
2116 " (window.URL || window.webkitURL).revokeObjectURL(\n",
2117 " fig.imageObj.src);\n",
2118 " }\n",
2119 "\n",
2120 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
2121 " evt.data);\n",
2122 " fig.updated_canvas_event();\n",
2123 " fig.waiting = false;\n",
2124 " return;\n",
2125 " }\n",
2126 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
2127 " fig.imageObj.src = evt.data;\n",
2128 " fig.updated_canvas_event();\n",
2129 " fig.waiting = false;\n",
2130 " return;\n",
2131 " }\n",
2132 "\n",
2133 " var msg = JSON.parse(evt.data);\n",
2134 " var msg_type = msg['type'];\n",
2135 "\n",
2136 " // Call the \"handle_{type}\" callback, which takes\n",
2137 " // the figure and JSON message as its only arguments.\n",
2138 " try {\n",
2139 " var callback = fig[\"handle_\" + msg_type];\n",
2140 " } catch (e) {\n",
2141 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
2142 " return;\n",
2143 " }\n",
2144 "\n",
2145 " if (callback) {\n",
2146 " try {\n",
2147 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
2148 " callback(fig, msg);\n",
2149 " } catch (e) {\n",
2150 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
2151 " }\n",
2152 " }\n",
2153 " };\n",
2154 "}\n",
2155 "\n",
2156 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
2157 "mpl.findpos = function(e) {\n",
2158 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
2159 " var targ;\n",
2160 " if (!e)\n",
2161 " e = window.event;\n",
2162 " if (e.target)\n",
2163 " targ = e.target;\n",
2164 " else if (e.srcElement)\n",
2165 " targ = e.srcElement;\n",
2166 " if (targ.nodeType == 3) // defeat Safari bug\n",
2167 " targ = targ.parentNode;\n",
2168 "\n",
2169 " // jQuery normalizes the pageX and pageY\n",
2170 " // pageX,Y are the mouse positions relative to the document\n",
2171 " // offset() returns the position of the element relative to the document\n",
2172 " var x = e.pageX - $(targ).offset().left;\n",
2173 " var y = e.pageY - $(targ).offset().top;\n",
2174 "\n",
2175 " return {\"x\": x, \"y\": y};\n",
2176 "};\n",
2177 "\n",
2178 "/*\n",
2179 " * return a copy of an object with only non-object keys\n",
2180 " * we need this to avoid circular references\n",
2181 " * http://stackoverflow.com/a/24161582/3208463\n",
2182 " */\n",
2183 "function simpleKeys (original) {\n",
2184 " return Object.keys(original).reduce(function (obj, key) {\n",
2185 " if (typeof original[key] !== 'object')\n",
2186 " obj[key] = original[key]\n",
2187 " return obj;\n",
2188 " }, {});\n",
2189 "}\n",
2190 "\n",
2191 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
2192 " var canvas_pos = mpl.findpos(event)\n",
2193 "\n",
2194 " if (name === 'button_press')\n",
2195 " {\n",
2196 " this.canvas.focus();\n",
2197 " this.canvas_div.focus();\n",
2198 " }\n",
2199 "\n",
2200 " var x = canvas_pos.x * mpl.ratio;\n",
2201 " var y = canvas_pos.y * mpl.ratio;\n",
2202 "\n",
2203 " this.send_message(name, {x: x, y: y, button: event.button,\n",
2204 " step: event.step,\n",
2205 " guiEvent: simpleKeys(event)});\n",
2206 "\n",
2207 " /* This prevents the web browser from automatically changing to\n",
2208 " * the text insertion cursor when the button is pressed. We want\n",
2209 " * to control all of the cursor setting manually through the\n",
2210 " * 'cursor' event from matplotlib */\n",
2211 " event.preventDefault();\n",
2212 " return false;\n",
2213 "}\n",
2214 "\n",
2215 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
2216 " // Handle any extra behaviour associated with a key event\n",
2217 "}\n",
2218 "\n",
2219 "mpl.figure.prototype.key_event = function(event, name) {\n",
2220 "\n",
2221 " // Prevent repeat events\n",
2222 " if (name == 'key_press')\n",
2223 " {\n",
2224 " if (event.which === this._key)\n",
2225 " return;\n",
2226 " else\n",
2227 " this._key = event.which;\n",
2228 " }\n",
2229 " if (name == 'key_release')\n",
2230 " this._key = null;\n",
2231 "\n",
2232 " var value = '';\n",
2233 " if (event.ctrlKey && event.which != 17)\n",
2234 " value += \"ctrl+\";\n",
2235 " if (event.altKey && event.which != 18)\n",
2236 " value += \"alt+\";\n",
2237 " if (event.shiftKey && event.which != 16)\n",
2238 " value += \"shift+\";\n",
2239 "\n",
2240 " value += 'k';\n",
2241 " value += event.which.toString();\n",
2242 "\n",
2243 " this._key_event_extra(event, name);\n",
2244 "\n",
2245 " this.send_message(name, {key: value,\n",
2246 " guiEvent: simpleKeys(event)});\n",
2247 " return false;\n",
2248 "}\n",
2249 "\n",
2250 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
2251 " if (name == 'download') {\n",
2252 " this.handle_save(this, null);\n",
2253 " } else {\n",
2254 " this.send_message(\"toolbar_button\", {name: name});\n",
2255 " }\n",
2256 "};\n",
2257 "\n",
2258 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
2259 " this.message.textContent = tooltip;\n",
2260 "};\n",
2261 "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",
2262 "\n",
2263 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
2264 "\n",
2265 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
2266 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
2267 " // object with the appropriate methods. Currently this is a non binary\n",
2268 " // socket, so there is still some room for performance tuning.\n",
2269 " var ws = {};\n",
2270 "\n",
2271 " ws.close = function() {\n",
2272 " comm.close()\n",
2273 " };\n",
2274 " ws.send = function(m) {\n",
2275 " //console.log('sending', m);\n",
2276 " comm.send(m);\n",
2277 " };\n",
2278 " // Register the callback with on_msg.\n",
2279 " comm.on_msg(function(msg) {\n",
2280 " //console.log('receiving', msg['content']['data'], msg);\n",
2281 " // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
2282 " ws.onmessage(msg['content']['data'])\n",
2283 " });\n",
2284 " return ws;\n",
2285 "}\n",
2286 "\n",
2287 "mpl.mpl_figure_comm = function(comm, msg) {\n",
2288 " // This is the function which gets called when the mpl process\n",
2289 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
2290 "\n",
2291 " var id = msg.content.data.id;\n",
2292 " // Get hold of the div created by the display call when the Comm\n",
2293 " // socket was opened in Python.\n",
2294 " var element = $(\"#\" + id);\n",
2295 " var ws_proxy = comm_websocket_adapter(comm)\n",
2296 "\n",
2297 " function ondownload(figure, format) {\n",
2298 " window.open(figure.imageObj.src);\n",
2299 " }\n",
2300 "\n",
2301 " var fig = new mpl.figure(id, ws_proxy,\n",
2302 " ondownload,\n",
2303 " element.get(0));\n",
2304 "\n",
2305 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
2306 " // web socket which is closed, not our websocket->open comm proxy.\n",
2307 " ws_proxy.onopen();\n",
2308 "\n",
2309 " fig.parent_element = element.get(0);\n",
2310 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
2311 " if (!fig.cell_info) {\n",
2312 " console.error(\"Failed to find cell for figure\", id, fig);\n",
2313 " return;\n",
2314 " }\n",
2315 "\n",
2316 " var output_index = fig.cell_info[2]\n",
2317 " var cell = fig.cell_info[0];\n",
2318 "\n",
2319 "};\n",
2320 "\n",
2321 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
2322 " var width = fig.canvas.width/mpl.ratio\n",
2323 " fig.root.unbind('remove')\n",
2324 "\n",
2325 " // Update the output cell to use the data from the current canvas.\n",
2326 " fig.push_to_output();\n",
2327 " var dataURL = fig.canvas.toDataURL();\n",
2328 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
2329 " // the notebook keyboard shortcuts fail.\n",
2330 " IPython.keyboard_manager.enable()\n",
2331 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
2332 " fig.close_ws(fig, msg);\n",
2333 "}\n",
2334 "\n",
2335 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
2336 " fig.send_message('closing', msg);\n",
2337 " // fig.ws.close()\n",
2338 "}\n",
2339 "\n",
2340 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
2341 " // Turn the data on the canvas into data in the output cell.\n",
2342 " var width = this.canvas.width/mpl.ratio\n",
2343 " var dataURL = this.canvas.toDataURL();\n",
2344 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
2345 "}\n",
2346 "\n",
2347 "mpl.figure.prototype.updated_canvas_event = function() {\n",
2348 " // Tell IPython that the notebook contents must change.\n",
2349 " IPython.notebook.set_dirty(true);\n",
2350 " this.send_message(\"ack\", {});\n",
2351 " var fig = this;\n",
2352 " // Wait a second, then push the new image to the DOM so\n",
2353 " // that it is saved nicely (might be nice to debounce this).\n",
2354 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
2355 "}\n",
2356 "\n",
2357 "mpl.figure.prototype._init_toolbar = function() {\n",
2358 " var fig = this;\n",
2359 "\n",
2360 " var nav_element = $('<div/>')\n",
2361 " nav_element.attr('style', 'width: 100%');\n",
2362 " this.root.append(nav_element);\n",
2363 "\n",
2364 " // Define a callback function for later on.\n",
2365 " function toolbar_event(event) {\n",
2366 " return fig.toolbar_button_onclick(event['data']);\n",
2367 " }\n",
2368 " function toolbar_mouse_event(event) {\n",
2369 " return fig.toolbar_button_onmouseover(event['data']);\n",
2370 " }\n",
2371 "\n",
2372 " for(var toolbar_ind in mpl.toolbar_items){\n",
2373 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
2374 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
2375 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
2376 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
2377 "\n",
2378 " if (!name) { continue; };\n",
2379 "\n",
2380 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
2381 " button.click(method_name, toolbar_event);\n",
2382 " button.mouseover(tooltip, toolbar_mouse_event);\n",
2383 " nav_element.append(button);\n",
2384 " }\n",
2385 "\n",
2386 " // Add the status bar.\n",
2387 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
2388 " nav_element.append(status_bar);\n",
2389 " this.message = status_bar[0];\n",
2390 "\n",
2391 " // Add the close button to the window.\n",
2392 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
2393 " 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",
2394 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
2395 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
2396 " buttongrp.append(button);\n",
2397 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
2398 " titlebar.prepend(buttongrp);\n",
2399 "}\n",
2400 "\n",
2401 "mpl.figure.prototype._root_extra_style = function(el){\n",
2402 " var fig = this\n",
2403 " el.on(\"remove\", function(){\n",
2404 "\tfig.close_ws(fig, {});\n",
2405 " });\n",
2406 "}\n",
2407 "\n",
2408 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
2409 " // this is important to make the div 'focusable\n",
2410 " el.attr('tabindex', 0)\n",
2411 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
2412 " // off when our div gets focus\n",
2413 "\n",
2414 " // location in version 3\n",
2415 " if (IPython.notebook.keyboard_manager) {\n",
2416 " IPython.notebook.keyboard_manager.register_events(el);\n",
2417 " }\n",
2418 " else {\n",
2419 " // location in version 2\n",
2420 " IPython.keyboard_manager.register_events(el);\n",
2421 " }\n",
2422 "\n",
2423 "}\n",
2424 "\n",
2425 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
2426 " var manager = IPython.notebook.keyboard_manager;\n",
2427 " if (!manager)\n",
2428 " manager = IPython.keyboard_manager;\n",
2429 "\n",
2430 " // Check for shift+enter\n",
2431 " if (event.shiftKey && event.which == 13) {\n",
2432 " this.canvas_div.blur();\n",
2433 " // select the cell after this one\n",
2434 " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
2435 " IPython.notebook.select(index + 1);\n",
2436 " }\n",
2437 "}\n",
2438 "\n",
2439 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
2440 " fig.ondownload(fig, null);\n",
2441 "}\n",
2442 "\n",
2443 "\n",
2444 "mpl.find_output_cell = function(html_output) {\n",
2445 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
2446 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
2447 " // IPython event is triggered only after the cells have been serialised, which for\n",
2448 " // our purposes (turning an active figure into a static one), is too late.\n",
2449 " var cells = IPython.notebook.get_cells();\n",
2450 " var ncells = cells.length;\n",
2451 " for (var i=0; i<ncells; i++) {\n",
2452 " var cell = cells[i];\n",
2453 " if (cell.cell_type === 'code'){\n",
2454 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
2455 " var data = cell.output_area.outputs[j];\n",
2456 " if (data.data) {\n",
2457 " // IPython >= 3 moved mimebundle to data attribute of output\n",
2458 " data = data.data;\n",
2459 " }\n",
2460 " if (data['text/html'] == html_output) {\n",
2461 " return [cell, data, j];\n",
2462 " }\n",
2463 " }\n",
2464 " }\n",
2465 " }\n",
2466 "}\n",
2467 "\n",
2468 "// Register the function which deals with the matplotlib target/channel.\n",
2469 "// The kernel may be null if the page has been refreshed.\n",
2470 "if (IPython.notebook.kernel != null) {\n",
2471 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
2472 "}\n"
2473 ],
2474 "text/plain": [
2475 "<IPython.core.display.Javascript object>"
2476 ]
2477 },
2478 "metadata": {},
2479 "output_type": "display_data"
2480 },
2481 {
2482 "data": {
2483 "text/html": [
2484 "<img src=\"\" width=\"1599.0666174222379\">"
2485 ],
2486 "text/plain": [
2487 "<IPython.core.display.HTML object>"
2488 ]
2489 },
2490 "metadata": {},
2491 "output_type": "display_data"
2492 },
2493 {
2494 "data": {
2495 "text/plain": [
2496 "<matplotlib.legend.Legend at 0x7f2c3bf1cc50>"
2497 ]
2498 },
2499 "execution_count": 42,
2500 "metadata": {},
2501 "output_type": "execute_result"
2502 }
2503 ],
2504 "source": [
2505 "plt.figure()\n",
2506 "for case in [(0,\"cold\"),(189,\"ambient\")]:\n",
2507 " fft=TF.fft(res.SWF(0,case[0])[\"E1\"],sampling_frequency=24576,window=np.hanning(2048))\n",
2508 " fft=pds.DataFrame(fft)\n",
2509 " fft=fft.set_index(\"f\").drop([0.0])[\"mod\"]\n",
2510 " fft.name=case[1]\n",
2511 " fft.plot()\n",
2512 " plt.loglog()\n",
2513 "plt.legend()"
2514 ]
2515 },
2516 {
2517 "cell_type": "markdown",
2518 "metadata": {
2519 "ExecuteTime": {
2520 "end_time": "2017-06-01T12:34:44.676201Z",
2521 "start_time": "2017-06-01T12:34:44.671776Z"
2522 }
2523 },
2524 "source": [
2525 "# FFT comparaison at F1"
2526 ]
2527 },
2528 {
2529 "cell_type": "code",
2530 "execution_count": 45,
2531 "metadata": {
2532 "ExecuteTime": {
2533 "end_time": "2017-06-01T13:39:36.109003Z",
2534 "start_time": "2017-06-01T13:39:35.931478Z"
2535 }
2536 },
2537 "outputs": [
2538 {
2539 "data": {
2540 "application/javascript": [
2541 "/* Put everything inside the global mpl namespace */\n",
2542 "window.mpl = {};\n",
2543 "\n",
2544 "\n",
2545 "mpl.get_websocket_type = function() {\n",
2546 " if (typeof(WebSocket) !== 'undefined') {\n",
2547 " return WebSocket;\n",
2548 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
2549 " return MozWebSocket;\n",
2550 " } else {\n",
2551 " alert('Your browser does not have WebSocket support.' +\n",
2552 " 'Please try Chrome, Safari or Firefox β‰₯ 6. ' +\n",
2553 " 'Firefox 4 and 5 are also supported but you ' +\n",
2554 " 'have to enable WebSockets in about:config.');\n",
2555 " };\n",
2556 "}\n",
2557 "\n",
2558 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
2559 " this.id = figure_id;\n",
2560 "\n",
2561 " this.ws = websocket;\n",
2562 "\n",
2563 " this.supports_binary = (this.ws.binaryType != undefined);\n",
2564 "\n",
2565 " if (!this.supports_binary) {\n",
2566 " var warnings = document.getElementById(\"mpl-warnings\");\n",
2567 " if (warnings) {\n",
2568 " warnings.style.display = 'block';\n",
2569 " warnings.textContent = (\n",
2570 " \"This browser does not support binary websocket messages. \" +\n",
2571 " \"Performance may be slow.\");\n",
2572 " }\n",
2573 " }\n",
2574 "\n",
2575 " this.imageObj = new Image();\n",
2576 "\n",
2577 " this.context = undefined;\n",
2578 " this.message = undefined;\n",
2579 " this.canvas = undefined;\n",
2580 " this.rubberband_canvas = undefined;\n",
2581 " this.rubberband_context = undefined;\n",
2582 " this.format_dropdown = undefined;\n",
2583 "\n",
2584 " this.image_mode = 'full';\n",
2585 "\n",
2586 " this.root = $('<div/>');\n",
2587 " this._root_extra_style(this.root)\n",
2588 " this.root.attr('style', 'display: inline-block');\n",
2589 "\n",
2590 " $(parent_element).append(this.root);\n",
2591 "\n",
2592 " this._init_header(this);\n",
2593 " this._init_canvas(this);\n",
2594 " this._init_toolbar(this);\n",
2595 "\n",
2596 " var fig = this;\n",
2597 "\n",
2598 " this.waiting = false;\n",
2599 "\n",
2600 " this.ws.onopen = function () {\n",
2601 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
2602 " fig.send_message(\"send_image_mode\", {});\n",
2603 " if (mpl.ratio != 1) {\n",
2604 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
2605 " }\n",
2606 " fig.send_message(\"refresh\", {});\n",
2607 " }\n",
2608 "\n",
2609 " this.imageObj.onload = function() {\n",
2610 " if (fig.image_mode == 'full') {\n",
2611 " // Full images could contain transparency (where diff images\n",
2612 " // almost always do), so we need to clear the canvas so that\n",
2613 " // there is no ghosting.\n",
2614 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
2615 " }\n",
2616 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
2617 " };\n",
2618 "\n",
2619 " this.imageObj.onunload = function() {\n",
2620 " this.ws.close();\n",
2621 " }\n",
2622 "\n",
2623 " this.ws.onmessage = this._make_on_message_function(this);\n",
2624 "\n",
2625 " this.ondownload = ondownload;\n",
2626 "}\n",
2627 "\n",
2628 "mpl.figure.prototype._init_header = function() {\n",
2629 " var titlebar = $(\n",
2630 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
2631 " 'ui-helper-clearfix\"/>');\n",
2632 " var titletext = $(\n",
2633 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
2634 " 'text-align: center; padding: 3px;\"/>');\n",
2635 " titlebar.append(titletext)\n",
2636 " this.root.append(titlebar);\n",
2637 " this.header = titletext[0];\n",
2638 "}\n",
2639 "\n",
2640 "\n",
2641 "\n",
2642 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
2643 "\n",
2644 "}\n",
2645 "\n",
2646 "\n",
2647 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
2648 "\n",
2649 "}\n",
2650 "\n",
2651 "mpl.figure.prototype._init_canvas = function() {\n",
2652 " var fig = this;\n",
2653 "\n",
2654 " var canvas_div = $('<div/>');\n",
2655 "\n",
2656 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
2657 "\n",
2658 " function canvas_keyboard_event(event) {\n",
2659 " return fig.key_event(event, event['data']);\n",
2660 " }\n",
2661 "\n",
2662 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
2663 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
2664 " this.canvas_div = canvas_div\n",
2665 " this._canvas_extra_style(canvas_div)\n",
2666 " this.root.append(canvas_div);\n",
2667 "\n",
2668 " var canvas = $('<canvas/>');\n",
2669 " canvas.addClass('mpl-canvas');\n",
2670 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
2671 "\n",
2672 " this.canvas = canvas[0];\n",
2673 " this.context = canvas[0].getContext(\"2d\");\n",
2674 "\n",
2675 " var backingStore = this.context.backingStorePixelRatio ||\n",
2676 "\tthis.context.webkitBackingStorePixelRatio ||\n",
2677 "\tthis.context.mozBackingStorePixelRatio ||\n",
2678 "\tthis.context.msBackingStorePixelRatio ||\n",
2679 "\tthis.context.oBackingStorePixelRatio ||\n",
2680 "\tthis.context.backingStorePixelRatio || 1;\n",
2681 "\n",
2682 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
2683 "\n",
2684 " var rubberband = $('<canvas/>');\n",
2685 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
2686 "\n",
2687 " var pass_mouse_events = true;\n",
2688 "\n",
2689 " canvas_div.resizable({\n",
2690 " start: function(event, ui) {\n",
2691 " pass_mouse_events = false;\n",
2692 " },\n",
2693 " resize: function(event, ui) {\n",
2694 " fig.request_resize(ui.size.width, ui.size.height);\n",
2695 " },\n",
2696 " stop: function(event, ui) {\n",
2697 " pass_mouse_events = true;\n",
2698 " fig.request_resize(ui.size.width, ui.size.height);\n",
2699 " },\n",
2700 " });\n",
2701 "\n",
2702 " function mouse_event_fn(event) {\n",
2703 " if (pass_mouse_events)\n",
2704 " return fig.mouse_event(event, event['data']);\n",
2705 " }\n",
2706 "\n",
2707 " rubberband.mousedown('button_press', mouse_event_fn);\n",
2708 " rubberband.mouseup('button_release', mouse_event_fn);\n",
2709 " // Throttle sequential mouse events to 1 every 20ms.\n",
2710 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
2711 "\n",
2712 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
2713 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
2714 "\n",
2715 " canvas_div.on(\"wheel\", function (event) {\n",
2716 " event = event.originalEvent;\n",
2717 " event['data'] = 'scroll'\n",
2718 " if (event.deltaY < 0) {\n",
2719 " event.step = 1;\n",
2720 " } else {\n",
2721 " event.step = -1;\n",
2722 " }\n",
2723 " mouse_event_fn(event);\n",
2724 " });\n",
2725 "\n",
2726 " canvas_div.append(canvas);\n",
2727 " canvas_div.append(rubberband);\n",
2728 "\n",
2729 " this.rubberband = rubberband;\n",
2730 " this.rubberband_canvas = rubberband[0];\n",
2731 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
2732 " this.rubberband_context.strokeStyle = \"#000000\";\n",
2733 "\n",
2734 " this._resize_canvas = function(width, height) {\n",
2735 " // Keep the size of the canvas, canvas container, and rubber band\n",
2736 " // canvas in synch.\n",
2737 " canvas_div.css('width', width)\n",
2738 " canvas_div.css('height', height)\n",
2739 "\n",
2740 " canvas.attr('width', width * mpl.ratio);\n",
2741 " canvas.attr('height', height * mpl.ratio);\n",
2742 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
2743 "\n",
2744 " rubberband.attr('width', width);\n",
2745 " rubberband.attr('height', height);\n",
2746 " }\n",
2747 "\n",
2748 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
2749 " // upon first draw.\n",
2750 " this._resize_canvas(600, 600);\n",
2751 "\n",
2752 " // Disable right mouse context menu.\n",
2753 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
2754 " return false;\n",
2755 " });\n",
2756 "\n",
2757 " function set_focus () {\n",
2758 " canvas.focus();\n",
2759 " canvas_div.focus();\n",
2760 " }\n",
2761 "\n",
2762 " window.setTimeout(set_focus, 100);\n",
2763 "}\n",
2764 "\n",
2765 "mpl.figure.prototype._init_toolbar = function() {\n",
2766 " var fig = this;\n",
2767 "\n",
2768 " var nav_element = $('<div/>')\n",
2769 " nav_element.attr('style', 'width: 100%');\n",
2770 " this.root.append(nav_element);\n",
2771 "\n",
2772 " // Define a callback function for later on.\n",
2773 " function toolbar_event(event) {\n",
2774 " return fig.toolbar_button_onclick(event['data']);\n",
2775 " }\n",
2776 " function toolbar_mouse_event(event) {\n",
2777 " return fig.toolbar_button_onmouseover(event['data']);\n",
2778 " }\n",
2779 "\n",
2780 " for(var toolbar_ind in mpl.toolbar_items) {\n",
2781 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
2782 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
2783 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
2784 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
2785 "\n",
2786 " if (!name) {\n",
2787 " // put a spacer in here.\n",
2788 " continue;\n",
2789 " }\n",
2790 " var button = $('<button/>');\n",
2791 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
2792 " 'ui-button-icon-only');\n",
2793 " button.attr('role', 'button');\n",
2794 " button.attr('aria-disabled', 'false');\n",
2795 " button.click(method_name, toolbar_event);\n",
2796 " button.mouseover(tooltip, toolbar_mouse_event);\n",
2797 "\n",
2798 " var icon_img = $('<span/>');\n",
2799 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
2800 " icon_img.addClass(image);\n",
2801 " icon_img.addClass('ui-corner-all');\n",
2802 "\n",
2803 " var tooltip_span = $('<span/>');\n",
2804 " tooltip_span.addClass('ui-button-text');\n",
2805 " tooltip_span.html(tooltip);\n",
2806 "\n",
2807 " button.append(icon_img);\n",
2808 " button.append(tooltip_span);\n",
2809 "\n",
2810 " nav_element.append(button);\n",
2811 " }\n",
2812 "\n",
2813 " var fmt_picker_span = $('<span/>');\n",
2814 "\n",
2815 " var fmt_picker = $('<select/>');\n",
2816 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
2817 " fmt_picker_span.append(fmt_picker);\n",
2818 " nav_element.append(fmt_picker_span);\n",
2819 " this.format_dropdown = fmt_picker[0];\n",
2820 "\n",
2821 " for (var ind in mpl.extensions) {\n",
2822 " var fmt = mpl.extensions[ind];\n",
2823 " var option = $(\n",
2824 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
2825 " fmt_picker.append(option)\n",
2826 " }\n",
2827 "\n",
2828 " // Add hover states to the ui-buttons\n",
2829 " $( \".ui-button\" ).hover(\n",
2830 " function() { $(this).addClass(\"ui-state-hover\");},\n",
2831 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
2832 " );\n",
2833 "\n",
2834 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
2835 " nav_element.append(status_bar);\n",
2836 " this.message = status_bar[0];\n",
2837 "}\n",
2838 "\n",
2839 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
2840 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
2841 " // which will in turn request a refresh of the image.\n",
2842 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
2843 "}\n",
2844 "\n",
2845 "mpl.figure.prototype.send_message = function(type, properties) {\n",
2846 " properties['type'] = type;\n",
2847 " properties['figure_id'] = this.id;\n",
2848 " this.ws.send(JSON.stringify(properties));\n",
2849 "}\n",
2850 "\n",
2851 "mpl.figure.prototype.send_draw_message = function() {\n",
2852 " if (!this.waiting) {\n",
2853 " this.waiting = true;\n",
2854 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
2855 " }\n",
2856 "}\n",
2857 "\n",
2858 "\n",
2859 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
2860 " var format_dropdown = fig.format_dropdown;\n",
2861 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
2862 " fig.ondownload(fig, format);\n",
2863 "}\n",
2864 "\n",
2865 "\n",
2866 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
2867 " var size = msg['size'];\n",
2868 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
2869 " fig._resize_canvas(size[0], size[1]);\n",
2870 " fig.send_message(\"refresh\", {});\n",
2871 " };\n",
2872 "}\n",
2873 "\n",
2874 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
2875 " var x0 = msg['x0'] / mpl.ratio;\n",
2876 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
2877 " var x1 = msg['x1'] / mpl.ratio;\n",
2878 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
2879 " x0 = Math.floor(x0) + 0.5;\n",
2880 " y0 = Math.floor(y0) + 0.5;\n",
2881 " x1 = Math.floor(x1) + 0.5;\n",
2882 " y1 = Math.floor(y1) + 0.5;\n",
2883 " var min_x = Math.min(x0, x1);\n",
2884 " var min_y = Math.min(y0, y1);\n",
2885 " var width = Math.abs(x1 - x0);\n",
2886 " var height = Math.abs(y1 - y0);\n",
2887 "\n",
2888 " fig.rubberband_context.clearRect(\n",
2889 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
2890 "\n",
2891 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
2892 "}\n",
2893 "\n",
2894 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
2895 " // Updates the figure title.\n",
2896 " fig.header.textContent = msg['label'];\n",
2897 "}\n",
2898 "\n",
2899 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
2900 " var cursor = msg['cursor'];\n",
2901 " switch(cursor)\n",
2902 " {\n",
2903 " case 0:\n",
2904 " cursor = 'pointer';\n",
2905 " break;\n",
2906 " case 1:\n",
2907 " cursor = 'default';\n",
2908 " break;\n",
2909 " case 2:\n",
2910 " cursor = 'crosshair';\n",
2911 " break;\n",
2912 " case 3:\n",
2913 " cursor = 'move';\n",
2914 " break;\n",
2915 " }\n",
2916 " fig.rubberband_canvas.style.cursor = cursor;\n",
2917 "}\n",
2918 "\n",
2919 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
2920 " fig.message.textContent = msg['message'];\n",
2921 "}\n",
2922 "\n",
2923 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
2924 " // Request the server to send over a new figure.\n",
2925 " fig.send_draw_message();\n",
2926 "}\n",
2927 "\n",
2928 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
2929 " fig.image_mode = msg['mode'];\n",
2930 "}\n",
2931 "\n",
2932 "mpl.figure.prototype.updated_canvas_event = function() {\n",
2933 " // Called whenever the canvas gets updated.\n",
2934 " this.send_message(\"ack\", {});\n",
2935 "}\n",
2936 "\n",
2937 "// A function to construct a web socket function for onmessage handling.\n",
2938 "// Called in the figure constructor.\n",
2939 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
2940 " return function socket_on_message(evt) {\n",
2941 " if (evt.data instanceof Blob) {\n",
2942 " /* FIXME: We get \"Resource interpreted as Image but\n",
2943 " * transferred with MIME type text/plain:\" errors on\n",
2944 " * Chrome. But how to set the MIME type? It doesn't seem\n",
2945 " * to be part of the websocket stream */\n",
2946 " evt.data.type = \"image/png\";\n",
2947 "\n",
2948 " /* Free the memory for the previous frames */\n",
2949 " if (fig.imageObj.src) {\n",
2950 " (window.URL || window.webkitURL).revokeObjectURL(\n",
2951 " fig.imageObj.src);\n",
2952 " }\n",
2953 "\n",
2954 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
2955 " evt.data);\n",
2956 " fig.updated_canvas_event();\n",
2957 " fig.waiting = false;\n",
2958 " return;\n",
2959 " }\n",
2960 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
2961 " fig.imageObj.src = evt.data;\n",
2962 " fig.updated_canvas_event();\n",
2963 " fig.waiting = false;\n",
2964 " return;\n",
2965 " }\n",
2966 "\n",
2967 " var msg = JSON.parse(evt.data);\n",
2968 " var msg_type = msg['type'];\n",
2969 "\n",
2970 " // Call the \"handle_{type}\" callback, which takes\n",
2971 " // the figure and JSON message as its only arguments.\n",
2972 " try {\n",
2973 " var callback = fig[\"handle_\" + msg_type];\n",
2974 " } catch (e) {\n",
2975 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
2976 " return;\n",
2977 " }\n",
2978 "\n",
2979 " if (callback) {\n",
2980 " try {\n",
2981 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
2982 " callback(fig, msg);\n",
2983 " } catch (e) {\n",
2984 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
2985 " }\n",
2986 " }\n",
2987 " };\n",
2988 "}\n",
2989 "\n",
2990 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
2991 "mpl.findpos = function(e) {\n",
2992 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
2993 " var targ;\n",
2994 " if (!e)\n",
2995 " e = window.event;\n",
2996 " if (e.target)\n",
2997 " targ = e.target;\n",
2998 " else if (e.srcElement)\n",
2999 " targ = e.srcElement;\n",
3000 " if (targ.nodeType == 3) // defeat Safari bug\n",
3001 " targ = targ.parentNode;\n",
3002 "\n",
3003 " // jQuery normalizes the pageX and pageY\n",
3004 " // pageX,Y are the mouse positions relative to the document\n",
3005 " // offset() returns the position of the element relative to the document\n",
3006 " var x = e.pageX - $(targ).offset().left;\n",
3007 " var y = e.pageY - $(targ).offset().top;\n",
3008 "\n",
3009 " return {\"x\": x, \"y\": y};\n",
3010 "};\n",
3011 "\n",
3012 "/*\n",
3013 " * return a copy of an object with only non-object keys\n",
3014 " * we need this to avoid circular references\n",
3015 " * http://stackoverflow.com/a/24161582/3208463\n",
3016 " */\n",
3017 "function simpleKeys (original) {\n",
3018 " return Object.keys(original).reduce(function (obj, key) {\n",
3019 " if (typeof original[key] !== 'object')\n",
3020 " obj[key] = original[key]\n",
3021 " return obj;\n",
3022 " }, {});\n",
3023 "}\n",
3024 "\n",
3025 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
3026 " var canvas_pos = mpl.findpos(event)\n",
3027 "\n",
3028 " if (name === 'button_press')\n",
3029 " {\n",
3030 " this.canvas.focus();\n",
3031 " this.canvas_div.focus();\n",
3032 " }\n",
3033 "\n",
3034 " var x = canvas_pos.x * mpl.ratio;\n",
3035 " var y = canvas_pos.y * mpl.ratio;\n",
3036 "\n",
3037 " this.send_message(name, {x: x, y: y, button: event.button,\n",
3038 " step: event.step,\n",
3039 " guiEvent: simpleKeys(event)});\n",
3040 "\n",
3041 " /* This prevents the web browser from automatically changing to\n",
3042 " * the text insertion cursor when the button is pressed. We want\n",
3043 " * to control all of the cursor setting manually through the\n",
3044 " * 'cursor' event from matplotlib */\n",
3045 " event.preventDefault();\n",
3046 " return false;\n",
3047 "}\n",
3048 "\n",
3049 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
3050 " // Handle any extra behaviour associated with a key event\n",
3051 "}\n",
3052 "\n",
3053 "mpl.figure.prototype.key_event = function(event, name) {\n",
3054 "\n",
3055 " // Prevent repeat events\n",
3056 " if (name == 'key_press')\n",
3057 " {\n",
3058 " if (event.which === this._key)\n",
3059 " return;\n",
3060 " else\n",
3061 " this._key = event.which;\n",
3062 " }\n",
3063 " if (name == 'key_release')\n",
3064 " this._key = null;\n",
3065 "\n",
3066 " var value = '';\n",
3067 " if (event.ctrlKey && event.which != 17)\n",
3068 " value += \"ctrl+\";\n",
3069 " if (event.altKey && event.which != 18)\n",
3070 " value += \"alt+\";\n",
3071 " if (event.shiftKey && event.which != 16)\n",
3072 " value += \"shift+\";\n",
3073 "\n",
3074 " value += 'k';\n",
3075 " value += event.which.toString();\n",
3076 "\n",
3077 " this._key_event_extra(event, name);\n",
3078 "\n",
3079 " this.send_message(name, {key: value,\n",
3080 " guiEvent: simpleKeys(event)});\n",
3081 " return false;\n",
3082 "}\n",
3083 "\n",
3084 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
3085 " if (name == 'download') {\n",
3086 " this.handle_save(this, null);\n",
3087 " } else {\n",
3088 " this.send_message(\"toolbar_button\", {name: name});\n",
3089 " }\n",
3090 "};\n",
3091 "\n",
3092 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
3093 " this.message.textContent = tooltip;\n",
3094 "};\n",
3095 "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",
3096 "\n",
3097 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
3098 "\n",
3099 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
3100 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
3101 " // object with the appropriate methods. Currently this is a non binary\n",
3102 " // socket, so there is still some room for performance tuning.\n",
3103 " var ws = {};\n",
3104 "\n",
3105 " ws.close = function() {\n",
3106 " comm.close()\n",
3107 " };\n",
3108 " ws.send = function(m) {\n",
3109 " //console.log('sending', m);\n",
3110 " comm.send(m);\n",
3111 " };\n",
3112 " // Register the callback with on_msg.\n",
3113 " comm.on_msg(function(msg) {\n",
3114 " //console.log('receiving', msg['content']['data'], msg);\n",
3115 " // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
3116 " ws.onmessage(msg['content']['data'])\n",
3117 " });\n",
3118 " return ws;\n",
3119 "}\n",
3120 "\n",
3121 "mpl.mpl_figure_comm = function(comm, msg) {\n",
3122 " // This is the function which gets called when the mpl process\n",
3123 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
3124 "\n",
3125 " var id = msg.content.data.id;\n",
3126 " // Get hold of the div created by the display call when the Comm\n",
3127 " // socket was opened in Python.\n",
3128 " var element = $(\"#\" + id);\n",
3129 " var ws_proxy = comm_websocket_adapter(comm)\n",
3130 "\n",
3131 " function ondownload(figure, format) {\n",
3132 " window.open(figure.imageObj.src);\n",
3133 " }\n",
3134 "\n",
3135 " var fig = new mpl.figure(id, ws_proxy,\n",
3136 " ondownload,\n",
3137 " element.get(0));\n",
3138 "\n",
3139 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
3140 " // web socket which is closed, not our websocket->open comm proxy.\n",
3141 " ws_proxy.onopen();\n",
3142 "\n",
3143 " fig.parent_element = element.get(0);\n",
3144 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
3145 " if (!fig.cell_info) {\n",
3146 " console.error(\"Failed to find cell for figure\", id, fig);\n",
3147 " return;\n",
3148 " }\n",
3149 "\n",
3150 " var output_index = fig.cell_info[2]\n",
3151 " var cell = fig.cell_info[0];\n",
3152 "\n",
3153 "};\n",
3154 "\n",
3155 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
3156 " var width = fig.canvas.width/mpl.ratio\n",
3157 " fig.root.unbind('remove')\n",
3158 "\n",
3159 " // Update the output cell to use the data from the current canvas.\n",
3160 " fig.push_to_output();\n",
3161 " var dataURL = fig.canvas.toDataURL();\n",
3162 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
3163 " // the notebook keyboard shortcuts fail.\n",
3164 " IPython.keyboard_manager.enable()\n",
3165 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
3166 " fig.close_ws(fig, msg);\n",
3167 "}\n",
3168 "\n",
3169 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
3170 " fig.send_message('closing', msg);\n",
3171 " // fig.ws.close()\n",
3172 "}\n",
3173 "\n",
3174 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
3175 " // Turn the data on the canvas into data in the output cell.\n",
3176 " var width = this.canvas.width/mpl.ratio\n",
3177 " var dataURL = this.canvas.toDataURL();\n",
3178 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
3179 "}\n",
3180 "\n",
3181 "mpl.figure.prototype.updated_canvas_event = function() {\n",
3182 " // Tell IPython that the notebook contents must change.\n",
3183 " IPython.notebook.set_dirty(true);\n",
3184 " this.send_message(\"ack\", {});\n",
3185 " var fig = this;\n",
3186 " // Wait a second, then push the new image to the DOM so\n",
3187 " // that it is saved nicely (might be nice to debounce this).\n",
3188 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
3189 "}\n",
3190 "\n",
3191 "mpl.figure.prototype._init_toolbar = function() {\n",
3192 " var fig = this;\n",
3193 "\n",
3194 " var nav_element = $('<div/>')\n",
3195 " nav_element.attr('style', 'width: 100%');\n",
3196 " this.root.append(nav_element);\n",
3197 "\n",
3198 " // Define a callback function for later on.\n",
3199 " function toolbar_event(event) {\n",
3200 " return fig.toolbar_button_onclick(event['data']);\n",
3201 " }\n",
3202 " function toolbar_mouse_event(event) {\n",
3203 " return fig.toolbar_button_onmouseover(event['data']);\n",
3204 " }\n",
3205 "\n",
3206 " for(var toolbar_ind in mpl.toolbar_items){\n",
3207 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
3208 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
3209 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
3210 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
3211 "\n",
3212 " if (!name) { continue; };\n",
3213 "\n",
3214 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
3215 " button.click(method_name, toolbar_event);\n",
3216 " button.mouseover(tooltip, toolbar_mouse_event);\n",
3217 " nav_element.append(button);\n",
3218 " }\n",
3219 "\n",
3220 " // Add the status bar.\n",
3221 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
3222 " nav_element.append(status_bar);\n",
3223 " this.message = status_bar[0];\n",
3224 "\n",
3225 " // Add the close button to the window.\n",
3226 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
3227 " 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",
3228 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
3229 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
3230 " buttongrp.append(button);\n",
3231 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
3232 " titlebar.prepend(buttongrp);\n",
3233 "}\n",
3234 "\n",
3235 "mpl.figure.prototype._root_extra_style = function(el){\n",
3236 " var fig = this\n",
3237 " el.on(\"remove\", function(){\n",
3238 "\tfig.close_ws(fig, {});\n",
3239 " });\n",
3240 "}\n",
3241 "\n",
3242 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
3243 " // this is important to make the div 'focusable\n",
3244 " el.attr('tabindex', 0)\n",
3245 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
3246 " // off when our div gets focus\n",
3247 "\n",
3248 " // location in version 3\n",
3249 " if (IPython.notebook.keyboard_manager) {\n",
3250 " IPython.notebook.keyboard_manager.register_events(el);\n",
3251 " }\n",
3252 " else {\n",
3253 " // location in version 2\n",
3254 " IPython.keyboard_manager.register_events(el);\n",
3255 " }\n",
3256 "\n",
3257 "}\n",
3258 "\n",
3259 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
3260 " var manager = IPython.notebook.keyboard_manager;\n",
3261 " if (!manager)\n",
3262 " manager = IPython.keyboard_manager;\n",
3263 "\n",
3264 " // Check for shift+enter\n",
3265 " if (event.shiftKey && event.which == 13) {\n",
3266 " this.canvas_div.blur();\n",
3267 " // select the cell after this one\n",
3268 " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
3269 " IPython.notebook.select(index + 1);\n",
3270 " }\n",
3271 "}\n",
3272 "\n",
3273 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
3274 " fig.ondownload(fig, null);\n",
3275 "}\n",
3276 "\n",
3277 "\n",
3278 "mpl.find_output_cell = function(html_output) {\n",
3279 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
3280 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
3281 " // IPython event is triggered only after the cells have been serialised, which for\n",
3282 " // our purposes (turning an active figure into a static one), is too late.\n",
3283 " var cells = IPython.notebook.get_cells();\n",
3284 " var ncells = cells.length;\n",
3285 " for (var i=0; i<ncells; i++) {\n",
3286 " var cell = cells[i];\n",
3287 " if (cell.cell_type === 'code'){\n",
3288 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
3289 " var data = cell.output_area.outputs[j];\n",
3290 " if (data.data) {\n",
3291 " // IPython >= 3 moved mimebundle to data attribute of output\n",
3292 " data = data.data;\n",
3293 " }\n",
3294 " if (data['text/html'] == html_output) {\n",
3295 " return [cell, data, j];\n",
3296 " }\n",
3297 " }\n",
3298 " }\n",
3299 " }\n",
3300 "}\n",
3301 "\n",
3302 "// Register the function which deals with the matplotlib target/channel.\n",
3303 "// The kernel may be null if the page has been refreshed.\n",
3304 "if (IPython.notebook.kernel != null) {\n",
3305 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
3306 "}\n"
3307 ],
3308 "text/plain": [
3309 "<IPython.core.display.Javascript object>"
3310 ]
3311 },
3312 "metadata": {},
3313 "output_type": "display_data"
3314 },
3315 {
3316 "data": {
3317 "text/html": [
3318 "<img src=\"\" width=\"1599.0666174222379\">"
3319 ],
3320 "text/plain": [
3321 "<IPython.core.display.HTML object>"
3322 ]
3323 },
3324 "metadata": {},
3325 "output_type": "display_data"
3326 },
3327 {
3328 "data": {
3329 "text/plain": [
3330 "<matplotlib.legend.Legend at 0x7f2c3bc53240>"
3331 ]
3332 },
3333 "execution_count": 45,
3334 "metadata": {},
3335 "output_type": "execute_result"
3336 }
3337 ],
3338 "source": [
3339 "plt.figure()\n",
3340 "for case in [(0,\"cold\"),(189,\"ambient\")]:\n",
3341 " fft=TF.fft(res.SWF(1,case[0])[\"E1\"],sampling_frequency=4096,window=np.hanning(2048))\n",
3342 " fft=pds.DataFrame(fft)\n",
3343 " fft=fft.set_index(\"f\").drop([0.0])[\"mod\"]\n",
3344 " fft.name=case[1]\n",
3345 " fft.plot()\n",
3346 " plt.loglog()\n",
3347 "plt.legend()"
3348 ]
3349 },
3350 {
3351 "cell_type": "markdown",
3352 "metadata": {},
3353 "source": [
3354 "# FFT comparaison at F2"
3355 ]
3356 },
3357 {
3358 "cell_type": "code",
3359 "execution_count": 46,
3360 "metadata": {
3361 "ExecuteTime": {
3362 "end_time": "2017-06-01T13:39:45.725492Z",
3363 "start_time": "2017-06-01T13:39:45.555386Z"
3364 }
3365 },
3366 "outputs": [
3367 {
3368 "data": {
3369 "application/javascript": [
3370 "/* Put everything inside the global mpl namespace */\n",
3371 "window.mpl = {};\n",
3372 "\n",
3373 "\n",
3374 "mpl.get_websocket_type = function() {\n",
3375 " if (typeof(WebSocket) !== 'undefined') {\n",
3376 " return WebSocket;\n",
3377 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
3378 " return MozWebSocket;\n",
3379 " } else {\n",
3380 " alert('Your browser does not have WebSocket support.' +\n",
3381 " 'Please try Chrome, Safari or Firefox β‰₯ 6. ' +\n",
3382 " 'Firefox 4 and 5 are also supported but you ' +\n",
3383 " 'have to enable WebSockets in about:config.');\n",
3384 " };\n",
3385 "}\n",
3386 "\n",
3387 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
3388 " this.id = figure_id;\n",
3389 "\n",
3390 " this.ws = websocket;\n",
3391 "\n",
3392 " this.supports_binary = (this.ws.binaryType != undefined);\n",
3393 "\n",
3394 " if (!this.supports_binary) {\n",
3395 " var warnings = document.getElementById(\"mpl-warnings\");\n",
3396 " if (warnings) {\n",
3397 " warnings.style.display = 'block';\n",
3398 " warnings.textContent = (\n",
3399 " \"This browser does not support binary websocket messages. \" +\n",
3400 " \"Performance may be slow.\");\n",
3401 " }\n",
3402 " }\n",
3403 "\n",
3404 " this.imageObj = new Image();\n",
3405 "\n",
3406 " this.context = undefined;\n",
3407 " this.message = undefined;\n",
3408 " this.canvas = undefined;\n",
3409 " this.rubberband_canvas = undefined;\n",
3410 " this.rubberband_context = undefined;\n",
3411 " this.format_dropdown = undefined;\n",
3412 "\n",
3413 " this.image_mode = 'full';\n",
3414 "\n",
3415 " this.root = $('<div/>');\n",
3416 " this._root_extra_style(this.root)\n",
3417 " this.root.attr('style', 'display: inline-block');\n",
3418 "\n",
3419 " $(parent_element).append(this.root);\n",
3420 "\n",
3421 " this._init_header(this);\n",
3422 " this._init_canvas(this);\n",
3423 " this._init_toolbar(this);\n",
3424 "\n",
3425 " var fig = this;\n",
3426 "\n",
3427 " this.waiting = false;\n",
3428 "\n",
3429 " this.ws.onopen = function () {\n",
3430 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
3431 " fig.send_message(\"send_image_mode\", {});\n",
3432 " if (mpl.ratio != 1) {\n",
3433 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
3434 " }\n",
3435 " fig.send_message(\"refresh\", {});\n",
3436 " }\n",
3437 "\n",
3438 " this.imageObj.onload = function() {\n",
3439 " if (fig.image_mode == 'full') {\n",
3440 " // Full images could contain transparency (where diff images\n",
3441 " // almost always do), so we need to clear the canvas so that\n",
3442 " // there is no ghosting.\n",
3443 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
3444 " }\n",
3445 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
3446 " };\n",
3447 "\n",
3448 " this.imageObj.onunload = function() {\n",
3449 " this.ws.close();\n",
3450 " }\n",
3451 "\n",
3452 " this.ws.onmessage = this._make_on_message_function(this);\n",
3453 "\n",
3454 " this.ondownload = ondownload;\n",
3455 "}\n",
3456 "\n",
3457 "mpl.figure.prototype._init_header = function() {\n",
3458 " var titlebar = $(\n",
3459 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
3460 " 'ui-helper-clearfix\"/>');\n",
3461 " var titletext = $(\n",
3462 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
3463 " 'text-align: center; padding: 3px;\"/>');\n",
3464 " titlebar.append(titletext)\n",
3465 " this.root.append(titlebar);\n",
3466 " this.header = titletext[0];\n",
3467 "}\n",
3468 "\n",
3469 "\n",
3470 "\n",
3471 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
3472 "\n",
3473 "}\n",
3474 "\n",
3475 "\n",
3476 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
3477 "\n",
3478 "}\n",
3479 "\n",
3480 "mpl.figure.prototype._init_canvas = function() {\n",
3481 " var fig = this;\n",
3482 "\n",
3483 " var canvas_div = $('<div/>');\n",
3484 "\n",
3485 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
3486 "\n",
3487 " function canvas_keyboard_event(event) {\n",
3488 " return fig.key_event(event, event['data']);\n",
3489 " }\n",
3490 "\n",
3491 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
3492 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
3493 " this.canvas_div = canvas_div\n",
3494 " this._canvas_extra_style(canvas_div)\n",
3495 " this.root.append(canvas_div);\n",
3496 "\n",
3497 " var canvas = $('<canvas/>');\n",
3498 " canvas.addClass('mpl-canvas');\n",
3499 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
3500 "\n",
3501 " this.canvas = canvas[0];\n",
3502 " this.context = canvas[0].getContext(\"2d\");\n",
3503 "\n",
3504 " var backingStore = this.context.backingStorePixelRatio ||\n",
3505 "\tthis.context.webkitBackingStorePixelRatio ||\n",
3506 "\tthis.context.mozBackingStorePixelRatio ||\n",
3507 "\tthis.context.msBackingStorePixelRatio ||\n",
3508 "\tthis.context.oBackingStorePixelRatio ||\n",
3509 "\tthis.context.backingStorePixelRatio || 1;\n",
3510 "\n",
3511 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
3512 "\n",
3513 " var rubberband = $('<canvas/>');\n",
3514 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
3515 "\n",
3516 " var pass_mouse_events = true;\n",
3517 "\n",
3518 " canvas_div.resizable({\n",
3519 " start: function(event, ui) {\n",
3520 " pass_mouse_events = false;\n",
3521 " },\n",
3522 " resize: function(event, ui) {\n",
3523 " fig.request_resize(ui.size.width, ui.size.height);\n",
3524 " },\n",
3525 " stop: function(event, ui) {\n",
3526 " pass_mouse_events = true;\n",
3527 " fig.request_resize(ui.size.width, ui.size.height);\n",
3528 " },\n",
3529 " });\n",
3530 "\n",
3531 " function mouse_event_fn(event) {\n",
3532 " if (pass_mouse_events)\n",
3533 " return fig.mouse_event(event, event['data']);\n",
3534 " }\n",
3535 "\n",
3536 " rubberband.mousedown('button_press', mouse_event_fn);\n",
3537 " rubberband.mouseup('button_release', mouse_event_fn);\n",
3538 " // Throttle sequential mouse events to 1 every 20ms.\n",
3539 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
3540 "\n",
3541 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
3542 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
3543 "\n",
3544 " canvas_div.on(\"wheel\", function (event) {\n",
3545 " event = event.originalEvent;\n",
3546 " event['data'] = 'scroll'\n",
3547 " if (event.deltaY < 0) {\n",
3548 " event.step = 1;\n",
3549 " } else {\n",
3550 " event.step = -1;\n",
3551 " }\n",
3552 " mouse_event_fn(event);\n",
3553 " });\n",
3554 "\n",
3555 " canvas_div.append(canvas);\n",
3556 " canvas_div.append(rubberband);\n",
3557 "\n",
3558 " this.rubberband = rubberband;\n",
3559 " this.rubberband_canvas = rubberband[0];\n",
3560 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
3561 " this.rubberband_context.strokeStyle = \"#000000\";\n",
3562 "\n",
3563 " this._resize_canvas = function(width, height) {\n",
3564 " // Keep the size of the canvas, canvas container, and rubber band\n",
3565 " // canvas in synch.\n",
3566 " canvas_div.css('width', width)\n",
3567 " canvas_div.css('height', height)\n",
3568 "\n",
3569 " canvas.attr('width', width * mpl.ratio);\n",
3570 " canvas.attr('height', height * mpl.ratio);\n",
3571 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
3572 "\n",
3573 " rubberband.attr('width', width);\n",
3574 " rubberband.attr('height', height);\n",
3575 " }\n",
3576 "\n",
3577 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
3578 " // upon first draw.\n",
3579 " this._resize_canvas(600, 600);\n",
3580 "\n",
3581 " // Disable right mouse context menu.\n",
3582 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
3583 " return false;\n",
3584 " });\n",
3585 "\n",
3586 " function set_focus () {\n",
3587 " canvas.focus();\n",
3588 " canvas_div.focus();\n",
3589 " }\n",
3590 "\n",
3591 " window.setTimeout(set_focus, 100);\n",
3592 "}\n",
3593 "\n",
3594 "mpl.figure.prototype._init_toolbar = function() {\n",
3595 " var fig = this;\n",
3596 "\n",
3597 " var nav_element = $('<div/>')\n",
3598 " nav_element.attr('style', 'width: 100%');\n",
3599 " this.root.append(nav_element);\n",
3600 "\n",
3601 " // Define a callback function for later on.\n",
3602 " function toolbar_event(event) {\n",
3603 " return fig.toolbar_button_onclick(event['data']);\n",
3604 " }\n",
3605 " function toolbar_mouse_event(event) {\n",
3606 " return fig.toolbar_button_onmouseover(event['data']);\n",
3607 " }\n",
3608 "\n",
3609 " for(var toolbar_ind in mpl.toolbar_items) {\n",
3610 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
3611 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
3612 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
3613 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
3614 "\n",
3615 " if (!name) {\n",
3616 " // put a spacer in here.\n",
3617 " continue;\n",
3618 " }\n",
3619 " var button = $('<button/>');\n",
3620 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
3621 " 'ui-button-icon-only');\n",
3622 " button.attr('role', 'button');\n",
3623 " button.attr('aria-disabled', 'false');\n",
3624 " button.click(method_name, toolbar_event);\n",
3625 " button.mouseover(tooltip, toolbar_mouse_event);\n",
3626 "\n",
3627 " var icon_img = $('<span/>');\n",
3628 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
3629 " icon_img.addClass(image);\n",
3630 " icon_img.addClass('ui-corner-all');\n",
3631 "\n",
3632 " var tooltip_span = $('<span/>');\n",
3633 " tooltip_span.addClass('ui-button-text');\n",
3634 " tooltip_span.html(tooltip);\n",
3635 "\n",
3636 " button.append(icon_img);\n",
3637 " button.append(tooltip_span);\n",
3638 "\n",
3639 " nav_element.append(button);\n",
3640 " }\n",
3641 "\n",
3642 " var fmt_picker_span = $('<span/>');\n",
3643 "\n",
3644 " var fmt_picker = $('<select/>');\n",
3645 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
3646 " fmt_picker_span.append(fmt_picker);\n",
3647 " nav_element.append(fmt_picker_span);\n",
3648 " this.format_dropdown = fmt_picker[0];\n",
3649 "\n",
3650 " for (var ind in mpl.extensions) {\n",
3651 " var fmt = mpl.extensions[ind];\n",
3652 " var option = $(\n",
3653 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
3654 " fmt_picker.append(option)\n",
3655 " }\n",
3656 "\n",
3657 " // Add hover states to the ui-buttons\n",
3658 " $( \".ui-button\" ).hover(\n",
3659 " function() { $(this).addClass(\"ui-state-hover\");},\n",
3660 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
3661 " );\n",
3662 "\n",
3663 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
3664 " nav_element.append(status_bar);\n",
3665 " this.message = status_bar[0];\n",
3666 "}\n",
3667 "\n",
3668 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
3669 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
3670 " // which will in turn request a refresh of the image.\n",
3671 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
3672 "}\n",
3673 "\n",
3674 "mpl.figure.prototype.send_message = function(type, properties) {\n",
3675 " properties['type'] = type;\n",
3676 " properties['figure_id'] = this.id;\n",
3677 " this.ws.send(JSON.stringify(properties));\n",
3678 "}\n",
3679 "\n",
3680 "mpl.figure.prototype.send_draw_message = function() {\n",
3681 " if (!this.waiting) {\n",
3682 " this.waiting = true;\n",
3683 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
3684 " }\n",
3685 "}\n",
3686 "\n",
3687 "\n",
3688 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
3689 " var format_dropdown = fig.format_dropdown;\n",
3690 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
3691 " fig.ondownload(fig, format);\n",
3692 "}\n",
3693 "\n",
3694 "\n",
3695 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
3696 " var size = msg['size'];\n",
3697 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
3698 " fig._resize_canvas(size[0], size[1]);\n",
3699 " fig.send_message(\"refresh\", {});\n",
3700 " };\n",
3701 "}\n",
3702 "\n",
3703 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
3704 " var x0 = msg['x0'] / mpl.ratio;\n",
3705 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
3706 " var x1 = msg['x1'] / mpl.ratio;\n",
3707 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
3708 " x0 = Math.floor(x0) + 0.5;\n",
3709 " y0 = Math.floor(y0) + 0.5;\n",
3710 " x1 = Math.floor(x1) + 0.5;\n",
3711 " y1 = Math.floor(y1) + 0.5;\n",
3712 " var min_x = Math.min(x0, x1);\n",
3713 " var min_y = Math.min(y0, y1);\n",
3714 " var width = Math.abs(x1 - x0);\n",
3715 " var height = Math.abs(y1 - y0);\n",
3716 "\n",
3717 " fig.rubberband_context.clearRect(\n",
3718 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
3719 "\n",
3720 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
3721 "}\n",
3722 "\n",
3723 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
3724 " // Updates the figure title.\n",
3725 " fig.header.textContent = msg['label'];\n",
3726 "}\n",
3727 "\n",
3728 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
3729 " var cursor = msg['cursor'];\n",
3730 " switch(cursor)\n",
3731 " {\n",
3732 " case 0:\n",
3733 " cursor = 'pointer';\n",
3734 " break;\n",
3735 " case 1:\n",
3736 " cursor = 'default';\n",
3737 " break;\n",
3738 " case 2:\n",
3739 " cursor = 'crosshair';\n",
3740 " break;\n",
3741 " case 3:\n",
3742 " cursor = 'move';\n",
3743 " break;\n",
3744 " }\n",
3745 " fig.rubberband_canvas.style.cursor = cursor;\n",
3746 "}\n",
3747 "\n",
3748 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
3749 " fig.message.textContent = msg['message'];\n",
3750 "}\n",
3751 "\n",
3752 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
3753 " // Request the server to send over a new figure.\n",
3754 " fig.send_draw_message();\n",
3755 "}\n",
3756 "\n",
3757 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
3758 " fig.image_mode = msg['mode'];\n",
3759 "}\n",
3760 "\n",
3761 "mpl.figure.prototype.updated_canvas_event = function() {\n",
3762 " // Called whenever the canvas gets updated.\n",
3763 " this.send_message(\"ack\", {});\n",
3764 "}\n",
3765 "\n",
3766 "// A function to construct a web socket function for onmessage handling.\n",
3767 "// Called in the figure constructor.\n",
3768 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
3769 " return function socket_on_message(evt) {\n",
3770 " if (evt.data instanceof Blob) {\n",
3771 " /* FIXME: We get \"Resource interpreted as Image but\n",
3772 " * transferred with MIME type text/plain:\" errors on\n",
3773 " * Chrome. But how to set the MIME type? It doesn't seem\n",
3774 " * to be part of the websocket stream */\n",
3775 " evt.data.type = \"image/png\";\n",
3776 "\n",
3777 " /* Free the memory for the previous frames */\n",
3778 " if (fig.imageObj.src) {\n",
3779 " (window.URL || window.webkitURL).revokeObjectURL(\n",
3780 " fig.imageObj.src);\n",
3781 " }\n",
3782 "\n",
3783 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
3784 " evt.data);\n",
3785 " fig.updated_canvas_event();\n",
3786 " fig.waiting = false;\n",
3787 " return;\n",
3788 " }\n",
3789 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
3790 " fig.imageObj.src = evt.data;\n",
3791 " fig.updated_canvas_event();\n",
3792 " fig.waiting = false;\n",
3793 " return;\n",
3794 " }\n",
3795 "\n",
3796 " var msg = JSON.parse(evt.data);\n",
3797 " var msg_type = msg['type'];\n",
3798 "\n",
3799 " // Call the \"handle_{type}\" callback, which takes\n",
3800 " // the figure and JSON message as its only arguments.\n",
3801 " try {\n",
3802 " var callback = fig[\"handle_\" + msg_type];\n",
3803 " } catch (e) {\n",
3804 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
3805 " return;\n",
3806 " }\n",
3807 "\n",
3808 " if (callback) {\n",
3809 " try {\n",
3810 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
3811 " callback(fig, msg);\n",
3812 " } catch (e) {\n",
3813 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
3814 " }\n",
3815 " }\n",
3816 " };\n",
3817 "}\n",
3818 "\n",
3819 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
3820 "mpl.findpos = function(e) {\n",
3821 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
3822 " var targ;\n",
3823 " if (!e)\n",
3824 " e = window.event;\n",
3825 " if (e.target)\n",
3826 " targ = e.target;\n",
3827 " else if (e.srcElement)\n",
3828 " targ = e.srcElement;\n",
3829 " if (targ.nodeType == 3) // defeat Safari bug\n",
3830 " targ = targ.parentNode;\n",
3831 "\n",
3832 " // jQuery normalizes the pageX and pageY\n",
3833 " // pageX,Y are the mouse positions relative to the document\n",
3834 " // offset() returns the position of the element relative to the document\n",
3835 " var x = e.pageX - $(targ).offset().left;\n",
3836 " var y = e.pageY - $(targ).offset().top;\n",
3837 "\n",
3838 " return {\"x\": x, \"y\": y};\n",
3839 "};\n",
3840 "\n",
3841 "/*\n",
3842 " * return a copy of an object with only non-object keys\n",
3843 " * we need this to avoid circular references\n",
3844 " * http://stackoverflow.com/a/24161582/3208463\n",
3845 " */\n",
3846 "function simpleKeys (original) {\n",
3847 " return Object.keys(original).reduce(function (obj, key) {\n",
3848 " if (typeof original[key] !== 'object')\n",
3849 " obj[key] = original[key]\n",
3850 " return obj;\n",
3851 " }, {});\n",
3852 "}\n",
3853 "\n",
3854 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
3855 " var canvas_pos = mpl.findpos(event)\n",
3856 "\n",
3857 " if (name === 'button_press')\n",
3858 " {\n",
3859 " this.canvas.focus();\n",
3860 " this.canvas_div.focus();\n",
3861 " }\n",
3862 "\n",
3863 " var x = canvas_pos.x * mpl.ratio;\n",
3864 " var y = canvas_pos.y * mpl.ratio;\n",
3865 "\n",
3866 " this.send_message(name, {x: x, y: y, button: event.button,\n",
3867 " step: event.step,\n",
3868 " guiEvent: simpleKeys(event)});\n",
3869 "\n",
3870 " /* This prevents the web browser from automatically changing to\n",
3871 " * the text insertion cursor when the button is pressed. We want\n",
3872 " * to control all of the cursor setting manually through the\n",
3873 " * 'cursor' event from matplotlib */\n",
3874 " event.preventDefault();\n",
3875 " return false;\n",
3876 "}\n",
3877 "\n",
3878 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
3879 " // Handle any extra behaviour associated with a key event\n",
3880 "}\n",
3881 "\n",
3882 "mpl.figure.prototype.key_event = function(event, name) {\n",
3883 "\n",
3884 " // Prevent repeat events\n",
3885 " if (name == 'key_press')\n",
3886 " {\n",
3887 " if (event.which === this._key)\n",
3888 " return;\n",
3889 " else\n",
3890 " this._key = event.which;\n",
3891 " }\n",
3892 " if (name == 'key_release')\n",
3893 " this._key = null;\n",
3894 "\n",
3895 " var value = '';\n",
3896 " if (event.ctrlKey && event.which != 17)\n",
3897 " value += \"ctrl+\";\n",
3898 " if (event.altKey && event.which != 18)\n",
3899 " value += \"alt+\";\n",
3900 " if (event.shiftKey && event.which != 16)\n",
3901 " value += \"shift+\";\n",
3902 "\n",
3903 " value += 'k';\n",
3904 " value += event.which.toString();\n",
3905 "\n",
3906 " this._key_event_extra(event, name);\n",
3907 "\n",
3908 " this.send_message(name, {key: value,\n",
3909 " guiEvent: simpleKeys(event)});\n",
3910 " return false;\n",
3911 "}\n",
3912 "\n",
3913 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
3914 " if (name == 'download') {\n",
3915 " this.handle_save(this, null);\n",
3916 " } else {\n",
3917 " this.send_message(\"toolbar_button\", {name: name});\n",
3918 " }\n",
3919 "};\n",
3920 "\n",
3921 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
3922 " this.message.textContent = tooltip;\n",
3923 "};\n",
3924 "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",
3925 "\n",
3926 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
3927 "\n",
3928 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
3929 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
3930 " // object with the appropriate methods. Currently this is a non binary\n",
3931 " // socket, so there is still some room for performance tuning.\n",
3932 " var ws = {};\n",
3933 "\n",
3934 " ws.close = function() {\n",
3935 " comm.close()\n",
3936 " };\n",
3937 " ws.send = function(m) {\n",
3938 " //console.log('sending', m);\n",
3939 " comm.send(m);\n",
3940 " };\n",
3941 " // Register the callback with on_msg.\n",
3942 " comm.on_msg(function(msg) {\n",
3943 " //console.log('receiving', msg['content']['data'], msg);\n",
3944 " // Pass the mpl event to the overriden (by mpl) onmessage function.\n",
3945 " ws.onmessage(msg['content']['data'])\n",
3946 " });\n",
3947 " return ws;\n",
3948 "}\n",
3949 "\n",
3950 "mpl.mpl_figure_comm = function(comm, msg) {\n",
3951 " // This is the function which gets called when the mpl process\n",
3952 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
3953 "\n",
3954 " var id = msg.content.data.id;\n",
3955 " // Get hold of the div created by the display call when the Comm\n",
3956 " // socket was opened in Python.\n",
3957 " var element = $(\"#\" + id);\n",
3958 " var ws_proxy = comm_websocket_adapter(comm)\n",
3959 "\n",
3960 " function ondownload(figure, format) {\n",
3961 " window.open(figure.imageObj.src);\n",
3962 " }\n",
3963 "\n",
3964 " var fig = new mpl.figure(id, ws_proxy,\n",
3965 " ondownload,\n",
3966 " element.get(0));\n",
3967 "\n",
3968 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
3969 " // web socket which is closed, not our websocket->open comm proxy.\n",
3970 " ws_proxy.onopen();\n",
3971 "\n",
3972 " fig.parent_element = element.get(0);\n",
3973 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
3974 " if (!fig.cell_info) {\n",
3975 " console.error(\"Failed to find cell for figure\", id, fig);\n",
3976 " return;\n",
3977 " }\n",
3978 "\n",
3979 " var output_index = fig.cell_info[2]\n",
3980 " var cell = fig.cell_info[0];\n",
3981 "\n",
3982 "};\n",
3983 "\n",
3984 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
3985 " var width = fig.canvas.width/mpl.ratio\n",
3986 " fig.root.unbind('remove')\n",
3987 "\n",
3988 " // Update the output cell to use the data from the current canvas.\n",
3989 " fig.push_to_output();\n",
3990 " var dataURL = fig.canvas.toDataURL();\n",
3991 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
3992 " // the notebook keyboard shortcuts fail.\n",
3993 " IPython.keyboard_manager.enable()\n",
3994 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
3995 " fig.close_ws(fig, msg);\n",
3996 "}\n",
3997 "\n",
3998 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
3999 " fig.send_message('closing', msg);\n",
4000 " // fig.ws.close()\n",
4001 "}\n",
4002 "\n",
4003 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
4004 " // Turn the data on the canvas into data in the output cell.\n",
4005 " var width = this.canvas.width/mpl.ratio\n",
4006 " var dataURL = this.canvas.toDataURL();\n",
4007 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
4008 "}\n",
4009 "\n",
4010 "mpl.figure.prototype.updated_canvas_event = function() {\n",
4011 " // Tell IPython that the notebook contents must change.\n",
4012 " IPython.notebook.set_dirty(true);\n",
4013 " this.send_message(\"ack\", {});\n",
4014 " var fig = this;\n",
4015 " // Wait a second, then push the new image to the DOM so\n",
4016 " // that it is saved nicely (might be nice to debounce this).\n",
4017 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
4018 "}\n",
4019 "\n",
4020 "mpl.figure.prototype._init_toolbar = function() {\n",
4021 " var fig = this;\n",
4022 "\n",
4023 " var nav_element = $('<div/>')\n",
4024 " nav_element.attr('style', 'width: 100%');\n",
4025 " this.root.append(nav_element);\n",
4026 "\n",
4027 " // Define a callback function for later on.\n",
4028 " function toolbar_event(event) {\n",
4029 " return fig.toolbar_button_onclick(event['data']);\n",
4030 " }\n",
4031 " function toolbar_mouse_event(event) {\n",
4032 " return fig.toolbar_button_onmouseover(event['data']);\n",
4033 " }\n",
4034 "\n",
4035 " for(var toolbar_ind in mpl.toolbar_items){\n",
4036 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
4037 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
4038 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
4039 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
4040 "\n",
4041 " if (!name) { continue; };\n",
4042 "\n",
4043 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
4044 " button.click(method_name, toolbar_event);\n",
4045 " button.mouseover(tooltip, toolbar_mouse_event);\n",
4046 " nav_element.append(button);\n",
4047 " }\n",
4048 "\n",
4049 " // Add the status bar.\n",
4050 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
4051 " nav_element.append(status_bar);\n",
4052 " this.message = status_bar[0];\n",
4053 "\n",
4054 " // Add the close button to the window.\n",
4055 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
4056 " 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",
4057 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
4058 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
4059 " buttongrp.append(button);\n",
4060 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
4061 " titlebar.prepend(buttongrp);\n",
4062 "}\n",
4063 "\n",
4064 "mpl.figure.prototype._root_extra_style = function(el){\n",
4065 " var fig = this\n",
4066 " el.on(\"remove\", function(){\n",
4067 "\tfig.close_ws(fig, {});\n",
4068 " });\n",
4069 "}\n",
4070 "\n",
4071 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
4072 " // this is important to make the div 'focusable\n",
4073 " el.attr('tabindex', 0)\n",
4074 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
4075 " // off when our div gets focus\n",
4076 "\n",
4077 " // location in version 3\n",
4078 " if (IPython.notebook.keyboard_manager) {\n",
4079 " IPython.notebook.keyboard_manager.register_events(el);\n",
4080 " }\n",
4081 " else {\n",
4082 " // location in version 2\n",
4083 " IPython.keyboard_manager.register_events(el);\n",
4084 " }\n",
4085 "\n",
4086 "}\n",
4087 "\n",
4088 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
4089 " var manager = IPython.notebook.keyboard_manager;\n",
4090 " if (!manager)\n",
4091 " manager = IPython.keyboard_manager;\n",
4092 "\n",
4093 " // Check for shift+enter\n",
4094 " if (event.shiftKey && event.which == 13) {\n",
4095 " this.canvas_div.blur();\n",
4096 " // select the cell after this one\n",
4097 " var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
4098 " IPython.notebook.select(index + 1);\n",
4099 " }\n",
4100 "}\n",
4101 "\n",
4102 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
4103 " fig.ondownload(fig, null);\n",
4104 "}\n",
4105 "\n",
4106 "\n",
4107 "mpl.find_output_cell = function(html_output) {\n",
4108 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
4109 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
4110 " // IPython event is triggered only after the cells have been serialised, which for\n",
4111 " // our purposes (turning an active figure into a static one), is too late.\n",
4112 " var cells = IPython.notebook.get_cells();\n",
4113 " var ncells = cells.length;\n",
4114 " for (var i=0; i<ncells; i++) {\n",
4115 " var cell = cells[i];\n",
4116 " if (cell.cell_type === 'code'){\n",
4117 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
4118 " var data = cell.output_area.outputs[j];\n",
4119 " if (data.data) {\n",
4120 " // IPython >= 3 moved mimebundle to data attribute of output\n",
4121 " data = data.data;\n",
4122 " }\n",
4123 " if (data['text/html'] == html_output) {\n",
4124 " return [cell, data, j];\n",
4125 " }\n",
4126 " }\n",
4127 " }\n",
4128 " }\n",
4129 "}\n",
4130 "\n",
4131 "// Register the function which deals with the matplotlib target/channel.\n",
4132 "// The kernel may be null if the page has been refreshed.\n",
4133 "if (IPython.notebook.kernel != null) {\n",
4134 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
4135 "}\n"
4136 ],
4137 "text/plain": [
4138 "<IPython.core.display.Javascript object>"
4139 ]
4140 },
4141 "metadata": {},
4142 "output_type": "display_data"
4143 },
4144 {
4145 "data": {
4146 "text/html": [
4147 "<img src=\"\" width=\"1599.0666174222379\">"
4148 ],
4149 "text/plain": [
4150 "<IPython.core.display.HTML object>"
4151 ]
4152 },
4153 "metadata": {},
4154 "output_type": "display_data"
4155 },
4156 {
4157 "data": {
4158 "text/plain": [
4159 "<matplotlib.legend.Legend at 0x7f2c3bf5a5c0>"
4160 ]
4161 },
4162 "execution_count": 46,
4163 "metadata": {},
4164 "output_type": "execute_result"
4165 }
4166 ],
4167 "source": [
4168 "plt.figure()\n",
4169 "for case in [(0,\"cold\"),(189,\"ambient\")]:\n",
4170 " fft=TF.fft(res.SWF(2,case[0])[\"E1\"],sampling_frequency=256,window=np.hanning(2048))\n",
4171 " fft=pds.DataFrame(fft)\n",
4172 " fft=fft.set_index(\"f\").drop([0.0])[\"mod\"]\n",
4173 " fft.name=case[1]\n",
4174 " fft.plot()\n",
4175 " plt.loglog()\n",
4176 "plt.legend()"
4177 ]
4178 }
4179 ],
4180 "metadata": {
4181 "kernelspec": {
4182 "display_name": "Python 3",
4183 "language": "python",
4184 "name": "python3"
4185 },
4186 "language_info": {
4187 "codemirror_mode": {
4188 "name": "ipython",
4189 "version": 3
4190 },
4191 "file_extension": ".py",
4192 "mimetype": "text/x-python",
4193 "name": "python",
4194 "nbconvert_exporter": "python",
4195 "pygments_lexer": "ipython3",
4196 "version": "3.5.3"
4197 },
4198 "toc": {
4199 "colors": {
4200 "hover_highlight": "#DAA520",
4201 "navigate_num": "#000000",
4202 "navigate_text": "#333333",
4203 "running_highlight": "#FF0000",
4204 "selected_highlight": "#FFD700",
4205 "sidebar_border": "#EEEEEE",
4206 "wrapper_background": "#FFFFFF"
4207 },
4208 "moveMenuLeft": true,
4209 "nav_menu": {
4210 "height": "101px",
4211 "width": "252px"
4212 },
4213 "navigate_menu": true,
4214 "number_sections": true,
4215 "sideBar": true,
4216 "threshold": 4,
4217 "toc_cell": false,
4218 "toc_section_display": "block",
4219 "toc_window_display": false,
4220 "widenNotebook": false
4221 }
4222 },
4223 "nbformat": 4,
4224 "nbformat_minor": 2
4225 }
General Comments 0
You need to be logged in to leave comments. Login now