##// END OF EJS Templates
Added Noise Vs Temperature analysis on 06/2018 PPBI
jeandet -
r17:b99dfda4ef4c master
parent child
Show More
This diff has been collapsed as it changes many lines, (1901 lines changed) Show them Hide them
@@ -5,8 +5,8
5 5 "execution_count": 1,
6 6 "metadata": {
7 7 "ExecuteTime": {
8 "end_time": "2018-06-29T12:19:37.010079Z",
9 "start_time": "2018-06-29T12:19:36.575782Z"
8 "end_time": "2018-07-04T06:49:55.623000Z",
9 "start_time": "2018-07-04T06:49:55.151858Z"
10 10 }
11 11 },
12 12 "outputs": [
@@ -50,6 +50,7
50 50 "from lfrcompliance.test_engine.testcontext import *\n",
51 51 "from lfrcompliance.test_engine.result_loader import *\n",
52 52 "from lfrcompliance.tcpackets.constants import *\n",
53 "from lfrcompliance.test_engine.tests.analysis import TF\n",
53 54 "import multiprocessing.dummy\n",
54 55 "from dateutil import parser\n",
55 56 "import gc\n",
@@ -74,8 +75,8
74 75 "execution_count": 2,
75 76 "metadata": {
76 77 "ExecuteTime": {
77 "end_time": "2018-06-29T12:19:40.297058Z",
78 "start_time": "2018-06-29T12:19:40.273101Z"
78 "end_time": "2018-07-04T06:49:59.147479Z",
79 "start_time": "2018-07-04T06:49:59.132804Z"
79 80 }
80 81 },
81 82 "outputs": [],
@@ -1726,11 +1727,11
1726 1727 },
1727 1728 {
1728 1729 "cell_type": "code",
1729 "execution_count": 5,
1730 "execution_count": 4,
1730 1731 "metadata": {
1731 1732 "ExecuteTime": {
1732 "end_time": "2018-06-29T12:19:46.965856Z",
1733 "start_time": "2018-06-29T12:19:46.947036Z"
1733 "end_time": "2018-07-04T06:53:55.741692Z",
1734 "start_time": "2018-07-04T06:53:55.733872Z"
1734 1735 }
1735 1736 },
1736 1737 "outputs": [],
@@ -1765,11 +1766,11
1765 1766 },
1766 1767 {
1767 1768 "cell_type": "code",
1768 "execution_count": 7,
1769 "execution_count": 33,
1769 1770 "metadata": {
1770 1771 "ExecuteTime": {
1771 "end_time": "2018-06-29T12:19:51.511148Z",
1772 "start_time": "2018-06-29T12:19:50.066350Z"
1772 "end_time": "2018-07-04T13:22:50.356614Z",
1773 "start_time": "2018-07-04T13:22:48.981284Z"
1773 1774 }
1774 1775 },
1775 1776 "outputs": [],
@@ -1869,117 +1870,1747
1869 1870 ]
1870 1871 },
1871 1872 {
1872 "cell_type": "markdown",
1873 "metadata": {},
1874 "source": [
1875 "# -30°C to 20°C transition analysis"
1876 ]
1877 },
1878 {
1879 "cell_type": "code",
1880 "execution_count": 10,
1881 "metadata": {
1882 "ExecuteTime": {
1883 "end_time": "2018-06-29T12:21:38.812448Z",
1884 "start_time": "2018-06-29T12:21:38.694283Z"
1885 }
1886 },
1887 "outputs": [],
1888 "source": [
1889 "!rm /home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/*.png"
1890 ]
1891 },
1892 {
1893 1873 "cell_type": "code",
1894 "execution_count": 11,
1874 "execution_count": 39,
1895 1875 "metadata": {
1896 1876 "ExecuteTime": {
1897 "end_time": "2018-06-29T12:21:41.747277Z",
1898 "start_time": "2018-06-29T12:21:40.400048Z"
1899 }
1877 "end_time": "2018-07-04T13:37:56.932529Z",
1878 "start_time": "2018-07-04T13:37:56.803657Z"
1879 },
1880 "scrolled": false
1900 1881 },
1901 "outputs": [],
1902 "source": [
1903 "res = ResultLoader(\"/home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/-30_to_20_transition.outpout\")\n",
1904 "res.decomutePackets()\n",
1905 "res.loadSWF()\n",
1906 "temperatures = load_temperatures('/home/jeandet/ownCloud/TESTS_LFR_PFM1_PPBI_06_2018/Thermal_Chamber_Logs/Essai du 26 juin 2018.csv', [\"Time\",\"air\",\"PCB\", \"socket\"])\n",
1907 "times=load_packets_time(\n",
1908 " sumfile=\"/home/jeandet/Documents/DATA/LFR_Packets/decom/2018_06_26_15_00_52_packet_record.sum\",\n",
1909 " logfile=\"/home/jeandet/Documents/DATA/LFR_Packets/2018_06_26_15_00_51_packet_log.data\")\n",
1910 "\n",
1911 "\n",
1912 "with open(\"/home/jeandet/Documents/DATA/LFR_Packets/decom/2018_06_26_15_00_52_packet_record_HK.hk\",\"r\") as file:\n",
1913 " lines=file.readlines()\n",
1914 " HK_TEMP = lines[6::9] \n",
1915 " HK_PCB_TEMP = [float(T.split()[1]) for T in HK_TEMP]\n",
1916 " HK_PCB_TIME = [val['Time'] for val in times[\"HK\"]]\n",
1917 " HK_TEMP_df = pds.Series(HK_PCB_TEMP, name='PCBTemp',index=pds.DatetimeIndex(HK_PCB_TIME, dtype='datetime64[ns]', freq=None))"
1918 ]
1919 },
1920 {
1921 "cell_type": "code",
1922 "execution_count": 12,
1923 "metadata": {
1924 "ExecuteTime": {
1925 "end_time": "2018-06-29T12:23:08.428149Z",
1926 "start_time": "2018-06-29T12:21:43.373905Z"
1882 "outputs": [
1883 {
1884 "data": {
1885 "application/javascript": [
1886 "/* Put everything inside the global mpl namespace */\n",
1887 "window.mpl = {};\n",
1888 "\n",
1889 "\n",
1890 "mpl.get_websocket_type = function() {\n",
1891 " if (typeof(WebSocket) !== 'undefined') {\n",
1892 " return WebSocket;\n",
1893 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
1894 " return MozWebSocket;\n",
1895 " } else {\n",
1896 " alert('Your browser does not have WebSocket support.' +\n",
1897 " 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
1898 " 'Firefox 4 and 5 are also supported but you ' +\n",
1899 " 'have to enable WebSockets in about:config.');\n",
1900 " };\n",
1901 "}\n",
1902 "\n",
1903 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
1904 " this.id = figure_id;\n",
1905 "\n",
1906 " this.ws = websocket;\n",
1907 "\n",
1908 " this.supports_binary = (this.ws.binaryType != undefined);\n",
1909 "\n",
1910 " if (!this.supports_binary) {\n",
1911 " var warnings = document.getElementById(\"mpl-warnings\");\n",
1912 " if (warnings) {\n",
1913 " warnings.style.display = 'block';\n",
1914 " warnings.textContent = (\n",
1915 " \"This browser does not support binary websocket messages. \" +\n",
1916 " \"Performance may be slow.\");\n",
1917 " }\n",
1918 " }\n",
1919 "\n",
1920 " this.imageObj = new Image();\n",
1921 "\n",
1922 " this.context = undefined;\n",
1923 " this.message = undefined;\n",
1924 " this.canvas = undefined;\n",
1925 " this.rubberband_canvas = undefined;\n",
1926 " this.rubberband_context = undefined;\n",
1927 " this.format_dropdown = undefined;\n",
1928 "\n",
1929 " this.image_mode = 'full';\n",
1930 "\n",
1931 " this.root = $('<div/>');\n",
1932 " this._root_extra_style(this.root)\n",
1933 " this.root.attr('style', 'display: inline-block');\n",
1934 "\n",
1935 " $(parent_element).append(this.root);\n",
1936 "\n",
1937 " this._init_header(this);\n",
1938 " this._init_canvas(this);\n",
1939 " this._init_toolbar(this);\n",
1940 "\n",
1941 " var fig = this;\n",
1942 "\n",
1943 " this.waiting = false;\n",
1944 "\n",
1945 " this.ws.onopen = function () {\n",
1946 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
1947 " fig.send_message(\"send_image_mode\", {});\n",
1948 " if (mpl.ratio != 1) {\n",
1949 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
1950 " }\n",
1951 " fig.send_message(\"refresh\", {});\n",
1952 " }\n",
1953 "\n",
1954 " this.imageObj.onload = function() {\n",
1955 " if (fig.image_mode == 'full') {\n",
1956 " // Full images could contain transparency (where diff images\n",
1957 " // almost always do), so we need to clear the canvas so that\n",
1958 " // there is no ghosting.\n",
1959 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
1960 " }\n",
1961 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
1962 " };\n",
1963 "\n",
1964 " this.imageObj.onunload = function() {\n",
1965 " fig.ws.close();\n",
1966 " }\n",
1967 "\n",
1968 " this.ws.onmessage = this._make_on_message_function(this);\n",
1969 "\n",
1970 " this.ondownload = ondownload;\n",
1971 "}\n",
1972 "\n",
1973 "mpl.figure.prototype._init_header = function() {\n",
1974 " var titlebar = $(\n",
1975 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
1976 " 'ui-helper-clearfix\"/>');\n",
1977 " var titletext = $(\n",
1978 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
1979 " 'text-align: center; padding: 3px;\"/>');\n",
1980 " titlebar.append(titletext)\n",
1981 " this.root.append(titlebar);\n",
1982 " this.header = titletext[0];\n",
1983 "}\n",
1984 "\n",
1985 "\n",
1986 "\n",
1987 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
1988 "\n",
1989 "}\n",
1990 "\n",
1991 "\n",
1992 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
1993 "\n",
1994 "}\n",
1995 "\n",
1996 "mpl.figure.prototype._init_canvas = function() {\n",
1997 " var fig = this;\n",
1998 "\n",
1999 " var canvas_div = $('<div/>');\n",
2000 "\n",
2001 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
2002 "\n",
2003 " function canvas_keyboard_event(event) {\n",
2004 " return fig.key_event(event, event['data']);\n",
2005 " }\n",
2006 "\n",
2007 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
2008 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
2009 " this.canvas_div = canvas_div\n",
2010 " this._canvas_extra_style(canvas_div)\n",
2011 " this.root.append(canvas_div);\n",
2012 "\n",
2013 " var canvas = $('<canvas/>');\n",
2014 " canvas.addClass('mpl-canvas');\n",
2015 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
2016 "\n",
2017 " this.canvas = canvas[0];\n",
2018 " this.context = canvas[0].getContext(\"2d\");\n",
2019 "\n",
2020 " var backingStore = this.context.backingStorePixelRatio ||\n",
2021 "\tthis.context.webkitBackingStorePixelRatio ||\n",
2022 "\tthis.context.mozBackingStorePixelRatio ||\n",
2023 "\tthis.context.msBackingStorePixelRatio ||\n",
2024 "\tthis.context.oBackingStorePixelRatio ||\n",
2025 "\tthis.context.backingStorePixelRatio || 1;\n",
2026 "\n",
2027 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
2028 "\n",
2029 " var rubberband = $('<canvas/>');\n",
2030 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
2031 "\n",
2032 " var pass_mouse_events = true;\n",
2033 "\n",
2034 " canvas_div.resizable({\n",
2035 " start: function(event, ui) {\n",
2036 " pass_mouse_events = false;\n",
2037 " },\n",
2038 " resize: function(event, ui) {\n",
2039 " fig.request_resize(ui.size.width, ui.size.height);\n",
2040 " },\n",
2041 " stop: function(event, ui) {\n",
2042 " pass_mouse_events = true;\n",
2043 " fig.request_resize(ui.size.width, ui.size.height);\n",
2044 " },\n",
2045 " });\n",
2046 "\n",
2047 " function mouse_event_fn(event) {\n",
2048 " if (pass_mouse_events)\n",
2049 " return fig.mouse_event(event, event['data']);\n",
2050 " }\n",
2051 "\n",
2052 " rubberband.mousedown('button_press', mouse_event_fn);\n",
2053 " rubberband.mouseup('button_release', mouse_event_fn);\n",
2054 " // Throttle sequential mouse events to 1 every 20ms.\n",
2055 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
2056 "\n",
2057 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
2058 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
2059 "\n",
2060 " canvas_div.on(\"wheel\", function (event) {\n",
2061 " event = event.originalEvent;\n",
2062 " event['data'] = 'scroll'\n",
2063 " if (event.deltaY < 0) {\n",
2064 " event.step = 1;\n",
2065 " } else {\n",
2066 " event.step = -1;\n",
2067 " }\n",
2068 " mouse_event_fn(event);\n",
2069 " });\n",
2070 "\n",
2071 " canvas_div.append(canvas);\n",
2072 " canvas_div.append(rubberband);\n",
2073 "\n",
2074 " this.rubberband = rubberband;\n",
2075 " this.rubberband_canvas = rubberband[0];\n",
2076 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
2077 " this.rubberband_context.strokeStyle = \"#000000\";\n",
2078 "\n",
2079 " this._resize_canvas = function(width, height) {\n",
2080 " // Keep the size of the canvas, canvas container, and rubber band\n",
2081 " // canvas in synch.\n",
2082 " canvas_div.css('width', width)\n",
2083 " canvas_div.css('height', height)\n",
2084 "\n",
2085 " canvas.attr('width', width * mpl.ratio);\n",
2086 " canvas.attr('height', height * mpl.ratio);\n",
2087 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
2088 "\n",
2089 " rubberband.attr('width', width);\n",
2090 " rubberband.attr('height', height);\n",
2091 " }\n",
2092 "\n",
2093 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
2094 " // upon first draw.\n",
2095 " this._resize_canvas(600, 600);\n",
2096 "\n",
2097 " // Disable right mouse context menu.\n",
2098 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
2099 " return false;\n",
2100 " });\n",
2101 "\n",
2102 " function set_focus () {\n",
2103 " canvas.focus();\n",
2104 " canvas_div.focus();\n",
2105 " }\n",
2106 "\n",
2107 " window.setTimeout(set_focus, 100);\n",
2108 "}\n",
2109 "\n",
2110 "mpl.figure.prototype._init_toolbar = function() {\n",
2111 " var fig = this;\n",
2112 "\n",
2113 " var nav_element = $('<div/>')\n",
2114 " nav_element.attr('style', 'width: 100%');\n",
2115 " this.root.append(nav_element);\n",
2116 "\n",
2117 " // Define a callback function for later on.\n",
2118 " function toolbar_event(event) {\n",
2119 " return fig.toolbar_button_onclick(event['data']);\n",
2120 " }\n",
2121 " function toolbar_mouse_event(event) {\n",
2122 " return fig.toolbar_button_onmouseover(event['data']);\n",
2123 " }\n",
2124 "\n",
2125 " for(var toolbar_ind in mpl.toolbar_items) {\n",
2126 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
2127 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
2128 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
2129 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
2130 "\n",
2131 " if (!name) {\n",
2132 " // put a spacer in here.\n",
2133 " continue;\n",
2134 " }\n",
2135 " var button = $('<button/>');\n",
2136 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
2137 " 'ui-button-icon-only');\n",
2138 " button.attr('role', 'button');\n",
2139 " button.attr('aria-disabled', 'false');\n",
2140 " button.click(method_name, toolbar_event);\n",
2141 " button.mouseover(tooltip, toolbar_mouse_event);\n",
2142 "\n",
2143 " var icon_img = $('<span/>');\n",
2144 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
2145 " icon_img.addClass(image);\n",
2146 " icon_img.addClass('ui-corner-all');\n",
2147 "\n",
2148 " var tooltip_span = $('<span/>');\n",
2149 " tooltip_span.addClass('ui-button-text');\n",
2150 " tooltip_span.html(tooltip);\n",
2151 "\n",
2152 " button.append(icon_img);\n",
2153 " button.append(tooltip_span);\n",
2154 "\n",
2155 " nav_element.append(button);\n",
2156 " }\n",
2157 "\n",
2158 " var fmt_picker_span = $('<span/>');\n",
2159 "\n",
2160 " var fmt_picker = $('<select/>');\n",
2161 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
2162 " fmt_picker_span.append(fmt_picker);\n",
2163 " nav_element.append(fmt_picker_span);\n",
2164 " this.format_dropdown = fmt_picker[0];\n",
2165 "\n",
2166 " for (var ind in mpl.extensions) {\n",
2167 " var fmt = mpl.extensions[ind];\n",
2168 " var option = $(\n",
2169 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
2170 " fmt_picker.append(option)\n",
2171 " }\n",
2172 "\n",
2173 " // Add hover states to the ui-buttons\n",
2174 " $( \".ui-button\" ).hover(\n",
2175 " function() { $(this).addClass(\"ui-state-hover\");},\n",
2176 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
2177 " );\n",
2178 "\n",
2179 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
2180 " nav_element.append(status_bar);\n",
2181 " this.message = status_bar[0];\n",
2182 "}\n",
2183 "\n",
2184 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
2185 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
2186 " // which will in turn request a refresh of the image.\n",
2187 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
2188 "}\n",
2189 "\n",
2190 "mpl.figure.prototype.send_message = function(type, properties) {\n",
2191 " properties['type'] = type;\n",
2192 " properties['figure_id'] = this.id;\n",
2193 " this.ws.send(JSON.stringify(properties));\n",
2194 "}\n",
2195 "\n",
2196 "mpl.figure.prototype.send_draw_message = function() {\n",
2197 " if (!this.waiting) {\n",
2198 " this.waiting = true;\n",
2199 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
2200 " }\n",
2201 "}\n",
2202 "\n",
2203 "\n",
2204 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
2205 " var format_dropdown = fig.format_dropdown;\n",
2206 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
2207 " fig.ondownload(fig, format);\n",
2208 "}\n",
2209 "\n",
2210 "\n",
2211 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
2212 " var size = msg['size'];\n",
2213 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
2214 " fig._resize_canvas(size[0], size[1]);\n",
2215 " fig.send_message(\"refresh\", {});\n",
2216 " };\n",
2217 "}\n",
2218 "\n",
2219 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
2220 " var x0 = msg['x0'] / mpl.ratio;\n",
2221 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
2222 " var x1 = msg['x1'] / mpl.ratio;\n",
2223 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
2224 " x0 = Math.floor(x0) + 0.5;\n",
2225 " y0 = Math.floor(y0) + 0.5;\n",
2226 " x1 = Math.floor(x1) + 0.5;\n",
2227 " y1 = Math.floor(y1) + 0.5;\n",
2228 " var min_x = Math.min(x0, x1);\n",
2229 " var min_y = Math.min(y0, y1);\n",
2230 " var width = Math.abs(x1 - x0);\n",
2231 " var height = Math.abs(y1 - y0);\n",
2232 "\n",
2233 " fig.rubberband_context.clearRect(\n",
2234 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
2235 "\n",
2236 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
2237 "}\n",
2238 "\n",
2239 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
2240 " // Updates the figure title.\n",
2241 " fig.header.textContent = msg['label'];\n",
2242 "}\n",
2243 "\n",
2244 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
2245 " var cursor = msg['cursor'];\n",
2246 " switch(cursor)\n",
2247 " {\n",
2248 " case 0:\n",
2249 " cursor = 'pointer';\n",
2250 " break;\n",
2251 " case 1:\n",
2252 " cursor = 'default';\n",
2253 " break;\n",
2254 " case 2:\n",
2255 " cursor = 'crosshair';\n",
2256 " break;\n",
2257 " case 3:\n",
2258 " cursor = 'move';\n",
2259 " break;\n",
2260 " }\n",
2261 " fig.rubberband_canvas.style.cursor = cursor;\n",
2262 "}\n",
2263 "\n",
2264 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
2265 " fig.message.textContent = msg['message'];\n",
2266 "}\n",
2267 "\n",
2268 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
2269 " // Request the server to send over a new figure.\n",
2270 " fig.send_draw_message();\n",
2271 "}\n",
2272 "\n",
2273 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
2274 " fig.image_mode = msg['mode'];\n",
2275 "}\n",
2276 "\n",
2277 "mpl.figure.prototype.updated_canvas_event = function() {\n",
2278 " // Called whenever the canvas gets updated.\n",
2279 " this.send_message(\"ack\", {});\n",
2280 "}\n",
2281 "\n",
2282 "// A function to construct a web socket function for onmessage handling.\n",
2283 "// Called in the figure constructor.\n",
2284 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
2285 " return function socket_on_message(evt) {\n",
2286 " if (evt.data instanceof Blob) {\n",
2287 " /* FIXME: We get \"Resource interpreted as Image but\n",
2288 " * transferred with MIME type text/plain:\" errors on\n",
2289 " * Chrome. But how to set the MIME type? It doesn't seem\n",
2290 " * to be part of the websocket stream */\n",
2291 " evt.data.type = \"image/png\";\n",
2292 "\n",
2293 " /* Free the memory for the previous frames */\n",
2294 " if (fig.imageObj.src) {\n",
2295 " (window.URL || window.webkitURL).revokeObjectURL(\n",
2296 " fig.imageObj.src);\n",
2297 " }\n",
2298 "\n",
2299 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
2300 " evt.data);\n",
2301 " fig.updated_canvas_event();\n",
2302 " fig.waiting = false;\n",
2303 " return;\n",
2304 " }\n",
2305 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
2306 " fig.imageObj.src = evt.data;\n",
2307 " fig.updated_canvas_event();\n",
2308 " fig.waiting = false;\n",
2309 " return;\n",
2310 " }\n",
2311 "\n",
2312 " var msg = JSON.parse(evt.data);\n",
2313 " var msg_type = msg['type'];\n",
2314 "\n",
2315 " // Call the \"handle_{type}\" callback, which takes\n",
2316 " // the figure and JSON message as its only arguments.\n",
2317 " try {\n",
2318 " var callback = fig[\"handle_\" + msg_type];\n",
2319 " } catch (e) {\n",
2320 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
2321 " return;\n",
2322 " }\n",
2323 "\n",
2324 " if (callback) {\n",
2325 " try {\n",
2326 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
2327 " callback(fig, msg);\n",
2328 " } catch (e) {\n",
2329 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
2330 " }\n",
2331 " }\n",
2332 " };\n",
2333 "}\n",
2334 "\n",
2335 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
2336 "mpl.findpos = function(e) {\n",
2337 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
2338 " var targ;\n",
2339 " if (!e)\n",
2340 " e = window.event;\n",
2341 " if (e.target)\n",
2342 " targ = e.target;\n",
2343 " else if (e.srcElement)\n",
2344 " targ = e.srcElement;\n",
2345 " if (targ.nodeType == 3) // defeat Safari bug\n",
2346 " targ = targ.parentNode;\n",
2347 "\n",
2348 " // jQuery normalizes the pageX and pageY\n",
2349 " // pageX,Y are the mouse positions relative to the document\n",
2350 " // offset() returns the position of the element relative to the document\n",
2351 " var x = e.pageX - $(targ).offset().left;\n",
2352 " var y = e.pageY - $(targ).offset().top;\n",
2353 "\n",
2354 " return {\"x\": x, \"y\": y};\n",
2355 "};\n",
2356 "\n",
2357 "/*\n",
2358 " * return a copy of an object with only non-object keys\n",
2359 " * we need this to avoid circular references\n",
2360 " * http://stackoverflow.com/a/24161582/3208463\n",
2361 " */\n",
2362 "function simpleKeys (original) {\n",
2363 " return Object.keys(original).reduce(function (obj, key) {\n",
2364 " if (typeof original[key] !== 'object')\n",
2365 " obj[key] = original[key]\n",
2366 " return obj;\n",
2367 " }, {});\n",
2368 "}\n",
2369 "\n",
2370 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
2371 " var canvas_pos = mpl.findpos(event)\n",
2372 "\n",
2373 " if (name === 'button_press')\n",
2374 " {\n",
2375 " this.canvas.focus();\n",
2376 " this.canvas_div.focus();\n",
2377 " }\n",
2378 "\n",
2379 " var x = canvas_pos.x * mpl.ratio;\n",
2380 " var y = canvas_pos.y * mpl.ratio;\n",
2381 "\n",
2382 " this.send_message(name, {x: x, y: y, button: event.button,\n",
2383 " step: event.step,\n",
2384 " guiEvent: simpleKeys(event)});\n",
2385 "\n",
2386 " /* This prevents the web browser from automatically changing to\n",
2387 " * the text insertion cursor when the button is pressed. We want\n",
2388 " * to control all of the cursor setting manually through the\n",
2389 " * 'cursor' event from matplotlib */\n",
2390 " event.preventDefault();\n",
2391 " return false;\n",
2392 "}\n",
2393 "\n",
2394 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
2395 " // Handle any extra behaviour associated with a key event\n",
2396 "}\n",
2397 "\n",
2398 "mpl.figure.prototype.key_event = function(event, name) {\n",
2399 "\n",
2400 " // Prevent repeat events\n",
2401 " if (name == 'key_press')\n",
2402 " {\n",
2403 " if (event.which === this._key)\n",
2404 " return;\n",
2405 " else\n",
2406 " this._key = event.which;\n",
2407 " }\n",
2408 " if (name == 'key_release')\n",
2409 " this._key = null;\n",
2410 "\n",
2411 " var value = '';\n",
2412 " if (event.ctrlKey && event.which != 17)\n",
2413 " value += \"ctrl+\";\n",
2414 " if (event.altKey && event.which != 18)\n",
2415 " value += \"alt+\";\n",
2416 " if (event.shiftKey && event.which != 16)\n",
2417 " value += \"shift+\";\n",
2418 "\n",
2419 " value += 'k';\n",
2420 " value += event.which.toString();\n",
2421 "\n",
2422 " this._key_event_extra(event, name);\n",
2423 "\n",
2424 " this.send_message(name, {key: value,\n",
2425 " guiEvent: simpleKeys(event)});\n",
2426 " return false;\n",
2427 "}\n",
2428 "\n",
2429 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
2430 " if (name == 'download') {\n",
2431 " this.handle_save(this, null);\n",
2432 " } else {\n",
2433 " this.send_message(\"toolbar_button\", {name: name});\n",
2434 " }\n",
2435 "};\n",
2436 "\n",
2437 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
2438 " this.message.textContent = tooltip;\n",
2439 "};\n",
2440 "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",
2441 "\n",
2442 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
2443 "\n",
2444 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
2445 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
2446 " // object with the appropriate methods. Currently this is a non binary\n",
2447 " // socket, so there is still some room for performance tuning.\n",
2448 " var ws = {};\n",
2449 "\n",
2450 " ws.close = function() {\n",
2451 " comm.close()\n",
2452 " };\n",
2453 " ws.send = function(m) {\n",
2454 " //console.log('sending', m);\n",
2455 " comm.send(m);\n",
2456 " };\n",
2457 " // Register the callback with on_msg.\n",
2458 " comm.on_msg(function(msg) {\n",
2459 " //console.log('receiving', msg['content']['data'], msg);\n",
2460 " // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
2461 " ws.onmessage(msg['content']['data'])\n",
2462 " });\n",
2463 " return ws;\n",
2464 "}\n",
2465 "\n",
2466 "mpl.mpl_figure_comm = function(comm, msg) {\n",
2467 " // This is the function which gets called when the mpl process\n",
2468 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
2469 "\n",
2470 " var id = msg.content.data.id;\n",
2471 " // Get hold of the div created by the display call when the Comm\n",
2472 " // socket was opened in Python.\n",
2473 " var element = $(\"#\" + id);\n",
2474 " var ws_proxy = comm_websocket_adapter(comm)\n",
2475 "\n",
2476 " function ondownload(figure, format) {\n",
2477 " window.open(figure.imageObj.src);\n",
2478 " }\n",
2479 "\n",
2480 " var fig = new mpl.figure(id, ws_proxy,\n",
2481 " ondownload,\n",
2482 " element.get(0));\n",
2483 "\n",
2484 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
2485 " // web socket which is closed, not our websocket->open comm proxy.\n",
2486 " ws_proxy.onopen();\n",
2487 "\n",
2488 " fig.parent_element = element.get(0);\n",
2489 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
2490 " if (!fig.cell_info) {\n",
2491 " console.error(\"Failed to find cell for figure\", id, fig);\n",
2492 " return;\n",
2493 " }\n",
2494 "\n",
2495 " var output_index = fig.cell_info[2]\n",
2496 " var cell = fig.cell_info[0];\n",
2497 "\n",
2498 "};\n",
2499 "\n",
2500 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
2501 " var width = fig.canvas.width/mpl.ratio\n",
2502 " fig.root.unbind('remove')\n",
2503 "\n",
2504 " // Update the output cell to use the data from the current canvas.\n",
2505 " fig.push_to_output();\n",
2506 " var dataURL = fig.canvas.toDataURL();\n",
2507 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
2508 " // the notebook keyboard shortcuts fail.\n",
2509 " IPython.keyboard_manager.enable()\n",
2510 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
2511 " fig.close_ws(fig, msg);\n",
2512 "}\n",
2513 "\n",
2514 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
2515 " fig.send_message('closing', msg);\n",
2516 " // fig.ws.close()\n",
2517 "}\n",
2518 "\n",
2519 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
2520 " // Turn the data on the canvas into data in the output cell.\n",
2521 " var width = this.canvas.width/mpl.ratio\n",
2522 " var dataURL = this.canvas.toDataURL();\n",
2523 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
2524 "}\n",
2525 "\n",
2526 "mpl.figure.prototype.updated_canvas_event = function() {\n",
2527 " // Tell IPython that the notebook contents must change.\n",
2528 " IPython.notebook.set_dirty(true);\n",
2529 " this.send_message(\"ack\", {});\n",
2530 " var fig = this;\n",
2531 " // Wait a second, then push the new image to the DOM so\n",
2532 " // that it is saved nicely (might be nice to debounce this).\n",
2533 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
2534 "}\n",
2535 "\n",
2536 "mpl.figure.prototype._init_toolbar = function() {\n",
2537 " var fig = this;\n",
2538 "\n",
2539 " var nav_element = $('<div/>')\n",
2540 " nav_element.attr('style', 'width: 100%');\n",
2541 " this.root.append(nav_element);\n",
2542 "\n",
2543 " // Define a callback function for later on.\n",
2544 " function toolbar_event(event) {\n",
2545 " return fig.toolbar_button_onclick(event['data']);\n",
2546 " }\n",
2547 " function toolbar_mouse_event(event) {\n",
2548 " return fig.toolbar_button_onmouseover(event['data']);\n",
2549 " }\n",
2550 "\n",
2551 " for(var toolbar_ind in mpl.toolbar_items){\n",
2552 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
2553 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
2554 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
2555 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
2556 "\n",
2557 " if (!name) { continue; };\n",
2558 "\n",
2559 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
2560 " button.click(method_name, toolbar_event);\n",
2561 " button.mouseover(tooltip, toolbar_mouse_event);\n",
2562 " nav_element.append(button);\n",
2563 " }\n",
2564 "\n",
2565 " // Add the status bar.\n",
2566 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
2567 " nav_element.append(status_bar);\n",
2568 " this.message = status_bar[0];\n",
2569 "\n",
2570 " // Add the close button to the window.\n",
2571 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
2572 " 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",
2573 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
2574 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
2575 " buttongrp.append(button);\n",
2576 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
2577 " titlebar.prepend(buttongrp);\n",
2578 "}\n",
2579 "\n",
2580 "mpl.figure.prototype._root_extra_style = function(el){\n",
2581 " var fig = this\n",
2582 " el.on(\"remove\", function(){\n",
2583 "\tfig.close_ws(fig, {});\n",
2584 " });\n",
2585 "}\n",
2586 "\n",
2587 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
2588 " // this is important to make the div 'focusable\n",
2589 " el.attr('tabindex', 0)\n",
2590 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
2591 " // off when our div gets focus\n",
2592 "\n",
2593 " // location in version 3\n",
2594 " if (IPython.notebook.keyboard_manager) {\n",
2595 " IPython.notebook.keyboard_manager.register_events(el);\n",
2596 " }\n",
2597 " else {\n",
2598 " // location in version 2\n",
2599 " IPython.keyboard_manager.register_events(el);\n",
2600 " }\n",
2601 "\n",
2602 "}\n",
2603 "\n",
2604 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
2605 " var manager = IPython.notebook.keyboard_manager;\n",
2606 " if (!manager)\n",
2607 " manager = IPython.keyboard_manager;\n",
2608 "\n",
2609 " // Check for shift+enter\n",
2610 " if (event.shiftKey && event.which == 13) {\n",
2611 " this.canvas_div.blur();\n",
2612 " event.shiftKey = false;\n",
2613 " // Send a \"J\" for go to next cell\n",
2614 " event.which = 74;\n",
2615 " event.keyCode = 74;\n",
2616 " manager.command_mode();\n",
2617 " manager.handle_keydown(event);\n",
2618 " }\n",
2619 "}\n",
2620 "\n",
2621 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
2622 " fig.ondownload(fig, null);\n",
2623 "}\n",
2624 "\n",
2625 "\n",
2626 "mpl.find_output_cell = function(html_output) {\n",
2627 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
2628 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
2629 " // IPython event is triggered only after the cells have been serialised, which for\n",
2630 " // our purposes (turning an active figure into a static one), is too late.\n",
2631 " var cells = IPython.notebook.get_cells();\n",
2632 " var ncells = cells.length;\n",
2633 " for (var i=0; i<ncells; i++) {\n",
2634 " var cell = cells[i];\n",
2635 " if (cell.cell_type === 'code'){\n",
2636 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
2637 " var data = cell.output_area.outputs[j];\n",
2638 " if (data.data) {\n",
2639 " // IPython >= 3 moved mimebundle to data attribute of output\n",
2640 " data = data.data;\n",
2641 " }\n",
2642 " if (data['text/html'] == html_output) {\n",
2643 " return [cell, data, j];\n",
2644 " }\n",
2645 " }\n",
2646 " }\n",
2647 " }\n",
2648 "}\n",
2649 "\n",
2650 "// Register the function which deals with the matplotlib target/channel.\n",
2651 "// The kernel may be null if the page has been refreshed.\n",
2652 "if (IPython.notebook.kernel != null) {\n",
2653 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
2654 "}\n"
2655 ],
2656 "text/plain": [
2657 "<IPython.core.display.Javascript object>"
2658 ]
2659 },
2660 "metadata": {},
2661 "output_type": "display_data"
2662 },
2663 {
2664 "data": {
2665 "text/html": [
2666 "<img src=\"\" width=\"900\">"
2667 ],
2668 "text/plain": [
2669 "<IPython.core.display.HTML object>"
2670 ]
2671 },
2672 "metadata": {},
2673 "output_type": "display_data"
2674 }
2675 ],
2676 "source": [
2677 "values = np.zeros(res.SWFCount())\n",
2678 "T = np.zeros(res.SWFCount())\n",
2679 "values2 = np.zeros(res.SWFCount())\n",
2680 "for i in range(0,res.SWFCount()):\n",
2681 " spec = TF.fft(res.SWF(0,i)[\"E1\"], TF.LFR_Fs0, np.hanning(2048))\n",
2682 " values[i] = spec[\"mod\"][200:].mean()\n",
2683 " T[i] = get_temperature_at(HK_TEMP_df,times[\"SWF0\"][i][\"Time\"])\n",
2684 " \n",
2685 "plt.figure(figsize=(9,6))\n",
2686 "plt.suptitle(\"Average noise Vs Temperature\")\n",
2687 "plt.xlabel(\"PCB Temperature(°C)\")\n",
2688 "plt.ylabel(\"Average noise\")\n",
2689 "plt.plot(T,values)\n",
2690 "plt.semilogy()\n",
2691 "plt.show()"
2692 ]
2693 },
2694 {
2695 "cell_type": "markdown",
2696 "metadata": {},
2697 "source": [
2698 "# -30°C to 20°C transition analysis"
2699 ]
2700 },
2701 {
2702 "cell_type": "code",
2703 "execution_count": 10,
2704 "metadata": {
2705 "ExecuteTime": {
2706 "end_time": "2018-06-29T12:21:38.812448Z",
2707 "start_time": "2018-06-29T12:21:38.694283Z"
2708 }
2709 },
2710 "outputs": [],
2711 "source": [
2712 "!rm /home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/*.png"
2713 ]
2714 },
2715 {
2716 "cell_type": "code",
2717 "execution_count": 40,
2718 "metadata": {
2719 "ExecuteTime": {
2720 "end_time": "2018-07-04T13:38:10.890126Z",
2721 "start_time": "2018-07-04T13:38:09.466843Z"
2722 }
2723 },
2724 "outputs": [],
2725 "source": [
2726 "res = ResultLoader(\"/home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/-30_to_20_transition.outpout\")\n",
2727 "res.decomutePackets()\n",
2728 "res.loadSWF()\n",
2729 "temperatures = load_temperatures('/home/jeandet/ownCloud/TESTS_LFR_PFM1_PPBI_06_2018/Thermal_Chamber_Logs/Essai du 26 juin 2018.csv', [\"Time\",\"air\",\"PCB\", \"socket\"])\n",
2730 "times=load_packets_time(\n",
2731 " sumfile=\"/home/jeandet/Documents/DATA/LFR_Packets/decom/2018_06_26_15_00_52_packet_record.sum\",\n",
2732 " logfile=\"/home/jeandet/Documents/DATA/LFR_Packets/2018_06_26_15_00_51_packet_log.data\")\n",
2733 "\n",
2734 "\n",
2735 "with open(\"/home/jeandet/Documents/DATA/LFR_Packets/decom/2018_06_26_15_00_52_packet_record_HK.hk\",\"r\") as file:\n",
2736 " lines=file.readlines()\n",
2737 " HK_TEMP = lines[6::9] \n",
2738 " HK_PCB_TEMP = [float(T.split()[1]) for T in HK_TEMP]\n",
2739 " HK_PCB_TIME = [val['Time'] for val in times[\"HK\"]]\n",
2740 " HK_TEMP_df = pds.Series(HK_PCB_TEMP, name='PCBTemp',index=pds.DatetimeIndex(HK_PCB_TIME, dtype='datetime64[ns]', freq=None))"
2741 ]
2742 },
2743 {
2744 "cell_type": "code",
2745 "execution_count": 12,
2746 "metadata": {
2747 "ExecuteTime": {
2748 "end_time": "2018-06-29T12:23:08.428149Z",
2749 "start_time": "2018-06-29T12:21:43.373905Z"
2750 },
2751 "scrolled": true
2752 },
2753 "outputs": [],
2754 "source": [
2755 "%%capture\n",
2756 "for i in range(0,res.SWFCount()):\n",
2757 " f, axes = plt.subplots(nrows=2, ncols=3,figsize=(24,10))\n",
2758 " df=res.SWF(0,i)\n",
2759 " for ax,col in zip(axes.flatten(),df.columns):\n",
2760 " ax.plot(np.arange(2048),df[col])\n",
2761 " ax.set_ylim(-30000,30000)\n",
2762 " patches, labels = ax.get_legend_handles_labels()\n",
2763 " ax.legend(patches, labels, loc='upper left')\n",
2764 " T = get_temperature_at(temperatures,times[\"SWF0\"][i][\"Time\"]-datetime.timedelta(minutes=4,seconds=10))\n",
2765 " T_HK = get_temperature_at(HK_TEMP_df,times[\"SWF0\"][i][\"Time\"])\n",
2766 " suptitle=plt.suptitle(\"Air={T_Air:3.1f}°C PCB(HK)={T_PCB:3.1f}°C socket={T_socket:3.1f}°C\".format(T_Air=T[\"air\"],T_PCB=T_HK,T_socket=T[\"socket\"]),y=1.05, fontsize=24)\n",
2767 " plt.tight_layout()\n",
2768 " plt.savefig(\"/home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/\"+\"/plot_{i}.png\".format(i=i),bbox_inches='tight',bbox_extra_artists=[suptitle])\n",
2769 " plt.close()\n",
2770 " del axes\n",
2771 " del f\n",
2772 " del df\n",
2773 " del suptitle\n",
2774 " gc.collect()"
2775 ]
2776 },
2777 {
2778 "cell_type": "code",
2779 "execution_count": 13,
2780 "metadata": {
2781 "ExecuteTime": {
2782 "end_time": "2018-06-29T12:24:22.887029Z",
2783 "start_time": "2018-06-29T12:24:11.457143Z"
2784 }
2785 },
2786 "outputs": [],
2787 "source": [
2788 "%%capture\n",
2789 "!cd /home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/ && ffmpeg -y -framerate 15 -i plot_%d.png minus30_to_20_transition.mp4 && ffmpeg -y -i minus30_to_20_transition.mp4 -c:v libvpx-vp9 -b:v 2M -threads 8 minus30_to_20_transition.webm"
2790 ]
2791 },
2792 {
2793 "cell_type": "code",
2794 "execution_count": 14,
2795 "metadata": {
2796 "ExecuteTime": {
2797 "end_time": "2018-06-29T12:25:16.067271Z",
2798 "start_time": "2018-06-29T12:25:16.062111Z"
2799 }
2800 },
2801 "outputs": [
2802 {
2803 "data": {
2804 "text/html": [
2805 "<video width=\"90%\" style=\"display:block; margin: 0 auto;\" controls src=\"https://hephaistos.lpp.polytechnique.fr/data/LFR/PPBI_06_2018/minus30_to_20_transition.webm\" type=\"video/webm\">"
2806 ],
2807 "text/plain": [
2808 "<IPython.core.display.HTML object>"
2809 ]
2810 },
2811 "metadata": {},
2812 "output_type": "display_data"
2813 }
2814 ],
2815 "source": [
2816 "%%HTML\n",
2817 "<video width=\"90%\" style=\"display:block; margin: 0 auto;\" controls src=\"https://hephaistos.lpp.polytechnique.fr/data/LFR/PPBI_06_2018/minus30_to_20_transition.webm\" type=\"video/webm\">"
2818 ]
2819 },
2820 {
2821 "cell_type": "code",
2822 "execution_count": 42,
2823 "metadata": {
2824 "ExecuteTime": {
2825 "end_time": "2018-07-04T13:38:34.304348Z",
2826 "start_time": "2018-07-04T13:38:34.172511Z"
2827 }
2828 },
2829 "outputs": [
2830 {
2831 "data": {
2832 "application/javascript": [
2833 "/* Put everything inside the global mpl namespace */\n",
2834 "window.mpl = {};\n",
2835 "\n",
2836 "\n",
2837 "mpl.get_websocket_type = function() {\n",
2838 " if (typeof(WebSocket) !== 'undefined') {\n",
2839 " return WebSocket;\n",
2840 " } else if (typeof(MozWebSocket) !== 'undefined') {\n",
2841 " return MozWebSocket;\n",
2842 " } else {\n",
2843 " alert('Your browser does not have WebSocket support.' +\n",
2844 " 'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
2845 " 'Firefox 4 and 5 are also supported but you ' +\n",
2846 " 'have to enable WebSockets in about:config.');\n",
2847 " };\n",
2848 "}\n",
2849 "\n",
2850 "mpl.figure = function(figure_id, websocket, ondownload, parent_element) {\n",
2851 " this.id = figure_id;\n",
2852 "\n",
2853 " this.ws = websocket;\n",
2854 "\n",
2855 " this.supports_binary = (this.ws.binaryType != undefined);\n",
2856 "\n",
2857 " if (!this.supports_binary) {\n",
2858 " var warnings = document.getElementById(\"mpl-warnings\");\n",
2859 " if (warnings) {\n",
2860 " warnings.style.display = 'block';\n",
2861 " warnings.textContent = (\n",
2862 " \"This browser does not support binary websocket messages. \" +\n",
2863 " \"Performance may be slow.\");\n",
2864 " }\n",
2865 " }\n",
2866 "\n",
2867 " this.imageObj = new Image();\n",
2868 "\n",
2869 " this.context = undefined;\n",
2870 " this.message = undefined;\n",
2871 " this.canvas = undefined;\n",
2872 " this.rubberband_canvas = undefined;\n",
2873 " this.rubberband_context = undefined;\n",
2874 " this.format_dropdown = undefined;\n",
2875 "\n",
2876 " this.image_mode = 'full';\n",
2877 "\n",
2878 " this.root = $('<div/>');\n",
2879 " this._root_extra_style(this.root)\n",
2880 " this.root.attr('style', 'display: inline-block');\n",
2881 "\n",
2882 " $(parent_element).append(this.root);\n",
2883 "\n",
2884 " this._init_header(this);\n",
2885 " this._init_canvas(this);\n",
2886 " this._init_toolbar(this);\n",
2887 "\n",
2888 " var fig = this;\n",
2889 "\n",
2890 " this.waiting = false;\n",
2891 "\n",
2892 " this.ws.onopen = function () {\n",
2893 " fig.send_message(\"supports_binary\", {value: fig.supports_binary});\n",
2894 " fig.send_message(\"send_image_mode\", {});\n",
2895 " if (mpl.ratio != 1) {\n",
2896 " fig.send_message(\"set_dpi_ratio\", {'dpi_ratio': mpl.ratio});\n",
2897 " }\n",
2898 " fig.send_message(\"refresh\", {});\n",
2899 " }\n",
2900 "\n",
2901 " this.imageObj.onload = function() {\n",
2902 " if (fig.image_mode == 'full') {\n",
2903 " // Full images could contain transparency (where diff images\n",
2904 " // almost always do), so we need to clear the canvas so that\n",
2905 " // there is no ghosting.\n",
2906 " fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
2907 " }\n",
2908 " fig.context.drawImage(fig.imageObj, 0, 0);\n",
2909 " };\n",
2910 "\n",
2911 " this.imageObj.onunload = function() {\n",
2912 " fig.ws.close();\n",
2913 " }\n",
2914 "\n",
2915 " this.ws.onmessage = this._make_on_message_function(this);\n",
2916 "\n",
2917 " this.ondownload = ondownload;\n",
2918 "}\n",
2919 "\n",
2920 "mpl.figure.prototype._init_header = function() {\n",
2921 " var titlebar = $(\n",
2922 " '<div class=\"ui-dialog-titlebar ui-widget-header ui-corner-all ' +\n",
2923 " 'ui-helper-clearfix\"/>');\n",
2924 " var titletext = $(\n",
2925 " '<div class=\"ui-dialog-title\" style=\"width: 100%; ' +\n",
2926 " 'text-align: center; padding: 3px;\"/>');\n",
2927 " titlebar.append(titletext)\n",
2928 " this.root.append(titlebar);\n",
2929 " this.header = titletext[0];\n",
2930 "}\n",
2931 "\n",
2932 "\n",
2933 "\n",
2934 "mpl.figure.prototype._canvas_extra_style = function(canvas_div) {\n",
2935 "\n",
2936 "}\n",
2937 "\n",
2938 "\n",
2939 "mpl.figure.prototype._root_extra_style = function(canvas_div) {\n",
2940 "\n",
2941 "}\n",
2942 "\n",
2943 "mpl.figure.prototype._init_canvas = function() {\n",
2944 " var fig = this;\n",
2945 "\n",
2946 " var canvas_div = $('<div/>');\n",
2947 "\n",
2948 " canvas_div.attr('style', 'position: relative; clear: both; outline: 0');\n",
2949 "\n",
2950 " function canvas_keyboard_event(event) {\n",
2951 " return fig.key_event(event, event['data']);\n",
2952 " }\n",
2953 "\n",
2954 " canvas_div.keydown('key_press', canvas_keyboard_event);\n",
2955 " canvas_div.keyup('key_release', canvas_keyboard_event);\n",
2956 " this.canvas_div = canvas_div\n",
2957 " this._canvas_extra_style(canvas_div)\n",
2958 " this.root.append(canvas_div);\n",
2959 "\n",
2960 " var canvas = $('<canvas/>');\n",
2961 " canvas.addClass('mpl-canvas');\n",
2962 " canvas.attr('style', \"left: 0; top: 0; z-index: 0; outline: 0\")\n",
2963 "\n",
2964 " this.canvas = canvas[0];\n",
2965 " this.context = canvas[0].getContext(\"2d\");\n",
2966 "\n",
2967 " var backingStore = this.context.backingStorePixelRatio ||\n",
2968 "\tthis.context.webkitBackingStorePixelRatio ||\n",
2969 "\tthis.context.mozBackingStorePixelRatio ||\n",
2970 "\tthis.context.msBackingStorePixelRatio ||\n",
2971 "\tthis.context.oBackingStorePixelRatio ||\n",
2972 "\tthis.context.backingStorePixelRatio || 1;\n",
2973 "\n",
2974 " mpl.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
2975 "\n",
2976 " var rubberband = $('<canvas/>');\n",
2977 " rubberband.attr('style', \"position: absolute; left: 0; top: 0; z-index: 1;\")\n",
2978 "\n",
2979 " var pass_mouse_events = true;\n",
2980 "\n",
2981 " canvas_div.resizable({\n",
2982 " start: function(event, ui) {\n",
2983 " pass_mouse_events = false;\n",
2984 " },\n",
2985 " resize: function(event, ui) {\n",
2986 " fig.request_resize(ui.size.width, ui.size.height);\n",
2987 " },\n",
2988 " stop: function(event, ui) {\n",
2989 " pass_mouse_events = true;\n",
2990 " fig.request_resize(ui.size.width, ui.size.height);\n",
2991 " },\n",
2992 " });\n",
2993 "\n",
2994 " function mouse_event_fn(event) {\n",
2995 " if (pass_mouse_events)\n",
2996 " return fig.mouse_event(event, event['data']);\n",
2997 " }\n",
2998 "\n",
2999 " rubberband.mousedown('button_press', mouse_event_fn);\n",
3000 " rubberband.mouseup('button_release', mouse_event_fn);\n",
3001 " // Throttle sequential mouse events to 1 every 20ms.\n",
3002 " rubberband.mousemove('motion_notify', mouse_event_fn);\n",
3003 "\n",
3004 " rubberband.mouseenter('figure_enter', mouse_event_fn);\n",
3005 " rubberband.mouseleave('figure_leave', mouse_event_fn);\n",
3006 "\n",
3007 " canvas_div.on(\"wheel\", function (event) {\n",
3008 " event = event.originalEvent;\n",
3009 " event['data'] = 'scroll'\n",
3010 " if (event.deltaY < 0) {\n",
3011 " event.step = 1;\n",
3012 " } else {\n",
3013 " event.step = -1;\n",
3014 " }\n",
3015 " mouse_event_fn(event);\n",
3016 " });\n",
3017 "\n",
3018 " canvas_div.append(canvas);\n",
3019 " canvas_div.append(rubberband);\n",
3020 "\n",
3021 " this.rubberband = rubberband;\n",
3022 " this.rubberband_canvas = rubberband[0];\n",
3023 " this.rubberband_context = rubberband[0].getContext(\"2d\");\n",
3024 " this.rubberband_context.strokeStyle = \"#000000\";\n",
3025 "\n",
3026 " this._resize_canvas = function(width, height) {\n",
3027 " // Keep the size of the canvas, canvas container, and rubber band\n",
3028 " // canvas in synch.\n",
3029 " canvas_div.css('width', width)\n",
3030 " canvas_div.css('height', height)\n",
3031 "\n",
3032 " canvas.attr('width', width * mpl.ratio);\n",
3033 " canvas.attr('height', height * mpl.ratio);\n",
3034 " canvas.attr('style', 'width: ' + width + 'px; height: ' + height + 'px;');\n",
3035 "\n",
3036 " rubberband.attr('width', width);\n",
3037 " rubberband.attr('height', height);\n",
3038 " }\n",
3039 "\n",
3040 " // Set the figure to an initial 600x600px, this will subsequently be updated\n",
3041 " // upon first draw.\n",
3042 " this._resize_canvas(600, 600);\n",
3043 "\n",
3044 " // Disable right mouse context menu.\n",
3045 " $(this.rubberband_canvas).bind(\"contextmenu\",function(e){\n",
3046 " return false;\n",
3047 " });\n",
3048 "\n",
3049 " function set_focus () {\n",
3050 " canvas.focus();\n",
3051 " canvas_div.focus();\n",
3052 " }\n",
3053 "\n",
3054 " window.setTimeout(set_focus, 100);\n",
3055 "}\n",
3056 "\n",
3057 "mpl.figure.prototype._init_toolbar = function() {\n",
3058 " var fig = this;\n",
3059 "\n",
3060 " var nav_element = $('<div/>')\n",
3061 " nav_element.attr('style', 'width: 100%');\n",
3062 " this.root.append(nav_element);\n",
3063 "\n",
3064 " // Define a callback function for later on.\n",
3065 " function toolbar_event(event) {\n",
3066 " return fig.toolbar_button_onclick(event['data']);\n",
3067 " }\n",
3068 " function toolbar_mouse_event(event) {\n",
3069 " return fig.toolbar_button_onmouseover(event['data']);\n",
3070 " }\n",
3071 "\n",
3072 " for(var toolbar_ind in mpl.toolbar_items) {\n",
3073 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
3074 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
3075 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
3076 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
3077 "\n",
3078 " if (!name) {\n",
3079 " // put a spacer in here.\n",
3080 " continue;\n",
3081 " }\n",
3082 " var button = $('<button/>');\n",
3083 " button.addClass('ui-button ui-widget ui-state-default ui-corner-all ' +\n",
3084 " 'ui-button-icon-only');\n",
3085 " button.attr('role', 'button');\n",
3086 " button.attr('aria-disabled', 'false');\n",
3087 " button.click(method_name, toolbar_event);\n",
3088 " button.mouseover(tooltip, toolbar_mouse_event);\n",
3089 "\n",
3090 " var icon_img = $('<span/>');\n",
3091 " icon_img.addClass('ui-button-icon-primary ui-icon');\n",
3092 " icon_img.addClass(image);\n",
3093 " icon_img.addClass('ui-corner-all');\n",
3094 "\n",
3095 " var tooltip_span = $('<span/>');\n",
3096 " tooltip_span.addClass('ui-button-text');\n",
3097 " tooltip_span.html(tooltip);\n",
3098 "\n",
3099 " button.append(icon_img);\n",
3100 " button.append(tooltip_span);\n",
3101 "\n",
3102 " nav_element.append(button);\n",
3103 " }\n",
3104 "\n",
3105 " var fmt_picker_span = $('<span/>');\n",
3106 "\n",
3107 " var fmt_picker = $('<select/>');\n",
3108 " fmt_picker.addClass('mpl-toolbar-option ui-widget ui-widget-content');\n",
3109 " fmt_picker_span.append(fmt_picker);\n",
3110 " nav_element.append(fmt_picker_span);\n",
3111 " this.format_dropdown = fmt_picker[0];\n",
3112 "\n",
3113 " for (var ind in mpl.extensions) {\n",
3114 " var fmt = mpl.extensions[ind];\n",
3115 " var option = $(\n",
3116 " '<option/>', {selected: fmt === mpl.default_extension}).html(fmt);\n",
3117 " fmt_picker.append(option)\n",
3118 " }\n",
3119 "\n",
3120 " // Add hover states to the ui-buttons\n",
3121 " $( \".ui-button\" ).hover(\n",
3122 " function() { $(this).addClass(\"ui-state-hover\");},\n",
3123 " function() { $(this).removeClass(\"ui-state-hover\");}\n",
3124 " );\n",
3125 "\n",
3126 " var status_bar = $('<span class=\"mpl-message\"/>');\n",
3127 " nav_element.append(status_bar);\n",
3128 " this.message = status_bar[0];\n",
3129 "}\n",
3130 "\n",
3131 "mpl.figure.prototype.request_resize = function(x_pixels, y_pixels) {\n",
3132 " // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
3133 " // which will in turn request a refresh of the image.\n",
3134 " this.send_message('resize', {'width': x_pixels, 'height': y_pixels});\n",
3135 "}\n",
3136 "\n",
3137 "mpl.figure.prototype.send_message = function(type, properties) {\n",
3138 " properties['type'] = type;\n",
3139 " properties['figure_id'] = this.id;\n",
3140 " this.ws.send(JSON.stringify(properties));\n",
3141 "}\n",
3142 "\n",
3143 "mpl.figure.prototype.send_draw_message = function() {\n",
3144 " if (!this.waiting) {\n",
3145 " this.waiting = true;\n",
3146 " this.ws.send(JSON.stringify({type: \"draw\", figure_id: this.id}));\n",
3147 " }\n",
3148 "}\n",
3149 "\n",
3150 "\n",
3151 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
3152 " var format_dropdown = fig.format_dropdown;\n",
3153 " var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
3154 " fig.ondownload(fig, format);\n",
3155 "}\n",
3156 "\n",
3157 "\n",
3158 "mpl.figure.prototype.handle_resize = function(fig, msg) {\n",
3159 " var size = msg['size'];\n",
3160 " if (size[0] != fig.canvas.width || size[1] != fig.canvas.height) {\n",
3161 " fig._resize_canvas(size[0], size[1]);\n",
3162 " fig.send_message(\"refresh\", {});\n",
3163 " };\n",
3164 "}\n",
3165 "\n",
3166 "mpl.figure.prototype.handle_rubberband = function(fig, msg) {\n",
3167 " var x0 = msg['x0'] / mpl.ratio;\n",
3168 " var y0 = (fig.canvas.height - msg['y0']) / mpl.ratio;\n",
3169 " var x1 = msg['x1'] / mpl.ratio;\n",
3170 " var y1 = (fig.canvas.height - msg['y1']) / mpl.ratio;\n",
3171 " x0 = Math.floor(x0) + 0.5;\n",
3172 " y0 = Math.floor(y0) + 0.5;\n",
3173 " x1 = Math.floor(x1) + 0.5;\n",
3174 " y1 = Math.floor(y1) + 0.5;\n",
3175 " var min_x = Math.min(x0, x1);\n",
3176 " var min_y = Math.min(y0, y1);\n",
3177 " var width = Math.abs(x1 - x0);\n",
3178 " var height = Math.abs(y1 - y0);\n",
3179 "\n",
3180 " fig.rubberband_context.clearRect(\n",
3181 " 0, 0, fig.canvas.width, fig.canvas.height);\n",
3182 "\n",
3183 " fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
3184 "}\n",
3185 "\n",
3186 "mpl.figure.prototype.handle_figure_label = function(fig, msg) {\n",
3187 " // Updates the figure title.\n",
3188 " fig.header.textContent = msg['label'];\n",
3189 "}\n",
3190 "\n",
3191 "mpl.figure.prototype.handle_cursor = function(fig, msg) {\n",
3192 " var cursor = msg['cursor'];\n",
3193 " switch(cursor)\n",
3194 " {\n",
3195 " case 0:\n",
3196 " cursor = 'pointer';\n",
3197 " break;\n",
3198 " case 1:\n",
3199 " cursor = 'default';\n",
3200 " break;\n",
3201 " case 2:\n",
3202 " cursor = 'crosshair';\n",
3203 " break;\n",
3204 " case 3:\n",
3205 " cursor = 'move';\n",
3206 " break;\n",
3207 " }\n",
3208 " fig.rubberband_canvas.style.cursor = cursor;\n",
3209 "}\n",
3210 "\n",
3211 "mpl.figure.prototype.handle_message = function(fig, msg) {\n",
3212 " fig.message.textContent = msg['message'];\n",
3213 "}\n",
3214 "\n",
3215 "mpl.figure.prototype.handle_draw = function(fig, msg) {\n",
3216 " // Request the server to send over a new figure.\n",
3217 " fig.send_draw_message();\n",
3218 "}\n",
3219 "\n",
3220 "mpl.figure.prototype.handle_image_mode = function(fig, msg) {\n",
3221 " fig.image_mode = msg['mode'];\n",
3222 "}\n",
3223 "\n",
3224 "mpl.figure.prototype.updated_canvas_event = function() {\n",
3225 " // Called whenever the canvas gets updated.\n",
3226 " this.send_message(\"ack\", {});\n",
3227 "}\n",
3228 "\n",
3229 "// A function to construct a web socket function for onmessage handling.\n",
3230 "// Called in the figure constructor.\n",
3231 "mpl.figure.prototype._make_on_message_function = function(fig) {\n",
3232 " return function socket_on_message(evt) {\n",
3233 " if (evt.data instanceof Blob) {\n",
3234 " /* FIXME: We get \"Resource interpreted as Image but\n",
3235 " * transferred with MIME type text/plain:\" errors on\n",
3236 " * Chrome. But how to set the MIME type? It doesn't seem\n",
3237 " * to be part of the websocket stream */\n",
3238 " evt.data.type = \"image/png\";\n",
3239 "\n",
3240 " /* Free the memory for the previous frames */\n",
3241 " if (fig.imageObj.src) {\n",
3242 " (window.URL || window.webkitURL).revokeObjectURL(\n",
3243 " fig.imageObj.src);\n",
3244 " }\n",
3245 "\n",
3246 " fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
3247 " evt.data);\n",
3248 " fig.updated_canvas_event();\n",
3249 " fig.waiting = false;\n",
3250 " return;\n",
3251 " }\n",
3252 " else if (typeof evt.data === 'string' && evt.data.slice(0, 21) == \"data:image/png;base64\") {\n",
3253 " fig.imageObj.src = evt.data;\n",
3254 " fig.updated_canvas_event();\n",
3255 " fig.waiting = false;\n",
3256 " return;\n",
3257 " }\n",
3258 "\n",
3259 " var msg = JSON.parse(evt.data);\n",
3260 " var msg_type = msg['type'];\n",
3261 "\n",
3262 " // Call the \"handle_{type}\" callback, which takes\n",
3263 " // the figure and JSON message as its only arguments.\n",
3264 " try {\n",
3265 " var callback = fig[\"handle_\" + msg_type];\n",
3266 " } catch (e) {\n",
3267 " console.log(\"No handler for the '\" + msg_type + \"' message type: \", msg);\n",
3268 " return;\n",
3269 " }\n",
3270 "\n",
3271 " if (callback) {\n",
3272 " try {\n",
3273 " // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
3274 " callback(fig, msg);\n",
3275 " } catch (e) {\n",
3276 " console.log(\"Exception inside the 'handler_\" + msg_type + \"' callback:\", e, e.stack, msg);\n",
3277 " }\n",
3278 " }\n",
3279 " };\n",
3280 "}\n",
3281 "\n",
3282 "// from http://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
3283 "mpl.findpos = function(e) {\n",
3284 " //this section is from http://www.quirksmode.org/js/events_properties.html\n",
3285 " var targ;\n",
3286 " if (!e)\n",
3287 " e = window.event;\n",
3288 " if (e.target)\n",
3289 " targ = e.target;\n",
3290 " else if (e.srcElement)\n",
3291 " targ = e.srcElement;\n",
3292 " if (targ.nodeType == 3) // defeat Safari bug\n",
3293 " targ = targ.parentNode;\n",
3294 "\n",
3295 " // jQuery normalizes the pageX and pageY\n",
3296 " // pageX,Y are the mouse positions relative to the document\n",
3297 " // offset() returns the position of the element relative to the document\n",
3298 " var x = e.pageX - $(targ).offset().left;\n",
3299 " var y = e.pageY - $(targ).offset().top;\n",
3300 "\n",
3301 " return {\"x\": x, \"y\": y};\n",
3302 "};\n",
3303 "\n",
3304 "/*\n",
3305 " * return a copy of an object with only non-object keys\n",
3306 " * we need this to avoid circular references\n",
3307 " * http://stackoverflow.com/a/24161582/3208463\n",
3308 " */\n",
3309 "function simpleKeys (original) {\n",
3310 " return Object.keys(original).reduce(function (obj, key) {\n",
3311 " if (typeof original[key] !== 'object')\n",
3312 " obj[key] = original[key]\n",
3313 " return obj;\n",
3314 " }, {});\n",
3315 "}\n",
3316 "\n",
3317 "mpl.figure.prototype.mouse_event = function(event, name) {\n",
3318 " var canvas_pos = mpl.findpos(event)\n",
3319 "\n",
3320 " if (name === 'button_press')\n",
3321 " {\n",
3322 " this.canvas.focus();\n",
3323 " this.canvas_div.focus();\n",
3324 " }\n",
3325 "\n",
3326 " var x = canvas_pos.x * mpl.ratio;\n",
3327 " var y = canvas_pos.y * mpl.ratio;\n",
3328 "\n",
3329 " this.send_message(name, {x: x, y: y, button: event.button,\n",
3330 " step: event.step,\n",
3331 " guiEvent: simpleKeys(event)});\n",
3332 "\n",
3333 " /* This prevents the web browser from automatically changing to\n",
3334 " * the text insertion cursor when the button is pressed. We want\n",
3335 " * to control all of the cursor setting manually through the\n",
3336 " * 'cursor' event from matplotlib */\n",
3337 " event.preventDefault();\n",
3338 " return false;\n",
3339 "}\n",
3340 "\n",
3341 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
3342 " // Handle any extra behaviour associated with a key event\n",
3343 "}\n",
3344 "\n",
3345 "mpl.figure.prototype.key_event = function(event, name) {\n",
3346 "\n",
3347 " // Prevent repeat events\n",
3348 " if (name == 'key_press')\n",
3349 " {\n",
3350 " if (event.which === this._key)\n",
3351 " return;\n",
3352 " else\n",
3353 " this._key = event.which;\n",
3354 " }\n",
3355 " if (name == 'key_release')\n",
3356 " this._key = null;\n",
3357 "\n",
3358 " var value = '';\n",
3359 " if (event.ctrlKey && event.which != 17)\n",
3360 " value += \"ctrl+\";\n",
3361 " if (event.altKey && event.which != 18)\n",
3362 " value += \"alt+\";\n",
3363 " if (event.shiftKey && event.which != 16)\n",
3364 " value += \"shift+\";\n",
3365 "\n",
3366 " value += 'k';\n",
3367 " value += event.which.toString();\n",
3368 "\n",
3369 " this._key_event_extra(event, name);\n",
3370 "\n",
3371 " this.send_message(name, {key: value,\n",
3372 " guiEvent: simpleKeys(event)});\n",
3373 " return false;\n",
3374 "}\n",
3375 "\n",
3376 "mpl.figure.prototype.toolbar_button_onclick = function(name) {\n",
3377 " if (name == 'download') {\n",
3378 " this.handle_save(this, null);\n",
3379 " } else {\n",
3380 " this.send_message(\"toolbar_button\", {name: name});\n",
3381 " }\n",
3382 "};\n",
3383 "\n",
3384 "mpl.figure.prototype.toolbar_button_onmouseover = function(tooltip) {\n",
3385 " this.message.textContent = tooltip;\n",
3386 "};\n",
3387 "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",
3388 "\n",
3389 "mpl.extensions = [\"eps\", \"jpeg\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
3390 "\n",
3391 "mpl.default_extension = \"png\";var comm_websocket_adapter = function(comm) {\n",
3392 " // Create a \"websocket\"-like object which calls the given IPython comm\n",
3393 " // object with the appropriate methods. Currently this is a non binary\n",
3394 " // socket, so there is still some room for performance tuning.\n",
3395 " var ws = {};\n",
3396 "\n",
3397 " ws.close = function() {\n",
3398 " comm.close()\n",
3399 " };\n",
3400 " ws.send = function(m) {\n",
3401 " //console.log('sending', m);\n",
3402 " comm.send(m);\n",
3403 " };\n",
3404 " // Register the callback with on_msg.\n",
3405 " comm.on_msg(function(msg) {\n",
3406 " //console.log('receiving', msg['content']['data'], msg);\n",
3407 " // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
3408 " ws.onmessage(msg['content']['data'])\n",
3409 " });\n",
3410 " return ws;\n",
3411 "}\n",
3412 "\n",
3413 "mpl.mpl_figure_comm = function(comm, msg) {\n",
3414 " // This is the function which gets called when the mpl process\n",
3415 " // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
3416 "\n",
3417 " var id = msg.content.data.id;\n",
3418 " // Get hold of the div created by the display call when the Comm\n",
3419 " // socket was opened in Python.\n",
3420 " var element = $(\"#\" + id);\n",
3421 " var ws_proxy = comm_websocket_adapter(comm)\n",
3422 "\n",
3423 " function ondownload(figure, format) {\n",
3424 " window.open(figure.imageObj.src);\n",
3425 " }\n",
3426 "\n",
3427 " var fig = new mpl.figure(id, ws_proxy,\n",
3428 " ondownload,\n",
3429 " element.get(0));\n",
3430 "\n",
3431 " // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
3432 " // web socket which is closed, not our websocket->open comm proxy.\n",
3433 " ws_proxy.onopen();\n",
3434 "\n",
3435 " fig.parent_element = element.get(0);\n",
3436 " fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
3437 " if (!fig.cell_info) {\n",
3438 " console.error(\"Failed to find cell for figure\", id, fig);\n",
3439 " return;\n",
3440 " }\n",
3441 "\n",
3442 " var output_index = fig.cell_info[2]\n",
3443 " var cell = fig.cell_info[0];\n",
3444 "\n",
3445 "};\n",
3446 "\n",
3447 "mpl.figure.prototype.handle_close = function(fig, msg) {\n",
3448 " var width = fig.canvas.width/mpl.ratio\n",
3449 " fig.root.unbind('remove')\n",
3450 "\n",
3451 " // Update the output cell to use the data from the current canvas.\n",
3452 " fig.push_to_output();\n",
3453 " var dataURL = fig.canvas.toDataURL();\n",
3454 " // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
3455 " // the notebook keyboard shortcuts fail.\n",
3456 " IPython.keyboard_manager.enable()\n",
3457 " $(fig.parent_element).html('<img src=\"' + dataURL + '\" width=\"' + width + '\">');\n",
3458 " fig.close_ws(fig, msg);\n",
3459 "}\n",
3460 "\n",
3461 "mpl.figure.prototype.close_ws = function(fig, msg){\n",
3462 " fig.send_message('closing', msg);\n",
3463 " // fig.ws.close()\n",
3464 "}\n",
3465 "\n",
3466 "mpl.figure.prototype.push_to_output = function(remove_interactive) {\n",
3467 " // Turn the data on the canvas into data in the output cell.\n",
3468 " var width = this.canvas.width/mpl.ratio\n",
3469 " var dataURL = this.canvas.toDataURL();\n",
3470 " this.cell_info[1]['text/html'] = '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
3471 "}\n",
3472 "\n",
3473 "mpl.figure.prototype.updated_canvas_event = function() {\n",
3474 " // Tell IPython that the notebook contents must change.\n",
3475 " IPython.notebook.set_dirty(true);\n",
3476 " this.send_message(\"ack\", {});\n",
3477 " var fig = this;\n",
3478 " // Wait a second, then push the new image to the DOM so\n",
3479 " // that it is saved nicely (might be nice to debounce this).\n",
3480 " setTimeout(function () { fig.push_to_output() }, 1000);\n",
3481 "}\n",
3482 "\n",
3483 "mpl.figure.prototype._init_toolbar = function() {\n",
3484 " var fig = this;\n",
3485 "\n",
3486 " var nav_element = $('<div/>')\n",
3487 " nav_element.attr('style', 'width: 100%');\n",
3488 " this.root.append(nav_element);\n",
3489 "\n",
3490 " // Define a callback function for later on.\n",
3491 " function toolbar_event(event) {\n",
3492 " return fig.toolbar_button_onclick(event['data']);\n",
3493 " }\n",
3494 " function toolbar_mouse_event(event) {\n",
3495 " return fig.toolbar_button_onmouseover(event['data']);\n",
3496 " }\n",
3497 "\n",
3498 " for(var toolbar_ind in mpl.toolbar_items){\n",
3499 " var name = mpl.toolbar_items[toolbar_ind][0];\n",
3500 " var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
3501 " var image = mpl.toolbar_items[toolbar_ind][2];\n",
3502 " var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
3503 "\n",
3504 " if (!name) { continue; };\n",
3505 "\n",
3506 " var button = $('<button class=\"btn btn-default\" href=\"#\" title=\"' + name + '\"><i class=\"fa ' + image + ' fa-lg\"></i></button>');\n",
3507 " button.click(method_name, toolbar_event);\n",
3508 " button.mouseover(tooltip, toolbar_mouse_event);\n",
3509 " nav_element.append(button);\n",
3510 " }\n",
3511 "\n",
3512 " // Add the status bar.\n",
3513 " var status_bar = $('<span class=\"mpl-message\" style=\"text-align:right; float: right;\"/>');\n",
3514 " nav_element.append(status_bar);\n",
3515 " this.message = status_bar[0];\n",
3516 "\n",
3517 " // Add the close button to the window.\n",
3518 " var buttongrp = $('<div class=\"btn-group inline pull-right\"></div>');\n",
3519 " 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",
3520 " button.click(function (evt) { fig.handle_close(fig, {}); } );\n",
3521 " button.mouseover('Stop Interaction', toolbar_mouse_event);\n",
3522 " buttongrp.append(button);\n",
3523 " var titlebar = this.root.find($('.ui-dialog-titlebar'));\n",
3524 " titlebar.prepend(buttongrp);\n",
3525 "}\n",
3526 "\n",
3527 "mpl.figure.prototype._root_extra_style = function(el){\n",
3528 " var fig = this\n",
3529 " el.on(\"remove\", function(){\n",
3530 "\tfig.close_ws(fig, {});\n",
3531 " });\n",
3532 "}\n",
3533 "\n",
3534 "mpl.figure.prototype._canvas_extra_style = function(el){\n",
3535 " // this is important to make the div 'focusable\n",
3536 " el.attr('tabindex', 0)\n",
3537 " // reach out to IPython and tell the keyboard manager to turn it's self\n",
3538 " // off when our div gets focus\n",
3539 "\n",
3540 " // location in version 3\n",
3541 " if (IPython.notebook.keyboard_manager) {\n",
3542 " IPython.notebook.keyboard_manager.register_events(el);\n",
3543 " }\n",
3544 " else {\n",
3545 " // location in version 2\n",
3546 " IPython.keyboard_manager.register_events(el);\n",
3547 " }\n",
3548 "\n",
3549 "}\n",
3550 "\n",
3551 "mpl.figure.prototype._key_event_extra = function(event, name) {\n",
3552 " var manager = IPython.notebook.keyboard_manager;\n",
3553 " if (!manager)\n",
3554 " manager = IPython.keyboard_manager;\n",
3555 "\n",
3556 " // Check for shift+enter\n",
3557 " if (event.shiftKey && event.which == 13) {\n",
3558 " this.canvas_div.blur();\n",
3559 " event.shiftKey = false;\n",
3560 " // Send a \"J\" for go to next cell\n",
3561 " event.which = 74;\n",
3562 " event.keyCode = 74;\n",
3563 " manager.command_mode();\n",
3564 " manager.handle_keydown(event);\n",
3565 " }\n",
3566 "}\n",
3567 "\n",
3568 "mpl.figure.prototype.handle_save = function(fig, msg) {\n",
3569 " fig.ondownload(fig, null);\n",
3570 "}\n",
3571 "\n",
3572 "\n",
3573 "mpl.find_output_cell = function(html_output) {\n",
3574 " // Return the cell and output element which can be found *uniquely* in the notebook.\n",
3575 " // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
3576 " // IPython event is triggered only after the cells have been serialised, which for\n",
3577 " // our purposes (turning an active figure into a static one), is too late.\n",
3578 " var cells = IPython.notebook.get_cells();\n",
3579 " var ncells = cells.length;\n",
3580 " for (var i=0; i<ncells; i++) {\n",
3581 " var cell = cells[i];\n",
3582 " if (cell.cell_type === 'code'){\n",
3583 " for (var j=0; j<cell.output_area.outputs.length; j++) {\n",
3584 " var data = cell.output_area.outputs[j];\n",
3585 " if (data.data) {\n",
3586 " // IPython >= 3 moved mimebundle to data attribute of output\n",
3587 " data = data.data;\n",
3588 " }\n",
3589 " if (data['text/html'] == html_output) {\n",
3590 " return [cell, data, j];\n",
3591 " }\n",
3592 " }\n",
3593 " }\n",
3594 " }\n",
3595 "}\n",
3596 "\n",
3597 "// Register the function which deals with the matplotlib target/channel.\n",
3598 "// The kernel may be null if the page has been refreshed.\n",
3599 "if (IPython.notebook.kernel != null) {\n",
3600 " IPython.notebook.kernel.comm_manager.register_target('matplotlib', mpl.mpl_figure_comm);\n",
3601 "}\n"
3602 ],
3603 "text/plain": [
3604 "<IPython.core.display.Javascript object>"
3605 ]
3606 },
3607 "metadata": {},
3608 "output_type": "display_data"
1927 3609 },
1928 "scrolled": true
1929 },
1930 "outputs": [],
1931 "source": [
1932 "%%capture\n",
1933 "for i in range(0,res.SWFCount()):\n",
1934 " f, axes = plt.subplots(nrows=2, ncols=3,figsize=(24,10))\n",
1935 " df=res.SWF(0,i)\n",
1936 " for ax,col in zip(axes.flatten(),df.columns):\n",
1937 " ax.plot(np.arange(2048),df[col])\n",
1938 " ax.set_ylim(-30000,30000)\n",
1939 " patches, labels = ax.get_legend_handles_labels()\n",
1940 " ax.legend(patches, labels, loc='upper left')\n",
1941 " T = get_temperature_at(temperatures,times[\"SWF0\"][i][\"Time\"]-datetime.timedelta(minutes=4,seconds=10))\n",
1942 " T_HK = get_temperature_at(HK_TEMP_df,times[\"SWF0\"][i][\"Time\"])\n",
1943 " suptitle=plt.suptitle(\"Air={T_Air:3.1f}°C PCB(HK)={T_PCB:3.1f}°C socket={T_socket:3.1f}°C\".format(T_Air=T[\"air\"],T_PCB=T_HK,T_socket=T[\"socket\"]),y=1.05, fontsize=24)\n",
1944 " plt.tight_layout()\n",
1945 " plt.savefig(\"/home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/\"+\"/plot_{i}.png\".format(i=i),bbox_inches='tight',bbox_extra_artists=[suptitle])\n",
1946 " plt.close()\n",
1947 " del axes\n",
1948 " del f\n",
1949 " del df\n",
1950 " del suptitle\n",
1951 " gc.collect()"
1952 ]
1953 },
1954 {
1955 "cell_type": "code",
1956 "execution_count": 13,
1957 "metadata": {
1958 "ExecuteTime": {
1959 "end_time": "2018-06-29T12:24:22.887029Z",
1960 "start_time": "2018-06-29T12:24:11.457143Z"
1961 }
1962 },
1963 "outputs": [],
1964 "source": [
1965 "%%capture\n",
1966 "!cd /home/jeandet/Documents/SOLO_LFR_Notebooks/PPBI_06_2018/temp/ && ffmpeg -y -framerate 15 -i plot_%d.png minus30_to_20_transition.mp4 && ffmpeg -y -i minus30_to_20_transition.mp4 -c:v libvpx-vp9 -b:v 2M -threads 8 minus30_to_20_transition.webm"
1967 ]
1968 },
1969 {
1970 "cell_type": "code",
1971 "execution_count": 14,
1972 "metadata": {
1973 "ExecuteTime": {
1974 "end_time": "2018-06-29T12:25:16.067271Z",
1975 "start_time": "2018-06-29T12:25:16.062111Z"
1976 }
1977 },
1978 "outputs": [
1979 3610 {
1980 3611 "data": {
1981 3612 "text/html": [
1982 "<video width=\"90%\" style=\"display:block; margin: 0 auto;\" controls src=\"https://hephaistos.lpp.polytechnique.fr/data/LFR/PPBI_06_2018/minus30_to_20_transition.webm\" type=\"video/webm\">"
3613 "<img src=\"\" width=\"900\">"
1983 3614 ],
1984 3615 "text/plain": [
1985 3616 "<IPython.core.display.HTML object>"
@@ -1990,16 +3621,22
1990 3621 }
1991 3622 ],
1992 3623 "source": [
1993 "%%HTML\n",
1994 "<video width=\"90%\" style=\"display:block; margin: 0 auto;\" controls src=\"https://hephaistos.lpp.polytechnique.fr/data/LFR/PPBI_06_2018/minus30_to_20_transition.webm\" type=\"video/webm\">"
3624 "values = np.zeros(res.SWFCount())\n",
3625 "T = np.zeros(res.SWFCount())\n",
3626 "values2 = np.zeros(res.SWFCount())\n",
3627 "for i in range(0,res.SWFCount()):\n",
3628 " spec = TF.fft(res.SWF(0,i)[\"E1\"], TF.LFR_Fs0, np.hanning(2048))\n",
3629 " values[i] = spec[\"mod\"][200:].mean()\n",
3630 " T[i] = get_temperature_at(HK_TEMP_df,times[\"SWF0\"][i][\"Time\"])\n",
3631 " \n",
3632 "plt.figure(figsize=(9,6))\n",
3633 "plt.suptitle(\"Average noise Vs Temperature\")\n",
3634 "plt.xlabel(\"PCB Temperature(°C)\")\n",
3635 "plt.ylabel(\"Average noise\")\n",
3636 "plt.plot(T,values)\n",
3637 "plt.semilogy()\n",
3638 "plt.show()"
1995 3639 ]
1996 },
1997 {
1998 "cell_type": "code",
1999 "execution_count": null,
2000 "metadata": {},
2001 "outputs": [],
2002 "source": []
2003 3640 }
2004 3641 ],
2005 3642 "metadata": {
@@ -2021,28 +3658,20
2021 3658 "version": "3.6.5"
2022 3659 },
2023 3660 "toc": {
2024 "colors": {
2025 "hover_highlight": "#DAA520",
2026 "navigate_num": "#000000",
2027 "navigate_text": "#333333",
2028 "running_highlight": "#FF0000",
2029 "selected_highlight": "#FFD700",
2030 "sidebar_border": "#EEEEEE",
2031 "wrapper_background": "#FFFFFF"
2032 },
2033 "moveMenuLeft": true,
3661 "base_numbering": 1,
2034 3662 "nav_menu": {
2035 3663 "height": "12px",
2036 3664 "width": "252px"
2037 3665 },
2038 "navigate_menu": true,
2039 3666 "number_sections": true,
2040 3667 "sideBar": true,
2041 "threshold": 4,
3668 "skip_h1_title": false,
3669 "title_cell": "Table of Contents",
3670 "title_sidebar": "Contents",
2042 3671 "toc_cell": false,
3672 "toc_position": {},
2043 3673 "toc_section_display": "block",
2044 "toc_window_display": false,
2045 "widenNotebook": false
3674 "toc_window_display": false
2046 3675 },
2047 3676 "varInspector": {
2048 3677 "cols": {
General Comments 0
You need to be logged in to leave comments. Login now